From f6fd2d331385938ea53065c5ad076eb1b2dab6b5 Mon Sep 17 00:00:00 2001 From: Vitaly Zakutny Date: Fri, 24 Nov 2023 00:29:03 +0300 Subject: [PATCH 1/3] chore: added tests for core lib --- .../__snapshots__/xml-locales.test.ts.snap | 56 +++++++++ .../src/utils/__snapshots__/xml.test.ts.snap | 15 +++ .../xml-locales/src/utils/helpers.test.ts | 49 ++++++++ packages/xml-locales/src/utils/xml.test.ts | 87 +++++++++++++ packages/xml-locales/src/xml-locales.test.ts | 117 ++++++++++++++++++ 5 files changed, 324 insertions(+) create mode 100644 packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap create mode 100644 packages/xml-locales/src/utils/__snapshots__/xml.test.ts.snap create mode 100644 packages/xml-locales/src/utils/helpers.test.ts create mode 100644 packages/xml-locales/src/utils/xml.test.ts create mode 100644 packages/xml-locales/src/xml-locales.test.ts diff --git a/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap b/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap new file mode 100644 index 0000000..cf772fe --- /dev/null +++ b/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap @@ -0,0 +1,56 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`XmlLocales > XmlLocales constructor > constructor should parse xml data 1`] = ` +XmlJsonData { + "resources": { + "string": [ + { + "#text": "value1", + "key_name": "key1", + }, + ], + }, +} +`; + +exports[`XmlLocales > should return json object 1`] = ` +XmlJsonData { + "resources": { + "#text": " + + +", + "string": [ + { + "#text": "value1", + "key_name": "key1", + }, + { + "#text": "value2", + "key_name": "key2", + }, + ], + }, +} +`; + +exports[`XmlLocales > should return xml string 1`] = ` +" + value1 + value2 +" +`; + +exports[`XmlLocales > to XML > should return xml string with formatting 1`] = ` +" + value1 + value2 +" +`; + +exports[`XmlLocales > to XML > should return xml string without formatting 1`] = ` +"value1value2 + + +" +`; diff --git a/packages/xml-locales/src/utils/__snapshots__/xml.test.ts.snap b/packages/xml-locales/src/utils/__snapshots__/xml.test.ts.snap new file mode 100644 index 0000000..8cfb998 --- /dev/null +++ b/packages/xml-locales/src/utils/__snapshots__/xml.test.ts.snap @@ -0,0 +1,15 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`XmlParser > should format xml string 1`] = ` +" + value1 + value2 +" +`; + +exports[`XmlParser > should parse json to xml 1`] = ` +"value1value2 + + +" +`; diff --git a/packages/xml-locales/src/utils/helpers.test.ts b/packages/xml-locales/src/utils/helpers.test.ts new file mode 100644 index 0000000..5540ccf --- /dev/null +++ b/packages/xml-locales/src/utils/helpers.test.ts @@ -0,0 +1,49 @@ +import { describe, expect, test } from 'vitest'; + +import { + checkKeyValueExist, + checkXmlKey, + replaceXmlNodeValue +} from './helpers.js'; + +const xmlData = { + resources: { + string: [ + { + key_name: 'key1', + '#text': 'value1' + }, + { + key_name: 'key2', + '#text': 'value2' + } + ] + } +}; + +describe('checkXmlKey', () => { + test('should return true if key exist', () => { + expect(checkXmlKey(xmlData, 'key1')).toBe(true); + }); + + test('should return false if key does not exist', () => { + expect(checkXmlKey(xmlData, 'key3')).toBe(false); + }); +}); + +describe('checkKeyValueExist', () => { + test('should return true if key value exist', () => { + expect(checkKeyValueExist('value1', xmlData.resources.string)).toBe(true); + }); + + test('should return false if key value does not exist', () => { + expect(checkKeyValueExist('value3', xmlData.resources.string)).toBe(false); + }); +}); + +describe('replaceXmlNodeValue', () => { + test('should replace the value of the key', () => { + const newXmlData = replaceXmlNodeValue(xmlData, 'key1', 'value3'); + expect(newXmlData.resources.string[0]?.['#text']).toBe('value3'); + }); +}); diff --git a/packages/xml-locales/src/utils/xml.test.ts b/packages/xml-locales/src/utils/xml.test.ts new file mode 100644 index 0000000..e77e317 --- /dev/null +++ b/packages/xml-locales/src/utils/xml.test.ts @@ -0,0 +1,87 @@ +import { describe, expect, test } from 'vitest'; + +import { + checkKeyValueExist, + checkXmlKey, + replaceXmlNodeValue +} from './helpers.js'; +import { XmlJsonData, XmlParser } from './xml.js'; + +const xmlData = ` + + value1 + value2 + +`; + +describe('XmlParser', () => { + test('should parse xml to json', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + expect(jsonData).toMatchObject({ + resources: { + string: [ + { + key_name: 'key1', + '#text': 'value1' + }, + { + key_name: 'key2', + '#text': 'value2' + } + ] + } + }); + }); + + test('should parse json to xml', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + const xmlString = xmlParser.jsonToXml(jsonData); + expect(xmlString).toMatchSnapshot(); + }); + + test('should format xml string', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + const xmlString = xmlParser.jsonToXml(jsonData); + const formattedXmlString = xmlParser.formate(xmlString); + expect(formattedXmlString).toMatchSnapshot(); + }); +}); + +describe('XmlJsonData', () => { + test('should check if key exist', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + const xmlJsonData = new XmlJsonData(jsonData); + + expect(checkXmlKey(xmlJsonData, 'key1')).toBe(true); + expect(checkXmlKey(xmlJsonData, 'key3')).toBe(false); + }); + + test('should check if key value exist', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + const xmlJsonData = new XmlJsonData(jsonData); + expect(checkKeyValueExist('value1', xmlJsonData.resources.string)).toBe( + true + ); + expect(checkKeyValueExist('value3', xmlJsonData.resources.string)).toBe( + false + ); + }); + + test('should replace the value of the key', () => { + const xmlParser = new XmlParser(); + const jsonData = xmlParser.xmlToJson(xmlData); + const xmlJsonData = new XmlJsonData(jsonData); + + expect( + checkKeyValueExist( + 'value3', + replaceXmlNodeValue(xmlJsonData, 'key1', 'value3').resources.string + ) + ).toBe(true); + }); +}); diff --git a/packages/xml-locales/src/xml-locales.test.ts b/packages/xml-locales/src/xml-locales.test.ts new file mode 100644 index 0000000..e477831 --- /dev/null +++ b/packages/xml-locales/src/xml-locales.test.ts @@ -0,0 +1,117 @@ +import { describe, expect, test } from 'vitest'; +import { c } from 'vitest/dist/reporters-5f784f42.js'; + +import { XmlLocales } from './xml-locales.js'; + +const xmlData = ` + value1 + value2 +`; + +const oneStringXmlData = ` + value1 +`; + +describe('XmlLocales', () => { + describe('add', () => { + test('should add new node', () => { + const xmlLocales = new XmlLocales(xmlData); + const jsonXml = xmlLocales.add({ key: 'key3', value: 'value3' }).toJSON(); + expect(jsonXml.resources.string[2]?.['#text']).toBe('value3'); + }); + + test('should replace the value of the key', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.add({ key: 'key1', value: 'value3' }); + const jsonXml = xmlLocales.add({ key: 'key3', value: 'value3' }).toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value3'); + }); + }); + + describe('remove', () => { + test('should remove the key', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.deleteByKey('key1'); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value2'); + }); + + test('should remove the value', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.deleteByValue('value1'); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value2'); + }); + + test('not found key or value', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.deleteByKey('key3'); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value1'); + }); + }); + + describe('sort', () => { + test('should sorted by "asc"', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.sort('asc'); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.key_name).toBe('key1'); + }); + + test('should sorted by "desc"', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.sort('desc'); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[1]?.key_name).toBe('key1'); + }); + }); + + describe('update', () => { + test('should update key', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.update({ oldValue: 'key1', newValue: 'newKey1' }); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.key_name).toBe('newKey1'); + }); + + test('should update value', () => { + const xmlLocales = new XmlLocales(xmlData); + xmlLocales.update({ oldValue: 'value1', newValue: 'newValue1' }); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('newValue1'); + }); + }); + + describe('XmlLocales constructor', () => { + test('should throw error if xml data is not defined', () => { + expect(() => new XmlLocales()).toThrow('XML data is not defined'); + }); + + test('constructor should parse xml data', () => { + const xmlLocales = new XmlLocales(oneStringXmlData); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml).toMatchSnapshot(); + }); + }); + + describe('to XML', () => { + test('should return xml string with formatting', () => { + const xmlLocales = new XmlLocales(xmlData); + const xmlString = xmlLocales.toXML(); + expect(xmlString).toMatchSnapshot(); + }); + + test('should return xml string without formatting', () => { + const xmlLocales = new XmlLocales(xmlData); + const xmlString = xmlLocales.toXML(false); + expect(xmlString).toMatchSnapshot(); + }); + }); + + test('should return json object', () => { + const xmlLocales = new XmlLocales(xmlData); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml).toMatchSnapshot(); + }); +}); From 1957b0543399aa77ad2f49596f92a8b099a84537 Mon Sep 17 00:00:00 2001 From: Vitaly Zakutny Date: Fri, 24 Nov 2023 00:42:14 +0300 Subject: [PATCH 2/3] chore: update tests --- .../__snapshots__/xml-locales.test.ts.snap | 21 ++++++++++ packages/xml-locales/src/xml-locales.test.ts | 40 +++++++++++++------ 2 files changed, 49 insertions(+), 12 deletions(-) diff --git a/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap b/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap index cf772fe..5816ae9 100644 --- a/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap +++ b/packages/xml-locales/src/__snapshots__/xml-locales.test.ts.snap @@ -13,6 +13,27 @@ XmlJsonData { } `; +exports[`XmlLocales > XmlLocales constructor > should return json object 1`] = ` +XmlJsonData { + "resources": { + "#text": " + + +", + "string": [ + { + "#text": "value1", + "key_name": "key1", + }, + { + "#text": "value2", + "key_name": "key2", + }, + ], + }, +} +`; + exports[`XmlLocales > should return json object 1`] = ` XmlJsonData { "resources": { diff --git a/packages/xml-locales/src/xml-locales.test.ts b/packages/xml-locales/src/xml-locales.test.ts index e477831..5b1b095 100644 --- a/packages/xml-locales/src/xml-locales.test.ts +++ b/packages/xml-locales/src/xml-locales.test.ts @@ -17,29 +17,36 @@ describe('XmlLocales', () => { test('should add new node', () => { const xmlLocales = new XmlLocales(xmlData); const jsonXml = xmlLocales.add({ key: 'key3', value: 'value3' }).toJSON(); - expect(jsonXml.resources.string[2]?.['#text']).toBe('value3'); + const newNode = jsonXml.resources.string[2]; + + expect(newNode?.key_name).toBe('key3'); + expect(newNode?.['#text']).toBe('value3'); }); test('should replace the value of the key', () => { const xmlLocales = new XmlLocales(xmlData); - xmlLocales.add({ key: 'key1', value: 'value3' }); - const jsonXml = xmlLocales.add({ key: 'key3', value: 'value3' }).toJSON(); - expect(jsonXml.resources.string[0]?.['#text']).toBe('value3'); + const jsonXml = xmlLocales.add({ key: 'key1', value: 'value3' }).toJSON(); + const newNode = jsonXml.resources.string[0]; + + expect(newNode?.key_name).toBe('key1'); + expect(newNode?.['#text']).toBe('value3'); }); }); describe('remove', () => { - test('should remove the key', () => { + test('should remove a node of the key', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.deleteByKey('key1'); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value2'); }); - test('should remove the value', () => { + test('should remove a node of the value', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.deleteByValue('value1'); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value2'); }); @@ -47,6 +54,7 @@ describe('XmlLocales', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.deleteByKey('key3'); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('value1'); }); }); @@ -56,6 +64,7 @@ describe('XmlLocales', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.sort('asc'); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.key_name).toBe('key1'); }); @@ -63,6 +72,7 @@ describe('XmlLocales', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.sort('desc'); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[1]?.key_name).toBe('key1'); }); }); @@ -72,6 +82,7 @@ describe('XmlLocales', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.update({ oldValue: 'key1', newValue: 'newKey1' }); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.key_name).toBe('newKey1'); }); @@ -79,6 +90,7 @@ describe('XmlLocales', () => { const xmlLocales = new XmlLocales(xmlData); xmlLocales.update({ oldValue: 'value1', newValue: 'newValue1' }); const jsonXml = xmlLocales.toJSON(); + expect(jsonXml.resources.string[0]?.['#text']).toBe('newValue1'); }); }); @@ -91,6 +103,14 @@ describe('XmlLocales', () => { test('constructor should parse xml data', () => { const xmlLocales = new XmlLocales(oneStringXmlData); const jsonXml = xmlLocales.toJSON(); + + expect(jsonXml).toMatchSnapshot(); + }); + + test('should return json object', () => { + const xmlLocales = new XmlLocales(xmlData); + const jsonXml = xmlLocales.toJSON(); + expect(jsonXml).toMatchSnapshot(); }); }); @@ -99,19 +119,15 @@ describe('XmlLocales', () => { test('should return xml string with formatting', () => { const xmlLocales = new XmlLocales(xmlData); const xmlString = xmlLocales.toXML(); + expect(xmlString).toMatchSnapshot(); }); test('should return xml string without formatting', () => { const xmlLocales = new XmlLocales(xmlData); const xmlString = xmlLocales.toXML(false); + expect(xmlString).toMatchSnapshot(); }); }); - - test('should return json object', () => { - const xmlLocales = new XmlLocales(xmlData); - const jsonXml = xmlLocales.toJSON(); - expect(jsonXml).toMatchSnapshot(); - }); }); From 0efe13c55d5e529ec755a7a8591604366a3723cb Mon Sep 17 00:00:00 2001 From: Vitaly Zakutny Date: Fri, 24 Nov 2023 00:43:23 +0300 Subject: [PATCH 3/3] chore: delete unused import --- packages/xml-locales/src/xml-locales.test.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/packages/xml-locales/src/xml-locales.test.ts b/packages/xml-locales/src/xml-locales.test.ts index 5b1b095..1ea7624 100644 --- a/packages/xml-locales/src/xml-locales.test.ts +++ b/packages/xml-locales/src/xml-locales.test.ts @@ -1,5 +1,4 @@ import { describe, expect, test } from 'vitest'; -import { c } from 'vitest/dist/reporters-5f784f42.js'; import { XmlLocales } from './xml-locales.js';