Skip to content

Commit

Permalink
Merge pull request #83 from cloudblue/LITE-29964-migrate-to-use-vitest
Browse files Browse the repository at this point in the history
  • Loading branch information
arnaugiralt authored Apr 19, 2024
2 parents 89d8f13 + 33b0bac commit 4037bc6
Show file tree
Hide file tree
Showing 32 changed files with 5,178 additions and 6,693 deletions.
23 changes: 9 additions & 14 deletions .eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ module.exports = {
'plugin:storybook/recommended',
'prettier',
'@vue/eslint-config-prettier/skip-formatting',
'plugin:vitest-globals/recommended',
],

plugins: ['vue'],
Expand All @@ -34,21 +35,15 @@ module.exports = {
'vue/attribute-hyphenation': ['error', 'never'],
},

overrides: [
// Config for unit tests
{
files: ['*.spec.js'],
plugins: ['jest'],
extends: ['plugin:jest/recommended', 'plugin:jest-formatting/strict'],
env: {
jest: true,
'jest/globals': true,
},
globals: {
global: 'writable',
},
},
env: {
'vitest-globals': true,
},

parserOptions: {
ecmaVersion: 'latest',
},

overrides: [
// Config for files that run in node env (config files, etc)
{
files: ['*.config.js', '.eslintrc.js'],
Expand Down
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ dist-ssr
coverage
*.local

/test/report.json

/cypress/videos/
/cypress/screenshots/

Expand Down
46 changes: 0 additions & 46 deletions components/jest.config.js

This file was deleted.

6 changes: 3 additions & 3 deletions components/src/core/injector/core/Core.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ describe('Core', () => {
[{ test: 123 }, null],
[null, { test: 123 }],
])('should do nothing while $state is %j and data is %j', (state, data) => {
global.Object.keys = jest.fn(Object.keys);
global.Object.keys = vi.fn(Object.keys);
core.state = state;
core.assign(data);

Expand Down Expand Up @@ -53,7 +53,7 @@ describe('Core', () => {
};

core.watchers = {
test: [jest.fn()],
test: [vi.fn()],
};

core.assign({
Expand All @@ -71,7 +71,7 @@ describe('Core', () => {
};

core.watchers = {
'*': [jest.fn()],
'*': [vi.fn()],
};

core.assign({
Expand Down
24 changes: 12 additions & 12 deletions components/src/core/injector/core/injectorFactory.spec.js
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
import injectorFactory from './injectorFactory';
import { processRoute } from '~core/router';

jest.mock('~core/router', () => ({
processRoute: jest.fn().mockReturnValue('processRouteMockedReturnValue'),
vi.mock('~core/router', () => ({
processRoute: vi.fn().mockReturnValue('processRouteMockedReturnValue'),
}));

describe('injectorFactory', () => {
describe('#watch()', () => {
it('should add callback as new watcher for passed property', () => {
const core = { watchers: {}, state: { foo: 'bar' } };
const injector = injectorFactory(core);
const cb = jest.fn();
const cb = vi.fn();

injector.watch('foo', cb);
core.watchers.foo[0]();
Expand All @@ -21,7 +21,7 @@ describe('injectorFactory', () => {
it('should add immediate callback call', () => {
const core = { watchers: {}, state: { foo: 'bar' } };
const injector = injectorFactory(core);
const cb = jest.fn();
const cb = vi.fn();

injector.watch('foo', cb, { immediate: true });

Expand All @@ -31,7 +31,7 @@ describe('injectorFactory', () => {
it('should add immediate callback call with "*" key', () => {
const core = { watchers: {}, state: { foo: 'bar' } };
const injector = injectorFactory(core);
const cb = jest.fn();
const cb = vi.fn();

injector.watch('*', cb, { immediate: true });

Expand All @@ -45,7 +45,7 @@ describe('injectorFactory', () => {
};

const injector = injectorFactory(core);
const cb = jest.fn();
const cb = vi.fn();

injector.watch('foo', cb);
core.watchers.foo[1]();
Expand All @@ -60,7 +60,7 @@ describe('injectorFactory', () => {
};

const injector = injectorFactory(core);
const cb = jest.fn();
const cb = vi.fn();

injector.watch(cb);
core.watchers['*'][0]();
Expand All @@ -74,10 +74,10 @@ describe('injectorFactory', () => {
let commit;

beforeEach(() => {
global.window.top.postMessage = jest.fn();
global.window.top.postMessage = vi.fn();

core = {
assign: jest.fn(),
assign: vi.fn(),
id: 'XXX',
state: {
foo: 'bar',
Expand Down Expand Up @@ -124,7 +124,7 @@ describe('injectorFactory', () => {

describe('#emit()', () => {
beforeEach(() => {
global.window.top.postMessage = jest.fn();
global.window.top.postMessage = vi.fn();
});

it('should emit proper event', () => {
Expand Down Expand Up @@ -173,7 +173,7 @@ describe('injectorFactory', () => {
describe('#listen()', () => {
it('should put provided callback to proper listeners', () => {
const core = { listeners: {} };
const cb = jest.fn();
const cb = vi.fn();
injectorFactory(core).listen('foo', cb);
core.listeners.foo();

Expand All @@ -187,7 +187,7 @@ describe('injectorFactory', () => {

beforeEach(() => {
injector = injectorFactory({});
injectorEmitSpy = jest.spyOn(injector, 'emit');
injectorEmitSpy = vi.spyOn(injector, 'emit');
});

it('calls processRoute with the given arguments', () => {
Expand Down
20 changes: 9 additions & 11 deletions components/src/core/injector/core/launcher.spec.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import launch from './launcher';

const resizeObserverCtorSpy = jest.fn();
const resizeObserverObserveSpy = jest.fn();
const resizeObserverCtorSpy = vi.fn();
const resizeObserverObserveSpy = vi.fn();
const resizeObserverEntriesStub = [
{
contentRect: {
Expand Down Expand Up @@ -30,20 +30,18 @@ describe('$init', () => {
let init;

beforeEach(() => {
global.window.addEventListener = jest.fn();
global.window.addEventListener = vi.fn();
global.window.name = 'XXX';
global.crypto = {
getRandomValues: jest.fn(() => ['abc']),
};
global.crypto.getRandomValues = vi.fn(() => ['abc']);

injector = {
listen: jest.fn(),
emit: jest.fn(),
listen: vi.fn(),
emit: vi.fn(),
};

core = {
size: jest.fn(() => 'SIZE'),
assign: jest.fn(),
size: vi.fn(() => 'SIZE'),
assign: vi.fn(),
};

init = () => launch(injector, core);
Expand Down Expand Up @@ -163,7 +161,7 @@ describe('$init', () => {
},
};

core.listeners = { test: jest.fn() };
core.listeners = { test: vi.fn() };
handler({ data });

expect(core.listeners.test).toHaveBeenCalledWith('TEST', data);
Expand Down
12 changes: 6 additions & 6 deletions components/src/core/injector/index.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,19 +4,19 @@ import Core from './core/Core';
import injectorFactory from './core/injectorFactory';
import launcher from './core/launcher';

jest.mock('./core/Core', () => ({
vi.mock('./core/Core', () => ({
__esModule: true,
default: jest.fn().mockImplementation(() => ({ core: 'CORE' })),
default: vi.fn().mockImplementation(() => ({ core: 'CORE' })),
}));

jest.mock('./core/injectorFactory', () => ({
vi.mock('./core/injectorFactory', () => ({
__esModule: true,
default: jest.fn(() => 'INJECTOR'),
default: vi.fn(() => 'INJECTOR'),
}));

jest.mock('./core/launcher', () => ({
vi.mock('./core/launcher', () => ({
__esModule: true,
default: jest.fn(() => Promise.resolve()),
default: vi.fn(() => Promise.resolve()),
}));

describe('createInjector', () => {
Expand Down
8 changes: 4 additions & 4 deletions components/src/index.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,14 @@ import createApp from './index';
import injector from '~core/injector';
import registerWidget from '~core/registerWidget';

jest.mock('~core/injector', () => ({
vi.mock('~core/injector', () => ({
__esModule: true,
default: jest.fn(() => 'app'),
default: vi.fn(() => 'app'),
}));

jest.mock('~core/registerWidget', () => ({
vi.mock('~core/registerWidget', () => ({
__esModule: true,
default: jest.fn(),
default: vi.fn(),
}));

describe('#createApp function', () => {
Expand Down
2 changes: 1 addition & 1 deletion components/src/widgets/button/widget.spec.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { mount } from '@vue/test-utils';
import Button from './widget';
import Button from './widget.vue';

describe('Button widget', () => {
let result;
Expand Down
2 changes: 1 addition & 1 deletion components/src/widgets/complexTable/widget.spec.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { mount } from '@vue/test-utils';
import ComplexTable from './widget';
import ComplexTable from './widget.vue';
import { nextTick } from 'vue';

describe('ComplexTable widget', () => {
Expand Down
7 changes: 3 additions & 4 deletions components/src/widgets/icon/widget.spec.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import Icon from './widget';
import Icon from './widget.vue';
import { googleSnowboardingBaseline } from '@cloudblueconnect/material-svg';

describe('Icon', () => {
let result;
Expand All @@ -12,9 +13,7 @@ describe('Icon', () => {
);
result = component.icon.value;

expect(result).toEqual(
'<svg>This replaces import of files from @cloudblueconnect/material-svg in .spec.js files to optimize the run time of all unit tests</svg>',
);
expect(result).toEqual(googleSnowboardingBaseline);
});
});

Expand Down
10 changes: 5 additions & 5 deletions components/src/widgets/menu/widget.spec.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { mount } from '@vue/test-utils';
import Menu from './widget';
import Menu from './widget.vue';

describe('Menu component', () => {
describe('methods', () => {
Expand All @@ -23,7 +23,7 @@ describe('Menu component', () => {

describe('#handleClickOutside', () => {
it('closes menu when clicked outside menu bounds', async () => {
const event = { composedPath: jest.fn().mockReturnValue(['slot', 'button']) };
const event = { composedPath: vi.fn().mockReturnValue(['slot', 'button']) };
const wrapper = mount(Menu);
wrapper.vm.menu = 'div';
wrapper.vm.showMenu = true;
Expand All @@ -33,7 +33,7 @@ describe('Menu component', () => {
});

it('does not close menu when clicked inside menu bounds', async () => {
const event = { composedPath: jest.fn().mockReturnValue(['slot', 'button']) };
const event = { composedPath: vi.fn().mockReturnValue(['slot', 'button']) };
const wrapper = mount(Menu);
wrapper.vm.menu = 'button';
wrapper.vm.showMenu = true;
Expand Down Expand Up @@ -67,7 +67,7 @@ describe('Menu component', () => {

describe('onMounted', () => {
it('adds up event listener on component mount', () => {
const addEventListenerSpy = jest.spyOn(document, 'addEventListener');
const addEventListenerSpy = vi.spyOn(document, 'addEventListener');

mount(Menu);

Expand All @@ -79,7 +79,7 @@ describe('Menu component', () => {

describe('onUnmounted', () => {
it('cleans up event listener on component unmount', async () => {
const removeEventListenerSpy = jest.spyOn(document, 'removeEventListener');
const removeEventListenerSpy = vi.spyOn(document, 'removeEventListener');

const wrapper = mount(Menu);
await wrapper.unmount();
Expand Down
Loading

0 comments on commit 4037bc6

Please sign in to comment.