56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
// ***********************************************************
|
|
// This example support/component.ts is processed and
|
|
// loaded automatically before your test files.
|
|
//
|
|
// This is a great place to put global configuration and
|
|
// behavior that modifies Cypress.
|
|
//
|
|
// You can change the location of this file or turn off
|
|
// automatically serving support files with the
|
|
// 'supportFile' configuration option.
|
|
//
|
|
// You can read more here:
|
|
// https://on.cypress.io/configuration
|
|
// ***********************************************************
|
|
|
|
// Import commands.js using ES2015 syntax:
|
|
import "../../tailwind.css";
|
|
import "./commands";
|
|
|
|
// Alternatively you can use CommonJS syntax:
|
|
// require('./commands')
|
|
|
|
import { setupI18n } from "@/i18n.ts";
|
|
import router from "@/router";
|
|
import { mount } from "cypress/vue";
|
|
import { createPinia } from "pinia";
|
|
|
|
// Augment the Cypress namespace to include type definitions for
|
|
// your custom command.
|
|
// Alternatively, can be defined in cypress/support/component.d.ts
|
|
// with a <reference path="./component" /> at the top of your spec.
|
|
declare global {
|
|
// eslint-disable-next-line @typescript-eslint/no-namespace
|
|
namespace Cypress {
|
|
interface Chainable {
|
|
mount: typeof mount;
|
|
}
|
|
}
|
|
}
|
|
|
|
Cypress.Commands.add("mount", (component, options = {}) => {
|
|
options.global = options.global || {};
|
|
options.global.plugins = options.global.plugins || [];
|
|
options.global.plugins.push(setupI18n());
|
|
options.global.plugins.push(createPinia());
|
|
|
|
if (!options.router) {
|
|
options.router = router;
|
|
}
|
|
|
|
return mount(component, options);
|
|
});
|
|
|
|
// Example use:
|
|
// cy.mount(MyComponent)
|