Compare commits
	
		
			No commits in common. "main" and "v4.2.2" have entirely different histories. 
		
	
	
		|  | @ -14,8 +14,7 @@ | |||
|   "env": { | ||||
|     "node": true, | ||||
|     "es6": true, | ||||
|     "jest/globals": true, | ||||
|     "es2020": true | ||||
|     "jest/globals": true | ||||
|   }, | ||||
|   "rules": { | ||||
|     // Error out for code formatting errors | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ jobs: | |||
|         id: requestActivationFile | ||||
|         uses: game-ci/unity-request-activation-file@v2.0-alpha-1 | ||||
|       - name: Upload activation file | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         uses: actions/upload-artifact@v3 | ||||
|         with: | ||||
|           name: ${{ steps.requestActivationFile.outputs.filePath }} | ||||
|           path: ${{ steps.requestActivationFile.outputs.filePath }} | ||||
|  |  | |||
|  | @ -18,19 +18,12 @@ jobs: | |||
|         projectPath: | ||||
|           - test-project | ||||
|         unityVersion: | ||||
|           - 2021.3.45f1 | ||||
|           - 2021.3.32f1 | ||||
|           - 2022.3.13f1 | ||||
|           - 2023.2.2f1 | ||||
|         targetPlatform: | ||||
|           - StandaloneOSX # Build a MacOS executable | ||||
|           - iOS # Build an iOS executable | ||||
|         include: | ||||
|           # Additionally test enableGpu build for a standalone windows target | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: StandaloneOSX | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: StandaloneOSX | ||||
|             buildProfile: 'Assets/Settings/Build Profiles/Sample macOS Build Profile.asset' | ||||
| 
 | ||||
|     steps: | ||||
|       ########################### | ||||
|  | @ -66,13 +59,11 @@ jobs: | |||
|           UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} | ||||
|           UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} | ||||
|           UNITY_SERIAL: ${{ secrets.UNITY_SERIAL }} | ||||
|           UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }} | ||||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           buildProfile: ${{ matrix.buildProfile }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue | ||||
|           # We use dirty build because we are replacing the default project settings file above | ||||
|           allowDirtyBuild: true | ||||
|  | @ -82,6 +73,6 @@ jobs: | |||
|       ########################### | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: Build ${{ matrix.targetPlatform }} on MacOS (${{ matrix.unityVersion }})${{ matrix.buildProfile && '  With Build Profile' || '' }} | ||||
|           name: Build ${{ matrix.targetPlatform }} on MacOS (${{ matrix.unityVersion }}) | ||||
|           path: build | ||||
|           retention-days: 14 | ||||
|  |  | |||
|  | @ -36,8 +36,7 @@ env: | |||
| 
 | ||||
| jobs: | ||||
|   buildForAllPlatformsUbuntu: | ||||
|     name: | ||||
|       "${{ matrix.targetPlatform }} on ${{ matrix.unityVersion}}${{startsWith(matrix.buildProfile, 'Assets') && ' (via Build Profile)' || '' }}" | ||||
|     name: ${{ matrix.targetPlatform }} on ${{ matrix.unityVersion }} | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|  | @ -92,12 +91,6 @@ jobs: | |||
|           - targetPlatform: StandaloneWindows64 | ||||
|             additionalParameters: -standaloneBuildSubtarget Server | ||||
|             buildWithIl2cpp: true | ||||
|         include: | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: WebGL | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: WebGL | ||||
|             buildProfile: 'Assets/Settings/Build Profiles/Sample WebGL Build Profile.asset' | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Clear Space for Android Build | ||||
|  | @ -143,7 +136,6 @@ jobs: | |||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           buildProfile: ${{ matrix.buildProfile }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue ${{ matrix.additionalParameters }} | ||||
|  | @ -166,7 +158,6 @@ jobs: | |||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           buildProfile: ${{ matrix.buildProfile }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue ${{ matrix.additionalParameters }} | ||||
|  | @ -188,7 +179,6 @@ jobs: | |||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           buildProfile: ${{ matrix.buildProfile }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue ${{ matrix.additionalParameters }} | ||||
|  | @ -201,6 +191,7 @@ jobs: | |||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: | ||||
|             "Build ${{ matrix.targetPlatform }}${{ startsWith(matrix.buildProfile, 'Assets') && ' (via Build Profile)' || '' }} on Ubuntu (${{ matrix.unityVersion }}_il2cpp_${{ matrix.buildWithIl2cpp }}_params_${{ matrix.additionalParameters }})" | ||||
|             'Build ${{ matrix.targetPlatform }} on Ubuntu (${{ matrix.unityVersion }}_il2cpp_${{ matrix.buildWithIl2cpp | ||||
|             }}_params_${{ matrix.additionalParameters }})' | ||||
|           path: build | ||||
|           retention-days: 14 | ||||
|  |  | |||
|  | @ -26,20 +26,7 @@ jobs: | |||
|           - StandaloneWindows64 # Build a Windows 64-bit standalone. | ||||
|           - WSAPlayer # Build a UWP App | ||||
|           - tvOS # Build an Apple TV XCode project | ||||
|         enableGpu: | ||||
|           - false | ||||
|         include: | ||||
|           # Additionally test enableGpu build for a standalone windows target | ||||
|           - projectPath: test-project | ||||
|             unityVersion: 2023.2.2f1 | ||||
|             targetPlatform: StandaloneWindows64 | ||||
|             enableGpu: true | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: StandaloneWindows64 | ||||
|           - unityVersion: 6000.0.36f1 | ||||
|             targetPlatform: StandaloneWindows64 | ||||
|             buildProfile: 'Assets/Settings/Build Profiles/Sample Windows Build Profile.asset' | ||||
|    | ||||
| 
 | ||||
|     steps: | ||||
|       ########################### | ||||
|       #         Checkout        # | ||||
|  | @ -78,14 +65,11 @@ jobs: | |||
|           UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} | ||||
|           UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} | ||||
|           UNITY_SERIAL: ${{ secrets.UNITY_SERIAL }} | ||||
|           UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }} | ||||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           buildProfile: ${{ matrix.buildProfile }} | ||||
|           enableGpu: ${{ matrix.enableGpu }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue | ||||
|           allowDirtyBuild: true | ||||
|       # We use dirty build because we are replacing the default project settings file above | ||||
|  | @ -105,13 +89,11 @@ jobs: | |||
|           UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} | ||||
|           UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} | ||||
|           UNITY_SERIAL: ${{ secrets.UNITY_SERIAL }} | ||||
|           UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }} | ||||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           enableGpu: ${{ matrix.enableGpu }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue | ||||
|           allowDirtyBuild: true | ||||
|       # We use dirty build because we are replacing the default project settings file above | ||||
|  | @ -130,13 +112,11 @@ jobs: | |||
|           UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} | ||||
|           UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} | ||||
|           UNITY_SERIAL: ${{ secrets.UNITY_SERIAL }} | ||||
|           UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }} | ||||
|         with: | ||||
|           buildName: 'GameCI Test Build' | ||||
|           projectPath: ${{ matrix.projectPath }} | ||||
|           unityVersion: ${{ matrix.unityVersion }} | ||||
|           targetPlatform: ${{ matrix.targetPlatform }} | ||||
|           enableGpu: ${{ matrix.enableGpu }} | ||||
|           customParameters: -profile SomeProfile -someBoolean -someValue exampleValue | ||||
|           allowDirtyBuild: true | ||||
|       # We use dirty build because we are replacing the default project settings file above | ||||
|  | @ -146,6 +126,6 @@ jobs: | |||
|       ########################### | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: Build ${{ matrix.targetPlatform }} on Windows (${{ matrix.unityVersion }})${{ matrix.enableGpu && ' With GPU' || '' }}${{ matrix.buildProfile && '  With Build Profile' || '' }} | ||||
|           name: Build ${{ matrix.targetPlatform }} on Windows (${{ matrix.unityVersion }}) | ||||
|           path: build | ||||
|           retention-days: 14 | ||||
|  |  | |||
|  | @ -3,11 +3,6 @@ name: Cloud Runner CI Pipeline | |||
| on: | ||||
|   push: { branches: [cloud-runner-develop, cloud-runner-preview, main] } | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       runGithubIntegrationTests: | ||||
|         description: 'Run GitHub Checks integration tests' | ||||
|         required: false | ||||
|         default: 'false' | ||||
| 
 | ||||
| permissions: | ||||
|   checks: write | ||||
|  | @ -195,7 +190,6 @@ jobs: | |||
|           UNITY_EMAIL: ${{ secrets.UNITY_EMAIL }} | ||||
|           UNITY_PASSWORD: ${{ secrets.UNITY_PASSWORD }} | ||||
|           UNITY_SERIAL: ${{ secrets.UNITY_SERIAL }} | ||||
| 
 | ||||
|           AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||
|           AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||
|           GIT_PRIVATE_TOKEN: ${{ secrets.GIT_PRIVATE_TOKEN }} | ||||
|  | @ -207,25 +201,8 @@ jobs: | |||
|           providerStrategy: ${{ matrix.providerStrategy }} | ||||
|       - run: | | ||||
|           cp ./cloud-runner-cache/cache/${{ steps.unity-build.outputs.CACHE_KEY }}/build/${{ steps.unity-build.outputs.BUILD_ARTIFACT }} ${{ steps.unity-build.outputs.BUILD_ARTIFACT }} | ||||
|       - uses: actions/upload-artifact@v4 | ||||
|       - uses: actions/upload-artifact@v3 | ||||
|         with: | ||||
|           name: ${{ matrix.providerStrategy }} Build (${{ matrix.targetPlatform }}) | ||||
|           path: ${{ steps.unity-build.outputs.BUILD_ARTIFACT }} | ||||
|           retention-days: 14 | ||||
| 
 | ||||
|   githubChecksIntegration: | ||||
|     name: GitHub Checks Integration | ||||
|     runs-on: ubuntu-latest | ||||
|     if: github.event_name == 'workflow_dispatch' && github.event.inputs.runGithubIntegrationTests == 'true' | ||||
|     env: | ||||
|       RUN_GITHUB_INTEGRATION_TESTS: true | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version: 20 | ||||
|           cache: 'yarn' | ||||
|       - run: yarn install --frozen-lockfile | ||||
|       - run: yarn test cloud-runner-github-checks-integration-test --detectOpenHandles --forceExit --runInBand | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|  |  | |||
|  | @ -18,11 +18,7 @@ inputs: | |||
|   projectPath: | ||||
|     required: false | ||||
|     default: '' | ||||
|     description: 'Path to the project to be built, relative to the repository root.' | ||||
|   buildProfile: | ||||
|     required: false | ||||
|     default: '' | ||||
|     description: 'Path to the build profile to activate, relative to the project root.' | ||||
|     description: 'Relative path to the project to be built.' | ||||
|   buildName: | ||||
|     required: false | ||||
|     default: '' | ||||
|  |  | |||
|  | @ -6,9 +6,6 @@ using UnityBuilderAction.Reporting; | |||
| using UnityBuilderAction.Versioning; | ||||
| using UnityEditor; | ||||
| using UnityEditor.Build.Reporting; | ||||
| #if UNITY_6000_0_OR_NEWER | ||||
| using UnityEditor.Build.Profile; | ||||
| #endif | ||||
| using UnityEngine; | ||||
| 
 | ||||
| namespace UnityBuilderAction | ||||
|  | @ -20,9 +17,47 @@ namespace UnityBuilderAction | |||
|       // Gather values from args | ||||
|       var options = ArgumentsParser.GetValidatedOptions(); | ||||
| 
 | ||||
|       // Gather values from project | ||||
|       var scenes = EditorBuildSettings.scenes.Where(scene => scene.enabled).Select(s => s.path).ToArray(); | ||||
|        | ||||
|       // Get all buildOptions from options | ||||
|       BuildOptions buildOptions = BuildOptions.None; | ||||
|       foreach (string buildOptionString in Enum.GetNames(typeof(BuildOptions))) { | ||||
|         if (options.ContainsKey(buildOptionString)) { | ||||
|           BuildOptions buildOptionEnum = (BuildOptions) Enum.Parse(typeof(BuildOptions), buildOptionString); | ||||
|           buildOptions |= buildOptionEnum; | ||||
|         } | ||||
|       } | ||||
| 
 | ||||
| #if UNITY_2021_2_OR_NEWER | ||||
|       // Determine subtarget | ||||
|       StandaloneBuildSubtarget buildSubtarget; | ||||
|       if (!options.TryGetValue("standaloneBuildSubtarget", out var subtargetValue) || !Enum.TryParse(subtargetValue, out buildSubtarget)) { | ||||
|         buildSubtarget = default; | ||||
|       } | ||||
| #endif | ||||
| 
 | ||||
|       // Define BuildPlayer Options | ||||
|       var buildPlayerOptions = new BuildPlayerOptions { | ||||
|         scenes = scenes, | ||||
|         locationPathName = options["customBuildPath"], | ||||
|         target = (BuildTarget) Enum.Parse(typeof(BuildTarget), options["buildTarget"]), | ||||
|         options = buildOptions, | ||||
| #if UNITY_2021_2_OR_NEWER | ||||
|         subtarget = (int) buildSubtarget | ||||
| #endif | ||||
|       }; | ||||
| 
 | ||||
|       // Set version for this build | ||||
|       VersionApplicator.SetVersion(options["buildVersion"]); | ||||
| 
 | ||||
|        | ||||
|       // Apply Android settings | ||||
|       if (buildPlayerOptions.target == BuildTarget.Android) | ||||
|       { | ||||
|         VersionApplicator.SetAndroidVersionCode(options["androidVersionCode"]); | ||||
|         AndroidSettings.Apply(options); | ||||
|       } | ||||
|        | ||||
|       // Execute default AddressableAsset content build, if the package is installed. | ||||
|       // Version defines would be the best solution here, but Unity 2018 doesn't support that, | ||||
|       // so we fall back to using reflection instead. | ||||
|  | @ -39,89 +74,10 @@ namespace UnityBuilderAction | |||
|         } | ||||
|         catch (Exception e) | ||||
|         { | ||||
|           Debug.LogError("Failed to run default addressables build:\n" + e); | ||||
|           Debug.LogError($"Failed to run default addressables build:\n{e}"); | ||||
|         } | ||||
|       } | ||||
| 
 | ||||
|       // Get all buildOptions from options | ||||
|       BuildOptions buildOptions = BuildOptions.None; | ||||
|       foreach (string buildOptionString in Enum.GetNames(typeof(BuildOptions))) { | ||||
|         if (options.ContainsKey(buildOptionString)) { | ||||
|           BuildOptions buildOptionEnum = (BuildOptions) Enum.Parse(typeof(BuildOptions), buildOptionString); | ||||
|           buildOptions |= buildOptionEnum; | ||||
|         } | ||||
|       } | ||||
| 
 | ||||
|       // Depending on whether the build is using a build profile, `buildPlayerOptions` will an instance | ||||
|       // of either `UnityEditor.BuildPlayerOptions` or `UnityEditor.BuildPlayerWithProfileOptions` | ||||
|       dynamic buildPlayerOptions; | ||||
| 
 | ||||
|       if (options.TryGetValue("activeBuildProfile", out var buildProfilePath)) { | ||||
|         if (string.IsNullOrEmpty(buildProfilePath)) { | ||||
|           throw new Exception("`-activeBuildProfile` is set but with an empty value; this shouldn't happen"); | ||||
|         } | ||||
| 
 | ||||
| #if UNITY_6000_0_OR_NEWER | ||||
|         // Load build profile from Assets folder | ||||
|         var buildProfile = AssetDatabase.LoadAssetAtPath<BuildProfile>(buildProfilePath) | ||||
|                            ?? throw new Exception("Build profile file not found at path: " + buildProfilePath); | ||||
| 
 | ||||
| #if !BUILD_PROFILE_LOADED | ||||
|         throw new Exception("Build profile's define symbol not present before script execution; shouldn't happen"); | ||||
| #endif // BUILD_PROFILE_LOADED | ||||
| 
 | ||||
|         // no need to set active profile, as already set by `-activeBuildProfile` CLI argument | ||||
|         // BuildProfile.SetActiveBuildProfile(buildProfile); | ||||
|         Debug.Log($"build profile: {buildProfile.name}"); | ||||
| 
 | ||||
|         // Define BuildPlayerWithProfileOptions | ||||
|         buildPlayerOptions = new BuildPlayerWithProfileOptions { | ||||
|             buildProfile = buildProfile, | ||||
|             locationPathName = options["customBuildPath"], | ||||
|             options = buildOptions, | ||||
|         }; | ||||
| #else // UNITY_6000_0_OR_NEWER | ||||
|         throw new Exception("Build profiles are not supported by this version of Unity (" + Application.unityVersion +")"); | ||||
| #endif // UNITY_6000_0_OR_NEWER | ||||
| 
 | ||||
|       } else { | ||||
| 
 | ||||
| #if BUILD_PROFILE_LOADED | ||||
|         throw new Exception("Build profile's define symbol present; shouldn't happen"); | ||||
| #endif // BUILD_PROFILE_LOADED | ||||
| 
 | ||||
|         // Gather values from project | ||||
|         var scenes = EditorBuildSettings.scenes.Where(scene => scene.enabled).Select(s => s.path).ToArray(); | ||||
| 
 | ||||
| #if UNITY_2021_2_OR_NEWER | ||||
|         // Determine subtarget | ||||
|         StandaloneBuildSubtarget buildSubtarget; | ||||
|         if (!options.TryGetValue("standaloneBuildSubtarget", out var subtargetValue) || !Enum.TryParse(subtargetValue, out buildSubtarget)) { | ||||
|           buildSubtarget = default; | ||||
|         } | ||||
| #endif | ||||
| 
 | ||||
|         BuildTarget buildTarget = (BuildTarget) Enum.Parse(typeof(BuildTarget), options["buildTarget"]); | ||||
| 
 | ||||
|         // Define BuildPlayerOptions | ||||
|         buildPlayerOptions = new BuildPlayerOptions { | ||||
|           scenes = scenes, | ||||
|           locationPathName = options["customBuildPath"], | ||||
|           target = buildTarget, | ||||
|           options = buildOptions, | ||||
| #if UNITY_2021_2_OR_NEWER | ||||
|           subtarget = (int) buildSubtarget | ||||
| #endif | ||||
|         }; | ||||
| 
 | ||||
|         // Apply Android settings | ||||
|         if (buildTarget == BuildTarget.Android) { | ||||
|           VersionApplicator.SetAndroidVersionCode(options["androidVersionCode"]); | ||||
|           AndroidSettings.Apply(options); | ||||
|         } | ||||
| 
 | ||||
|       } | ||||
| 
 | ||||
|       // Perform build | ||||
|       BuildReport buildReport = BuildPipeline.BuildPlayer(buildPlayerOptions); | ||||
| 
 | ||||
|  |  | |||
|  | @ -56,17 +56,17 @@ namespace UnityBuilderAction.Input | |||
|           case "androidStudioProject": | ||||
|             EditorUserBuildSettings.exportAsGoogleAndroidProject = true; | ||||
|             if (buildAppBundle != null) | ||||
|               buildAppBundle.SetValue(null, false, null); | ||||
|               buildAppBundle.SetValue(null, false); | ||||
|             break; | ||||
|           case "androidAppBundle": | ||||
|             EditorUserBuildSettings.exportAsGoogleAndroidProject = false; | ||||
|             if (buildAppBundle != null) | ||||
|               buildAppBundle.SetValue(null, true, null); | ||||
|               buildAppBundle.SetValue(null, true); | ||||
|             break; | ||||
|           case "androidPackage": | ||||
|             EditorUserBuildSettings.exportAsGoogleAndroidProject = false; | ||||
|             if (buildAppBundle != null) | ||||
|               buildAppBundle.SetValue(null, false, null); | ||||
|               buildAppBundle.SetValue(null, false); | ||||
|             break; | ||||
|         } | ||||
|       } | ||||
|  | @ -74,20 +74,7 @@ namespace UnityBuilderAction.Input | |||
|       string symbolType; | ||||
|       if (options.TryGetValue("androidSymbolType", out symbolType) && !string.IsNullOrEmpty(symbolType)) | ||||
|       { | ||||
| #if UNITY_6000_0_OR_NEWER | ||||
|         switch (symbolType) | ||||
|         { | ||||
|           case "public": | ||||
|             SetDebugSymbols("SymbolTable"); | ||||
|             break; | ||||
|           case "debugging": | ||||
|             SetDebugSymbols("Full"); | ||||
|             break; | ||||
|           case "none": | ||||
|             SetDebugSymbols("None"); | ||||
|             break; | ||||
|         } | ||||
| #elif UNITY_2021_1_OR_NEWER | ||||
| #if UNITY_2021_1_OR_NEWER | ||||
|         switch (symbolType) | ||||
|         { | ||||
|           case "public": | ||||
|  | @ -114,37 +101,5 @@ namespace UnityBuilderAction.Input | |||
| #endif | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
| #if UNITY_6000_0_OR_NEWER | ||||
|     private static void SetDebugSymbols(string enumValueName) | ||||
|     { | ||||
|       // UnityEditor.Android.UserBuildSettings and Unity.Android.Types.DebugSymbolLevel are part of the Unity Android module. | ||||
|       // Reflection is used here to ensure the code works even if the module is not installed. | ||||
| 
 | ||||
|       var debugSymbolsType = Type.GetType("UnityEditor.Android.UserBuildSettings+DebugSymbols, UnityEditor.Android.Extensions"); | ||||
|       if (debugSymbolsType == null) | ||||
|       { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       var levelProp = debugSymbolsType.GetProperty("level", BindingFlags.Static | BindingFlags.Public); | ||||
|       if (levelProp == null) | ||||
|       { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       var enumType = Type.GetType("Unity.Android.Types.DebugSymbolLevel, Unity.Android.Types"); | ||||
|       if (enumType == null) | ||||
|       { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       if (!Enum.TryParse(enumType, enumValueName, false , out var enumValue)) | ||||
|       { | ||||
|         return; | ||||
|       } | ||||
|       levelProp.SetValue(null, enumValue); | ||||
|     } | ||||
| #endif | ||||
|   } | ||||
| } | ||||
|  |  | |||
|  | @ -21,19 +21,6 @@ namespace UnityBuilderAction.Input | |||
|         EditorApplication.Exit(110); | ||||
|       } | ||||
| 
 | ||||
| #if UNITY_6000_0_OR_NEWER | ||||
|       var buildProfileSupport = true; | ||||
| #else | ||||
|       var buildProfileSupport = false; | ||||
| #endif // UNITY_6000_0_OR_NEWER | ||||
| 
 | ||||
|       string buildProfile; | ||||
|       if (buildProfileSupport && validatedOptions.TryGetValue("activeBuildProfile", out buildProfile)) { | ||||
|         if (validatedOptions.ContainsKey("buildTarget")) { | ||||
|           Console.WriteLine("Extra argument -buildTarget"); | ||||
|           EditorApplication.Exit(122); | ||||
|         } | ||||
|       } else { | ||||
|       string buildTarget; | ||||
|       if (!validatedOptions.TryGetValue("buildTarget", out buildTarget)) { | ||||
|         Console.WriteLine("Missing argument -buildTarget"); | ||||
|  | @ -41,10 +28,9 @@ namespace UnityBuilderAction.Input | |||
|       } | ||||
| 
 | ||||
|       if (!Enum.IsDefined(typeof(BuildTarget), buildTarget)) { | ||||
|         Console.WriteLine(buildTarget + " is not a defined " + typeof(BuildTarget).Name); | ||||
|         Console.WriteLine($"{buildTarget} is not a defined {nameof(BuildTarget)}"); | ||||
|         EditorApplication.Exit(121); | ||||
|       } | ||||
|       } | ||||
| 
 | ||||
|       string customBuildPath; | ||||
|       if (!validatedOptions.TryGetValue("customBuildPath", out customBuildPath)) { | ||||
|  | @ -55,10 +41,10 @@ namespace UnityBuilderAction.Input | |||
|       const string defaultCustomBuildName = "TestBuild"; | ||||
|       string customBuildName; | ||||
|       if (!validatedOptions.TryGetValue("customBuildName", out customBuildName)) { | ||||
|         Console.WriteLine("Missing argument -customBuildName, defaulting to" + defaultCustomBuildName); | ||||
|         Console.WriteLine($"Missing argument -customBuildName, defaulting to {defaultCustomBuildName}."); | ||||
|         validatedOptions.Add("customBuildName", defaultCustomBuildName); | ||||
|       } else if (customBuildName == "") { | ||||
|         Console.WriteLine("Invalid argument -customBuildName, defaulting to" + defaultCustomBuildName); | ||||
|         Console.WriteLine($"Invalid argument -customBuildName, defaulting to {defaultCustomBuildName}."); | ||||
|         validatedOptions.Add("customBuildName", defaultCustomBuildName); | ||||
|       } | ||||
| 
 | ||||
|  | @ -71,11 +57,11 @@ namespace UnityBuilderAction.Input | |||
|       string[] args = Environment.GetCommandLineArgs(); | ||||
| 
 | ||||
|       Console.WriteLine( | ||||
|         EOL + | ||||
|         "###########################" + EOL + | ||||
|         "#    Parsing settings     #" + EOL + | ||||
|         "###########################" + EOL + | ||||
|         EOL | ||||
|         $"{EOL}" + | ||||
|         $"###########################{EOL}" + | ||||
|         $"#    Parsing settings     #{EOL}" + | ||||
|         $"###########################{EOL}" + | ||||
|         $"{EOL}" | ||||
|       ); | ||||
| 
 | ||||
|       // Extract flags with optional values | ||||
|  | @ -92,7 +78,7 @@ namespace UnityBuilderAction.Input | |||
|         string displayValue = secret ? "*HIDDEN*" : "\"" + value + "\""; | ||||
| 
 | ||||
|         // Assign | ||||
|         Console.WriteLine("Found flag \"" + flag + "\" with value " + displayValue); | ||||
|         Console.WriteLine($"Found flag \"{flag}\" with value {displayValue}."); | ||||
|         providedArguments.Add(flag, value); | ||||
|       } | ||||
|     } | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ namespace UnityBuilderAction.Reporting | |||
|                     prefix = "error"; | ||||
|                     break; | ||||
|             } | ||||
|             Console.WriteLine(Environment.NewLine + "::" + prefix + "::" + condition + Environment.NewLine + stackTrace); | ||||
|             Console.WriteLine($"{Environment.NewLine}::{prefix} ::{condition}{Environment.NewLine}{stackTrace}"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -11,16 +11,16 @@ namespace UnityBuilderAction.Reporting | |||
|     public static void ReportSummary(BuildSummary summary) | ||||
|     { | ||||
|       Console.WriteLine( | ||||
|         EOL + | ||||
|         "###########################" + EOL + | ||||
|         "#      Build results      #" + EOL + | ||||
|         "###########################" + EOL + | ||||
|         EOL + | ||||
|         "Duration: " + summary.totalTime.ToString() + EOL + | ||||
|         "Warnings: " + summary.totalWarnings.ToString() + EOL + | ||||
|         "Errors: " + summary.totalErrors.ToString() + EOL + | ||||
|         "Size: " + summary.totalSize.ToString() + " bytes" + EOL + | ||||
|         EOL | ||||
|         $"{EOL}" + | ||||
|         $"###########################{EOL}" + | ||||
|         $"#      Build results      #{EOL}" + | ||||
|         $"###########################{EOL}" + | ||||
|         $"{EOL}" + | ||||
|         $"Duration: {summary.totalTime.ToString()}{EOL}" + | ||||
|         $"Warnings: {summary.totalWarnings.ToString()}{EOL}" + | ||||
|         $"Errors: {summary.totalErrors.ToString()}{EOL}" + | ||||
|         $"Size: {summary.totalSize.ToString()} bytes{EOL}" + | ||||
|         $"{EOL}" | ||||
|       ); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -21,11 +21,11 @@ namespace UnityBuilderAction.Versioning | |||
|         version = GetSemanticCommitVersion(); | ||||
|         Console.WriteLine("Repository has a valid version tag."); | ||||
|       } else { | ||||
|         version = "0.0." + GetTotalNumberOfCommits(); | ||||
|         version = $"0.0.{GetTotalNumberOfCommits()}"; | ||||
|         Console.WriteLine("Repository does not have tags to base the version on."); | ||||
|       } | ||||
| 
 | ||||
|       Console.WriteLine("Version is " + version); | ||||
|       Console.WriteLine($"Version is {version}"); | ||||
| 
 | ||||
|       return version; | ||||
|     } | ||||
|  |  | |||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -4,69 +4,21 @@ | |||
| echo "Changing to \"$ACTIVATE_LICENSE_PATH\" directory." | ||||
| pushd "$ACTIVATE_LICENSE_PATH" | ||||
| 
 | ||||
| if [[ -n "$UNITY_SERIAL" && -n "$UNITY_EMAIL" && -n "$UNITY_PASSWORD" ]]; then | ||||
|   # | ||||
|   # SERIAL LICENSE MODE | ||||
|   # | ||||
|   # This will activate unity, using the serial activation process. | ||||
|   # | ||||
| echo "Requesting activation" | ||||
| 
 | ||||
|   echo "Requesting activation" | ||||
| # Activate license | ||||
| /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/MacOS/Unity \ | ||||
|   -logFile - \ | ||||
|   -batchmode \ | ||||
|   -nographics \ | ||||
|   -quit \ | ||||
|   -serial "$UNITY_SERIAL" \ | ||||
|   -username "$UNITY_EMAIL" \ | ||||
|   -password "$UNITY_PASSWORD" \ | ||||
|   -projectPath "$ACTIVATE_LICENSE_PATH" | ||||
| 
 | ||||
|   # Activate license | ||||
|   /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/MacOS/Unity \ | ||||
|     -logFile - \ | ||||
|     -batchmode \ | ||||
|     -nographics \ | ||||
|     -quit \ | ||||
|     -serial "$UNITY_SERIAL" \ | ||||
|     -username "$UNITY_EMAIL" \ | ||||
|     -password "$UNITY_PASSWORD" \ | ||||
|     -projectPath "$ACTIVATE_LICENSE_PATH" | ||||
| 
 | ||||
|   # Store the exit code from the verify command | ||||
|   UNITY_EXIT_CODE=$? | ||||
| 
 | ||||
| elif [[ -n "$UNITY_LICENSING_SERVER" ]]; then | ||||
|   # | ||||
|   # Custom Unity License Server | ||||
|   # | ||||
|   echo "Adding licensing server config" | ||||
|   mkdir -p "$UNITY_LICENSE_PATH/config/" | ||||
|   cp "$ACTION_FOLDER/unity-config/services-config.json" "$UNITY_LICENSE_PATH/config/services-config.json" | ||||
| 
 | ||||
|   /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/Frameworks/UnityLicensingClient.app/Contents/MacOS/Unity.Licensing.Client \ | ||||
|     --acquire-floating > license.txt | ||||
| 
 | ||||
|   # Store the exit code from the verify command | ||||
|   UNITY_EXIT_CODE=$? | ||||
| 
 | ||||
|   if [ $UNITY_EXIT_CODE -eq 0 ]; then | ||||
|     PARSEDFILE=$(grep -oE '\"[^"]*\"' < license.txt | tr -d '"') | ||||
|     export FLOATING_LICENSE | ||||
|     FLOATING_LICENSE=$(sed -n 2p <<< "$PARSEDFILE") | ||||
|     FLOATING_LICENSE_TIMEOUT=$(sed -n 4p <<< "$PARSEDFILE") | ||||
| 
 | ||||
|     echo "Acquired floating license: \"$FLOATING_LICENSE\" with timeout $FLOATING_LICENSE_TIMEOUT" | ||||
|   fi | ||||
| else | ||||
|   # | ||||
|   # NO LICENSE ACTIVATION STRATEGY MATCHED | ||||
|   # | ||||
|   # This will exit since no activation strategies could be matched. | ||||
|   # | ||||
|   echo "License activation strategy could not be determined." | ||||
|   echo "" | ||||
|   echo "Visit https://game.ci/docs/github/activation for more" | ||||
|   echo "details on how to set up one of the possible activation strategies." | ||||
| 
 | ||||
|   echo "::error ::No valid license activation strategy could be determined. Make sure to provide UNITY_EMAIL, UNITY_PASSWORD, and either a UNITY_SERIAL \ | ||||
| or UNITY_LICENSE. Otherwise please use UNITY_LICENSING_SERVER. See more info at https://game.ci/docs/github/activation" | ||||
| 
 | ||||
|   # Immediately exit as no UNITY_EXIT_CODE can be derived. | ||||
|   exit 1; | ||||
| 
 | ||||
| fi | ||||
| # Store the exit code from the verify command | ||||
| UNITY_EXIT_CODE=$? | ||||
| 
 | ||||
| # | ||||
| # Display information about the result | ||||
|  |  | |||
|  | @ -19,23 +19,6 @@ echo "Using build name \"$BUILD_NAME\"." | |||
| 
 | ||||
| echo "Using build target \"$BUILD_TARGET\"." | ||||
| 
 | ||||
| # | ||||
| # Display the build profile | ||||
| # | ||||
| 
 | ||||
| if [ -z "$BUILD_PROFILE" ]; then | ||||
|   # User has not provided a build profile | ||||
|   # | ||||
|   echo "Doing a default \"$BUILD_TARGET\" platform build." | ||||
|   # | ||||
| else | ||||
|   # User has provided a path to a build profile `.asset` file | ||||
|   # | ||||
|   echo "Using build profile \"$BUILD_PROFILE\" relative to \"$UNITY_PROJECT_PATH\"." | ||||
|   # | ||||
| fi | ||||
| 
 | ||||
| 
 | ||||
| # | ||||
| # Display build path and file | ||||
| # | ||||
|  | @ -149,13 +132,13 @@ echo "" | |||
|   $( [ "${MANUAL_EXIT}" == "true" ] || echo "-quit" ) \ | ||||
|   -batchmode \ | ||||
|   $( [ "${ENABLE_GPU}" == "true" ] || echo "-nographics" ) \ | ||||
|   -username "$UNITY_EMAIL" \ | ||||
|   -password "$UNITY_PASSWORD" \ | ||||
|   -customBuildName "$BUILD_NAME" \ | ||||
|   -projectPath "$UNITY_PROJECT_PATH" \ | ||||
|   $( [ -z "$BUILD_PROFILE" ] && echo "-buildTarget $BUILD_TARGET") \ | ||||
|   -buildTarget "$BUILD_TARGET" \ | ||||
|   -customBuildTarget "$BUILD_TARGET" \ | ||||
|   -customBuildPath "$CUSTOM_BUILD_PATH" \ | ||||
|   -customBuildProfile "$BUILD_PROFILE" \ | ||||
|   ${BUILD_PROFILE:+-activeBuildProfile} ${BUILD_PROFILE:+"$BUILD_PROFILE"} \ | ||||
|   -executeMethod "$BUILD_METHOD" \ | ||||
|   -buildVersion "$VERSION" \ | ||||
|   -androidVersionCode "$ANDROID_VERSION_CODE" \ | ||||
|  |  | |||
|  | @ -4,29 +4,15 @@ | |||
| echo "Changing to \"$ACTIVATE_LICENSE_PATH\" directory." | ||||
| pushd "$ACTIVATE_LICENSE_PATH" | ||||
| 
 | ||||
| if [[ -n "$UNITY_LICENSING_SERVER" ]]; then | ||||
|   # | ||||
|   # Return any floating license used. | ||||
|   # | ||||
|   echo "Returning floating license: \"$FLOATING_LICENSE\"" | ||||
|   /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/Frameworks/UnityLicensingClient.app/Contents/MacOS/Unity.Licensing.Client \ | ||||
|     --return-floating "$FLOATING_LICENSE" | ||||
| elif [[ -n "$UNITY_SERIAL" ]]; then | ||||
|   # | ||||
|   # SERIAL LICENSE MODE | ||||
|   # | ||||
|   # This will return the license that is currently in use. | ||||
|   # | ||||
|   /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/MacOS/Unity \ | ||||
|     -logFile - \ | ||||
|     -batchmode \ | ||||
|     -nographics \ | ||||
|     -quit \ | ||||
|     -username "$UNITY_EMAIL" \ | ||||
|     -password "$UNITY_PASSWORD" \ | ||||
|     -returnlicense \ | ||||
|     -projectPath "$ACTIVATE_LICENSE_PATH" | ||||
| fi | ||||
| /Applications/Unity/Hub/Editor/$UNITY_VERSION/Unity.app/Contents/MacOS/Unity \ | ||||
|   -logFile - \ | ||||
|   -batchmode \ | ||||
|   -nographics \ | ||||
|   -quit \ | ||||
|   -username "$UNITY_EMAIL" \ | ||||
|   -password "$UNITY_PASSWORD" \ | ||||
|   -returnlicense \ | ||||
|   -projectPath "$ACTIVATE_LICENSE_PATH" | ||||
| 
 | ||||
| # Return to previous working directory | ||||
| popd | ||||
|  |  | |||
|  | @ -68,18 +68,14 @@ elif [[ -n "$UNITY_LICENSING_SERVER" ]]; then | |||
|   echo "Adding licensing server config" | ||||
| 
 | ||||
|   /opt/unity/Editor/Data/Resources/Licensing/Client/Unity.Licensing.Client --acquire-floating > license.txt #is this accessible in a env variable? | ||||
|   PARSEDFILE=$(grep -oP '\".*?\"' < license.txt | tr -d '"') | ||||
|   export FLOATING_LICENSE | ||||
|   FLOATING_LICENSE=$(sed -n 2p <<< "$PARSEDFILE") | ||||
|   FLOATING_LICENSE_TIMEOUT=$(sed -n 4p <<< "$PARSEDFILE") | ||||
| 
 | ||||
|   echo "Acquired floating license: \"$FLOATING_LICENSE\" with timeout $FLOATING_LICENSE_TIMEOUT" | ||||
|   # Store the exit code from the verify command | ||||
|   UNITY_EXIT_CODE=$? | ||||
| 
 | ||||
|   if [ $UNITY_EXIT_CODE -eq 0 ]; then | ||||
|     PARSEDFILE=$(grep -oP '\".*?\"' < license.txt | tr -d '"') | ||||
|     export FLOATING_LICENSE | ||||
|     FLOATING_LICENSE=$(sed -n 2p <<< "$PARSEDFILE") | ||||
|     FLOATING_LICENSE_TIMEOUT=$(sed -n 4p <<< "$PARSEDFILE") | ||||
| 
 | ||||
|     echo "Acquired floating license: \"$FLOATING_LICENSE\" with timeout $FLOATING_LICENSE_TIMEOUT" | ||||
|   fi | ||||
| else | ||||
|   # | ||||
|   # NO LICENSE ACTIVATION STRATEGY MATCHED | ||||
|  |  | |||
|  | @ -19,22 +19,6 @@ echo "Using build name \"$BUILD_NAME\"." | |||
| 
 | ||||
| echo "Using build target \"$BUILD_TARGET\"." | ||||
| 
 | ||||
| # | ||||
| # Display the build profile | ||||
| # | ||||
| 
 | ||||
| if [ -z "$BUILD_PROFILE" ]; then | ||||
|   # User has not provided a build profile | ||||
|   # | ||||
|   echo "Doing a default \"$BUILD_TARGET\" platform build." | ||||
|   # | ||||
| else | ||||
|   # User has provided a path to a build profile `.asset` file | ||||
|   # | ||||
|   echo "Using build profile \"$BUILD_PROFILE\" relative to \"$UNITY_PROJECT_PATH\"." | ||||
|   # | ||||
| fi | ||||
| 
 | ||||
| # | ||||
| # Display build path and file | ||||
| # | ||||
|  | @ -125,11 +109,9 @@ unity-editor \ | |||
|   $( [ "${MANUAL_EXIT}" == "true" ] || echo "-quit" ) \ | ||||
|   -customBuildName "$BUILD_NAME" \ | ||||
|   -projectPath "$UNITY_PROJECT_PATH" \ | ||||
|   $( [ -z "$BUILD_PROFILE" ] && echo "-buildTarget $BUILD_TARGET" ) \ | ||||
|   -buildTarget "$BUILD_TARGET" \ | ||||
|   -customBuildTarget "$BUILD_TARGET" \ | ||||
|   -customBuildPath "$CUSTOM_BUILD_PATH" \ | ||||
|   -customBuildProfile "$BUILD_PROFILE" \ | ||||
|   ${BUILD_PROFILE:+-activeBuildProfile} ${BUILD_PROFILE:+"$BUILD_PROFILE"} \ | ||||
|   -executeMethod "$BUILD_METHOD" \ | ||||
|   -buildVersion "$VERSION" \ | ||||
|   -androidVersionCode "$ANDROID_VERSION_CODE" \ | ||||
|  |  | |||
|  | @ -50,30 +50,6 @@ if ( ($null -ne ${env:UNITY_SERIAL}) -and ($null -ne ${env:UNITY_EMAIL}) -and ($ | |||
|       Start-Sleep -Seconds 3 | ||||
|   } | ||||
| } | ||||
| elseif( ($null -ne ${env:UNITY_LICENSING_SERVER})) | ||||
| { | ||||
|     # | ||||
|     # Custom Unity License Server | ||||
|     # | ||||
| 
 | ||||
|     Write-Output "Adding licensing server config" | ||||
| 
 | ||||
|     $ACTIVATION_OUTPUT = Start-Process -FilePath "$Env:UNITY_PATH\Editor\Data\Resources\Licensing\Client\Unity.Licensing.Client.exe" ` | ||||
|                                        -ArgumentList "--acquire-floating" ` | ||||
|                                        -NoNewWindow ` | ||||
|                                        -PassThru ` | ||||
|                                        -Wait ` | ||||
|                                        -RedirectStandardOutput "license.txt" | ||||
| 
 | ||||
|     $PARSEDFILE = (Get-Content "license.txt" | Select-String -AllMatches -Pattern '\".*?\"' | ForEach-Object { $_.Matches.Value }) -replace '"' | ||||
| 
 | ||||
|     $env:FLOATING_LICENSE = $PARSEDFILE[1] | ||||
|     $FLOATING_LICENSE_TIMEOUT = $PARSEDFILE[3] | ||||
| 
 | ||||
|     Write-Output "Acquired floating license: ""$env:FLOATING_LICENSE"" with timeout $FLOATING_LICENSE_TIMEOUT" | ||||
|     # Store the exit code from the verify command | ||||
|     $ACTIVATION_EXIT_CODE = $ACTIVATION_OUTPUT.ExitCode | ||||
| } | ||||
| else | ||||
| { | ||||
|     # | ||||
|  |  | |||
|  | @ -16,25 +16,6 @@ Write-Output "$('Using build name "')$($Env:BUILD_NAME)$('".')" | |||
| 
 | ||||
| Write-Output "$('Using build target "')$($Env:BUILD_TARGET)$('".')" | ||||
| 
 | ||||
| # | ||||
| # Display the build profile | ||||
| # | ||||
| 
 | ||||
| if ($Env:BUILD_PROFILE) | ||||
| { | ||||
|   # User has provided a path to a build profile `.asset` file | ||||
|   # | ||||
|   Write-Output "$('Using build profile "')$($Env:BUILD_PROFILE)$('" relative to "')$($Env:UNITY_PROJECT_PATH)$('".')" | ||||
|   # | ||||
| } | ||||
| else | ||||
| { | ||||
|   # User has not provided a build profile | ||||
|   # | ||||
|   Write-Output "$('Doing a default "')$($Env:BUILD_TARGET)$('" platform build.')" | ||||
|   # | ||||
| } | ||||
| 
 | ||||
| # | ||||
| # Display build path and file | ||||
| # | ||||
|  | @ -148,27 +129,20 @@ Write-Output "#    Building project     #" | |||
| Write-Output "###########################" | ||||
| Write-Output "" | ||||
| 
 | ||||
| $unityGraphics = "-nographics" | ||||
| 
 | ||||
| if ($LLVMPIPE_INSTALLED -eq "true") | ||||
| { | ||||
|   $unityGraphics = "-force-opengl" | ||||
| } | ||||
| 
 | ||||
| # If $Env:CUSTOM_PARAMETERS contains spaces and is passed directly on the command line to Unity, powershell will wrap it | ||||
| # in double quotes.  To avoid this, parse $Env:CUSTOM_PARAMETERS into an array, while respecting any quotations within the string. | ||||
| $_, $customParametersArray = Invoke-Expression('Write-Output -- "" ' + $Env:CUSTOM_PARAMETERS) | ||||
| $unityArgs = @( | ||||
|     "-quit", | ||||
|     "-batchmode", | ||||
|     $unityGraphics, | ||||
|     "-nographics", | ||||
|     "-silent-crashes", | ||||
|     "-customBuildName", "`"$Env:BUILD_NAME`"", | ||||
|     "-projectPath", "`"$Env:UNITY_PROJECT_PATH`"", | ||||
|     "-executeMethod", "`"$Env:BUILD_METHOD`"", | ||||
|     "-buildTarget", "`"$Env:BUILD_TARGET`"", | ||||
|     "-customBuildTarget", "`"$Env:BUILD_TARGET`"", | ||||
|     "-customBuildPath", "`"$Env:CUSTOM_BUILD_PATH`"", | ||||
|     "-customBuildProfile", "`"$Env:BUILD_PROFILE`"", | ||||
|     "-buildVersion", "`"$Env:VERSION`"", | ||||
|     "-androidVersionCode", "`"$Env:ANDROID_VERSION_CODE`"", | ||||
|     "-androidKeystorePass", "`"$Env:ANDROID_KEYSTORE_PASS`"", | ||||
|  | @ -180,13 +154,6 @@ $unityArgs = @( | |||
|     "-logfile", "-" | ||||
| ) + $customParametersArray | ||||
| 
 | ||||
| if (-not $Env:BUILD_PROFILE) { | ||||
|     $unityArgs += @("-buildTarget", "`"$Env:BUILD_TARGET`"") | ||||
| } | ||||
| if ($Env:BUILD_PROFILE) { | ||||
|     $unityArgs += @("-activeBuildProfile", "`"$Env:BUILD_PROFILE`"") | ||||
| } | ||||
| 
 | ||||
| # Remove null items as that will fail the Start-Process call | ||||
| $unityArgs = $unityArgs | Where-Object { $_ -ne $null } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,13 +1,5 @@ | |||
| Get-Process | ||||
| 
 | ||||
| # Copy .upmconfig.toml if it exists | ||||
| if (Test-Path "C:\githubhome\.upmconfig.toml") { | ||||
|   Write-Host "Copying .upmconfig.toml to $Env:USERPROFILE\.upmconfig.toml" | ||||
|   Copy-Item -Path "C:\githubhome\.upmconfig.toml" -Destination "$Env:USERPROFILE\.upmconfig.toml" -Force | ||||
| } else { | ||||
|   Write-Host "No .upmconfig.toml found at C:\githubhome" | ||||
| } | ||||
| 
 | ||||
| # Import any necessary registry keys, ie: location of windows 10 sdk | ||||
| # No guarantee that there will be any necessary registry keys, ie: tvOS | ||||
| Get-ChildItem -Path c:\regkeys -File | ForEach-Object { reg import $_.fullname } | ||||
|  | @ -21,11 +13,6 @@ Get-Process -Name regsvr32 | ForEach-Object { Stop-Process -Id $_.Id -Force } | |||
| # Setup Git Credentials | ||||
| . "c:\steps\set_gitcredential.ps1" | ||||
| 
 | ||||
| if ($env:ENABLE_GPU -eq "true") { | ||||
|   # Install LLVMpipe software graphics driver | ||||
|   . "c:\steps\install_llvmpipe.ps1" | ||||
| } | ||||
| 
 | ||||
| # Activate Unity | ||||
| if ($env:SKIP_ACTIVATION -ne "true") { | ||||
|   . "c:\steps\activate.ps1" | ||||
|  |  | |||
|  | @ -1,56 +0,0 @@ | |||
| $Private:repo = "mmozeiko/build-mesa" | ||||
| $Private:downloadPath = "$Env:TEMP\mesa.zip" | ||||
| $Private:extractPath = "$Env:TEMP\mesa" | ||||
| $Private:destinationPath = "$Env:UNITY_PATH\Editor\" | ||||
| $Private:version = "25.1.0" | ||||
| 
 | ||||
| $LLVMPIPE_INSTALLED = "false" | ||||
| 
 | ||||
| try { | ||||
|     # Get the release info from GitHub API (version fixed to decrease probability of breakage) | ||||
|     $releaseUrl = "https://api.github.com/repos/$repo/releases/tags/$version" | ||||
|     $release = Invoke-RestMethod -Uri $releaseUrl -Headers @{ "User-Agent" = "PowerShell" } | ||||
| 
 | ||||
|     # Get the download URL for the zip asset | ||||
|     $zipUrl = $release.assets | Where-Object { $_.name -like "mesa-llvmpipe-x64*.zip" } | Select-Object -First 1 -ExpandProperty browser_download_url | ||||
| 
 | ||||
|     if (-not $zipUrl) { | ||||
|         throw "No zip file found in the latest release." | ||||
|     } | ||||
| 
 | ||||
|     # Download the zip file | ||||
|     Write-Host "Downloading $zipUrl..." | ||||
|     Invoke-WebRequest -Uri $zipUrl -OutFile $downloadPath | ||||
| 
 | ||||
|     # Create extraction directory if it doesn't exist | ||||
|     if (-not (Test-Path $extractPath)) { | ||||
|         New-Item -ItemType Directory -Path $extractPath | Out-Null | ||||
|     } | ||||
| 
 | ||||
|     # Extract the zip file | ||||
|     Write-Host "Extracting $downloadPath to $extractPath..." | ||||
|     Expand-Archive -Path $downloadPath -DestinationPath $extractPath -Force | ||||
| 
 | ||||
|     # Create destination directory if it doesn't exist | ||||
|     if (-not (Test-Path $destinationPath)) { | ||||
|         New-Item -ItemType Directory -Path $destinationPath | Out-Null | ||||
|     } | ||||
| 
 | ||||
|     # Copy extracted files to destination | ||||
|     Write-Host "Copying files to $destinationPath..." | ||||
|     Copy-Item -Path "$extractPath\*" -Destination $destinationPath -Recurse -Force | ||||
| 
 | ||||
|     Write-Host "Successfully downloaded, extracted, and copied Mesa files to $destinationPath" | ||||
| 
 | ||||
|     $LLVMPIPE_INSTALLED = "true" | ||||
| } catch { | ||||
|     Write-Error "An error occurred: $_" | ||||
| } finally { | ||||
|     # Clean up temporary files | ||||
|     if (Test-Path $downloadPath) { | ||||
|         Remove-Item $downloadPath -Force | ||||
|     } | ||||
|     if (Test-Path $extractPath) { | ||||
|         Remove-Item $extractPath -Recurse -Force | ||||
|     } | ||||
| } | ||||
|  | @ -6,16 +6,7 @@ Write-Output "#      Return License     #" | |||
| Write-Output "###########################" | ||||
| Write-Output "" | ||||
| 
 | ||||
| if (($null -ne ${env:UNITY_LICENSING_SERVER})) | ||||
| { | ||||
|   Write-Output "Returning floating license: ""$env:FLOATING_LICENSE""" | ||||
|   Start-Process -FilePath "$Env:UNITY_PATH\Editor\Data\Resources\Licensing\Client\Unity.Licensing.Client.exe" ` | ||||
|                 -ArgumentList "--return-floating ""$env:FLOATING_LICENSE"" " ` | ||||
|                 -NoNewWindow ` | ||||
|                 -Wait | ||||
| } | ||||
| 
 | ||||
| elseif (($null -ne ${env:UNITY_SERIAL}) -and ($null -ne ${env:UNITY_EMAIL}) -and ($null -ne ${env:UNITY_PASSWORD})) | ||||
| if (($null -ne ${env:UNITY_SERIAL}) -and ($null -ne ${env:UNITY_EMAIL}) -and ($null -ne ${env:UNITY_PASSWORD})) | ||||
| { | ||||
|   # | ||||
|   # SERIAL LICENSE MODE | ||||
|  |  | |||
|  | @ -5,12 +5,12 @@ else { | |||
|     Write-Host "GIT_PRIVATE_TOKEN is set configuring git credentials" | ||||
| 
 | ||||
|     git config --global credential.helper store | ||||
|     git config --global --replace-all url."https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "ssh://git@github.com/" | ||||
|     git config --global --add url."https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "git@github.com" | ||||
|     git config --global --add url."https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "https://github.com/" | ||||
|     git config --global --replace-all "url.https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "ssh://git@github.com/" | ||||
|     git config --global --add "url.https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "git@github.com" | ||||
|     git config --global --add "url.https://token:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "https://github.com/" | ||||
| 
 | ||||
|     git config --global url."https://ssh:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "ssh://git@github.com/" | ||||
|     git config --global url."https://git:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "git@github.com:" | ||||
|     git config --global "url.https://ssh:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "ssh://git@github.com/" | ||||
|     git config --global "url.https://git:$env:GIT_PRIVATE_TOKEN@github.com/".insteadOf "git@github.com:" | ||||
| } | ||||
| 
 | ||||
| Write-Host "---------- git config --list -------------" | ||||
|  |  | |||
|  | @ -25,8 +25,6 @@ module.exports = { | |||
|   // An array of regexp pattern strings, matched against all module paths before considered 'visible' to the module loader
 | ||||
|   modulePathIgnorePatterns: ['<rootDir>/lib/', '<rootDir>/dist/'], | ||||
| 
 | ||||
|   // Files that will be run before Jest is loaded to set globals like fetch
 | ||||
|   setupFiles: ['<rootDir>/src/jest.globals.ts'], | ||||
|   // A list of paths to modules that run some code to configure or set up the testing framework after the environment is ready
 | ||||
|   // A list of paths to modules that run some code to configure or set up the testing framework before each test
 | ||||
|   setupFilesAfterEnv: ['<rootDir>/src/jest.setup.ts'], | ||||
| }; | ||||
|  |  | |||
							
								
								
									
										11
									
								
								package.json
								
								
								
								
							
							
						
						
									
										11
									
								
								package.json
								
								
								
								
							|  | @ -28,15 +28,10 @@ | |||
|     "node": ">=18.x" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@actions/cache": "^4.0.0", | ||||
|     "@actions/core": "^1.11.1", | ||||
|     "@actions/cache": "^3.2.4", | ||||
|     "@actions/core": "^1.10.1", | ||||
|     "@actions/exec": "^1.1.1", | ||||
|     "@actions/github": "^6.0.0", | ||||
|     "@aws-sdk/client-cloudformation": "^3.777.0", | ||||
|     "@aws-sdk/client-cloudwatch-logs": "^3.777.0", | ||||
|     "@aws-sdk/client-ecs": "^3.778.0", | ||||
|     "@aws-sdk/client-kinesis": "^3.777.0", | ||||
|     "@aws-sdk/client-s3": "^3.779.0", | ||||
|     "@kubernetes/client-node": "^0.16.3", | ||||
|     "@octokit/core": "^5.1.0", | ||||
|     "async-wait-until": "^2.0.12", | ||||
|  | @ -50,7 +45,7 @@ | |||
|     "reflect-metadata": "^0.1.13", | ||||
|     "semver": "^7.5.2", | ||||
|     "ts-md5": "^1.3.1", | ||||
|     "unity-changeset": "^3.1.0", | ||||
|     "unity-changeset": "^2.0.0", | ||||
|     "uuid": "^9.0.0", | ||||
|     "yaml": "^2.2.2" | ||||
|   }, | ||||
|  |  | |||
|  | @ -1,29 +0,0 @@ | |||
| // Integration test for exercising real GitHub check creation and updates.
 | ||||
| import CloudRunner from '../model/cloud-runner/cloud-runner'; | ||||
| import UnityVersioning from '../model/unity-versioning'; | ||||
| import GitHub from '../model/github'; | ||||
| import { TIMEOUT_INFINITE, createParameters } from '../test-utils/cloud-runner-test-helpers'; | ||||
| 
 | ||||
| const runIntegration = process.env.RUN_GITHUB_INTEGRATION_TESTS === 'true'; | ||||
| const describeOrSkip = runIntegration ? describe : describe.skip; | ||||
| 
 | ||||
| describeOrSkip('Cloud Runner Github Checks Integration', () => { | ||||
|   it( | ||||
|     'creates and updates a real GitHub check', | ||||
|     async () => { | ||||
|       const buildParameter = await createParameters({ | ||||
|         versioning: 'None', | ||||
|         projectPath: 'test-project', | ||||
|         unityVersion: UnityVersioning.read('test-project'), | ||||
|         asyncCloudRunner: `true`, | ||||
|         githubChecks: `true`, | ||||
|       }); | ||||
|       await CloudRunner.setup(buildParameter); | ||||
|       const checkId = await GitHub.createGitHubCheck(`integration create`); | ||||
|       expect(checkId).not.toEqual(''); | ||||
|       await GitHub.updateGitHubCheck(`1 ${new Date().toISOString()}`, `integration`); | ||||
|       await GitHub.updateGitHubCheck(`2 ${new Date().toISOString()}`, `integration`, `success`, `completed`); | ||||
|     }, | ||||
|     TIMEOUT_INFINITE, | ||||
|   ); | ||||
| }); | ||||
|  | @ -1,3 +0,0 @@ | |||
| import { fetch as undiciFetch, Headers, Request, Response } from 'undici'; | ||||
| 
 | ||||
| Object.assign(globalThis, { fetch: undiciFetch, Headers, Request, Response }); | ||||
|  | @ -71,12 +71,6 @@ describe('BuildParameters', () => { | |||
|       await expect(BuildParameters.create()).resolves.toEqual(expect.objectContaining({ projectPath: mockValue })); | ||||
|     }); | ||||
| 
 | ||||
|     it('returns the build profile', async () => { | ||||
|       const mockValue = 'path/to/build_profile.asset'; | ||||
|       jest.spyOn(Input, 'buildProfile', 'get').mockReturnValue(mockValue); | ||||
|       await expect(BuildParameters.create()).resolves.toEqual(expect.objectContaining({ buildProfile: mockValue })); | ||||
|     }); | ||||
| 
 | ||||
|     it('returns the build name', async () => { | ||||
|       const mockValue = 'someBuildName'; | ||||
|       jest.spyOn(Input, 'buildName', 'get').mockReturnValue(mockValue); | ||||
|  |  | |||
|  | @ -26,7 +26,6 @@ class BuildParameters { | |||
|   public runnerTempPath!: string; | ||||
|   public targetPlatform!: string; | ||||
|   public projectPath!: string; | ||||
|   public buildProfile!: string; | ||||
|   public buildName!: string; | ||||
|   public buildPath!: string; | ||||
|   public buildFile!: string; | ||||
|  | @ -153,7 +152,6 @@ class BuildParameters { | |||
|       runnerTempPath: Input.runnerTempPath, | ||||
|       targetPlatform: Input.targetPlatform, | ||||
|       projectPath: Input.projectPath, | ||||
|       buildProfile: Input.buildProfile, | ||||
|       buildName: Input.buildName, | ||||
|       buildPath: `${Input.buildsPath}/${Input.targetPlatform}`, | ||||
|       buildFile, | ||||
|  |  | |||
|  | @ -1,18 +1,6 @@ | |||
| import CloudRunnerLogger from '../../services/core/cloud-runner-logger'; | ||||
| import * as core from '@actions/core'; | ||||
| import { | ||||
|   CloudFormation, | ||||
|   CreateStackCommand, | ||||
|   CreateStackCommandInput, | ||||
|   DescribeStacksCommand, | ||||
|   DescribeStacksCommandInput, | ||||
|   ListStacksCommand, | ||||
|   Parameter, | ||||
|   UpdateStackCommand, | ||||
|   UpdateStackCommandInput, | ||||
|   waitUntilStackCreateComplete, | ||||
|   waitUntilStackUpdateComplete, | ||||
| } from '@aws-sdk/client-cloudformation'; | ||||
| import * as SDK from 'aws-sdk'; | ||||
| import { BaseStackFormation } from './cloud-formations/base-stack-formation'; | ||||
| import crypto from 'node:crypto'; | ||||
| 
 | ||||
|  | @ -22,49 +10,51 @@ export class AWSBaseStack { | |||
|   } | ||||
|   private baseStackName: string; | ||||
| 
 | ||||
|   async setupBaseStack(CF: CloudFormation) { | ||||
|   async setupBaseStack(CF: SDK.CloudFormation) { | ||||
|     const baseStackName = this.baseStackName; | ||||
| 
 | ||||
|     const baseStack = BaseStackFormation.formation; | ||||
| 
 | ||||
|     // Cloud Formation Input
 | ||||
|     const describeStackInput: DescribeStacksCommandInput = { | ||||
|     const describeStackInput: SDK.CloudFormation.DescribeStacksInput = { | ||||
|       StackName: baseStackName, | ||||
|     }; | ||||
|     const parametersWithoutHash: Parameter[] = [{ ParameterKey: 'EnvironmentName', ParameterValue: baseStackName }]; | ||||
|     const parametersWithoutHash: SDK.CloudFormation.Parameter[] = [ | ||||
|       { ParameterKey: 'EnvironmentName', ParameterValue: baseStackName }, | ||||
|     ]; | ||||
|     const parametersHash = crypto | ||||
|       .createHash('md5') | ||||
|       .update(baseStack + JSON.stringify(parametersWithoutHash)) | ||||
|       .digest('hex'); | ||||
|     const parameters: Parameter[] = [ | ||||
|     const parameters: SDK.CloudFormation.Parameter[] = [ | ||||
|       ...parametersWithoutHash, | ||||
|       ...[{ ParameterKey: 'Version', ParameterValue: parametersHash }], | ||||
|     ]; | ||||
|     const updateInput: UpdateStackCommandInput = { | ||||
|     const updateInput: SDK.CloudFormation.UpdateStackInput = { | ||||
|       StackName: baseStackName, | ||||
|       TemplateBody: baseStack, | ||||
|       Parameters: parameters, | ||||
|       Capabilities: ['CAPABILITY_IAM'], | ||||
|     }; | ||||
|     const createStackInput: CreateStackCommandInput = { | ||||
|     const createStackInput: SDK.CloudFormation.CreateStackInput = { | ||||
|       StackName: baseStackName, | ||||
|       TemplateBody: baseStack, | ||||
|       Parameters: parameters, | ||||
|       Capabilities: ['CAPABILITY_IAM'], | ||||
|     }; | ||||
| 
 | ||||
|     const stacks = await CF.send( | ||||
|       new ListStacksCommand({ StackStatusFilter: ['UPDATE_COMPLETE', 'CREATE_COMPLETE', 'ROLLBACK_COMPLETE'] }), | ||||
|     ); | ||||
|     const stacks = await CF.listStacks({ | ||||
|       StackStatusFilter: ['UPDATE_COMPLETE', 'CREATE_COMPLETE', 'ROLLBACK_COMPLETE'], | ||||
|     }).promise(); | ||||
|     const stackNames = stacks.StackSummaries?.map((x) => x.StackName) || []; | ||||
|     const stackExists: Boolean = stackNames.includes(baseStackName) || false; | ||||
|     const describeStack = async () => { | ||||
|       return await CF.send(new DescribeStacksCommand(describeStackInput)); | ||||
|       return await CF.describeStacks(describeStackInput).promise(); | ||||
|     }; | ||||
|     try { | ||||
|       if (!stackExists) { | ||||
|         CloudRunnerLogger.log(`${baseStackName} stack does not exist (${JSON.stringify(stackNames)})`); | ||||
|         await CF.send(new CreateStackCommand(createStackInput)); | ||||
|         await CF.createStack(createStackInput).promise(); | ||||
|         CloudRunnerLogger.log(`created stack (version: ${parametersHash})`); | ||||
|       } | ||||
|       const CFState = await describeStack(); | ||||
|  | @ -75,13 +65,7 @@ export class AWSBaseStack { | |||
|       const stackVersion = stack.Parameters?.find((x) => x.ParameterKey === 'Version')?.ParameterValue; | ||||
| 
 | ||||
|       if (stack.StackStatus === 'CREATE_IN_PROGRESS') { | ||||
|         await waitUntilStackCreateComplete( | ||||
|           { | ||||
|             client: CF, | ||||
|             maxWaitTime: 200, | ||||
|           }, | ||||
|           describeStackInput, | ||||
|         ); | ||||
|         await CF.waitFor('stackCreateComplete', describeStackInput).promise(); | ||||
|       } | ||||
| 
 | ||||
|       if (stackExists) { | ||||
|  | @ -89,7 +73,7 @@ export class AWSBaseStack { | |||
|         if (parametersHash !== stackVersion) { | ||||
|           CloudRunnerLogger.log(`Attempting update of base stack`); | ||||
|           try { | ||||
|             await CF.send(new UpdateStackCommand(updateInput)); | ||||
|             await CF.updateStack(updateInput).promise(); | ||||
|           } catch (error: any) { | ||||
|             if (error['message'].includes('No updates are to be performed')) { | ||||
|               CloudRunnerLogger.log(`No updates are to be performed`); | ||||
|  | @ -109,13 +93,7 @@ export class AWSBaseStack { | |||
|           ); | ||||
|         } | ||||
|         if (stack.StackStatus === 'UPDATE_IN_PROGRESS') { | ||||
|           await waitUntilStackUpdateComplete( | ||||
|             { | ||||
|               client: CF, | ||||
|               maxWaitTime: 200, | ||||
|             }, | ||||
|             describeStackInput, | ||||
|           ); | ||||
|           await CF.waitFor('stackUpdateComplete', describeStackInput).promise(); | ||||
|         } | ||||
|       } | ||||
|       CloudRunnerLogger.log('base stack is now ready'); | ||||
|  |  | |||
|  | @ -1,15 +1,15 @@ | |||
| import CloudRunnerLogger from '../../services/core/cloud-runner-logger'; | ||||
| import { CloudFormation, DescribeStackEventsCommand } from '@aws-sdk/client-cloudformation'; | ||||
| import * as SDK from 'aws-sdk'; | ||||
| import * as core from '@actions/core'; | ||||
| import CloudRunner from '../../cloud-runner'; | ||||
| 
 | ||||
| export class AWSError { | ||||
|   static async handleStackCreationFailure(error: any, CF: CloudFormation, taskDefStackName: string) { | ||||
|   static async handleStackCreationFailure(error: any, CF: SDK.CloudFormation, taskDefStackName: string) { | ||||
|     CloudRunnerLogger.log('aws error: '); | ||||
|     core.error(JSON.stringify(error, undefined, 4)); | ||||
|     if (CloudRunner.buildParameters.cloudRunnerDebug) { | ||||
|       CloudRunnerLogger.log('Getting events and resources for task stack'); | ||||
|       const events = (await CF.send(new DescribeStackEventsCommand({ StackName: taskDefStackName }))).StackEvents; | ||||
|       const events = (await CF.describeStackEvents({ StackName: taskDefStackName }).promise()).StackEvents; | ||||
|       CloudRunnerLogger.log(JSON.stringify(events, undefined, 4)); | ||||
|     } | ||||
|   } | ||||
|  |  | |||
|  | @ -1,12 +1,4 @@ | |||
| import { | ||||
|   CloudFormation, | ||||
|   CreateStackCommand, | ||||
|   CreateStackCommandInput, | ||||
|   DescribeStackResourcesCommand, | ||||
|   DescribeStacksCommand, | ||||
|   ListStacksCommand, | ||||
|   waitUntilStackCreateComplete, | ||||
| } from '@aws-sdk/client-cloudformation'; | ||||
| import * as SDK from 'aws-sdk'; | ||||
| import CloudRunnerAWSTaskDef from './cloud-runner-aws-task-def'; | ||||
| import CloudRunnerSecret from '../../options/cloud-runner-secret'; | ||||
| import { AWSCloudFormationTemplates } from './aws-cloud-formation-templates'; | ||||
|  | @ -24,7 +16,7 @@ export class AWSJobStack { | |||
|   } | ||||
| 
 | ||||
|   public async setupCloudFormations( | ||||
|     CF: CloudFormation, | ||||
|     CF: SDK.CloudFormation, | ||||
|     buildGuid: string, | ||||
|     image: string, | ||||
|     entrypoint: string[], | ||||
|  | @ -127,7 +119,7 @@ export class AWSJobStack { | |||
|     let previousStackExists = true; | ||||
|     while (previousStackExists) { | ||||
|       previousStackExists = false; | ||||
|       const stacks = await CF.send(new ListStacksCommand({})); | ||||
|       const stacks = await CF.listStacks().promise(); | ||||
|       if (!stacks.StackSummaries) { | ||||
|         throw new Error('Faild to get stacks'); | ||||
|       } | ||||
|  | @ -140,7 +132,7 @@ export class AWSJobStack { | |||
|         } | ||||
|       } | ||||
|     } | ||||
|     const createStackInput: CreateStackCommandInput = { | ||||
|     const createStackInput: SDK.CloudFormation.CreateStackInput = { | ||||
|       StackName: taskDefStackName, | ||||
|       TemplateBody: taskDefCloudFormation, | ||||
|       Capabilities: ['CAPABILITY_IAM'], | ||||
|  | @ -148,15 +140,9 @@ export class AWSJobStack { | |||
|     }; | ||||
|     try { | ||||
|       CloudRunnerLogger.log(`Creating job aws formation ${taskDefStackName}`); | ||||
|       await CF.send(new CreateStackCommand(createStackInput)); | ||||
|       await waitUntilStackCreateComplete( | ||||
|         { | ||||
|           client: CF, | ||||
|           maxWaitTime: 200, | ||||
|         }, | ||||
|         { StackName: taskDefStackName }, | ||||
|       ); | ||||
|       const describeStack = await CF.send(new DescribeStacksCommand({ StackName: taskDefStackName })); | ||||
|       await CF.createStack(createStackInput).promise(); | ||||
|       await CF.waitFor('stackCreateComplete', { StackName: taskDefStackName }).promise(); | ||||
|       const describeStack = await CF.describeStacks({ StackName: taskDefStackName }).promise(); | ||||
|       for (const parameter of parameters) { | ||||
|         if (!describeStack.Stacks?.[0].Parameters?.some((x) => x.ParameterKey === parameter.ParameterKey)) { | ||||
|           throw new Error(`Parameter ${parameter.ParameterKey} not found in stack`); | ||||
|  | @ -167,7 +153,7 @@ export class AWSJobStack { | |||
|       throw error; | ||||
|     } | ||||
| 
 | ||||
|     const createCleanupStackInput: CreateStackCommandInput = { | ||||
|     const createCleanupStackInput: SDK.CloudFormation.CreateStackInput = { | ||||
|       StackName: `${taskDefStackName}-cleanup`, | ||||
|       TemplateBody: CleanupCronFormation.formation, | ||||
|       Capabilities: ['CAPABILITY_IAM'], | ||||
|  | @ -197,7 +183,7 @@ export class AWSJobStack { | |||
|     if (CloudRunnerOptions.useCleanupCron) { | ||||
|       try { | ||||
|         CloudRunnerLogger.log(`Creating job cleanup formation`); | ||||
|         await CF.send(new CreateStackCommand(createCleanupStackInput)); | ||||
|         await CF.createStack(createCleanupStackInput).promise(); | ||||
| 
 | ||||
|         // await CF.waitFor('stackCreateComplete', { StackName: createCleanupStackInput.StackName }).promise();
 | ||||
|       } catch (error) { | ||||
|  | @ -207,15 +193,12 @@ export class AWSJobStack { | |||
|     } | ||||
| 
 | ||||
|     const taskDefResources = ( | ||||
|       await CF.send( | ||||
|         new DescribeStackResourcesCommand({ | ||||
|           StackName: taskDefStackName, | ||||
|         }), | ||||
|       ) | ||||
|       await CF.describeStackResources({ | ||||
|         StackName: taskDefStackName, | ||||
|       }).promise() | ||||
|     ).StackResources; | ||||
| 
 | ||||
|     const baseResources = (await CF.send(new DescribeStackResourcesCommand({ StackName: this.baseStackName }))) | ||||
|       .StackResources; | ||||
|     const baseResources = (await CF.describeStackResources({ StackName: this.baseStackName }).promise()).StackResources; | ||||
| 
 | ||||
|     return { | ||||
|       taskDefStackName, | ||||
|  |  | |||
|  | @ -1,19 +1,4 @@ | |||
| import { | ||||
|   DescribeTasksCommand, | ||||
|   ECS, | ||||
|   RunTaskCommand, | ||||
|   RunTaskCommandInput, | ||||
|   Task, | ||||
|   waitUntilTasksRunning, | ||||
| } from '@aws-sdk/client-ecs'; | ||||
| import { | ||||
|   DescribeStreamCommand, | ||||
|   DescribeStreamCommandOutput, | ||||
|   GetRecordsCommand, | ||||
|   GetRecordsCommandOutput, | ||||
|   GetShardIteratorCommand, | ||||
|   Kinesis, | ||||
| } from '@aws-sdk/client-kinesis'; | ||||
| import * as AWS from 'aws-sdk'; | ||||
| import CloudRunnerEnvironmentVariable from '../../options/cloud-runner-environment-variable'; | ||||
| import * as core from '@actions/core'; | ||||
| import CloudRunnerAWSTaskDef from './cloud-runner-aws-task-def'; | ||||
|  | @ -27,8 +12,8 @@ import CloudRunnerOptions from '../../options/cloud-runner-options'; | |||
| import GitHub from '../../../github'; | ||||
| 
 | ||||
| class AWSTaskRunner { | ||||
|   public static ECS: ECS; | ||||
|   public static Kinesis: Kinesis; | ||||
|   public static ECS: AWS.ECS; | ||||
|   public static Kinesis: AWS.Kinesis; | ||||
|   private static readonly encodedUnderscore = `$252F`; | ||||
|   static async runTask( | ||||
|     taskDef: CloudRunnerAWSTaskDef, | ||||
|  | @ -75,7 +60,7 @@ class AWSTaskRunner { | |||
|       throw new Error(`Container Overrides length must be at most 8192`); | ||||
|     } | ||||
| 
 | ||||
|     const task = await AWSTaskRunner.ECS.send(new RunTaskCommand(runParameters as RunTaskCommandInput)); | ||||
|     const task = await AWSTaskRunner.ECS.runTask(runParameters).promise(); | ||||
|     const taskArn = task.tasks?.[0].taskArn || ''; | ||||
|     CloudRunnerLogger.log('Cloud runner job is starting'); | ||||
|     await AWSTaskRunner.waitUntilTaskRunning(taskArn, cluster); | ||||
|  | @ -123,13 +108,7 @@ class AWSTaskRunner { | |||
| 
 | ||||
|   private static async waitUntilTaskRunning(taskArn: string, cluster: string) { | ||||
|     try { | ||||
|       await waitUntilTasksRunning( | ||||
|         { | ||||
|           client: AWSTaskRunner.ECS, | ||||
|           maxWaitTime: 120, | ||||
|         }, | ||||
|         { tasks: [taskArn], cluster }, | ||||
|       ); | ||||
|       await AWSTaskRunner.ECS.waitFor('tasksRunning', { tasks: [taskArn], cluster }).promise(); | ||||
|     } catch (error_) { | ||||
|       const error = error_ as Error; | ||||
|       await new Promise((resolve) => setTimeout(resolve, 3000)); | ||||
|  | @ -145,7 +124,10 @@ class AWSTaskRunner { | |||
|   } | ||||
| 
 | ||||
|   static async describeTasks(clusterName: string, taskArn: string) { | ||||
|     const tasks = await AWSTaskRunner.ECS.send(new DescribeTasksCommand({ cluster: clusterName, tasks: [taskArn] })); | ||||
|     const tasks = await AWSTaskRunner.ECS.describeTasks({ | ||||
|       cluster: clusterName, | ||||
|       tasks: [taskArn], | ||||
|     }).promise(); | ||||
|     if (tasks.tasks?.[0]) { | ||||
|       return tasks.tasks?.[0]; | ||||
|     } else { | ||||
|  | @ -187,7 +169,9 @@ class AWSTaskRunner { | |||
|     output: string, | ||||
|     shouldCleanup: boolean, | ||||
|   ) { | ||||
|     const records = await AWSTaskRunner.Kinesis.send(new GetRecordsCommand({ ShardIterator: iterator })); | ||||
|     const records = await AWSTaskRunner.Kinesis.getRecords({ | ||||
|       ShardIterator: iterator, | ||||
|     }).promise(); | ||||
|     iterator = records.NextShardIterator || ''; | ||||
|     ({ shouldReadLogs, output, shouldCleanup } = AWSTaskRunner.logRecords( | ||||
|       records, | ||||
|  | @ -200,7 +184,7 @@ class AWSTaskRunner { | |||
|     return { iterator, shouldReadLogs, output, shouldCleanup }; | ||||
|   } | ||||
| 
 | ||||
|   private static checkStreamingShouldContinue(taskData: Task, timestamp: number, shouldReadLogs: boolean) { | ||||
|   private static checkStreamingShouldContinue(taskData: AWS.ECS.Task, timestamp: number, shouldReadLogs: boolean) { | ||||
|     if (taskData?.lastStatus === 'UNKNOWN') { | ||||
|       CloudRunnerLogger.log('## Cloud runner job unknwon'); | ||||
|     } | ||||
|  | @ -220,17 +204,15 @@ class AWSTaskRunner { | |||
|   } | ||||
| 
 | ||||
|   private static logRecords( | ||||
|     records: GetRecordsCommandOutput, | ||||
|     records: AWS.Kinesis.GetRecordsOutput, | ||||
|     iterator: string, | ||||
|     shouldReadLogs: boolean, | ||||
|     output: string, | ||||
|     shouldCleanup: boolean, | ||||
|   ) { | ||||
|     if ((records.Records ?? []).length > 0 && iterator) { | ||||
|       for (const record of records.Records ?? []) { | ||||
|         const json = JSON.parse( | ||||
|           zlib.gunzipSync(Buffer.from(record.Data as unknown as string, 'base64')).toString('utf8'), | ||||
|         ); | ||||
|     if (records.Records.length > 0 && iterator) { | ||||
|       for (const record of records.Records) { | ||||
|         const json = JSON.parse(zlib.gunzipSync(Buffer.from(record.Data as string, 'base64')).toString('utf8')); | ||||
|         if (json.messageType === 'DATA_MESSAGE') { | ||||
|           for (const logEvent of json.logEvents) { | ||||
|             ({ shouldReadLogs, shouldCleanup, output } = FollowLogStreamService.handleIteration( | ||||
|  | @ -248,19 +230,19 @@ class AWSTaskRunner { | |||
|   } | ||||
| 
 | ||||
|   private static async getLogStream(kinesisStreamName: string) { | ||||
|     return await AWSTaskRunner.Kinesis.send(new DescribeStreamCommand({ StreamName: kinesisStreamName })); | ||||
|     return await AWSTaskRunner.Kinesis.describeStream({ | ||||
|       StreamName: kinesisStreamName, | ||||
|     }).promise(); | ||||
|   } | ||||
| 
 | ||||
|   private static async getLogIterator(stream: DescribeStreamCommandOutput) { | ||||
|   private static async getLogIterator(stream: AWS.Kinesis.DescribeStreamOutput) { | ||||
|     return ( | ||||
|       ( | ||||
|         await AWSTaskRunner.Kinesis.send( | ||||
|           new GetShardIteratorCommand({ | ||||
|             ShardIteratorType: 'TRIM_HORIZON', | ||||
|             StreamName: stream.StreamDescription?.StreamName ?? '', | ||||
|             ShardId: stream.StreamDescription?.Shards?.[0]?.ShardId || '', | ||||
|           }), | ||||
|         ) | ||||
|         await AWSTaskRunner.Kinesis.getShardIterator({ | ||||
|           ShardIteratorType: 'TRIM_HORIZON', | ||||
|           StreamName: stream.StreamDescription.StreamName, | ||||
|           ShardId: stream.StreamDescription.Shards[0].ShardId, | ||||
|         }).promise() | ||||
|       ).ShardIterator || '' | ||||
|     ); | ||||
|   } | ||||
|  |  | |||
|  | @ -1,9 +1,9 @@ | |||
| import { StackResource } from '@aws-sdk/client-cloudformation'; | ||||
| import * as AWS from 'aws-sdk'; | ||||
| 
 | ||||
| class CloudRunnerAWSTaskDef { | ||||
|   public taskDefStackName!: string; | ||||
|   public taskDefCloudFormation!: string; | ||||
|   public taskDefResources: StackResource[] | undefined; | ||||
|   public baseResources: StackResource[] | undefined; | ||||
|   public taskDefResources: AWS.CloudFormation.StackResources | undefined; | ||||
|   public baseResources: AWS.CloudFormation.StackResources | undefined; | ||||
| } | ||||
| export default CloudRunnerAWSTaskDef; | ||||
|  |  | |||
|  | @ -1,6 +1,4 @@ | |||
| import { CloudFormation, DeleteStackCommand, waitUntilStackDeleteComplete } from '@aws-sdk/client-cloudformation'; | ||||
| import { ECS as ECSClient } from '@aws-sdk/client-ecs'; | ||||
| import { Kinesis } from '@aws-sdk/client-kinesis'; | ||||
| import * as SDK from 'aws-sdk'; | ||||
| import CloudRunnerSecret from '../../options/cloud-runner-secret'; | ||||
| import CloudRunnerEnvironmentVariable from '../../options/cloud-runner-environment-variable'; | ||||
| import CloudRunnerAWSTaskDef from './cloud-runner-aws-task-def'; | ||||
|  | @ -77,7 +75,7 @@ class AWSBuildEnvironment implements ProviderInterface { | |||
|     defaultSecretsArray: { ParameterKey: string; EnvironmentVariable: string; ParameterValue: string }[], | ||||
|   ) { | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const CF = new CloudFormation({ region: Input.region }); | ||||
|     const CF = new SDK.CloudFormation(); | ||||
|     await new AwsBaseStack(this.baseStackName).setupBaseStack(CF); | ||||
|   } | ||||
| 
 | ||||
|  | @ -91,10 +89,10 @@ class AWSBuildEnvironment implements ProviderInterface { | |||
|     secrets: CloudRunnerSecret[], | ||||
|   ): Promise<string> { | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const ECS = new ECSClient({ region: Input.region }); | ||||
|     const CF = new CloudFormation({ region: Input.region }); | ||||
|     const ECS = new SDK.ECS(); | ||||
|     const CF = new SDK.CloudFormation(); | ||||
|     AwsTaskRunner.ECS = ECS; | ||||
|     AwsTaskRunner.Kinesis = new Kinesis({ region: Input.region }); | ||||
|     AwsTaskRunner.Kinesis = new SDK.Kinesis(); | ||||
|     CloudRunnerLogger.log(`AWS Region: ${CF.config.region}`); | ||||
|     const entrypoint = ['/bin/sh']; | ||||
|     const startTimeMs = Date.now(); | ||||
|  | @ -131,31 +129,23 @@ class AWSBuildEnvironment implements ProviderInterface { | |||
|     } | ||||
|   } | ||||
| 
 | ||||
|   async cleanupResources(CF: CloudFormation, taskDef: CloudRunnerAWSTaskDef) { | ||||
|   async cleanupResources(CF: SDK.CloudFormation, taskDef: CloudRunnerAWSTaskDef) { | ||||
|     CloudRunnerLogger.log('Cleanup starting'); | ||||
|     await CF.send(new DeleteStackCommand({ StackName: taskDef.taskDefStackName })); | ||||
|     await CF.deleteStack({ | ||||
|       StackName: taskDef.taskDefStackName, | ||||
|     }).promise(); | ||||
|     if (CloudRunnerOptions.useCleanupCron) { | ||||
|       await CF.send(new DeleteStackCommand({ StackName: `${taskDef.taskDefStackName}-cleanup` })); | ||||
|       await CF.deleteStack({ | ||||
|         StackName: `${taskDef.taskDefStackName}-cleanup`, | ||||
|       }).promise(); | ||||
|     } | ||||
| 
 | ||||
|     await waitUntilStackDeleteComplete( | ||||
|       { | ||||
|         client: CF, | ||||
|         maxWaitTime: 200, | ||||
|       }, | ||||
|       { | ||||
|         StackName: taskDef.taskDefStackName, | ||||
|       }, | ||||
|     ); | ||||
|     await waitUntilStackDeleteComplete( | ||||
|       { | ||||
|         client: CF, | ||||
|         maxWaitTime: 200, | ||||
|       }, | ||||
|       { | ||||
|         StackName: `${taskDef.taskDefStackName}-cleanup`, | ||||
|       }, | ||||
|     ); | ||||
|     await CF.waitFor('stackDeleteComplete', { | ||||
|       StackName: taskDef.taskDefStackName, | ||||
|     }).promise(); | ||||
|     await CF.waitFor('stackDeleteComplete', { | ||||
|       StackName: `${taskDef.taskDefStackName}-cleanup`, | ||||
|     }).promise(); | ||||
|     CloudRunnerLogger.log(`Deleted Stack: ${taskDef.taskDefStackName}`); | ||||
|     CloudRunnerLogger.log('Cleanup complete'); | ||||
|   } | ||||
|  |  | |||
|  | @ -1,11 +1,4 @@ | |||
| import { | ||||
|   CloudFormation, | ||||
|   DeleteStackCommand, | ||||
|   DeleteStackCommandInput, | ||||
|   DescribeStackResourcesCommand, | ||||
| } from '@aws-sdk/client-cloudformation'; | ||||
| import { CloudWatchLogs, DeleteLogGroupCommand } from '@aws-sdk/client-cloudwatch-logs'; | ||||
| import { ECS, StopTaskCommand } from '@aws-sdk/client-ecs'; | ||||
| import AWS from 'aws-sdk'; | ||||
| import Input from '../../../../input'; | ||||
| import CloudRunnerLogger from '../../../services/core/cloud-runner-logger'; | ||||
| import { TaskService } from './task-service'; | ||||
|  | @ -19,9 +12,9 @@ export class GarbageCollectionService { | |||
| 
 | ||||
|   public static async cleanup(deleteResources = false, OneDayOlderOnly: boolean = false) { | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const CF = new CloudFormation({ region: Input.region }); | ||||
|     const ecs = new ECS({ region: Input.region }); | ||||
|     const cwl = new CloudWatchLogs({ region: Input.region }); | ||||
|     const CF = new AWS.CloudFormation(); | ||||
|     const ecs = new AWS.ECS(); | ||||
|     const cwl = new AWS.CloudWatchLogs(); | ||||
|     const taskDefinitionsInUse = new Array(); | ||||
|     const tasks = await TaskService.getTasks(); | ||||
| 
 | ||||
|  | @ -30,14 +23,14 @@ export class GarbageCollectionService { | |||
|       taskDefinitionsInUse.push(taskElement.taskDefinitionArn); | ||||
|       if (deleteResources && (!OneDayOlderOnly || GarbageCollectionService.isOlderThan1day(taskElement.createdAt!))) { | ||||
|         CloudRunnerLogger.log(`Stopping task ${taskElement.containers?.[0].name}`); | ||||
|         await ecs.send(new StopTaskCommand({ task: taskElement.taskArn || '', cluster: element })); | ||||
|         await ecs.stopTask({ task: taskElement.taskArn || '', cluster: element }).promise(); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     const jobStacks = await TaskService.getCloudFormationJobStacks(); | ||||
|     for (const element of jobStacks) { | ||||
|       if ( | ||||
|         (await CF.send(new DescribeStackResourcesCommand({ StackName: element.StackName }))).StackResources?.some( | ||||
|         (await CF.describeStackResources({ StackName: element.StackName }).promise()).StackResources?.some( | ||||
|           (x) => x.ResourceType === 'AWS::ECS::TaskDefinition' && taskDefinitionsInUse.includes(x.PhysicalResourceId), | ||||
|         ) | ||||
|       ) { | ||||
|  | @ -46,10 +39,7 @@ export class GarbageCollectionService { | |||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       if ( | ||||
|         deleteResources && | ||||
|         (!OneDayOlderOnly || (element.CreationTime && GarbageCollectionService.isOlderThan1day(element.CreationTime))) | ||||
|       ) { | ||||
|       if (deleteResources && (!OneDayOlderOnly || GarbageCollectionService.isOlderThan1day(element.CreationTime))) { | ||||
|         if (element.StackName === 'game-ci' || element.TemplateDescription === 'Game-CI base stack') { | ||||
|           CloudRunnerLogger.log(`Skipping ${element.StackName} ignore list`); | ||||
| 
 | ||||
|  | @ -57,8 +47,8 @@ export class GarbageCollectionService { | |||
|         } | ||||
| 
 | ||||
|         CloudRunnerLogger.log(`Deleting ${element.StackName}`); | ||||
|         const deleteStackInput: DeleteStackCommandInput = { StackName: element.StackName }; | ||||
|         await CF.send(new DeleteStackCommand(deleteStackInput)); | ||||
|         const deleteStackInput: AWS.CloudFormation.DeleteStackInput = { StackName: element.StackName }; | ||||
|         await CF.deleteStack(deleteStackInput).promise(); | ||||
|       } | ||||
|     } | ||||
|     const logGroups = await TaskService.getLogGroups(); | ||||
|  | @ -68,7 +58,7 @@ export class GarbageCollectionService { | |||
|         (!OneDayOlderOnly || GarbageCollectionService.isOlderThan1day(new Date(element.creationTime!))) | ||||
|       ) { | ||||
|         CloudRunnerLogger.log(`Deleting ${element.logGroupName}`); | ||||
|         await cwl.send(new DeleteLogGroupCommand({ logGroupName: element.logGroupName || '' })); | ||||
|         await cwl.deleteLogGroup({ logGroupName: element.logGroupName || '' }).promise(); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,31 +1,12 @@ | |||
| import { | ||||
|   CloudFormation, | ||||
|   DescribeStackResourcesCommand, | ||||
|   DescribeStacksCommand, | ||||
|   ListStacksCommand, | ||||
|   StackSummary, | ||||
| } from '@aws-sdk/client-cloudformation'; | ||||
| import { | ||||
|   CloudWatchLogs, | ||||
|   DescribeLogGroupsCommand, | ||||
|   DescribeLogGroupsCommandInput, | ||||
|   LogGroup, | ||||
| } from '@aws-sdk/client-cloudwatch-logs'; | ||||
| import { | ||||
|   DescribeTasksCommand, | ||||
|   DescribeTasksCommandInput, | ||||
|   ECS, | ||||
|   ListClustersCommand, | ||||
|   ListTasksCommand, | ||||
|   ListTasksCommandInput, | ||||
|   Task, | ||||
| } from '@aws-sdk/client-ecs'; | ||||
| import { ListObjectsCommand, ListObjectsCommandInput, S3 } from '@aws-sdk/client-s3'; | ||||
| import AWS from 'aws-sdk'; | ||||
| import Input from '../../../../input'; | ||||
| import CloudRunnerLogger from '../../../services/core/cloud-runner-logger'; | ||||
| import { BaseStackFormation } from '../cloud-formations/base-stack-formation'; | ||||
| import AwsTaskRunner from '../aws-task-runner'; | ||||
| import { ListObjectsRequest } from 'aws-sdk/clients/s3'; | ||||
| import CloudRunner from '../../../cloud-runner'; | ||||
| import { StackSummaries } from 'aws-sdk/clients/cloudformation'; | ||||
| import { LogGroups } from 'aws-sdk/clients/cloudwatchlogs'; | ||||
| 
 | ||||
| export class TaskService { | ||||
|   static async watch() { | ||||
|  | @ -39,24 +20,20 @@ export class TaskService { | |||
|     return output; | ||||
|   } | ||||
|   public static async getCloudFormationJobStacks() { | ||||
|     const result: StackSummary[] = []; | ||||
|     const result: StackSummaries = []; | ||||
|     CloudRunnerLogger.log(``); | ||||
|     CloudRunnerLogger.log(`List Cloud Formation Stacks`); | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const CF = new CloudFormation({ region: Input.region }); | ||||
|     const CF = new AWS.CloudFormation(); | ||||
|     const stacks = | ||||
|       (await CF.send(new ListStacksCommand({}))).StackSummaries?.filter( | ||||
|       (await CF.listStacks().promise()).StackSummaries?.filter( | ||||
|         (_x) => | ||||
|           _x.StackStatus !== 'DELETE_COMPLETE' && _x.TemplateDescription !== BaseStackFormation.baseStackDecription, | ||||
|       ) || []; | ||||
|     CloudRunnerLogger.log(``); | ||||
|     CloudRunnerLogger.log(`Cloud Formation Stacks ${stacks.length}`); | ||||
|     for (const element of stacks) { | ||||
|       if (!element.CreationTime) { | ||||
|         CloudRunnerLogger.log(`${element.StackName} due to undefined CreationTime`); | ||||
|       } | ||||
| 
 | ||||
|       const ageDate: Date = new Date(Date.now() - (element.CreationTime?.getTime() ?? 0)); | ||||
|       const ageDate: Date = new Date(Date.now() - element.CreationTime.getTime()); | ||||
| 
 | ||||
|       CloudRunnerLogger.log( | ||||
|         `Task Stack ${element.StackName} - Age D${Math.floor( | ||||
|  | @ -66,18 +43,14 @@ export class TaskService { | |||
|       result.push(element); | ||||
|     } | ||||
|     const baseStacks = | ||||
|       (await CF.send(new ListStacksCommand({}))).StackSummaries?.filter( | ||||
|       (await CF.listStacks().promise()).StackSummaries?.filter( | ||||
|         (_x) => | ||||
|           _x.StackStatus !== 'DELETE_COMPLETE' && _x.TemplateDescription === BaseStackFormation.baseStackDecription, | ||||
|       ) || []; | ||||
|     CloudRunnerLogger.log(``); | ||||
|     CloudRunnerLogger.log(`Base Stacks ${baseStacks.length}`); | ||||
|     for (const element of baseStacks) { | ||||
|       if (!element.CreationTime) { | ||||
|         CloudRunnerLogger.log(`${element.StackName} due to undefined CreationTime`); | ||||
|       } | ||||
| 
 | ||||
|       const ageDate: Date = new Date(Date.now() - (element.CreationTime?.getTime() ?? 0)); | ||||
|       const ageDate: Date = new Date(Date.now() - element.CreationTime.getTime()); | ||||
| 
 | ||||
|       CloudRunnerLogger.log( | ||||
|         `Task Stack ${element.StackName} - Age D${Math.floor( | ||||
|  | @ -91,22 +64,22 @@ export class TaskService { | |||
|     return result; | ||||
|   } | ||||
|   public static async getTasks() { | ||||
|     const result: { taskElement: Task; element: string }[] = []; | ||||
|     const result: { taskElement: AWS.ECS.Task; element: string }[] = []; | ||||
|     CloudRunnerLogger.log(``); | ||||
|     CloudRunnerLogger.log(`List Tasks`); | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const ecs = new ECS({ region: Input.region }); | ||||
|     const clusters = (await ecs.send(new ListClustersCommand({}))).clusterArns || []; | ||||
|     const ecs = new AWS.ECS(); | ||||
|     const clusters = (await ecs.listClusters().promise()).clusterArns || []; | ||||
|     CloudRunnerLogger.log(`Task Clusters ${clusters.length}`); | ||||
|     for (const element of clusters) { | ||||
|       const input: ListTasksCommandInput = { | ||||
|       const input: AWS.ECS.ListTasksRequest = { | ||||
|         cluster: element, | ||||
|       }; | ||||
| 
 | ||||
|       const list = (await ecs.send(new ListTasksCommand(input))).taskArns || []; | ||||
|       const list = (await ecs.listTasks(input).promise()).taskArns || []; | ||||
|       if (list.length > 0) { | ||||
|         const describeInput: DescribeTasksCommandInput = { tasks: list, cluster: element }; | ||||
|         const describeList = (await ecs.send(new DescribeTasksCommand(describeInput))).tasks || []; | ||||
|         const describeInput: AWS.ECS.DescribeTasksRequest = { tasks: list, cluster: element }; | ||||
|         const describeList = (await ecs.describeTasks(describeInput).promise()).tasks || []; | ||||
|         if (describeList.length === 0) { | ||||
|           CloudRunnerLogger.log(`No Tasks`); | ||||
|           continue; | ||||
|  | @ -132,48 +105,37 @@ export class TaskService { | |||
|   } | ||||
|   public static async awsDescribeJob(job: string) { | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const CF = new CloudFormation({ region: Input.region }); | ||||
|     try { | ||||
|       const stack = | ||||
|         (await CF.send(new ListStacksCommand({}))).StackSummaries?.find((_x) => _x.StackName === job) || undefined; | ||||
|       const stackInfo = (await CF.send(new DescribeStackResourcesCommand({ StackName: job }))) || undefined; | ||||
|       const stackInfo2 = (await CF.send(new DescribeStacksCommand({ StackName: job }))) || undefined; | ||||
|       if (stack === undefined) { | ||||
|         throw new Error('stack not defined'); | ||||
|       } | ||||
|       if (!stack.CreationTime) { | ||||
|         CloudRunnerLogger.log(`${stack.StackName} due to undefined CreationTime`); | ||||
|       } | ||||
|       const ageDate: Date = new Date(Date.now() - (stack.CreationTime?.getTime() ?? 0)); | ||||
|       const message = ` | ||||
|     const CF = new AWS.CloudFormation(); | ||||
|     const stack = (await CF.listStacks().promise()).StackSummaries?.find((_x) => _x.StackName === job) || undefined; | ||||
|     const stackInfo = (await CF.describeStackResources({ StackName: job }).promise()) || undefined; | ||||
|     const stackInfo2 = (await CF.describeStacks({ StackName: job }).promise()) || undefined; | ||||
|     if (stack === undefined) { | ||||
|       throw new Error('stack not defined'); | ||||
|     } | ||||
|     const ageDate: Date = new Date(Date.now() - stack.CreationTime.getTime()); | ||||
|     const message = ` | ||||
|     Task Stack ${stack.StackName} | ||||
|     Age D${Math.floor(ageDate.getHours() / 24)} H${ageDate.getHours()} M${ageDate.getMinutes()} | ||||
|     ${JSON.stringify(stack, undefined, 4)} | ||||
|     ${JSON.stringify(stackInfo, undefined, 4)} | ||||
|     ${JSON.stringify(stackInfo2, undefined, 4)} | ||||
|     `;
 | ||||
|       CloudRunnerLogger.log(message); | ||||
|     CloudRunnerLogger.log(message); | ||||
| 
 | ||||
|       return message; | ||||
|     } catch (error) { | ||||
|       CloudRunnerLogger.error( | ||||
|         `Failed to describe job ${job}: ${error instanceof Error ? error.message : String(error)}`, | ||||
|       ); | ||||
|       throw error; | ||||
|     } | ||||
|     return message; | ||||
|   } | ||||
|   public static async getLogGroups() { | ||||
|     const result: Array<LogGroup> = []; | ||||
|     const result: LogGroups = []; | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const ecs = new CloudWatchLogs(); | ||||
|     let logStreamInput: DescribeLogGroupsCommandInput = { | ||||
|     const ecs = new AWS.CloudWatchLogs(); | ||||
|     let logStreamInput: AWS.CloudWatchLogs.DescribeLogGroupsRequest = { | ||||
|       /* logGroupNamePrefix: 'game-ci' */ | ||||
|     }; | ||||
|     let logGroupsDescribe = await ecs.send(new DescribeLogGroupsCommand(logStreamInput)); | ||||
|     let logGroupsDescribe = await ecs.describeLogGroups(logStreamInput).promise(); | ||||
|     const logGroups = logGroupsDescribe.logGroups || []; | ||||
|     while (logGroupsDescribe.nextToken) { | ||||
|       logStreamInput = { /* logGroupNamePrefix: 'game-ci',*/ nextToken: logGroupsDescribe.nextToken }; | ||||
|       logGroupsDescribe = await ecs.send(new DescribeLogGroupsCommand(logStreamInput)); | ||||
|       logGroupsDescribe = await ecs.describeLogGroups(logStreamInput).promise(); | ||||
|       logGroups.push(...(logGroupsDescribe?.logGroups || [])); | ||||
|     } | ||||
| 
 | ||||
|  | @ -197,12 +159,11 @@ export class TaskService { | |||
|   } | ||||
|   public static async getLocks() { | ||||
|     process.env.AWS_REGION = Input.region; | ||||
|     const s3 = new S3({ region: Input.region }); | ||||
|     const listRequest: ListObjectsCommandInput = { | ||||
|     const s3 = new AWS.S3(); | ||||
|     const listRequest: ListObjectsRequest = { | ||||
|       Bucket: CloudRunner.buildParameters.awsStackName, | ||||
|     }; | ||||
| 
 | ||||
|     const results = await s3.send(new ListObjectsCommand(listRequest)); | ||||
|     const results = await s3.listObjects(listRequest).promise(); | ||||
| 
 | ||||
|     return results.Contents || []; | ||||
|   } | ||||
|  |  | |||
|  | @ -1,66 +1,59 @@ | |||
| import { BuildParameters } from '../..'; | ||||
| import CloudRunner from '../cloud-runner'; | ||||
| import UnityVersioning from '../../unity-versioning'; | ||||
| import { Cli } from '../../cli/cli'; | ||||
| import CloudRunnerOptions from '../options/cloud-runner-options'; | ||||
| import setups from './cloud-runner-suite.test'; | ||||
| import { OptionValues } from 'commander'; | ||||
| import GitHub from '../../github'; | ||||
| import { TIMEOUT_INFINITE, createParameters } from '../../../test-utils/cloud-runner-test-helpers'; | ||||
| export const TIMEOUT_INFINITE = 1e9; | ||||
| async function CreateParameters(overrides: OptionValues | undefined) { | ||||
|   if (overrides) Cli.options = overrides; | ||||
| 
 | ||||
|   return BuildParameters.create(); | ||||
| } | ||||
| describe('Cloud Runner Github Checks', () => { | ||||
|   setups(); | ||||
|   it('Responds', () => {}); | ||||
| 
 | ||||
|   beforeEach(() => { | ||||
|     // Mock GitHub API requests to avoid real network calls
 | ||||
|     jest.spyOn(GitHub as any, 'createGitHubCheckRequest').mockResolvedValue({ | ||||
|       status: 201, | ||||
|       data: { id: '1' }, | ||||
|     }); | ||||
|     jest.spyOn(GitHub as any, 'updateGitHubCheckRequest').mockResolvedValue({ | ||||
|       status: 200, | ||||
|       data: {}, | ||||
|     }); | ||||
|     // eslint-disable-next-line unicorn/no-useless-undefined
 | ||||
|     jest.spyOn(GitHub as any, 'runUpdateAsyncChecksWorkflow').mockResolvedValue(undefined); | ||||
|   }); | ||||
| 
 | ||||
|   afterEach(() => { | ||||
|     jest.restoreAllMocks(); | ||||
|   }); | ||||
| 
 | ||||
|   it( | ||||
|     'Check Handling Direct', | ||||
|     async () => { | ||||
|       // Setup parameters
 | ||||
|       const buildParameter = await createParameters({ | ||||
|         versioning: 'None', | ||||
|         projectPath: 'test-project', | ||||
|         unityVersion: UnityVersioning.read('test-project'), | ||||
|         asyncCloudRunner: `true`, | ||||
|         githubChecks: `true`, | ||||
|       }); | ||||
|       await CloudRunner.setup(buildParameter); | ||||
|       CloudRunner.buildParameters.githubCheckId = await GitHub.createGitHubCheck(`direct create`); | ||||
|       await GitHub.updateGitHubCheck(`1 ${new Date().toISOString()}`, `direct`); | ||||
|       await GitHub.updateGitHubCheck(`2 ${new Date().toISOString()}`, `direct`, `success`, `completed`); | ||||
|     }, | ||||
|     TIMEOUT_INFINITE, | ||||
|   ); | ||||
|   it( | ||||
|     'Check Handling Via Async Workflow', | ||||
|     async () => { | ||||
|       // Setup parameters
 | ||||
|       const buildParameter = await createParameters({ | ||||
|         versioning: 'None', | ||||
|         projectPath: 'test-project', | ||||
|         unityVersion: UnityVersioning.read('test-project'), | ||||
|         asyncCloudRunner: `true`, | ||||
|         githubChecks: `true`, | ||||
|       }); | ||||
|       GitHub.forceAsyncTest = true; | ||||
|       await CloudRunner.setup(buildParameter); | ||||
|       CloudRunner.buildParameters.githubCheckId = await GitHub.createGitHubCheck(`async create`); | ||||
|       await GitHub.updateGitHubCheck(`1 ${new Date().toISOString()}`, `async`); | ||||
|       await GitHub.updateGitHubCheck(`2 ${new Date().toISOString()}`, `async`, `success`, `completed`); | ||||
|       GitHub.forceAsyncTest = false; | ||||
|     }, | ||||
|     TIMEOUT_INFINITE, | ||||
|   ); | ||||
|   if (CloudRunnerOptions.cloudRunnerDebug) { | ||||
|     it( | ||||
|       'Check Handling Direct', | ||||
|       async () => { | ||||
|         // Setup parameters
 | ||||
|         const buildParameter = await CreateParameters({ | ||||
|           versioning: 'None', | ||||
|           projectPath: 'test-project', | ||||
|           unityVersion: UnityVersioning.read('test-project'), | ||||
|           asyncCloudRunner: `true`, | ||||
|           githubChecks: `true`, | ||||
|         }); | ||||
|         await CloudRunner.setup(buildParameter); | ||||
|         CloudRunner.buildParameters.githubCheckId = await GitHub.createGitHubCheck(`direct create`); | ||||
|         await GitHub.updateGitHubCheck(`1 ${new Date().toISOString()}`, `direct`); | ||||
|         await GitHub.updateGitHubCheck(`2 ${new Date().toISOString()}`, `direct`, `success`, `completed`); | ||||
|       }, | ||||
|       TIMEOUT_INFINITE, | ||||
|     ); | ||||
|     it( | ||||
|       'Check Handling Via Async Workflow', | ||||
|       async () => { | ||||
|         // Setup parameters
 | ||||
|         const buildParameter = await CreateParameters({ | ||||
|           versioning: 'None', | ||||
|           projectPath: 'test-project', | ||||
|           unityVersion: UnityVersioning.read('test-project'), | ||||
|           asyncCloudRunner: `true`, | ||||
|           githubChecks: `true`, | ||||
|         }); | ||||
|         GitHub.forceAsyncTest = true; | ||||
|         await CloudRunner.setup(buildParameter); | ||||
|         CloudRunner.buildParameters.githubCheckId = await GitHub.createGitHubCheck(`async create`); | ||||
|         await GitHub.updateGitHubCheck(`1 ${new Date().toISOString()}`, `async`); | ||||
|         await GitHub.updateGitHubCheck(`2 ${new Date().toISOString()}`, `async`, `success`, `completed`); | ||||
|         GitHub.forceAsyncTest = false; | ||||
|       }, | ||||
|       TIMEOUT_INFINITE, | ||||
|     ); | ||||
|   } | ||||
| }); | ||||
|  |  | |||
|  | @ -92,7 +92,6 @@ class Docker { | |||
|     const { | ||||
|       workspace, | ||||
|       actionFolder, | ||||
|       runnerTempPath, | ||||
|       gitPrivateToken, | ||||
|       dockerWorkspacePath, | ||||
|       dockerCpuLimit, | ||||
|  | @ -100,18 +99,13 @@ class Docker { | |||
|       dockerIsolationMode, | ||||
|     } = parameters; | ||||
| 
 | ||||
|     const githubHome = path.join(runnerTempPath, '_github_home'); | ||||
|     if (!existsSync(githubHome)) mkdirSync(githubHome); | ||||
| 
 | ||||
|     return `docker run \ | ||||
|             --workdir c:${dockerWorkspacePath} \ | ||||
|             --rm \ | ||||
|             ${ImageEnvironmentFactory.getEnvVarString(parameters)} \ | ||||
|             --env BEE_CACHE_DIRECTORY=c:${dockerWorkspacePath}/Library/bee_cache \ | ||||
|             --env GITHUB_WORKSPACE=c:${dockerWorkspacePath} \ | ||||
|             ${gitPrivateToken ? `--env GIT_PRIVATE_TOKEN="${gitPrivateToken}"` : ''} \ | ||||
|             --volume "${workspace}":"c:${dockerWorkspacePath}" \ | ||||
|             --volume "${githubHome}":"C:/githubhome" \ | ||||
|             --volume "c:/regkeys":"c:/regkeys" \ | ||||
|             --volume "C:/Program Files/Microsoft Visual Studio":"C:/Program Files/Microsoft Visual Studio" \ | ||||
|             --volume "C:/Program Files (x86)/Microsoft Visual Studio":"C:/Program Files (x86)/Microsoft Visual Studio" \ | ||||
|  | @ -119,7 +113,6 @@ class Docker { | |||
|             --volume "C:/ProgramData/Microsoft/VisualStudio":"C:/ProgramData/Microsoft/VisualStudio" \ | ||||
|             --volume "${actionFolder}/default-build-script":"c:/UnityBuilderAction" \ | ||||
|             --volume "${actionFolder}/platforms/windows":"c:/steps" \ | ||||
|             --volume "${actionFolder}/unity-config":"C:/ProgramData/Unity/config" \ | ||||
|             --volume "${actionFolder}/BlankProject":"c:/BlankProject" \ | ||||
|             --cpus=${dockerCpuLimit} \ | ||||
|             --memory=${dockerMemoryLimit} \ | ||||
|  |  | |||
|  | @ -36,7 +36,6 @@ class ImageEnvironmentFactory { | |||
|         value: process.env.USYM_UPLOAD_AUTH_TOKEN, | ||||
|       }, | ||||
|       { name: 'PROJECT_PATH', value: parameters.projectPath }, | ||||
|       { name: 'BUILD_PROFILE', value: parameters.buildProfile }, | ||||
|       { name: 'BUILD_TARGET', value: parameters.targetPlatform }, | ||||
|       { name: 'BUILD_NAME', value: parameters.buildName }, | ||||
|       { name: 'BUILD_PATH', value: parameters.buildPath }, | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ import ImageTag from './image-tag'; | |||
| 
 | ||||
| describe('ImageTag', () => { | ||||
|   const testImageParameters = { | ||||
|     editorVersion: '2099.9.9f9', | ||||
|     editorVersion: '2099.9.f9f9', | ||||
|     targetPlatform: 'Test', | ||||
|     builderPlatform: '', | ||||
|     containerRegistryRepository: 'unityci/editor', | ||||
|  | @ -27,7 +27,7 @@ describe('ImageTag', () => { | |||
|       expect(image.builderPlatform).toStrictEqual(testImageParameters.builderPlatform); | ||||
|     }); | ||||
| 
 | ||||
|     test.each(['2000.0.0f0', '2011.1.11f1', '6000.0.0f1'])('accepts %p version format', (version) => { | ||||
|     test.each(['2000.0.0f0', '2011.1.11f1'])('accepts %p version format', (version) => { | ||||
|       expect( | ||||
|         () => | ||||
|           new ImageTag({ | ||||
|  | @ -50,23 +50,23 @@ describe('ImageTag', () => { | |||
|   describe('toString', () => { | ||||
|     it('returns the correct version', () => { | ||||
|       const image = new ImageTag({ | ||||
|         editorVersion: '2099.1.1111f1', | ||||
|         editorVersion: '2099.1.1111', | ||||
|         targetPlatform: testImageParameters.targetPlatform, | ||||
|         containerRegistryRepository: 'unityci/editor', | ||||
|         containerRegistryImageVersion: '3', | ||||
|       }); | ||||
|       switch (process.platform) { | ||||
|         case 'win32': | ||||
|           expect(image.toString()).toStrictEqual(`${defaults.image}:windows-2099.1.1111f1-3`); | ||||
|           expect(image.toString()).toStrictEqual(`${defaults.image}:windows-2099.1.1111-3`); | ||||
|           break; | ||||
|         case 'linux': | ||||
|           expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2099.1.1111f1-3`); | ||||
|           expect(image.toString()).toStrictEqual(`${defaults.image}:ubuntu-2099.1.1111-3`); | ||||
|           break; | ||||
|       } | ||||
|     }); | ||||
|     it('returns customImage if given', () => { | ||||
|       const image = new ImageTag({ | ||||
|         editorVersion: '2099.1.1111f1', | ||||
|         editorVersion: '2099.1.1111', | ||||
|         targetPlatform: testImageParameters.targetPlatform, | ||||
|         customImage: `${defaults.image}:2099.1.1111@347598437689743986`, | ||||
|         containerRegistryRepository: 'unityci/editor', | ||||
|  |  | |||
|  | @ -42,7 +42,7 @@ class ImageTag { | |||
|   } | ||||
| 
 | ||||
|   static get versionPattern(): RegExp { | ||||
|     return /^\d+\.\d+\.\d+[a-z]\d+$/; | ||||
|     return /^(20\d{2}\.\d\.\w{3,4}|3)$/; | ||||
|   } | ||||
| 
 | ||||
|   static get targetPlatformSuffixes() { | ||||
|  | @ -58,7 +58,6 @@ class ImageTag { | |||
|       android: 'android', | ||||
|       ios: 'ios', | ||||
|       tvos: 'appletv', | ||||
|       visionos: 'visionos', | ||||
|       facebook: 'facebook', | ||||
|     }; | ||||
|   } | ||||
|  | @ -83,21 +82,8 @@ class ImageTag { | |||
|     version: string, | ||||
|     providerStrategy: string, | ||||
|   ): string { | ||||
|     const { | ||||
|       generic, | ||||
|       webgl, | ||||
|       mac, | ||||
|       windows, | ||||
|       windowsIl2cpp, | ||||
|       wsaPlayer, | ||||
|       linux, | ||||
|       linuxIl2cpp, | ||||
|       android, | ||||
|       ios, | ||||
|       tvos, | ||||
|       visionos, | ||||
|       facebook, | ||||
|     } = ImageTag.targetPlatformSuffixes; | ||||
|     const { generic, webgl, mac, windows, windowsIl2cpp, wsaPlayer, linux, linuxIl2cpp, android, ios, tvos, facebook } = | ||||
|       ImageTag.targetPlatformSuffixes; | ||||
| 
 | ||||
|     const [major, minor] = version.split('.').map((digit) => Number(digit)); | ||||
| 
 | ||||
|  | @ -150,17 +136,11 @@ class ImageTag { | |||
|       case Platform.types.XboxOne: | ||||
|         return windows; | ||||
|       case Platform.types.tvOS: | ||||
|         if (process.platform !== 'win32' && process.platform !== 'darwin') { | ||||
|           throw new Error(`tvOS can only be built on Windows or macOS base OS`); | ||||
|         if (process.platform !== 'win32') { | ||||
|           throw new Error(`tvOS can only be built on a windows base OS`); | ||||
|         } | ||||
| 
 | ||||
|         return tvos; | ||||
|       case Platform.types.VisionOS: | ||||
|         if (process.platform !== 'darwin') { | ||||
|           throw new Error(`visionOS can only be built on a macOS base OS`); | ||||
|         } | ||||
| 
 | ||||
|         return visionos; | ||||
|       case Platform.types.Switch: | ||||
|         return windows; | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,19 +59,6 @@ describe('Input', () => { | |||
|     }); | ||||
|   }); | ||||
| 
 | ||||
|   describe('buildProfile', () => { | ||||
|     it('returns the default value', () => { | ||||
|       expect(Input.buildProfile).toStrictEqual(''); | ||||
|     }); | ||||
| 
 | ||||
|     it('takes input from the users workflow', () => { | ||||
|       const mockValue = 'path/to/build_profile.asset'; | ||||
|       const spy = jest.spyOn(core, 'getInput').mockReturnValue(mockValue); | ||||
|       expect(Input.buildProfile).toStrictEqual(mockValue); | ||||
|       expect(spy).toHaveBeenCalledTimes(1); | ||||
|     }); | ||||
|   }); | ||||
| 
 | ||||
|   describe('buildName', () => { | ||||
|     it('returns the default value', () => { | ||||
|       expect(Input.buildName).toStrictEqual(Input.targetPlatform); | ||||
|  |  | |||
|  | @ -107,10 +107,6 @@ class Input { | |||
|     return rawProjectPath.replace(/\/$/, ''); | ||||
|   } | ||||
| 
 | ||||
|   static get buildProfile(): string { | ||||
|     return Input.getInput('buildProfile') ?? ''; | ||||
|   } | ||||
| 
 | ||||
|   static get runnerTempPath(): string { | ||||
|     return Input.getInput('RUNNER_TEMP') ?? ''; | ||||
|   } | ||||
|  |  | |||
|  | @ -101,10 +101,7 @@ class SetupMac { | |||
|         moduleArgument.push('--module', 'ios'); | ||||
|         break; | ||||
|       case 'tvOS': | ||||
|         moduleArgument.push('--module', 'appletv'); | ||||
|         break; | ||||
|       case 'VisionOS': | ||||
|         moduleArgument.push('--module', 'visionos'); | ||||
|         moduleArgument.push('--module', 'tvos'); | ||||
|         break; | ||||
|       case 'StandaloneOSX': | ||||
|         moduleArgument.push('--module', 'mac-il2cpp'); | ||||
|  | @ -173,7 +170,6 @@ class SetupMac { | |||
|     process.env.UNITY_LICENSING_SERVER = buildParameters.unityLicensingServer; | ||||
|     process.env.SKIP_ACTIVATION = buildParameters.skipActivation; | ||||
|     process.env.PROJECT_PATH = buildParameters.projectPath; | ||||
|     process.env.BUILD_PROFILE = buildParameters.buildProfile; | ||||
|     process.env.BUILD_TARGET = buildParameters.targetPlatform; | ||||
|     process.env.BUILD_NAME = buildParameters.buildName; | ||||
|     process.env.BUILD_PATH = buildParameters.buildPath; | ||||
|  |  | |||
|  | @ -4,14 +4,9 @@ import { BuildParameters } from '..'; | |||
| class ValidateWindows { | ||||
|   public static validate(buildParameters: BuildParameters) { | ||||
|     ValidateWindows.validateWindowsPlatformRequirements(buildParameters.targetPlatform); | ||||
| 
 | ||||
|     const { unityLicensingServer } = buildParameters; | ||||
|     const hasLicensingCredentials = process.env.UNITY_EMAIL && process.env.UNITY_PASSWORD; | ||||
|     const hasValidLicensingStrategy = hasLicensingCredentials || unityLicensingServer; | ||||
| 
 | ||||
|     if (!hasValidLicensingStrategy) { | ||||
|       throw new Error(`Unity email and password or alternatively a Unity licensing server url must be set for 
 | ||||
|                        Windows based builds to authenticate the license. Make sure to set them inside UNITY_EMAIL | ||||
|     if (!(process.env.UNITY_EMAIL && process.env.UNITY_PASSWORD)) { | ||||
|       throw new Error(`Unity email and password must be set for Windows based builds to
 | ||||
|                        authenticate the license. Make sure to set them inside UNITY_EMAIL | ||||
|                        and UNITY_PASSWORD in Github Secrets and pass them into the environment.`);
 | ||||
|     } | ||||
|   } | ||||
|  |  | |||
|  | @ -16,7 +16,6 @@ class Platform { | |||
|       PS4: 'PS4', | ||||
|       XboxOne: 'XboxOne', | ||||
|       tvOS: 'tvOS', | ||||
|       VisionOS: 'VisionOS', | ||||
|       Switch: 'Switch', | ||||
| 
 | ||||
|       // Unsupported
 | ||||
|  |  | |||
|  | @ -7,9 +7,9 @@ describe('Unity Versioning', () => { | |||
|     }); | ||||
| 
 | ||||
|     it('parses from ProjectVersion.txt', () => { | ||||
|       const projectVersionContents = `m_EditorVersion: 2021.3.45f1
 | ||||
|       m_EditorVersionWithRevision: 2021.3.45f1 (cb45f9cae8b7)`;
 | ||||
|       expect(UnityVersioning.parse(projectVersionContents)).toBe('2021.3.45f1'); | ||||
|       const projectVersionContents = `m_EditorVersion: 2021.3.4f1
 | ||||
|       m_EditorVersionWithRevision: 2021.3.4f1 (cb45f9cae8b7)`;
 | ||||
|       expect(UnityVersioning.parse(projectVersionContents)).toBe('2021.3.4f1'); | ||||
|     }); | ||||
| 
 | ||||
|     it('parses Unity 6000 and newer from ProjectVersion.txt', () => { | ||||
|  | @ -25,13 +25,13 @@ describe('Unity Versioning', () => { | |||
|     }); | ||||
| 
 | ||||
|     it('reads from test-project', () => { | ||||
|       expect(UnityVersioning.read('./test-project')).toBe('2021.3.45f1'); | ||||
|       expect(UnityVersioning.read('./test-project')).toBe('2021.3.4f1'); | ||||
|     }); | ||||
|   }); | ||||
| 
 | ||||
|   describe('determineUnityVersion', () => { | ||||
|     it('defaults to parsed version', () => { | ||||
|       expect(UnityVersioning.determineUnityVersion('./test-project', 'auto')).toBe('2021.3.45f1'); | ||||
|       expect(UnityVersioning.determineUnityVersion('./test-project', 'auto')).toBe('2021.3.4f1'); | ||||
|     }); | ||||
| 
 | ||||
|     it('use specified unityVersion', () => { | ||||
|  |  | |||
|  | @ -207,21 +207,7 @@ export default class Versioning { | |||
|    * identifies the current commit. | ||||
|    */ | ||||
|   static async getVersionDescription() { | ||||
|     const versionTags = (await this.git(['tag', '--list', '--merged', 'HEAD', '--sort=-creatordate'])) | ||||
|       .split('\n') | ||||
|       .filter((tag) => new RegExp(this.grepCompatibleInputVersionRegex).test(tag)); | ||||
| 
 | ||||
|     if (versionTags.length === 0) { | ||||
|       core.warning('No valid version tags found. Using fallback description.'); | ||||
| 
 | ||||
|       return this.git(['describe', '--long', '--tags', '--always', 'HEAD']); | ||||
|     } | ||||
| 
 | ||||
|     const latestVersionTag = versionTags[0]; | ||||
|     const commitsCount = (await this.git(['rev-list', `${latestVersionTag}..HEAD`, '--count'])).trim(); | ||||
|     const commitHash = (await this.git(['rev-parse', '--short', 'HEAD'])).trim(); | ||||
| 
 | ||||
|     return `${latestVersionTag}-${commitsCount}-g${commitHash}`; | ||||
|     return this.git(['describe', '--long', '--tags', '--always', 'HEAD']); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
|  | @ -1,11 +0,0 @@ | |||
| import { BuildParameters } from '../model'; | ||||
| import { Cli } from '../model/cli/cli'; | ||||
| import { OptionValues } from 'commander'; | ||||
| 
 | ||||
| export const TIMEOUT_INFINITE = 1e9; | ||||
| 
 | ||||
| export async function createParameters(overrides?: OptionValues) { | ||||
|   if (overrides) Cli.options = overrides; | ||||
| 
 | ||||
|   return BuildParameters.create(); | ||||
| } | ||||
|  | @ -1,8 +0,0 @@ | |||
| fileFormatVersion: 2 | ||||
| guid: 28bfc999a135648538355bfcb6a23aee | ||||
| folderAsset: yes | ||||
| DefaultImporter: | ||||
|   externalObjects: {} | ||||
|   userData:  | ||||
|   assetBundleName:  | ||||
|   assetBundleVariant:  | ||||
|  | @ -1,8 +0,0 @@ | |||
| fileFormatVersion: 2 | ||||
| guid: cd91492ed9aca40c49d42156a4a8f387 | ||||
| folderAsset: yes | ||||
| DefaultImporter: | ||||
|   externalObjects: {} | ||||
|   userData:  | ||||
|   assetBundleName:  | ||||
|   assetBundleVariant:  | ||||
|  | @ -1,47 +0,0 @@ | |||
| %YAML 1.1 | ||||
| %TAG !u! tag:unity3d.com,2011: | ||||
| --- !u!114 &11400000 | ||||
| MonoBehaviour: | ||||
|   m_ObjectHideFlags: 0 | ||||
|   m_CorrespondingSourceObject: {fileID: 0} | ||||
|   m_PrefabInstance: {fileID: 0} | ||||
|   m_PrefabAsset: {fileID: 0} | ||||
|   m_GameObject: {fileID: 0} | ||||
|   m_Enabled: 1 | ||||
|   m_EditorHideFlags: 0 | ||||
|   m_Script: {fileID: 15003, guid: 0000000000000000e000000000000000, type: 0} | ||||
|   m_Name: Sample WebGL Build Profile | ||||
|   m_EditorClassIdentifier:  | ||||
|   m_AssetVersion: 1 | ||||
|   m_BuildTarget: 20 | ||||
|   m_Subtarget: 0 | ||||
|   m_PlatformId: 84a3bb9e7420477f885e98145999eb20 | ||||
|   m_PlatformBuildProfile: | ||||
|     rid: 200022742090383361 | ||||
|   m_OverrideGlobalSceneList: 0 | ||||
|   m_Scenes: [] | ||||
|   m_ScriptingDefines:  | ||||
|     - BUILD_PROFILE_LOADED | ||||
|   m_PlayerSettingsYaml: | ||||
|     m_Settings: [] | ||||
|   references: | ||||
|     version: 2 | ||||
|     RefIds: | ||||
|     - rid: 200022742090383361 | ||||
|       type: {class: WebGLPlatformSettings, ns: UnityEditor.WebGL, asm: UnityEditor.WebGL.Extensions} | ||||
|       data: | ||||
|         m_Development: 0 | ||||
|         m_ConnectProfiler: 0 | ||||
|         m_BuildWithDeepProfilingSupport: 0 | ||||
|         m_AllowDebugging: 0 | ||||
|         m_WaitForManagedDebugger: 0 | ||||
|         m_ManagedDebuggerFixedPort: 0 | ||||
|         m_ExplicitNullChecks: 0 | ||||
|         m_ExplicitDivideByZeroChecks: 0 | ||||
|         m_ExplicitArrayBoundsChecks: 0 | ||||
|         m_CompressionType: -1 | ||||
|         m_InstallInBuildFolder: 0 | ||||
|         m_CodeOptimization: 0 | ||||
|         m_WebGLClientBrowserPath:  | ||||
|         m_WebGLClientBrowserType: 0 | ||||
|         m_WebGLTextureSubtarget: 0 | ||||
|  | @ -1,8 +0,0 @@ | |||
| fileFormatVersion: 2 | ||||
| guid: b9aac23ad2add4b439decb0cf65b0d68 | ||||
| NativeFormatImporter: | ||||
|   externalObjects: {} | ||||
|   mainObjectFileID: 11400000 | ||||
|   userData:  | ||||
|   assetBundleName:  | ||||
|   assetBundleVariant:  | ||||
|  | @ -1,49 +0,0 @@ | |||
| %YAML 1.1 | ||||
| %TAG !u! tag:unity3d.com,2011: | ||||
| --- !u!114 &11400000 | ||||
| MonoBehaviour: | ||||
|   m_ObjectHideFlags: 0 | ||||
|   m_CorrespondingSourceObject: {fileID: 0} | ||||
|   m_PrefabInstance: {fileID: 0} | ||||
|   m_PrefabAsset: {fileID: 0} | ||||
|   m_GameObject: {fileID: 0} | ||||
|   m_Enabled: 1 | ||||
|   m_EditorHideFlags: 0 | ||||
|   m_Script: {fileID: 15003, guid: 0000000000000000e000000000000000, type: 0} | ||||
|   m_Name: Sample Windows Build Profile | ||||
|   m_EditorClassIdentifier:  | ||||
|   m_AssetVersion: 1 | ||||
|   m_BuildTarget: 19 | ||||
|   m_Subtarget: 2 | ||||
|   m_PlatformId: 4e3c793746204150860bf175a9a41a05 | ||||
|   m_PlatformBuildProfile: | ||||
|     rid: 9120355575023534081 | ||||
|   m_OverrideGlobalSceneList: 0 | ||||
|   m_Scenes: [] | ||||
|   m_ScriptingDefines: | ||||
|   - BUILD_PROFILE_LOADED | ||||
|   m_PlayerSettingsYaml: | ||||
|     m_Settings: [] | ||||
|   references: | ||||
|     version: 2 | ||||
|     RefIds: | ||||
|     - rid: 9120355575023534081 | ||||
|       type: {class: WindowsPlatformSettings, ns: UnityEditor.WindowsStandalone, asm: UnityEditor.WindowsStandalone.Extensions} | ||||
|       data: | ||||
|         m_Development: 1 | ||||
|         m_ConnectProfiler: 0 | ||||
|         m_BuildWithDeepProfilingSupport: 0 | ||||
|         m_AllowDebugging: 0 | ||||
|         m_WaitForManagedDebugger: 0 | ||||
|         m_ManagedDebuggerFixedPort: 0 | ||||
|         m_ExplicitNullChecks: 0 | ||||
|         m_ExplicitDivideByZeroChecks: 0 | ||||
|         m_ExplicitArrayBoundsChecks: 0 | ||||
|         m_CompressionType: 0 | ||||
|         m_InstallInBuildFolder: 0 | ||||
|         m_WindowsBuildAndRunDeployTarget: 0 | ||||
|         m_Architecture: 0 | ||||
|         m_CreateSolution: 0 | ||||
|         m_CopyPDBFiles: 0 | ||||
|         m_WindowsDevicePortalAddress:  | ||||
|         m_WindowsDevicePortalUsername:  | ||||
|  | @ -1,8 +0,0 @@ | |||
| fileFormatVersion: 2 | ||||
| guid: 89540e92f0e247d4084f426eb3bdb288 | ||||
| NativeFormatImporter: | ||||
|   externalObjects: {} | ||||
|   mainObjectFileID: 11400000 | ||||
|   userData:  | ||||
|   assetBundleName:  | ||||
|   assetBundleVariant:  | ||||
|  | @ -1,46 +0,0 @@ | |||
| %YAML 1.1 | ||||
| %TAG !u! tag:unity3d.com,2011: | ||||
| --- !u!114 &11400000 | ||||
| MonoBehaviour: | ||||
|   m_ObjectHideFlags: 0 | ||||
|   m_CorrespondingSourceObject: {fileID: 0} | ||||
|   m_PrefabInstance: {fileID: 0} | ||||
|   m_PrefabAsset: {fileID: 0} | ||||
|   m_GameObject: {fileID: 0} | ||||
|   m_Enabled: 1 | ||||
|   m_EditorHideFlags: 0 | ||||
|   m_Script: {fileID: 15003, guid: 0000000000000000e000000000000000, type: 0} | ||||
|   m_Name: Sample macOS Build Profile | ||||
|   m_EditorClassIdentifier:  | ||||
|   m_AssetVersion: 1 | ||||
|   m_BuildTarget: 2 | ||||
|   m_Subtarget: 2 | ||||
|   m_PlatformId: 0d2129357eac403d8b359c2dcbf82502 | ||||
|   m_PlatformBuildProfile: | ||||
|     rid: 9120355587586260993 | ||||
|   m_OverrideGlobalSceneList: 0 | ||||
|   m_Scenes: [] | ||||
|   m_ScriptingDefines: | ||||
|   - BUILD_PROFILE_LOADED | ||||
|   m_PlayerSettingsYaml: | ||||
|     m_Settings: [] | ||||
|   references: | ||||
|     version: 2 | ||||
|     RefIds: | ||||
|     - rid: 9120355587586260993 | ||||
|       type: {class: OSXStandaloneBuildProfile, ns: UnityEditor.OSXStandalone, asm: UnityEditor.OSXStandalone.Extensions} | ||||
|       data: | ||||
|         m_Development: 0 | ||||
|         m_ConnectProfiler: 0 | ||||
|         m_BuildWithDeepProfilingSupport: 0 | ||||
|         m_AllowDebugging: 0 | ||||
|         m_WaitForManagedDebugger: 0 | ||||
|         m_ManagedDebuggerFixedPort: 0 | ||||
|         m_ExplicitNullChecks: 0 | ||||
|         m_ExplicitDivideByZeroChecks: 0 | ||||
|         m_ExplicitArrayBoundsChecks: 0 | ||||
|         m_CompressionType: 0 | ||||
|         m_InstallInBuildFolder: 0 | ||||
|         m_MacOSXcodeBuildConfig: 1 | ||||
|         m_Architecture: 2 | ||||
|         m_CreateXcodeProject: 0 | ||||
|  | @ -1,8 +0,0 @@ | |||
| fileFormatVersion: 2 | ||||
| guid: 081f4929fd671734ea1aa1511be7ec97 | ||||
| NativeFormatImporter: | ||||
|   externalObjects: {} | ||||
|   mainObjectFileID: 11400000 | ||||
|   userData:  | ||||
|   assetBundleName:  | ||||
|   assetBundleVariant:  | ||||
|  | @ -1,7 +1,7 @@ | |||
| { | ||||
|   "dependencies": { | ||||
|     "com.unity.burst": "1.8.22", | ||||
|     "com.unity.ide.visualstudio": "2.0.23", | ||||
|     "com.unity.burst": "1.6.6", | ||||
|     "com.unity.ide.visualstudio": "2.0.22", | ||||
|     "com.unity.modules.ai": "1.0.0", | ||||
|     "com.unity.modules.androidjni": "1.0.0", | ||||
|     "com.unity.modules.animation": "1.0.0", | ||||
|  |  | |||
|  | @ -1,12 +1,11 @@ | |||
| { | ||||
|   "dependencies": { | ||||
|     "com.unity.burst": { | ||||
|       "version": "1.8.22", | ||||
|       "version": "1.6.6", | ||||
|       "depth": 0, | ||||
|       "source": "registry", | ||||
|       "dependencies": { | ||||
|         "com.unity.mathematics": "1.2.1", | ||||
|         "com.unity.modules.jsonserialize": "1.0.0" | ||||
|         "com.unity.mathematics": "1.2.1" | ||||
|       }, | ||||
|       "url": "https://packages.unity.com" | ||||
|     }, | ||||
|  | @ -18,7 +17,7 @@ | |||
|       "url": "https://packages.unity.com" | ||||
|     }, | ||||
|     "com.unity.ide.visualstudio": { | ||||
|       "version": "2.0.23", | ||||
|       "version": "2.0.22", | ||||
|       "depth": 0, | ||||
|       "source": "registry", | ||||
|       "dependencies": { | ||||
|  | @ -34,7 +33,7 @@ | |||
|       "url": "https://packages.unity.com" | ||||
|     }, | ||||
|     "com.unity.test-framework": { | ||||
|       "version": "1.1.33", | ||||
|       "version": "1.1.31", | ||||
|       "depth": 1, | ||||
|       "source": "registry", | ||||
|       "dependencies": { | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| --- !u!129 &1 | ||||
| PlayerSettings: | ||||
|   m_ObjectHideFlags: 0 | ||||
|   serializedVersion: 24 | ||||
|   serializedVersion: 23 | ||||
|   productGUID: f3f6a917a3bba0046bb55998f8678f8c | ||||
|   AndroidProfiler: 0 | ||||
|   AndroidFilterTouchesWhenObscured: 0 | ||||
|  | @ -48,7 +48,6 @@ PlayerSettings: | |||
|   defaultScreenHeightWeb: 600 | ||||
|   m_StereoRenderingPath: 0 | ||||
|   m_ActiveColorSpace: 0 | ||||
|   unsupportedMSAAFallback: 0 | ||||
|   m_MTRendering: 1 | ||||
|   mipStripping: 0 | ||||
|   numberOfMipsStripped: 0 | ||||
|  | @ -75,7 +74,6 @@ PlayerSettings: | |||
|   androidMinimumWindowWidth: 400 | ||||
|   androidMinimumWindowHeight: 300 | ||||
|   androidFullscreenMode: 1 | ||||
|   androidAutoRotationBehavior: 1 | ||||
|   defaultIsNativeResolution: 1 | ||||
|   macRetinaSupport: 1 | ||||
|   runInBackground: 1 | ||||
|  | @ -123,7 +121,6 @@ PlayerSettings: | |||
|   switchNVNOtherPoolsGranularity: 16777216 | ||||
|   switchNVNMaxPublicTextureIDCount: 0 | ||||
|   switchNVNMaxPublicSamplerIDCount: 0 | ||||
|   switchMaxWorkerMultiple: 8 | ||||
|   stadiaPresentMode: 0 | ||||
|   stadiaTargetFramerate: 0 | ||||
|   vulkanNumSwapchainBuffers: 3 | ||||
|  | @ -183,10 +180,10 @@ PlayerSettings: | |||
|   StripUnusedMeshComponents: 1 | ||||
|   VertexChannelCompressionMask: 4054 | ||||
|   iPhoneSdkVersion: 988 | ||||
|   iOSTargetOSVersionString: 12.0 | ||||
|   iOSTargetOSVersionString: 11.0 | ||||
|   tvOSSdkVersion: 0 | ||||
|   tvOSRequireExtendedGameController: 0 | ||||
|   tvOSTargetOSVersionString: 12.0 | ||||
|   tvOSTargetOSVersionString: 11.0 | ||||
|   uIPrerenderedIcon: 0 | ||||
|   uIRequiresPersistentWiFi: 0 | ||||
|   uIRequiresFullScreen: 1 | ||||
|  | @ -250,7 +247,6 @@ PlayerSettings: | |||
|   useCustomLauncherGradleManifest: 0 | ||||
|   useCustomBaseGradleTemplate: 0 | ||||
|   useCustomGradlePropertiesTemplate: 0 | ||||
|   useCustomGradleSettingsTemplate: 0 | ||||
|   useCustomProguardFile: 0 | ||||
|   AndroidTargetArchitectures: 3 | ||||
|   AndroidTargetDevices: 0 | ||||
|  | @ -271,6 +267,7 @@ PlayerSettings: | |||
|     banner: {fileID: 0} | ||||
|   androidGamepadSupportLevel: 0 | ||||
|   chromeosInputEmulation: 1 | ||||
|   AndroidMinifyWithR8: 0 | ||||
|   AndroidMinifyRelease: 0 | ||||
|   AndroidMinifyDebug: 0 | ||||
|   AndroidValidateAppBundleSize: 1 | ||||
|  | @ -519,7 +516,6 @@ PlayerSettings: | |||
|   - m_BuildTarget: WebGL | ||||
|     m_StaticBatching: 0 | ||||
|     m_DynamicBatching: 0 | ||||
|   m_BuildTargetShaderSettings: [] | ||||
|   m_BuildTargetGraphicsJobs: | ||||
|   - m_BuildTarget: MacStandaloneSupport | ||||
|     m_GraphicsJobs: 0 | ||||
|  | @ -571,8 +567,6 @@ PlayerSettings: | |||
|     m_Devices: | ||||
|     - Oculus | ||||
|     - OpenVR | ||||
|   m_DefaultShaderChunkSizeInMB: 16 | ||||
|   m_DefaultShaderChunkCount: 0 | ||||
|   openGLRequireES31: 0 | ||||
|   openGLRequireES31AEP: 0 | ||||
|   openGLRequireES32: 0 | ||||
|  | @ -616,7 +610,7 @@ PlayerSettings: | |||
|   switchSocketConcurrencyLimit: 14 | ||||
|   switchScreenResolutionBehavior: 2 | ||||
|   switchUseCPUProfiler: 0 | ||||
|   switchEnableFileSystemTrace: 0 | ||||
|   switchUseGOLDLinker: 0 | ||||
|   switchLTOSetting: 0 | ||||
|   switchApplicationID: 0x01004b9000490000 | ||||
|   switchNSODependencies:  | ||||
|  | @ -693,6 +687,7 @@ PlayerSettings: | |||
|   switchReleaseVersion: 0 | ||||
|   switchDisplayVersion: 1.0.0 | ||||
|   switchStartupUserAccount: 0 | ||||
|   switchTouchScreenUsage: 0 | ||||
|   switchSupportedLanguagesMask: 0 | ||||
|   switchLogoType: 0 | ||||
|   switchApplicationErrorCodeCategory:  | ||||
|  | @ -734,7 +729,6 @@ PlayerSettings: | |||
|   switchNativeFsCacheSize: 32 | ||||
|   switchIsHoldTypeHorizontal: 0 | ||||
|   switchSupportedNpadCount: 8 | ||||
|   switchEnableTouchScreen: 1 | ||||
|   switchSocketConfigEnabled: 0 | ||||
|   switchTcpInitialSendBufferSize: 32 | ||||
|   switchTcpInitialReceiveBufferSize: 64 | ||||
|  | @ -745,8 +739,8 @@ PlayerSettings: | |||
|   switchSocketBufferEfficiency: 4 | ||||
|   switchSocketInitializeEnabled: 1 | ||||
|   switchNetworkInterfaceManagerInitializeEnabled: 1 | ||||
|   switchPlayerConnectionEnabled: 1 | ||||
|   switchUseNewStyleFilepaths: 0 | ||||
|   switchUseLegacyFmodPriorities: 1 | ||||
|   switchUseMicroSleepForYield: 1 | ||||
|   switchEnableRamDiskSupport: 0 | ||||
|   switchMicroSleepForYieldTime: 25 | ||||
|  | @ -821,7 +815,6 @@ PlayerSettings: | |||
|   ps4videoRecordingFeaturesUsed: 0 | ||||
|   ps4contentSearchFeaturesUsed: 0 | ||||
|   ps4CompatibilityPS5: 0 | ||||
|   ps4AllowPS5Detection: 0 | ||||
|   ps4GPU800MHz: 1 | ||||
|   ps4attribEyeToEyeDistanceSettingVR: 0 | ||||
|   ps4IncludedModules: [] | ||||
|  | @ -846,7 +839,6 @@ PlayerSettings: | |||
|   webGLLinkerTarget: 1 | ||||
|   webGLThreadsSupport: 0 | ||||
|   webGLDecompressionFallback: 0 | ||||
|   webGLPowerPreference: 2 | ||||
|   scriptingDefineSymbols: {} | ||||
|   additionalCompilerArguments: {} | ||||
|   platformArchitecture: {} | ||||
|  | @ -855,21 +847,7 @@ PlayerSettings: | |||
|     Server: 0 | ||||
|     Standalone: 0 | ||||
|   il2cppCompilerConfiguration: {} | ||||
|   managedStrippingLevel: | ||||
|     Android: 1 | ||||
|     EmbeddedLinux: 1 | ||||
|     GameCoreScarlett: 1 | ||||
|     GameCoreXboxOne: 1 | ||||
|     Lumin: 1 | ||||
|     Nintendo Switch: 1 | ||||
|     PS4: 1 | ||||
|     PS5: 1 | ||||
|     Stadia: 1 | ||||
|     WebGL: 1 | ||||
|     Windows Store Apps: 1 | ||||
|     XboxOne: 1 | ||||
|     iPhone: 1 | ||||
|     tvOS: 1 | ||||
|   managedStrippingLevel: {} | ||||
|   incrementalIl2cppBuild: {} | ||||
|   suppressCommonWarnings: 1 | ||||
|   allowUnsafeCode: 0 | ||||
|  | @ -885,11 +863,11 @@ PlayerSettings: | |||
|   m_MobileRenderingPath: 1 | ||||
|   metroPackageName: Template3D | ||||
|   metroPackageVersion: 1.0.0.0 | ||||
|   metroCertificatePath: C:\Users\david\Documents\GitHub\unity-builder\test-project\Assets\WSATestCertificate.pfx | ||||
|   metroCertificatePath:  | ||||
|   metroCertificatePassword:  | ||||
|   metroCertificateSubject: GameCI | ||||
|   metroCertificateIssuer: GameCI | ||||
|   metroCertificateNotAfter: 00b8ac9241f7dc01 | ||||
|   metroCertificateSubject:  | ||||
|   metroCertificateIssuer:  | ||||
|   metroCertificateNotAfter: 0000000000000000 | ||||
|   metroApplicationDescription: Template_3D | ||||
|   wsaImages: {} | ||||
|   metroTileShortName: TestProject | ||||
|  | @ -904,7 +882,6 @@ PlayerSettings: | |||
|   metroTileBackgroundColor: {r: 0.13333334, g: 0.17254902, b: 0.21568628, a: 0} | ||||
|   metroSplashScreenBackgroundColor: {r: 0.12941177, g: 0.17254902, b: 0.21568628, a: 1} | ||||
|   metroSplashScreenUseBackgroundColor: 0 | ||||
|   syncCapabilities: 0 | ||||
|   platformCapabilities: {} | ||||
|   metroTargetDeviceFamilies: {} | ||||
|   metroFTAName:  | ||||
|  | @ -954,7 +931,6 @@ PlayerSettings: | |||
|     m_VersionName:  | ||||
|   apiCompatibilityLevel: 6 | ||||
|   activeInputHandler: 0 | ||||
|   windowsGamepadBackendHint: 0 | ||||
|   cloudProjectId:  | ||||
|   framebufferDepthMemorylessMode: 0 | ||||
|   qualitySettingsNames: [] | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| m_EditorVersion: 2021.3.45f1 | ||||
| m_EditorVersionWithRevision: 2021.3.45f1 (0da89fac8e79) | ||||
| m_EditorVersion: 2021.3.4f1 | ||||
| m_EditorVersionWithRevision: 2021.3.4f1 (cb45f9cae8b7) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue