* gnu/packages/node.scm (node): Update to 8.9.1. [source]: Apply 'node-test-http2-server-rst-stream.patch'. [arguments]: Skip 'doc-only' target in 'check', which attempts to use npm to retrieve 'js-yaml' package. Remove test/doctool/test-make-doc.js. Do not remove now-missing test case. Remove new test case that fails in containers due to networking. * gnu/packages/patches/node-test-http2-server-rst-stream.patch: New file. Signed-off-by: Ludovic Courtès <ludo@gnu.org>
		
			
				
	
	
		
			131 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
From a41cc020fd6e40b358103425edfa50e6a10fc973 Mon Sep 17 00:00:00 2001
 | 
						|
From: Anatoli Papirovski <apapirovski@mac.com>
 | 
						|
Date: Thu, 2 Nov 2017 12:46:31 -0400
 | 
						|
Subject: [PATCH] test: fix flaky test-http2-server-rst-stream.js
 | 
						|
 | 
						|
PR-URL: https://github.com/nodejs/node/pull/16690
 | 
						|
Fixes: https://github.com/nodejs/node/issues/16688
 | 
						|
Reviewed-By: James M Snell <jasnell@gmail.com>
 | 
						|
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
 | 
						|
---
 | 
						|
 test/parallel/test-http2-server-rst-stream.js | 93 ++++++++++-----------------
 | 
						|
 1 file changed, 35 insertions(+), 58 deletions(-)
 | 
						|
 | 
						|
diff --git a/test/parallel/test-http2-server-rst-stream.js b/test/parallel/test-http2-server-rst-stream.js
 | 
						|
index b92217dc99..dd38efb42f 100644
 | 
						|
--- a/test/parallel/test-http2-server-rst-stream.js
 | 
						|
+++ b/test/parallel/test-http2-server-rst-stream.js
 | 
						|
@@ -5,11 +5,9 @@ if (!common.hasCrypto)
 | 
						|
   common.skip('missing crypto');
 | 
						|
 const assert = require('assert');
 | 
						|
 const http2 = require('http2');
 | 
						|
+const Countdown = require('../common/countdown');
 | 
						|
 
 | 
						|
 const {
 | 
						|
-  HTTP2_HEADER_METHOD,
 | 
						|
-  HTTP2_HEADER_PATH,
 | 
						|
-  HTTP2_METHOD_POST,
 | 
						|
   NGHTTP2_CANCEL,
 | 
						|
   NGHTTP2_NO_ERROR,
 | 
						|
   NGHTTP2_PROTOCOL_ERROR,
 | 
						|
@@ -17,63 +15,42 @@ const {
 | 
						|
   NGHTTP2_INTERNAL_ERROR
 | 
						|
 } = http2.constants;
 | 
						|
 
 | 
						|
-const errCheck = common.expectsError({ code: 'ERR_HTTP2_STREAM_ERROR' }, 6);
 | 
						|
+const tests = [
 | 
						|
+  ['rstStream', NGHTTP2_NO_ERROR, false],
 | 
						|
+  ['rstWithNoError', NGHTTP2_NO_ERROR, false],
 | 
						|
+  ['rstWithProtocolError', NGHTTP2_PROTOCOL_ERROR, true],
 | 
						|
+  ['rstWithCancel', NGHTTP2_CANCEL, false],
 | 
						|
+  ['rstWithRefuse', NGHTTP2_REFUSED_STREAM, true],
 | 
						|
+  ['rstWithInternalError', NGHTTP2_INTERNAL_ERROR, true]
 | 
						|
+];
 | 
						|
+
 | 
						|
+const server = http2.createServer();
 | 
						|
+server.on('stream', (stream, headers) => {
 | 
						|
+  const method = headers['rstmethod'];
 | 
						|
+  stream[method]();
 | 
						|
+});
 | 
						|
+
 | 
						|
+server.listen(0, common.mustCall(() => {
 | 
						|
+  const client = http2.connect(`http://localhost:${server.address().port}`);
 | 
						|
+
 | 
						|
+  const countdown = new Countdown(tests.length, common.mustCall(() => {
 | 
						|
+    client.destroy();
 | 
						|
+    server.close();
 | 
						|
+  }));
 | 
						|
 
 | 
						|
-function checkRstCode(rstMethod, expectRstCode) {
 | 
						|
-  const server = http2.createServer();
 | 
						|
-  server.on('stream', (stream, headers, flags) => {
 | 
						|
-    stream.respond({
 | 
						|
-      'content-type': 'text/html',
 | 
						|
-      ':status': 200
 | 
						|
+  tests.forEach((test) => {
 | 
						|
+    const req = client.request({
 | 
						|
+      ':method': 'POST',
 | 
						|
+      rstmethod: test[0]
 | 
						|
     });
 | 
						|
-    stream.write('test');
 | 
						|
-    if (rstMethod === 'rstStream')
 | 
						|
-      stream[rstMethod](expectRstCode);
 | 
						|
-    else
 | 
						|
-      stream[rstMethod]();
 | 
						|
-
 | 
						|
-    if (expectRstCode !== NGHTTP2_NO_ERROR &&
 | 
						|
-        expectRstCode !== NGHTTP2_CANCEL) {
 | 
						|
-      stream.on('error', common.mustCall(errCheck));
 | 
						|
-    } else {
 | 
						|
-      stream.on('error', common.mustNotCall());
 | 
						|
-    }
 | 
						|
-  });
 | 
						|
-
 | 
						|
-  server.listen(0, common.mustCall(() => {
 | 
						|
-    const port = server.address().port;
 | 
						|
-    const client = http2.connect(`http://localhost:${port}`);
 | 
						|
-
 | 
						|
-    const headers = {
 | 
						|
-      [HTTP2_HEADER_PATH]: '/',
 | 
						|
-      [HTTP2_HEADER_METHOD]: HTTP2_METHOD_POST
 | 
						|
-    };
 | 
						|
-    const req = client.request(headers);
 | 
						|
-
 | 
						|
-    req.setEncoding('utf8');
 | 
						|
-    req.on('streamClosed', common.mustCall((actualRstCode) => {
 | 
						|
-      assert.strictEqual(
 | 
						|
-        expectRstCode, actualRstCode, `${rstMethod} is not match rstCode`);
 | 
						|
-      server.close();
 | 
						|
-      client.destroy();
 | 
						|
+    req.on('streamClosed', common.mustCall((code) => {
 | 
						|
+      assert.strictEqual(code, test[1]);
 | 
						|
+      countdown.dec();
 | 
						|
     }));
 | 
						|
-    req.on('data', common.mustCall());
 | 
						|
     req.on('aborted', common.mustCall());
 | 
						|
-    req.on('end', common.mustCall());
 | 
						|
-
 | 
						|
-    if (expectRstCode !== NGHTTP2_NO_ERROR &&
 | 
						|
-        expectRstCode !== NGHTTP2_CANCEL) {
 | 
						|
-      req.on('error', common.mustCall(errCheck));
 | 
						|
-    } else {
 | 
						|
+    if (test[2])
 | 
						|
+      req.on('error', common.mustCall());
 | 
						|
+    else
 | 
						|
       req.on('error', common.mustNotCall());
 | 
						|
-    }
 | 
						|
-
 | 
						|
-  }));
 | 
						|
-}
 | 
						|
-
 | 
						|
-checkRstCode('rstStream', NGHTTP2_NO_ERROR);
 | 
						|
-checkRstCode('rstWithNoError', NGHTTP2_NO_ERROR);
 | 
						|
-checkRstCode('rstWithProtocolError', NGHTTP2_PROTOCOL_ERROR);
 | 
						|
-checkRstCode('rstWithCancel', NGHTTP2_CANCEL);
 | 
						|
-checkRstCode('rstWithRefuse', NGHTTP2_REFUSED_STREAM);
 | 
						|
-checkRstCode('rstWithInternalError', NGHTTP2_INTERNAL_ERROR);
 | 
						|
+  });
 | 
						|
+}));
 | 
						|
-- 
 | 
						|
2.15.0
 | 
						|
 |