mirror of
https://github.com/shaka-project/shaka-player.git
synced 2026-06-15 16:06:41 +03:00
7e6a0f38ff
This corrects/normalizes license headers in misc. files, such as config files, docs, build tools, tests, and externs. This does not affect the compiled output, and is only done for consistency. Issue #2638 Change-Id: I9d8da2de55243b08d7df2b743aac73c6f15e858a
59 lines
1.7 KiB
JavaScript
59 lines
1.7 KiB
JavaScript
/*! @license
|
|
* Shaka Player
|
|
* Copyright 2016 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
describe('ArrayUtils', () => {
|
|
const ArrayUtils = shaka.util.ArrayUtils;
|
|
|
|
describe('hasSameElements', () => {
|
|
it('determines same elements', () => {
|
|
expectEqual([], []);
|
|
expectEqual([1, 2, 3], [1, 2, 3]);
|
|
expectEqual([1, 2, 3], [3, 2, 1]);
|
|
expectEqual([1, 1, 2], [1, 2, 1]);
|
|
expectEqual([1, 2, 2, 1], [1, 2, 1, 2]);
|
|
expectEqual([1, NaN, NaN], [NaN, NaN, 1]);
|
|
|
|
expectNotEqual([1], [2]);
|
|
expectNotEqual([1, 2], [1]);
|
|
expectNotEqual([1, 1, 2], [1, 2]);
|
|
expectNotEqual([1, 2], [1, 1, 2]);
|
|
expectNotEqual([1, 2], [1, 2, 3]);
|
|
expectNotEqual([1, 2, 3, 1], [1, 2, 1, 2]);
|
|
});
|
|
|
|
it('handles different types', () => {
|
|
expectEqual(['1', 2], [2, '1']);
|
|
const a = {};
|
|
expectEqual([a], [a]);
|
|
expectEqual([1, a], [a, 1]);
|
|
|
|
expectNotEqual(['f'], [NaN]);
|
|
expectNotEqual([{}], [{}]);
|
|
expectNotEqual([1], [{}]);
|
|
expectNotEqual([1], ['1']);
|
|
});
|
|
|
|
it('allows custom comparer', () => {
|
|
const comp = (a, b) => a.i == b.i;
|
|
expectEqual([{i: 1}], [{i: 1}], comp);
|
|
expectEqual([{i: 1}, {i: 2}], [{i: 2}, {i: 1}], comp);
|
|
expectEqual([{i: 1}, {i: 1}], [{i: 1}, {i: 1}], comp);
|
|
expectEqual([{i: 1, x: 1}], [{i: 1, x: 2}], comp);
|
|
|
|
expectNotEqual([{i: 1}], [{i: 1}, {i: 1}], comp);
|
|
expectNotEqual([{i: 1}], [{i: 2}], comp);
|
|
});
|
|
|
|
function expectEqual(a, b, comp = undefined) {
|
|
expect(ArrayUtils.hasSameElements(a, b, comp)).toBe(true);
|
|
}
|
|
|
|
function expectNotEqual(a, b, comp = undefined) {
|
|
expect(ArrayUtils.hasSameElements(a, b, comp)).toBe(false);
|
|
}
|
|
});
|
|
});
|