52

The devDependencies section of npm's package.json documentation says to list your test dependencies there so that users of your package don't have to pull down extra dependencies. Would it make sense to also add my test directory to .npmignore in that case?

1

3 Answers 3

52

Yes that's what most people do, here are some npmignore files for popular Node.js modules:

https://github.com/socketio/socket.io/blob/ab46351a8446516fb4eea3b8333f7c0f18afaac5/.npmignore

Other people allowlist what they want published in their package.json files setting:

https://github.com/senchalabs/connect/blob/master/package.json
https://github.com/strongloop/express/blob/master/package.json

Sign up to request clarification or add additional context in comments.

3 Comments

Some might find it useful to keep tests there so people can do npm test module if for some reason something isn't working and they want to test the modules they're using.
I would suggest that if people want to run tests for my module/package, they would actually take the time to clone my repo and run npm install so they get all the actual development dependencies. It sucks big time when you start depending on some module that happens to have about 20 megabytes of autogenerated test code published to npm (e.g. moment-timezone <= 0.0.3), along with a bunch of test frameworks that I don't need in order to use the module.
first link is broken
21

One thing that I haven't been able to find explicitly mentioned anywhere is the fact that the "files" entry in package.json supports using a ! prefix on an entry. So, for example, I have a "files" entry that looks like this:

{
  "files": [
    "lib/**/*",
    "!lib/**/*.map"
  ],
}

I do that because my lib directory includes .map files that I don't want to include in the package, and this includes everything but the *.map files.

6 Comments

Is this documented somewhere? I can't get this to work (npm v8) and neither can I find any documentation about it.
The files entry is documented to to follow a similar syntax to .gitignore, but reversed. See: docs.npmjs.com/cli/v9/configuring-npm/package-json#files
It definitely worked for me in npm 6, but I'm not sure I've tested it in npm 8. However, even though the npm documentation link above is for v9, the v8 documentation says the same thing (replace v9 with v8 in the link).
Yes, it says, "File patterns follow a similar syntax to .gitignore, but reversed..." Since .gitignore allows bang characters, I tried it out, and it worked for me. I don't know why it's not working for you.
!/src/**/__tests__/*.test.ts worked for me.
|
5

Another approach is to use a lib folder and store everything in there. Then you can configure your package.json to consider only that folder.

In order to work you need also to move your main file inside lib and specify it in the package.json. See example below:

{
  "name": "your-package",
  "main": "./lib/index.js",
  "files": [
    "/lib"
  ]
}

More info are available on this nice article

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.