UNPKG

prray

Version:

'Promisified' Array, comes with async method supports(such as mapAsync). And it is compatible with normal array.

76 lines (75 loc) 3.34 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const ava_1 = require("ava"); const sinon = require("sinon"); const prray_1 = require("../src/prray"); const prraypromise_1 = require("../src/prraypromise"); const test_utils_1 = require("./test-utils"); ava_1.default('prray map', (t) => __awaiter(this, void 0, void 0, function* () { const p = prray_1.prray([1, 2, 3]); const result = p.map(test_utils_1.addOne); t.true(result instanceof prray_1.Prray); t.deepEqual(result, prray_1.prray([2, 3, 4])); })); ava_1.default('prray map with async callback', (t) => __awaiter(this, void 0, void 0, function* () { const p = prray_1.prray([1, 2, 3]); const result = p.map(test_utils_1.addOneAsync); t.true(result instanceof prray_1.Prray); t.true(result[0] instanceof Promise); t.deepEqual(yield Promise.all(result), [2, 3, 4]); })); ava_1.default('prraypromise map', (t) => __awaiter(this, void 0, void 0, function* () { const pp = test_utils_1.toPrrayPromise([1, 2, 3]); const result = pp.map(test_utils_1.addOne); t.true(result instanceof prraypromise_1.PrrayPromise); t.deepEqual(yield result, prray_1.prray([2, 3, 4])); })); ava_1.default('prraypromise map with async callback', (t) => __awaiter(this, void 0, void 0, function* () { const p = test_utils_1.toPrrayPromise([1, 2, 3]); const result = p.map(test_utils_1.addOneAsync); t.true(result instanceof prraypromise_1.PrrayPromise); const resolved = yield result; t.true(resolved[0] instanceof Promise); t.deepEqual(yield Promise.all(resolved), [2, 3, 4]); })); ava_1.default('prray map detail', (t) => __awaiter(this, void 0, void 0, function* () { const prr = prray_1.prray(['a', 'b', 'c']); const func = sinon.fake(); prr.map(func); t.is(func.called, true); t.is(func.callCount, 3); t.is(func.args[0][0], 'a'); t.is(func.args[0][1], 0); t.is(func.args[0][2], prr); t.is(func.args[1][0], 'b'); t.is(func.args[1][1], 1); t.is(func.args[1][2], prr); t.is(func.args[2][0], 'c'); t.is(func.args[2][1], 2); t.is(func.args[2][2], prr); })); ava_1.default('prraypromise map detail', (t) => __awaiter(this, void 0, void 0, function* () { const prr = prray_1.prray(['a', 'b', 'c']); const prom = test_utils_1.toPrrayPromise(prr); const func = sinon.fake(); yield prom.map(func); t.is(func.called, true); t.is(func.callCount, 3); t.is(func.args[0][0], 'a'); t.is(func.args[0][1], 0); t.is(func.args[0][2], prr); t.is(func.args[1][0], 'b'); t.is(func.args[1][1], 1); t.is(func.args[1][2], prr); t.is(func.args[2][0], 'c'); t.is(func.args[2][1], 2); t.is(func.args[2][2], prr); }));