-
Notifications
You must be signed in to change notification settings - Fork 150
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
fix: add special case for [email protected] optional dependencies #372
Conversation
Looks like https://github.com/vercel/nft/actions/runs/7054667887/job/19203908329?pr=372#step:8:7545 So we might need to change the repo to use npm or at least this specific test needs npm. @lovell is that expected? |
Adding |
yarn v1 has been in maintenance mode for almost 4 years and does not properly support |
b011392
to
4d6d3e5
Compare
@styfle Whatcha think about this PR? Merge it? |
Co-authored-by: Steven <[email protected]>
Co-authored-by: Steven <[email protected]>
Great to see some progress on this, thank you. The sharp-related change adds 10 lines whereas the majority of this PR appears to relate to replacing yarn v1 with the latest npm. If clean version control history is of interest then may I suggest a split into a PR for the package manager upgrade and a PR to support |
Even if we split it into 2 PRs, it will still have the same problem because we can't run tests without installing This should be wrapping up soon though, there was a bug in jest causing some confusion and I think we have it resolved. |
@@ -13,6 +13,9 @@ console.log('created directory ' + tmpdir); | |||
|
|||
// These are tests known to fail so we skip them | |||
const ignoreCategories = new Set([ | |||
'Generator function.sent Meta Property', | |||
'Class and Property Decorators', | |||
'throw expressions', | |||
]); |
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.
We are skipping these tests now because they currently fail.
At first I thought this must be a regression since the tests were passing on main (head is 285c930). However, the tests were always failing and jest was silently succeeding. Regenerating the lockfile, implicitly upgraded jest from 27.4.5
to 27.5.1
(due to the ^
prefix) and this included a fix that is now surfacing the error.
I also converted this file from jest
to node:test
just to confirm that it also fails on main.
Since these tests are Stage 2 features, likely no one has noticed they don't work because no JS runtime implements them.
Looks like we're running into this npm bug now 🤦 |
🎉 This PR is included in version 0.26.1 🎉 The release is available on: Your semantic-release bot 📦🚀 |
There's a need to skip some integration tests for Windows, this PR moves the logic for skipping to the test setup itself rather than altering the tests and dependencies as we were doing in the `prepare-install` step. The pre-install logic was also deleting the `package-lock.json`, I'm not 100% clear on what the purpose was, but seems like it may have been done accidentally given the context of the [diff here](#372 (comment)). With the previous logic, CI started to fail on Windows because the `package-lock.json` was removed before install, causing us to install a later version of dependency. Instead of removing that line of code in the `prepare-install` file, just trying this approach which feels a little more straightforward. --------- Co-authored-by: Nathan Rajlich <[email protected]>
@vercel/nft
does not pick up platform-specific binaries forsharp
#371Additionally:
yarn
withnpm
(sharp requires it)@ffmpeg-installer/ffmpeg
,oracledb
,sharp
to versions which support Apple Siliconmicrotime-node-gyp
test on Apple SiliconI also skipped a few ECMAScript Next tests because they currently fail.
At first I thought this must be a regression since the tests were passing on main (head is 285c930). However, the tests were always failing and jest was silently succeeding. Regenerating the lockfile, implicitly upgraded jest from
27.4.5
to27.5.1
(due to the^
prefix) and this included a fix that is now surfacing the error.I also converted this file from
jest
tonode:test
just to confirm that it also fails on main.Since these tests are Stage 2 features, likely no one has noticed they don't work because no JS runtime implements them.