-
Notifications
You must be signed in to change notification settings - Fork 3.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
[BUG] npm publish ignores files exclusion glob #2441
Comments
👋 I'm also seeing this, after upgrading to v7 and publishing express-validator, files that were previously ignored started affecting consumers. express-validator/express-validator#973 Note: the lines above have been unchanged for about 2 years. |
The documentation for https://docs.npmjs.com/cli/v6/configuring-npm/package-json#files |
from the docs you linked:
that's not a workaround. the files are still being published. the whole point of negating is to exclude files from publishing.
Possibly, although unlikely. this has worked for years, I assume since |
Oh, are the problem files in Reproduced issue with node v15.5.1 and npm 7.3.0 on macOS v15.1.
I agree! I made a typo. I meant "unintended change". |
Additionally: the docs mention "File patterns follow a similar syntax to .gitignore", so I expected anything that works there to work in the |
Thanks @gustavohenke and @dnalborczyk for pointing out the relevant information in the documentation I linked. My apologies, I was wrong with suggestion that |
Confirmed this is a changing behavior from 6 to 7 ~/D/n/foo $ npx npm@6 publish --dry-run
Need to install the following packages:
npm@6
Ok to proceed? (y) y
npm notice
npm notice 📦 foo@1.0.0
npm notice === Tarball Contents ===
npm notice 6B dist/index.js
npm notice 401B package.json
npm notice 3B README.md
npm notice === Tarball Details ===
npm notice name: foo
npm notice version: 1.0.0
npm notice package size: 406 B
npm notice unpacked size: 410 B
npm notice shasum: 91fb8aa3b4d3d7891ab1a8340d209ffb4c39d642
npm notice integrity: sha512-g76XXMn/nll+6[...]HXtFYalqhCB9w==
npm notice total files: 3
npm notice
+ foo@1.0.0
~/D/n/foo $ npx npm@7 publish --dry-run
Need to install the following packages:
npm@7
Ok to proceed? (y) y
npm notice
npm notice 📦 foo@1.0.0
npm notice === Tarball Contents ===
npm notice 3B README.md
npm notice 0B dist/__mocks__/foo.json
npm notice 6B dist/__tests__/index.js
npm notice 6B dist/index.js
npm notice 401B package.json
npm notice === Tarball Details ===
npm notice name: foo
npm notice version: 1.0.0
npm notice filename: foo-1.0.0.tgz
npm notice package size: 467 B
npm notice unpacked size: 416 B
npm notice shasum: 25ea3021a75979fd9b30b3abd8c76e781deb7350
npm notice integrity: sha512-GNQTXwW8Z3+sz[...]aMXRJSG78irJA==
npm notice total files: 5
npm notice
+ foo@1.0.0 |
+1. This was also mentioned as fixed in #2009, but clearly was not. |
just a quick update for now: i've refactored npm-packlist to behave more like it did in npm@6 while still keeping most of the benefits of the state it's in today. unfortunately, we've decided that this change is a breaking change. yes, it restores the behavior of npm@6 but because the current behavior has been around for 2 semver-major ranges changing it now is another breakage. due to this, we plan to land the refactor that fixes this issue as part of the first release of npm@9 which should hopefully not be too much longer. for reference, here's the pull request with the refactor: npm/npm-packlist#88 |
In case you’re interested, this is part of my package.json: "files": [
"package.json",
"README.md",
"LICENSE",
"dist/**/*.js",
"dist/**/*.js.map",
"dist/**/*.d.ts",
"dist/**/*.d.ts.map",
"src/**/*.ts",
"!dist/**/*_test.js",
"!dist/**/*_test.js.map",
"!dist/**/*_test.d.ts",
"!dist/**/*_test.d.ts.map",
"!src/**/*_test.ts"
], |
Current Behavior:
npm publish --dry-run
includes__tests__
and__mocks__
package.json:
Expected Behavior:
should exclude
__tests__
and__mocks__
works with npm
v6.14.9
.Steps To Reproduce:
see above
Environment:
The text was updated successfully, but these errors were encountered: