Files
cypress/packages/proxy/lib/http/error-middleware.ts
Zach Bloomquist 2454c19afb feat: proxy logging (#16730)
Co-authored-by: Chris Breiding <chrisbreiding@users.noreply.github.com>
2021-08-02 21:10:19 +00:00

68 lines
1.4 KiB
TypeScript

import debugModule from 'debug'
import { HttpMiddleware } from '.'
import { InterceptError } from '@packages/net-stubbing'
import { Readable } from 'stream'
import { Request } from '@cypress/request'
import errors from '@packages/server/lib/errors'
const debug = debugModule('cypress:proxy:http:error-middleware')
export type ErrorMiddleware = HttpMiddleware<{
error: Error
incomingResStream?: Readable
outgoingReq?: Request
}>
const LogError: ErrorMiddleware = function () {
debug('error proxying request %o', {
error: this.error,
url: this.req.url,
headers: this.req.headers,
})
this.next()
}
const SendToDriver: ErrorMiddleware = function () {
if (this.req.browserPreRequest) {
this.socket.toDriver('request:event', 'request:error', {
requestId: this.req.browserPreRequest.requestId,
error: errors.clone(this.error),
})
}
this.next()
}
export const AbortRequest: ErrorMiddleware = function () {
if (this.outgoingReq) {
debug('aborting outgoingReq')
this.outgoingReq.abort()
}
this.next()
}
export const UnpipeResponse: ErrorMiddleware = function () {
if (this.incomingResStream) {
debug('unpiping resStream from response')
this.incomingResStream.unpipe()
}
this.next()
}
export const DestroyResponse: ErrorMiddleware = function () {
this.res.destroy()
this.end()
}
export default {
LogError,
SendToDriver,
InterceptError,
AbortRequest,
UnpipeResponse,
DestroyResponse,
}