include e2e builder launch time the `complete` request payload (#9)
							parent
							
								
									828fa88525
								
							
						
					
					
						commit
						cb07435230
					
				
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										10
									
								
								src/main.ts
								
								
								
								
							
							
						
						
									
										10
									
								
								src/main.ts
								
								
								
								
							|  | @ -33,9 +33,11 @@ async function getBlacksmithHttpClient(): Promise<AxiosInstance> { | ||||||
| 
 | 
 | ||||||
| async function reportBuildCompleted() { | async function reportBuildCompleted() { | ||||||
|   try { |   try { | ||||||
|  |     const builderLaunchTime = stateHelper.blacksmithBuilderLaunchTime; | ||||||
|     const client = await getBlacksmithHttpClient(); |     const client = await getBlacksmithHttpClient(); | ||||||
|     const response = await client.post(`/${stateHelper.blacksmithBuildTaskId}/complete`); |     client.post(`/${stateHelper.blacksmithBuildTaskId}/complete`, { | ||||||
|     core.info(`Blacksmith builder ${stateHelper.blacksmithBuildTaskId} completed: ${JSON.stringify(response.data)}`); |       builder_launch_time: builderLaunchTime | ||||||
|  |     }); | ||||||
|   } catch (error) { |   } catch (error) { | ||||||
|     core.warning('Error completing Blacksmith build:', error); |     core.warning('Error completing Blacksmith build:', error); | ||||||
|     throw error; |     throw error; | ||||||
|  | @ -78,7 +80,6 @@ async function getRemoteBuilderAddr(inputs: context.Inputs): Promise<string | nu | ||||||
|       payload = {dockerfile_path: dockerfilePath}; |       payload = {dockerfile_path: dockerfilePath}; | ||||||
|       core.info(`Using dockerfile path: ${dockerfilePath}`); |       core.info(`Using dockerfile path: ${dockerfilePath}`); | ||||||
|     } |     } | ||||||
|     core.info(`Anvil service: ${client.defaults.baseURL}`); |  | ||||||
|     let response; |     let response; | ||||||
|     let retries = 0; |     let retries = 0; | ||||||
|     const maxRetries = 10; |     const maxRetries = 10; | ||||||
|  | @ -117,9 +118,8 @@ async function getRemoteBuilderAddr(inputs: context.Inputs): Promise<string | nu | ||||||
|       if (ec2Instance) { |       if (ec2Instance) { | ||||||
|         const elapsedTime = ((Date.now() - startTime) / 1000).toFixed(2); |         const elapsedTime = ((Date.now() - startTime) / 1000).toFixed(2); | ||||||
|         core.info(`Blacksmith builder agent ready after ${elapsedTime} seconds`); |         core.info(`Blacksmith builder agent ready after ${elapsedTime} seconds`); | ||||||
|  |         stateHelper.setBlacksmithBuilderLaunchTime(elapsedTime); | ||||||
|         return `tcp://${ec2Instance['instance_ip']}:4242` as string; |         return `tcp://${ec2Instance['instance_ip']}:4242` as string; | ||||||
|       } else { |  | ||||||
|         core.info(`Waiting...`); |  | ||||||
|       } |       } | ||||||
|       await new Promise(resolve => setTimeout(resolve, 200)); |       await new Promise(resolve => setTimeout(resolve, 200)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| 
 | 
 | ||||||
| import { Inputs, sanitizeInputs } from './context'; | import {Inputs, sanitizeInputs} from './context'; | ||||||
| 
 | 
 | ||||||
| export const tmpDir = process.env['STATE_tmpDir'] || ''; | export const tmpDir = process.env['STATE_tmpDir'] || ''; | ||||||
| export const inputs = process.env['STATE_inputs'] ? JSON.parse(process.env['STATE_inputs']) : undefined; | export const inputs = process.env['STATE_inputs'] ? JSON.parse(process.env['STATE_inputs']) : undefined; | ||||||
|  | @ -11,6 +11,7 @@ export const blacksmithClientKey = process.env['STATE_blacksmithClientKey'] || ' | ||||||
| export const blacksmithClientCaCertificate = process.env['STATE_blacksmithClientCaCertificate'] || ''; | export const blacksmithClientCaCertificate = process.env['STATE_blacksmithClientCaCertificate'] || ''; | ||||||
| export const blacksmithRootCaCertificate = process.env['STATE_blacksmithRootCaCertificate'] || ''; | export const blacksmithRootCaCertificate = process.env['STATE_blacksmithRootCaCertificate'] || ''; | ||||||
| export const remoteDockerBuildStatus = process.env['STATE_remoteDockerBuildStatus'] || ''; | export const remoteDockerBuildStatus = process.env['STATE_remoteDockerBuildStatus'] || ''; | ||||||
|  | export const blacksmithBuilderLaunchTime = process.env['STATE_blacksmithBuilderLaunchTime'] || ''; | ||||||
| 
 | 
 | ||||||
| export function setTmpDir(tmpDir: string) { | export function setTmpDir(tmpDir: string) { | ||||||
|   core.saveState('tmpDir', tmpDir); |   core.saveState('tmpDir', tmpDir); | ||||||
|  | @ -32,6 +33,11 @@ export function setBlacksmithBuildTaskId(blacksmithBuildTaskId: string) { | ||||||
|   core.saveState('blacksmithBuildTaskId', blacksmithBuildTaskId); |   core.saveState('blacksmithBuildTaskId', blacksmithBuildTaskId); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // setBlacksmithBuilderLaunchTime sets the time (in seconds) it took to launch the Blacksmith builder
 | ||||||
|  | export function setBlacksmithBuilderLaunchTime(blacksmithBuilderLaunchTime: string) { | ||||||
|  |   core.saveState('blacksmithBuilderLaunchTime', blacksmithBuilderLaunchTime); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export function setBlacksmithClientKey(blacksmithClientKey: string) { | export function setBlacksmithClientKey(blacksmithClientKey: string) { | ||||||
|   core.saveState('blacksmithClientKey', blacksmithClientKey); |   core.saveState('blacksmithClientKey', blacksmithClientKey); | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue