mirror of
				https://github.com/actions/setup-go.git
				synced 2025-10-26 12:56:24 +00:00 
			
		
		
		
	mocked tests work with no internet
This commit is contained in:
		
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -20,7 +20,7 @@ describe('setup-go', () => { | |||||||
|   let archSpy: jest.SpyInstance; |   let archSpy: jest.SpyInstance; | ||||||
|   let dlSpy: jest.SpyInstance; |   let dlSpy: jest.SpyInstance; | ||||||
|   let exSpy: jest.SpyInstance; |   let exSpy: jest.SpyInstance; | ||||||
|   let http: httpm.HttpClient = new httpm.HttpClient('setup-go-tests'); |   //let http: httpm.HttpClient = new httpm.HttpClient('setup-go-tests'); | ||||||
|  |  | ||||||
|   beforeEach(() => { |   beforeEach(() => { | ||||||
|     tcSpy = jest.spyOn(tc, 'find'); |     tcSpy = jest.spyOn(tc, 'find'); | ||||||
| @@ -30,13 +30,7 @@ describe('setup-go', () => { | |||||||
|     archSpy = jest.spyOn(sys, 'getArch'); |     archSpy = jest.spyOn(sys, 'getArch'); | ||||||
|     dlSpy = jest.spyOn(tc, 'downloadTool'); |     dlSpy = jest.spyOn(tc, 'downloadTool'); | ||||||
|     exSpy = jest.spyOn(tc, 'extractTar'); |     exSpy = jest.spyOn(tc, 'extractTar'); | ||||||
|     getSpy = jest.spyOn(http, 'getJson'); |     getSpy = jest.spyOn(im, 'getVersions'); | ||||||
|     getSpy.mockImplementation( |  | ||||||
|       () => |  | ||||||
|         <ITypedResponse<im.IGoVersion[]>>{ |  | ||||||
|           result: goJsonData |  | ||||||
|         } |  | ||||||
|     ); |  | ||||||
|     cnSpy.mockImplementation(line => { |     cnSpy.mockImplementation(line => { | ||||||
|       // uncomment to debug |       // uncomment to debug | ||||||
|       //process.stderr.write('write2:' + line + '\n'); |       //process.stderr.write('write2:' + line + '\n'); | ||||||
| @@ -82,19 +76,21 @@ describe('setup-go', () => { | |||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('can mock go versions query', async () => { |   it('can mock go versions query', async () => { | ||||||
|     let r: ITypedResponse<im.IGoVersion[]> = await http.getJson< |     getSpy.mockImplementation( | ||||||
|       im.IGoVersion[] |       () => <im.IGoVersion[]>goJsonData | ||||||
|     >('https://asite.notexist.com/path'); |     ); | ||||||
|     expect(r).toBeDefined(); |     let versions: im.IGoVersion[] | null = await im.getVersions('https://non.existant.com/path'); | ||||||
|     let versions = r.result; |  | ||||||
|     expect(versions).toBeDefined(); |     expect(versions).toBeDefined(); | ||||||
|     let l: number = versions ? versions.length : 0; |     let l: number = versions ? versions.length : 0; | ||||||
|     expect(l).toBe(76); |     expect(l).toBe(91); | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   it('finds stable match for exact version', async () => { |   it('finds stable match for exact version', async () => { | ||||||
|     platSpy.mockImplementation(() => 'linux'); |     platSpy.mockImplementation(() => 'linux'); | ||||||
|     archSpy.mockImplementation(() => 'amd64'); |     archSpy.mockImplementation(() => 'amd64'); | ||||||
|  |     getSpy.mockImplementation( | ||||||
|  |       () => <im.IGoVersion[]>goJsonData | ||||||
|  |     ); | ||||||
|  |  | ||||||
|     // get request is already mocked |     // get request is already mocked | ||||||
|     // spec: 1.13.1 => 1.13.1 (exact) |     // spec: 1.13.1 => 1.13.1 (exact) | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								dist/index.js
									
									
									
									
										vendored
									
									
								
							| @@ -4558,7 +4558,7 @@ module.exports = require("fs"); | |||||||
| /***/ }), | /***/ }), | ||||||
|  |  | ||||||
| /***/ 749: | /***/ 749: | ||||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | /***/ (function(module, exports, __webpack_require__) { | ||||||
|  |  | ||||||
| "use strict"; | "use strict"; | ||||||
|  |  | ||||||
| @@ -4614,9 +4614,7 @@ function findMatch(versionSpec, stable) { | |||||||
|         let platFilter = sys.getPlatform(); |         let platFilter = sys.getPlatform(); | ||||||
|         let match; |         let match; | ||||||
|         const dlUrl = 'https://golang.org/dl/?mode=json&include=all'; |         const dlUrl = 'https://golang.org/dl/?mode=json&include=all'; | ||||||
|         // this returns versions descending so latest is first |         let candidates = yield module.exports.getVersions(dlUrl); | ||||||
|         let http = new httpm.HttpClient('setup-go'); |  | ||||||
|         let candidates = (yield http.getJson(dlUrl)).result; |  | ||||||
|         if (!candidates) { |         if (!candidates) { | ||||||
|             throw new Error(`golang download url did not return results: ${dlUrl}`); |             throw new Error(`golang download url did not return results: ${dlUrl}`); | ||||||
|         } |         } | ||||||
| @@ -4647,6 +4645,15 @@ function findMatch(versionSpec, stable) { | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| exports.findMatch = findMatch; | exports.findMatch = findMatch; | ||||||
|  | function getVersions(dlUrl) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         // this returns versions descending so latest is first | ||||||
|  |         let http = new httpm.HttpClient('setup-go'); | ||||||
|  |         let candidates = (yield http.getJson(dlUrl)).result; | ||||||
|  |         return candidates; | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.getVersions = getVersions; | ||||||
|  |  | ||||||
|  |  | ||||||
| /***/ }), | /***/ }), | ||||||
|   | |||||||
| @@ -56,14 +56,9 @@ export async function findMatch( | |||||||
|   let platFilter = sys.getPlatform(); |   let platFilter = sys.getPlatform(); | ||||||
|  |  | ||||||
|   let match: IGoVersion | undefined; |   let match: IGoVersion | undefined; | ||||||
|  |  | ||||||
|   const dlUrl: string = 'https://golang.org/dl/?mode=json&include=all'; |   const dlUrl: string = 'https://golang.org/dl/?mode=json&include=all'; | ||||||
|  |   let candidates: IGoVersion[] | null = await module.exports.getVersions(dlUrl); | ||||||
|   // this returns versions descending so latest is first |  | ||||||
|   let http: httpm.HttpClient = new httpm.HttpClient('setup-go'); |  | ||||||
|   let candidates: IGoVersion[] | null = (await http.getJson<IGoVersion[]>( |  | ||||||
|     dlUrl |  | ||||||
|   )).result; |  | ||||||
|  |  | ||||||
|   if (!candidates) { |   if (!candidates) { | ||||||
|     throw new Error(`golang download url did not return results: ${dlUrl}`); |     throw new Error(`golang download url did not return results: ${dlUrl}`); | ||||||
|   } |   } | ||||||
| @@ -98,3 +93,13 @@ export async function findMatch( | |||||||
|  |  | ||||||
|   return match; |   return match; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export async function getVersions(dlUrl: string): Promise<IGoVersion[] | null> { | ||||||
|  |   // this returns versions descending so latest is first | ||||||
|  |   let http: httpm.HttpClient = new httpm.HttpClient('setup-go');   | ||||||
|  |   let candidates: IGoVersion[] | null = (await http.getJson<IGoVersion[]>( | ||||||
|  |     dlUrl | ||||||
|  |   )).result; | ||||||
|  |  | ||||||
|  |   return candidates; | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user