Issue
After upgrading to NodeJS Plugin version 1.3.0, jobs will start to fail with this stacktrace:
java.lang.NullPointerException at jenkins.plugins.nodejs.NodeJSBuildWrapper.setUp(NodeJSBuildWrapper.java:166) at jenkins.tasks.SimpleBuildWrapper.setUp(SimpleBuildWrapper.java:146) at hudson.maven.MavenModuleSetBuild$MavenModuleSetBuildExecution.doRun(MavenModuleSetBuild.java:667) at hudson.model.AbstractBuild$AbstractBuildExecution.run(AbstractBuild.java:504) at hudson.model.Run.execute(Run.java:1818) at hudson.maven.MavenModuleSetBuild.run(MavenModuleSetBuild.java:543) at hudson.model.ResourceController.execute(ResourceController.java:97) at hudson.model.Executor.run(Executor.java:429)
The plugin introduced cache locator strategy and also guarantees that cache locator strategy cannot be null both after calling the constructor and calling the appropriate setter method. But that applies only if we create a new job or change the configuration for nodejs for an existing job, using nodejs-plugin 1.3.0. But if you have an existing job, which was created before nodejs-plugin 1.3.0, it is missing the configuration for cache locator strategy.
This will affect all jobs using this plugin after upgrade to 1.3.0.
Environment
- 
CloudBees CI (CloudBees Core) on modern cloud platforms - Managed controller 
- 
CloudBees CI (CloudBees Core) on modern cloud platforms - Operations Center 
- 
CloudBees CI (CloudBees Core) on traditional platforms - Client controller 
- 
CloudBees CI (CloudBees Core) on traditional platforms - Operations Center 
- 
CloudBees Jenkins Enterprise 
- 
CloudBees Jenkins Enterprise - Managed controller 
- 
CloudBees Jenkins Enterprise - Operations center 
Workaround
Open up the job configuration for an effected job, save the configuration again to force the update of the cache location strategy.
New jobs are not affected by this.