-
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
test\addons\load-long-path\test.js - windows 32 bit failures #3667
Comments
@orangemocha any input on this ? |
I can reproduce on my Windows 7 machine, with a 32-bit build but not with a 64-bit one. On 32-bit, LoadLibraryExW returns ERROR_INSUFFICIENT_BUFFER for long paths, in spite of the long path syntax. This is consistent with some user reports on MSDN (eg https://msdn.microsoft.com/en-us/library/windows/desktop/ms684175(v=vs.85).aspx). I am reaching out to the owners of the API to find out more. |
Thanks for the update |
Any upadate on this ? |
It is a confirmed bug on Wow64 only (meaning 32-bit Node on 64-bit Windows). I reported to the Windows team. It will be fixed in future updates but it's unlikely to be backported. Next of my todo list is to try the following workarounds in Node:
|
@orangemocha did you have any luck with the work arounds ? |
Relative syntax is a no-go, as it would require setting the current directory or dll search path, which both have global side effects. However, I could make it load through a symbolic link. I could submit a patch to libuv (uv_dlopen) or make it node-specific. The patch creates a symbolic link in the user temp folder, calls LoadLibrary on it, then deletes the sym link. @saghul would the above patch be desirable in libuv? |
The workaround might not work in 100% of scenarios. For example, I think it might break usage of GetModuleHandle cc @nodejs/platform-windows |
@orangemocha IMHO such a workaround belongs in Node, rather than libuv. |
It looks like this won't be easy to implement in Node, because we use uv_dlopen and uv_dlopen doesn't return the original error code (it formats it into a string messages and returns success/failure). @saghul , would this workaround be acceptable in libuv? |
@orangemocha should this be closed as "no good way to fix"? I'm assuming what you said in your libuv comment applies here too. |
@gibm I first would like to mark this test in the status file so it gets skipped on 32-bit. |
We couldn't find an acceptable workaround, so I am closing this issue as "won't fix". If people run into this problem, we should advise them to use a 64-bit build of Node. I added a skip for the test on WOW64 with 6e2ae8a. I'll keep tracking this bug internally to make sure it eventually gets fixed in Windows. |
yiyiyi |
This test fails on WOW64 because of a bug in the OS, and there is no acceptable workaround. Ref: nodejs#3667 PR-URL: nodejs#6675 Reviewed-By: bnoordhuis - Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: cjihrig - Colin Ihrig <cjihrig@gmail.com>
This test fails on WOW64 because of a bug in the OS, and there is no acceptable workaround. Ref: nodejs#3667 PR-URL: nodejs#6675 Reviewed-By: bnoordhuis - Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: cjihrig - Colin Ihrig <cjihrig@gmail.com>
I'm seeing failures in our internal builds for test\addons\load-long-path\test.js for windows 32 bit.
I know it was validated that it worked for 32 bit as part of #2965 but I can't see what I'm doing wrong.
I looked in the CI to see if I could find this test running, but I don't think its runs for Windows.
I checked out the latest from the 4.2.2. branch built and ran the test. In addition, I had to build the module for the test with:
E:\test2\node>Release\node deps\npm\node_modules\node-gyp\bin\node-gyp rebuild --directory=e:\test2\node\test\addons\load-long-path --nodedir=e:\test2\node
The failure I see is the same as in our build environment:
Can anybody spot what I'm doing wrong or point me to somewhere in the CI were the test is run so that I can see if its doing anything I'm not ?
In both my local test and the build environment its running on Windows 7 SP1 64 bit with MSVC 2013 installed.
The text was updated successfully, but these errors were encountered: