| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | import BuildParameters from '../../../build-parameters'; | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  | import CloudRunnerEnvironmentVariable from '../../options/cloud-runner-environment-variable'; | 
					
						
							|  |  |  | import CloudRunnerLogger from '../../services/core/cloud-runner-logger'; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | import { ProviderInterface } from '../provider-interface'; | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  | import CloudRunnerSecret from '../../options/cloud-runner-secret'; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | import Docker from '../../../docker'; | 
					
						
							|  |  |  | import { Action } from '../../..'; | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  | import { writeFileSync } from 'node:fs'; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | import CloudRunner from '../../cloud-runner'; | 
					
						
							|  |  |  | import { ProviderResource } from '../provider-resource'; | 
					
						
							|  |  |  | import { ProviderWorkflow } from '../provider-workflow'; | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  | import { CloudRunnerSystem } from '../../services/core/cloud-runner-system'; | 
					
						
							|  |  |  | import * as fs from 'node:fs'; | 
					
						
							|  |  |  | import { CommandHookService } from '../../services/hooks/command-hook-service'; | 
					
						
							| 
									
										
										
										
											2023-03-04 00:25:40 +00:00
										 |  |  | import { StringKeyValuePair } from '../../../shared-types'; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | class LocalDockerCloudRunner implements ProviderInterface { | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  |   public buildParameters!: BuildParameters; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   listResources(): Promise<ProviderResource[]> { | 
					
						
							|  |  |  |     return new Promise((resolve) => resolve([])); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   listWorkflow(): Promise<ProviderWorkflow[]> { | 
					
						
							|  |  |  |     throw new Error('Method not implemented.'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   watchWorkflow(): Promise<string> { | 
					
						
							|  |  |  |     throw new Error('Method not implemented.'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   garbageCollect( | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     filter: string, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     previewOnly: boolean, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     olderThan: Number, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     fullCache: boolean, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     baseDependencies: boolean, | 
					
						
							|  |  |  |   ): Promise<string> { | 
					
						
							|  |  |  |     return new Promise((result) => result(``)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   async cleanupWorkflow( | 
					
						
							|  |  |  |     buildGuid: string, | 
					
						
							|  |  |  |     buildParameters: BuildParameters, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     branchName: string, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     defaultSecretsArray: { ParameterKey: string; EnvironmentVariable: string; ParameterValue: string }[], | 
					
						
							|  |  |  |   ) { | 
					
						
							|  |  |  |     const { workspace } = Action; | 
					
						
							| 
									
										
											  
											
												Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
											
										 
											2023-01-20 17:40:57 +00:00
										 |  |  |     if ( | 
					
						
							|  |  |  |       fs.existsSync( | 
					
						
							|  |  |  |         `${workspace}/cloud-runner-cache/cache/build/build-${buildParameters.buildGuid}.tar${ | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  |           CloudRunner.buildParameters.useCompressionStrategy ? '.lz4' : '' | 
					
						
							| 
									
										
											  
											
												Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
											
										 
											2023-01-20 17:40:57 +00:00
										 |  |  |         }`,
 | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       await CloudRunnerSystem.Run(`ls ${workspace}/cloud-runner-cache/cache/build/`); | 
					
						
							|  |  |  |       await CloudRunnerSystem.Run( | 
					
						
							| 
									
										
											  
											
												Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
											
										 
											2023-01-20 17:40:57 +00:00
										 |  |  |         `rm -r ${workspace}/cloud-runner-cache/cache/build/build-${buildParameters.buildGuid}.tar${ | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  |           CloudRunner.buildParameters.useCompressionStrategy ? '.lz4' : '' | 
					
						
							| 
									
										
											  
											
												Cloud runner develop - better parameterization of s3 usage, improved async workflow and GC, github checks early integration (#479)
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* custom steps may leave value undefined, will be pulled from env vars
* add 3 new premade steps, steam-deploy-client, steam-deploy-project, aws-s3-pull-build
* fix
* fix
* fix
* continue building async-workflow support
* test checks
* test checks
* test checks
* move github checks within build workflow
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* async workflow test for aws only
* cleanup logging
* disable lz4 compression by default
* disable lz4 compression by default
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* AWS BASE STACK for tests
* disable lz4 compression by default
* disable lz4 compression by default
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* Update github check with aws log
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* kinesis and subscription filter for logs creation skipped when watchToEnd false
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* cleanup local pipeline, log aws formation
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* async pipeline
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* workflow
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
* parameterize s3
											
										 
											2023-01-20 17:40:57 +00:00
										 |  |  |         }`,
 | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   setupWorkflow( | 
					
						
							|  |  |  |     buildGuid: string, | 
					
						
							|  |  |  |     buildParameters: BuildParameters, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     branchName: string, | 
					
						
							|  |  |  |     // eslint-disable-next-line no-unused-vars
 | 
					
						
							|  |  |  |     defaultSecretsArray: { ParameterKey: string; EnvironmentVariable: string; ParameterValue: string }[], | 
					
						
							|  |  |  |   ) { | 
					
						
							|  |  |  |     this.buildParameters = buildParameters; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public async runTaskInWorkflow( | 
					
						
							|  |  |  |     buildGuid: string, | 
					
						
							|  |  |  |     image: string, | 
					
						
							|  |  |  |     commands: string, | 
					
						
							|  |  |  |     mountdir: string, | 
					
						
							|  |  |  |     workingdir: string, | 
					
						
							|  |  |  |     environment: CloudRunnerEnvironmentVariable[], | 
					
						
							|  |  |  |     secrets: CloudRunnerSecret[], | 
					
						
							|  |  |  |   ): Promise<string> { | 
					
						
							|  |  |  |     CloudRunnerLogger.log(buildGuid); | 
					
						
							|  |  |  |     CloudRunnerLogger.log(commands); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const { workspace, actionFolder } = Action; | 
					
						
							| 
									
										
										
										
											2023-03-04 00:25:40 +00:00
										 |  |  |     const content: StringKeyValuePair[] = []; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |     for (const x of secrets) { | 
					
						
							|  |  |  |       content.push({ name: x.EnvironmentVariable, value: x.ParameterValue }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     for (const x of environment) { | 
					
						
							|  |  |  |       content.push({ name: x.name, value: x.value }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // if (this.buildParameters?.cloudRunnerIntegrationTests) {
 | 
					
						
							|  |  |  |     //   core.info(JSON.stringify(content, undefined, 4));
 | 
					
						
							|  |  |  |     //   core.info(JSON.stringify(secrets, undefined, 4));
 | 
					
						
							|  |  |  |     //   core.info(JSON.stringify(environment, undefined, 4));
 | 
					
						
							|  |  |  |     // }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // eslint-disable-next-line unicorn/no-for-loop
 | 
					
						
							|  |  |  |     for (let index = 0; index < content.length; index++) { | 
					
						
							|  |  |  |       if (content[index] === undefined) { | 
					
						
							|  |  |  |         delete content[index]; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     let myOutput = ''; | 
					
						
							|  |  |  |     const sharedFolder = `/data/`; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // core.info(JSON.stringify({ workspace, actionFolder, ...this.buildParameters, ...content }, undefined, 4));
 | 
					
						
							|  |  |  |     const entrypointFilePath = `start.sh`; | 
					
						
							|  |  |  |     const fileContents = `#!/bin/bash
 | 
					
						
							|  |  |  | set -e | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | mkdir -p /github/workspace/cloud-runner-cache | 
					
						
							|  |  |  | mkdir -p /data/cache | 
					
						
							|  |  |  | cp -a /github/workspace/cloud-runner-cache/. ${sharedFolder} | 
					
						
							| 
									
										
										
										
											2023-03-27 11:14:23 +00:00
										 |  |  | ${CommandHookService.ApplyHooksToCommands(commands, this.buildParameters)} | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | cp -a ${sharedFolder}. /github/workspace/cloud-runner-cache/ | 
					
						
							|  |  |  | `;
 | 
					
						
							|  |  |  |     writeFileSync(`${workspace}/${entrypointFilePath}`, fileContents, { | 
					
						
							|  |  |  |       flag: 'w', | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (CloudRunner.buildParameters.cloudRunnerDebug) { | 
					
						
							|  |  |  |       CloudRunnerLogger.log(`Running local-docker: \n ${fileContents}`); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (fs.existsSync(`${workspace}/cloud-runner-cache`)) { | 
					
						
							|  |  |  |       await CloudRunnerSystem.Run(`ls ${workspace}/cloud-runner-cache && du -sh ${workspace}/cloud-runner-cache`); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-11-28 07:24:58 +00:00
										 |  |  |     const exitCode = await Docker.run( | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       image, | 
					
						
							|  |  |  |       { workspace, actionFolder, ...this.buildParameters }, | 
					
						
							|  |  |  |       false, | 
					
						
							|  |  |  |       `chmod +x /github/workspace/${entrypointFilePath} && /github/workspace/${entrypointFilePath}`, | 
					
						
							|  |  |  |       content, | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         listeners: { | 
					
						
							|  |  |  |           stdout: (data: Buffer) => { | 
					
						
							|  |  |  |             myOutput += data.toString(); | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           stderr: (data: Buffer) => { | 
					
						
							|  |  |  |             myOutput += `[LOCAL-DOCKER-ERROR]${data.toString()}`; | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       true, | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-28 07:24:58 +00:00
										 |  |  |     // Docker doesn't exit on fail now so adding this to ensure behavior is unchanged
 | 
					
						
							|  |  |  |     // TODO: Is there a helpful way to consume the exit code or is it best to except
 | 
					
						
							|  |  |  |     if (exitCode !== 0) { | 
					
						
							|  |  |  |       throw new Error(`Build failed with exit code ${exitCode}`); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |     return myOutput; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | export default LocalDockerCloudRunner; |