Update windows images and add docker parameters

pull/244/head
David Finol 2023-11-04 20:35:56 -05:00
parent 7b6d529621
commit 129fddf8db
12 changed files with 2042 additions and 1470 deletions

View File

@ -60,6 +60,24 @@ inputs:
required: false required: false
default: '' default: ''
description: 'User and optionally group (user or user:group or uid:gid) to give ownership of the resulting build artifacts' description: 'User and optionally group (user or user:group or uid:gid) to give ownership of the resulting build artifacts'
dockerCpuLimit:
required: false
default: ''
description: 'Number of CPU cores to assign the docker container. Defaults to all available cores on all platforms.'
dockerMemoryLimit:
required: false
default: ''
description:
'Amount of memory to assign the docker container. Defaults to 95% of total system memory rounded down to the
nearest megabyte on Linux and 80% on Windows. On unrecognized platforms, defaults to 75% of total system memory.
To manually specify a value, use the format <number><unit>, where unit is either m or g. ie: 512m = 512 megabytes'
dockerIsolationMode:
required: false
default: 'default'
description:
'Isolation mode to use for the docker container. Can be one of process, hyperv, or default. Default will pick the
default mode as described by Microsoft where server versions use process and desktop versions use hyperv. Only
applicable on Windows'
unityLicensingServer: unityLicensingServer:
required: false required: false
default: '' default: ''

37
dist/index.js vendored
View File

@ -98,7 +98,7 @@ function run() {
try { try {
model_1.Action.checkCompatibility(); model_1.Action.checkCompatibility();
const { workspace, actionFolder } = model_1.Action; const { workspace, actionFolder } = model_1.Action;
const { editorVersion, customImage, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, sshPublicKeysDirectoryPath, gitPrivateToken, githubToken, checkName, packageMode, packageName, chownFilesTo, unityLicensingServer, } = model_1.Input.getFromUser(); const { editorVersion, customImage, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, sshPublicKeysDirectoryPath, gitPrivateToken, githubToken, checkName, packageMode, packageName, chownFilesTo, dockerCpuLimit, dockerMemoryLimit, dockerIsolationMode, unityLicensingServer, } = model_1.Input.getFromUser();
const baseImage = new model_1.ImageTag({ editorVersion, customImage }); const baseImage = new model_1.ImageTag({ editorVersion, customImage });
const runnerContext = model_1.Action.runnerContext(); const runnerContext = model_1.Action.runnerContext();
try { try {
@ -118,6 +118,9 @@ function run() {
gitPrivateToken, gitPrivateToken,
githubToken, githubToken,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer }, runnerContext)); unityLicensingServer }, runnerContext));
} }
finally { finally {
@ -263,7 +266,7 @@ const Docker = {
}); });
}, },
getLinuxCommand(image, parameters) { getLinuxCommand(image, parameters) {
const { actionFolder, editorVersion, workspace, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, sshPublicKeysDirectoryPath, packageMode, packageName, gitPrivateToken, githubToken, runnerTemporaryPath, chownFilesTo, unityLicensingServer, } = parameters; const { actionFolder, editorVersion, workspace, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, sshPublicKeysDirectoryPath, packageMode, packageName, gitPrivateToken, githubToken, runnerTemporaryPath, chownFilesTo, dockerCpuLimit, dockerMemoryLimit, unityLicensingServer, } = parameters;
const githubHome = path_1.default.join(runnerTemporaryPath, '_github_home'); const githubHome = path_1.default.join(runnerTemporaryPath, '_github_home');
if (!(0, fs_1.existsSync)(githubHome)) if (!(0, fs_1.existsSync)(githubHome))
(0, fs_1.mkdirSync)(githubHome); (0, fs_1.mkdirSync)(githubHome);
@ -317,6 +320,8 @@ const Docker = {
--volume "${actionFolder}/steps:/steps:z" \ --volume "${actionFolder}/steps:/steps:z" \
--volume "${actionFolder}/entrypoint.sh:/entrypoint.sh:z" \ --volume "${actionFolder}/entrypoint.sh:/entrypoint.sh:z" \
--volume "${actionFolder}/unity-config:/usr/share/unity3d/config/:z" \ --volume "${actionFolder}/unity-config:/usr/share/unity3d/config/:z" \
--cpus=${dockerCpuLimit} \
--memory=${dockerMemoryLimit} \
${sshAgent ? `--volume ${sshAgent}:/ssh-agent` : ''} \ ${sshAgent ? `--volume ${sshAgent}:/ssh-agent` : ''} \
${sshAgent && !sshPublicKeysDirectoryPath ${sshAgent && !sshPublicKeysDirectoryPath
? `--volume /home/runner/.ssh/known_hosts:/root/.ssh/known_hosts:ro` ? `--volume /home/runner/.ssh/known_hosts:/root/.ssh/known_hosts:ro`
@ -330,7 +335,7 @@ const Docker = {
/bin/bash -c /entrypoint.sh`; /bin/bash -c /entrypoint.sh`;
}, },
getWindowsCommand(image, parameters) { getWindowsCommand(image, parameters) {
const { actionFolder, editorVersion, workspace, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, packageMode, packageName, gitPrivateToken, githubToken, runnerTemporaryPath, chownFilesTo, unityLicensingServer, } = parameters; const { actionFolder, editorVersion, workspace, projectPath, customParameters, testMode, coverageOptions, artifactsPath, useHostNetwork, sshAgent, packageMode, packageName, gitPrivateToken, githubToken, runnerTemporaryPath, chownFilesTo, dockerCpuLimit, dockerMemoryLimit, dockerIsolationMode, unityLicensingServer, } = parameters;
const githubHome = path_1.default.join(runnerTemporaryPath, '_github_home'); const githubHome = path_1.default.join(runnerTemporaryPath, '_github_home');
if (!(0, fs_1.existsSync)(githubHome)) if (!(0, fs_1.existsSync)(githubHome))
(0, fs_1.mkdirSync)(githubHome); (0, fs_1.mkdirSync)(githubHome);
@ -386,6 +391,9 @@ const Docker = {
${sshAgent ${sshAgent
? `--volume c:/Users/Administrator/.ssh/known_hosts:c:/root/.ssh/known_hosts` ? `--volume c:/Users/Administrator/.ssh/known_hosts:c:/root/.ssh/known_hosts`
: ''} \ : ''} \
--cpus=${dockerCpuLimit} \
--memory=${dockerMemoryLimit} \
--isolation=${dockerIsolationMode} \
${useHostNetwork ? '--net=host' : ''} \ ${useHostNetwork ? '--net=host' : ''} \
${githubToken ? '--env USE_EXIT_CODE=false' : '--env USE_EXIT_CODE=true'} \ ${githubToken ? '--env USE_EXIT_CODE=false' : '--env USE_EXIT_CODE=true'} \
${image} \ ${image} \
@ -422,7 +430,7 @@ class ImageTag {
this.targetPlatform = targetPlatform; this.targetPlatform = targetPlatform;
this.targetPlatformSuffix = ImageTag.getTargetPlatformSuffix(targetPlatform, editorVersion); this.targetPlatformSuffix = ImageTag.getTargetPlatformSuffix(targetPlatform, editorVersion);
this.imagePlatformPrefix = ImageTag.getImagePlatformPrefix(process.platform); this.imagePlatformPrefix = ImageTag.getImagePlatformPrefix(process.platform);
this.imageRollingVersion = 2; this.imageRollingVersion = 3;
} }
static get versionPattern() { static get versionPattern() {
return /^20\d{2}\.\d\.\w{3,4}|3$/; return /^20\d{2}\.\d\.\w{3,4}|3$/;
@ -571,6 +579,7 @@ Object.defineProperty(exports, "__esModule", ({ value: true }));
const unity_version_parser_1 = __importDefault(__nccwpck_require__(7049)); const unity_version_parser_1 = __importDefault(__nccwpck_require__(7049));
const fs_1 = __importDefault(__nccwpck_require__(7147)); const fs_1 = __importDefault(__nccwpck_require__(7147));
const core_1 = __nccwpck_require__(2186); const core_1 = __nccwpck_require__(2186);
const os_1 = __importDefault(__nccwpck_require__(2037));
const Input = { const Input = {
get testModes() { get testModes() {
return ['all', 'playmode', 'editmode', 'standalone']; return ['all', 'playmode', 'editmode', 'standalone'];
@ -637,6 +646,23 @@ const Input = {
const rawPackageMode = (0, core_1.getInput)('packageMode') || 'false'; const rawPackageMode = (0, core_1.getInput)('packageMode') || 'false';
let packageName = ''; let packageName = '';
const chownFilesTo = (0, core_1.getInput)('chownFilesTo') || ''; const chownFilesTo = (0, core_1.getInput)('chownFilesTo') || '';
const dockerCpuLimit = (0, core_1.getInput)('dockerCpuLimit') || os_1.default.cpus().length.toString();
const bytesInMegabyte = 1024 * 1024;
let memoryMultiplier;
switch (os_1.default.platform()) {
case 'linux':
memoryMultiplier = 0.95;
break;
case 'win32':
memoryMultiplier = 0.8;
break;
default:
memoryMultiplier = 0.75;
break;
}
const dockerMemoryLimit = (0, core_1.getInput)('dockerMemoryLimit') ||
`${Math.floor((os_1.default.totalmem() / bytesInMegabyte) * memoryMultiplier)}m`;
const dockerIsolationMode = (0, core_1.getInput)('dockerIsolationMode') || 'default';
// Validate input // Validate input
if (!this.testModes.includes(testMode)) { if (!this.testModes.includes(testMode)) {
throw new Error(`Invalid testMode ${testMode}`); throw new Error(`Invalid testMode ${testMode}`);
@ -694,6 +720,9 @@ const Input = {
packageMode, packageMode,
packageName, packageName,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer, unityLicensingServer,
}; };
}, },

2
dist/index.js.map vendored

File diff suppressed because one or more lines are too long

View File

@ -8,4 +8,6 @@ module.exports = {
'^.+\\.ts$': 'ts-jest', '^.+\\.ts$': 'ts-jest',
}, },
verbose: true, verbose: true,
modulePathIgnorePatterns: ['<rootDir>/lib/', '<rootDir>/dist/'],
setupFilesAfterEnv: ['<rootDir>/src/jest.setup.ts'],
}; };

View File

@ -1,6 +1,6 @@
{ {
"name": "unity-test-runner", "name": "unity-test-runner",
"version": "2.0.0", "version": "3.0.0",
"description": "Run tests for any Unity project.", "description": "Run tests for any Unity project.",
"main": "dist/index.js", "main": "dist/index.js",
"repository": "git@github.com:game-ci/unity-test-runner.git", "repository": "git@github.com:game-ci/unity-test-runner.git",
@ -24,7 +24,7 @@
}, },
"devDependencies": { "devDependencies": {
"@types/jest": "^26.0.15", "@types/jest": "^26.0.15",
"@types/node": "^14.14.9", "@types/node": "^20.8.10",
"@types/semver": "^7.3.5", "@types/semver": "^7.3.5",
"@typescript-eslint/parser": "^5.9.0", "@typescript-eslint/parser": "^5.9.0",
"@vercel/ncc": "^0.33.1", "@vercel/ncc": "^0.33.1",
@ -37,11 +37,14 @@
"husky": "^7.0.4", "husky": "^7.0.4",
"jest": "^26.6.3", "jest": "^26.6.3",
"jest-circus": "^26.6.3", "jest-circus": "^26.6.3",
"jest-fail-on-console": "^3.0.2",
"js-yaml": "^3.14.0", "js-yaml": "^3.14.0",
"lint-staged": "^12.1.2", "lint-staged": "^12.1.2",
"prettier": "^2.2.1", "prettier": "^2.2.1",
"ts-jest": "^26.4.4", "ts-jest": "^26.4.4",
"typescript": "^4.1.5" "ts-node": "10.4.0",
"typescript": "^4.1.5",
"yarn-audit-fix": "^9.3.8"
}, },
"lint-staged": { "lint-staged": {
"*.{js,jsx,ts,tsx}": [ "*.{js,jsx,ts,tsx}": [

View File

@ -0,0 +1,9 @@
import failOnConsole from 'jest-fail-on-console';
// Fail when console logs something inside a test - use spyOn instead
failOnConsole({
shouldFailOnWarn: true,
shouldFailOnError: true,
shouldFailOnLog: true,
shouldFailOnAssert: true,
});

View File

@ -23,6 +23,9 @@ export async function run() {
packageMode, packageMode,
packageName, packageName,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer, unityLicensingServer,
} = Input.getFromUser(); } = Input.getFromUser();
const baseImage = new ImageTag({ editorVersion, customImage }); const baseImage = new ImageTag({ editorVersion, customImage });
@ -46,6 +49,9 @@ export async function run() {
gitPrivateToken, gitPrivateToken,
githubToken, githubToken,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer, unityLicensingServer,
...runnerContext, ...runnerContext,
}); });

View File

@ -69,6 +69,8 @@ const Docker = {
githubToken, githubToken,
runnerTemporaryPath, runnerTemporaryPath,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
unityLicensingServer, unityLicensingServer,
} = parameters; } = parameters;
@ -126,6 +128,8 @@ const Docker = {
--volume "${actionFolder}/steps:/steps:z" \ --volume "${actionFolder}/steps:/steps:z" \
--volume "${actionFolder}/entrypoint.sh:/entrypoint.sh:z" \ --volume "${actionFolder}/entrypoint.sh:/entrypoint.sh:z" \
--volume "${actionFolder}/unity-config:/usr/share/unity3d/config/:z" \ --volume "${actionFolder}/unity-config:/usr/share/unity3d/config/:z" \
--cpus=${dockerCpuLimit} \
--memory=${dockerMemoryLimit} \
${sshAgent ? `--volume ${sshAgent}:/ssh-agent` : ''} \ ${sshAgent ? `--volume ${sshAgent}:/ssh-agent` : ''} \
${ ${
sshAgent && !sshPublicKeysDirectoryPath sshAgent && !sshPublicKeysDirectoryPath
@ -161,6 +165,9 @@ const Docker = {
githubToken, githubToken,
runnerTemporaryPath, runnerTemporaryPath,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer, unityLicensingServer,
} = parameters; } = parameters;
@ -222,6 +229,9 @@ const Docker = {
? `--volume c:/Users/Administrator/.ssh/known_hosts:c:/root/.ssh/known_hosts` ? `--volume c:/Users/Administrator/.ssh/known_hosts:c:/root/.ssh/known_hosts`
: '' : ''
} \ } \
--cpus=${dockerCpuLimit} \
--memory=${dockerMemoryLimit} \
--isolation=${dockerIsolationMode} \
${useHostNetwork ? '--net=host' : ''} \ ${useHostNetwork ? '--net=host' : ''} \
${githubToken ? '--env USE_EXIT_CODE=false' : '--env USE_EXIT_CODE=true'} \ ${githubToken ? '--env USE_EXIT_CODE=false' : '--env USE_EXIT_CODE=true'} \
${image} \ ${image} \

View File

@ -50,7 +50,7 @@ describe('ImageTag', () => {
targetPlatform: some.targetPlatform, targetPlatform: some.targetPlatform,
}); });
expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2099.1.1111-2`); expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2099.1.1111-3`);
}); });
it('returns customImage if given', () => { it('returns customImage if given', () => {
const image = new ImageTag({ const image = new ImageTag({
@ -65,13 +65,13 @@ describe('ImageTag', () => {
it('returns the specific build platform', () => { it('returns the specific build platform', () => {
const image = new ImageTag({ editorVersion: '2022.3.7f1', targetPlatform: 'WebGL' }); const image = new ImageTag({ editorVersion: '2022.3.7f1', targetPlatform: 'WebGL' });
expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2022.3.7f1-webgl-2`); expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2022.3.7f1-webgl-3`);
}); });
it('returns no specific build platform for generic targetPlatforms', () => { it('returns no specific build platform for generic targetPlatforms', () => {
const image = new ImageTag({ targetPlatform: 'NoTarget' }); const image = new ImageTag({ targetPlatform: 'NoTarget' });
expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2022.3.7f1-2`); expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2022.3.7f1-3`);
}); });
}); });
}); });

View File

@ -31,7 +31,7 @@ class ImageTag {
this.targetPlatform = targetPlatform; this.targetPlatform = targetPlatform;
this.targetPlatformSuffix = ImageTag.getTargetPlatformSuffix(targetPlatform, editorVersion); this.targetPlatformSuffix = ImageTag.getTargetPlatformSuffix(targetPlatform, editorVersion);
this.imagePlatformPrefix = ImageTag.getImagePlatformPrefix(process.platform); this.imagePlatformPrefix = ImageTag.getImagePlatformPrefix(process.platform);
this.imageRollingVersion = 2; this.imageRollingVersion = 3;
} }
static get versionPattern() { static get versionPattern() {

View File

@ -1,6 +1,7 @@
import UnityVersionParser from './unity-version-parser'; import UnityVersionParser from './unity-version-parser';
import fs from 'fs'; import fs from 'fs';
import { getInput } from '@actions/core'; import { getInput } from '@actions/core';
import os from 'os';
const Input = { const Input = {
get testModes() { get testModes() {
@ -85,6 +86,24 @@ const Input = {
const rawPackageMode = getInput('packageMode') || 'false'; const rawPackageMode = getInput('packageMode') || 'false';
let packageName = ''; let packageName = '';
const chownFilesTo = getInput('chownFilesTo') || ''; const chownFilesTo = getInput('chownFilesTo') || '';
const dockerCpuLimit = getInput('dockerCpuLimit') || os.cpus().length.toString();
const bytesInMegabyte = 1024 * 1024;
let memoryMultiplier;
switch (os.platform()) {
case 'linux':
memoryMultiplier = 0.95;
break;
case 'win32':
memoryMultiplier = 0.8;
break;
default:
memoryMultiplier = 0.75;
break;
}
const dockerMemoryLimit =
getInput('dockerMemoryLimit') ||
`${Math.floor((os.totalmem() / bytesInMegabyte) * memoryMultiplier)}m`;
const dockerIsolationMode = getInput('dockerIsolationMode') || 'default';
// Validate input // Validate input
if (!this.testModes.includes(testMode)) { if (!this.testModes.includes(testMode)) {
@ -159,6 +178,9 @@ const Input = {
packageMode, packageMode,
packageName, packageName,
chownFilesTo, chownFilesTo,
dockerCpuLimit,
dockerMemoryLimit,
dockerIsolationMode,
unityLicensingServer, unityLicensingServer,
}; };
}, },

1019
yarn.lock

File diff suppressed because it is too large Load Diff