/** * Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info. * * @author David Sehnal */ import * as Sort from '../util/sort' function shuffle(data: T, len: number, clone: (s: T) => T, swap: Sort.Swapper = Sort.arraySwap) { const a = clone(data); for (let i = len - 1; i > 0; i--) { const j = Math.floor(Math.random() * (i + 1)); swap(a, i, j); } return a; } function shuffleArray(data: any[]) { return shuffle(data, data.length, t => [...t]); } describe('qsort-array asc', () => { const data0 = new Array(50); for (let i = 0; i < data0.length; i++) data0[i] = i; const data1 = [1, 1, 2, 2, 3, 3, 4, 4, 4, 6, 6, 6]; function test(name: string, data: any[], randomize: boolean) { it(name, () => { // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ]; if (randomize) { for (let i = 0; i < 10; i++) { expect(Sort.sortArray(shuffleArray(data))).toEqual(data); } } else { expect(Sort.sortArray([...data])).toEqual(data); } }); } test('uniq', data0, false); test('uniq shuffle', data0, true); test('rep', data1, false); test('rep shuffle', data1, true); }) describe('qsort-array generic', () => { const data0 = new Array(50); for (let i = 0; i < data0.length; i++) data0[i] = i; const data1 = [1, 1, 2, 2, 3, 3, 4, 4, 4, 6, 6, 6]; function test(name: string, data: any[], randomize: boolean) { it(name, () => { // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ]; if (randomize) { for (let i = 0; i < 10; i++) { expect(Sort.sort(shuffleArray(data), 0, data.length, Sort.arrayLess, Sort.arraySwap)).toEqual(data); } } else { expect(Sort.sort([...data], 0, data.length, Sort.arrayLess, Sort.arraySwap)).toEqual(data); } }); } test('uniq', data0, false); test('uniq shuffle', data0, true); test('rep', data1, false); test('rep shuffle', data1, true); }) describe('qsort-dual array', () => { const len = 3; const data = { xs: [0, 1, 2], ys: ['x', 'y', 'z'] }; const cmp: Sort.Comparer = (data, i, j) => data.xs[i] - data.xs[j]; const swap: Sort.Swapper = (data, i, j) => { Sort.arraySwap(data.xs, i, j); Sort.arraySwap(data.ys, i, j); } const clone = (d: typeof data) => ({ xs: [...d.xs], ys: [...d.ys] }) function test(name: string, src: typeof data, randomize: boolean) { it(name, () => { // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ]; if (randomize) { for (let i = 0; i < 10; i++) { expect(Sort.sort(shuffle(src, len, clone, swap), 0, len, cmp, swap)).toEqual(data); } } else { expect(Sort.sort(clone(src), 0, len, cmp, swap)).toEqual(data); } }); } test('sorted', data, false); test('shuffled', data, true); })