Убить или закрыть веб-сокет на apollo-сервере после теста шутки - PullRequest
0 голосов
/ 18 июня 2020

Я хотел бы знать, как я могу закрыть веб-сокет после шутливого теста?

Сейчас у меня есть:

пакетов. json

"scripts": {
    "test": "jest --watchAll"
  },
  "jest": {
    "globalSetup": "./tests/jest/globalSetup.js",
    "globalTeardown": "./tests/jest/globalTeardown.js"
  },

сервер. js

...
const server = new ApolloServer({
    typeDefs,
    resolvers,
    context(request) {
        return {
            prisma,
            request,
        }
    },
})

export { server as default }

globalSetup. js

require("@babel/register")

const server = require("../../server").default

// console.log(server)
module.exports = async () => {
    global.httpServer = await server.listen({ port: 4000 })
}

globalTeardown . js

module.exports = async () => {
    console.log("stop") // Show stop in the console
    await global.httpServer.stop
}

Запускаю эту команду:

npm запустить тест

Тест выполняется, но на часах, если я изменю один тест, у меня будет такая ошибка:

Error: listen EADDRINUSE: address already in use :::4000
    at Server.setupListenHandle [as _listen2] (net.js:1313:16)
    at listenInCluster (net.js:1361:12)
    at Server.listen (net.js:1449:7)
    at /Users/jeremiechazelle/Sites/project/server/node_modules/apollo-server/src/index.ts:128:18
    at new Promise (<anonymous>)
    at ApolloServer.<anonymous> (/Users/jeremiechazelle/Sites/project/server/node_modules/apollo-server/src/index.ts:123:11)
    at Generator.next (<anonymous>)
    at /Users/jeremiechazelle/Sites/project/server/node_modules/apollo-server/dist/index.js:18:71
    at new Promise (<anonymous>)
    at __awaiter (/Users/jeremiechazelle/Sites/project/server/node_modules/apollo-server/dist/index.js:14:12)
Emitted 'error' event on WebSocketServer instance at:
    at Server.emit (events.js:316:20)
    at emitErrorNT (net.js:1340:8)
    at processTicksAndRejections (internal/process/task_queues.js:84:21) {
  code: 'EADDRINUSE',
  errno: -48,
  syscall: 'listen',
  address: '::',
  port: 4000
}

После выполнения теста я смотрю порт 4000 с помощью этой команды: lsof -i: 4000 , и я всегда вижу:

enter image description here

Порт не закрыт ...

1 Ответ

1 голос
/ 18 июня 2020

server.listen возвращает Promise, который разрешается в объект ServerInfo

export interface ServerInfo {
  address: string;
  family: string;
  url: string;
  subscriptionsUrl: string;
  port: number | string;
  subscriptionsPath: string;
  server: http.Server;
}

Поэтому вам нужно вызвать global.httpServer.server.close().

...