mirror of
https://github.com/game-ci/unity-builder.git
synced 2026-05-31 13:56:13 -07:00
* Rename "Cloud Runner" to "Orchestrator" across entire codebase Breaking change: All CloudRunner classes, options, environment variables, and action.yml inputs have been renamed to Orchestrator equivalents. - Renamed src/model/cloud-runner/ directory to src/model/orchestrator/ - Renamed all cloud-runner-* files to orchestrator-* - Renamed all CloudRunner* classes to Orchestrator* (15+ classes) - Renamed all cloudRunner* properties to orchestrator* equivalents - Renamed CLOUD_RUNNER_* env vars to ORCHESTRATOR_* - Updated action.yml [CloudRunner] markers to [Orchestrator] - Updated workflow files and package.json test scripts - Updated all runtime strings (cache paths, log messages, branch refs) - Rebuilt dist/index.js No backward compatibility layer is provided. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Remove tracked log/temp files and add to .gitignore Remove $LOG_FILE and temp/job-log.txt debug artifacts that should not be in the repository. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
143 lines
5.5 KiB
TypeScript
143 lines
5.5 KiB
TypeScript
import { BuildParameters, Orchestrator, ImageTag, Input } from '../..';
|
|
import { TaskParameterSerializer } from '../services/core/task-parameter-serializer';
|
|
import UnityVersioning from '../../unity-versioning';
|
|
import { Cli } from '../../cli/cli';
|
|
import GitHub from '../../github';
|
|
import setups from './orchestrator-suite.test';
|
|
import { OrchestratorStatics } from '../options/orchestrator-statics';
|
|
import OrchestratorOptions from '../options/orchestrator-options';
|
|
import OrchestratorLogger from '../services/core/orchestrator-logger';
|
|
|
|
async function CreateParameters(overrides: any) {
|
|
if (overrides) {
|
|
Cli.options = overrides;
|
|
}
|
|
const originalValue = GitHub.githubInputEnabled;
|
|
GitHub.githubInputEnabled = false;
|
|
const results = await BuildParameters.create();
|
|
GitHub.githubInputEnabled = originalValue;
|
|
delete Cli.options;
|
|
|
|
return results;
|
|
}
|
|
|
|
describe('Orchestrator Sync Environments', () => {
|
|
setups();
|
|
const testSecretName = 'testSecretName';
|
|
const testSecretValue = 'testSecretValue';
|
|
it('Responds', () => {});
|
|
|
|
if (OrchestratorOptions.orchestratorDebug) {
|
|
it('All build parameters sent to orchestrator as env vars', async () => {
|
|
// Setup parameters
|
|
const buildParameter = await CreateParameters({
|
|
versioning: 'None',
|
|
projectPath: 'test-project',
|
|
unityVersion: UnityVersioning.read('test-project'),
|
|
targetPlatform: 'StandaloneWindows64',
|
|
customJob: `
|
|
- name: 'step 1'
|
|
image: 'ubuntu'
|
|
commands: 'printenv'
|
|
secrets:
|
|
- name: '${testSecretName}'
|
|
value: '${testSecretValue}'
|
|
`,
|
|
orchestratorDebug: true,
|
|
});
|
|
const baseImage = new ImageTag(buildParameter);
|
|
if (baseImage.toString().includes('undefined')) {
|
|
throw new Error(`Base image is undefined`);
|
|
}
|
|
|
|
// Run the job
|
|
const file = (await Orchestrator.run(buildParameter, baseImage.toString())).BuildResults;
|
|
|
|
// Assert results
|
|
// expect(file).toContain(JSON.stringify(buildParameter));
|
|
expect(file).toContain(`${Input.ToEnvVarFormat(testSecretName)}=${testSecretValue}`);
|
|
const environmentVariables = TaskParameterSerializer.createOrchestratorEnvironmentVariables(buildParameter);
|
|
const secrets = TaskParameterSerializer.readDefaultSecrets().map((x) => {
|
|
return {
|
|
name: x.EnvironmentVariable,
|
|
value: x.ParameterValue,
|
|
};
|
|
});
|
|
|
|
// Apply the same localhost -> host.docker.internal replacement that the Docker provider does
|
|
// This ensures the test expectations match what's actually in the output
|
|
const endpointEnvironmentNames = new Set([
|
|
'AWS_S3_ENDPOINT',
|
|
'AWS_ENDPOINT',
|
|
'AWS_CLOUD_FORMATION_ENDPOINT',
|
|
'AWS_ECS_ENDPOINT',
|
|
'AWS_KINESIS_ENDPOINT',
|
|
'AWS_CLOUD_WATCH_LOGS_ENDPOINT',
|
|
'INPUT_AWSS3ENDPOINT',
|
|
'INPUT_AWSENDPOINT',
|
|
]);
|
|
const combined = [...environmentVariables, ...secrets]
|
|
.filter((element) => element.value !== undefined && element.value !== '' && typeof element.value !== 'function')
|
|
.map((x) => {
|
|
if (typeof x.value === `string`) {
|
|
x.value = x.value.replace(/\s+/g, '');
|
|
|
|
// Apply localhost -> host.docker.internal replacement for LocalStack endpoints
|
|
// when using local-docker or aws provider (which uses Docker)
|
|
if (
|
|
endpointEnvironmentNames.has(x.name) &&
|
|
(x.value.startsWith('http://localhost') || x.value.startsWith('http://127.0.0.1')) &&
|
|
(OrchestratorOptions.providerStrategy === 'local-docker' ||
|
|
OrchestratorOptions.providerStrategy === 'aws')
|
|
) {
|
|
x.value = x.value
|
|
.replace('http://localhost', 'http://host.docker.internal')
|
|
.replace('http://127.0.0.1', 'http://host.docker.internal');
|
|
}
|
|
}
|
|
|
|
return x;
|
|
})
|
|
.filter((element) => {
|
|
return !['UNITY_LICENSE', 'UNITY_LICENSE', 'CUSTOM_JOB', 'CUSTOM_JOB'].includes(element.name);
|
|
});
|
|
const newLinePurgedFile = file
|
|
.replace(/\s+/g, '')
|
|
.replace(new RegExp(`\\[${OrchestratorStatics.logPrefix}\\]`, 'g'), '');
|
|
for (const element of combined) {
|
|
expect(newLinePurgedFile).toContain(`${element.name}`);
|
|
OrchestratorLogger.log(`Contains ${element.name}`);
|
|
const fullNameEqualValue = `${element.name}=${element.value}`;
|
|
expect(newLinePurgedFile).toContain(fullNameEqualValue);
|
|
}
|
|
}, 1_000_000_000);
|
|
}
|
|
});
|
|
|
|
describe('Orchestrator Environment Serializer', () => {
|
|
setups();
|
|
const testSecretName = 'testSecretName';
|
|
const testSecretValue = 'testSecretValue';
|
|
it('Orchestrator Parameter Serialization', async () => {
|
|
// Setup parameters
|
|
const buildParameter = await CreateParameters({
|
|
versioning: 'None',
|
|
projectPath: 'test-project',
|
|
unityVersion: UnityVersioning.read('test-project'),
|
|
customJob: `
|
|
- name: 'step 1'
|
|
image: 'alpine'
|
|
commands: 'printenv'
|
|
secrets:
|
|
- name: '${testSecretName}'
|
|
value: '${testSecretValue}'
|
|
`,
|
|
});
|
|
|
|
const result = TaskParameterSerializer.createOrchestratorEnvironmentVariables(buildParameter);
|
|
expect(result.find((x) => Number.parseInt(x.name)) !== undefined).toBeFalsy();
|
|
const result2 = TaskParameterSerializer.createOrchestratorEnvironmentVariables(buildParameter);
|
|
expect(result2.find((x) => Number.parseInt(x.name)) !== undefined).toBeFalsy();
|
|
});
|
|
});
|