2021-05-21 15:17:21 +02:00
|
|
|
const ArrayUtils = require('./ArrayUtils');
|
2017-12-19 19:01:29 +00:00
|
|
|
|
2023-02-20 12:02:29 -03:00
|
|
|
describe('ArrayUtils', () => {
|
2017-12-19 19:01:29 +00:00
|
|
|
|
2022-11-15 10:23:50 +00:00
|
|
|
|
2017-12-19 19:01:29 +00:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should remove array elements', (async () => {
|
2017-12-19 19:01:29 +00:00
|
|
|
let a = ['un', 'deux', 'trois'];
|
|
|
|
a = ArrayUtils.removeElement(a, 'deux');
|
|
|
|
|
|
|
|
expect(a[0]).toBe('un');
|
|
|
|
expect(a[1]).toBe('trois');
|
|
|
|
expect(a.length).toBe(2);
|
|
|
|
|
|
|
|
a = ['un', 'deux', 'trois'];
|
|
|
|
a = ArrayUtils.removeElement(a, 'not in there');
|
|
|
|
expect(a.length).toBe(3);
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2017-12-19 19:01:29 +00:00
|
|
|
|
2022-05-26 15:57:44 +01:00
|
|
|
it('should pull array elements', (async () => {
|
|
|
|
expect(ArrayUtils.pull(['a', 'b', 'c', 'a', 'b', 'c'], 'a')).toEqual(['b', 'c', 'b', 'c']);
|
|
|
|
expect(ArrayUtils.pull(['b', 'c', 'b', 'c'], 'a')).toEqual(['b', 'c', 'b', 'c']);
|
|
|
|
expect(ArrayUtils.pull(['a', 'b', 'c', 'a', 'b', 'c'], 'a', 'c')).toEqual(['b', 'b']);
|
|
|
|
expect(ArrayUtils.pull([], 'a')).toEqual([]);
|
|
|
|
}));
|
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should find items using binary search', (async () => {
|
2018-01-29 20:51:14 +00:00
|
|
|
let items = ['aaa', 'ccc', 'bbb'];
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'bbb')).toBe(-1); // Array not sorted!
|
|
|
|
items.sort();
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'bbb')).toBe(1);
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'ccc')).toBe(2);
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'oops')).toBe(-1);
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'aaa')).toBe(0);
|
|
|
|
|
|
|
|
items = [];
|
|
|
|
expect(ArrayUtils.binarySearch(items, 'aaa')).toBe(-1);
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2018-01-29 20:51:14 +00:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should compare arrays', (async () => {
|
2018-05-10 12:02:39 +01:00
|
|
|
expect(ArrayUtils.contentEquals([], [])).toBe(true);
|
|
|
|
expect(ArrayUtils.contentEquals(['a'], ['a'])).toBe(true);
|
|
|
|
expect(ArrayUtils.contentEquals(['b', 'a'], ['a', 'b'])).toBe(true);
|
|
|
|
expect(ArrayUtils.contentEquals(['b'], ['a', 'b'])).toBe(false);
|
2019-09-23 23:23:10 +01:00
|
|
|
}));
|
2018-05-10 12:02:39 +01:00
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should merge overlapping intervals', (async () => {
|
2020-03-28 13:05:00 +00:00
|
|
|
const testCases = [
|
|
|
|
[
|
|
|
|
[],
|
|
|
|
[],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
[[0, 50]],
|
|
|
|
[[0, 50]],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
[[0, 20], [20, 30]],
|
|
|
|
[[0, 30]],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
[[0, 10], [10, 50], [15, 30], [20, 80], [80, 95]],
|
|
|
|
[[0, 95]],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
[[0, 5], [0, 10], [25, 35], [30, 60], [50, 60], [85, 100]],
|
|
|
|
[[0, 10], [25, 60], [85, 100]],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
[[0, 5], [10, 40], [35, 50], [35, 75], [50, 60], [80, 85], [80, 90]],
|
|
|
|
[[0, 5], [10, 75], [80, 90]],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2023-06-30 09:39:21 +01:00
|
|
|
// eslint-disable-next-line github/array-foreach -- Old code before rule was applied
|
2020-03-28 13:05:00 +00:00
|
|
|
testCases.forEach((t, i) => {
|
|
|
|
const intervals = t[0];
|
|
|
|
const expected = t[1];
|
|
|
|
|
|
|
|
const actual = ArrayUtils.mergeOverlappingIntervals(intervals, intervals.length);
|
|
|
|
expect(actual).toEqual(expected, `Test case ${i}`);
|
|
|
|
});
|
|
|
|
}));
|
|
|
|
|
2019-07-30 09:35:42 +02:00
|
|
|
});
|