test262/test/built-ins/Simd/swizzle.js

49 lines
1.5 KiB
JavaScript
Raw Normal View History

// Copyright (C) 2016 ecmascript_simd authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: swizzle
description: Tests Simd swizzle.
includes: [simdUtilities.js]
---*/
function testSwizzle(type) {
assert.sameValue('function', typeof type.fn.swizzle);
var a = createTestValue(type); // 0, 1, 2, 3, 4, 5, 6, ...
var indices = [];
// Identity swizzle.
for (var i = 0; i < type.lanes; i++) indices.push(i);
var result = type.fn.swizzle.apply(type.fn, [a].concat(indices));
checkValue(type, result, function(index) {
return type.fn.extractLane(a, index);
});
// Reverse swizzle.
indices.reverse();
var result = type.fn.swizzle.apply(type.fn, [a].concat(indices));
checkValue(type, result, function(index) {
return type.fn.extractLane(a, type.lanes - index - 1);
});
function testIndexCheck(index, err) {
for (var i = 0; i < type.lanes; i++) {
var args = [a].concat(indices);
args[i + 1] = index;
assert.throws(err, function() { type.fn.swizzle.apply(type.fn, args); });
}
}
// RangeError
testIndexCheck(type.lanes, RangeError);
testIndexCheck(-1, RangeError);
testIndexCheck(128, RangeError);
testIndexCheck(13.37, TypeError);
testIndexCheck(undefined, TypeError);
testIndexCheck({}, TypeError);
testIndexCheck('yo', TypeError);
}
simdTypes.filter(isNumerical).forEach(function(type) {
testSimdFunction(type.name + ' swizzle', function() {
testSwizzle(type);
});
});