| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | import SharedWorkspaceLocking from '../services/shared-workspace-locking'; | 
					
						
							|  |  |  | import { Cli } from '../../cli/cli'; | 
					
						
							|  |  |  | import setups from './cloud-runner-suite.test'; | 
					
						
							|  |  |  | import CloudRunnerLogger from '../services/cloud-runner-logger'; | 
					
						
							|  |  |  | import { v4 as uuidv4 } from 'uuid'; | 
					
						
							|  |  |  | import CloudRunnerOptions from '../cloud-runner-options'; | 
					
						
							|  |  |  | import UnityVersioning from '../../unity-versioning'; | 
					
						
							|  |  |  | import BuildParameters from '../../build-parameters'; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | import CloudRunner from '../cloud-runner'; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | async function CreateParameters(overrides) { | 
					
						
							|  |  |  |   if (overrides) { | 
					
						
							|  |  |  |     Cli.options = overrides; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return await BuildParameters.create(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('Cloud Runner Locking', () => { | 
					
						
							|  |  |  |   setups(); | 
					
						
							|  |  |  |   it('Responds', () => {}); | 
					
						
							|  |  |  |   if (CloudRunnerOptions.cloudRunnerDebug) { | 
					
						
							|  |  |  |     it(`Simple Locking Flow`, async () => { | 
					
						
							|  |  |  |       Cli.options.retainWorkspaces = true; | 
					
						
							|  |  |  |       const overrides: any = { | 
					
						
							|  |  |  |         versioning: 'None', | 
					
						
							|  |  |  |         projectPath: 'test-project', | 
					
						
							|  |  |  |         unityVersion: UnityVersioning.determineUnityVersion('test-project', UnityVersioning.read('test-project')), | 
					
						
							|  |  |  |         targetPlatform: 'StandaloneLinux64', | 
					
						
							|  |  |  |         cacheKey: `test-case-${uuidv4()}`, | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       const buildParameters = await CreateParameters(overrides); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const newWorkspaceName = `test-workspace-${uuidv4()}`; | 
					
						
							|  |  |  |       const runId = uuidv4(); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |       CloudRunner.buildParameters = buildParameters; | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       await SharedWorkspaceLocking.CreateWorkspace(newWorkspaceName, buildParameters); | 
					
						
							| 
									
										
										
										
											2023-02-12 02:39:04 +00:00
										 |  |  |       expect(SharedWorkspaceLocking.DoesCacheKeyTopLevelExist(buildParameters)).toBeTruthy(); | 
					
						
							|  |  |  |       expect(SharedWorkspaceLocking.DoesWorkspaceExist(newWorkspaceName, buildParameters)).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       const isExpectedUnlockedBeforeLocking = | 
					
						
							|  |  |  |         (await SharedWorkspaceLocking.IsWorkspaceLocked(newWorkspaceName, buildParameters)) === false; | 
					
						
							|  |  |  |       expect(isExpectedUnlockedBeforeLocking).toBeTruthy(); | 
					
						
							|  |  |  |       await SharedWorkspaceLocking.LockWorkspace(newWorkspaceName, runId, buildParameters); | 
					
						
							| 
									
										
										
										
											2023-02-12 05:23:36 +00:00
										 |  |  |       const lines = await SharedWorkspaceLocking.ReadLines(`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}`); | 
					
						
							|  |  |  |       expect(lines.map((x) => x.replace(`/`, ``)).includes(buildParameters.cacheKey)); | 
					
						
							| 
									
										
										
										
											2023-02-12 04:26:31 +00:00
										 |  |  |       expect(await SharedWorkspaceLocking.DoesCacheKeyTopLevelExist(buildParameters)).toBeTruthy(); | 
					
						
							|  |  |  |       expect(await SharedWorkspaceLocking.DoesWorkspaceExist(newWorkspaceName, buildParameters)).toBeTruthy(); | 
					
						
							| 
									
										
										
										
											2023-02-12 04:22:01 +00:00
										 |  |  |       const allLocks = await SharedWorkspaceLocking.GetAllLocks(newWorkspaceName, buildParameters); | 
					
						
							|  |  |  |       expect( | 
					
						
							| 
									
										
										
										
											2023-02-12 03:34:34 +00:00
										 |  |  |         ( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.ReadLines( | 
					
						
							|  |  |  |             `aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParameters.cacheKey}/`, | 
					
						
							|  |  |  |           ) | 
					
						
							| 
									
										
										
										
											2023-02-12 05:35:20 +00:00
										 |  |  |         ).filter((x) => x.includes(`${newWorkspaceName}_lock`)).length, | 
					
						
							| 
									
										
										
										
											2023-02-12 04:22:01 +00:00
										 |  |  |       ).toBeGreaterThan(0); | 
					
						
							|  |  |  |       expect( | 
					
						
							|  |  |  |         ( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.ReadLines( | 
					
						
							|  |  |  |             `aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParameters.cacheKey}/`, | 
					
						
							|  |  |  |           ) | 
					
						
							| 
									
										
										
										
											2023-02-12 05:35:20 +00:00
										 |  |  |         ).filter((x) => x.includes(`${newWorkspaceName}_workspace`)).length, | 
					
						
							| 
									
										
										
										
											2023-02-12 04:22:01 +00:00
										 |  |  |       ).toBeGreaterThan(0); | 
					
						
							| 
									
										
										
										
											2023-02-12 05:35:20 +00:00
										 |  |  |       expect(allLocks.filter((x) => x.includes(`${newWorkspaceName}_lock`)).length).toBeGreaterThan(0); | 
					
						
							| 
									
										
										
										
											2022-11-07 20:41:00 +00:00
										 |  |  |       const isExpectedLockedAfterLocking = | 
					
						
							|  |  |  |         (await SharedWorkspaceLocking.IsWorkspaceLocked(newWorkspaceName, buildParameters)) === true; | 
					
						
							|  |  |  |       expect(isExpectedLockedAfterLocking).toBeTruthy(); | 
					
						
							|  |  |  |       const locksBeforeRelease = await SharedWorkspaceLocking.GetAllLocks(newWorkspaceName, buildParameters); | 
					
						
							|  |  |  |       CloudRunnerLogger.log(JSON.stringify(locksBeforeRelease, undefined, 4)); | 
					
						
							|  |  |  |       expect(locksBeforeRelease.length).toBe(1); | 
					
						
							|  |  |  |       await SharedWorkspaceLocking.ReleaseWorkspace(newWorkspaceName, runId, buildParameters); | 
					
						
							|  |  |  |       const locks = await SharedWorkspaceLocking.GetAllLocks(newWorkspaceName, buildParameters); | 
					
						
							|  |  |  |       expect(locks.length).toBe(0); | 
					
						
							|  |  |  |       const isExpectedLockedAfterReleasing = | 
					
						
							|  |  |  |         (await SharedWorkspaceLocking.IsWorkspaceLocked(newWorkspaceName, buildParameters)) === false; | 
					
						
							|  |  |  |       expect(isExpectedLockedAfterReleasing).toBeTruthy(); | 
					
						
							|  |  |  |     }, 150000); | 
					
						
							|  |  |  |     it.skip('All Locking Actions', async () => { | 
					
						
							|  |  |  |       Cli.options.retainWorkspaces = true; | 
					
						
							|  |  |  |       const overrides: any = { | 
					
						
							|  |  |  |         versioning: 'None', | 
					
						
							|  |  |  |         projectPath: 'test-project', | 
					
						
							|  |  |  |         unityVersion: UnityVersioning.determineUnityVersion('test-project', UnityVersioning.read('test-project')), | 
					
						
							|  |  |  |         targetPlatform: 'StandaloneLinux64', | 
					
						
							|  |  |  |         cacheKey: `test-case-${uuidv4()}`, | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       const buildParameters = await CreateParameters(overrides); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `GetAllWorkspaces ${JSON.stringify(await SharedWorkspaceLocking.GetAllWorkspaces(buildParameters))}`, | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `GetFreeWorkspaces ${JSON.stringify(await SharedWorkspaceLocking.GetFreeWorkspaces(buildParameters))}`, | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `IsWorkspaceLocked ${JSON.stringify( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.IsWorkspaceLocked(`test-workspace-${uuidv4()}`, buildParameters), | 
					
						
							|  |  |  |         )}`,
 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `GetFreeWorkspaces ${JSON.stringify(await SharedWorkspaceLocking.GetFreeWorkspaces(buildParameters))}`, | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `LockWorkspace ${JSON.stringify( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.LockWorkspace(`test-workspace-${uuidv4()}`, uuidv4(), buildParameters), | 
					
						
							|  |  |  |         )}`,
 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `CreateLockableWorkspace ${JSON.stringify( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.CreateWorkspace(`test-workspace-${uuidv4()}`, buildParameters), | 
					
						
							|  |  |  |         )}`,
 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       CloudRunnerLogger.log( | 
					
						
							|  |  |  |         `GetLockedWorkspace ${JSON.stringify( | 
					
						
							|  |  |  |           await SharedWorkspaceLocking.GetOrCreateLockedWorkspace( | 
					
						
							|  |  |  |             `test-workspace-${uuidv4()}`, | 
					
						
							|  |  |  |             uuidv4(), | 
					
						
							|  |  |  |             buildParameters, | 
					
						
							|  |  |  |           ), | 
					
						
							|  |  |  |         )}`,
 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }, 3000000); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }); |