Skip to content

Commit

Permalink
fix: corrections to assert.compareArray and assert.compareArray.format (
Browse files Browse the repository at this point in the history
  • Loading branch information
rwaldron authored Oct 1, 2021
1 parent d9ddf80 commit b3158bc
Show file tree
Hide file tree
Showing 11 changed files with 114 additions and 45 deletions.
15 changes: 9 additions & 6 deletions harness/compareArray.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,17 +26,20 @@ compareArray.isSameValue = function(a, b) {
return a === b;
};

compareArray.format = function(array) {
return `[${array.map(String).join(', ')}]`;
compareArray.format = function(arrayLike) {
return `[${[].map.call(arrayLike, String).join(', ')}]`;
};

assert.compareArray = function(actual, expected, message) {
message = message === undefined ? '' : message;
assert(actual != null, `First argument shouldn't be nullish. ${message}`);
assert(expected != null, `Second argument shouldn't be nullish. ${message}`);
var format = compareArray.format;
assert(
compareArray(actual, expected),
`Expected ${format(actual)} and ${format(expected)} to have the same contents. ${message}`
);
var result = compareArray(actual, expected);

// The following prevents actual and expected from being iterated and evaluated
// more than once unless absolutely necessary.
if (!result) {
assert(false, `Expected ${format(actual)} and ${format(expected)} to have the same contents. ${message}`);
}
};
38 changes: 38 additions & 0 deletions test/harness/compare-array-arguments.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
// Copyright (C) 2021 Rick Waldron. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.

/*---
description: >
Accepts spreadable arguments
includes: [compareArray.js]
---*/

const fixture = [0, 'a', undefined];

function checkFormatOfAssertionMessage(func, errorMessage) {
var caught = false;
try {
func();
} catch (error) {
caught = true;
assert.sameValue(error.constructor, Test262Error);
assert.sameValue(error.message, errorMessage);
}

assert(caught, `Expected ${func} to throw, but it didn't.`);
}

function f() {
assert.compareArray(arguments, fixture);
assert.compareArray(fixture, arguments);

checkFormatOfAssertionMessage(() => {
assert.compareArray(arguments, [], 'arguments and []');
}, 'Expected [0, a, undefined] and [] to have the same contents. arguments and []');

checkFormatOfAssertionMessage(() => {
assert.compareArray([], arguments, '[] and arguments');
}, 'Expected [] and [0, a, undefined] to have the same contents. [] and arguments');
}

f(...fixture);
34 changes: 34 additions & 0 deletions test/harness/compare-array-arraylike.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
// Copyright (C) 2021 Rick Waldron. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.

/*---
description: >
Accepts spreadable arguments
includes: [compareArray.js]
---*/

function checkFormatOfAssertionMessage(func, errorMessage) {
var caught = false;
try {
func();
} catch (error) {
caught = true;
assert.sameValue(error.constructor, Test262Error);
assert.sameValue(error.message, errorMessage);
}

assert(caught, `Expected ${func} to throw, but it didn't.`);
}

const fixture = { length: 3, 0: 0, 1: 'a', 2: undefined};

assert.compareArray(fixture, [0, 'a', undefined]);
assert.compareArray([0, 'a', undefined], fixture);

checkFormatOfAssertionMessage(() => {
assert.compareArray(fixture, [], 'fixture and []');
}, 'Expected [0, a, undefined] and [] to have the same contents. fixture and []');

checkFormatOfAssertionMessage(() => {
assert.compareArray([], fixture, '[] and fixture');
}, 'Expected [] and [0, a, undefined] to have the same contents. [] and fixture');
6 changes: 3 additions & 3 deletions test/harness/compare-array-different-elements.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@ includes: [compareArray.js]
var first = [0, 'a', undefined];
var second = [0, 'b', undefined];

if (compareArray(first, second) !== false) {
throw new Error('Arrays containing different elements are not equivalent.');
}
assert.throws(Test262Error, () => {
assert.compareArray(first, second);
}, 'Arrays containing different elements are not equivalent.');
13 changes: 7 additions & 6 deletions test/harness/compare-array-different-length.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,11 @@ description: >
includes: [compareArray.js]
---*/

if (compareArray([], [undefined]) !== false) {
throw new Error('Arrays of differing lengths are not equivalent.');
}

if (compareArray([undefined], []) !== false) {
throw new Error('Arrays of differing lengths are not equivalent.');
}
assert.throws(Test262Error, () => {
assert.compareArray([], [undefined]);
}, 'Arrays of differing lengths are not equivalent.');

assert.throws(Test262Error, () => {
assert.compareArray([undefined], []);
}, 'Arrays of differing lengths are not equivalent.');
4 changes: 1 addition & 3 deletions test/harness/compare-array-empty.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,4 @@ description: >
includes: [compareArray.js]
---*/

if (compareArray([], []) !== true) {
throw new Error('Empty arrays are equivalent.');
}
assert.compareArray([], [], 'Empty arrays are equivalent.');
6 changes: 3 additions & 3 deletions test/harness/compare-array-same-elements-different-order.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,6 @@ var obj = {};
var first = [0, 1, '', 's', null, undefined, obj];
var second = [0, 1, '', 's', undefined, null, obj];

if (compareArray(first, second) !== false) {
throw new Error('Arrays containing the same elements in different order are not equivalent.');
}
assert.throws(Test262Error, () => {
assert.compareArray(first, second);
}, 'Arrays containing the same elements in different order are not equivalent.');
4 changes: 1 addition & 3 deletions test/harness/compare-array-same-elements-same-order.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,4 @@ var obj = {};
var first = [0, 1, '', 's', undefined, null, obj];
var second = [0, 1, '', 's', undefined, null, obj];

if (compareArray(first, second) !== true) {
throw new Error('Arrays containing the same elements in the same order are equivalent.');
}
assert.compareArray(first, second, 'Arrays containing the same elements in the same order are equivalent.');
6 changes: 4 additions & 2 deletions test/harness/compare-array-samevalue.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,7 @@ description: >
includes: [compareArray.js]
---*/

assert(compareArray([NaN], [NaN]));
assert(!compareArray([0], [-0]));
assert.compareArray([NaN], [NaN]);
assert.throws(Test262Error, () => {
assert.compareArray([0], [-0]);
});
31 changes: 13 additions & 18 deletions test/harness/compare-array-sparse.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,22 +7,17 @@ description: >
includes: [compareArray.js]
---*/

if (compareArray([,], [,]) !== true) {
throw new Error('Sparse arrays of the same length are equivalent.');
}

if (compareArray([,], [,,]) !== false) {
throw new Error('Sparse arrays of differing lengths are not equivalent.');
}

if (compareArray([,,], [,]) !== false) {
throw new Error('Sparse arrays of differing lengths are not equivalent.');
}

if (compareArray([,], []) !== false) {
throw new Error('Sparse arrays are not equivalent to empty arrays.');
}

if (compareArray([], [,]) !== false) {
throw new Error('Sparse arrays are not equivalent to empty arrays.');
}
assert.compareArray([,], [,], 'Sparse arrays of the same length are equivalent.');
assert.throws(Test262Error, () => {
assert.compareArray([,], [,,]);
}, 'Sparse arrays of differing lengths are not equivalent.');
assert.throws(Test262Error, () => {
assert.compareArray([,,], [,]);
}, 'Sparse arrays of differing lengths are not equivalent.');
assert.throws(Test262Error, () => {
assert.compareArray([,], []);
}, 'Sparse arrays are not equivalent to empty arrays.');
assert.throws(Test262Error, () => {
assert.compareArray([], [,]);
}, 'Sparse arrays are not equivalent to empty arrays.');
2 changes: 1 addition & 1 deletion test/harness/compare-array-symbol.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ features: [Symbol]
var threw = false;

try {
assert.compareArray([Symbol()], [Symbol('desc')]);
assert.compareArray([Symbol()], [Symbol('desc')]);
} catch (err) {
threw = true;

Expand Down

0 comments on commit b3158bc

Please sign in to comment.