The package rpms/nodejs-p-locate.git has added or updated architecture specific content in
its
spec file (ExclusiveArch/ExcludeArch or %ifarch/%ifnarch) in commit(s):
https://src.fedoraproject.org/cgit/rpms/nodejs-p-locate.git/commit/?id=53....
Change:
+ExclusiveArch: %{nodejs_arches} noarch
Thanks.
Full change:
============
commit 535f1761bdb010bb51e88bce884fc21df7154fe2
Author: Jared K. Smith <jaredsmith(a)jaredsmith.net>
Date: Wed May 3 14:14:54 2017 -0400
Initial packaging
diff --git a/.gitignore b/.gitignore
index e69de29..1acb980 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1 @@
+/p-locate-2.0.0.tgz
diff --git a/nodejs-p-locate.spec b/nodejs-p-locate.spec
new file mode 100644
index 0000000..319f645
--- /dev/null
+++ b/nodejs-p-locate.spec
@@ -0,0 +1,63 @@
+%{?nodejs_find_provides_and_requires}
+
+%global packagename p-locate
+
+# tests missing due to missing npm(ava)
+%global enable_tests 0
+
+Name: nodejs-p-locate
+Version: 2.0.0
+Release: 1%{?dist}
+Summary: Get the first fulfilled promise that satisfies the provided testing function
+
+License: MIT
+URL:
https://github.com/sindresorhus/p-locate
+Source0:
https://registry.npmjs.org/%{packagename}/-/%{packagename}-%{version}.tgz
+# The test files are not included in the npm tarball.
+Source1:
https://raw.githubusercontent.com/sindresorhus/p-locate/v%{version}/test.js
+
+ExclusiveArch: %{nodejs_arches} noarch
+BuildArch: noarch
+
+BuildRequires: nodejs-packaging
+BuildRequires: npm(p-limit)
+%if 0%{?enable_tests}
+BuildRequires: ava
+%endif
+
+%description
+Get the first fulfilled promise that satisfies the provided testing function
+
+
+%prep
+%autosetup -n package
+# setup the tests
+cp -p %{SOURCE1} .
+
+%build
+# nothing to do!
+
+%install
+mkdir -p %{buildroot}%{nodejs_sitelib}/%{packagename}
+cp -pr package.json index.js \
+ %{buildroot}%{nodejs_sitelib}/%{packagename}
+
+%nodejs_symlink_deps
+
+%check
+%nodejs_symlink_deps --check
+%{__nodejs} -e 'require("./")'
+%if 0%{?enable_tests}
+%{_bindir}/ava
+%else
+%{_bindir}/echo -e "\e[101m -=#=- Tests disabled -=#=- \e[0m"
+%endif
+
+%files
+%doc readme.md
+%license license
+%{nodejs_sitelib}/%{packagename}
+
+%changelog
+* Thu Apr 20 2017 Jared Smith <jsmith(a)fedoraproject.org> - 2.0.0-1
+- Initial packaging
diff --git a/sources b/sources
index e69de29..6689f90 100644
--- a/sources
+++ b/sources
@@ -0,0 +1 @@
+SHA512 (p-locate-2.0.0.tgz) =
9d08daee6ee048ab9ec285517a7e390ad55f38347772b377828550d030d9f4ddf21f182992e06166ab1a8a8b52411ac00d4ae77b7e3aa5e63b913dd34800b292
diff --git a/test.js b/test.js
new file mode 100644
index 0000000..5501549
--- /dev/null
+++ b/test.js
@@ -0,0 +1,41 @@
+import {serial as test} from 'ava';
+import delay from 'delay';
+import inRange from 'in-range';
+import timeSpan from 'time-span';
+import m from './';
+
+const input = [
+ [1, 300],
+ [2, 400],
+ [3, 200],
+ Promise.resolve([4, 100]) // ensures promises work in the input
+];
+
+const tester = ([val, ms]) => delay(ms).then(() => val === 2 || val === 3);
+
+test('main', async t => {
+ const end = timeSpan();
+ t.is((await m(input, tester))[0], 2);
+ t.true(inRange(end(), 370, 450), 'should be time of item `2`');
+});
+
+test('option {preserveOrder:false}', async t => {
+ const end = timeSpan();
+ t.is((await m(input, tester, {preserveOrder: false}))[0], 3);
+ t.true(inRange(end(), 170, 250), 'should be time of item `3`');
+});
+
+test('option {concurrency:1}', async t => {
+ const end = timeSpan();
+ t.is((await m(input, tester, {concurrency: 1}))[0], 2);
+ t.true(inRange(end(), 670, 750), 'should be time of items `1` and `2`, since they
run serially');
+});
+
+test('returns `undefined` when nothing could be found', async t => {
+ t.is((await m([1, 2, 3], () => false)), undefined);
+});
+
+test('rejected return value in `tester` rejects the promise', async t => {
+ const fixtureErr = new Error('fixture');
+ await t.throws(m([1, 2, 3], () => Promise.reject(fixtureErr)), fixtureErr.message);
+});