import { mount } from 'cypress/vue'; import { Quasar } from 'quasar'; import { i18n } from 'src/boot/i18n'; // *********************************************** // This example commands.js shows you how to // create various custom commands and overwrite // existing commands. // // For more comprehensive examples of custom // commands please read more here: // https://on.cypress.io/custom-commands // *********************************************** // // // -- This is a parent command -- // Cypress.Commands.add('login', (email, password) => { ... }) // // // -- This is a child command -- // Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... }) // // // -- This is a dual command -- // Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... }) // // // -- This will overwrite an existing command -- // Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... }) import { createTestingPinia } from '@pinia/testing'; const pinia = createTestingPinia({ createSpy: () => {}, stubActions: false }); Cypress.Commands.add('vnMount', (component, options = {}) => { const globalConfig = { global: { plugins: [Quasar, i18n, pinia], }, }; // options.global = options.global || {}; // options.global.stubs = options.global.stubs || {}; // options.global.stubs.transition = false; // options.global.components = options.global.components || {}; // options.global.plugins = options.global.plugins || []; // Use store passed in from options, or initialize a new one // const { /* store = getStore(), */ ...mountOptions } = options; // Add plugins here // options.global.plugins.push({ // install(app) { // app.use(i18n); // }, // }); console.info(globalConfig); return mount(component, { ...globalConfig, ...options }); });