NodeJS
New LTS NodeJS versions are released every 12 months and supported for three years. Moodle tries to ensure a compromise between support and churn by ensuring that the version of NodeJS in use is supported at all times.
Policy statement
NodeJS
- This policy will be applied to all supported branches, including stable and security-only releases.
- This policy does not require that any tool be updated, unless strictly needed by nodejs/npm or its own dependencies/changes
- It won't include npm audit changes either. Those are handled separately.
- Normally, only changes to
.nvmrc
andpackage.json
will happen. - Changes to project dependencies should be handled in a separate issue.
Project Dependencies
- To avoid impact to the community, dependency updates which impact built output should be kept to a minimum.
- Dependency updates should be backported to the first Major release in a Series, for example Moodle 5.0.
Upgrade guidelines
NodeJS
To update the NodeJS version required, the following approach is typically recommended:
-
Update the
.nvmrc
file to reflect thelts/[name]
of the new LTS version -
Update the
package.json
to set theengines
for the new restiction in the format:>= [new version] < [next version]
, for example:"engines": {
"node": ">=20.11.0 <21"
} -
Install the new NodeJS version:
nvm install && nvm use
-
Update the NodeJS dependencies with the new version of NodeJS:
rm -rf node_modules
npm install -
Verify the update:
npx grunt
npx grunt jsdoc
In most situations there will be no issues here and changes can be committed and backported to all stable and security-supported branches.
Troubleshooting
Where a project dependency is no longer supported due to the new version of NodeJS, it may be necessary to upgrade the dependency.
Project dependencies
The following tooling may be useful for the purposes of updating the project dependencies:
npm outdated
npm audit