Skip to content

Commit

Permalink
Accept async iterable as input (#8)
Browse files Browse the repository at this point in the history
  • Loading branch information
noamokman authored Dec 27, 2023
1 parent def9865 commit 2723855
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 17 deletions.
4 changes: 3 additions & 1 deletion index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,9 @@ for await (const element of pFilterIterable(places, filterer)) {
```
*/
export function pFilterIterable<ValueType>(
input: Iterable<ValueType | PromiseLike<ValueType>>,
input:
| AsyncIterable<ValueType | PromiseLike<ValueType>>
| Iterable<ValueType | PromiseLike<ValueType>>,
filterer: (
element: ValueType,
index: number
Expand Down
12 changes: 12 additions & 0 deletions index.test-d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,18 @@ expectType<AsyncIterable<string>>(
),
);

async function * getPlaces(): AsyncIterable<string> {
yield 'Bangkok, Thailand';
yield 'Berlin, Germany';
yield 'Tokyo, Japan';
}

expectType<AsyncIterable<string>>(
pFilterIterable(getPlaces(), async place =>
place === 'Bangkok, Thailand' ? true : Promise.resolve(false),
),
);

expectType<AsyncIterable<number>>(
pFilterIterable(new Set([1, 2]), number => number > 1, {concurrency: 1}),
);
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -41,11 +41,11 @@
"parallel"
],
"dependencies": {
"p-map": "^7.0.0"
"p-map": "^7.0.1"
},
"devDependencies": {
"ava": "^6.0.1",
"tsd": "^0.30.0",
"tsd": "^0.30.1",
"xo": "^0.56.0"
}
}
45 changes: 31 additions & 14 deletions test.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,15 @@ test('handles empty iterable', async t => {
});

test('pFilterIterable', async t => {
const iterableToArray = async iterable => {
const array = [];
for await (const item of iterable) {
array.push(item);
}

return array;
};

const rangeIterable = {
async * [Symbol.asyncIterator]() {
yield 1;
Expand All @@ -26,21 +35,29 @@ test('pFilterIterable', async t => {
yield 4;
},
};
const iterable = pFilterIterable(rangeIterable, x => x % 2);
const results = [];
for await (const x of iterable) {
results.push(x);
}

t.deepEqual(results, [1, 3]);
t.deepEqual(
await iterableToArray(pFilterIterable(rangeIterable, x => x % 2)),
[1, 3],
);

const iterable2 = pFilterIterable(rangeIterable, x =>
Promise.resolve(x % 2),
t.deepEqual(
await iterableToArray(
pFilterIterable(rangeIterable, x => Promise.resolve(x % 2)),
),
[1, 3],
);
const results2 = [];
for await (const x of iterable2) {
results2.push(x);
}

t.deepEqual(results2, [1, 3]);
t.deepEqual(
await iterableToArray(
pFilterIterable([Promise.resolve(1), 2, 3, 4], x => x % 2),
),
[1, 3],
);
t.deepEqual(
await iterableToArray(
pFilterIterable([1, 2, 3, 4], x => Promise.resolve(x % 2)),
),
[1, 3],
);
t.deepEqual(await iterableToArray(pFilterIterable([])), []);
});

0 comments on commit 2723855

Please sign in to comment.