unity-builder/src/model/cloud-runner/workflows/build-automation-workflow.ts

62 lines
2.2 KiB
TypeScript
Raw Normal View History

2021-10-06 01:19:42 +00:00
import CloudRunnerLogger from '../services/cloud-runner-logger';
2021-12-30 18:47:01 +00:00
import { TaskParameterSerializer } from '../services/task-parameter-serializer';
2021-10-06 01:19:42 +00:00
import { CloudRunnerState } from '../state/cloud-runner-state';
import { CloudRunnerStepState } from '../state/cloud-runner-step-state';
import { BuildStep } from '../steps/build-step';
2021-12-25 19:08:57 +00:00
import { SetupStep } from '../steps/setup-step';
2021-10-06 01:19:42 +00:00
import { CustomWorkflow } from './custom-workflow';
import { WorkflowInterface } from './workflow-interface';
2022-01-03 05:30:55 +00:00
import * as core from '@actions/core';
2021-10-06 01:19:42 +00:00
export class BuildAutomationWorkflow implements WorkflowInterface {
async run(cloudRunnerStepState: CloudRunnerStepState) {
2021-11-21 17:20:11 +00:00
try {
2021-12-30 20:25:28 +00:00
return await BuildAutomationWorkflow.standardBuildAutomation(cloudRunnerStepState.image);
2021-11-21 17:20:11 +00:00
} catch (error) {
throw error;
}
2021-10-06 01:19:42 +00:00
}
private static async standardBuildAutomation(baseImage: any) {
2021-11-21 17:20:11 +00:00
try {
CloudRunnerLogger.log(`Cloud Runner is running standard build automation`);
2021-12-30 20:25:28 +00:00
let output = '';
2022-01-01 08:07:08 +00:00
if (CloudRunnerState.buildParams.preBuildSteps !== '') {
output += await CustomWorkflow.runCustomJob(CloudRunnerState.buildParams.preBuildSteps);
}
CloudRunnerLogger.logWithTime('Configurable pre build step(s) time');
2022-01-03 05:30:55 +00:00
core.startGroup('setup');
2021-12-30 20:25:28 +00:00
output += await new SetupStep().run(
2021-11-21 17:20:11 +00:00
new CloudRunnerStepState(
'alpine/git',
2021-12-30 18:47:01 +00:00
TaskParameterSerializer.readBuildEnvironmentVariables(),
2021-11-21 17:20:11 +00:00
CloudRunnerState.defaultSecrets,
),
);
CloudRunnerLogger.logWithTime('Download repository step time');
2021-10-06 01:19:42 +00:00
2022-01-03 05:30:55 +00:00
core.startGroup('build');
2021-12-30 20:25:28 +00:00
output += await new BuildStep().run(
2021-11-21 17:20:11 +00:00
new CloudRunnerStepState(
baseImage,
2021-12-30 18:47:01 +00:00
TaskParameterSerializer.readBuildEnvironmentVariables(),
2021-11-21 17:20:11 +00:00
CloudRunnerState.defaultSecrets,
),
);
CloudRunnerLogger.logWithTime('Build time');
2021-10-06 01:19:42 +00:00
2021-11-21 17:20:11 +00:00
if (CloudRunnerState.buildParams.postBuildSteps !== '') {
2021-12-30 20:25:28 +00:00
output += await CustomWorkflow.runCustomJob(CloudRunnerState.buildParams.postBuildSteps);
2021-11-21 17:20:11 +00:00
}
2022-01-01 08:07:08 +00:00
CloudRunnerLogger.logWithTime('Configurable post build step(s) time');
2021-10-06 01:19:42 +00:00
2021-11-21 17:20:11 +00:00
CloudRunnerLogger.log(`Cloud Runner finished running standard build automation`);
2021-12-30 20:25:28 +00:00
return output;
2021-11-21 17:20:11 +00:00
} catch (error) {
throw error;
}
2021-10-06 01:19:42 +00:00
}
}