2022-11-07 20:41:00 +00:00
|
|
|
import { CloudRunnerSystem } from './cloud-runner-system';
|
|
|
|
import * as fs from 'fs';
|
|
|
|
import CloudRunnerLogger from './cloud-runner-logger';
|
|
|
|
import CloudRunnerOptions from '../cloud-runner-options';
|
|
|
|
import BuildParameters from '../../build-parameters';
|
|
|
|
import CloudRunner from '../cloud-runner';
|
|
|
|
export class SharedWorkspaceLocking {
|
2023-02-12 03:34:34 +00:00
|
|
|
public static get workspaceBucketRoot() {
|
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
|
|
|
return `s3://${CloudRunner.buildParameters.awsBaseStackName}/`;
|
|
|
|
}
|
2023-02-12 03:34:34 +00:00
|
|
|
public static get workspaceRoot() {
|
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
|
|
|
return `${SharedWorkspaceLocking.workspaceBucketRoot}locks/`;
|
|
|
|
}
|
2022-11-07 20:41:00 +00:00
|
|
|
public static async GetAllWorkspaces(buildParametersContext: BuildParameters): Promise<string[]> {
|
2023-02-10 05:34:37 +00:00
|
|
|
if (!(await SharedWorkspaceLocking.DoesCacheKeyTopLevelExist(buildParametersContext))) {
|
2022-11-07 20:41:00 +00:00
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
await SharedWorkspaceLocking.ReadLines(
|
|
|
|
`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/`,
|
|
|
|
)
|
2023-02-10 05:29:15 +00:00
|
|
|
)
|
|
|
|
.map((x) => x.replace(`/`, ``))
|
2023-02-18 22:57:00 +00:00
|
|
|
.filter((x) => x.endsWith(`_workspace`))
|
2023-02-19 00:47:35 +00:00
|
|
|
.map((x) => x.split(`_`)[1]);
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
2023-02-10 05:34:37 +00:00
|
|
|
public static async DoesCacheKeyTopLevelExist(buildParametersContext: BuildParameters) {
|
2023-02-19 14:19:37 +00:00
|
|
|
const rootLines = await SharedWorkspaceLocking.ReadLines(`aws s3 ls ${SharedWorkspaceLocking.workspaceBucketRoot}`);
|
2023-02-12 05:23:36 +00:00
|
|
|
const lines = await SharedWorkspaceLocking.ReadLines(`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}`);
|
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
|
|
|
|
2023-02-19 14:19:37 +00:00
|
|
|
return (
|
|
|
|
rootLines.map((x) => x.replace(`/`, ``)).includes(`locks`) &&
|
|
|
|
lines.map((x) => x.replace(`/`, ``)).includes(buildParametersContext.cacheKey)
|
|
|
|
);
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
2023-02-19 02:42:26 +00:00
|
|
|
|
|
|
|
public static NewWorkspaceName() {
|
|
|
|
return `${CloudRunner.retainedWorkspacePrefix}-${CloudRunner.buildParameters.buildGuid}`;
|
|
|
|
}
|
2023-02-16 22:54:06 +00:00
|
|
|
public static async GetAllLocksForWorkspace(
|
|
|
|
workspace: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<string[]> {
|
2022-11-07 20:41:00 +00:00
|
|
|
if (!(await SharedWorkspaceLocking.DoesWorkspaceExist(workspace, buildParametersContext))) {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
await SharedWorkspaceLocking.ReadLines(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/`,
|
2022-11-07 20:41:00 +00:00
|
|
|
)
|
|
|
|
)
|
|
|
|
.map((x) => x.replace(`/`, ``))
|
2023-02-17 00:07:46 +00:00
|
|
|
.filter((x) => x.includes(workspace) && x.endsWith(`_lock`));
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
public static async GetOrCreateLockedWorkspace(
|
|
|
|
workspace: string,
|
|
|
|
runId: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
) {
|
|
|
|
if (!CloudRunnerOptions.retainWorkspaces) {
|
2023-02-13 19:11:02 +00:00
|
|
|
return false;
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
2023-02-19 02:22:25 +00:00
|
|
|
if (await SharedWorkspaceLocking.DoesCacheKeyTopLevelExist(buildParametersContext)) {
|
|
|
|
const workspaces = await SharedWorkspaceLocking.GetFreeWorkspaces(buildParametersContext);
|
|
|
|
CloudRunnerLogger.log(`run agent ${runId} is trying to access a workspace, free: ${JSON.stringify(workspaces)}`);
|
|
|
|
for (const element of workspaces) {
|
|
|
|
await new Promise((promise) => setTimeout(promise, 1000));
|
|
|
|
const lockResult = await SharedWorkspaceLocking.LockWorkspace(element, runId, buildParametersContext);
|
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
|
|
|
CloudRunnerLogger.log(
|
2023-02-19 02:22:25 +00:00
|
|
|
`run agent: ${runId} try lock workspace: ${element} locking attempt result: ${lockResult}`,
|
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
|
|
|
|
2023-02-19 02:22:25 +00:00
|
|
|
if (lockResult) {
|
|
|
|
return true;
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-02-19 02:42:26 +00:00
|
|
|
if (await SharedWorkspaceLocking.DoesWorkspaceExist(workspace, buildParametersContext)) {
|
|
|
|
workspace = SharedWorkspaceLocking.NewWorkspaceName();
|
|
|
|
CloudRunner.lockedWorkspace = workspace;
|
|
|
|
}
|
|
|
|
|
2022-11-07 20:41:00 +00:00
|
|
|
const createResult = await SharedWorkspaceLocking.CreateWorkspace(workspace, buildParametersContext, runId);
|
2023-02-13 19:28:30 +00:00
|
|
|
const lockResult = await SharedWorkspaceLocking.LockWorkspace(workspace, runId, buildParametersContext);
|
2022-11-07 20:41:00 +00:00
|
|
|
CloudRunnerLogger.log(
|
2023-02-16 22:36:52 +00:00
|
|
|
`run agent ${runId} didn't find a free workspace so created: ${workspace} createWorkspaceSuccess: ${createResult} Lock:${lockResult}`,
|
2022-11-07 20:41:00 +00:00
|
|
|
);
|
|
|
|
|
2023-02-13 19:28:30 +00:00
|
|
|
return createResult && lockResult;
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public static async DoesWorkspaceExist(workspace: string, buildParametersContext: BuildParameters) {
|
2023-02-12 05:30:30 +00:00
|
|
|
return (
|
2023-02-19 02:08:22 +00:00
|
|
|
(await SharedWorkspaceLocking.GetAllWorkspaces(buildParametersContext)).filter((x) => x.includes(workspace))
|
|
|
|
.length > 0
|
2023-02-12 05:30:30 +00:00
|
|
|
);
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
public static async HasWorkspaceLock(
|
|
|
|
workspace: string,
|
|
|
|
runId: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<boolean> {
|
2023-02-16 22:54:06 +00:00
|
|
|
const locks = (await SharedWorkspaceLocking.GetAllLocksForWorkspace(workspace, buildParametersContext))
|
2022-11-07 20:41:00 +00:00
|
|
|
.map((x) => {
|
|
|
|
return {
|
|
|
|
name: x,
|
|
|
|
timestamp: Number(x.split(`_`)[0]),
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.sort((x) => x.timestamp);
|
|
|
|
const lockMatches = locks.filter((x) => x.name.includes(runId));
|
|
|
|
const includesRunLock = lockMatches.length > 0 && locks.indexOf(lockMatches[0]) === 0;
|
|
|
|
CloudRunnerLogger.log(
|
|
|
|
`Checking has workspace lock, runId: ${runId}, workspace: ${workspace}, success: ${includesRunLock} \n- Num of locks created by Run Agent: ${
|
|
|
|
lockMatches.length
|
|
|
|
} Num of Locks: ${locks.length}, Time ordered index for Run Agent: ${locks.indexOf(lockMatches[0])} \n \n`,
|
|
|
|
);
|
|
|
|
|
|
|
|
return includesRunLock;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static async GetFreeWorkspaces(buildParametersContext: BuildParameters): Promise<string[]> {
|
|
|
|
const result: string[] = [];
|
|
|
|
const workspaces = await SharedWorkspaceLocking.GetAllWorkspaces(buildParametersContext);
|
|
|
|
for (const element of workspaces) {
|
|
|
|
await new Promise((promise) => setTimeout(promise, 1500));
|
|
|
|
const isLocked = await SharedWorkspaceLocking.IsWorkspaceLocked(element, buildParametersContext);
|
|
|
|
const isBelowMax = await SharedWorkspaceLocking.IsWorkspaceBelowMax(element, buildParametersContext);
|
2023-02-16 21:37:48 +00:00
|
|
|
CloudRunnerLogger.log(`workspace ${element} locked:${isLocked} below max:${isBelowMax}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
if (!isLocked && isBelowMax) {
|
|
|
|
result.push(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static async IsWorkspaceBelowMax(
|
|
|
|
workspace: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<boolean> {
|
|
|
|
const workspaces = await SharedWorkspaceLocking.GetAllWorkspaces(buildParametersContext);
|
|
|
|
if (workspace === ``) {
|
|
|
|
return (
|
|
|
|
workspaces.length < buildParametersContext.maxRetainedWorkspaces ||
|
|
|
|
buildParametersContext.maxRetainedWorkspaces === 0
|
|
|
|
);
|
|
|
|
}
|
|
|
|
const ordered: any[] = [];
|
|
|
|
for (const ws of workspaces) {
|
|
|
|
ordered.push({
|
|
|
|
name: ws,
|
|
|
|
timestamp: await SharedWorkspaceLocking.GetWorkspaceTimestamp(ws, buildParametersContext),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
ordered.sort((x) => x.timestamp);
|
|
|
|
const matches = ordered.filter((x) => x.name.includes(workspace));
|
|
|
|
const isWorkspaceBelowMax =
|
|
|
|
matches.length > 0 &&
|
|
|
|
(ordered.indexOf(matches[0]) < buildParametersContext.maxRetainedWorkspaces ||
|
|
|
|
buildParametersContext.maxRetainedWorkspaces === 0);
|
|
|
|
|
|
|
|
return isWorkspaceBelowMax;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static async GetWorkspaceTimestamp(
|
|
|
|
workspace: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<Number> {
|
|
|
|
if (workspace.split(`_`).length > 0) {
|
|
|
|
return Number(workspace.split(`_`)[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(await SharedWorkspaceLocking.DoesWorkspaceExist(workspace, buildParametersContext))) {
|
|
|
|
throw new Error("Workspace doesn't exist, can't call get all locks");
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
await SharedWorkspaceLocking.ReadLines(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/`,
|
2022-11-07 20:41:00 +00:00
|
|
|
)
|
|
|
|
)
|
|
|
|
.map((x) => x.replace(`/`, ``))
|
2023-02-19 00:55:22 +00:00
|
|
|
.filter((x) => x.includes(workspace) && x.endsWith(`_workspace`))
|
2022-11-07 20:41:00 +00:00
|
|
|
.map((x) => Number(x))[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
public static async IsWorkspaceLocked(workspace: string, buildParametersContext: BuildParameters): Promise<boolean> {
|
|
|
|
if (!(await SharedWorkspaceLocking.DoesWorkspaceExist(workspace, buildParametersContext))) {
|
2023-02-18 23:13:10 +00:00
|
|
|
throw new Error(`workspace doesn't exist ${workspace}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
const files = await SharedWorkspaceLocking.ReadLines(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 ls ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/`,
|
2022-11-07 20:41:00 +00:00
|
|
|
);
|
|
|
|
|
2023-02-17 21:45:26 +00:00
|
|
|
if (workspace.includes(`_`)) {
|
|
|
|
workspace = workspace.split(`_`)[1];
|
|
|
|
}
|
|
|
|
|
2022-11-07 20:41:00 +00:00
|
|
|
const lockFilesExist =
|
|
|
|
files.filter((x) => {
|
2023-02-16 23:11:01 +00:00
|
|
|
return x.includes(workspace) && x.endsWith(`_lock`);
|
2022-11-07 20:41:00 +00:00
|
|
|
}).length > 0;
|
|
|
|
|
2023-02-12 02:27:09 +00:00
|
|
|
return lockFilesExist;
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public static async CreateWorkspace(
|
|
|
|
workspace: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
lockId: string = ``,
|
|
|
|
): Promise<boolean> {
|
|
|
|
if (lockId !== ``) {
|
|
|
|
await SharedWorkspaceLocking.LockWorkspace(workspace, lockId, buildParametersContext);
|
|
|
|
}
|
2023-02-19 02:42:26 +00:00
|
|
|
if (await SharedWorkspaceLocking.DoesWorkspaceExist(workspace, buildParametersContext)) {
|
|
|
|
throw new Error(`${workspace} already exists`);
|
|
|
|
}
|
2022-11-07 20:41:00 +00:00
|
|
|
const timestamp = Date.now();
|
2023-02-10 04:46:31 +00:00
|
|
|
const file = `${timestamp}_${workspace}_workspace`;
|
2022-11-07 20:41:00 +00:00
|
|
|
fs.writeFileSync(file, '');
|
|
|
|
await CloudRunnerSystem.Run(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 cp ./${file} ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/${file}`,
|
2022-11-07 20:41:00 +00:00
|
|
|
false,
|
|
|
|
true,
|
|
|
|
);
|
|
|
|
fs.rmSync(file);
|
|
|
|
|
2023-02-12 04:30:29 +00:00
|
|
|
const workspaces = await SharedWorkspaceLocking.GetAllWorkspaces(buildParametersContext);
|
2022-11-07 20:41:00 +00:00
|
|
|
|
|
|
|
CloudRunnerLogger.log(`All workspaces ${workspaces}`);
|
|
|
|
if (!(await SharedWorkspaceLocking.IsWorkspaceBelowMax(workspace, buildParametersContext))) {
|
2023-02-16 22:39:31 +00:00
|
|
|
CloudRunnerLogger.log(`Workspace is above max ${workspaces} ${buildParametersContext.maxRetainedWorkspaces}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
await SharedWorkspaceLocking.CleanupWorkspace(workspace, buildParametersContext);
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static async LockWorkspace(
|
|
|
|
workspace: string,
|
|
|
|
runId: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<boolean> {
|
2023-02-13 18:54:29 +00:00
|
|
|
const existingWorkspace = workspace.endsWith(`_workspace`);
|
|
|
|
const ending = existingWorkspace ? workspace : `${workspace}_workspace`;
|
|
|
|
const file = `${Date.now()}_${runId}_${ending}_lock`;
|
2022-11-07 20:41:00 +00:00
|
|
|
fs.writeFileSync(file, '');
|
|
|
|
await CloudRunnerSystem.Run(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 cp ./${file} ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/${file}`,
|
2022-11-07 20:41:00 +00:00
|
|
|
false,
|
|
|
|
true,
|
|
|
|
);
|
|
|
|
fs.rmSync(file);
|
|
|
|
|
2023-02-16 19:50:18 +00:00
|
|
|
const hasLock = await SharedWorkspaceLocking.HasWorkspaceLock(workspace, runId, buildParametersContext);
|
|
|
|
|
|
|
|
if (hasLock) {
|
|
|
|
CloudRunner.lockedWorkspace = workspace;
|
|
|
|
}
|
|
|
|
|
|
|
|
return hasLock;
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public static async ReleaseWorkspace(
|
|
|
|
workspace: string,
|
|
|
|
runId: string,
|
|
|
|
buildParametersContext: BuildParameters,
|
|
|
|
): Promise<boolean> {
|
2023-02-16 22:54:06 +00:00
|
|
|
const files = await SharedWorkspaceLocking.GetAllLocksForWorkspace(workspace, buildParametersContext);
|
2023-02-17 00:07:46 +00:00
|
|
|
const file = files.find((x) => x.includes(workspace) && x.endsWith(`_lock`) && x.includes(runId));
|
2023-02-13 21:13:27 +00:00
|
|
|
CloudRunnerLogger.log(`All Locks ${files} ${workspace} ${runId}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
CloudRunnerLogger.log(`Deleting lock ${workspace}/${file}`);
|
2023-02-10 05:34:37 +00:00
|
|
|
CloudRunnerLogger.log(`rm ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/${file}`);
|
2022-11-07 20:41:00 +00:00
|
|
|
await CloudRunnerSystem.Run(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 rm ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey}/${file}`,
|
2022-11-07 20:41:00 +00:00
|
|
|
false,
|
|
|
|
true,
|
|
|
|
);
|
|
|
|
|
2023-02-13 21:43:03 +00:00
|
|
|
return !(await SharedWorkspaceLocking.HasWorkspaceLock(workspace, runId, buildParametersContext));
|
2022-11-07 20:41:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public static async CleanupWorkspace(workspace: string, buildParametersContext: BuildParameters) {
|
|
|
|
await CloudRunnerSystem.Run(
|
2023-02-10 04:46:31 +00:00
|
|
|
`aws s3 rm ${SharedWorkspaceLocking.workspaceRoot}${buildParametersContext.cacheKey} --exclude "*" --include "*_${workspace}_*"`,
|
2022-11-07 20:41:00 +00:00
|
|
|
false,
|
|
|
|
true,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-02-12 03:34:34 +00:00
|
|
|
public static async ReadLines(command: string): Promise<string[]> {
|
2022-11-07 20:41:00 +00:00
|
|
|
return CloudRunnerSystem.RunAndReadLines(command);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SharedWorkspaceLocking;
|