Skip to content

Commit

Permalink
Use p.completed
Browse files Browse the repository at this point in the history
  • Loading branch information
sosukesuzuki committed Dec 31, 2023
1 parent 7b7b865 commit 1716324
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 49 deletions.
41 changes: 8 additions & 33 deletions test/node-test/abort-controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ const { createServer } = require('http')
const { createReadStream } = require('fs')
const { wrapWithAsyncIterable } = require('../utils/async-iterators')
const { tspl } = require('@matteo.collina/tspl')
const { promiseWithResolvers } = require('../utils/promise')
const { ttype } = require('../utils/node-test')

const controllers = [{
Expand All @@ -30,8 +29,6 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()

server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
const abortController = new AbortControllerImpl()
Expand All @@ -41,11 +38,10 @@ for (const { AbortControllerImpl, controllerName } of controllers) {

client.request({ path: '/', method: 'GET', signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})

await promise
await p.completed
})

test(`Abort ${controllerName} before sending request (no body)`, async (t) => {
Expand All @@ -61,9 +57,6 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise: promise1, resolve: resolve1 } = promiseWithResolvers()
const { promise: promise2, resolve: resolve2 } = promiseWithResolvers()

server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
const abortController = new AbortControllerImpl()
Expand All @@ -77,19 +70,17 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
response.body.on('end', () => {
p.strictEqual('hello', Buffer.concat(bufs).toString('utf8'))
resolve1()
})
})

client.request({ path: '/', method: 'GET', signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve2()
})

abortController.abort()
})

await Promise.all([promise1, promise2])
await p.completed
})

test(`Abort ${controllerName} while waiting response (no body)`, async (t) => {
Expand All @@ -103,19 +94,16 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()

server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))

client.request({ path: '/', method: 'GET', signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})

await promise
await p.completed
})

test(`Abort ${controllerName} while waiting response (write headers started) (no body)`, async (t) => {
Expand All @@ -130,19 +118,16 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()

server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))

client.request({ path: '/', method: 'GET', signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})

await promise
await p.completed
})

test(`Abort ${controllerName} while waiting response (write headers and write body started) (no body)`, async (t) => {
Expand All @@ -155,8 +140,6 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()

server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))
Expand All @@ -168,12 +151,11 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
response.body.on('error', err => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})
})

await promise
await p.completed
})

function waitingWithBody (body, type) { // eslint-disable-line
Expand All @@ -188,18 +170,15 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()
server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))

client.request({ path: '/', method: 'POST', body, signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})

await promise
await p.completed
})
}

Expand All @@ -221,17 +200,15 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()
server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))

client.request({ path: '/', method: 'POST', body, signal: abortController.signal }, (err, response) => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})
await promise
await p.completed
})
}

Expand All @@ -251,7 +228,6 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
t.after(server.close.bind(server))

const { promise, resolve } = promiseWithResolvers()
server.listen(0, () => {
const client = new Client(`http://localhost:${server.address().port}`)
t.after(client.destroy.bind(client))
Expand All @@ -263,11 +239,10 @@ for (const { AbortControllerImpl, controllerName } of controllers) {
})
response.body.on('error', err => {
ttype(p, err, errors.RequestAbortedError)
resolve()
})
})
})
await promise
await p.completed
})
}

Expand Down
16 changes: 0 additions & 16 deletions test/utils/promise.js

This file was deleted.

0 comments on commit 1716324

Please sign in to comment.