diff --git a/.github/.keepalive b/.github/.keepalive new file mode 100644 index 0000000..ea4bc73 --- /dev/null +++ b/.github/.keepalive @@ -0,0 +1 @@ +2023-11-01T03:05:30.202Z diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index b17435b..0037bdb 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -182,7 +182,11 @@ jobs: fi # Trim leading and trailing whitespace: dep=$(echo "$dep" | xargs) - version="^$(npm view $dep version)" + version="$(npm view $dep version)" + if [[ -z "$version" ]]; then + continue + fi + version="^$version" jq -r --arg dep "$dep" --arg version "$version" '.dependencies[$dep] = $version' package.json > package.json.tmp mv package.json.tmp package.json done @@ -192,7 +196,11 @@ jobs: fi # Trim leading and trailing whitespace: dep=$(echo "$dep" | xargs) - version="^$(npm view $dep version)" + version="$(npm view $dep version)" + if [[ -z "$version" ]]; then + continue + fi + version="^$version" jq -r --arg dep "$dep" --arg version "$version" '.devDependencies[$dep] = $version' package.json > package.json.tmp mv package.json.tmp package.json done diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 93c4bde..0dae4fe 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -37,3 +37,4 @@ Stephannie Jiménez Gacha Yernar Yergaziyev orimiles5 <97595296+orimiles5@users.noreply.github.com> rei2hu +Robert Gislason diff --git a/test/dist/test.js b/test/dist/test.js index 36baf8e..a8a9c60 100644 --- a/test/dist/test.js +++ b/test/dist/test.js @@ -1,7 +1,7 @@ /** * @license Apache-2.0 * -* Copyright (c) 2018 The Stdlib Authors. +* Copyright (c) 2023 The Stdlib Authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -21,258 +21,13 @@ // MODULES // var tape = require( 'tape' ); -var indexOf = require( '@stdlib/utils-index-of' ); -var defineProperty = require( '@stdlib/utils-define-property' ); -var inherit = require( '@stdlib/utils-inherit' ); -var inheritedWritablePropertyNames = require( './../../dist' ); // eslint-disable-line id-length +var main = require( './../../dist' ); // TESTS // -tape( 'main export is a function', function test( t ) { +tape( 'main export is defined', function test( t ) { t.ok( true, __filename ); - t.strictEqual( typeof inheritedWritablePropertyNames, 'function', 'main export is a function' ); - t.end(); -}); - -tape( 'the function throws an error if not provided a positive integer for the inheritance level', function test( t ) { - var values; - var i; - - values = [ - '5', - -5, - 0, - 3.14, - NaN, - true, - false, - null, - void 0, - [], - {}, - function noop() {} - ]; - for ( i = 0; i < values.length; i++ ) { - t.throws( badValue( values[i] ), TypeError, 'throws an error when provided '+values[i] ); - } - t.end(); - - function badValue( value ) { - return function badValue() { - inheritedWritablePropertyNames( {}, value ); - }; - } -}); - -tape( 'the function returns an array of an object\'s inherited writable property names', function test( t ) { - var expected; - var actual; - var obj; - var idx; - var i; - - function Foo() { - this.a = 'a'; - this.b = 'b'; - defineProperty( this, 'c', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'c' - }); - defineProperty( this, 'f', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'f' - }); - return this; - } - - Foo.prototype.d = 'd'; - defineProperty( Foo.prototype, 'e', { - 'configurable': false, - 'enumerable': false, - 'writable': false, - 'value': 'e' - }); - Foo.prototype.f = 'f'; - - obj = new Foo(); - - expected = [ 'd', 'f' ]; - actual = inheritedWritablePropertyNames( obj ); - - t.strictEqual( actual.length >= expected.length, true, 'has expected length' ); - for ( i = 0; i < expected.length; i++ ) { - idx = indexOf( actual, expected[ i ] ); - t.strictEqual( idx !== -1, true, 'contains property name: '+expected[i] ); - } - t.end(); -}); - -tape( 'the function returns an array of an object\'s inherited writable property names (multiple inheritance)', function test( t ) { - var expected; - var actual; - var obj; - var idx; - var i; - - function Bar() { - this.a = 'a'; - defineProperty( this, 'd', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'd' - }); - return this; - } - - Bar.prototype.b = 'b'; - Bar.prototype.c = 'c'; - defineProperty( Bar.prototype, 'd', { - 'configurable': false, - 'enumerable': false, - 'writable': false, - 'value': 'd' - }); - defineProperty( Bar.prototype, 'f', { - 'configurable': true, - 'enumerable': false, - 'writable': true, - 'value': 'f' - }); - - function Foo() { - Bar.call( this ); - this.a = 'a'; - this.b = 'b'; - defineProperty( this, 'd', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'd' - }); - return this; - } - - inherit( Foo, Bar ); - - Foo.prototype.b = 'b'; - defineProperty( Foo.prototype, 'e', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'e' - }); - defineProperty( Foo.prototype, 'f', { - 'configurable': true, - 'enumerable': true, - 'writable': false, - 'value': 'f' - }); - - obj = new Foo(); - - expected = [ 'b', 'e', 'c' ]; - actual = inheritedWritablePropertyNames( obj ); - - t.strictEqual( actual.length >= expected.length, true, 'has expected length' ); - for ( i = 0; i < expected.length; i++ ) { - idx = indexOf( actual, expected[ i ] ); - t.strictEqual( idx !== -1, true, 'contains property name: '+expected[i] ); - } - idx = indexOf( actual, 'f' ); - t.strictEqual( idx, -1, 'does not contain property' ); - t.end(); -}); - -tape( 'the function supports limiting the inheritance level', function test( t ) { - var expected; - var actual; - var obj; - var idx; - var i; - - function Bar() { - this.boop = 'beep'; - this.a = { - 'b': 'c' - }; - defineProperty( this, 'd', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'e' - }); - return this; - } - - Bar.prototype.bar = [ 'foo' ]; - defineProperty( Bar.prototype, 'bap', { - 'configurable': false, - 'enumerable': false, - 'writable': false, - 'value': 'baz' - }); - - function Foo() { - Bar.call( this ); - this.beep = 'boop'; - this.a = { - 'b': 'c' - }; - defineProperty( this, 'd', { - 'configurable': false, - 'enumerable': false, - 'writable': true, - 'value': 'e' - }); - return this; - } - - inherit( Foo, Bar ); - - Foo.prototype.foo = [ 'bar' ]; - defineProperty( Foo.prototype, 'baz', { - 'configurable': false, - 'enumerable': false, - 'writable': false, - 'value': 'bap' - }); - - obj = new Foo(); - - expected = [ 'foo' ]; - actual = inheritedWritablePropertyNames( obj, 1 ); - - t.strictEqual( actual.length >= expected.length, true, 'has expected length' ); - for ( i = 0; i < expected.length; i++ ) { - idx = indexOf( actual, expected[ i ] ); - t.strictEqual( idx !== -1, true, 'contains property name: '+expected[i] ); - } - idx = indexOf( actual, 'bar' ); - t.strictEqual( idx === -1, true, 'does not contain property' ); - t.end(); -}); - -tape( 'the function returns an empty array if provided `null` or `undefined`', function test( t ) { - var expected; - var actual; - var values; - var i; - - values = [ - void 0, - null - ]; - expected = []; - - for ( i = 0; i < values.length; i++ ) { - actual = inheritedWritablePropertyNames( values[ i ] ); - t.deepEqual( actual, expected, 'returns expected value when provided '+values[ i ] ); - } + t.strictEqual( main !== void 0, true, 'main export is defined' ); t.end(); });