mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
aa6fac68da
ESLint 4.x has stricter linting than previous versions. We are currently using the legacy indentation rules in the test directory. This commit changes the indentation of files to comply with the stricter 4.x linting and enable stricter linting in the test directory. PR-URL: https://github.com/nodejs/node/pull/14431 Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Vse Mozhet Byt <vsemozhetbyt@gmail.com> Reviewed-By: Trevor Norris <trev.norris@gmail.com>
54 lines
1.8 KiB
JavaScript
54 lines
1.8 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
|
|
if (!common.hasIntl)
|
|
common.skip('missing Intl');
|
|
|
|
const assert = require('assert');
|
|
const { domainToASCII, domainToUnicode } = require('url');
|
|
|
|
// Tests below are not from WPT.
|
|
const tests = require('../fixtures/url-idna.js');
|
|
const wptToASCIITests = require('../fixtures/url-toascii.js');
|
|
|
|
{
|
|
const expectedError = common.expectsError(
|
|
{ code: 'ERR_MISSING_ARGS', type: TypeError }, 2);
|
|
assert.throws(() => domainToASCII(), expectedError);
|
|
assert.throws(() => domainToUnicode(), expectedError);
|
|
assert.strictEqual(domainToASCII(undefined), 'undefined');
|
|
assert.strictEqual(domainToUnicode(undefined), 'undefined');
|
|
}
|
|
|
|
{
|
|
for (const [i, { ascii, unicode }] of tests.entries()) {
|
|
assert.strictEqual(ascii, domainToASCII(unicode),
|
|
`domainToASCII(${i + 1})`);
|
|
assert.strictEqual(unicode, domainToUnicode(ascii),
|
|
`domainToUnicode(${i + 1})`);
|
|
assert.strictEqual(ascii, domainToASCII(domainToUnicode(ascii)),
|
|
`domainToASCII(domainToUnicode(${i + 1}))`);
|
|
assert.strictEqual(unicode, domainToUnicode(domainToASCII(unicode)),
|
|
`domainToUnicode(domainToASCII(${i + 1}))`);
|
|
}
|
|
}
|
|
|
|
{
|
|
for (const [i, test] of wptToASCIITests.entries()) {
|
|
if (typeof test === 'string')
|
|
continue; // skip comments
|
|
const { comment, input, output } = test;
|
|
let caseComment = `Case ${i + 1}`;
|
|
if (comment)
|
|
caseComment += ` (${comment})`;
|
|
if (output === null) {
|
|
assert.strictEqual(domainToASCII(input), '', caseComment);
|
|
assert.strictEqual(domainToUnicode(input), '', caseComment);
|
|
} else {
|
|
assert.strictEqual(domainToASCII(input), output, caseComment);
|
|
const roundtripped = domainToASCII(domainToUnicode(input));
|
|
assert.strictEqual(roundtripped, output, caseComment);
|
|
}
|
|
}
|
|
}
|