|
1 | 1 | 'use strict';
|
2 | 2 |
|
3 |
| -let Promise = require('bluebird'), |
4 |
| - fs = require('fs'), |
5 |
| - connect = require('connect'), |
6 |
| - serveStatic = require('serve-static'), |
7 |
| - http = require('http'), |
8 |
| - http2 = require('http2'), |
9 |
| - path = require('path'); |
| 3 | +const Promise = require('bluebird'); |
| 4 | +const fs = require('fs'); |
| 5 | +const connect = require('connect'); |
| 6 | +const serveStatic = require('serve-static'); |
| 7 | +const http = require('http'); |
| 8 | +const http2 = require('http2'); |
| 9 | +const path = require('path'); |
10 | 10 |
|
11 | 11 | Promise.promisifyAll(fs);
|
12 | 12 |
|
| 13 | +let server; |
| 14 | +let isListening = false; |
| 15 | + |
13 | 16 | function createServer(useHttp2) {
|
14 |
| - const testdataFolder = path.join(__dirname, '..'), |
15 |
| - app = connect(); |
| 17 | + const testdataFolder = path.join(__dirname, '..'); |
| 18 | + const app = connect(); |
16 | 19 |
|
17 | 20 | app.use(serveStatic(path.resolve(testdataFolder, 'http-server'), {}));
|
| 21 | + |
18 | 22 | if (useHttp2) {
|
19 |
| - const certsFolder = path.join(testdataFolder, 'testdata', 'certs'), |
20 |
| - httpsOptions = { |
21 |
| - key: fs.readFileSync(path.join(certsFolder, 'server.key'), 'utf8'), |
22 |
| - cert: fs.readFileSync(path.join(certsFolder, 'server.crt'), 'utf8'), |
23 |
| - passphrase: 'coach' |
24 |
| - }; |
| 23 | + const certsFolder = path.join(testdataFolder, 'testdata', 'certs'); |
| 24 | + const httpsOptions = { |
| 25 | + key: fs.readFileSync(path.join(certsFolder, 'server.key'), 'utf8'), |
| 26 | + cert: fs.readFileSync(path.join(certsFolder, 'server.crt'), 'utf8'), |
| 27 | + passphrase: 'coach' |
| 28 | + }; |
25 | 29 |
|
26 | 30 | return http2.createServer(httpsOptions, app);
|
27 | 31 | } else {
|
28 | 32 | return http.createServer(app);
|
29 | 33 | }
|
30 | 34 | }
|
31 | 35 |
|
32 |
| -let server; |
33 |
| - |
34 | 36 | module.exports = {
|
35 | 37 | async startServer(useHttp2) {
|
36 | 38 | if (!server) {
|
37 | 39 | server = createServer(useHttp2);
|
38 | 40 | }
|
39 |
| - return new Promise((resolve, reject) => { |
40 |
| - server |
41 |
| - .listen(0, '0.0.0.0') |
42 |
| - .on('error', e => reject(e)) |
43 |
| - .on('listening', () => resolve(server.address())); |
44 |
| - }); |
| 41 | + |
| 42 | + if (!isListening) { |
| 43 | + await new Promise((resolve, reject) => { |
| 44 | + server |
| 45 | + .listen(0, '0.0.0.0') |
| 46 | + .on('error', reject) |
| 47 | + .on('listening', () => { |
| 48 | + isListening = true; |
| 49 | + resolve(server.address()); |
| 50 | + }); |
| 51 | + }); |
| 52 | + } |
| 53 | + |
| 54 | + return server.address(); |
45 | 55 | },
|
| 56 | + |
46 | 57 | async stopServer() {
|
47 |
| - return Promise.resolve(server.close()).finally(() => { |
| 58 | + if (server && isListening) { |
| 59 | + await Promise.resolve(server.close()); |
48 | 60 | server = undefined;
|
49 |
| - }); |
| 61 | + isListening = false; |
| 62 | + } |
50 | 63 | }
|
51 | 64 | };
|
0 commit comments