|
1 | 1 | /** |
2 | 2 | * @license Apache-2.0 |
3 | 3 | * |
4 | | -* Copyright (c) 2018 The Stdlib Authors. |
| 4 | +* Copyright (c) 2023 The Stdlib Authors. |
5 | 5 | * |
6 | 6 | * Licensed under the Apache License, Version 2.0 (the "License"); |
7 | 7 | * you may not use this file except in compliance with the License. |
|
20 | 20 |
|
21 | 21 | // MODULES // |
22 | 22 |
|
23 | | -var vm = require( 'vm' ); // TODO: handle in-browser tests |
24 | 23 | var tape = require( 'tape' ); |
25 | | -var IS_BROWSER = require( '@stdlib/assert-is-browser' ); |
26 | | -var inherit = require( '@stdlib/utils-inherit' ); |
27 | | -var isSyntaxError = require( './../../dist' ); |
28 | | - |
29 | | - |
30 | | -// VARIABLES // |
31 | | - |
32 | | -var opts = { |
33 | | - 'skip': IS_BROWSER |
34 | | -}; |
| 24 | +var main = require( './../../dist' ); |
35 | 25 |
|
36 | 26 |
|
37 | 27 | // TESTS // |
38 | 28 |
|
39 | | -tape( 'main export is a function', function test( t ) { |
| 29 | +tape( 'main export is defined', function test( t ) { |
40 | 30 | t.ok( true, __filename ); |
41 | | - t.strictEqual( typeof isSyntaxError, 'function', 'main export is a function' ); |
42 | | - t.end(); |
43 | | -}); |
44 | | - |
45 | | -tape( 'the function returns `true` if provided a `SyntaxError` object', function test( t ) { |
46 | | - var values; |
47 | | - var i; |
48 | | - |
49 | | - values = [ |
50 | | - new SyntaxError( 'syntax error' ) |
51 | | - ]; |
52 | | - |
53 | | - for ( i = 0; i < values.length; i++ ) { |
54 | | - t.strictEqual( isSyntaxError( values[ i ] ), true, 'returns true when provided '+values[i] ); |
55 | | - } |
56 | | - t.end(); |
57 | | -}); |
58 | | - |
59 | | -tape( 'the function returns `true` if provided an object inheriting from `SyntaxError`', function test( t ) { |
60 | | - function CustomError( msg ) { |
61 | | - SyntaxError.call( this ); |
62 | | - this.name = 'CustomError'; |
63 | | - this.message = msg; |
64 | | - return this; |
65 | | - } |
66 | | - |
67 | | - inherit( CustomError, SyntaxError ); |
68 | | - |
69 | | - t.strictEqual( isSyntaxError( new CustomError( 'custom error' ) ), true, 'returns true when provided a value which inherits from SyntaxError' ); |
70 | | - t.end(); |
71 | | -}); |
72 | | - |
73 | | -tape( 'the function returns `true` if provided a `SyntaxError` object from a different realm', opts, function test( t ) { |
74 | | - var error = vm.runInNewContext( 'new SyntaxError()' ); |
75 | | - t.strictEqual( isSyntaxError( error ), true, 'returns true' ); |
76 | | - t.end(); |
77 | | -}); |
78 | | - |
79 | | -tape( 'the function returns `true` if provided an object from a different realm which inherits from a `SyntaxError` object', opts, function test( t ) { |
80 | | - var error = vm.runInNewContext( 'function Err() { return this; }; Err.prototype = new SyntaxError(); new Err();' ); |
81 | | - t.strictEqual( isSyntaxError( error ), true, 'returns true' ); |
82 | | - t.end(); |
83 | | -}); |
84 | | - |
85 | | -tape( 'the function returns `false` if not provided a `SyntaxError` object', function test( t ) { |
86 | | - var values; |
87 | | - var i; |
88 | | - |
89 | | - values = [ |
90 | | - '5', |
91 | | - 5, |
92 | | - NaN, |
93 | | - true, |
94 | | - false, |
95 | | - null, |
96 | | - void 0, |
97 | | - [], |
98 | | - {}, |
99 | | - function noop() {}, |
100 | | - function error() {}, |
101 | | - new Date(), |
102 | | - new RegExp( '.*' ), // eslint-disable-line prefer-regex-literals |
103 | | - new Error( 'error' ), |
104 | | - new EvalError( 'eval error' ), |
105 | | - new ReferenceError( 'reference error' ), |
106 | | - new RangeError( 'range error' ), |
107 | | - new TypeError( 'type error' ), |
108 | | - new URIError( 'URI error' ) |
109 | | - ]; |
110 | | - |
111 | | - for ( i = 0; i < values.length; i++ ) { |
112 | | - t.strictEqual( isSyntaxError( values[ i ] ), false, 'returns false when provided '+values[i] ); |
113 | | - } |
| 31 | + t.strictEqual( main !== void 0, true, 'main export is defined' ); |
114 | 32 | t.end(); |
115 | 33 | }); |
0 commit comments