| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  | import CloudRunner from '../cloud-runner'; | 
					
						
							|  |  |  | import { BuildParameters, ImageTag } from '../..'; | 
					
						
							|  |  |  | import UnityVersioning from '../../unity-versioning'; | 
					
						
							|  |  |  | import { Cli } from '../../cli/cli'; | 
					
						
							|  |  |  | import CloudRunnerLogger from '../services/cloud-runner-logger'; | 
					
						
							|  |  |  | import { v4 as uuidv4 } from 'uuid'; | 
					
						
							|  |  |  | import CloudRunnerOptions from '../cloud-runner-options'; | 
					
						
							|  |  |  | import setups from './cloud-runner-suite.test'; | 
					
						
							| 
									
										
										
										
											2022-10-08 01:29:11 +00:00
										 |  |  | import { CloudRunnerCustomSteps } from '../services/cloud-runner-custom-steps'; | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | async function CreateParameters(overrides) { | 
					
						
							|  |  |  |   if (overrides) { | 
					
						
							|  |  |  |     Cli.options = overrides; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return await BuildParameters.create(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-08 01:52:44 +00:00
										 |  |  | describe('Cloud Runner Custom Hooks And Steps', () => { | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  |   it('Responds', () => {}); | 
					
						
							|  |  |  |   setups(); | 
					
						
							| 
									
										
										
										
											2022-10-08 01:52:44 +00:00
										 |  |  |   it('Check parsing and reading of steps', async () => { | 
					
						
							| 
									
										
										
										
											2022-10-08 01:50:58 +00:00
										 |  |  |     const yamlString = `hook: before
 | 
					
						
							|  |  |  | commands: echo "test"`;
 | 
					
						
							| 
									
										
										
										
											2022-10-08 04:49:38 +00:00
										 |  |  |     const yamlString2 = `- hook: before
 | 
					
						
							|  |  |  |   commands: echo "test"`;
 | 
					
						
							| 
									
										
										
										
											2022-10-08 01:50:58 +00:00
										 |  |  |     const stringObject = CloudRunnerCustomSteps.ParseSteps(yamlString); | 
					
						
							| 
									
										
										
										
											2022-10-08 04:49:38 +00:00
										 |  |  |     const stringObject2 = CloudRunnerCustomSteps.ParseSteps(yamlString2); | 
					
						
							| 
									
										
										
										
											2022-10-13 19:14:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-08 01:50:58 +00:00
										 |  |  |     CloudRunnerLogger.log(yamlString); | 
					
						
							|  |  |  |     CloudRunnerLogger.log(JSON.stringify(stringObject, undefined, 4)); | 
					
						
							| 
									
										
										
										
											2022-10-13 19:14:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-08 01:50:58 +00:00
										 |  |  |     expect(stringObject.length).toBe(1); | 
					
						
							|  |  |  |     expect(stringObject[0].hook).toBe(`before`); | 
					
						
							| 
									
										
										
										
											2022-10-08 04:49:38 +00:00
										 |  |  |     expect(stringObject2.length).toBe(1); | 
					
						
							|  |  |  |     expect(stringObject2[0].hook).toBe(`before`); | 
					
						
							| 
									
										
										
										
											2022-10-13 19:14:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     const getCustomStepsFromFiles = CloudRunnerCustomSteps.GetCustomStepsFromFiles(`before`); | 
					
						
							|  |  |  |     CloudRunnerLogger.log(JSON.stringify(getCustomStepsFromFiles, undefined, 4)); | 
					
						
							| 
									
										
										
										
											2022-10-08 01:29:11 +00:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2022-10-13 17:54:25 +00:00
										 |  |  |   if (CloudRunnerOptions.cloudRunnerDebug && CloudRunnerOptions.cloudRunnerCluster !== `k8s`) { | 
					
						
							| 
									
										
										
										
											2022-10-08 01:52:44 +00:00
										 |  |  |     it('Run build once - check for pre and post custom hooks run contents', async () => { | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  |       const overrides = { | 
					
						
							|  |  |  |         versioning: 'None', | 
					
						
							|  |  |  |         projectPath: 'test-project', | 
					
						
							|  |  |  |         unityVersion: UnityVersioning.determineUnityVersion('test-project', UnityVersioning.read('test-project')), | 
					
						
							|  |  |  |         targetPlatform: 'StandaloneLinux64', | 
					
						
							|  |  |  |         cacheKey: `test-case-${uuidv4()}`, | 
					
						
							| 
									
										
										
										
											2022-10-13 18:13:09 +00:00
										 |  |  |         customStepFiles: `my-test-step-pre-build,my-test-step-post-build`, | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  |       }; | 
					
						
							|  |  |  |       const buildParameter2 = await CreateParameters(overrides); | 
					
						
							|  |  |  |       const baseImage2 = new ImageTag(buildParameter2); | 
					
						
							|  |  |  |       const results2 = await CloudRunner.run(buildParameter2, baseImage2.toString()); | 
					
						
							|  |  |  |       CloudRunnerLogger.log(`run 2 succeeded`); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const build2ContainsBuildSucceeded = results2.includes('Build succeeded'); | 
					
						
							| 
									
										
										
										
											2022-10-07 23:32:52 +00:00
										 |  |  |       const build2ContainsPreBuildHookRunMessage = results2.includes('before-build hook test!'); | 
					
						
							|  |  |  |       const build2ContainsPostBuildHookRunMessage = results2.includes('after-build hook test!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const build2ContainsPreBuildStepMessage = results2.includes('before-build step test!'); | 
					
						
							|  |  |  |       const build2ContainsPostBuildStepMessage = results2.includes('after-build step test!'); | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       expect(build2ContainsBuildSucceeded).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2022-10-07 00:33:07 +00:00
										 |  |  |       expect(build2ContainsPreBuildHookRunMessage).toBeTruthy(); | 
					
						
							|  |  |  |       expect(build2ContainsPostBuildHookRunMessage).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2022-10-07 23:32:52 +00:00
										 |  |  |       expect(build2ContainsPreBuildStepMessage).toBeTruthy(); | 
					
						
							|  |  |  |       expect(build2ContainsPostBuildStepMessage).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2022-10-22 17:47:26 +00:00
										 |  |  |     }, 1_000_000_000_000); | 
					
						
							| 
									
										
										
										
											2022-10-06 19:42:33 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | }); |