fix: exclude prereleases from version retrived by getLastRelease
				
					
				
			This commit is contained in:
		
							parent
							
								
									e5a73d8628
								
							
						
					
					
						commit
						e4618a2fbc
					
				| @ -33,7 +33,9 @@ module.exports = async (tagFormat, logger) => { | |||||||
|     .map(tag => { |     .map(tag => { | ||||||
|       return {gitTag: tag, version: (tag.match(tagRegexp) || new Array(2))[1]}; |       return {gitTag: tag, version: (tag.match(tagRegexp) || new Array(2))[1]}; | ||||||
|     }) |     }) | ||||||
|     .filter(tag => tag.version && semver.valid(semver.clean(tag.version))) |     .filter( | ||||||
|  |       tag => tag.version && semver.valid(semver.clean(tag.version)) && !semver.prerelease(semver.clean(tag.version)) | ||||||
|  |     ) | ||||||
|     .sort((a, b) => semver.rcompare(a.version, b.version)); |     .sort((a, b) => semver.rcompare(a.version, b.version)); | ||||||
| 
 | 
 | ||||||
|   debug('found tags: %o', tags); |   debug('found tags: %o', tags); | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ test.afterEach.always(() => { | |||||||
|   process.chdir(cwd); |   process.chdir(cwd); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| test.serial('Get the highest valid tag', async t => { | test.serial('Get the highest non-prerelease valid tag', async t => { | ||||||
|   // Create a git repository, set the current working directory at the root of the repo
 |   // Create a git repository, set the current working directory at the root of the repo
 | ||||||
|   await gitRepo(); |   await gitRepo(); | ||||||
|   // Create some commits and tags
 |   // Create some commits and tags
 | ||||||
| @ -29,6 +29,8 @@ test.serial('Get the highest valid tag', async t => { | |||||||
|   await gitTagVersion('v1.0.0'); |   await gitTagVersion('v1.0.0'); | ||||||
|   await gitCommits(['Fourth']); |   await gitCommits(['Fourth']); | ||||||
|   await gitTagVersion('v3.0'); |   await gitTagVersion('v3.0'); | ||||||
|  |   await gitCommits(['Fifth']); | ||||||
|  |   await gitTagVersion('v3.0.0-beta.1'); | ||||||
| 
 | 
 | ||||||
|   const result = await getLastRelease(`v\${version}`, t.context.logger); |   const result = await getLastRelease(`v\${version}`, t.context.logger); | ||||||
| 
 | 
 | ||||||
| @ -117,4 +119,11 @@ test.serial('Get the highest valid tag corresponding to the "tagFormat"', async | |||||||
|     gitTag: '2.0.0-1.0.0-bar.1', |     gitTag: '2.0.0-1.0.0-bar.1', | ||||||
|     version: '1.0.0', |     version: '1.0.0', | ||||||
|   }); |   }); | ||||||
|  | 
 | ||||||
|  |   await gitTagVersion('3.0.0-bar.1'); | ||||||
|  |   t.deepEqual(await getLastRelease(`\${version}-bar.1`, t.context.logger), { | ||||||
|  |     gitHead, | ||||||
|  |     gitTag: '3.0.0-bar.1', | ||||||
|  |     version: '3.0.0', | ||||||
|  |   }); | ||||||
| }); | }); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user