/**
|
* @license
|
* Copyright 2023 Google LLC. All Rights Reserved.
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
* you may not use this file except in compliance with the License.
|
* You may obtain a copy of the License at
|
*
|
* http://www.apache.org/licenses/LICENSE-2.0
|
*
|
* Unless required by applicable law or agreed to in writing, software
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* See the License for the specific language governing permissions and
|
* limitations under the License.
|
* =============================================================================
|
*/
|
import { expectArraysEqual } from '../test_util';
|
import { CompositeArrayBuffer } from './composite_array_buffer';
|
describe('CompositeArrayBuffer', () => {
|
const uniformBuffers = [
|
new Uint8Array([0, 1, 2, 3]).buffer,
|
new Uint8Array([4, 5, 6, 7]).buffer,
|
new Uint8Array([8, 9, 10, 11]).buffer,
|
new Uint8Array([12, 13, 14, 15]).buffer,
|
new Uint8Array([16]).buffer,
|
];
|
const nonUniformBuffers = [
|
new Uint8Array([0, 1, 2]).buffer,
|
new Uint8Array([3, 4, 5, 6, 7]).buffer,
|
new Uint8Array([8, 9, 10, 11]).buffer,
|
new Uint8Array([12, 13, 14, 15, 16]).buffer,
|
];
|
const bufferTestCases = [
|
['uniform', uniformBuffers],
|
['non-uniform', nonUniformBuffers]
|
];
|
for (const [buffersType, buffers] of bufferTestCases) {
|
let composite;
|
beforeEach(() => {
|
composite = new CompositeArrayBuffer(buffers);
|
});
|
it(`${buffersType}: slices across multiple buffers`, () => {
|
expectArraysEqual(new Uint8Array(composite.slice(1, 13)), [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]);
|
});
|
it(`${buffersType}: slices to the end of the array when \'end\' is not ` +
|
'specified', () => {
|
expectArraysEqual(new Uint8Array(composite.slice(5)), [5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]);
|
});
|
it(`${buffersType}: makes a copy when slice() is called with no arguments`, () => {
|
expectArraysEqual(new Uint8Array(composite.slice()), [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]);
|
});
|
it(`${buffersType}: slices from zero when start is negative`, () => {
|
expectArraysEqual(new Uint8Array(composite.slice(-4, 5)), [0, 1, 2, 3, 4]);
|
});
|
it(`${buffersType}: slices to the end when end is greater than length`, () => {
|
expectArraysEqual(new Uint8Array(composite.slice(7, 1000)), [7, 8, 9, 10, 11, 12, 13, 14, 15, 16]);
|
});
|
it(`${buffersType}: slices multiple ranges out of order`, () => {
|
expectArraysEqual(new Uint8Array(composite.slice(13, 15)), [13, 14]);
|
expectArraysEqual(new Uint8Array(composite.slice(0, 2)), [0, 1]);
|
expectArraysEqual(new Uint8Array(composite.slice(9, 13)), [9, 10, 11, 12]);
|
});
|
}
|
it('can be created from an empty arraybuffer', () => {
|
const array = new Uint8Array([]);
|
const singleComposite = new CompositeArrayBuffer(array.buffer);
|
expectArraysEqual(new Uint8Array(singleComposite.slice()), []);
|
});
|
it('can be created from a single array', () => {
|
const array = new Uint8Array([1, 2, 3]);
|
const singleComposite = new CompositeArrayBuffer(array.buffer);
|
expectArraysEqual(new Uint8Array(singleComposite.slice()), array);
|
});
|
it('can be created from zero arrays', () => {
|
const singleComposite = new CompositeArrayBuffer([]);
|
expectArraysEqual(new Uint8Array(singleComposite.slice()), new Uint8Array());
|
});
|
it('can be created from undefined input', () => {
|
const singleComposite = new CompositeArrayBuffer();
|
expectArraysEqual(new Uint8Array(singleComposite.slice()), new Uint8Array());
|
});
|
it('treats NaN as zero when passed as the start of slice', () => {
|
const array = new Uint8Array([1, 2, 3]);
|
const composite = new CompositeArrayBuffer(array.buffer);
|
expectArraysEqual(new Uint8Array(composite.slice(NaN, 2)), [1, 2]);
|
});
|
it('treats NaN as zero when passed as the end of slice', () => {
|
const array = new Uint8Array([1, 2, 3]);
|
const composite = new CompositeArrayBuffer(array.buffer);
|
expectArraysEqual(new Uint8Array(composite.slice(0, NaN)), []);
|
});
|
it('supports TypedArray input', () => {
|
// This support is necessary for some tests in tfjs-converter. Maybe those
|
// tests are misconfigured?
|
const array = new Uint8Array([1, 2, 3]);
|
const composite = new CompositeArrayBuffer(array);
|
expectArraysEqual(new Uint8Array(composite.slice(0, 2)), [1, 2]);
|
});
|
});
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"composite_array_buffer_test.js","sourceRoot":"","sources":["../../../../../../tfjs-core/src/io/composite_array_buffer_test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2023 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport {expectArraysEqual} from '../test_util';\nimport {CompositeArrayBuffer} from './composite_array_buffer';\n\ndescribe('CompositeArrayBuffer', () => {\n  const uniformBuffers = [\n    new Uint8Array([0, 1, 2, 3]).buffer,\n    new Uint8Array([4, 5, 6, 7]).buffer,\n    new Uint8Array([8, 9, 10, 11]).buffer,\n    new Uint8Array([12, 13, 14, 15]).buffer,\n    new Uint8Array([16]).buffer,\n  ];\n\n  const nonUniformBuffers = [\n    new Uint8Array([0, 1, 2]).buffer,\n    new Uint8Array([3, 4, 5, 6, 7]).buffer,\n    new Uint8Array([8, 9, 10, 11]).buffer,\n    new Uint8Array([12, 13, 14, 15, 16]).buffer,\n  ];\n\n  const bufferTestCases = [\n    ['uniform', uniformBuffers],\n    ['non-uniform', nonUniformBuffers]\n  ] as const;\n\n  for (const [buffersType, buffers] of bufferTestCases) {\n    let composite: CompositeArrayBuffer;\n    beforeEach(() => {\n      composite = new CompositeArrayBuffer(buffers);\n    });\n\n    it(`${buffersType}: slices across multiple buffers`, () => {\n      expectArraysEqual(new Uint8Array(composite.slice(1, 13)),\n                        [1,2,3,4,5,6,7,8,9,10,11,12]);\n    });\n\n    it(`${buffersType}: slices to the end of the array when \\'end\\' is not ` +\n      'specified', () => {\n        expectArraysEqual(new Uint8Array(composite.slice(5)),\n                          [5,6,7,8,9,10,11,12,13,14,15,16]);\n      });\n\n    it(`${buffersType}: makes a copy when slice() is called with no arguments`,\n       () => {\n         expectArraysEqual(new Uint8Array(composite.slice()),\n                           [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16]);\n       });\n\n    it(`${buffersType}: slices from zero when start is negative`, () => {\n      expectArraysEqual(new Uint8Array(composite.slice(-4, 5)),\n                        [0,1,2,3,4]);\n    });\n\n    it(`${buffersType}: slices to the end when end is greater than length`,\n       () => {\n         expectArraysEqual(new Uint8Array(composite.slice(7, 1000)),\n                           [7,8,9,10,11,12,13,14,15,16]);\n       });\n\n    it(`${buffersType}: slices multiple ranges out of order`, () => {\n      expectArraysEqual(new Uint8Array(composite.slice(13, 15)), [13, 14]);\n      expectArraysEqual(new Uint8Array(composite.slice(0, 2)), [0, 1]);\n      expectArraysEqual(new Uint8Array(composite.slice(9, 13)),\n                        [9, 10, 11, 12]);\n    });\n  }\n\n  it('can be created from an empty arraybuffer', () => {\n    const array = new Uint8Array([]);\n    const singleComposite = new CompositeArrayBuffer(array.buffer);\n    expectArraysEqual(new Uint8Array(singleComposite.slice()), []);\n  });\n\n  it('can be created from a single array', () => {\n    const array = new Uint8Array([1,2,3]);\n    const singleComposite = new CompositeArrayBuffer(array.buffer);\n    expectArraysEqual(new Uint8Array(singleComposite.slice()), array);\n  });\n\n  it('can be created from zero arrays', () => {\n    const singleComposite = new CompositeArrayBuffer([]);\n    expectArraysEqual(new Uint8Array(singleComposite.slice()),\n                      new Uint8Array());\n  });\n\n  it('can be created from undefined input', () => {\n    const singleComposite = new CompositeArrayBuffer();\n    expectArraysEqual(new Uint8Array(singleComposite.slice()),\n                      new Uint8Array());\n  });\n\n  it('treats NaN as zero when passed as the start of slice', () => {\n    const array = new Uint8Array([1,2,3]);\n    const composite = new CompositeArrayBuffer(array.buffer);\n    expectArraysEqual(new Uint8Array(composite.slice(NaN, 2)), [1,2]);\n  });\n\n  it('treats NaN as zero when passed as the end of slice', () => {\n    const array = new Uint8Array([1,2,3]);\n    const composite = new CompositeArrayBuffer(array.buffer);\n    expectArraysEqual(new Uint8Array(composite.slice(0, NaN)), []);\n  });\n\n  it('supports TypedArray input', () => {\n    // This support is necessary for some tests in tfjs-converter. Maybe those\n    // tests are misconfigured?\n    const array = new Uint8Array([1,2,3]);\n    const composite = new CompositeArrayBuffer(array);\n    expectArraysEqual(new Uint8Array(composite.slice(0, 2)), [1,2]);\n  });\n});\n"]}
|