Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v9.9.0 proposal #19428

Merged
merged 134 commits into from
Mar 21, 2018
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
134 commits
Select commit Hold shift + click to select a range
5a78c6c
doc: improve assert documentation
BridgeAR Nov 13, 2017
bae5de1
assert: add strict functionality export
BridgeAR Nov 13, 2017
db73d1c
assert: use object argument in innerFail
BridgeAR Dec 9, 2017
24aeca7
assert: fix throws and doesNotThrow stack frames
BridgeAR Dec 15, 2017
1e5c7e3
test: refactor common.expectsError
BridgeAR Dec 15, 2017
612ba1a
assert: improve assert.throws
BridgeAR Dec 9, 2017
7457093
doc: improve .throws RegExp info
BridgeAR Dec 11, 2017
ebd60fa
assert: .throws accept objects
BridgeAR Dec 10, 2017
f96ea47
assert: fix strict regression
BridgeAR Dec 28, 2017
b35eabb
lib: handle `throw undefined` in assert.throws()
bnoordhuis Jan 7, 2018
fd4c05a
util: fix custom inspect description
BridgeAR Dec 9, 2017
ce3a5af
util: rename util.inspect argument
BridgeAR Dec 9, 2017
c18ac52
util: add util.inspect compact option
BridgeAR Dec 9, 2017
5aa3a2d
assert: improve error messages
BridgeAR Dec 9, 2017
ead727c
tty: add getColorDepth function
BridgeAR Jan 16, 2018
74f0d1a
tty: refactor to es6
BridgeAR Jan 17, 2018
d3c2534
assert: use destructuring for errors
BridgeAR Jan 22, 2018
e9ac468
assert: fix throws trace
BridgeAR Feb 6, 2018
968b867
doc: document asserts Weak(Map|Set) behavior
BridgeAR Jan 19, 2018
9abbb6b
assert: fix infinite loop
BridgeAR Feb 7, 2018
5e6b42e
assert: show proper differences
BridgeAR Feb 7, 2018
16ab3b5
test: address unreliable test-performance
Trott Mar 8, 2018
b01bd80
fs: fix `createReadStream(…, {end: n})` for non-seekable fds
addaleax Mar 13, 2018
9c0c0e6
stream: add no-half-open enforcer only if needed
lpinca Feb 23, 2018
8d33e5c
assert: improve error check
BridgeAR Dec 9, 2017
9ec0eab
doc: make suggestion more direct in stream.md
Trott Mar 4, 2018
27088cf
doc: improve onboarding instructions
joyeecheung Mar 3, 2018
152c931
stream: make Duplex inherits from DuplexBase
lpinca Mar 5, 2018
5b12d3a
net: do not inherit the no-half-open enforcer
lpinca Feb 24, 2018
12f19a6
n-api: update documentation
Mar 1, 2018
46b5915
test: skip postmortem metadata test when nm fails
joyeecheung Mar 3, 2018
84acb9f
doc: add inspector usage example
ofrobots Mar 6, 2018
563bed0
benchmark,lib,test,tools: use consistent quotes
Trott Mar 5, 2018
64f6462
src: use smart pointer in AsyncWrap::WeakCallback
danbev Mar 6, 2018
9557e66
doc: update labels info in onboarding-extras.md
Trott Mar 6, 2018
fa43d2f
test: rename test-regress-GH-1726
ryzokuken Mar 6, 2018
da44c2c
test: rename test-regress-GH-1697
ryzokuken Mar 6, 2018
bdbfc0e
test: rename test-regress-GH-4015
ryzokuken Mar 6, 2018
2262a34
test: rename test-regress-GH-4027
ryzokuken Mar 6, 2018
22484e1
test: rename tests to remove "regress" keyword
ryzokuken Mar 6, 2018
c0c6d58
test: address nits and rename the corresponding fixture
ryzokuken Mar 6, 2018
636a5f6
test: rename test-regress-GH-784.js
ryzokuken Mar 6, 2018
0ece7cc
test: rename test-regress-GH-877.js
ryzokuken Mar 6, 2018
5c21d16
doc: add watson to collaborators
watson Mar 8, 2018
d117f5f
doc: remove warning against readable/readable.read
Trott Mar 7, 2018
044995e
crypto: use bool over int consistently
tniessen Mar 8, 2018
38eb432
test: refactor http-https-default-ports
ken23421 Mar 4, 2018
7c36175
doc: remove superfluous adverb from style guide
Trott Mar 8, 2018
a04e4ae
doc: remove confusing "cats" from style guide
Trott Mar 8, 2018
27754c5
src: add incr/decr operators for Reference
danbev Mar 2, 2018
5a1437c
build: update arm64 minimum supported platform
gibfahn Mar 6, 2018
9613e02
tools,bootstrap: preprocess gypi files to json
devsnek Mar 5, 2018
a4a4819
test: do not check text for engine-generated error
Trott Mar 8, 2018
411f3e0
test: remove flaky status for test-npm-install
Trott Mar 8, 2018
8e88a18
doc: add warning to assert.doesNotThrow()
BridgeAR Feb 10, 2018
3e6858e
repl: better handling of recoverable errors
princejwesley Feb 21, 2018
e4c320e
test: Remove unnecessary asserion messages in test-crypto-hash.js
pgrzesik Feb 25, 2018
530b8a4
benchmark: fix benchmark for url
daynin Mar 2, 2018
f0c8f69
test: fix test-abort-backtrace in shared lib build
yhwang Mar 7, 2018
6c5afeb
doc: make caveat in stream.md more concise
Trott Mar 9, 2018
c9b12f3
doc: remove superfluous text in onboarding-extras
Trott Mar 9, 2018
d3bc72e
test: name test files appropriately
ryzokuken Mar 7, 2018
b8ca616
test: fix compiler warnings in callback-scope
danbev Mar 9, 2018
4b9914a
src: avoid duplicate Before/AtExitCallback structs
danbev Mar 8, 2018
71b1c7f
async_hooks: don't set hook_fields[kTotals] to 0
danbev Mar 7, 2018
49481d0
src: add convenience ctor for async trigger id scope
addaleax Mar 7, 2018
0602166
tls: expose Finished messages in TLSSocket
codedot Mar 2, 2018
89fbbc4
http2: simplify timeout tracking
addaleax Feb 22, 2018
84ae59e
test: fix path in doctool/test-doctool-json
vsemozhetbyt Mar 11, 2018
f679ac1
n-api: resolve promise in test
Mar 8, 2018
f84f548
test: fix assertion argument order
Trott Mar 9, 2018
f06622c
lib: define printErr() in script string
cjihrig Mar 11, 2018
f36521b
n-api,test: add a new.target test to addons-napi
boingoing Jan 17, 2018
66694e2
tools: fix test-npm-package
targos Mar 12, 2018
be20914
test: shared lib build doesn't handle SIGPIPE
yhwang Mar 7, 2018
e247f19
doc: improve style guide text
Trott Mar 9, 2018
11a0ef5
test: delete test/parallel/test-regress-GH-4948
ryzokuken Mar 11, 2018
e208282
src: refactor emit before/after/promiseResolve
danbev Mar 12, 2018
7f652c2
doc: update username and email
hiroppy Mar 14, 2018
3f7c4ee
build: do not cd on vcbuild help
vsemozhetbyt Mar 12, 2018
a9bd8bf
path: remove redundant function
daynin Mar 8, 2018
5da3ee7
doc: clarify default TLS handshake timeout
Trott Mar 12, 2018
9aa5090
test: fix test-cluster-send-handle-large-payload
Trott Mar 13, 2018
5a56327
doc: fix minor issues in async_hooks.md
Trott Mar 13, 2018
99e6734
doc: improve best practices in onboarding-extras
Trott Mar 13, 2018
0c9577e
n-api,test: add int64 bounds tests
kfarnung Mar 12, 2018
03fb817
src: add extractPromiseWrap function
danbev Mar 13, 2018
126a161
src: fix indenting of wrap->EmitTraceEventBefore
danbev Mar 14, 2018
7a3d1d2
src: remove unused uv.h include from async_wrap.cc
danbev Mar 14, 2018
c1fa092
doc: fix typos on n-api
shama Mar 16, 2018
01749f0
test: fix flaky test-http2-settings-flood
Trott Mar 14, 2018
528798c
n-api: add missing exception checking
mhdawson Mar 15, 2018
072adfe
url: replace "magic" numbers by constants
daynin Feb 27, 2018
b229912
doc: do not announce obvious examples
Trott Mar 9, 2018
f490421
test: use descriptive names for regression tests
ryzokuken Mar 10, 2018
054dd28
src: make AsyncWrap constructors delegate
danbev Mar 15, 2018
43c482b
src: fix indentation of params in env-inl.h
danbev Mar 16, 2018
42b6d80
http2: don't aggressively inline
jasnell Mar 16, 2018
4277635
http2: clean up Http2Settings
jasnell Mar 16, 2018
3bf69cd
http2: some general code improvements
jasnell Mar 16, 2018
7df6d9d
test: rename regression tests file names
ryzokuken Mar 13, 2018
da62c5c
src: fix minor typo in comment stream_base.h
danbev Mar 18, 2018
0e6f720
n-api: separate out async_hooks test
Mar 16, 2018
e3ce084
test: fix flaky test-http2-ping-flood
Trott Mar 16, 2018
8757799
src: remove unused stdlib.h include
danbev Mar 18, 2018
f0f31d0
async_hooks: add copyHooks function
danbev Mar 16, 2018
519850f
test: http2 client setNextStreamID errors
trivikr Feb 18, 2018
03c321a
crypto: allow passing null as IV unless required
tniessen Feb 7, 2018
5966b8c
deps: v8: cherry-pick fixes for v8:7535
Flarna Mar 13, 2018
1ba1861
src: remove unused using declarations async_wrap
danbev Feb 21, 2018
49391a7
src: fix util abort
BridgeAR Mar 7, 2018
607b33c
fs: support as and as+ flags in stringToFlags()
SirR4T Feb 15, 2018
a4c28d7
doc: fix deprecation removed by mistake
targos Mar 20, 2018
36f664e
deps: V8: backport 596d55a from upstream
MylesBorins Sep 18, 2017
22b8f9f
test: introduce SetUpTestCase/TearDownTestCase
danbev Feb 3, 2018
4e9279d
test: remove NodeTestFixture from Env constructor
danbev Feb 3, 2018
5478746
test: refactor assert test
BridgeAR Feb 6, 2018
574d061
test: remove assert.doesNotThrow()
BridgeAR Feb 9, 2018
1eac1d7
test: minor refactoring
BridgeAR Feb 10, 2018
d795865
tools: add assert.doesNotThrow eslint rule
BridgeAR Feb 12, 2018
9d1e409
tools: enable no-unsafe-finally
BridgeAR Feb 13, 2018
ff82acb
doc: update buffer examples
BridgeAR Feb 12, 2018
9e10ddc
tools: enable eslint no-undef-init rule
BridgeAR Feb 17, 2018
d4d7df8
tools: enable eslint strict key-spacing
BridgeAR Feb 17, 2018
b04dd7b
tools: enable eslint one-var rule
BridgeAR Feb 17, 2018
cb732ae
doc: enable eslint prefer-template rule
BridgeAR Feb 17, 2018
d57a242
errors: implement new error handling
BridgeAR Feb 19, 2018
ffa16aa
errors: update all internal errors
BridgeAR Feb 19, 2018
07845fc
console: port errors to new system
BridgeAR Feb 19, 2018
f4f0266
errors: add comments about falsy error types
BridgeAR Feb 19, 2018
6997af7
repl: upper case comments first char
BridgeAR Dec 30, 2017
55f7bbb
repl: refactor code for readability
BridgeAR Dec 30, 2017
3914e97
http2: fixes error handling
mcollina Mar 8, 2018
74fb02f
2018-03-21, Version 9.9.0 (Current)
MylesBorins Mar 18, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
assert: use object argument in innerFail
Right now it is difficult to know what argument stands for what
property. By refactoring the arguments into a object it is clear
what stands for what.

Backport-PR-URL: #19230
PR-URL: #17582
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Jon Moss <me@jonathanmoss.me>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Anatoli Papirovski <apapirovski@mac.com>
  • Loading branch information
BridgeAR authored and MylesBorins committed Mar 20, 2018
commit db73d1c13bd65ceb1293353e4fb733d0f3f81460
118 changes: 92 additions & 26 deletions lib/assert.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,19 +36,13 @@ const assert = module.exports = ok;
// both the actual and expected values to the assertion error for
// display purposes.

function innerFail(actual, expected, message, operator, stackStartFunction) {
if (message instanceof Error) throw message;
function innerFail(obj) {
if (obj.message instanceof Error) throw obj.message;

throw new errors.AssertionError({
message,
actual,
expected,
operator,
stackStartFunction
});
throw new errors.AssertionError(obj);
}

function fail(actual, expected, message, operator, stackStartFunction) {
function fail(actual, expected, message, operator, stackStartFn) {
const argsLen = arguments.length;

if (argsLen === 0) {
Expand All @@ -60,7 +54,13 @@ function fail(actual, expected, message, operator, stackStartFunction) {
operator = '!=';
}

innerFail(actual, expected, message, operator, stackStartFunction || fail);
innerFail({
actual,
expected,
message,
operator,
stackStartFn: stackStartFn || fail
});
}

assert.fail = fail;
Expand All @@ -75,67 +75,124 @@ assert.AssertionError = errors.AssertionError;
// Pure assertion tests whether a value is truthy, as determined
// by !!value.
function ok(value, message) {
if (!value) innerFail(value, true, message, '==', ok);
if (!value) {
innerFail({
actual: value,
expected: true,
message,
operator: '==',
stackStartFn: ok
});
}
}
assert.ok = ok;

// The equality assertion tests shallow, coercive equality with ==.
/* eslint-disable no-restricted-properties */
assert.equal = function equal(actual, expected, message) {
// eslint-disable-next-line eqeqeq
if (actual != expected) innerFail(actual, expected, message, '==', equal);
if (actual != expected) {
innerFail({
actual,
expected,
message,
operator: '==',
stackStartFn: equal
});
}
};

// The non-equality assertion tests for whether two objects are not
// equal with !=.
assert.notEqual = function notEqual(actual, expected, message) {
// eslint-disable-next-line eqeqeq
if (actual == expected) {
innerFail(actual, expected, message, '!=', notEqual);
innerFail({
actual,
expected,
message,
operator: '!=',
stackStartFn: notEqual
});
}
};

// The equivalence assertion tests a deep equality relation.
assert.deepEqual = function deepEqual(actual, expected, message) {
if (!isDeepEqual(actual, expected)) {
innerFail(actual, expected, message, 'deepEqual', deepEqual);
innerFail({
actual,
expected,
message,
operator: 'deepEqual',
stackStartFn: deepEqual
});
}
};

// The non-equivalence assertion tests for any deep inequality.
assert.notDeepEqual = function notDeepEqual(actual, expected, message) {
if (isDeepEqual(actual, expected)) {
innerFail(actual, expected, message, 'notDeepEqual', notDeepEqual);
innerFail({
actual,
expected,
message,
operator: 'notDeepEqual',
stackStartFn: notDeepEqual
});
}
};
/* eslint-enable */

assert.deepStrictEqual = function deepStrictEqual(actual, expected, message) {
if (!isDeepStrictEqual(actual, expected)) {
innerFail(actual, expected, message, 'deepStrictEqual', deepStrictEqual);
innerFail({
actual,
expected,
message,
operator: 'deepStrictEqual',
stackStartFn: deepStrictEqual
});
}
};

assert.notDeepStrictEqual = notDeepStrictEqual;
function notDeepStrictEqual(actual, expected, message) {
if (isDeepStrictEqual(actual, expected)) {
innerFail(actual, expected, message, 'notDeepStrictEqual',
notDeepStrictEqual);
innerFail({
actual,
expected,
message,
operator: 'notDeepStrictEqual',
stackStartFn: notDeepStrictEqual
});
}
}

// The strict equality assertion tests strict equality, as determined by ===.
assert.strictEqual = function strictEqual(actual, expected, message) {
if (actual !== expected) {
innerFail(actual, expected, message, '===', strictEqual);
innerFail({
actual,
expected,
message,
operator: '===',
stackStartFn: strictEqual
});
}
};

// The strict non-equality assertion tests for strict inequality, as
// determined by !==.
assert.notStrictEqual = function notStrictEqual(actual, expected, message) {
if (actual === expected) {
innerFail(actual, expected, message, '!==', notStrictEqual);
innerFail({
actual,
expected,
message,
operator: '!==',
stackStartFn: notStrictEqual
});
}
};

Expand Down Expand Up @@ -183,18 +240,27 @@ function innerThrows(shouldThrow, block, expected, message) {
details += ` (${expected.name})`;
}
details += message ? `: ${message}` : '.';
fail(actual, expected, `Missing expected exception${details}`, 'throws');
innerFail({
actual,
expected,
operator: 'throws',
message: `Missing expected exception${details}`,
stackStartFn: innerThrows
});
}
if (expected && expectedException(actual, expected) === false) {
throw actual;
}
} else if (actual !== undefined) {
if (!expected || expectedException(actual, expected)) {
details = message ? `: ${message}` : '.';
fail(actual,
expected,
`Got unwanted exception${details}\n${actual.message}`,
'doesNotThrow');
innerFail({
actual,
expected,
operator: 'doesNotThrow',
message: `Got unwanted exception${details}\n${actual.message}`,
stackStartFn: innerThrows
});
}
throw actual;
}
Expand Down
4 changes: 2 additions & 2 deletions lib/internal/errors.js
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ class AssertionError extends Error {
if (typeof options !== 'object' || options === null) {
throw new exports.TypeError('ERR_INVALID_ARG_TYPE', 'options', 'Object');
}
var { actual, expected, message, operator, stackStartFunction } = options;
var { actual, expected, message, operator, stackStartFn } = options;
if (message) {
super(message);
} else {
Expand All @@ -102,7 +102,7 @@ class AssertionError extends Error {
this.actual = actual;
this.expected = expected;
this.operator = operator;
Error.captureStackTrace(this, stackStartFunction);
Error.captureStackTrace(this, stackStartFn);
}
}

Expand Down
2 changes: 1 addition & 1 deletion test/message/error_exit.out
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Exiting with code=1
assert.js:*
throw new errors.AssertionError({
throw new errors.AssertionError(obj);
^

AssertionError [ERR_ASSERTION]: 1 === 2
Expand Down
9 changes: 9 additions & 0 deletions test/parallel/test-assert.js
Original file line number Diff line number Diff line change
Expand Up @@ -780,3 +780,12 @@ common.expectsError(
/* eslint-enable no-restricted-properties */
assert(7);
}

common.expectsError(
() => assert.ok(null),
{
code: 'ERR_ASSERTION',
type: assert.AssertionError,
message: 'null == true'
}
);