Skip to content

Commit

Permalink
Add promise package with defer (#18)
Browse files Browse the repository at this point in the history
  • Loading branch information
kanziw authored Oct 1, 2022
1 parent f156bbf commit 57626f4
Show file tree
Hide file tree
Showing 12 changed files with 200 additions and 2 deletions.
19 changes: 19 additions & 0 deletions .pnp.cjs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion packages/date/README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# @kanziwdate/
# @kanziw/date

[![npm version](https://img.shields.io/npm/v/@kanziw/date)](https://www.npmjs.com/package/@kanziw/date)
[![license](https://img.shields.io/npm/l/@kanziw/date)](https://www.npmjs.com/package/@kanziw/date)
Expand Down
2 changes: 1 addition & 1 deletion packages/date/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@kanziw/date",
"version": "0.1.0",
"version": "0.1.1",
"description": "A collection of utility libraries about date",
"repository": {
"type": "git",
Expand Down
File renamed without changes.
3 changes: 3 additions & 0 deletions packages/promise/.npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
src/
**/__tests__/
tsconfig.json
51 changes: 51 additions & 0 deletions packages/promise/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
# @kanziw/promise

[![npm version](https://img.shields.io/npm/v/@kanziw/promise)](https://www.npmjs.com/package/@kanziw/promise)
[![license](https://img.shields.io/npm/l/@kanziw/promise)](https://www.npmjs.com/package/@kanziw/promise)
[![npm downloads](https://img.shields.io/npm/dt/@kanziw/promise)](https://www.npmjs.com/package/@kanziw/promise)


## defer

Handle promise resolve/reject manually.

```ts
import { defer } from '@kanziw/promise'

async function rollbackableInsert() {
const commitOrRollback = defer<void>()
const insertedId = defer<string>()

const txPromise = db.withTransaction(async conn => {
const { insertId } = await conn.execute(qb.insertInto('table').values({}))
.then(insertedId.resolve)
.catch(err => {
insertedId.reject(err)
throw err
});

await commitOrRollback.promise
})

const commit = async () => {
commitOrRollback.resolve()
return txPromise
};

return {
insertId: await insertedId.promise,
commit,
rollback: deferWaitTransaction.reject,
}
}

const { insertId, commit, rollback } = await rollbackableInsert()

try {
// some business logic
await commit()
} catch (err) {
await rollback()
throw err
}
```
41 changes: 41 additions & 0 deletions packages/promise/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
{
"name": "@kanziw/promise",
"version": "0.1.0",
"description": "A collection of utility libraries about promise",
"repository": {
"type": "git",
"url": "git+https://github.com/kanziw/kanziwjs.git",
"directory": "packages/promise"
},
"publishConfig": {
"access": "public"
},
"homepage": "https://github.com/kanziw/kanziwjs/tree/main/packages/promise#readme",
"keywords": [
"promise",
"kanziw",
"defer"
],
"author": {
"name": "Jiwoong Jung",
"email": "kanziwoong@gmail.com"
},
"main": "./lib/index.js",
"types": "./lib/index.d.ts",
"packageManager": "yarn@3.2.0",
"scripts": {
"lint": "yarn workspace kanziwjs eslint packages/promise",
"test": "yarn workspace kanziwjs test packages/promise",
"clean": "rimraf lib",
"build": "yarn clean && yarn tsc",
"publish": "yarn build && yarn publish-if-not-published"
},
"devDependencies": {
"@types/jest": "^27.5.0",
"@types/node": "^17.0.25",
"publish-if-not-published": "^3.1.2",
"rimraf": "^3.0.2",
"typescript": "^4.6.3"
},
"license": "MIT"
}
44 changes: 44 additions & 0 deletions packages/promise/src/__tests__/defer.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import { setTimeout as delay } from 'timers/promises'

import { defer } from '../defer'

describe('defer', () => {
it('success w/ resolve', async() => {
const { deferWait, checkDeferWaitStatus } = deferTester()

const beforeResolveResult = await checkDeferWaitStatus()
expect(beforeResolveResult).toEqual('pending')

deferWait.resolve()
const afterResolveResult = await checkDeferWaitStatus()
expect(afterResolveResult).toEqual('resolved')
})

it('success w/ reject', async() => {
const { deferWait, checkDeferWaitStatus } = deferTester()

const beforeRejectResult = await checkDeferWaitStatus()
expect(beforeRejectResult).toEqual('pending')

deferWait.reject()
const afterRejectResult = await checkDeferWaitStatus()
expect(afterRejectResult).toEqual('rejected')
})
})

function deferTester() {
const deferWait = defer()
const checkDeferWaitStatus = async() => (
Promise.race([
delay(10).then(() => 'pending'),
deferWait.promise
.then(() => 'resolved')
.catch(() => 'rejected'),
])
)

return {
deferWait,
checkDeferWaitStatus,
}
}
17 changes: 17 additions & 0 deletions packages/promise/src/defer.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
/* eslint-disable @typescript-eslint/no-unused-vars */
/* eslint-disable @typescript-eslint/no-empty-function */

export const defer = <T=void>() => {
const defer = {
promise: Promise.resolve(undefined as unknown as T),
resolve: (_value: T | PromiseLike<T>) => {},
reject: (_reason?: any) => {},
}
defer.promise = new Promise((resolve, reject) => {
defer.resolve = resolve
defer.reject = reject
})

return defer
}
1 change: 1 addition & 0 deletions packages/promise/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export * from './defer'
10 changes: 10 additions & 0 deletions packages/promise/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"extends": "../../tsconfig.json",
"compilerOptions": {
"rootDir": "src",
"outDir": "lib",
},
"include": [
"src"
]
}
12 changes: 12 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -1998,6 +1998,18 @@ __metadata:
languageName: unknown
linkType: soft

"@kanziw/promise@workspace:packages/promise":
version: 0.0.0-use.local
resolution: "@kanziw/promise@workspace:packages/promise"
dependencies:
"@types/jest": ^27.5.0
"@types/node": ^17.0.25
publish-if-not-published: ^3.1.2
rimraf: ^3.0.2
typescript: ^4.6.3
languageName: unknown
linkType: soft

"@kanziw/time@workspace:packages/time":
version: 0.0.0-use.local
resolution: "@kanziw/time@workspace:packages/time"
Expand Down

0 comments on commit 57626f4

Please sign in to comment.