Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/build/lib/test/i18n.test.ts
4772 views
1
/*---------------------------------------------------------------------------------------------
2
* Copyright (c) Microsoft Corporation. All rights reserved.
3
* Licensed under the MIT License. See License.txt in the project root for license information.
4
*--------------------------------------------------------------------------------------------*/
5
6
import assert from 'assert';
7
import * as i18n from '../i18n.ts';
8
9
suite('XLF Parser Tests', () => {
10
const sampleXlf = '<?xml version="1.0" encoding="utf-8"?><xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2"><file original="vs/base/common/keybinding" source-language="en" datatype="plaintext"><body><trans-unit id="key1"><source xml:lang="en">Key #1</source></trans-unit><trans-unit id="key2"><source xml:lang="en">Key #2 &amp;</source></trans-unit></body></file></xliff>';
11
const sampleTranslatedXlf = '<?xml version="1.0" encoding="utf-8"?><xliff version="1.2" xmlns="urn:oasis:names:tc:xliff:document:1.2"><file original="vs/base/common/keybinding" source-language="en" target-language="ru" datatype="plaintext"><body><trans-unit id="key1"><source xml:lang="en">Key #1</source><target>Кнопка #1</target></trans-unit><trans-unit id="key2"><source xml:lang="en">Key #2 &amp;</source><target>Кнопка #2 &amp;</target></trans-unit></body></file></xliff>';
12
const name = 'vs/base/common/keybinding';
13
const keys = ['key1', 'key2'];
14
const messages = ['Key #1', 'Key #2 &'];
15
const translatedMessages = { key1: 'Кнопка #1', key2: 'Кнопка #2 &' };
16
17
test('Keys & messages to XLF conversion', () => {
18
const xlf = new i18n.XLF('vscode-workbench');
19
xlf.addFile(name, keys, messages);
20
const xlfString = xlf.toString();
21
22
assert.strictEqual(xlfString.replace(/\s{2,}/g, ''), sampleXlf);
23
});
24
25
test('XLF to keys & messages conversion', () => {
26
i18n.XLF.parse(sampleTranslatedXlf).then(function (resolvedFiles) {
27
assert.deepStrictEqual(resolvedFiles[0].messages, translatedMessages);
28
assert.strictEqual(resolvedFiles[0].name, name);
29
});
30
});
31
32
test('JSON file source path to Transifex resource match', () => {
33
const editorProject: string = 'vscode-editor',
34
workbenchProject: string = 'vscode-workbench';
35
36
const platform: i18n.Resource = { name: 'vs/platform', project: editorProject },
37
editorContrib = { name: 'vs/editor/contrib', project: editorProject },
38
editor = { name: 'vs/editor', project: editorProject },
39
base = { name: 'vs/base', project: editorProject },
40
code = { name: 'vs/code', project: workbenchProject },
41
workbenchParts = { name: 'vs/workbench/contrib/html', project: workbenchProject },
42
workbenchServices = { name: 'vs/workbench/services/textfile', project: workbenchProject },
43
workbench = { name: 'vs/workbench', project: workbenchProject };
44
45
assert.deepStrictEqual(i18n.getResource('vs/platform/actions/browser/menusExtensionPoint'), platform);
46
assert.deepStrictEqual(i18n.getResource('vs/editor/contrib/clipboard/browser/clipboard'), editorContrib);
47
assert.deepStrictEqual(i18n.getResource('vs/editor/common/modes/modesRegistry'), editor);
48
assert.deepStrictEqual(i18n.getResource('vs/base/common/errorMessage'), base);
49
assert.deepStrictEqual(i18n.getResource('vs/code/electron-main/window'), code);
50
assert.deepStrictEqual(i18n.getResource('vs/workbench/contrib/html/browser/webview'), workbenchParts);
51
assert.deepStrictEqual(i18n.getResource('vs/workbench/services/textfile/node/testFileService'), workbenchServices);
52
assert.deepStrictEqual(i18n.getResource('vs/workbench/browser/parts/panel/panelActions'), workbench);
53
});
54
});
55
56