-
Notifications
You must be signed in to change notification settings - Fork 30.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
http2: multiple cleanups and s/streamClosed/close #17328
Conversation
socket.once('connect', setupFn); | ||
const connectEvent = | ||
socket instanceof tls.TLSSocket ? 'secureConnect' : 'connect'; | ||
socket.once(connectEvent, setupFn); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it possible to add a test for this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are already tests for it that have been flaky, this should fix those flaky tests. One of the existing ones could be modified to check that a secureConnect
handler has been registered.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jasnell Can you point me to one? I volunteer to try and make it fail/pass consistently :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
http2-create-client-secure-session is one, which should be fixed by this PR.
I've updated it to include the check for secureConnect
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍
lib/internal/http2/compat.js
Outdated
@@ -250,7 +250,7 @@ class Http2ServerRequest extends Readable { | |||
stream.on('close', onStreamClosedRequest); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you remove this and the associated function? They should not be necessary.
lib/internal/http2/compat.js
Outdated
@@ -383,7 +383,7 @@ class Http2ServerResponse extends Stream { | |||
stream.on('close', onStreamClosedResponse); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same as above.
Can you remove this and the associated function? They should not be necessary.
lib/internal/http2/core.js
Outdated
@@ -959,13 +968,14 @@ class Http2Session extends EventEmitter { | |||
this.on('shutdown', callback); | |||
} | |||
|
|||
const fn = submitShutdown.bind(this, options); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this be a bit more descriptively named? (Similar to setupFn
elsewhere in this code.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍 This event confused me many times. Thanks for clearing it up.
General improvements to test and verify that a secureConnect handler is present
2e5bcdb
to
4b964e5
Compare
Landed in 0fb1e07...093a870 |
Includes multiple cleanups in core.js along with:
streamClosed
/cc @nodejs/http2
Fixes: #15303
Checklist
make -j4 test
(UNIX), orvcbuild test
(Windows) passesAffected core subsystem(s)
http2