feat: #7079 created VnLocation front test #1126

Merged
provira merged 6 commits from 7079-testVnLocation into dev 2024-12-24 13:08:11 +00:00
2 changed files with 101 additions and 1 deletions
Showing only changes of commit bf41f338b7 - Show all commits

View File

@ -26,7 +26,7 @@ const locationProperties = [
(obj) => obj.country?.name,
];
const formatLocation = (obj, properties) => {
const formatLocation = (obj, properties = locationProperties) => {
const parts = properties.map((prop) => {
if (typeof prop === 'string') {
return obj[prop];

View File

@ -0,0 +1,100 @@
import { createWrapper } from 'app/test/vitest/helper';
import VnLocation from 'components/common/VnLocation.vue';
import { vi, afterEach, expect, it, beforeEach, describe } from 'vitest';
function buildComponent(data) {
return createWrapper(VnLocation, {
global: {
stubs: [''],
jsegarra marked this conversation as resolved
Review

Que hace esta linea?
Si la eliminas que ocurre?

Que hace esta linea? Si la eliminas que ocurre?
props: {
location: data
}
},
}).vm;
}
afterEach(() => {
vi.clearAllMocks();
});
describe('formatLocation', () => {
let locationBase;
beforeEach(() => {
locationBase = {
postcode: '46680',
city: 'Algemesi',
province: { name: 'Valencia' },
country: { name: 'Spain' }
};
});
it('should return the postcode, city, province and country', () => {
const location = { ...locationBase };
const vm = buildComponent(location);
const parts = vm.formatLocation(location);
expect(parts).toEqual('46680, Algemesi(Valencia), Spain');
});
it('should return the postcode and country', () => {
const location = { ...locationBase, city: undefined };
const vm = buildComponent(location);
const parts = vm.formatLocation(location);
expect(parts).toEqual('46680, Spain');
});
it('should return the city, province and country', () => {
const location = { ...locationBase, postcode: undefined };
const vm = buildComponent(location);
const parts = vm.formatLocation(location);
expect(parts).toEqual('Algemesi(Valencia), Spain');
});
it('should return the country', () => {
const location = { ...locationBase, postcode: undefined, city: undefined, province: undefined };
const vm = buildComponent(location);
const parts = vm.formatLocation(location);
Review

porque lo has llamado parts?

porque lo has llamado parts?
Review

Es significativo?

Es significativo?
Review

No, el nombre se podria cambiar y no pasaria nada. De hecho seria mas correcto llamarlo algo como "resultado"

No, el nombre se podria cambiar y no pasaria nada. De hecho seria mas correcto llamarlo algo como "resultado"
Review

Otra opción, si solo vas a usar en 1 sitio el resultado de vm.formatLocation, es que lo pongas como argumento en el expect. Porque, porque vas a crear una variable de 1 uso??
Si tienes dudas, me comentas

Otra opción, si solo vas a usar en 1 sitio el resultado de vm.formatLocation, es que lo pongas como argumento en el expect. Porque, porque vas a crear una variable de 1 uso?? Si tienes dudas, me comentas
expect(parts).toEqual('Spain');
});
});
describe('showLabel', () => {
let locationBase;
beforeEach(() => {
locationBase = {
code: '46680',
town: 'Algemesi',
province: 'Valencia',
country: 'Spain'
};
});
it('should show the label with postcode, city, province and country', () => {
const location = { ...locationBase };
const vm = buildComponent(location);
const label = vm.showLabel(location);
expect(label).toEqual('46680, Algemesi(Valencia), Spain');
});
it('should show the label with postcode and country', () => {
const location = { ...locationBase, town: undefined };
const vm = buildComponent(location);
const label = vm.showLabel(location);
expect(label).toEqual('46680, Spain');
});
it('should show the label with city, province and country', () => {
const location = { ...locationBase, code: undefined };
const vm = buildComponent(location);
const label = vm.showLabel(location);
expect(label).toEqual('Algemesi(Valencia), Spain');
});
it('should show the label with country', () => {
const location = { ...locationBase, code: undefined, town: undefined, province: undefined };
const vm = buildComponent(location);
const label = vm.showLabel(location);
expect(label).toEqual('Spain');
});
});