19f392e33a657e73ed77d6e9111965cc5bdc9f4a4da1bda847276c8a07af55bc810bf95e1fee5764dd4f42446328ddc03969e0fcd02f8a327c68452185c0d4 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. 'use strict';
  2. var test = require('tape');
  3. var typedArrayByteOffset = require('../');
  4. var isCallable = require('is-callable');
  5. var generators = require('make-generator-function')();
  6. var arrowFn = require('make-arrow-function')();
  7. var forEach = require('for-each');
  8. var inspect = require('object-inspect');
  9. var typedArrayNames = require('possible-typed-array-names');
  10. test('not arrays', function (t) {
  11. t.test('non-number/string primitives', function (st) {
  12. // @ts-expect-error
  13. st.equal(false, typedArrayByteOffset(), 'undefined is not typed array');
  14. st.equal(false, typedArrayByteOffset(null), 'null is not typed array');
  15. st.equal(false, typedArrayByteOffset(false), 'false is not typed array');
  16. st.equal(false, typedArrayByteOffset(true), 'true is not typed array');
  17. st.end();
  18. });
  19. t.equal(false, typedArrayByteOffset({}), 'object is not typed array');
  20. t.equal(false, typedArrayByteOffset(/a/g), 'regex literal is not typed array');
  21. t.equal(false, typedArrayByteOffset(new RegExp('a', 'g')), 'regex object is not typed array');
  22. t.equal(false, typedArrayByteOffset(new Date()), 'new Date() is not typed array');
  23. t.test('numbers', function (st) {
  24. st.equal(false, typedArrayByteOffset(42), 'number is not typed array');
  25. st.equal(false, typedArrayByteOffset(Object(42)), 'number object is not typed array');
  26. st.equal(false, typedArrayByteOffset(NaN), 'NaN is not typed array');
  27. st.equal(false, typedArrayByteOffset(Infinity), 'Infinity is not typed array');
  28. st.end();
  29. });
  30. t.test('strings', function (st) {
  31. st.equal(false, typedArrayByteOffset('foo'), 'string primitive is not typed array');
  32. st.equal(false, typedArrayByteOffset(Object('foo')), 'string object is not typed array');
  33. st.end();
  34. });
  35. t.end();
  36. });
  37. test('Functions', function (t) {
  38. t.equal(false, typedArrayByteOffset(function () {}), 'function is not typed array');
  39. t.end();
  40. });
  41. test('Generators', { skip: generators.length === 0 }, function (t) {
  42. forEach(generators, function (genFn) {
  43. t.equal(false, typedArrayByteOffset(genFn), 'generator function ' + inspect(genFn) + ' is not typed array');
  44. });
  45. t.end();
  46. });
  47. test('Arrow functions', { skip: !arrowFn }, function (t) {
  48. t.equal(false, typedArrayByteOffset(arrowFn), 'arrow function is not typed array');
  49. t.end();
  50. });
  51. test('Typed Arrays', function (t) {
  52. var length = 32;
  53. var byteOffset = 16;
  54. forEach(typedArrayNames, function (typedArray) {
  55. var buffer = new ArrayBuffer(length);
  56. var TypedArray = global[typedArray];
  57. if (isCallable(TypedArray)) {
  58. // @ts-expect-error hush, TS, TAs can take an optional byte offset arg
  59. var arr = new TypedArray(buffer, byteOffset);
  60. t.equal(typedArrayByteOffset(arr), byteOffset, 'new ' + typedArray + '(new ArrayBuffer(' + length + '), ' + byteOffset + ') is typed array of byte offset ' + byteOffset);
  61. } else {
  62. t.comment('# SKIP ' + typedArray + ' is not supported');
  63. }
  64. });
  65. t.end();
  66. });