74 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			74 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | --- | |||
|  | id: 587d7fb5367417b2b2512c01 | |||
|  | title: Manage npm Dependencies By Understanding Semantic Versioning | |||
|  | challengeType: 2 | |||
|  | forumTopicId: 301529 | |||
|  | dashedName: manage-npm-dependencies-by-understanding-semantic-versioning | |||
|  | --- | |||
|  | 
 | |||
|  | # --description--
 | |||
|  | 
 | |||
|  | `Versions` of the npm packages in the dependencies section of your package.json file follow what’s called Semantic Versioning (SemVer), an industry standard for software versioning aiming to make it easier to manage dependencies. Libraries, frameworks or other tools published on npm should use SemVer in order to clearly communicate what kind of changes projects can expect if they update. | |||
|  | 
 | |||
|  | Knowing SemVer can be useful when you develop software that uses external dependencies (which you almost always do). One day, your understanding of these numbers will save you from accidentally introducing breaking changes to your project without understanding why things that worked yesterday suddenly don’t work today. This is how Semantic Versioning works according to the official website: | |||
|  | 
 | |||
|  | ```json | |||
|  | "package": "MAJOR.MINOR.PATCH" | |||
|  | ``` | |||
|  | 
 | |||
|  | The MAJOR version should increment when you make incompatible API changes. The MINOR version should increment when you add functionality in a backwards-compatible manner. The PATCH version should increment when you make backwards-compatible bug fixes. This means that PATCHes are bug fixes and MINORs add new features but neither of them break what worked before. Finally, MAJORs add changes that won’t work with earlier versions. | |||
|  | 
 | |||
|  | # --instructions--
 | |||
|  | 
 | |||
|  | In the dependencies section of your package.json file, change the `version` of moment to match MAJOR version 2, MINOR version 10 and PATCH version 2 | |||
|  | 
 | |||
|  | # --hints--
 | |||
|  | 
 | |||
|  | "dependencies" should include "moment" | |||
|  | 
 | |||
|  | ```js | |||
|  | (getUserInput) => | |||
|  |   $.get(getUserInput('url') + '/_api/package.json').then( | |||
|  |     (data) => { | |||
|  |       var packJson = JSON.parse(data); | |||
|  |       assert.property( | |||
|  |         packJson.dependencies, | |||
|  |         'moment', | |||
|  |         '"dependencies" does not include "moment"' | |||
|  |       ); | |||
|  |     }, | |||
|  |     (xhr) => { | |||
|  |       throw new Error(xhr.responseText); | |||
|  |     } | |||
|  |   ); | |||
|  | ``` | |||
|  | 
 | |||
|  | "moment" version should be "2.10.2" | |||
|  | 
 | |||
|  | ```js | |||
|  | (getUserInput) => | |||
|  |   $.get(getUserInput('url') + '/_api/package.json').then( | |||
|  |     (data) => { | |||
|  |       var packJson = JSON.parse(data); | |||
|  |       assert.equal( | |||
|  |         packJson.dependencies.moment, | |||
|  |         '2.10.2', | |||
|  |         'Wrong version of "moment". It should be 2.10.2' | |||
|  |       ); | |||
|  |     }, | |||
|  |     (xhr) => { | |||
|  |       throw new Error(xhr.responseText); | |||
|  |     } | |||
|  |   ); | |||
|  | ``` | |||
|  | 
 | |||
|  | # --solutions--
 | |||
|  | 
 | |||
|  | ```js | |||
|  | /** | |||
|  |   Backend challenges don't need solutions,  | |||
|  |   because they would need to be tested against a full working project.  | |||
|  |   Please check our contributing guidelines to learn more. | |||
|  | */ | |||
|  | ``` |