1WORKSPACES(7) WORKSPACES(7)
2
3
4
6 workspaces - Working with workspaces
7
8 Description
9 Workspaces is a generic term that refers to the set of features in the
10 npm cli that provides support to managing multiple packages from your
11 local files system from within a singular top-level, root package.
12
13 This set of features makes up for a much more streamlined workflow han‐
14 dling linked packages from the local file system. Automating the link‐
15 ing process as part of npm install and avoiding manually having to use
16 npm link in order to add references to packages that should be sym‐
17 linked into the current node_modules folder.
18
19 We also refer to these packages being auto-symlinked during npm install
20 as a single workspace, meaning it's a nested package within the current
21 local file system that is explicitly defined in the npm help pack‐
22 age.json workspaces configuration.
23
24 Defining workspaces
25 Workspaces are usually defined via the workspaces property of the npm
26 help package.json file, e.g:
27
28 {
29 "name": "my-workspaces-powered-project",
30 "workspaces": [
31 "workspace-a"
32 ]
33 }
34
35 Given the above package.json example living at a current working direc‐
36 tory . that contains a folder named workspace-a that itself contains a
37 package.json inside it, defining a Node.js package, e.g:
38
39 .
40 +-- package.json
41 `-- workspace-a
42 `-- package.json
43
44 The expected result once running npm install in this current working
45 directory . is that the folder workspace-a will get symlinked to the
46 node_modules folder of the current working dir.
47
48 Below is a post npm install example, given that same previous example
49 structure of files and folders:
50
51 .
52 +-- node_modules
53 | `-- workspace-a -> ../workspace-a
54 +-- package-lock.json
55 +-- package.json
56 `-- workspace-a
57 `-- package.json
58
59 Getting started with workspaces
60 You may automate the required steps to define a new workspace using npm
61 help init. For example in a project that already has a package.json de‐
62 fined you can run:
63
64 npm init -w ./packages/a
65
66 This command will create the missing folders and a new package.json
67 file (if needed) while also making sure to properly configure the
68 "workspaces" property of your root project package.json.
69
70 Adding dependencies to a workspace
71 It's possible to directly add/remove/update dependencies of your
72 workspaces using the npm help workspace config.
73
74 For example, assuming the following structure:
75
76 .
77 +-- package.json
78 `-- packages
79 +-- a
80 | `-- package.json
81 `-- b
82 `-- package.json
83
84 If you want to add a dependency named abbrev from the registry as a de‐
85 pendency of your workspace a, you may use the workspace config to tell
86 the npm installer that package should be added as a dependency of the
87 provided workspace:
88
89 npm install abbrev -w a
90
91 Note: other installing commands such as uninstall, ci, etc will also
92 respect the provided workspace configuration.
93
94 Using workspaces
95 Given the specifities of how Node.js handles module resolution
96 https://nodejs.org/dist/latest-v14.x/docs/api/modules.html#mod‐
97 ules_all_together it's possible to consume any defined workspace by
98 it's declared package.json name. Continuing from the example defined
99 above, let's also create a Node.js script that will require the
100 workspace-a example module, e.g:
101
102 // ./workspace-a/index.js
103 module.exports = 'a'
104
105 // ./lib/index.js
106 const moduleA = require('workspace-a')
107 console.log(moduleA) // -> a
108
109 When running it with:
110
111 node lib/index.js
112
113 This demonstrates how the nature of node_modules resolution allows for
114 workspaces to enable a portable workflow for requiring each workspace
115 in such a way that is also easy to npm help publish these nested
116 workspaces to be consumed elsewhere.
117
118 Running commands in the context of workspaces
119 You can use the workspace configuration option to run commands in the
120 context of a configured workspace.
121
122 Following is a quick example on how to use the npm run command in the
123 context of nested workspaces. For a project containing multiple
124 workspaces, e.g:
125
126 .
127 +-- package.json
128 `-- packages
129 +-- a
130 | `-- package.json
131 `-- b
132 `-- package.json
133
134 By running a command using the workspace option, it's possible to run
135 the given command in the context of that specific workspace. e.g:
136
137 npm run test --workspace=a
138
139 This will run the test script defined within the ./packages/a/pack‐
140 age.json file.
141
142 Please note that you can also specify this argument multiple times in
143 the command-line in order to target multiple workspaces, e.g:
144
145 npm run test --workspace=a --workspace=b
146
147 It's also possible to use the workspaces (plural) configuration option
148 to enable the same behavior but running that command in the context of
149 all configured workspaces. e.g:
150
151 npm run test --workspaces
152
153 Will run the test script in both ./packages/a and ./packages/b.
154
155 Commands will be run in each workspace in the order they appear in your
156 package.json
157
158 {
159 "workspaces": [ "packages/a", "packages/b" ]
160 }
161
162 Order of run is different with:
163
164 {
165 "workspaces": [ "packages/b", "packages/a" ]
166 }
167
168 Ignoring missing scripts
169 It is not required for all of the workspaces to implement scripts run
170 with the npm run command.
171
172 By running the command with the --if-present flag, npm will ignore
173 workspaces missing target script.
174
175 npm run test --workspaces --if-present
176
177 See also
178 • npm help install
179
180 • npm help publish
181
182 • npm help run-script
183
184 • npm help config
185
186
187
188
189 October 2021 WORKSPACES(7)