From c9df8e257aef64d989e5e6c2333216c53586d4ed Mon Sep 17 00:00:00 2001 From: Andrea Delgado <114981520+andreadlgdo@users.noreply.github.com> Date: Wed, 19 Jun 2024 11:25:15 +0200 Subject: [PATCH] fix: unit test --- .../__tests__/renderless-filter.spec.ts | 65 +++++-------------- .../filters/__tests__/simple-filter.spec.ts | 6 +- 2 files changed, 21 insertions(+), 50 deletions(-) diff --git a/packages/x-components/src/x-modules/facets/components/filters/__tests__/renderless-filter.spec.ts b/packages/x-components/src/x-modules/facets/components/filters/__tests__/renderless-filter.spec.ts index 8689b6316d..082282d26b 100644 --- a/packages/x-components/src/x-modules/facets/components/filters/__tests__/renderless-filter.spec.ts +++ b/packages/x-components/src/x-modules/facets/components/filters/__tests__/renderless-filter.spec.ts @@ -1,18 +1,17 @@ -import { BooleanFilter } from '@empathyco/x-types'; -import { mount, Wrapper } from '@vue/test-utils'; -import Vue from 'vue'; +import { mount } from '@vue/test-utils'; +import { nextTick, reactive } from 'vue'; import { getXComponentXModuleName, isXComponent } from '../../../../../components'; -import { XEventsTypes } from '../../../../../wiring/events.types'; import { createSimpleFilter, getSimpleFilterStub } from '../../../../../__stubs__/filters-stubs.factory'; -import { getDataTestSelector } from '../../../../../__tests__/utils'; +import { getDataTestSelector, installNewXPlugin } from '../../../../../__tests__/utils'; import RenderlessFilter from '../renderless-filter.vue'; +import { XPlugin } from '../../../../../plugins/x-plugin'; function renderComponent({ - filter = createSimpleFilter('category', 'food'), - clickEvents, + filter = reactive(createSimpleFilter('category', 'food')), + clickEvents = {}, template = ` ` -}: RenderOptions = {}): RenderAPI { - Vue.observable(filter); - const emit = jest.fn(); +} = {}) { + installNewXPlugin(); + + //Vue.observable(filter); + const wrapper = mount( { components: { RenderlessFilter }, @@ -41,11 +42,6 @@ function renderComponent({ propsData: { filter, clickEvents - }, - mocks: { - $x: { - emit - } } } ); @@ -54,14 +50,14 @@ function renderComponent({ return { wrapper: renderlessFilterWrapper, - emit, + emit: jest.spyOn(XPlugin.bus, 'emit'), filter, - clickFilter() { + clickFilter: () => { renderlessFilterWrapper.trigger('click'); }, - async selectFilter() { + selectFilter: async () => { filter.selected = true; - await Vue.nextTick(); + await nextTick(); } }; } @@ -80,7 +76,7 @@ describe('testing Renderless Filter component', () => { }); it('emits UserClickedAFilter and other custom events when clicked', () => { - const filter = getSimpleFilterStub(); + const filter = reactive(getSimpleFilterStub()); const { wrapper, clickFilter, emit } = renderComponent({ filter, clickEvents: { @@ -117,39 +113,14 @@ describe('testing Renderless Filter component', () => { }); it('disables the filter when it has no results', async () => { - const filter = createSimpleFilter('category', 'men', false); + const filter = reactive(createSimpleFilter('category', 'men', false)); const { wrapper } = renderComponent({ filter }); expect(wrapper.attributes('disabled')).toBeUndefined(); filter.totalResults = 0; - await wrapper.vm.$nextTick(); + await nextTick(); expect(wrapper.attributes('disabled')).toBe('disabled'); }); }); - -interface RenderOptions { - /** The template containing the {@link RenderlessFilter} component to render. */ - template?: string; - /** The filter data. Passed as prop to the {@link RenderlessFilter} component. */ - filter?: BooleanFilter; - /** - * Additional events to emit when the filter is clicked. - * Passed as prop to the {@link RenderlessFilter} component. - */ - clickEvents?: Partial; -} - -interface RenderAPI { - /** Wrapper of the {@link RenderlessFilter} component. */ - wrapper: Wrapper; - /** Mock of the {@link XBus.emit} function. */ - emit: jest.Mock; - /** The rendered filter data. */ - filter: BooleanFilter; - /** Fakes a click on the filter component. */ - clickFilter: () => void; - /** Sets the {@link RenderAPI.filter} `selected` property to `true`. */ - selectFilter: () => Promise; -} diff --git a/packages/x-components/src/x-modules/facets/components/filters/__tests__/simple-filter.spec.ts b/packages/x-components/src/x-modules/facets/components/filters/__tests__/simple-filter.spec.ts index 8c1ff466d2..ee536e26f2 100644 --- a/packages/x-components/src/x-modules/facets/components/filters/__tests__/simple-filter.spec.ts +++ b/packages/x-components/src/x-modules/facets/components/filters/__tests__/simple-filter.spec.ts @@ -1,6 +1,6 @@ import { SimpleFilter as SimpleFilterModel } from '@empathyco/x-types'; import { mount, Wrapper } from '@vue/test-utils'; -import Vue from 'vue'; +import Vue, { nextTick } from 'vue'; import { createSimpleFilter } from '../../../../../__stubs__/filters-stubs.factory'; import { getDataTestSelector } from '../../../../../__tests__/utils'; import { getXComponentXModuleName, isXComponent } from '../../../../../components'; @@ -44,11 +44,11 @@ function renderSimpleFilter({ }, selectFilter() { filter.selected = true; - return Vue.nextTick(); + return nextTick(); }, updateFilter(newFields) { Object.assign(filter, newFields); - return Vue.nextTick(); + return nextTick(); } }; }