feat: refs #7055 created FilterItemForm test #1187

Merged
provira merged 8 commits from 7055-testFilterItemForm into dev 2025-01-14 06:03:51 +00:00
1 changed files with 71 additions and 0 deletions
Showing only changes of commit 5dc14b8dc1 - Show all commits
src/components/__tests__

View File

@ -0,0 +1,71 @@
import { createWrapper, axios } from 'app/test/vitest/helper';
import FilterItemForm from 'components/FilterItemForm.vue';
jsegarra marked this conversation as resolved Outdated

src
así seguimos el standard de los test
Por ejemplo en la #1197 hemos puesto src/components

src así seguimos el standard de los test Por ejemplo en la #1197 hemos puesto src/components

arreglado

arreglado
import { vi, afterEach, beforeAll, describe, expect, it } from 'vitest';
describe('FilterItemForm', () => {
let vm;
let wrapper;
beforeAll(() => {
wrapper = createWrapper(FilterItemForm, {
props: {
url: 'Items/withName',
},
});
vm = wrapper.vm;
wrapper = wrapper.wrapper;
vi.spyOn(axios, 'get').mockResolvedValue({ data: [] });
});
it('should set up itemFilter and itemFilterParams correctly', async () => {
wrapper.setProps({
itemFilter: {
include: [
{ relation: 'producer', scope: { fields: ['name'] } },
{ relation: 'ink', scope: { fields: ['name'] } },
],
where: { name: { like: '%bolas de madera%' } },
},
itemFilterParams: { name: 'bolas de madera' },
});
Review

Este it, debería comprobar el filtro que se le pasa a la petición de axios.
En el siguiente it, si que se comprueba estando vacío, y aquí que tiene valores no se comprueba? Tendría que haber expect en ambos casos

Este it, debería comprobar el filtro que se le pasa a la petición de axios. En el siguiente it, si que se comprueba estando vacío, y aquí que tiene valores no se comprueba? Tendría que haber expect en ambos casos
Review

añadido

añadido
await vm.onSubmit();
const expectedFilter = {
include: [
{ relation: 'producer', scope: { fields: ['name'] } },
{ relation: 'ink', scope: { fields: ['name'] } },
],
where: {
name: { like: '%bolas de madera%' },
size: 'large',
producerFk: 1,
typeFk: 2,
Review

Es el mismo expect, pero creo que 2 ocurrencias se puede dar como bueno

Es el mismo expect, pero creo que 2 ocurrencias se puede dar como bueno
inkFk: 3,
},
};
expect(axios.get).toHaveBeenCalledWith('Items/withName', {
params: { filter: JSON.stringify(expectedFilter) },
});
});
it('should handle an empty itemFilterParams correctly', async () => {
vm.itemFilterParams = {};
await vm.onSubmit();
const expectedFilter = {
include: [
{ relation: 'producer', scope: { fields: ['name'] } },
{ relation: 'ink', scope: { fields: ['name'] } },
],
where: {},
};
expect(axios.get).toHaveBeenCalledWith('Items/withName', {
params: { filter: JSON.stringify(expectedFilter) },
});
});
});