mirror of
https://github.com/game-ci/unity-builder.git
synced 2026-02-05 08:59:09 +08:00
* Enable noImplicitAny Add types to all implicit any variables Bump target to ES2020 for recent language features (optional chaining) Code cleanup Add debug configuration for vscode Remove autorun flag from jest to remove warning Bump packages to fix dependency version mismatch warning Changed @arkweid/lefthook to @evilmartians/lefthook as @arkweid/lefthook has been deprecated in favor of @evilmartians/lefthook Added concurrency groups to integrity check and build workflows. New commits to branches will cancel superseded runs on the same branch/pr Update imports to not use require syntax Use node packages (ie node:fs rather than fs) AndroidVersionCode is now a string rather than a number as it gets converted to a string when passed out of the system Reduce timeout for windows builds Remove 2020.1.17f1 from windows builds due to repeated license activation errors Update naming scheme of workflows for consistency Update build names so target platform and unity version aren't cut off by github actions UI * Add exclude to test matrix for 2022.2 on android until Unity bug is fixed --------- Co-authored-by: AndrewKahr <AndrewKahr@users.noreply.github.com>
80 lines
3.4 KiB
TypeScript
80 lines
3.4 KiB
TypeScript
import CloudRunner from '../cloud-runner';
|
|
import { BuildParameters, ImageTag } from '../..';
|
|
import UnityVersioning from '../../unity-versioning';
|
|
import { Cli } from '../../cli/cli';
|
|
import CloudRunnerLogger from '../services/cloud-runner-logger';
|
|
import { v4 as uuidv4 } from 'uuid';
|
|
import CloudRunnerOptions from '../cloud-runner-options';
|
|
import setups from './cloud-runner-suite.test';
|
|
import fs from 'node:fs';
|
|
import { OptionValues } from 'commander';
|
|
|
|
async function CreateParameters(overrides: OptionValues | undefined) {
|
|
if (overrides) {
|
|
Cli.options = overrides;
|
|
}
|
|
|
|
return await BuildParameters.create();
|
|
}
|
|
|
|
describe('Cloud Runner Caching', () => {
|
|
it('Responds', () => {});
|
|
setups();
|
|
if (CloudRunnerOptions.cloudRunnerDebug) {
|
|
it('Run one build it should not use cache, run subsequent build which should use cache', async () => {
|
|
const overrides = {
|
|
versioning: 'None',
|
|
projectPath: 'test-project',
|
|
unityVersion: UnityVersioning.determineUnityVersion('test-project', UnityVersioning.read('test-project')),
|
|
targetPlatform: 'StandaloneLinux64',
|
|
cacheKey: `test-case-${uuidv4()}`,
|
|
customStepFiles: `debug-cache`,
|
|
};
|
|
if (CloudRunnerOptions.cloudRunnerCluster === `k8s`) {
|
|
overrides.customStepFiles += `,aws-s3-pull-cache,aws-s3-upload-cache`;
|
|
}
|
|
const buildParameter = await CreateParameters(overrides);
|
|
expect(buildParameter.projectPath).toEqual(overrides.projectPath);
|
|
|
|
const baseImage = new ImageTag(buildParameter);
|
|
const results = await CloudRunner.run(buildParameter, baseImage.toString());
|
|
const libraryString = 'Rebuilding Library because the asset database could not be found!';
|
|
const cachePushFail = 'Did not push source folder to cache because it was empty Library';
|
|
const buildSucceededString = 'Build succeeded';
|
|
|
|
expect(results).toContain(libraryString);
|
|
expect(results).toContain(buildSucceededString);
|
|
expect(results).not.toContain(cachePushFail);
|
|
|
|
CloudRunnerLogger.log(`run 1 succeeded`);
|
|
|
|
if (CloudRunnerOptions.cloudRunnerCluster === `local-docker`) {
|
|
const cacheFolderExists = fs.existsSync(`cloud-runner-cache/cache/${overrides.cacheKey}`);
|
|
expect(cacheFolderExists).toBeTruthy();
|
|
}
|
|
const buildParameter2 = await CreateParameters(overrides);
|
|
|
|
buildParameter2.cacheKey = buildParameter.cacheKey;
|
|
const baseImage2 = new ImageTag(buildParameter2);
|
|
const results2 = await CloudRunner.run(buildParameter2, baseImage2.toString());
|
|
CloudRunnerLogger.log(`run 2 succeeded`);
|
|
|
|
const build2ContainsCacheKey = results2.includes(buildParameter.cacheKey);
|
|
const build2ContainsBuildSucceeded = results2.includes(buildSucceededString);
|
|
const build2NotContainsNoLibraryMessage = !results2.includes(libraryString);
|
|
const build2NotContainsZeroLibraryCacheFilesMessage = !results2.includes(
|
|
'There is 0 files/dir in the cache pulled contents for Library',
|
|
);
|
|
const build2NotContainsZeroLFSCacheFilesMessage = !results2.includes(
|
|
'There is 0 files/dir in the cache pulled contents for LFS',
|
|
);
|
|
|
|
expect(build2ContainsCacheKey).toBeTruthy();
|
|
expect(build2ContainsBuildSucceeded).toBeTruthy();
|
|
expect(build2NotContainsZeroLibraryCacheFilesMessage).toBeTruthy();
|
|
expect(build2NotContainsZeroLFSCacheFilesMessage).toBeTruthy();
|
|
expect(build2NotContainsNoLibraryMessage).toBeTruthy();
|
|
}, 1_000_000_000);
|
|
}
|
|
});
|