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

57 lines
2.1 KiB
TypeScript
Raw Normal View History

2021-10-06 01:19:42 +00:00
import CloudRunnerLogger from '../services/cloud-runner-logger';
import { CloudRunnerState } from '../state/cloud-runner-state';
import { CloudRunnerStepState } from '../state/cloud-runner-step-state';
import { BuildStep } from '../steps/build-step';
import { CompressionStep } from '../steps/compression-step';
import { DownloadRepositoryStep } from '../steps/download-repository-step';
import { CustomWorkflow } from './custom-workflow';
import { WorkflowInterface } from './workflow-interface';
export class BuildAutomationWorkflow implements WorkflowInterface {
async run(cloudRunnerStepState: CloudRunnerStepState) {
await BuildAutomationWorkflow.standardBuildAutomation(cloudRunnerStepState.image);
}
private static async standardBuildAutomation(baseImage: any) {
CloudRunnerLogger.log(`Cloud Runner is running standard build automation`);
await new DownloadRepositoryStep().run(
new CloudRunnerStepState(
'alpine/git',
CloudRunnerState.readBuildEnvironmentVariables(),
CloudRunnerState.defaultSecrets,
),
);
CloudRunnerLogger.logWithTime('Download repository step time');
2021-10-29 21:54:48 +00:00
if (CloudRunnerState.buildParams.preBuildSteps === '') {
await CustomWorkflow.runCustomJob(CloudRunnerState.buildParams.preBuildSteps);
}
2021-10-06 01:19:42 +00:00
CloudRunnerLogger.logWithTime('Pre build step(s) time');
new BuildStep().run(
new CloudRunnerStepState(
baseImage,
CloudRunnerState.readBuildEnvironmentVariables(),
CloudRunnerState.defaultSecrets,
),
);
CloudRunnerLogger.logWithTime('Build time');
await new CompressionStep().run(
new CloudRunnerStepState(
'alpine',
CloudRunnerState.readBuildEnvironmentVariables(),
CloudRunnerState.defaultSecrets,
),
);
CloudRunnerLogger.logWithTime('Compression time');
2021-10-29 21:54:48 +00:00
if (CloudRunnerState.buildParams.postBuildSteps === '') {
await CustomWorkflow.runCustomJob(CloudRunnerState.buildParams.postBuildSteps);
}
2021-10-06 01:19:42 +00:00
CloudRunnerLogger.logWithTime('Post build step(s) time');
CloudRunnerLogger.log(`Cloud Runner finished running standard build automation`);
}
}