2022-01-25 17:44:45 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { assert } from 'chai';
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
import { diffArraysAsSets } from '../../util/diffArraysAsSets';
|
|
|
|
|
|
|
|
function assertMatch<T>({
|
|
|
|
added,
|
|
|
|
removed,
|
|
|
|
}: {
|
|
|
|
added: Array<T>;
|
|
|
|
removed: Array<T>;
|
|
|
|
}) {
|
|
|
|
return added.length === 0 && removed.length === 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('diffArraysAsSets', () => {
|
2022-01-25 17:44:45 +00:00
|
|
|
it('returns true if arrays are both empty', () => {
|
|
|
|
const left: Array<string> = [];
|
|
|
|
const right: Array<string> = [];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
assertMatch(diffArraysAsSets(left, right));
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns true if arrays are equal', () => {
|
|
|
|
const left = [1, 2, 3];
|
|
|
|
const right = [1, 2, 3];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
assertMatch(diffArraysAsSets(left, right));
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns true if arrays are equal but out of order', () => {
|
|
|
|
const left = [1, 2, 3];
|
|
|
|
const right = [3, 1, 2];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
assertMatch(diffArraysAsSets(left, right));
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns true if arrays are equal but one has duplicates', () => {
|
|
|
|
const left = [1, 2, 3, 1];
|
|
|
|
const right = [1, 2, 3];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
assertMatch(diffArraysAsSets(left, right));
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns false if first array has missing elements', () => {
|
|
|
|
const left = [1, 2];
|
|
|
|
const right = [1, 2, 3];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
const { added, removed } = diffArraysAsSets(left, right);
|
|
|
|
assert.deepEqual(added, [3]);
|
|
|
|
assert.deepEqual(removed, []);
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns false if second array has missing elements', () => {
|
|
|
|
const left = [1, 2, 3];
|
|
|
|
const right = [1, 2];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
const { added, removed } = diffArraysAsSets(left, right);
|
|
|
|
assert.deepEqual(added, []);
|
|
|
|
assert.deepEqual(removed, [3]);
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('returns false if second array is empty', () => {
|
|
|
|
const left = [1, 2, 3];
|
|
|
|
const right: Array<number> = [];
|
|
|
|
|
2024-10-02 13:45:58 +00:00
|
|
|
const { added, removed } = diffArraysAsSets(left, right);
|
|
|
|
assert.deepEqual(added, []);
|
|
|
|
assert.deepEqual(removed, [1, 2, 3]);
|
2022-01-25 17:44:45 +00:00
|
|
|
});
|
|
|
|
});
|