onnxruntime/js/node/test/unittests/lib/tensor.ts
Yulong Wang 009f342caf
[JS] refactor Javascript/Typescript libraries in ONNX Runtime (#7308)
* working on re-organizing js code for ortweb

* remove dup files

* move folder

* fix common references

* fix common es5

* add webpack to common

* split interfact/impl

* use cjs for node

* add npmignore for common

* update sourcemap config for common

* update node

* adjust folder/path in CI and build

* update folder

* nit: readme

* add bundle for dev

* correct nodejs paths

* enable ORT_API_MANUAL_INIT

* set name for umd library

* correct name for commonjs export

* add priority into registerBackend()

* fix npm ci pwd

* update eslintrc

* revise code

* revert package-lock lockfileVersion 2->1

* update prebuild

* resolve comments

* update document

* revise eslint config

* update eslint for typescript rules

* revert changes by mistake in backend.ts

* add env

* resolve comments
2021-04-16 01:33:10 -07:00

101 lines
4.4 KiB
TypeScript

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
import * as assert from 'assert';
// tensor with type information
import {Tensor} from 'onnxruntime-common';
import {createTestData, NUMERIC_TYPE_MAP} from '../../test-utils';
// tensor with no type information, used for testing type check
const TensorAny = Tensor as any;
function testAllTensortypes(
title: string, length: number,
funcNumerictypes: (passtypeParam: boolean, type: Tensor.Type, data: Tensor.DataType) => void,
funcStringtype?: (passtypeParam: boolean, data: string[]) => void): void {
NUMERIC_TYPE_MAP.forEach((ctor, type) => {
it(`${title} - (${type}, ${ctor.name})`, () => {
funcNumerictypes(true, type, createTestData(type, length));
});
if (type !== 'bool') {
it(`${title} - (${ctor.name})`, () => {
funcNumerictypes(false, type, createTestData(type, length));
});
}
});
if (!funcStringtype) {
it(`${title} - (string, ${Array.name})`, () => {
funcNumerictypes(true, 'string', createTestData('string', length));
});
it(`${title} - (${Array.name})`, () => {
funcNumerictypes(false, 'string', createTestData('string', length));
});
} else {
it(`${title} - (string, string[])`, () => {
funcStringtype(true, createTestData('string', length) as string[]);
});
it(`${title} - (string[])`, () => {
funcStringtype(false, createTestData('string', length) as string[]);
});
}
}
describe('UnitTests - tensor', () => {
testAllTensortypes('check data and type', 100, (passtypeParam, type, data) => { // numeric and string tensors
const tensor0 = passtypeParam ? new Tensor(type, data) : new Tensor(data);
assert.strictEqual(tensor0.data, data, 'tensor.data and data should be the same object.');
assert.strictEqual(tensor0.type, type, 'tensor.type and type should be equal.');
});
testAllTensortypes('check dims (omitted)', 200, (passtypeParam, type, data) => { // numeric and string tensors
const tensor0 = passtypeParam ? new Tensor(type, data) : new Tensor(data);
assert.deepStrictEqual(
tensor0.dims, [200],
'tensor.dims should be a number array with exactly 1 item, with value of the array length.');
});
testAllTensortypes('check dims (specified)', 60, (passtypeParam, type, data) => { // numeric and string tensors
const tensor0 = passtypeParam ? new Tensor(type, data, [3, 4, 5]) : new Tensor(data, [3, 4, 5]);
assert.deepStrictEqual(tensor0.dims, [3, 4, 5], 'tensor.dims should be a number array with the given 3 items.');
});
testAllTensortypes(
'BAD CALL - invalid dims type', 100, (passtypeParam, type, data) => { // numeric and string tensors
assert.throws(() => {
const badDims = {};
passtypeParam ? new TensorAny(type, data, badDims) : new TensorAny(data, badDims);
}, {name: 'TypeError', message: /must be a number array/});
});
testAllTensortypes(
'BAD CALL - invalid dims element type', 100, (passtypeParam, type, data) => { // numeric and string tensors
assert.throws(() => {
const badDims = [1, 2, ''];
passtypeParam ? new TensorAny(type, data, badDims) : new TensorAny(data, badDims);
}, {name: 'TypeError', message: /must be an integer/});
});
testAllTensortypes(
'BAD CALL - invalid dims number type (negative)', 100,
(passtypeParam, type, data) => { // numeric and string tensors
assert.throws(() => {
const badDims = [1, 2, -1];
passtypeParam ? new TensorAny(type, data, badDims) : new TensorAny(data, badDims);
}, {name: 'RangeError', message: /must be a non-negative integer/});
});
testAllTensortypes(
'BAD CALL - invalid dims number type (non-integer)', 100,
(passtypeParam, type, data) => { // numeric and string tensors
assert.throws(() => {
const badDims = [1, 2, 1.5];
passtypeParam ? new TensorAny(type, data, badDims) : new TensorAny(data, badDims);
}, {name: 'TypeError', message: /must be an integer/});
});
testAllTensortypes(
'BAD CALL - length and dims does not match', 100, (passtypeParam, type, data) => { // numeric and string tensors
assert.throws(() => {
const badDims = [10, 8];
passtypeParam ? new TensorAny(type, data, badDims) : new TensorAny(data, badDims);
}, {name: 'Error', message: /does not match data length/});
});
});