mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
a7335bd1f0
In preparation for a lint rule that will enforce assert.deepStrictEqual() over assert.deepEqual(), change tests and benchmarks accordingly. For tests and benchmarks that are testing or benchmarking assert.deepEqual() itself, apply a comment to ignore the upcoming rule. PR-URL: https://github.com/nodejs/node/pull/6213 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
25 lines
729 B
JavaScript
25 lines
729 B
JavaScript
'use strict';
|
|
require('../common');
|
|
const assert = require('assert');
|
|
|
|
const qs = require('querystring');
|
|
|
|
assert.deepStrictEqual(qs.escape(5), '5');
|
|
assert.deepStrictEqual(qs.escape('test'), 'test');
|
|
assert.deepStrictEqual(qs.escape({}), '%5Bobject%20Object%5D');
|
|
assert.deepStrictEqual(qs.escape([5, 10]), '5%2C10');
|
|
|
|
// using toString for objects
|
|
assert.strictEqual(
|
|
qs.escape({test: 5, toString: () => 'test', valueOf: () => 10 }),
|
|
'test'
|
|
);
|
|
|
|
// toString is not callable, must throw an error
|
|
assert.throws(() => qs.escape({toString: 5}));
|
|
|
|
// should use valueOf instead of non-callable toString
|
|
assert.strictEqual(qs.escape({toString: 5, valueOf: () => 'test'}), 'test');
|
|
|
|
assert.throws(() => qs.escape(Symbol('test')));
|