diff --git a/back/methods/mrw-config/cancelShipment.js b/back/methods/mrw-config/cancelShipment.js
index 56d206529..98aa8be39 100644
--- a/back/methods/mrw-config/cancelShipment.js
+++ b/back/methods/mrw-config/cancelShipment.js
@@ -39,6 +39,9 @@ module.exports = Self => {
const xmlString = response.data;
const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, 'text/xml');
+
+ await Self.rawSql('CALL util.debugAdd(?,?);', ['cancelShipment', xmlDoc]);
+
const result = xmlDoc.getElementsByTagName('Mensaje')[0].textContent;
return result.toLowerCase().includes('se ha cancelado correctamente');
};
diff --git a/back/models/say-simple-config.json b/back/models/say-simple-config.json
index edc4caa43..d5d4f8a6f 100644
--- a/back/models/say-simple-config.json
+++ b/back/models/say-simple-config.json
@@ -13,6 +13,9 @@
},
"url": {
"type": "string"
+ },
+ "defaultChannel": {
+ "type": "number"
}
},
"acls": [
diff --git a/db/dump/fixtures.before.sql b/db/dump/fixtures.before.sql
index 68d8be097..cc258e2e3 100644
--- a/db/dump/fixtures.before.sql
+++ b/db/dump/fixtures.before.sql
@@ -4023,9 +4023,8 @@ INSERT INTO srt.buffer (id, x, y, `size`, `length`, stateFk, typeFk, isActive, c
INSERT IGNORE INTO vn.saySimpleCountry (countryFk, channel)
- VALUES (19, 1169),
- (8, 1183),
- (NULL, 1320);
+ VALUES (19, '1169'),
+ (8, '1183');
-INSERT IGNORE INTO vn.saySimpleConfig (url)
- VALUES ('saysimle-url-mock');
\ No newline at end of file
+INSERT IGNORE INTO vn.saySimpleConfig (url, defaultChannel)
+ VALUES ('saysimle-url-mock', 1320);
\ No newline at end of file
diff --git a/db/routines/account/views/myUser.sql b/db/routines/account/views/myUser.sql
index f520d893b..8d927dc0f 100644
--- a/db/routines/account/views/myUser.sql
+++ b/db/routines/account/views/myUser.sql
@@ -7,8 +7,7 @@ AS SELECT `u`.`id` AS `id`,
`u`.`email` AS `email`,
`u`.`nickname` AS `nickname`,
`u`.`lang` AS `lang`,
- `u`.`role` AS `role`,
- `u`.`recoverPass` AS `recoverPass`
+ `u`.`role` AS `role`
FROM `account`.`user` `u`
WHERE `u`.`name` = `myUser_getName`()
WITH CASCADED CHECK OPTION
diff --git a/db/routines/vn/procedures/stockBought_calculate.sql b/db/routines/vn/procedures/stockBought_calculate.sql
index ba044604a..c3b5a0dc6 100644
--- a/db/routines/vn/procedures/stockBought_calculate.sql
+++ b/db/routines/vn/procedures/stockBought_calculate.sql
@@ -59,7 +59,7 @@ proc: BEGIN
INSERT INTO stockBought(workerFk, bought, dated)
SELECT tb.workerFk,
- ROUND(GREATEST(tb.bought - IFNULL(ts.sold, 0), 0), 1),
+ ROUND(GREATEST(tb.bought - IFNULL(ts.sold, 0), 0), 2),
vDated
FROM tStockBought tb
LEFT JOIN tStockSold ts ON ts.workerFk = tb.workerFk;
diff --git a/db/versions/11251-navyChrysanthemum/00-firstScript.sql b/db/versions/11251-navyChrysanthemum/00-firstScript.sql
index 801405e59..7c2c69839 100644
--- a/db/versions/11251-navyChrysanthemum/00-firstScript.sql
+++ b/db/versions/11251-navyChrysanthemum/00-firstScript.sql
@@ -1,3 +1,2 @@
-UPDATE vn.sale
- SET originalQuantity = quantity
- WHERE originalQuantity IS NULL
+-- Debido a que tardaba mucho en la subida a master, se ha creado una nueva versión para que el proceso no se vea afectado y se ejecute por la noche.
+-- Se crea de nuevo en la versión 11344-grayBamboo
diff --git a/db/versions/11343-silverAsparagus/00-firstScript.sql b/db/versions/11343-silverAsparagus/00-firstScript.sql
new file mode 100644
index 000000000..bcee42eea
--- /dev/null
+++ b/db/versions/11343-silverAsparagus/00-firstScript.sql
@@ -0,0 +1,9 @@
+INSERT INTO salix.ACL (model, property, accessType, principalId)
+ VALUES ('Collection', 'create', 'WRITE', 'productionBoss'),
+ ('Collection', 'upsert', 'WRITE', 'productionBoss'),
+ ('Collection', 'replaceById', 'WRITE', 'productionBoss'),
+ ('Collection', 'updateAll', 'WRITE', 'productionBoss'),
+ ('Collection', 'updateAttributes', 'WRITE', 'productionBoss'),
+ ('Collection', 'deleteById', 'WRITE', 'productionBoss'),
+ ('Collection', 'destroyAll', 'WRITE', 'productionBoss'),
+ ('Collection', 'destroyById', 'WRITE', 'productionBoss');
diff --git a/db/versions/11344-grayBamboo/00-firstScript.sql b/db/versions/11344-grayBamboo/00-firstScript.sql
new file mode 100644
index 000000000..1fbd2a0d8
--- /dev/null
+++ b/db/versions/11344-grayBamboo/00-firstScript.sql
@@ -0,0 +1,3 @@
+UPDATE vn.sale
+ SET originalQuantity = quantity
+ WHERE originalQuantity IS NULL
\ No newline at end of file
diff --git a/db/versions/11251-navyChrysanthemum/01-firstScript.sql b/db/versions/11344-grayBamboo/01-firstScript.sql
similarity index 100%
rename from db/versions/11251-navyChrysanthemum/01-firstScript.sql
rename to db/versions/11344-grayBamboo/01-firstScript.sql
diff --git a/db/versions/11345-salmonEucalyptus/00-firstScript.sql b/db/versions/11345-salmonEucalyptus/00-firstScript.sql
new file mode 100644
index 000000000..ecbc36c40
--- /dev/null
+++ b/db/versions/11345-salmonEucalyptus/00-firstScript.sql
@@ -0,0 +1,2 @@
+ALTER TABLE account.user CHANGE recoverPass recoverPass__ tinyint(3) unsigned NOT NULL DEFAULT 1 COMMENT '@deprecated 2024-11-13';
+ALTER TABLE account.user CHANGE sync sync__ tinyint(4) NOT NULL DEFAULT 0 COMMENT '@deprecated 2024-11-13';
\ No newline at end of file
diff --git a/db/versions/11347-redErica/00-firstScript.sql b/db/versions/11347-redErica/00-firstScript.sql
new file mode 100644
index 000000000..5da1d6096
--- /dev/null
+++ b/db/versions/11347-redErica/00-firstScript.sql
@@ -0,0 +1,9 @@
+DROP TABLE IF EXISTS vn.saySimpleConfig;
+
+CREATE TABLE vn.saySimpleConfig(
+ id INT AUTO_INCREMENT PRIMARY KEY,
+ url VARCHAR(255) NOT NULL,
+ defaultChannel VARCHAR(128)
+);
+
+ALTER TABLE vn.saySimpleCountry MODIFY COLUMN channel VARCHAR(128);
\ No newline at end of file
diff --git a/db/versions/11348-bronzeCamellia/00-firstScript.sql b/db/versions/11348-bronzeCamellia/00-firstScript.sql
new file mode 100644
index 000000000..fa466f1a4
--- /dev/null
+++ b/db/versions/11348-bronzeCamellia/00-firstScript.sql
@@ -0,0 +1,2 @@
+ALTER TABLE vn.clientObservation MODIFY COLUMN observationTypeFk tinyint(3) unsigned DEFAULT 4 NOT NULL;
+UPDATE vn.clientObservation SET observationTypeFk=4 WHERE observationTypeFk=0;
diff --git a/e2e/paths/04-item/01_summary.spec.js b/e2e/paths/04-item/01_summary.spec.js
deleted file mode 100644
index 51195be48..000000000
--- a/e2e/paths/04-item/01_summary.spec.js
+++ /dev/null
@@ -1,133 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item summary path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'item');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should search for an item', async() => {
- await page.doSearch('Ranged weapon');
- const resultsCount = await page.countElement(selectors.itemsIndex.searchResult);
-
- await page.waitForTextInElement(selectors.itemsIndex.firstSearchResult, 'Ranged weapon');
- await page.waitToClick(selectors.itemsIndex.firstResultPreviewButton);
- const isVisible = await page.isVisible(selectors.itemSummary.basicData);
-
- expect(resultsCount).toBe(4);
- expect(isVisible).toBeTruthy();
- });
-
- it(`should check the item summary preview shows fields from basic data`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.basicData, 'Ranged weapon longbow 200cm');
- const result = await page.waitToGetProperty(selectors.itemSummary.basicData, 'innerText');
-
- expect(result).toContain('Ranged weapon longbow 200cm');
- });
-
- it(`should check the item summary preview shows fields from tags`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.tags, 'Brown');
- const result = await page.waitToGetProperty(selectors.itemSummary.tags, 'innerText');
-
- expect(result).toContain('Brown');
- });
-
- it(`should check the item summary preview shows fields from botanical`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.botanical, 'Abelia');
- const result = await page.waitToGetProperty(selectors.itemSummary.botanical, 'innerText');
-
- expect(result).toContain('Abelia');
- });
-
- it(`should check the item summary preview shows fields from barcode`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.barcode, '1');
- const result = await page.waitToGetProperty(selectors.itemSummary.barcode, 'innerText');
-
- expect(result).toContain('1');
- });
-
- it(`should close the summary popup`, async() => {
- await page.closePopup();
- await page.waitForSelector(selectors.itemSummary.basicData, {hidden: true});
- });
-
- it('should search for other item', async() => {
- await page.doSearch('Melee Reinforced');
- const resultsCount = await page.countElement(selectors.itemsIndex.searchResult);
-
- await page.waitToClick(selectors.itemsIndex.firstResultPreviewButton);
- await page.waitForSelector(selectors.itemSummary.basicData, {visible: true});
-
- expect(resultsCount).toBe(3);
- });
-
- it(`should now check the item summary preview shows fields from basic data`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.basicData, 'Melee Reinforced weapon combat fist 15cm');
- const result = await page.waitToGetProperty(selectors.itemSummary.basicData, 'innerText');
-
- expect(result).toContain('Melee Reinforced weapon combat fist 15cm');
- });
-
- it(`should now check the item summary preview shows fields from tags`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.tags, 'Silver');
- const result = await page.waitToGetProperty(selectors.itemSummary.tags, 'innerText');
-
- expect(result).toContain('Silver');
- });
-
- it(`should now check the item summary preview shows fields from botanical`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.botanical, '-');
- const result = await page.waitToGetProperty(selectors.itemSummary.botanical, 'innerText');
-
- expect(result).toContain('-');
- });
-
- it(`should now close the summary popup`, async() => {
- await page.closePopup();
- await page.waitForSelector(selectors.itemSummary.basicData, {hidden: true});
- });
-
- it(`should navigate to one of the items detailed section`, async() => {
- await page.accessToSearchResult('Melee weapon combat fist 15cm');
- await page.waitForState('item.card.summary');
- });
-
- it(`should check the descritor edit button is not visible for employee`, async() => {
- const visibleButton = await page.isVisible(selectors.itemDescriptor.editButton);
-
- expect(visibleButton).toBeFalsy();
- });
-
- it(`should check the item summary shows fields from basic data section`, async() => {
- await page.waitForTextInElement(selectors.itemSummary.basicData, 'Melee weapon combat fist 15cm');
- const result = await page.waitToGetProperty(selectors.itemSummary.basicData, 'innerText');
-
- expect(result).toContain('Melee weapon combat fist 15cm');
- });
-
- it(`should check the item summary shows fields from tags section`, async() => {
- const result = await page.waitToGetProperty(selectors.itemSummary.tags, 'innerText');
-
- expect(result).toContain('Silver');
- });
-
- it(`should check the item summary shows fields from botanical section`, async() => {
- const result = await page.waitToGetProperty(selectors.itemSummary.botanical, 'innerText');
-
- expect(result).toContain('procera');
- });
-
- it(`should check the item summary shows fields from barcodes section`, async() => {
- const result = await page.waitToGetProperty(selectors.itemSummary.barcode, 'innerText');
-
- expect(result).toContain('4');
- });
-});
diff --git a/e2e/paths/04-item/02_basic_data.spec.js b/e2e/paths/04-item/02_basic_data.spec.js
deleted file mode 100644
index 3bad18303..000000000
--- a/e2e/paths/04-item/02_basic_data.spec.js
+++ /dev/null
@@ -1,64 +0,0 @@
-import getBrowser from '../../helpers/puppeteer';
-
-const $ = {
- form: 'vn-item-basic-data form',
- intrastatForm: '.vn-dialog.shown form',
- newIntrastatButton: 'vn-item-basic-data vn-icon-button[vn-tooltip="New intrastat"] > button'
-};
-
-describe('Item Edit basic data path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('Melee weapon combat fist 15cm');
- });
-
- beforeEach(async() => {
- await page.accessToSection('item.card.basicData');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should edit the item basic data and confirm the item data was edited`, async() => {
- const values = {
- type: 'Anthurium',
- intrastat: 'Coral y materiales similares',
- relevancy: 1,
- generic: 'Pallet',
- isActive: false,
- priceInKg: true,
- isFragile: true,
- packingOut: 5
- };
-
- const message = await page.sendForm($.form, values);
- await page.reloadSection('item.card.basicData');
- const formValues = await page.fetchForm($.form, Object.keys(values));
-
- expect(message.isSuccess).toBeTrue();
- expect(formValues).toEqual(values);
- });
-
- it(`should create a new intrastat and save it`, async() => {
- await page.click($.newIntrastatButton);
- await page.waitForSelector($.intrastatForm);
- await page.fillForm($.intrastatForm, {
- id: '588420239',
- description: 'Tropical Flowers'
- });
- await page.respondToDialog('accept');
-
- const message = await page.sendForm($.form);
- await page.reloadSection('item.card.basicData');
- const formValues = await page.fetchForm($.form, ['intrastat']);
-
- expect(message.isSuccess).toBeTrue();
- expect(formValues).toEqual({intrastat: 'Tropical Flowers'});
- });
-});
diff --git a/e2e/paths/04-item/03_tax.spec.js b/e2e/paths/04-item/03_tax.spec.js
deleted file mode 100644
index 6013094e9..000000000
--- a/e2e/paths/04-item/03_tax.spec.js
+++ /dev/null
@@ -1,48 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item edit tax path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('Ranged weapon longbow 200cm');
- await page.accessToSection('item.card.tax');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should add the item tax to all countries`, async() => {
- await page.autocompleteSearch(selectors.itemTax.firstClass, 'General VAT');
- await page.autocompleteSearch(selectors.itemTax.secondClass, 'General VAT');
- await page.waitToClick(selectors.itemTax.submitTaxButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the first item tax class was edited`, async() => {
- await page.reloadSection('item.card.tax');
- const firstVatType = await page.waitToGetProperty(selectors.itemTax.firstClass, 'value');
-
- expect(firstVatType).toEqual('General VAT');
- });
-
- it(`should confirm the second item tax class was edited`, async() => {
- const secondVatType = await page
- .waitToGetProperty(selectors.itemTax.secondClass, 'value');
-
- expect(secondVatType).toEqual('General VAT');
- });
-
- it(`should edit the first class without saving the form`, async() => {
- await page.autocompleteSearch(selectors.itemTax.firstClass, 'Reduced VAT');
- const firstVatType = await page.waitToGetProperty(selectors.itemTax.firstClass, 'value');
-
- expect(firstVatType).toEqual('Reduced VAT');
- });
-});
diff --git a/e2e/paths/04-item/04_tags.spec.js b/e2e/paths/04-item/04_tags.spec.js
deleted file mode 100644
index f13cf9aa4..000000000
--- a/e2e/paths/04-item/04_tags.spec.js
+++ /dev/null
@@ -1,79 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item create tags path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('Ranged weapon longbow 200cm');
- await page.accessToSection('item.card.tags');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should create a new tag and delete a former one', async() => {
- await page.waitToClick(selectors.itemTags.fourthRemoveTagButton);
- await page.waitToClick(selectors.itemTags.addItemTagButton);
- await page.autocompleteSearch(selectors.itemTags.seventhTag, 'Ancho de la base');
- await page.write(selectors.itemTags.seventhValue, '50');
- await page.clearInput(selectors.itemTags.seventhRelevancy);
- await page.write(selectors.itemTags.seventhRelevancy, '4');
- await page.waitToClick(selectors.itemTags.submitItemTagsButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the fourth row data is the expected one', async() => {
- await page.reloadSection('item.card.tags');
- await page.waitForSelector('vn-item-tags');
- let result = await page.waitToGetProperty(selectors.itemTags.fourthTag, 'value');
-
- expect(result).toEqual('Ancho de la base');
-
- result = await page
- .waitToGetProperty(selectors.itemTags.fourthValue, 'value');
-
- expect(result).toEqual('50');
-
- result = await page
- .waitToGetProperty(selectors.itemTags.fourthRelevancy, 'value');
-
- expect(result).toEqual('4');
- });
-
- it('should confirm the fifth row data is the expected one', async() => {
- let tag = await page
- .waitToGetProperty(selectors.itemTags.fifthTag, 'value');
-
- let value = await page
- .waitToGetProperty(selectors.itemTags.fifthValue, 'value');
-
- let relevancy = await page
- .waitToGetProperty(selectors.itemTags.fifthRelevancy, 'value');
-
- expect(tag).toEqual('Color');
- expect(value).toEqual('Brown');
- expect(relevancy).toEqual('5');
- });
-
- it('should confirm the sixth row data is the expected one', async() => {
- let tag = await page
- .waitToGetProperty(selectors.itemTags.sixthTag, 'value');
-
- let value = await page
- .waitToGetProperty(selectors.itemTags.sixthValue, 'value');
-
- let relevancy = await page
- .waitToGetProperty(selectors.itemTags.sixthRelevancy, 'value');
-
- expect(tag).toEqual('Categoria');
- expect(value).toEqual('+1 precission');
- expect(relevancy).toEqual('6');
- });
-});
diff --git a/e2e/paths/04-item/05_botanical.spec.js b/e2e/paths/04-item/05_botanical.spec.js
deleted file mode 100644
index 1671cc5d2..000000000
--- a/e2e/paths/04-item/05_botanical.spec.js
+++ /dev/null
@@ -1,66 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item Create botanical path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('Ranged weapon pistol 9mm');
- await page.accessToSection('item.card.botanical');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should create a new botanical for the item`, async() => {
- await page.autocompleteSearch(selectors.itemBotanical.genus, 'Abelia');
- await page.autocompleteSearch(selectors.itemBotanical.species, 'dealbata');
- await page.waitToClick(selectors.itemBotanical.submitBotanicalButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the Genus for the item was created`, async() => {
- await page.waitForTextInField(selectors.itemBotanical.genus, 'Abelia');
- const result = await page
- .waitToGetProperty(selectors.itemBotanical.genus, 'value');
-
- expect(result).toEqual('Abelia');
- });
-
- it(`should confirm the Species for the item was created`, async() => {
- const result = await page
- .waitToGetProperty(selectors.itemBotanical.species, 'value');
-
- expect(result).toEqual('dealbata');
- });
-
- it(`should edit botanical for the item`, async() => {
- await page.autocompleteSearch(selectors.itemBotanical.genus, 'Abies');
- await page.autocompleteSearch(selectors.itemBotanical.species, 'decurrens');
- await page.waitToClick(selectors.itemBotanical.submitBotanicalButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the Genus for the item was edited`, async() => {
- await page.waitForTextInField(selectors.itemBotanical.genus, 'Abies');
- const result = await page
- .waitToGetProperty(selectors.itemBotanical.genus, 'value');
-
- expect(result).toEqual('Abies');
- });
-
- it(`should confirm the Species for the item was edited`, async() => {
- const result = await page
- .waitToGetProperty(selectors.itemBotanical.species, 'value');
-
- expect(result).toEqual('decurrens');
- });
-});
diff --git a/e2e/paths/04-item/06_barcode.spec.js b/e2e/paths/04-item/06_barcode.spec.js
deleted file mode 100644
index 36c9c39ae..000000000
--- a/e2e/paths/04-item/06_barcode.spec.js
+++ /dev/null
@@ -1,37 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item Create barcodes path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('Ranged weapon longbow 200cm');
- await page.accessToSection('item.card.itemBarcode');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should click create a new code and delete a former one`, async() => {
- await page.waitToClick(selectors.itemBarcodes.firstCodeRemoveButton);
- await page.waitToClick(selectors.itemBarcodes.addBarcodeButton);
- await page.write(selectors.itemBarcodes.thirdCode, '5');
- await page.waitToClick(selectors.itemBarcodes.submitBarcodesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the barcode 5 is created and it is now the third barcode as the first was deleted`, async() => {
- await page.reloadSection('item.card.itemBarcode');
- await page.waitForTextInField(selectors.itemBarcodes.thirdCode, '5');
- const result = await page
- .waitToGetProperty(selectors.itemBarcodes.thirdCode, 'value');
-
- expect(result).toEqual('5');
- });
-});
diff --git a/e2e/paths/04-item/07_create.spec.js b/e2e/paths/04-item/07_create.spec.js
deleted file mode 100644
index c20be9ebc..000000000
--- a/e2e/paths/04-item/07_create.spec.js
+++ /dev/null
@@ -1,65 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-const $ = {
- form: 'vn-item-create form'
-};
-
-describe('Item Create', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should access to the create item view by clicking the create floating button', async() => {
- await page.waitToClick(selectors.itemsIndex.createItemButton);
- await page.waitForState('item.create');
- });
-
- it('should return to the item index by clickig the cancel button', async() => {
- await page.waitToClick(selectors.itemCreateView.cancelButton);
- await page.waitForState('item.index');
- });
-
- it('should now access to the create item view by clicking the create floating button', async() => {
- await page.waitToClick(selectors.itemsIndex.createItemButton);
- await page.waitForState('item.create');
- });
-
- it('should throw an error when insert an invalid priority', async() => {
- const values = {
- name: 'Infinity Gauntlet',
- type: 'Crisantemo',
- intrastat: 'Coral y materiales similares',
- origin: 'Holand',
- priority: null
- };
- const message = await page.sendForm($.form, values);
-
- expect(message.text).toContain('Valid priorities');
- });
-
- it('should create the Infinity Gauntlet item', async() => {
- const values = {
- name: 'Infinity Gauntlet',
- type: 'Crisantemo',
- intrastat: 'Coral y materiales similares',
- origin: 'Holand',
- priority: '2'
- };
-
- await page.fillForm($.form, values);
- const formValues = await page.fetchForm($.form, Object.keys(values));
- const message = await page.sendForm($.form);
-
- expect(message.isSuccess).toBeTrue();
- expect(formValues).toEqual(values);
- });
-});
diff --git a/e2e/paths/04-item/08_regularize.spec.js b/e2e/paths/04-item/08_regularize.spec.js
deleted file mode 100644
index 9b3074776..000000000
--- a/e2e/paths/04-item/08_regularize.spec.js
+++ /dev/null
@@ -1,141 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item regularize path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'item');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should edit the user local warehouse', async() => {
- await page.waitForSpinnerLoad();
- await page.waitToClick(selectors.globalItems.userMenuButton);
- await page.autocompleteSearch(selectors.globalItems.userLocalWarehouse, 'Warehouse Four');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should check the local settings were saved', async() => {
- const userLocalWarehouse = await page
- .waitToGetProperty(selectors.globalItems.userLocalWarehouse, 'value');
-
- await page.closePopup();
-
- expect(userLocalWarehouse).toContain('Warehouse Four');
- });
-
- it('should search for a specific item', async() => {
- await page.accessToSearchResult('Ranged weapon pistol 9mm');
- await page.waitForState('item.card.summary');
- });
-
- it('should open the regularize dialog and check the warehouse matches the local user settings', async() => {
- await page.waitToClick(selectors.itemDescriptor.moreMenu);
- await page.waitToClick(selectors.itemDescriptor.moreMenuRegularizeButton);
- const result = await page.waitToGetProperty(selectors.itemDescriptor.regularizeWarehouse, 'value');
-
- expect(result).toEqual('Warehouse Four');
- });
-
- it('should regularize the item', async() => {
- await page.write(selectors.itemDescriptor.regularizeQuantity, '100');
- await page.autocompleteSearch(selectors.itemDescriptor.regularizeWarehouse, 'Warehouse One');
- await page.waitToClick(selectors.itemDescriptor.regularizeSaveButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should click on the Tickets button of the top bar menu', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await Promise.all([
- page.waitForNavigation({waitUntil: ['load', 'networkidle0', 'domcontentloaded']}),
- page.waitToClick(selectors.globalItems.ticketsButton)
- ]);
- await page.waitForState('ticket.index');
- });
-
- it('should clear the user local settings now', async() => {
- await page.waitToClick(selectors.globalItems.userMenuButton);
- await page.waitForContentLoaded();
- await page.clearInput(selectors.globalItems.userConfigFirstAutocomplete);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should search for the ticket with alias missing', async() => {
- await page.keyboard.press('Escape');
- await page.accessToSearchResult('missing');
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should check the ticket sale quantity is showing a negative value`, async() => {
- await page.waitForTextInElement(selectors.ticketSummary.firstSaleQuantity, '-100');
- const result = await page
- .waitToGetProperty(selectors.ticketSummary.firstSaleQuantity, 'innerText');
-
- expect(result).toContain('-100');
- });
-
- it(`should check the ticket sale discount is 100%`, async() => {
- const result = await page
- .waitToGetProperty(selectors.ticketSummary.firstSaleDiscount, 'innerText');
-
- expect(result).toContain('100 %');
- });
-
- it('should now click on the Items button of the top bar menu', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.itemsButton);
- await page.waitForState('item.index');
- });
-
- it('should search for the item once again', async() => {
- await page.accessToSearchResult('Ranged weapon pistol 9mm');
- await page.waitForState('item.card.summary');
- });
-
- it('should regularize the item once more', async() => {
- await page.waitToClick(selectors.itemDescriptor.moreMenu);
- await page.waitToClick(selectors.itemDescriptor.moreMenuRegularizeButton);
- await page.write(selectors.itemDescriptor.regularizeQuantity, '100');
- await page.autocompleteSearch(selectors.itemDescriptor.regularizeWarehouse, 'Warehouse One');
- await page.waitToClick(selectors.itemDescriptor.regularizeSaveButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should again click on the Tickets button of the top bar menu', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await Promise.all([
- page.waitForNavigation({waitUntil: ['load', 'networkidle0', 'domcontentloaded']}),
- page.waitToClick(selectors.globalItems.ticketsButton)
- ]);
- await page.waitForState('ticket.index');
- });
-
- it('should search for the ticket missing once again', async() => {
- await page.accessToSearchResult('Missing');
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should check the ticket contains now two sales`, async() => {
- await page.waitForTextInElement(selectors.ticketSummary.firstSaleQuantity, '-100');
- const result = await page.countElement(selectors.ticketSummary.sale);
-
- expect(result).toEqual(2);
- });
-});
diff --git a/e2e/paths/04-item/09_index.spec.js b/e2e/paths/04-item/09_index.spec.js
deleted file mode 100644
index 6e0a4bd5c..000000000
--- a/e2e/paths/04-item/09_index.spec.js
+++ /dev/null
@@ -1,84 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item index path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('salesPerson', 'item');
- await page.waitToClick(selectors.globalItems.searchButton);
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should click on the fields to show button to open the list of columns to show', async() => {
- await page.waitToClick(selectors.itemsIndex.shownColumns);
- const visible = await page.isVisible(selectors.itemsIndex.shownColumnsList);
-
- expect(visible).toBeTruthy();
- });
-
- it('should unmark all checkboxes except the first and the last ones', async() => {
- await page.waitToClick(selectors.itemsIndex.idCheckbox);
- await page.waitToClick(selectors.itemsIndex.stemsCheckbox);
- await page.waitToClick(selectors.itemsIndex.sizeCheckbox);
- await page.waitToClick(selectors.itemsIndex.typeCheckbox);
- await page.waitToClick(selectors.itemsIndex.categoryCheckbox);
- await page.waitToClick(selectors.itemsIndex.intrastadCheckbox);
- await page.waitToClick(selectors.itemsIndex.originCheckbox);
- await page.waitToClick(selectors.itemsIndex.buyerCheckbox);
- await page.waitToClick(selectors.itemsIndex.weightByPieceCheckbox);
- await page.waitToClick(selectors.itemsIndex.saveFieldsButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should navigate forth and back to see the images column is still visible', async() => {
- await page.closePopup();
- await page.waitToClick(selectors.itemsIndex.firstSearchResult);
- await page.waitToClick(selectors.itemDescriptor.goBackToModuleIndexButton);
- await page.waitToClick(selectors.globalItems.searchButton);
- await page.waitForSelector(selectors.itemsIndex.searchResult);
- await page.waitImgLoad(selectors.itemsIndex.firstItemImage);
- const imageVisible = await page.isVisible(selectors.itemsIndex.firstItemImageTd);
-
- expect(imageVisible).toBeTruthy();
- });
-
- it('should check the ids column is not visible', async() => {
- await page.waitForSelector(selectors.itemsIndex.firstItemId, {hidden: true});
- });
-
- it('should mark all unchecked boxes to leave the index as it was', async() => {
- await page.waitToClick(selectors.itemsIndex.shownColumns);
- await page.waitToClick(selectors.itemsIndex.idCheckbox);
- await page.waitToClick(selectors.itemsIndex.stemsCheckbox);
- await page.waitToClick(selectors.itemsIndex.sizeCheckbox);
- await page.waitToClick(selectors.itemsIndex.typeCheckbox);
- await page.waitToClick(selectors.itemsIndex.categoryCheckbox);
- await page.waitToClick(selectors.itemsIndex.intrastadCheckbox);
- await page.waitToClick(selectors.itemsIndex.originCheckbox);
- await page.waitToClick(selectors.itemsIndex.buyerCheckbox);
- await page.waitToClick(selectors.itemsIndex.weightByPieceCheckbox);
- await page.waitToClick(selectors.itemsIndex.saveFieldsButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should now navigate forth and back to see the ids column is now visible', async() => {
- await page.closePopup();
- await page.waitToClick(selectors.itemsIndex.firstSearchResult);
- await page.waitToClick(selectors.itemDescriptor.goBackToModuleIndexButton);
- await page.waitToClick(selectors.globalItems.searchButton);
- await page.waitForSelector(selectors.itemsIndex.searchResult);
- const idVisible = await page.isVisible(selectors.itemsIndex.firstItemId);
-
- expect(idVisible).toBeTruthy();
- });
-});
diff --git a/e2e/paths/04-item/10_item_log.spec.js b/e2e/paths/04-item/10_item_log.spec.js
deleted file mode 100644
index c88fbd337..000000000
--- a/e2e/paths/04-item/10_item_log.spec.js
+++ /dev/null
@@ -1,45 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item log path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('developer', 'item');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should search for the Knowledge artifact to confirm it isn't created yet`, async() => {
- await page.doSearch('Knowledge artifact');
- const nResults = await page.countElement(selectors.itemsIndex.searchResult);
-
- expect(nResults).toEqual(1);
- });
-
- it('should access to the create item view by clicking the create floating button', async() => {
- await page.waitToClick(selectors.itemsIndex.createItemButton);
- await page.waitForState('item.create');
- });
-
- it('should create the Knowledge artifact item', async() => {
- await page.write(selectors.itemCreateView.temporalName, 'Knowledge artifact');
- await page.autocompleteSearch(selectors.itemCreateView.type, 'Crisantemo');
- await page.autocompleteSearch(selectors.itemCreateView.intrastat, 'Coral y materiales similares');
- await page.autocompleteSearch(selectors.itemCreateView.origin, 'Holand');
- await page.waitToClick(selectors.itemCreateView.createButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should return to the items index by clicking the return to items button', async() => {
- await page.waitToClick(selectors.itemBasicData.goToItemIndexButton);
- await page.waitForSelector(selectors.itemsIndex.createItemButton);
- await page.waitForState('item.index');
- });
-});
diff --git a/e2e/paths/04-item/11_descriptor.spec.js b/e2e/paths/04-item/11_descriptor.spec.js
deleted file mode 100644
index eb9ed2573..000000000
--- a/e2e/paths/04-item/11_descriptor.spec.js
+++ /dev/null
@@ -1,41 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item descriptor path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSearchResult('1');
- await page.accessToSection('item.card.basicData');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should set the item to inactive', async() => {
- await page.waitToClick(selectors.itemBasicData.isActiveCheckbox);
- await page.waitToClick(selectors.itemBasicData.submitBasicDataButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should reload the section and check the inactive icon is visible', async() => {
- await page.reloadSection('item.card.basicData');
- const visibleIcon = await page.isVisible(selectors.itemDescriptor.inactiveIcon);
-
- expect(visibleIcon).toBeTruthy();
- });
-
- it('should set the item back to active', async() => {
- await page.waitToClick(selectors.itemBasicData.isActiveCheckbox);
- await page.waitToClick(selectors.itemBasicData.submitBasicDataButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-});
diff --git a/e2e/paths/04-item/12_request.spec.js b/e2e/paths/04-item/12_request.spec.js
deleted file mode 100644
index e0f3a1b45..000000000
--- a/e2e/paths/04-item/12_request.spec.js
+++ /dev/null
@@ -1,45 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Item request path', () => {
- let browser;
- let page;
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSection('item.request');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should reach the item request section', async() => {
- await page.waitForState('item.request');
- });
-
- it('should fill the id and quantity then check the concept was updated', async() => {
- await page.writeOnEditableTD(selectors.itemRequest.firstRequestItemID, '4');
- await page.writeOnEditableTD(selectors.itemRequest.firstRequestQuantity, '10');
- await page.waitForTextInElement(selectors.itemRequest.firstRequestConcept, 'Melee weapon heavy shield 100cm');
- let filledConcept = await page.waitToGetProperty(selectors.itemRequest.firstRequestConcept, 'innerText');
-
- expect(filledConcept).toContain('Melee weapon heavy shield 100cm');
- });
-
- it('should check the status of the request should now be accepted', async() => {
- let status = await page.waitToGetProperty(selectors.itemRequest.firstRequestStatus, 'innerText');
-
- expect(status).toContain('Accepted');
- });
-
- it('should now click on the second declain request icon then type the reason', async() => {
- await page.waitToClick(selectors.itemRequest.secondRequestDecline);
- await page.write(selectors.itemRequest.declineReason, 'Not quite as expected');
- await page.respondToDialog('accept');
- let status = await page.waitToGetProperty(selectors.itemRequest.secondRequestStatus, 'innerText');
-
- expect(status).toContain('Denied');
- });
-});
diff --git a/e2e/paths/04-item/13_fixedPrice.spec.js b/e2e/paths/04-item/13_fixedPrice.spec.js
deleted file mode 100644
index f36138e18..000000000
--- a/e2e/paths/04-item/13_fixedPrice.spec.js
+++ /dev/null
@@ -1,97 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-const $ = selectors.itemFixedPrice;
-
-describe('Item fixed prices path', () => {
- let browser;
- let page;
- let httpRequest;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyer', 'item');
- await page.accessToSection('item.fixedPrice');
- page.on('request', req => {
- if (req.url().includes(`FixedPrices/filter`))
- httpRequest = req.url();
- });
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should filter using all the fields', async() => {
- await page.write($.generalSearchFilter, 'item');
- await page.keyboard.press('Enter');
-
- expect(httpRequest).toContain('search=item');
-
- await page.click($.chip);
- await page.click($.reignFilter);
-
- expect(httpRequest).toContain('categoryFk');
-
- await page.autocompleteSearch($.typeFilter, 'Alstroemeria');
-
- expect(httpRequest).toContain('typeFk');
-
- await page.click($.chip);
- await page.autocompleteSearch($.buyerFilter, 'buyerNick');
-
- expect(httpRequest).toContain('buyerFk');
-
- await page.click($.chip);
- await page.autocompleteSearch($.warehouseFilter, 'Algemesi');
-
- expect(httpRequest).toContain('warehouseFk');
-
- await page.click($.chip);
- await page.click($.mineFilter);
-
- expect(httpRequest).toContain('mine=true');
-
- await page.click($.chip);
- await page.click($.hasMinPriceFilter);
-
- expect(httpRequest).toContain('hasMinPrice=true');
-
- await page.click($.chip);
- await page.click($.addTag);
- await page.autocompleteSearch($.tagFilter, 'Color');
- await page.autocompleteSearch($.tagValueFilter, 'Brown');
-
- expect(httpRequest).toContain('tags');
-
- await page.click($.chip);
- });
-
- it('should click on the add new fixed price button', async() => {
- await page.waitToClick($.add);
- await page.waitForSelector($.fourthFixedPrice);
- });
-
- it('should fill the fixed price data', async() => {
- const now = Date.vnNew();
- await page.autocompleteSearch($.fourthWarehouse, 'Warehouse one');
- await page.writeOnEditableTD($.fourthGroupingPrice, '1');
- await page.writeOnEditableTD($.fourthPackingPrice, '1');
- await page.write($.fourthMinPrice, '1');
- await page.pickDate($.fourthStarted, now);
- await page.pickDate($.fourthEnded, now);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should reload the section and check the created price has the expected ID', async() => {
- await page.goto(`http://localhost:5000/#!/item/fixed-price`);
- await page.autocompleteSearch($.warehouseFilter, 'Warehouse one');
- await page.click($.chip);
- const result = await page.waitToGetProperty($.fourthItemID, 'value');
-
- expect(result).toContain('13');
- });
-});
diff --git a/e2e/paths/05-ticket/01-sale/01_list_sales.spec.js b/e2e/paths/05-ticket/01-sale/01_list_sales.spec.js
deleted file mode 100644
index ad0975889..000000000
--- a/e2e/paths/05-ticket/01-sale/01_list_sales.spec.js
+++ /dev/null
@@ -1,99 +0,0 @@
-import selectors from '../../../helpers/selectors.js';
-import getBrowser from '../../../helpers/puppeteer';
-
-describe('Ticket List sale path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('13');
- await page.accessToSection('ticket.card.sale');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should confirm the first ticket sale contains the colour tag', async() => {
- const value = await page
- .waitToGetProperty(selectors.ticketSales.firstSaleColour, 'innerText');
-
- expect(value).toContain('Black');
- });
-
- it('should confirm the first sale contains the price', async() => {
- const value = await page
- .waitToGetProperty(selectors.ticketSales.firstSalePrice, 'innerText');
-
- expect(value).toContain('1.72');
- });
-
- it('should confirm the first sale contains the discount', async() => {
- const value = await page
- .waitToGetProperty(selectors.ticketSales.firstSaleDiscount, 'innerText');
-
- expect(value).toContain('0.00%');
- });
-
- it('should confirm the first sale contains the total import', async() => {
- const value = await page
- .waitToGetProperty(selectors.ticketSales.firstSaleImport, 'innerText');
-
- expect(value).toContain('34.40');
- });
-
- it('should add an empty item to the sale list', async() => {
- await page.waitToClick(selectors.ticketSales.newItemButton);
- const sales = await page
- .countElement(selectors.ticketSales.saleLine);
-
- expect(sales).toEqual(2);
- });
-
- it('should select a valid item to be added as the second item in the sales list', async() => {
- let searchValue = 'Melee weapon heavy shield 100cm';
- await page.autocompleteSearch(selectors.ticketSales.secondSaleIdAutocomplete, searchValue);
- await page.waitToClick(selectors.ticketSales.secondSaleQuantityCell);
- await page.type(selectors.ticketSales.secondSaleQuantity, '8');
- await page.keyboard.press('Enter');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should update the description of the new sale', async() => {
- await page.click(selectors.ticketSales.secondSaleConceptCell);
- await page.write(selectors.ticketSales.secondSaleConceptInput, 'Aegis of Valor');
- await page.keyboard.press('Enter');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should add a third empty item to the sale list', async() => {
- await page.waitToClick(selectors.ticketSales.newItemButton);
- await page.waitForNumberOfElements(selectors.ticketSales.saleLine, 3);
- const sales = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(sales).toEqual(3);
- });
-
- it('should select the 2nd and 3th item and delete both', async() => {
- await page.waitToClick(selectors.ticketSales.secondSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.thirdSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.deleteSaleButton);
- await page.waitToClick(selectors.globalItems.acceptButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should verify there's only 1 single line remaining`, async() => {
- const sales = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(sales).toEqual(1);
- });
-});
diff --git a/e2e/paths/05-ticket/01-sale/02_edit_sale.spec.js b/e2e/paths/05-ticket/01-sale/02_edit_sale.spec.js
deleted file mode 100644
index d9689e31a..000000000
--- a/e2e/paths/05-ticket/01-sale/02_edit_sale.spec.js
+++ /dev/null
@@ -1,415 +0,0 @@
-import selectors from '../../../helpers/selectors.js';
-import getBrowser from '../../../helpers/puppeteer';
-
-describe('Ticket Edit sale path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('salesPerson', 'ticket');
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should click on the first sale claim icon to navigate over there`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleClaimIcon);
- await page.waitForNavigation();
- await page.goBack();
- await page.goBack();
- });
-
- it('should navigate to the tickets index', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.ticketsButton);
- await page.waitForState('ticket.index');
- });
-
- it(`should search for a ticket and then navigate to it's sales`, async() => {
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- });
-
- it(`should set the ticket as libre`, async() => {
- const searchValue = 'libre';
- await page.waitToClick(selectors.ticketSales.stateMenuButton);
- await page.write(selectors.ticketSales.moreMenuState, searchValue);
- try {
- await page.waitForFunction(searchValue => {
- const element = document.querySelector('li.active');
- if (element)
- return element.innerText.toLowerCase().includes(searchValue.toLowerCase());
- }, {}, searchValue);
- } catch (error) {
- const builtSelector = await page.selectorFormater(selectors.ticketSales.moreMenuState);
- const inputValue = await page.evaluate(() => {
- return document.querySelector('.vn-drop-down.shown vn-textfield input').value;
- });
- throw new Error(`${builtSelector} value is ${inputValue}! ${error}`);
- }
- await page.waitForState('ticket.card.sale');
- await page.keyboard.press('Enter');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should check it's state is libre now`, async() => {
- await page.waitForTextInElement(selectors.ticketDescriptor.stateLabelValue, 'Libre');
- const result = await page.waitToGetProperty(selectors.ticketDescriptor.stateLabelValue, 'innerText');
-
- expect(result).toEqual('State Libre');
- });
-
- it(`should set the ticket as OK`, async() => {
- await page.waitToClick(selectors.ticketSales.setOk);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should check it's state is OK now`, async() => {
- await page.waitForTextInElement(selectors.ticketDescriptor.stateLabelValue, 'OK');
- const result = await page.waitToGetProperty(selectors.ticketDescriptor.stateLabelValue, 'innerText');
-
- expect(result).toEqual('State OK');
- });
-
- it(`should check the zoomed image isn't present`, async() => {
- const result = await page.countElement(selectors.ticketSales.firstSaleZoomedImage);
-
- expect(result).toEqual(0);
- });
-
- it(`should click on the thumbnail image of the 1st sale and see the zoomed image`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleThumbnailImage);
- const result = await page.countElement(selectors.ticketSales.firstSaleZoomedImage);
-
- expect(result).toEqual(1);
- });
-
- it(`should click on the zoomed image to close it`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleZoomedImage);
- const result = await page.countElement(selectors.ticketSales.firstSaleZoomedImage);
-
- expect(result).toEqual(0);
- });
-
- it(`should click on the first sale ID making now the item descriptor visible`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleId);
- await page.waitImgLoad(selectors.ticketSales.firstSaleDescriptorImage);
- const visible = await page.isVisible(selectors.ticketSales.saleDescriptorPopover);
-
- expect(visible).toBeTruthy();
- });
-
- it(`should click on the descriptor image of the 1st sale and see the zoomed image`, async() => {
- await page.waitToClick('vn-item-descriptor img');
- const result = await page.countElement(selectors.ticketSales.firstSaleZoomedImage);
-
- expect(result).toEqual(1);
- });
-
- it(`should now click on the zoomed image to close it`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleZoomedImage);
- const result = await page.countElement(selectors.ticketSales.firstSaleZoomedImage);
-
- expect(result).toEqual(0);
- });
-
- it(`should click on the summary icon of the item-descriptor to access to the item summary`, async() => {
- await page.waitToClick(selectors.ticketSales.saleDescriptorPopoverSummaryButton);
- await page.waitForState('item.card.summary');
- });
-
- it('should return to ticket sales section', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.ticketsButton);
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- });
-
- it('should remove 1 from the first sale quantity', async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleQuantityCell);
- await page.waitForSelector(selectors.ticketSales.firstSaleQuantity);
- await page.type(selectors.ticketSales.firstSaleQuantity, '9\u000d');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should update the price', async() => {
- await page.waitToClick(selectors.ticketSales.firstSalePrice);
- await page.waitForSelector(selectors.ticketSales.firstSalePriceInput);
- await page.type(selectors.ticketSales.firstSalePriceInput, '5\u000d');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the price have been updated', async() => {
- const result = await page.waitToGetProperty(selectors.ticketSales.firstSalePrice, 'innerText');
-
- expect(result).toContain('5.00');
- });
-
- it('should confirm the total price for that item have been updated', async() => {
- const result = await page.waitToGetProperty(selectors.ticketSales.firstSaleImport, 'innerText');
-
- expect(result).toContain('45.00');
- });
-
- it('should update the discount', async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleDiscount);
- await page.waitForSelector(selectors.ticketSales.firstSaleDiscountInput);
- await page.type(selectors.ticketSales.firstSaleDiscountInput, '50');
- await page.waitToClick(selectors.ticketSales.saveSaleDiscountButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the discount have been updated', async() => {
- await page.waitForTextInElement(selectors.ticketSales.firstSaleDiscount, '50.00%');
- const result = await page.waitToGetProperty(selectors.ticketSales.firstSaleDiscount, 'innerText');
-
- expect(result).toContain('50.00%');
- });
-
- it('should confirm the total import for that item have been updated', async() => {
- await page.waitForTextInElement(selectors.ticketSales.firstSaleImport, '22.50');
- const result = await page.waitToGetProperty(selectors.ticketSales.firstSaleImport, 'innerText');
-
- expect(result).toContain('22.50');
- });
-
- it('should recalculate price of sales', async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.secondSaleCheckbox);
-
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuRecalculatePrice);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should log in as salesAssistant and navigate to ticket sales', async() => {
- await page.loginAndModule('salesAssistant', 'ticket');
- await page.accessToSearchResult('15');
- await page.accessToSection('ticket.card.sale');
- });
-
- it('should select the first sale and create a refund with warehouse', async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuRefund);
- await page.waitToClick(selectors.ticketSales.refundWithWarehouse);
- await page.waitForSnackbar();
- await page.waitForState('ticket.card.sale');
- });
-
- it('should select the first sale and create a refund without warehouse', async() => {
- await page.accessToSearchResult('18');
- await page.waitToClick(selectors.ticketSales.firstSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuRefund);
- await page.waitToClick(selectors.ticketSales.refundWithoutWarehouse);
- await page.waitForSnackbar();
- await page.waitForState('ticket.card.sale');
- });
-
- it('should show error trying to delete a ticket with a refund', async() => {
- await page.loginAndModule('salesPerson', 'ticket');
- await page.accessToSearchResult('8');
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuDeleteTicket);
- await page.waitToClick(selectors.globalItems.acceptButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Tickets with associated refunds can\'t be deleted');
- await page.waitToClick(selectors.globalItems.cancelButton);
- });
-
- it('should select the third sale and create a claim of it', async() => {
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- await page.waitToClick(selectors.ticketSales.thirdSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuCreateClaim);
- await page.waitToClick(selectors.globalItems.acceptButton);
- await page.waitForNavigation();
- });
-
- it('should search for a ticket then access to the sales section', async() => {
- await page.goBack();
- await page.goBack();
- await page.loginAndModule('salesPerson', 'ticket');
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- });
-
- it('should select the third sale and delete it', async() => {
- await page.waitToClick(selectors.ticketSales.thirdSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.deleteSaleButton);
- await page.waitToClick(selectors.globalItems.acceptButton);
- await page.waitForSpinnerLoad();
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the third sale was deleted`, async() => {
- const result = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(result).toEqual(3);
- });
-
- it('should select the second sale and transfer it to a valid ticket', async() => {
- const targetTicketId = '12';
-
- await page.waitToClick(selectors.ticketSales.secondSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.transferSaleButton);
- await page.waitToClick(selectors.ticketSales.transferQuantityCell);
- await page.type(selectors.ticketSales.transferQuantityInput, '10\u000d');
- await page.type(selectors.ticketSales.moveToTicketInput, targetTicketId);
- await page.waitToClick(selectors.ticketSales.moveToTicketButton);
- await page.expectURL(`ticket/${targetTicketId}/sale`);
- });
-
- it('should confirm the transfered line is the correct one', async() => {
- await page.waitForSelector(selectors.ticketSales.secondSaleText);
- const result = await page.waitToGetProperty(selectors.ticketSales.secondSaleText, 'innerText');
-
- expect(result).toContain(`Melee weapon heavy shield`);
- });
-
- it('should confirm the transfered quantity is the correct one', async() => {
- const result = await page.waitToGetProperty(selectors.ticketSales.firstSaleQuantityCell, 'innerText');
-
- expect(result).toContain('20');
- });
-
- it('should go back to the original ticket sales section', async() => {
- await page.waitToClick(selectors.ticketDescriptor.goBackToModuleIndexButton);
- await page.accessToSearchResult('16');
- await page.accessToSection('ticket.card.sale');
- });
-
- it(`should confirm the original ticket has still three lines`, async() => {
- await page.waitForSelector(selectors.ticketSales.saleLine);
- const result = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(result).toEqual(3);
- });
-
- it(`should confirm the second sale quantity is now half of it's original value after the transfer`, async() => {
- const result = await page.waitToGetProperty(selectors.ticketSales.secondSaleQuantityCell, 'innerText');
-
- expect(result).toContain('10');
- });
-
- it('should go back to the receiver ticket sales section', async() => {
- await page.waitToClick(selectors.ticketDescriptor.goBackToModuleIndexButton);
- await page.accessToSearchResult('12');
- await page.accessToSection('ticket.card.sale');
- });
-
- it('should transfer the sale back to the original ticket', async() => {
- const targetTicketId = '16';
-
- await page.waitToClick(selectors.ticketSales.secondSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.transferSaleButton);
- await page.type(selectors.ticketSales.moveToTicketInput, targetTicketId);
- await page.waitToClick(selectors.ticketSales.moveToTicketButton);
- await page.expectURL(`ticket/${targetTicketId}/sale`);
- });
-
- it('should confirm the original ticket received the line', async() => {
- const expectedLines = 4;
- await page.waitForNumberOfElements(selectors.ticketSales.saleLine, expectedLines);
- const result = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(result).toEqual(expectedLines);
- });
-
- it(`should throw an error when attempting to create a ticket for an inactive client`, async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleCheckbox);
- await page.waitToClick(selectors.ticketSales.transferSaleButton);
- await page.waitToClick(selectors.ticketSales.moveToNewTicketButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(`You can't create a ticket for an inactive client`);
-
- await page.closePopup();
- });
-
- it('should go now to the ticket sales section of an active, not frozen client', async() => {
- await page.waitToClick(selectors.ticketDescriptor.goBackToModuleIndexButton);
- await page.accessToSearchResult('13');
- await page.accessToSection('ticket.card.sale');
- });
-
- it(`should select all sales, tranfer them to a new ticket and delete the sender ticket as it would've been left empty`, async() => {
- const senderTicketId = '13';
-
- await page.waitToClick(selectors.ticketSales.selectAllSalesCheckbox);
- await page.waitToClick(selectors.ticketSales.transferSaleButton);
- await page.waitToClick(selectors.ticketSales.moveToNewTicketButton);
- await page.evaluate((selector, ticketId) => {
- return document.querySelector(selector).innerText.toLowerCase().indexOf(`#${ticketId}`) == -1;
- }, selectors.ticketDescriptor.id, senderTicketId);
- await page.waitForState('ticket.card.sale');
- });
-
- it('should confirm the new ticket received the line', async() => {
- const expectedLines = 1;
- const result = await page.countElement(selectors.ticketSales.saleLine);
-
- expect(result).toEqual(expectedLines);
- });
-
- it('should check the first sale reserved icon isnt visible', async() => {
- const result = await page.isVisible(selectors.ticketSales.firstSaleReservedIcon);
-
- expect(result).toBeFalsy();
- });
-
- it('should mark the first sale as reserved', async() => {
- await page.waitToClick(selectors.ticketSales.firstSaleCheckbox);
-
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuReserve);
- await page.closePopup();
- await page.waitForClassNotPresent(selectors.ticketSales.firstSaleReservedIcon, 'ng-hide');
- const result = await page.isVisible(selectors.ticketSales.firstSaleReservedIcon);
-
- expect(result).toBeTruthy();
- });
-
- it('should unmark the first sale as reserved', async() => {
- await page.waitToClick(selectors.ticketSales.moreMenu);
- await page.waitToClick(selectors.ticketSales.moreMenuUnmarkReseved);
- await page.waitForClassPresent(selectors.ticketSales.firstSaleReservedIcon, 'ng-hide');
- const result = await page.isVisible(selectors.ticketSales.firstSaleReservedIcon);
-
- expect(result).toBeFalsy();
- });
-
- it('should log in as Production role and go to a target ticket summary', async() => {
- await page.loginAndModule('production', 'ticket');
- await page.accessToSearchResult('13');
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should check the ticket is deleted`, async() => {
- await page.waitForSelector(selectors.ticketDescriptor.isDeletedIcon);
- });
-});
diff --git a/e2e/paths/05-ticket/01_observations.spec.js b/e2e/paths/05-ticket/01_observations.spec.js
deleted file mode 100644
index cf37f9ff1..000000000
--- a/e2e/paths/05-ticket/01_observations.spec.js
+++ /dev/null
@@ -1,50 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Create notes path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('5');
- await page.accessToSection('ticket.card.observation');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should create a new note', async() => {
- await page.waitToClick(selectors.ticketNotes.addNoteButton);
- await page.autocompleteSearch(selectors.ticketNotes.firstNoteType, 'ItemPicker');
- await page.write(selectors.ticketNotes.firstDescription, 'description');
- await page.waitToClick(selectors.ticketNotes.submitNotesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the note is the expected one', async() => {
- await page.reloadSection('ticket.card.observation');
- const result = await page
- .waitToGetProperty(selectors.ticketNotes.firstNoteType, 'value');
-
- expect(result).toEqual('ItemPicker');
-
- const firstDescription = await page
- .waitToGetProperty(selectors.ticketNotes.firstDescription, 'value');
-
- expect(firstDescription).toEqual('description');
- });
-
- it('should delete the note', async() => {
- await page.waitToClick(selectors.ticketNotes.firstNoteRemoveButton);
- await page.waitToClick(selectors.ticketNotes.submitNotesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-});
diff --git a/e2e/paths/05-ticket/02_expeditions_and_log.spec.js b/e2e/paths/05-ticket/02_expeditions_and_log.spec.js
deleted file mode 100644
index 4e8005043..000000000
--- a/e2e/paths/05-ticket/02_expeditions_and_log.spec.js
+++ /dev/null
@@ -1,32 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket expeditions and log path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('production', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.expedition');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should delete a former expedition and confirm the remaining expedition are the expected ones`, async() => {
- await page.waitToClick(selectors.ticketExpedition.thirdSaleCheckbox);
- await page.waitToClick(selectors.ticketExpedition.deleteExpeditionButton);
- await page.waitToClick(selectors.globalItems.acceptButton);
- await page.reloadSection('ticket.card.expedition');
-
- await page.waitForSelector(selectors.ticketExpedition.expeditionRow, {});
- const result = await page
- .countElement(selectors.ticketExpedition.expeditionRow);
-
- expect(result).toEqual(6);
- });
-});
diff --git a/e2e/paths/05-ticket/04_packages.spec.js b/e2e/paths/05-ticket/04_packages.spec.js
deleted file mode 100644
index 1e6a0a173..000000000
--- a/e2e/paths/05-ticket/04_packages.spec.js
+++ /dev/null
@@ -1,78 +0,0 @@
-import getBrowser from '../../helpers/puppeteer';
-
-const $ = {
- firstPackage: 'vn-autocomplete[label="Package"]',
- firstQuantity: 'vn-ticket-package vn-horizontal:nth-child(1) vn-input-number[ng-model="package.quantity"]',
- firstRemovePackageButton: 'vn-icon-button[vn-tooltip="Remove package"]',
- addPackageButton: 'vn-icon-button[vn-tooltip="Add package"]',
- savePackagesButton: `button[type=submit]`
-};
-
-describe('Ticket Create packages path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.package');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should attempt create a new package but receive an error if package is blank`, async() => {
- await page.waitToClick($.firstRemovePackageButton);
- await page.waitToClick($.addPackageButton);
- await page.write($.firstQuantity, '99');
- await page.waitToClick($.savePackagesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Package cannot be blank');
- });
-
- it(`should delete the first package and receive and error to save a new one with blank quantity`, async() => {
- await page.clearInput($.firstQuantity);
- await page.autocompleteSearch($.firstPackage, 'Container medical box 100cm');
- await page.waitToClick($.savePackagesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Some fields are invalid');
- });
-
- it(`should confirm the quantity input isn't invalid yet`, async() => {
- const result = await page
- .evaluate(selector => {
- return document.querySelector(`${selector} input`).checkValidity();
- }, $.firstQuantity);
-
- expect(result).toBeTruthy();
- });
-
- it(`should create a new package with correct data`, async() => {
- await page.clearInput($.firstQuantity);
- await page.write($.firstQuantity, '-99');
- await page.waitToClick($.savePackagesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the first select is the expected one`, async() => {
- await page.reloadSection('ticket.card.package');
- await page.waitForTextInField($.firstPackage, 'Container medical box 100cm');
- const result = await page.waitToGetProperty($.firstPackage, 'value');
-
- expect(result).toEqual('Container medical box 100cm');
- });
-
- it(`should confirm quantity is just a number and the string part was ignored by the imput number`, async() => {
- await page.waitForTextInField($.firstQuantity, '-99');
- const result = await page.waitToGetProperty($.firstQuantity, 'value');
-
- expect(result).toEqual('-99');
- });
-});
diff --git a/e2e/paths/05-ticket/05_tracking_state.spec.js b/e2e/paths/05-ticket/05_tracking_state.spec.js
deleted file mode 100644
index 5cfc1c9d4..000000000
--- a/e2e/paths/05-ticket/05_tracking_state.spec.js
+++ /dev/null
@@ -1,72 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Create new tracking state path', () => {
- let browser;
- let page;
-
- afterAll(async() => {
- await browser.close();
- });
-
- describe('as production', () => {
- it('should log into the ticket 1 tracking', async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('production', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.tracking.index');
- });
-
- it('should access to the create state view by clicking the create floating button', async() => {
- await page.waitToClick(selectors.ticketTracking.createStateButton);
- await page.waitForSelector(selectors.createStateView.state, {visible: true});
- await page.waitForState('ticket.card.tracking.edit');
- });
-
- it(`should create a new state`, async() => {
- await page.autocompleteSearch(selectors.createStateView.state, 'OK');
- await page.waitToClick(selectors.createStateView.saveStateButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
- });
-
- describe('as salesPerson', () => {
- it('should now log into the ticket 1 tracking', async() => {
- await page.loginAndModule('salesPerson', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.tracking.index');
- });
-
- it('should now access to the create state view by clicking the create floating button', async() => {
- await page.waitForSelector('.vn-popup', {hidden: true});
- await page.waitToClick(selectors.ticketTracking.createStateButton);
- await page.waitForState('ticket.card.tracking.edit');
- });
-
- it(`should attemp to create an state for which salesPerson doesn't have permissions`, async() => {
- await page.autocompleteSearch(selectors.createStateView.state, 'Encajado');
- await page.waitToClick(selectors.createStateView.saveStateButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(`You don't have enough privileges`);
- });
-
- it(`should make sure the worker gets autocomplete uppon selecting the assigned state`, async() => {
- await page.autocompleteSearch(selectors.createStateView.state, 'asignado');
- const result = await page
- .waitToGetProperty(selectors.createStateView.worker, 'value');
-
- expect(result).toEqual('salesperson');
- });
-
- it(`should succesfully create a valid state`, async() => {
- await page.waitToClick(selectors.createStateView.saveStateButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
- });
-});
diff --git a/e2e/paths/05-ticket/06_basic_data_steps.spec.js b/e2e/paths/05-ticket/06_basic_data_steps.spec.js
deleted file mode 100644
index 77f0e0459..000000000
--- a/e2e/paths/05-ticket/06_basic_data_steps.spec.js
+++ /dev/null
@@ -1,143 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Edit basic data path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('11');
- await page.accessToSection('ticket.card.basicData.stepOne');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should confirm the zone autocomplete is disabled unless your role is productionBoss`, async() => {
- await page.waitForSelector(selectors.ticketBasicData.zone, {});
- const disabled = await page.evaluate(selector => {
- return document.querySelector(selector).disabled;
- }, `${selectors.ticketBasicData.zone} input`);
-
- expect(disabled).toBeTruthy();
- });
-
- it(`should now log as productionBoss to perform the rest of the tests`, async() => {
- await page.loginAndModule('productionBoss', 'ticket');
- await page.accessToSearchResult('11');
- await page.accessToSection('ticket.card.basicData.stepOne');
- });
-
- it(`should confirm the zone autocomplete is enabled for the role productionBoss`, async() => {
- await page.waitForSpinnerLoad();
- await page.waitForSelector(selectors.ticketBasicData.zone);
- const disabled = await page.evaluate(selector => {
- return document.querySelector(selector).disabled;
- }, `${selectors.ticketBasicData.zone} input`);
-
- expect(disabled).toBeFalsy();
- });
-
- it(`should check the zone is for Gotham247`, async() => {
- let zone = await page
- .waitToGetProperty(selectors.ticketBasicData.zone, 'value');
-
- expect(zone).toContain('Zone 247 A');
- });
-
- it(`should edit the ticket agency then check there are no zones for it`, async() => {
- await page.autocompleteSearch(selectors.ticketBasicData.agency, 'Super-Man delivery');
- let emptyZone = await page
- .expectPropertyValue(selectors.ticketBasicData.zone, 'value', '');
-
- expect(emptyZone).toBeTruthy();
- });
-
- it(`should edit the ticket zone then check the agency is for the new zone`, async() => {
- await page.clearInput(selectors.ticketBasicData.agency);
- await page.autocompleteSearch(selectors.ticketBasicData.zone, 'Zone expensive A');
- let zone = await page
- .waitToGetProperty(selectors.ticketBasicData.agency, 'value');
-
- expect(zone).toContain('Gotham247Expensive');
- });
-
- it(`should click next`, async() => {
- await page.waitToClick(selectors.ticketBasicData.nextStepButton);
- await page.waitForState('ticket.card.basicData.stepTwo');
- });
-
- it(`should have a price diference`, async() => {
- const result = await page
- .waitToGetProperty(selectors.ticketBasicData.stepTwoTotalPriceDif, 'innerText');
-
- expect(result).toContain('-€228.25');
- });
-
- it(`should select a new reason for the changes made then click on finalize`, async() => {
- await page.waitToClick(selectors.ticketBasicData.chargesReason);
- await page.waitToClick(selectors.ticketBasicData.finalizeButton);
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should not find ticket`, async() => {
- await page.doSearch('29');
- const count = await page.countElement(selectors.ticketsIndex.searchResult);
-
- expect(count).toEqual(0);
- });
-
- it(`should split ticket without negatives`, async() => {
- const newAgency = 'Gotham247';
- const newDate = Date.vnNew();
- newDate.setDate(newDate.getDate() - 1);
-
- await page.accessToSearchResult('14');
- await page.accessToSection('ticket.card.basicData.stepOne');
-
- await page.autocompleteSearch(selectors.ticketBasicData.agency, newAgency);
- await page.pickDate(selectors.ticketBasicData.shipped, newDate);
-
- await page.waitToClick(selectors.ticketBasicData.nextStepButton);
-
- await page.waitToClick(selectors.ticketBasicData.finalizeButton);
-
- await page.waitForState('ticket.card.summary');
-
- const newTicketAgency = await page
- .waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryAgency, 'innerText');
- const newTicketDate = await page
- .waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryDate, 'innerText');
-
- expect(newAgency).toEqual(newTicketAgency);
- expect(newTicketDate).toContain(newDate.getDate());
- });
-
- it(`should new ticket have sale of old ticket`, async() => {
- await page.accessToSection('ticket.card.sale');
- await page.waitForState('ticket.card.sale');
-
- const item = await page.waitToGetProperty(selectors.ticketSales.firstSaleId, 'innerText');
-
- expect(item).toEqual('4');
- });
-
- it(`should old ticket have old date and agency`, async() => {
- const oldDate = Date.vnNew();
- const oldAgency = 'Super-Man delivery';
-
- await page.accessToSearchResult('14');
-
- const oldTicketAgency = await page
- .waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryAgency, 'innerText');
- const oldTicketDate = await page
- .waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryDate, 'innerText');
-
- expect(oldTicketAgency).toEqual(oldAgency);
- expect(oldTicketDate).toContain(oldDate.getDate());
- });
-});
diff --git a/e2e/paths/05-ticket/08_components.spec.js b/e2e/paths/05-ticket/08_components.spec.js
deleted file mode 100644
index ab2aa85b2..000000000
--- a/e2e/paths/05-ticket/08_components.spec.js
+++ /dev/null
@@ -1,30 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket List components path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.components');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should confirm the total base is correct', async() => {
- const name = 'Base €';
- const minLength = name.length;
-
- await page.waitPropertyLength(selectors.ticketComponents.base, 'innerText', minLength);
- const base = await page.waitToGetProperty(selectors.ticketComponents.base, 'innerText');
-
- expect(base).toContain('Base');
- expect(base.length).toBeGreaterThan(minLength);
- });
-});
diff --git a/e2e/paths/05-ticket/09_weekly.spec.js b/e2e/paths/05-ticket/09_weekly.spec.js
deleted file mode 100644
index 370d422e6..000000000
--- a/e2e/paths/05-ticket/09_weekly.spec.js
+++ /dev/null
@@ -1,123 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket descriptor path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('buyerBoss', 'ticket');
- await page.accessToSection('ticket.weekly.index');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should count the amount of tickets in the turns section', async() => {
- const result = await page.countElement(selectors.ticketsIndex.weeklyTicket);
-
- expect(result).toEqual(6);
- });
-
- it('should go back to the ticket index then search and access a ticket summary', async() => {
- await page.accessToSection('ticket.index');
- await page.accessToSearchResult('33');
- });
-
- it('should add the ticket to thursday turn using the descriptor more menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuAddToTurn);
- await page.waitToClick(selectors.ticketDescriptor.thursdayButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Current ticket deleted and added to shift');
- });
-
- it('should again click on the Tickets button of the top bar menu', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.ticketsButton);
- await page.waitForState('ticket.index');
- });
-
- it('should confirm the ticket 33 was added to thursday', async() => {
- await page.accessToSection('ticket.weekly.index');
- const result = await page.waitToGetProperty(selectors.ticketsIndex.thirdWeeklyTicket, 'value');
-
- expect(result).toEqual('Thursday');
- });
-
- it('should click on the Tickets button of the top bar menu once more', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.ticketsButton);
- await page.waitForState('ticket.index');
- });
-
- it('should now search for the ticket 33', async() => {
- await page.accessToSearchResult('33');
- await page.waitForState('ticket.card.summary');
- });
-
- it('should add the ticket to saturday turn using the descriptor more menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuAddToTurn);
- await page.waitToClick(selectors.ticketDescriptor.saturdayButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Current ticket deleted and added to shift');
- });
-
- it('should click on the Tickets button of the top bar menu once again', async() => {
- await page.waitToClick(selectors.globalItems.applicationsMenuButton);
- await page.waitForSelector(selectors.globalItems.applicationsMenuVisible);
- await page.waitToClick(selectors.globalItems.ticketsButton);
- await page.waitForState('ticket.index');
- });
-
- it('should confirm the ticket 33 was added on saturday', async() => {
- await page.accessToSection('ticket.weekly.index');
- await page.waitForTimeout(5000);
-
- const result = await page.waitToGetProperty(selectors.ticketsIndex.thirdWeeklyTicket, 'value');
-
- expect(result).toEqual('Saturday');
- });
-
- it('should now search for the weekly ticket 33', async() => {
- await page.doSearch('33');
- const nResults = await page.countElement(selectors.ticketsIndex.searchWeeklyResult);
-
- expect(nResults).toEqual(2);
- });
-
- it('should delete the weekly ticket 33', async() => {
- await page.waitToClick(selectors.ticketsIndex.firstWeeklyTicketDeleteIcon);
- await page.waitToClick(selectors.ticketsIndex.acceptDeleteTurn);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the sixth weekly ticket was deleted', async() => {
- await page.doSearch();
- const nResults = await page.countElement(selectors.ticketsIndex.searchWeeklyResult);
-
- expect(nResults).toEqual(6);
- });
-
- it('should update the agency then remove it afterwards', async() => {
- await page.autocompleteSearch(selectors.ticketsIndex.firstWeeklyTicketAgency, 'Gotham247');
- let message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
-
- await page.clearInput(selectors.ticketsIndex.firstWeeklyTicketAgency);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-});
diff --git a/e2e/paths/05-ticket/10_request.spec.js b/e2e/paths/05-ticket/10_request.spec.js
deleted file mode 100644
index 1b580aec2..000000000
--- a/e2e/paths/05-ticket/10_request.spec.js
+++ /dev/null
@@ -1,77 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket purchase request path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('salesPerson', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.request.index');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should add a new request', async() => {
- await page.waitToClick(selectors.ticketRequests.addRequestButton);
- await page.write(selectors.ticketRequests.descriptionInput, 'New stuff');
- await page.write(selectors.ticketRequests.quantity, '9');
- await page.autocompleteSearch(selectors.ticketRequests.atender, 'buyerNick');
- await page.write(selectors.ticketRequests.price, '999');
- await page.waitToClick(selectors.ticketRequests.saveButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should have been redirected to the request index', async() => {
- await page.waitForState('ticket.card.request.index');
- });
-
- it(`should edit the third request quantity as it's state is still new`, async() => {
- await page.write(selectors.ticketRequests.thirdRequestQuantity, '9');
- await page.keyboard.press('Enter');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should check the new request was added', async() => {
- await page.reloadSection('ticket.card.request.index');
- const result = await page.waitToGetProperty(selectors.ticketRequests.thirdRequestQuantity, 'value');
-
- expect(result).toEqual('99');
- });
-
- it(`should check the first request can't be edited as its state is different to new`, async() => {
- await page.waitForClassPresent(selectors.ticketRequests.firstRequestQuantity, 'disabled');
- const result = await page.isDisabled(selectors.ticketRequests.firstRequestQuantity);
-
- expect(result).toBe(true);
- });
-
- it(`should check the second request can't be edited as its state is different to new`, async() => {
- await page.waitForClassPresent(selectors.ticketRequests.secondRequestQuantity, 'disabled');
- const result = await page.isDisabled(selectors.ticketRequests.secondRequestQuantity);
-
- expect(result).toBe(true);
- });
-
- it('should delete the added request', async() => {
- await page.waitToClick(selectors.ticketRequests.thirdRemoveRequestButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should check the request was deleted', async() => {
- await page.reloadSection('ticket.card.request.index');
- await page.waitForSelector(selectors.ticketRequests.addRequestButton);
- await page.waitForSelector(selectors.ticketRequests.thirdDescription, {hidden: true});
- });
-});
diff --git a/e2e/paths/05-ticket/12_descriptor.spec.js b/e2e/paths/05-ticket/12_descriptor.spec.js
deleted file mode 100644
index 95a114c45..000000000
--- a/e2e/paths/05-ticket/12_descriptor.spec.js
+++ /dev/null
@@ -1,148 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket descriptor path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('salesperson', 'ticket');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- describe('Delete ticket', () => {
- it('should search for an specific ticket', async() => {
- await page.accessToSearchResult('18');
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should update the shipped hour using the descriptor menu`, async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuChangeShippedHour);
- await page.pickTime(selectors.ticketDescriptor.changeShippedHour, '08:15');
- await page.waitToClick(selectors.ticketDescriptor.acceptChangeHourButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Shipped hour updated');
- });
-
- it(`should confirm the ticket descriptor shows the correct shipping hour`, async() => {
- await page.waitForState('ticket.card.summary');
- const result = await page
- .waitToGetProperty(selectors.ticketDescriptor.descriptorDeliveryDate, 'innerText');
-
- expect(result).toContain('08:15');
- });
-
- it('should delete the ticket using the descriptor menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuDeleteTicket);
- await page.waitToClick(selectors.ticketDescriptor.acceptDialog);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Ticket deleted. You can undo this action within the first hour');
- });
-
- it('should have been relocated to the ticket index', async() => {
- await page.waitForState('ticket.index');
- });
-
- it(`should search for the deleted ticket and check the deletedTicket icon and it's date`, async() => {
- await page.write(selectors.ticketsIndex.topbarSearch, '18');
- await page.waitToClick(selectors.globalItems.searchButton);
- await page.waitForState('ticket.card.summary');
- await page.isVisible(selectors.ticketDescriptor.isDeletedIcon);
- const result = await page.waitToGetProperty(selectors.ticketsIndex.searchResultDate, 'innerText');
-
- expect(result).toContain(2000);
- });
- });
-
- describe('Restore ticket', () => {
- it('should restore the ticket using the descriptor menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuRestoreTicket);
- await page.waitToClick(selectors.ticketDescriptor.acceptDialog);
- await page.waitForState('ticket.card.summary');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
- });
-
- describe('Make invoice', () => {
- it('should login as administrative role then search for a ticket', async() => {
- const invoiceableTicketId = '14';
-
- await page.loginAndModule('administrative', 'ticket');
- await page.accessToSearchResult(invoiceableTicketId);
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should make sure the ticket doesn't have an invoiceOutFk yet`, async() => {
- const result = await page
- .waitToGetProperty(selectors.ticketSummary.invoiceOutRef, 'innerText');
-
- expect(result).toEqual('-');
- });
-
- it('should invoice the ticket using the descriptor menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitForContentLoaded();
- await page.waitToClick(selectors.ticketDescriptor.moreMenuMakeInvoice);
- await page.waitToClick(selectors.ticketDescriptor.acceptInvoiceOutButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Ticket invoiced');
- });
-
- it(`should make sure the ticket summary have an invoiceOutFk`, async() => {
- await page.waitForTextInElement(selectors.ticketSummary.invoiceOutRef, 'T4444445');
- const result = await page.waitToGetProperty(selectors.ticketSummary.invoiceOutRef, 'innerText');
-
- expect(result).toEqual('T4444445');
- });
-
- it(`should regenerate the invoice using the descriptor menu`, async() => {
- const expectedMessage = 'The invoice PDF document has been regenerated';
-
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitForContentLoaded();
- await page.waitToClick(selectors.ticketDescriptor.moreMenuRegenerateInvoice);
- await page.respondToDialog('accept');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(expectedMessage);
- });
- });
-
- describe('SMS', () => {
- it('should send the payment SMS using the descriptor menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuSMSOptions);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuPaymentSMS);
- await page.waitForSelector(selectors.ticketDescriptor.SMStext);
- await page.waitPropertyLength(selectors.ticketDescriptor.SMStext, 'value', 128);
- await page.waitToClick(selectors.ticketDescriptor.sendSMSbutton);
- const message = await page.waitForSnackbar();
-
- expect(message).toBeDefined();
- });
-
- it('should send the import SMS using the descriptor menu', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenuSMSOptions);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuSendImportSms);
- await page.waitForSelector(selectors.ticketDescriptor.SMStext);
- await page.waitPropertyLength(selectors.ticketDescriptor.SMStext, 'value', 144);
- await page.waitToClick(selectors.ticketDescriptor.sendSMSbutton);
- const message = await page.waitForSnackbar();
-
- expect(message).toBeDefined();
- });
- });
-});
diff --git a/e2e/paths/05-ticket/13_services.spec.js b/e2e/paths/05-ticket/13_services.spec.js
deleted file mode 100644
index 50df23582..000000000
--- a/e2e/paths/05-ticket/13_services.spec.js
+++ /dev/null
@@ -1,127 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket services path', () => {
- let browser;
- let page;
- const invoicedTicketId = '1';
-
- afterAll(async() => {
- await browser.close();
- });
-
- describe('as employee', () => {
- it('should log in as employee, search for an invoice and get to services', async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult(invoicedTicketId);
- await page.accessToSection('ticket.card.service');
- });
-
- it('should find the add descripton button disabled for this user role', async() => {
- await page.waitForClassPresent(selectors.ticketService.firstAddServiceTypeButton, 'disabled');
- await page.waitToClick(selectors.ticketService.addServiceButton);
- await page.waitForSelector(selectors.ticketService.firstAddServiceTypeButton);
- const disabled = await page.isDisabled(selectors.ticketService.firstAddServiceTypeButton);
-
- expect(disabled).toBe(true);
- });
-
- it('should receive an error if you attempt to save a service without access rights', async() => {
- await page.clearInput(selectors.ticketService.firstPrice);
- await page.write(selectors.ticketService.firstPrice, '999');
- await page.waitToClick(selectors.ticketService.saveServiceButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(`The current ticket can't be modified`);
- });
- });
-
- describe('as administrative', () => {
- let editableTicketId = '16';
- it('should navigate to the services of a target ticket', async() => {
- await page.loginAndModule('administrative', 'ticket');
- await page.accessToSearchResult(editableTicketId);
- await page.accessToSection('ticket.card.service');
- });
-
- it('should click on the add button to prepare the form to create a new service', async() => {
- await page.waitToClick(selectors.ticketService.addServiceButton);
- const result = await page
- .isVisible(selectors.ticketService.firstServiceType);
-
- expect(result).toBeTruthy();
- });
-
- it('should receive an error if you attempt to save it with empty fields', async() => {
- await page.waitToClick(selectors.ticketService.saveServiceButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(`can't be blank`);
- });
-
- it('should click on the add new service type to open the dialog', async() => {
- await page.waitToClick(selectors.ticketService.firstAddServiceTypeButton);
- await page.waitForSelector('.vn-dialog.shown');
- const result = await page.isVisible(selectors.ticketService.newServiceTypeName);
-
- expect(result).toBeTruthy();
- });
-
- it('should receive an error if service type is empty on submit', async() => {
- await page.waitToClick(selectors.ticketService.saveServiceTypeButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain(`Name can't be empty`);
- });
-
- it('should create a new service type then add price then create the service', async() => {
- await page.write(selectors.ticketService.newServiceTypeName, 'Documentos');
- await page.waitToClick(selectors.ticketService.saveServiceTypeButton);
- await page.write(selectors.ticketService.firstPrice, '999');
- await page.waitToClick(selectors.ticketService.saveServiceButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the service description was created correctly', async() => {
- await page.reloadSection('ticket.card.service');
- const result = await page
- .waitToGetProperty(selectors.ticketService.firstServiceType, 'value');
-
- expect(result).toEqual('Documentos');
- });
-
- it('should confirm the service quantity was created correctly', async() => {
- const result = await page
- .waitToGetProperty(selectors.ticketService.firstQuantity, 'value');
-
- expect(result).toEqual('1');
- });
-
- it('should confirm the service price was created correctly', async() => {
- const result = await page
- .waitToGetProperty(selectors.ticketService.firstPrice, 'value');
-
- expect(result).toEqual('999');
- });
-
- it('should delete the service', async() => {
- await page.waitToClick(selectors.ticketService.fistDeleteServiceButton);
- await page.waitForNumberOfElements(selectors.ticketService.serviceLine, 0);
- await page.waitToClick(selectors.ticketService.saveServiceButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should confirm the service was removed`, async() => {
- await page.reloadSection('ticket.card.service');
- const nResults = await page.countElement(selectors.ticketService.serviceLine);
-
- expect(nResults).toEqual(0);
- });
- });
-});
diff --git a/e2e/paths/05-ticket/14_create_ticket.spec.js b/e2e/paths/05-ticket/14_create_ticket.spec.js
deleted file mode 100644
index 1f9c0c40a..000000000
--- a/e2e/paths/05-ticket/14_create_ticket.spec.js
+++ /dev/null
@@ -1,69 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket create path', () => {
- let browser;
- let page;
- let nextMonth = Date.vnNew();
- nextMonth.setMonth(nextMonth.getMonth() + 1);
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('salesPerson', 'ticket');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should open the new ticket form', async() => {
- await page.waitToClick(selectors.ticketsIndex.newTicketButton);
- await page.waitForState('ticket.create');
- });
-
- it('should succeed to create a ticket', async() => {
- await page.autocompleteSearch(selectors.createTicketView.client, 'Clark Kent');
- await page.pickDate(selectors.createTicketView.deliveryDate, nextMonth);
- await page.autocompleteSearch(selectors.createTicketView.warehouse, 'Warehouse Two');
- await page.autocompleteSearch(selectors.createTicketView.agency, 'Gotham247');
- await page.waitToClick(selectors.createTicketView.createButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should check the url is now the summary of the ticket', async() => {
- await page.waitForState('ticket.card.summary');
- });
-
- it('should again open the new ticket form', async() => {
- await page.waitToClick(selectors.globalItems.returnToModuleIndexButton);
- await page.waitToClick(selectors.ticketsIndex.newTicketButton);
- await page.waitForState('ticket.create');
- });
-
- it('should succeed to create another ticket for the same client', async() => {
- await page.autocompleteSearch(selectors.createTicketView.client, 'Clark Kent');
- await page.pickDate(selectors.createTicketView.deliveryDate, nextMonth);
- await page.autocompleteSearch(selectors.createTicketView.warehouse, 'Warehouse One');
- await page.autocompleteSearch(selectors.createTicketView.agency, 'Gotham247');
- await page.waitToClick(selectors.createTicketView.createButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should check the url is now the summary of the created ticket', async() => {
- await page.waitForState('ticket.card.summary');
- });
-
- it('should delete the current ticket', async() => {
- await page.waitToClick(selectors.ticketDescriptor.moreMenu);
- await page.waitToClick(selectors.ticketDescriptor.moreMenuDeleteTicket);
- await page.waitToClick(selectors.ticketDescriptor.acceptDialog);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Ticket deleted. You can undo this action within the first hour');
- });
-});
diff --git a/e2e/paths/05-ticket/15_create_ticket_from_client.spec.js b/e2e/paths/05-ticket/15_create_ticket_from_client.spec.js
deleted file mode 100644
index 51ead6461..000000000
--- a/e2e/paths/05-ticket/15_create_ticket_from_client.spec.js
+++ /dev/null
@@ -1,37 +0,0 @@
-import getBrowser from '../../helpers/puppeteer';
-
-const $ = {
- form: 'vn-ticket-create-card',
- moreMenu: 'vn-client-descriptor vn-icon-button[icon=more_vert]',
- simpleTicketButton: '.vn-menu [name="simpleTicket"]'
-};
-
-describe('Ticket create from client path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'client');
- await page.accessToSearchResult('Petter Parker');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should create simple ticket and check if the client details are the expected ones', async() => {
- await page.waitToClick($.moreMenu);
- await page.waitToClick($.simpleTicketButton);
- await page.waitForState('ticket.create');
-
- const values = {
- client: 'Petter Parker',
- address: 'Petter Parker'
- };
- const formValues = await page.fetchForm($.form, Object.keys(values));
-
- expect(formValues).toEqual(values);
- });
-});
diff --git a/e2e/paths/05-ticket/16_summary.spec.js b/e2e/paths/05-ticket/16_summary.spec.js
deleted file mode 100644
index a6017e454..000000000
--- a/e2e/paths/05-ticket/16_summary.spec.js
+++ /dev/null
@@ -1,108 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Summary path', () => {
- let browser;
- let page;
- const ticketId = '20';
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should navigate to the target ticket summary section', async() => {
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult(ticketId);
- await page.waitForState('ticket.card.summary');
- });
-
- it(`should display details from the ticket and it's client on the top of the header`, async() => {
- await page.waitForTextInElement(selectors.ticketSummary.header, 'Bruce Banner');
- const result = await page.waitToGetProperty(selectors.ticketSummary.header, 'innerText');
-
- expect(result).toContain(`Ticket #${ticketId}`);
- expect(result).toContain('Bruce Banner (1109)');
- expect(result).toContain('Somewhere in Thailand');
- });
-
- it('should display ticket details', async() => {
- let result = await page
- .waitToGetProperty(selectors.ticketSummary.state, 'innerText');
-
- expect(result).toContain('Arreglar');
- });
-
- it('should display delivery details', async() => {
- let result = await page
- .waitToGetProperty(selectors.ticketSummary.route, 'innerText');
-
- expect(result).toContain('3');
- });
-
- it('should display the ticket total', async() => {
- let result = await page
- .waitToGetProperty(selectors.ticketSummary.total, 'innerText');
-
- expect(result).toContain('€155.54');
- });
-
- it('should display the ticket line(s)', async() => {
- let result = await page
- .waitToGetProperty(selectors.ticketSummary.firstSaleItemId, 'innerText');
-
- expect(result).toContain('2');
- });
-
- it(`should click on the first sale ID to make the item descriptor visible`, async() => {
- await page.waitToClick(selectors.ticketSummary.firstSaleItemId);
- await page.waitImgLoad(selectors.ticketSummary.firstSaleDescriptorImage);
- const visible = await page.isVisible(selectors.ticketSummary.itemDescriptorPopover);
-
- expect(visible).toBeTruthy();
- });
-
- it(`should check the url for the item diary link of the descriptor is for the right item id`, async() => {
- await page.waitForSelector(selectors.ticketSummary.itemDescriptorPopoverItemDiaryButton, {visible: true});
- });
-
- it('should log in as production then navigate to the summary of the same ticket', async() => {
- await page.loginAndModule('production', 'ticket');
- await page.accessToSearchResult(ticketId);
- await page.waitForState('ticket.card.summary');
- });
-
- it('should set the ticket state to OK using the top right button', async() => {
- const searchValue = 'OK';
- await page.waitToClick(selectors.ticketSummary.stateButton);
- await page.write(selectors.ticketSummary.stateAutocomplete, searchValue);
- try {
- await page.waitForFunction(text => {
- const element = document.querySelector('li.active');
- if (element)
- return element.innerText.toLowerCase().includes(text.toLowerCase());
- }, {}, searchValue);
- } catch (error) {
- const state = await page.evaluate(() => {
- const stateSelector = 'vn-ticket-summary vn-label-value:nth-child(1) > section > span';
- return document.querySelector(stateSelector).value;
- });
- throw new Error(`${stateSelector} innerText is ${state}! ${error}`);
- }
- await page.keyboard.press('Enter');
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it('should confirm the ticket state was updated', async() => {
- await page.waitForSpinnerLoad();
- const result = await page.waitToGetProperty(selectors.ticketSummary.state, 'innerText');
-
- expect(result).toContain('OK');
- });
-});
diff --git a/e2e/paths/05-ticket/17_log.spec.js b/e2e/paths/05-ticket/17_log.spec.js
deleted file mode 100644
index e1da2df44..000000000
--- a/e2e/paths/05-ticket/17_log.spec.js
+++ /dev/null
@@ -1,34 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket log path', () => {
- let browser;
- let page;
- const ticketId = '5';
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should navigate to the target ticket notes section', async() => {
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult(ticketId);
- await page.accessToSection('ticket.card.observation');
- await page.waitForState('ticket.card.observation');
- });
-
- it('should create a new note for the test', async() => {
- await page.waitToClick(selectors.ticketNotes.addNoteButton);
- await page.autocompleteSearch(selectors.ticketNotes.firstNoteType, 'ItemPicker');
- await page.write(selectors.ticketNotes.firstDescription, 'description');
- await page.waitToClick(selectors.ticketNotes.submitNotesButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-});
diff --git a/e2e/paths/05-ticket/18_index_payout.spec.js b/e2e/paths/05-ticket/18_index_payout.spec.js
deleted file mode 100644
index 9c5518424..000000000
--- a/e2e/paths/05-ticket/18_index_payout.spec.js
+++ /dev/null
@@ -1,70 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-const $ = {
- newPayment: '.vn-dialog.shown',
- anyBalanceLine: 'vn-client-balance-index vn-tbody > vn-tr',
- firstLineReference: 'vn-client-balance-index vn-tbody > vn-tr:nth-child(1) > vn-td-editable'
-};
-
-describe('Ticket index payout path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('administrative', 'ticket');
- await page.waitForState('ticket.index');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should check the second ticket from a client and 1 of another', async() => {
- await page.waitToClick(selectors.globalItems.searchButton);
- await page.waitToClick(selectors.ticketsIndex.thirdTicketCheckbox);
- await page.waitToClick(selectors.ticketsIndex.fifthTicketCheckbox);
- await page.waitToClick(selectors.ticketsIndex.payoutButton);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('You cannot make a payment on account from multiple clients');
- });
-
- it('should search for tickets of the same client then open the payout form', async() => {
- await page.waitToClick(selectors.ticketsIndex.openAdvancedSearchButton);
- await page.write(selectors.ticketsIndex.advancedSearchClient, '1101');
- await page.keyboard.press('Enter');
- await page.waitForNumberOfElements(selectors.ticketsIndex.anySearchResult, 10);
- await page.waitToClick(selectors.ticketsIndex.firstTicketCheckbox);
- await page.waitToClick(selectors.ticketsIndex.secondTicketCheckbox);
-
- await page.waitToClick(selectors.ticketsIndex.payoutButton);
-
- await page.waitForSelector(selectors.ticketsIndex.payoutCompany);
- });
-
- it('should fill the company and bank to perform a payout and check a new balance line was entered', async() => {
- await page.fillForm($.newPayment, {
- company: 'VNL',
- bank: 'cash',
- amountPaid: 100,
- description: 'Payment',
- viewReceipt: false
- });
- await page.respondToDialog('accept');
- const message = await page.waitForSnackbar();
-
- await page.waitToClick(selectors.globalItems.homeButton);
- await page.selectModule('client');
- await page.accessToSearchResult('1101');
- await page.accessToSection('client.card.balance.index');
- await page.waitForSelector($.anyBalanceLine);
- const count = await page.countElement($.anyBalanceLine);
- const reference = await page.innerText($.firstLineReference);
-
- expect(message.isSuccess).toBeTrue();
- expect(count).toEqual(4);
- expect(reference).toContain('Payment');
- });
-});
diff --git a/e2e/paths/05-ticket/19_dms.spec.js b/e2e/paths/05-ticket/19_dms.spec.js
deleted file mode 100644
index be2ac4338..000000000
--- a/e2e/paths/05-ticket/19_dms.spec.js
+++ /dev/null
@@ -1,49 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket DMS path', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.dms.index');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should import a document', async() => {
- await page.waitToClick(selectors.ticketDms.import);
- await page.autocompleteSearch(selectors.ticketDms.document, '1');
- await page.waitToClick(selectors.ticketDms.saveImport);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Data saved!');
- });
-
- it(`should check there's a listed document now`, async() => {
- const result = await page.countElement(selectors.ticketDms.anyDocument);
-
- expect(result).toEqual(1);
- });
-
- it('should attempt to import an existing document on this ticket', async() => {
- await page.waitToClick(selectors.ticketDms.import);
- await page.autocompleteSearch(selectors.ticketDms.document, '1');
- await page.waitToClick(selectors.ticketDms.saveImport);
- const message = await page.waitForSnackbar();
-
- expect(message.text).toContain('This document already exists on this ticket');
- });
-
- it(`should check there's still one document`, async() => {
- const result = await page.countElement(selectors.ticketDms.anyDocument);
-
- expect(result).toEqual(1);
- });
-});
diff --git a/e2e/paths/05-ticket/20_moveExpedition.spec.js b/e2e/paths/05-ticket/20_moveExpedition.spec.js
deleted file mode 100644
index ae23c9c99..000000000
--- a/e2e/paths/05-ticket/20_moveExpedition.spec.js
+++ /dev/null
@@ -1,50 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket expeditions', () => {
- let browser;
- let page;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('production', 'ticket');
- await page.accessToSearchResult('1');
- await page.accessToSection('ticket.card.expedition');
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it(`should move one expedition to new ticket withoute route`, async() => {
- await page.waitToClick(selectors.ticketExpedition.thirdSaleCheckbox);
- await page.waitToClick(selectors.ticketExpedition.moveExpeditionButton);
- await page.waitToClick(selectors.ticketExpedition.moreMenuWithoutRoute);
- await page.waitToClick(selectors.ticketExpedition.saveButton);
- await page.waitForState('ticket.card.summary');
- await page.accessToSection('ticket.card.expedition');
-
- await page.waitForSelector(selectors.ticketExpedition.expeditionRow, {});
- const result = await page
- .countElement(selectors.ticketExpedition.expeditionRow);
-
- expect(result).toEqual(2);
- });
-
- it(`should move one expedition to new ticket with route`, async() => {
- await page.waitToClick(selectors.ticketExpedition.firstSaleCheckbox);
- await page.waitToClick(selectors.ticketExpedition.moveExpeditionButton);
- await page.waitToClick(selectors.ticketExpedition.moreMenuWithRoute);
- await page.write(selectors.ticketExpedition.newRouteId, '1');
- await page.waitToClick(selectors.ticketExpedition.saveButton);
- await page.waitForState('ticket.card.summary');
- await page.accessToSection('ticket.card.expedition');
-
- await page.waitForSelector(selectors.ticketExpedition.expeditionRow, {});
- const result = await page
- .countElement(selectors.ticketExpedition.expeditionRow);
-
- expect(result).toEqual(2);
- });
-});
diff --git a/e2e/paths/05-ticket/21_future.spec.js b/e2e/paths/05-ticket/21_future.spec.js
deleted file mode 100644
index 60bb9c38d..000000000
--- a/e2e/paths/05-ticket/21_future.spec.js
+++ /dev/null
@@ -1,99 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Future path', () => {
- let browser;
- let page;
- let httpRequest;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSection('ticket.future');
- page.on('request', req => {
- if (req.url().includes(`Tickets/getTicketsFuture`))
- httpRequest = req.url();
- });
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should search with required data, check three last tickets and move to the future', async() => {
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketFuture.warehouseFk);
- await page.waitToClick(selectors.ticketFuture.submit);
- let message = await page.waitForSnackbar();
-
- expect(message.text).toContain('warehouseFk is a required argument');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketFuture.futureScopeDays);
- await page.waitToClick(selectors.ticketFuture.submit);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('futureScopeDays is a required argument');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketFuture.originScopeDays);
- await page.waitToClick(selectors.ticketFuture.submit);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('originScopeDays is a required argument');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
- await page.waitToClick(selectors.ticketFuture.submit);
-
- expect(httpRequest).toBeDefined();
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
-
- await page.autocompleteSearch(selectors.ticketFuture.ipt, 'H');
- await page.waitToClick(selectors.ticketFuture.submit);
-
- expect(httpRequest).toContain('ipt=H');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
-
- await page.clearInput(selectors.ticketFuture.ipt);
-
- await page.autocompleteSearch(selectors.ticketFuture.futureIpt, 'H');
- await page.waitToClick(selectors.ticketFuture.submit);
-
- expect(httpRequest).toContain('futureIpt=H');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
-
- await page.clearInput(selectors.ticketFuture.futureIpt);
-
- await page.autocompleteSearch(selectors.ticketFuture.state, 'Free');
- await page.waitToClick(selectors.ticketFuture.submit);
-
- expect(httpRequest).toContain('state=0');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
-
- await page.clearInput(selectors.ticketFuture.state);
-
- await page.autocompleteSearch(selectors.ticketFuture.futureState, 'Free');
- await page.waitToClick(selectors.ticketFuture.submit);
-
- expect(httpRequest).toContain('futureState=0');
-
- await page.waitToClick(selectors.ticketFuture.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketFuture.state);
- await page.clearInput(selectors.ticketFuture.futureState);
- await page.waitToClick(selectors.ticketFuture.submit);
-
- await page.waitForNumberOfElements(selectors.ticketFuture.searchResult, 5);
- await page.waitToClick(selectors.ticketFuture.multiCheck);
- await page.waitToClick(selectors.ticketFuture.firstCheck);
- await page.waitToClick(selectors.ticketFuture.moveButton);
- await page.waitToClick(selectors.globalItems.acceptButton);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Tickets moved successfully!');
- });
-});
diff --git a/e2e/paths/05-ticket/22_advance.spec.js b/e2e/paths/05-ticket/22_advance.spec.js
deleted file mode 100644
index 0e5b5e0c3..000000000
--- a/e2e/paths/05-ticket/22_advance.spec.js
+++ /dev/null
@@ -1,79 +0,0 @@
-import selectors from '../../helpers/selectors.js';
-import getBrowser from '../../helpers/puppeteer';
-
-describe('Ticket Advance path', () => {
- let browser;
- let page;
- let httpRequest;
-
- beforeAll(async() => {
- browser = await getBrowser();
- page = browser.page;
- await page.loginAndModule('employee', 'ticket');
- await page.accessToSection('ticket.advance');
- page.on('request', req => {
- if (req.url().includes(`Tickets/getTicketsAdvance`))
- httpRequest = req.url();
- });
- });
-
- afterAll(async() => {
- await browser.close();
- });
-
- it('should search with the required data, check the first ticket and move to the present', async() => {
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketAdvance.warehouseFk);
-
- await page.waitToClick(selectors.ticketAdvance.submit);
- let message = await page.waitForSnackbar();
-
- expect(message.text).toContain('warehouseFk is a required argument');
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketAdvance.dateToAdvance);
- await page.waitToClick(selectors.ticketAdvance.submit);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('dateToAdvance is a required argument');
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketAdvance.dateFuture);
- await page.waitToClick(selectors.ticketAdvance.submit);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('dateFuture is a required argument');
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.waitToClick(selectors.ticketAdvance.submit);
-
- expect(httpRequest).toBeDefined();
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.autocompleteSearch(selectors.ticketAdvance.futureIpt, 'H');
- await page.waitToClick(selectors.ticketAdvance.submit);
-
- expect(httpRequest).toContain('futureIpt=H');
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketAdvance.futureIpt);
- await page.waitToClick(selectors.ticketAdvance.submit);
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.autocompleteSearch(selectors.ticketAdvance.ipt, 'H');
- await page.waitToClick(selectors.ticketAdvance.submit);
-
- expect(httpRequest).toContain('ipt=H');
-
- await page.waitToClick(selectors.ticketAdvance.openAdvancedSearchButton);
- await page.clearInput(selectors.ticketAdvance.ipt);
- await page.waitToClick(selectors.ticketAdvance.submit);
-
- await page.waitToClick(selectors.ticketAdvance.firstCheck);
- await page.waitToClick(selectors.ticketAdvance.moveButton);
- await page.waitToClick(selectors.ticketAdvance.acceptButton);
- message = await page.waitForSnackbar();
-
- expect(message.text).toContain('Tickets moved successfully!');
- });
-});
diff --git a/loopback/locale/en.json b/loopback/locale/en.json
index 4ad3f76e2..95f6ff326 100644
--- a/loopback/locale/en.json
+++ b/loopback/locale/en.json
@@ -241,9 +241,8 @@
"The height must be greater than 50cm": "The height must be greater than 50cm",
"The maximum height of the wagon is 200cm": "The maximum height of the wagon is 200cm",
"The quantity claimed cannot be greater than the quantity of the line": "The quantity claimed cannot be greater than the quantity of the line",
- "There are tickets for this area, delete them first": "There are tickets for this area, delete them first",
- "ticketLostExpedition": "The ticket [{{ticketId}}]({{{ticketUrl}}}) has the following lost expedition:{{ expeditionId }}",
- "null": "null",
"Invalid or expired verification code": "Invalid or expired verification code",
+ "There are tickets for this area, delete them first": "There are tickets for this area, delete them first",
+ "ticketLostExpedition": "The ticket [{{ticketId}}]({{{ticketUrl}}}) has the following lost expedition:{{ expeditionId }}",
"Payment method is required": "Payment method is required"
-}
\ No newline at end of file
+}
diff --git a/modules/account/back/locale/vn-user/en.yml b/modules/account/back/locale/vn-user/en.yml
index 51de7c40d..f911ee1eb 100644
--- a/modules/account/back/locale/vn-user/en.yml
+++ b/modules/account/back/locale/vn-user/en.yml
@@ -15,7 +15,5 @@ columns:
image: image
hasGrant: has grant
userFk: user
- recoverPass: recover password
role: role
- sync: pending sync
lastPassChange: password changed
diff --git a/modules/account/back/locale/vn-user/es.yml b/modules/account/back/locale/vn-user/es.yml
index 85e8bc0dc..c05dd872c 100644
--- a/modules/account/back/locale/vn-user/es.yml
+++ b/modules/account/back/locale/vn-user/es.yml
@@ -15,7 +15,5 @@ columns:
image: imagen
hasGrant: puede delegar
userFk: usuario
- recoverPass: recuperar contraseña
role: rol
- sync: Pendiente de sincronizar
lastPassChange: contraseña modificada
diff --git a/modules/client/back/models/client-observation.json b/modules/client/back/models/client-observation.json
index 86351862d..1d906420a 100644
--- a/modules/client/back/models/client-observation.json
+++ b/modules/client/back/models/client-observation.json
@@ -55,7 +55,7 @@
"relation": "user",
"scope": {
"fields": [
- "nickname"
+ "name"
]
}
}
diff --git a/modules/entry/back/methods/stock-bought/getStockBought.js b/modules/entry/back/methods/stock-bought/getStockBought.js
index c1f99c496..9768b58e7 100644
--- a/modules/entry/back/methods/stock-bought/getStockBought.js
+++ b/modules/entry/back/methods/stock-bought/getStockBought.js
@@ -6,6 +6,9 @@ module.exports = Self => {
arg: 'workerFk',
type: 'number',
description: 'The id for a buyer',
+ }, {
+ arg: 'filter',
+ type: 'object',
},
{
arg: 'dated',
@@ -23,7 +26,7 @@ module.exports = Self => {
}
});
- Self.getStockBought = async(workerFk, dated = Date.vnNew()) => {
+ Self.getStockBought = async(workerFk, filter, dated = Date.vnNew()) => {
const models = Self.app.models;
const today = Date.vnNew();
dated.setHours(0, 0, 0, 0);
@@ -31,7 +34,7 @@ module.exports = Self => {
await models.StockBought.rawSql(`CALL vn.stockBought_calculate(?)`, [dated]);
- const filter = {
+ const defaultFilter = {
where: {dated},
include: [
{
@@ -53,6 +56,6 @@ module.exports = Self => {
if (workerFk) filter.where.workerFk = workerFk;
- return models.StockBought.find(filter);
+ return models.StockBought.find({...filter, ...defaultFilter});
};
};
diff --git a/modules/entry/back/methods/stock-bought/getStockBoughtDetail.js b/modules/entry/back/methods/stock-bought/getStockBoughtDetail.js
index d5f712edf..60b099682 100644
--- a/modules/entry/back/methods/stock-bought/getStockBoughtDetail.js
+++ b/modules/entry/back/methods/stock-bought/getStockBoughtDetail.js
@@ -1,3 +1,4 @@
+const ParameterizedSQL = require('loopback-connector').ParameterizedSQL;
module.exports = Self => {
Self.remoteMethod('getStockBoughtDetail', {
description: 'Returns the detail of stock bought for a given date and a worker',
@@ -12,6 +13,9 @@ module.exports = Self => {
type: 'string',
description: 'The date to filter',
required: true,
+ }, {
+ arg: 'filter',
+ type: 'object',
}
],
returns: {
@@ -24,11 +28,10 @@ module.exports = Self => {
}
});
- Self.getStockBoughtDetail = async(workerFk, dated) => {
- const models = Self.app.models;
+ Self.getStockBoughtDetail = async(workerFk, dated, filter, options) => {
+ const conn = Self.dataSource.connector;
const myOptions = {};
let tx;
- let result;
if (typeof options == 'object')
Object.assign(myOptions, options);
@@ -39,8 +42,10 @@ module.exports = Self => {
}
try {
- await models.StockBought.rawSql(`CALL vn.item_calculateStock(?)`, [dated], myOptions);
- result = await Self.rawSql(
+ const stmts = [];
+ stmts.push(new ParameterizedSQL(`CALL vn.item_calculateStock(?)`, [dated]));
+
+ const query = new ParameterizedSQL(
`SELECT b.entryFk entryFk,
i.id itemFk,
i.name itemName,
@@ -61,11 +66,17 @@ module.exports = Self => {
JOIN volumeConfig vc
WHERE ic.display
AND w.id = ?`,
- [workerFk], myOptions
+ [workerFk]
);
- await Self.rawSql(`DROP TEMPORARY TABLE tmp.item, tmp.buyUltimate;`, [], myOptions);
+
+ stmts.push(query.merge(conn.makeSuffix(filter)));
+
+ stmts.push(new ParameterizedSQL(`DROP TEMPORARY TABLE tmp.item, tmp.buyUltimate`));
+
+ const sql = ParameterizedSQL.join(stmts, ';');
+ const result = await conn.executeStmt(sql, myOptions);
if (tx) await tx.commit();
- return result;
+ return result[1];
} catch (e) {
await tx.rollback();
throw e;
diff --git a/modules/item/front/barcode/index.html b/modules/item/front/barcode/index.html
deleted file mode 100644
index 8d6cb3af8..000000000
--- a/modules/item/front/barcode/index.html
+++ /dev/null
@@ -1,57 +0,0 @@
-
- |
- - Item ID - | -- Description - | -- Grouping price - | -- Packing price - | -- Min price - | -- Started - | -- Ended - | -- Warehouse - | -- |
---|---|---|---|---|---|---|---|---|---|
- |
-
- {{id}}
-
- |
-
-
-
- {{itemFk.selection.name}}
-
-
- {{price.subName}}- |
-
- |
-
- |
-
- |
-
- |
-
- |
-
- |
-
- |
-
- | - Identifier - | -- Grouping - | -- Packing - | -- Description - | -- Stems - | -- Size - | -- Type - | -- Category - | -- Intrastat - | -- Origin - | -- Buyer - | -- Weight/Piece - | -- Multiplier - | -- Active - | -- Producer - | -- Landed - | -- |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
- - | -- - {{::item.id}} - - | -{{::item.grouping | dashIfEmpty}} | -{{::item.packing | dashIfEmpty}} | -
-
-
- {{::item.subName}}- |
- {{::item.stems}} | -{{::item.size}} | -- {{::item.typeName}} - | -- {{::item.category}} - | -- {{::item.intrastat}} - | -{{::item.origin}} | -- - {{::item.userName}} - - | -{{::item.weightByPiece}} | -{{::item.stemMultiplier}} | -
- |
- {{::item.producer | dashIfEmpty}} | -{{::item.landed | date:'dd/MM/yyyy'}} | -
- |
-
- |
- - Created - | -- Item - | -- Concept - | -- Parking - | -- Shelving - | -- Etiqueta - | -- Packing - | -
---|---|---|---|---|---|---|---|
- |
- {{::itemShelvingPlacementSupplyStock.created | date: 'dd/MM/yyyy'}} | -- {{::itemShelvingPlacementSupplyStock.itemFk}} - | -- - {{itemShelvingPlacementSupplyStock.longName}} - - | -- {{::itemShelvingPlacementSupplyStock.parking}} - | -- {{::itemShelvingPlacementSupplyStock.shelving}} - | -- {{(itemShelvingPlacementSupplyStock.stock / itemShelvingPlacementSupplyStock.packing).toFixed(2)}} - | -- {{::itemShelvingPlacementSupplyStock.packing}} - | -
Visible
-{{$ctrl.summary.visible}}
-Available
-{{$ctrl.summary.available}}
-
-
- {{$ctrl.summary.item.description}} -
-- {{barcode.code}} -
-{{$t('code')}} | {{$t('boxes')}} | -+ | {{$t('packing')}} | -{{$t('concept')}} | -{{$t('reference')}} | -{{$t('tags')}} | -{{$t('quantity')}} | -- | {{$t('price')}} | -- | {{$t('amount')}} | +{{$t('concept')}} | +{{$t('reference')}} | +{{$t('tags')}} | +{{$t('quantity')}} | ++ | {{$t('price')}} | ++ | {{$t('amount')}} | ||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
{{buy.itemFk}} | {{buy.stickers}} | -x | -{{buy.packing}} | -{{buy.name}} | -{{buy.comment}} | -- {{buy.tag5}} → {{buy.value5}} - {{buy.tag6}} → {{buy.value6}} - {{buy.tag7}} → {{buy.value7}} + | x | +{{buy.packing}} | +{{buy.name}} | +referencia de prueba | +
+
+
+ {{buy.tag5}}→ {{buy.value5}}
+ {{buy.tag6}}→ {{buy.value6}}
+
+
{{buy.tag7}}→ {{buy.value7}}
+ {{buy.tag8}}→ {{buy.value8}}
+ |
- {{buy.quantity | number($i18n.locale)}} | -x | -{{buy.buyingValue | currency('EUR', $i18n.locale)}} | -= | -+ | {{buy.quantity | number($i18n.locale)}} | +x | +{{buy.buyingValue | currency('EUR', $i18n.locale)}} | += | +{{buy.buyingValue * buy.quantity | currency('EUR', $i18n.locale)}} |
{{getTotalBy('stickers')}} | diff --git a/print/templates/reports/entry-order/locale/es.yml b/print/templates/reports/entry-order/locale/es.yml index 5a6716ba1..9ec357802 100644 --- a/print/templates/reports/entry-order/locale/es.yml +++ b/print/templates/reports/entry-order/locale/es.yml @@ -16,4 +16,5 @@ entry: Entrada {0} supplierData: Datos del proveedor notes: Notas reference: Referencia -tags: Tags \ No newline at end of file +tags: Etiquetas +code: Código \ No newline at end of file diff --git a/print/templates/reports/entry-order/sql/buys.sql b/print/templates/reports/entry-order/sql/buys.sql index 92c055483..545849908 100644 --- a/print/templates/reports/entry-order/sql/buys.sql +++ b/print/templates/reports/entry-order/sql/buys.sql @@ -10,7 +10,9 @@ SELECT b.itemFk, i.tag6, i.value6, i.tag7, - i.value7 + i.value7, + i.tag8, + i.value8 FROM buy b JOIN item i ON i.id = b.itemFk LEFT JOIN item i2 ON i2.id = b.itemOriginalFk |