1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- /**
- * Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info.
- *
- * @author David Sehnal <david.sehnal@gmail.com>
- */
- import Interval from '../interval'
- import SortedArray from '../sorted-array'
- describe('sortedArray', () => {
- function testI(name: string, a: Interval, b: Interval) {
- it(name, () => expect(Interval.areEqual(a, b)).toBe(true));
- }
- function test(name: string, a: any, b: any) {
- it(name, () => expect(a).toEqual(b));
- }
- const a1234 = SortedArray.ofSortedArray([1, 2, 3, 4]);
- const a2468 = SortedArray.ofSortedArray([2, 4, 6, 8]);
- test('size', SortedArray.size(a1234), 4);
- test('min/max', [SortedArray.min(a1234), SortedArray.max(a1234)], [1, 4]);
- test('start/end', [SortedArray.start(a1234), SortedArray.end(a1234)], [1, 5]);
- test('has', SortedArray.has(a1234, 5), false);
- test('has', SortedArray.has(a1234, 4), true);
- it('has-all', () => {
- for (let i = 1; i <= 4; i++) expect(SortedArray.has(a1234, i)).toBe(true);
- });
- test('indexOf', SortedArray.indexOf(a2468, 5), -1);
- test('indexOf', SortedArray.indexOf(a2468, 2), 0);
- test('getAt', a2468[1], 4);
- test('areEqual', SortedArray.areEqual(a2468, a2468), true);
- test('areEqual1', SortedArray.areEqual(a2468, SortedArray.ofUnsortedArray([4, 2, 8, 6])), true);
- test('areEqual2', SortedArray.areEqual(a1234, a2468), false);
- test('predIndex1', SortedArray.findPredecessorIndex(a1234, 5), 4);
- test('predIndex2', SortedArray.findPredecessorIndex(a1234, 2), 1);
- test('predIndex3', SortedArray.findPredecessorIndex(a2468, 4), 1);
- test('predIndex4', SortedArray.findPredecessorIndex(a2468, 3), 1);
- test('predIndexInt', SortedArray.findPredecessorIndexInInterval(a1234, 0, Interval.ofRange(2, 3)), 2);
- testI('findRange', SortedArray.findRange(a2468, 2, 4), Interval.ofRange(0, 1));
- // console.log(Interval.findPredecessorIndexInInterval(Interval.ofBounds(0, 3), 2, Interval.ofBounds(0, 3)))
- // console.log(SortedArray.findPredecessorIndexInInterval(SortedArray.ofSortedArray([0, 1, 2]), 2, Interval.ofBounds(0, 3)))
- });
|