gx
chenyc
2025-06-12 7b72ac13a83764a662159d4a49b7fffb90476ecb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/**
 * @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"]}