mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-04 01:25:38 -05:00
SQL Operations Studio Public Preview 1 (0.23) release source code
This commit is contained in:
327
src/vs/base/test/common/strings.test.ts
Normal file
327
src/vs/base/test/common/strings.test.ts
Normal file
@@ -0,0 +1,327 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
'use strict';
|
||||
|
||||
import * as assert from 'assert';
|
||||
import strings = require('vs/base/common/strings');
|
||||
|
||||
suite('Strings', () => {
|
||||
test('equalsIgnoreCase', function () {
|
||||
assert(strings.equalsIgnoreCase('', ''));
|
||||
assert(!strings.equalsIgnoreCase('', '1'));
|
||||
assert(!strings.equalsIgnoreCase('1', ''));
|
||||
|
||||
assert(strings.equalsIgnoreCase('a', 'a'));
|
||||
assert(strings.equalsIgnoreCase('abc', 'Abc'));
|
||||
assert(strings.equalsIgnoreCase('abc', 'ABC'));
|
||||
assert(strings.equalsIgnoreCase('Höhenmeter', 'HÖhenmeter'));
|
||||
assert(strings.equalsIgnoreCase('ÖL', 'Öl'));
|
||||
});
|
||||
|
||||
test('beginsWithIgnoreCase', function () {
|
||||
assert(strings.beginsWithIgnoreCase('', ''));
|
||||
assert(!strings.beginsWithIgnoreCase('', '1'));
|
||||
assert(strings.beginsWithIgnoreCase('1', ''));
|
||||
|
||||
assert(strings.beginsWithIgnoreCase('a', 'a'));
|
||||
assert(strings.beginsWithIgnoreCase('abc', 'Abc'));
|
||||
assert(strings.beginsWithIgnoreCase('abc', 'ABC'));
|
||||
assert(strings.beginsWithIgnoreCase('Höhenmeter', 'HÖhenmeter'));
|
||||
assert(strings.beginsWithIgnoreCase('ÖL', 'Öl'));
|
||||
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'a'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'A'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'alles k'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'alles K'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'ALLES K'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'alles klar'));
|
||||
assert(strings.beginsWithIgnoreCase('alles klar', 'ALLES KLAR'));
|
||||
|
||||
assert(!strings.beginsWithIgnoreCase('alles klar', ' ALLES K'));
|
||||
assert(!strings.beginsWithIgnoreCase('alles klar', 'ALLES K '));
|
||||
assert(!strings.beginsWithIgnoreCase('alles klar', 'öALLES K '));
|
||||
assert(!strings.beginsWithIgnoreCase('alles klar', ' '));
|
||||
assert(!strings.beginsWithIgnoreCase('alles klar', 'ö'));
|
||||
});
|
||||
|
||||
test('compareIgnoreCase', function () {
|
||||
|
||||
function assertCompareIgnoreCase(a: string, b: string, recurse = true): void {
|
||||
let actual = strings.compareIgnoreCase(a, b);
|
||||
actual = actual > 0 ? 1 : actual < 0 ? -1 : actual;
|
||||
|
||||
let expected = strings.compare(a.toLowerCase(), b.toLowerCase());
|
||||
expected = expected > 0 ? 1 : expected < 0 ? -1 : expected;
|
||||
assert.equal(actual, expected, `${a} <> ${b}`);
|
||||
|
||||
if (recurse) {
|
||||
assertCompareIgnoreCase(b, a, false);
|
||||
}
|
||||
}
|
||||
|
||||
assertCompareIgnoreCase('', '');
|
||||
assertCompareIgnoreCase('abc', 'ABC');
|
||||
assertCompareIgnoreCase('abc', 'ABc');
|
||||
assertCompareIgnoreCase('abc', 'ABcd');
|
||||
assertCompareIgnoreCase('abc', 'abcd');
|
||||
assertCompareIgnoreCase('foo', 'föo');
|
||||
assertCompareIgnoreCase('Code', 'code');
|
||||
assertCompareIgnoreCase('Code', 'cöde');
|
||||
|
||||
assertCompareIgnoreCase('B', 'a');
|
||||
assertCompareIgnoreCase('a', 'B');
|
||||
assertCompareIgnoreCase('b', 'a');
|
||||
assertCompareIgnoreCase('a', 'b');
|
||||
|
||||
assertCompareIgnoreCase('aa', 'ab');
|
||||
assertCompareIgnoreCase('aa', 'aB');
|
||||
assertCompareIgnoreCase('aa', 'aA');
|
||||
assertCompareIgnoreCase('a', 'aa');
|
||||
assertCompareIgnoreCase('ab', 'aA');
|
||||
assertCompareIgnoreCase('O', '/');
|
||||
});
|
||||
|
||||
test('format', function () {
|
||||
assert.strictEqual(strings.format('Foo Bar'), 'Foo Bar');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar'), 'Foo {0} Bar');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar', 'yes'), 'Foo yes Bar');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar {0}', 'yes'), 'Foo yes Bar yes');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar {1}{2}', 'yes'), 'Foo yes Bar {1}{2}');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar {1}{2}', 'yes', undefined), 'Foo yes Bar undefined{2}');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar {1}{2}', 'yes', 5, false), 'Foo yes Bar 5false');
|
||||
assert.strictEqual(strings.format('Foo {0} Bar. {1}', '(foo)', '.test'), 'Foo (foo) Bar. .test');
|
||||
});
|
||||
|
||||
test('overlap', function () {
|
||||
assert.equal(strings.overlap('foobar', 'arr, I am a priate'), 2);
|
||||
assert.equal(strings.overlap('no', 'overlap'), 1);
|
||||
assert.equal(strings.overlap('no', '0verlap'), 0);
|
||||
assert.equal(strings.overlap('nothing', ''), 0);
|
||||
assert.equal(strings.overlap('', 'nothing'), 0);
|
||||
assert.equal(strings.overlap('full', 'full'), 4);
|
||||
assert.equal(strings.overlap('full', 'fulloverlap'), 4);
|
||||
});
|
||||
|
||||
test('computeLineStarts', function () {
|
||||
function assertLineStart(text: string, ...offsets: number[]): void {
|
||||
const actual = strings.computeLineStarts(text);
|
||||
assert.equal(actual.length, offsets.length);
|
||||
if (actual.length !== offsets.length) {
|
||||
return;
|
||||
}
|
||||
while (offsets.length > 0) {
|
||||
assert.equal(actual.pop(), offsets.pop());
|
||||
}
|
||||
}
|
||||
|
||||
assertLineStart('', 0);
|
||||
assertLineStart('farboo', 0);
|
||||
assertLineStart('far\nboo', 0, 4);
|
||||
assertLineStart('far\rboo', 0, 4);
|
||||
assertLineStart('far\r\nboo', 0, 5);
|
||||
assertLineStart('far\n\rboo', 0, 4, 5);
|
||||
assertLineStart('far\n \rboo', 0, 4, 6);
|
||||
assertLineStart('far\nboo\nfar', 0, 4, 8);
|
||||
});
|
||||
|
||||
|
||||
test('pad', function () {
|
||||
assert.strictEqual(strings.pad(1, 0), '1');
|
||||
assert.strictEqual(strings.pad(1, 1), '1');
|
||||
assert.strictEqual(strings.pad(1, 2), '01');
|
||||
assert.strictEqual(strings.pad(0, 2), '00');
|
||||
});
|
||||
|
||||
test('escape', function () {
|
||||
assert.strictEqual(strings.escape(''), '');
|
||||
assert.strictEqual(strings.escape('foo'), 'foo');
|
||||
assert.strictEqual(strings.escape('foo bar'), 'foo bar');
|
||||
assert.strictEqual(strings.escape('<foo bar>'), '<foo bar>');
|
||||
assert.strictEqual(strings.escape('<foo>Hello</foo>'), '<foo>Hello</foo>');
|
||||
});
|
||||
|
||||
test('startsWith', function () {
|
||||
assert(strings.startsWith('foo', 'f'));
|
||||
assert(strings.startsWith('foo', 'fo'));
|
||||
assert(strings.startsWith('foo', 'foo'));
|
||||
assert(!strings.startsWith('foo', 'o'));
|
||||
assert(!strings.startsWith('', 'f'));
|
||||
assert(strings.startsWith('foo', ''));
|
||||
assert(strings.startsWith('', ''));
|
||||
});
|
||||
|
||||
test('endsWith', function () {
|
||||
assert(strings.endsWith('foo', 'o'));
|
||||
assert(strings.endsWith('foo', 'oo'));
|
||||
assert(strings.endsWith('foo', 'foo'));
|
||||
assert(strings.endsWith('foo bar foo', 'foo'));
|
||||
assert(!strings.endsWith('foo', 'f'));
|
||||
assert(!strings.endsWith('', 'f'));
|
||||
assert(strings.endsWith('foo', ''));
|
||||
assert(strings.endsWith('', ''));
|
||||
assert(strings.endsWith('/', '/'));
|
||||
});
|
||||
|
||||
test('ltrim', function () {
|
||||
assert.strictEqual(strings.ltrim('foo', 'f'), 'oo');
|
||||
assert.strictEqual(strings.ltrim('foo', 'o'), 'foo');
|
||||
assert.strictEqual(strings.ltrim('http://www.test.de', 'http://'), 'www.test.de');
|
||||
assert.strictEqual(strings.ltrim('/foo/', '/'), 'foo/');
|
||||
assert.strictEqual(strings.ltrim('//foo/', '/'), 'foo/');
|
||||
assert.strictEqual(strings.ltrim('/', ''), '/');
|
||||
assert.strictEqual(strings.ltrim('/', '/'), '');
|
||||
assert.strictEqual(strings.ltrim('///', '/'), '');
|
||||
assert.strictEqual(strings.ltrim('', ''), '');
|
||||
assert.strictEqual(strings.ltrim('', '/'), '');
|
||||
});
|
||||
|
||||
test('rtrim', function () {
|
||||
assert.strictEqual(strings.rtrim('foo', 'o'), 'f');
|
||||
assert.strictEqual(strings.rtrim('foo', 'f'), 'foo');
|
||||
assert.strictEqual(strings.rtrim('http://www.test.de', '.de'), 'http://www.test');
|
||||
assert.strictEqual(strings.rtrim('/foo/', '/'), '/foo');
|
||||
assert.strictEqual(strings.rtrim('/foo//', '/'), '/foo');
|
||||
assert.strictEqual(strings.rtrim('/', ''), '/');
|
||||
assert.strictEqual(strings.rtrim('/', '/'), '');
|
||||
assert.strictEqual(strings.rtrim('///', '/'), '');
|
||||
assert.strictEqual(strings.rtrim('', ''), '');
|
||||
assert.strictEqual(strings.rtrim('', '/'), '');
|
||||
});
|
||||
|
||||
test('trim', function () {
|
||||
assert.strictEqual(strings.trim(' foo '), 'foo');
|
||||
assert.strictEqual(strings.trim(' foo'), 'foo');
|
||||
assert.strictEqual(strings.trim('bar '), 'bar');
|
||||
assert.strictEqual(strings.trim(' '), '');
|
||||
assert.strictEqual(strings.trim('foo bar', 'bar'), 'foo ');
|
||||
});
|
||||
|
||||
test('trimWhitespace', function () {
|
||||
assert.strictEqual(' foo '.trim(), 'foo');
|
||||
assert.strictEqual(' foo '.trim(), 'foo');
|
||||
assert.strictEqual(' foo'.trim(), 'foo');
|
||||
assert.strictEqual('bar '.trim(), 'bar');
|
||||
assert.strictEqual(' '.trim(), '');
|
||||
assert.strictEqual(' '.trim(), '');
|
||||
});
|
||||
|
||||
test('appendWithLimit', function () {
|
||||
assert.strictEqual(strings.appendWithLimit('ab', 'cd', 100), 'abcd');
|
||||
assert.strictEqual(strings.appendWithLimit('ab', 'cd', 2), '...cd');
|
||||
assert.strictEqual(strings.appendWithLimit('ab', 'cdefgh', 4), '...efgh');
|
||||
assert.strictEqual(strings.appendWithLimit('abcdef', 'ghijk', 7), '...efghijk');
|
||||
});
|
||||
|
||||
test('repeat', () => {
|
||||
assert.strictEqual(strings.repeat(' ', 4), ' ');
|
||||
assert.strictEqual(strings.repeat(' ', 1), ' ');
|
||||
assert.strictEqual(strings.repeat(' ', 0), '');
|
||||
assert.strictEqual(strings.repeat('abc', 2), 'abcabc');
|
||||
});
|
||||
|
||||
test('lastNonWhitespaceIndex', () => {
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc \t \t '), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc'), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc\t'), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc '), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc \t \t '), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc \t \t abc \t \t '), 11);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex('abc \t \t abc \t \t ', 8), 2);
|
||||
assert.strictEqual(strings.lastNonWhitespaceIndex(' \t \t '), -1);
|
||||
});
|
||||
|
||||
test('containsRTL', () => {
|
||||
assert.equal(strings.containsRTL('a'), false);
|
||||
assert.equal(strings.containsRTL(''), false);
|
||||
assert.equal(strings.containsRTL(strings.UTF8_BOM_CHARACTER + 'a'), false);
|
||||
assert.equal(strings.containsRTL('hello world!'), false);
|
||||
assert.equal(strings.containsRTL('a📚📚b'), false);
|
||||
assert.equal(strings.containsRTL('هناك حقيقة مثبتة منذ زمن طويل'), true);
|
||||
assert.equal(strings.containsRTL('זוהי עובדה מבוססת שדעתו'), true);
|
||||
});
|
||||
|
||||
test('containsEmoji', () => {
|
||||
assert.equal(strings.containsEmoji('a'), false);
|
||||
assert.equal(strings.containsEmoji(''), false);
|
||||
assert.equal(strings.containsEmoji(strings.UTF8_BOM_CHARACTER + 'a'), false);
|
||||
assert.equal(strings.containsEmoji('hello world!'), false);
|
||||
assert.equal(strings.containsEmoji('هناك حقيقة مثبتة منذ زمن طويل'), false);
|
||||
assert.equal(strings.containsEmoji('זוהי עובדה מבוססת שדעתו'), false);
|
||||
|
||||
assert.equal(strings.containsEmoji('a📚📚b'), true);
|
||||
assert.equal(strings.containsEmoji('1F600 # 😀 grinning face'), true);
|
||||
assert.equal(strings.containsEmoji('1F47E # 👾 alien monster'), true);
|
||||
assert.equal(strings.containsEmoji('1F467 1F3FD # 👧🏽 girl: medium skin tone'), true);
|
||||
assert.equal(strings.containsEmoji('26EA # ⛪ church'), true);
|
||||
assert.equal(strings.containsEmoji('231B # ⌛ hourglass'), true);
|
||||
assert.equal(strings.containsEmoji('2702 # ✂ scissors'), true);
|
||||
assert.equal(strings.containsEmoji('1F1F7 1F1F4 # 🇷🇴 Romania'), true);
|
||||
});
|
||||
|
||||
test('isBasicASCII', () => {
|
||||
function assertIsBasicASCII(str: string, expected: boolean): void {
|
||||
assert.equal(strings.isBasicASCII(str), expected, str + ` (${str.charCodeAt(0)})`);
|
||||
}
|
||||
assertIsBasicASCII('abcdefghijklmnopqrstuvwxyz', true);
|
||||
assertIsBasicASCII('ABCDEFGHIJKLMNOPQRSTUVWXYZ', true);
|
||||
assertIsBasicASCII('1234567890', true);
|
||||
assertIsBasicASCII('`~!@#$%^&*()-_=+[{]}\\|;:\'",<.>/?', true);
|
||||
assertIsBasicASCII(' ', true);
|
||||
assertIsBasicASCII('\t', true);
|
||||
assertIsBasicASCII('\n', true);
|
||||
assertIsBasicASCII('\r', true);
|
||||
|
||||
let ALL = '\r\t\n';
|
||||
for (let i = 32; i < 127; i++) {
|
||||
ALL += String.fromCharCode(i);
|
||||
}
|
||||
assertIsBasicASCII(ALL, true);
|
||||
|
||||
assertIsBasicASCII(String.fromCharCode(31), false);
|
||||
assertIsBasicASCII(String.fromCharCode(127), false);
|
||||
assertIsBasicASCII('ü', false);
|
||||
assertIsBasicASCII('a📚📚b', false);
|
||||
});
|
||||
|
||||
test('createRegExp', () => {
|
||||
// Empty
|
||||
assert.throws(() => strings.createRegExp('', false));
|
||||
|
||||
// Escapes appropriately
|
||||
assert.equal(strings.createRegExp('abc', false).source, 'abc');
|
||||
assert.equal(strings.createRegExp('([^ ,.]*)', false).source, '\\(\\[\\^ ,\\.\\]\\*\\)');
|
||||
assert.equal(strings.createRegExp('([^ ,.]*)', true).source, '([^ ,.]*)');
|
||||
|
||||
// Whole word
|
||||
assert.equal(strings.createRegExp('abc', false, { wholeWord: true }).source, '\\babc\\b');
|
||||
assert.equal(strings.createRegExp('abc', true, { wholeWord: true }).source, '\\babc\\b');
|
||||
assert.equal(strings.createRegExp(' abc', true, { wholeWord: true }).source, ' abc\\b');
|
||||
assert.equal(strings.createRegExp('abc ', true, { wholeWord: true }).source, '\\babc ');
|
||||
assert.equal(strings.createRegExp(' abc ', true, { wholeWord: true }).source, ' abc ');
|
||||
|
||||
const regExpWithoutFlags = strings.createRegExp('abc', true);
|
||||
assert(!regExpWithoutFlags.global);
|
||||
assert(regExpWithoutFlags.ignoreCase);
|
||||
assert(!regExpWithoutFlags.multiline);
|
||||
|
||||
const regExpWithFlags = strings.createRegExp('abc', true, { global: true, matchCase: true, multiline: true });
|
||||
assert(regExpWithFlags.global);
|
||||
assert(!regExpWithFlags.ignoreCase);
|
||||
assert(regExpWithFlags.multiline);
|
||||
});
|
||||
|
||||
test('getLeadingWhitespace', () => {
|
||||
assert.equal(strings.getLeadingWhitespace(' foo'), ' ');
|
||||
assert.equal(strings.getLeadingWhitespace(' foo', 2), '');
|
||||
assert.equal(strings.getLeadingWhitespace(' foo', 1, 1), '');
|
||||
assert.equal(strings.getLeadingWhitespace(' foo', 0, 1), ' ');
|
||||
assert.equal(strings.getLeadingWhitespace(' '), ' ');
|
||||
assert.equal(strings.getLeadingWhitespace(' ', 1), ' ');
|
||||
assert.equal(strings.getLeadingWhitespace(' ', 0, 1), ' ');
|
||||
assert.equal(strings.getLeadingWhitespace('\t\tfunction foo(){', 0, 1), '\t');
|
||||
assert.equal(strings.getLeadingWhitespace('\t\tfunction foo(){', 0, 2), '\t\t');
|
||||
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user