-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
querystring: check that maxKeys is finite #5066
Conversation
LGTM, but should the test be in a separate commit? |
I'm really not sure, I can check previous commits. To me it makes sense to include the test with the commit removing the regression. |
// maxKeys <= 0 means that we should not limit keys count | ||
if (maxKeys > 0) { |
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.
Wouldn't it be better, if we just throw an isFinite
check here?
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.
that is actually a great idea.
568da30
to
83d9a13
Compare
Sadly, it is as per the spec only.
and 9.6 ToUint32: (Unsigned 32 Bit Integer) says,
|
@thefourtheye great idea, I've restructured this commit @evanlucas I'll need another LGTM. Rather than reverting I've added an extra check for infinity. It now makes much more sense to include the test |
@nodejs/testing is there a preference to writing more smaller tests, or putting this in with another test already testing querystring? |
Yea, I like this. LGTM. Definitely need CI on this one though to make sure arm is happy with it too |
Adding a new test is fine in this case, and it would be better to have this issue also mentioned somewhere in the comments. |
@@ -0,0 +1,36 @@ | |||
'use strict'; | |||
const common = require('../common'); |
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.
Didn't our linter complain about unused variable? I thought this,
## disallow declaration of variables that are not used in the code
no-unused-vars: [2, {"args": "none"}]
forbids us
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.
yeah... I just pushed an update that fixes the linting issues
928bb12
to
34c252c
Compare
// 27def4f introduced a change to parse that would cause Inifity | ||
// to be passed to String.prototype.split as an argument for limit | ||
// In this instance split will always return an empty array | ||
// this test confirms that the output of parse is the expe4cted length |
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.
expe4cted
-> expected
34c252c
to
e754fe7
Compare
// In this instance split will always return an empty array | ||
// this test confirms that the output of parse is the expe4cted length | ||
// when passed Infinity as the argument for maxKeys | ||
const result = parse(params, undefined, undefined, {maxKeys: Infinity}); |
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.
Now that we are doing it, let's introduce tests with NaN
, 'Infinity'
and 'NaN'
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.
@thefourtheye I've updated the test to include tests for all four "non finite" values
e754fe7
to
f65ba73
Compare
I couldn't think of any other corner cases. LGTM. |
It might be a little more efficient to add the |
LGTM with a comment. |
In that case we can simply do |
Speaking for myself only, I definitely prefer smaller, isolated tests. |
const assert = require('assert'); | ||
const parse = require('querystring').parse; | ||
|
||
// taken from express-js/body-parser |
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.
put in a full github url including hash for the exact version you're pulling from
/cc @manvalls @thealphanerd I think this is ok, lgtm
One thing to keep in mind is that separate tests take longer to run in CI than compacting them into fewer tests. Primarily due to very slow startup time on slower ARM machines but also it seems like this AIX and musl libc based systems have slow exit times (ref #5056). More files, separate tests is certainly the nicer way to approach it but I just wanted to register the above concern so that @nodejs/testing is aware of this and can (maybe) take it into account when forming opinions on how to best structure tests. |
@cjihrig @thefourtheye if we made the suggested change then maxKeys will always = 1000, this would also result in a behaviour change |
1856970
to
518f4f5
Compare
@rvagg I've updated the test with a comment that includes the github link, with sha and line numbers. As you can expect this link is far over the max characters per line. I've split it on to two lines, hopefully that isn't confusing |
@thealphanerd no, this is what I was proposing. It should be functionally equivalent to what you have, but slightly more efficient. And, as @thefourtheye pointed out, the last two conditions can be condensed to var maxKeys = 1000;
if (options && typeof options.maxKeys === 'number' && isFinite(options.maxKeys)) {
maxKeys = options.maxKeys;
}
// maxKeys <= 0 means that we should not limit keys count
if (maxKeys > 0) { |
maxKeys is set just above though. Meaning that thus the split will be called with maxKeys set to 1000 which is still a behavior change. To double check that I am correct I have implemented your change and run it against the tests and we get a failure
|
Sorry, you're right. I was thinking we wanted |
Ya, that doesn't look right. Can we fix this behavior here? |
@thefourtheye I think we can fix that behavior, but that would be a Major change. In the mean time we do need to patch back the behavior that is expected (imho). Or are you arguing that the behavior itself was a bug? |
@thealphanerd Though it seems odd, as you pointed out, our priority here is to get this fixed asap, with the current functionality. Perhaps we can improve this in a separate patch. LGTM. |
I think it is also worth mentioning that #5012 rewrite all the code this is touching. |
Technically, exit itself is quick. What happens is that the parent exits without reaping the child processes, so init (pid 1) has to reap those zombies. The slow timeout on Alpine Linux was due to busybox init has a "design flaw" that will intentionally delay the reaping of the orphaned child processes. This has actually nothing to do with musl libc and I am pretty sure that busybox init with glibc has the exact same issue. Most likely this is what AIX init does too. Exit times are fast. But someone/something needs to reap the dead processes. Ideally should the parent process take care of that instead of letting init (pid 1) do it. |
Rubber-stamp LGTM |
518f4f5
to
e529f08
Compare
There was a very subtle change in behavior introduced with 27def4f In the past if querystring.parse was given Infinity for maxKeys, everything worked as expected. Check to see is maxKeys is Infinity before forwarding the value to String.prototype.split which causes this regression PR-URL: nodejs#5066 Reviewed-By: Evan Lucas <[email protected]> Reviewed By: Sakthipriyan Vairamani <[email protected]> Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Jeremiah Senkpiel <[email protected]>
e529f08
to
878bcd4
Compare
Landed as 878bcd4 |
Express must be happy now, right? |
Thanks @ncopa, that's very interesting background |
There was a very subtle change in behavior introduced with 27def4f In the past if querystring.parse was given Infinity for maxKeys, everything worked as expected. Check to see is maxKeys is Infinity before forwarding the value to String.prototype.split which causes this regression PR-URL: #5066 Reviewed-By: Evan Lucas <[email protected]> Reviewed By: Sakthipriyan Vairamani <[email protected]> Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Jeremiah Senkpiel <[email protected]>
There was a very subtle change in behavior introduced with 27def4f In the past if querystring.parse was given Infinity for maxKeys, everything worked as expected. Check to see is maxKeys is Infinity before forwarding the value to String.prototype.split which causes this regression PR-URL: #5066 Reviewed-By: Evan Lucas <[email protected]> Reviewed By: Sakthipriyan Vairamani <[email protected]> Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Jeremiah Senkpiel <[email protected]>
There was a very subtle change in behavior introduced with 27def4f In the past if querystring.parse was given Infinity for maxKeys, everything worked as expected. Check to see is maxKeys is Infinity before forwarding the value to String.prototype.split which causes this regression PR-URL: nodejs#5066 Reviewed-By: Evan Lucas <[email protected]> Reviewed By: Sakthipriyan Vairamani <[email protected]> Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Jeremiah Senkpiel <[email protected]>
There was a very subtle change in behavior introduced with 27def4f
In the past if querystring.parse was given Infinity for maxKeys,
everything worked as expected.
Check to see is maxKeys is Infinity before forwarding the value to
String.prototype.split which causes this regression