Skip to content
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

[BUG] npm picks up wrong platform on npm install #8005

Closed
2 tasks done
KDean-Dolphin opened this issue Dec 31, 2024 · 2 comments
Closed
2 tasks done

[BUG] npm picks up wrong platform on npm install #8005

KDean-Dolphin opened this issue Dec 31, 2024 · 2 comments
Labels
Bug thing that needs fixing Needs Triage needs review for next steps

Comments

@KDean-Dolphin
Copy link

Is there an existing issue for this?

  • I have searched the existing issues

This issue exists in the latest npm version

  • I am using the latest npm

Current Behavior

Installing package that has a development dependency that in turn has platform-specific dependencies crashes because npm install selects the wrong platform.

Expected Behavior

  1. Running npm install <package> should ignore devDependencies in the installed package. It doesn't. This is a well known and frustratingly old bug ([BUG] Dev dependency should not throw “unsupported platform” error when using --production flag on npm install #2921).
  2. With multiple dependencies to choose from, the one that is compatible with the operating system should be selected. It isn't, and the install fails with EBADPLATFORM.

Steps To Reproduce

On macOS 15.2 or Windows 11 running under Parallels on macOS:

  1. Create and switch to a new directory.
  2. Run npm init.
  3. Accept all the defaults.
  4. Run npm install @aidc-toolkit/dev.
  5. Sob quietly as your development grinds to a halt.
% npm install @aidc-toolkit/dev
npm error code EBADPLATFORM
npm error notsup Unsupported platform for @rollup/rollup-linux-x64-gnu@4.29.1: wanted {"os":"linux","cpu":"x64","libc":"glibc"} (current: {"os":"darwin","cpu":"arm64"})
npm error notsup Valid os:    linux
npm error notsup Actual os:   darwin
npm error notsup Valid cpu:   x64
npm error notsup Actual cpu:  arm64
npm error notsup Valid libc:  glibc
npm error notsup Actual libc: undefined
npm error A complete log of this run can be found in: /Users/kevindean/.npm/_logs/2024-12-31T13_14_19_280Z-debug-0.log

Environment

  • npm: 11.0
  • Node.js: v22.11.0
  • OS Name: macOS
  • System Model Name:
  • npm config:
; copy and paste output from `npm config ls` here

; node bin location = /Users/kevindean/.asdf/installs/nodejs/22.11.0/bin/node
; node version = v22.11.0
; npm local prefix = /Users/kevindean/Temp/npmtest
; npm version = 11.0.0
; cwd = /Users/kevindean/Temp/npmtest
; HOME = /Users/kevindean
; Run npm config ls -l to show all defaults.

@milaninfy
Copy link
Contributor

milaninfy commented Jan 7, 2025

I see that dependency causing failure is @rollup/rollup-linux-x64-gnu is listed as dependencies in the package you are trying to install which is not compatible with current engine hence npm is failing to install.

~/workarea/rep $ npm view @aidc-toolkit/dev dependencies 
{
  '@eslint/js': '^9.17.0',
  '@octokit/types': '^13.6.2',
  '@rollup/rollup-linux-x64-gnu': '^4.29.1',
  '@stylistic/eslint-plugin': '^2.12.1',
  'eslint-config-love': '^114.0.0',
  'eslint-plugin-jsdoc': '^50.6.1',
  octokit: '^4.0.3',
  'typescript-eslint': '^8.19.0',
  yaml: '^2.6.1'
}
~/workarea/rep $ npm view @rollup/rollup-linux-x64-gnu os cpu libc   
os = 'linux'
cpu = 'x64'
libc = 'glibc'

@KDean-Dolphin
Copy link
Author

Thank you. This is one of those things that warrants as much banging my head as my desk can sustain.

That dependency doesn't exist in the repository version of package.json; it's added during the GitHub Action that packages and publishes the project because of a known bug in installing platform-specific dependencies.

        # This is necessary to work around platform-specific optional dependencies bug
        # (https://github.com/npm/cli/issues/4828).
        npm install @rollup/rollup-linux-x64-gnu

Due to some significant refactoring that has taken place in the months since I added that line to the script, the conditions that trigger the bug no longer exist, so I can safely remove it. In hindsight, I should have added --save=false to prevent it from updating package.json in the first place.

Thanks @milaninfy for looking into this, and thanks for teaching me about the npm view command, which prompted me to look at package.json in the published package instead of in the source.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug thing that needs fixing Needs Triage needs review for next steps
Projects
None yet
Development

No branches or pull requests

2 participants