From cbf51885cd657c99db480e93aeb9daa37c9edf96 Mon Sep 17 00:00:00 2001 From: Eric Ribeiro Date: Wed, 31 Aug 2022 11:39:48 -0700 Subject: [PATCH] feat: make artifact storage optional (#27) * feat: make artifacts storage optional * test: replace test jobs with pre-steps --- .circleci/test-deploy.yml | 416 +++++++------------------------------- src/commands/build.yml | 31 ++- src/jobs/build.yml | 11 +- 3 files changed, 100 insertions(+), 358 deletions(-) diff --git a/.circleci/test-deploy.yml b/.circleci/test-deploy.yml index 53b09d3..a99ad87 100644 --- a/.circleci/test-deploy.yml +++ b/.circleci/test-deploy.yml @@ -7,343 +7,32 @@ filters: &filters tags: only: /.*/ -jobs: - build-il2cpp: - description: > - Simple drop-in job to build your Unity game. +pre-steps: + mono: &mono + - run: + name: "Clone the demo project" + command: | + # Clone the "mono" demo project + git clone --branch master --single-branch https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git ../Unity2D-Demo-Game-CI-CD + + # Clone the Unity orb + git clone https://github.com/game-ci/unity-orb.git . - parameters: - step-name: - type: string - default: Build the project - description: | - Specify a custom step name for the build command, if desired. - executor: - type: executor - description: | - Pick an Executor to run the build job with. - unity-username-var-name: - type: env_var_name - default: "UNITY_USERNAME" - description: | - Enter the name of the environment variable containing your Unity username. - This is only necessary if you have a Plus or Pro license. - unity-password-var-name: - type: env_var_name - default: "UNITY_PASSWORD" - description: | - Enter the name of the environment variable containing your Unity password. - This is only necessary if you have a Plus or Pro license. - unity-serial-var-name: - type: env_var_name - default: "UNITY_SERIAL" - description: | - Enter the name of the environment variable containing your Unity serial number. - This is only necessary if you have a Plus or Pro license. - unity-license-var-name: - type: env_var_name - default: "UNITY_ENCODED_LICENSE" - description: | - Enter the name of the environment variable containing your Unity license file encoded in base64. - A different license must be provided for every Unity major version. - This is only necessary if you have a Personal license. - project-path: - type: string - default: "." - description: | - Enter the path of your Unity project. - This should be the directory that has an "Assets" folder inside it. - build-target: - type: string - description: | - The target platform of your build. - Accepted arguments vary with Unity's version and can be found in the docs: https://docs.unity3d.com/2022.2/Documentation/ScriptReference/BuildTarget.html - build-name: - type: string - default: "UnityBuild" - description: | - Enter the name for this build. - compress: - type: boolean - default: true - description: | - Whether to compress the build output to a ".tar.gz" archive. - This is recommended if you want to download the build artifacts from the GameCI dashboard. - If left to "false" for decompressed WebGL builds, the built project can be run directly from the GameCI dashboard. + # Move the demo project to the project folder + mv ../Unity2D-Demo-Game-CI-CD ./Unity2D-Demo-Game-CI-CD + il2cpp: &il2cpp + - run: + name: "Clone the demo project" + command: | + # Clone the "il2cpp" demo project + mkdir /tmp/unity + git clone --branch windows-il2cpp --single-branch https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git ../Unity2D-Demo-Game-CI-CD - executor: << parameters.executor >> + # Clone the Unity orb + git clone https://github.com/game-ci/unity-orb.git . - steps: - - run: - name: "Clone CircleCI demo repository" - command: | - git clone https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git - cd Unity2D-Demo-Game-CI-CD - git fetch --all - git checkout windows-il2cpp - - unity/prepare-env: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - unity-serial-var-name: << parameters.unity-serial-var-name >> - unity-license-var-name: << parameters.unity-license-var-name >> - project-path: <> - cache-version: v2 - - unity/build: - step-name: << parameters.step-name >> - build-name: <> - build-target: <> - project-path: <> - compress: <> - cache-version: v2 - - unity/return-license: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - - build-mono: - description: > - Simple drop-in job to build your Unity game. - - parameters: - step-name: - type: string - default: Build the project - description: | - Specify a custom step name for the build command, if desired. - executor: - type: executor - description: | - Pick an Executor to run the build job with. - unity-username-var-name: - type: env_var_name - default: "UNITY_USERNAME" - description: | - Enter the name of the environment variable containing your Unity username. - This is only necessary if you have a Plus or Pro license. - unity-password-var-name: - type: env_var_name - default: "UNITY_PASSWORD" - description: | - Enter the name of the environment variable containing your Unity password. - This is only necessary if you have a Plus or Pro license. - unity-serial-var-name: - type: env_var_name - default: "UNITY_SERIAL" - description: | - Enter the name of the environment variable containing your Unity serial number. - This is only necessary if you have a Plus or Pro license. - unity-license-var-name: - type: env_var_name - default: "UNITY_ENCODED_LICENSE" - description: | - Enter the name of the environment variable containing your Unity license file encoded in base64. - A different license must be provided for every Unity major version. - This is only necessary if you have a Personal license. - project-path: - type: string - default: "." - description: | - Enter the path of your Unity project. - This should be the directory that has an "Assets" folder inside it. - build-target: - type: string - description: | - The target platform of your build. - Accepted arguments vary with Unity's version and can be found in the docs: https://docs.unity3d.com/2022.2/Documentation/ScriptReference/BuildTarget.html - build-name: - type: string - default: "UnityBuild" - description: | - Enter the name for this build. - compress: - type: boolean - default: true - description: | - Whether to compress the build output to a ".tar.gz" archive. - This is recommended if you want to download the build artifacts from the GameCI dashboard. - If left to "false" for decompressed WebGL builds, the built project can be run directly from the GameCI dashboard. - - executor: << parameters.executor >> - - steps: - - run: - name: "Clone CircleCI demo repository" - command: | - git clone https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git - - unity/prepare-env: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - unity-serial-var-name: << parameters.unity-serial-var-name >> - unity-license-var-name: << parameters.unity-license-var-name >> - project-path: <> - - unity/build: - step-name: << parameters.step-name >> - build-name: <> - build-target: <> - project-path: <> - compress: <> - - unity/return-license: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - - build: - description: > - Simple drop-in job to build your Unity game. - - parameters: - step-name: - type: string - default: Build the project - description: | - Specify a custom step name for the build command, if desired. - executor: - type: executor - description: | - Pick an Executor to run the build job with. - unity-username-var-name: - type: env_var_name - default: "UNITY_USERNAME" - description: | - Enter the name of the environment variable containing your Unity username. - This is only necessary if you have a Plus or Pro license. - unity-password-var-name: - type: env_var_name - default: "UNITY_PASSWORD" - description: | - Enter the name of the environment variable containing your Unity password. - This is only necessary if you have a Plus or Pro license. - unity-serial-var-name: - type: env_var_name - default: "UNITY_SERIAL" - description: | - Enter the name of the environment variable containing your Unity serial number. - This is only necessary if you have a Plus or Pro license. - unity-license-var-name: - type: env_var_name - default: "UNITY_ENCODED_LICENSE" - description: | - Enter the name of the environment variable containing your Unity license file encoded in base64. - A different license must be provided for every Unity major version. - This is only necessary if you have a Personal license. - project-path: - type: string - default: "." - description: | - Enter the path of your Unity project. - This should be the directory that has an "Assets" folder inside it. - build-target: - type: string - description: | - The target platform of your build. - Accepted arguments vary with Unity's version and can be found in the docs: https://docs.unity3d.com/2022.2/Documentation/ScriptReference/BuildTarget.html - build-name: - type: string - default: "UnityBuild" - description: | - Enter the name for this build. - compress: - type: boolean - default: true - description: | - Whether to compress the build output to a ".tar.gz" archive. - This is recommended if you want to download the build artifacts from the GameCI dashboard. - If left to "false" for decompressed WebGL builds, the built project can be run directly from the GameCI dashboard. - - executor: << parameters.executor >> - - steps: - - run: - name: "Clone CircleCI demo repository" - command: | - git clone https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git - - unity/prepare-env: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - unity-serial-var-name: << parameters.unity-serial-var-name >> - unity-license-var-name: << parameters.unity-license-var-name >> - project-path: <> - - unity/build: - step-name: << parameters.step-name >> - build-name: <> - build-target: <> - project-path: <> - compress: <> - - unity/return-license: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - - test: - description: > - Simple drop-in job to build your Unity game. - - parameters: - step-name: - type: string - default: Run tests - description: | - Specify a custom step name for the test command, if desired. - executor: - type: executor - description: | - Pick an Executor to run the build job with. - unity-username-var-name: - type: env_var_name - default: "UNITY_USERNAME" - description: | - Enter the name of the environment variable containing your Unity username. - This is only necessary if you have a Plus or Pro license. - unity-password-var-name: - type: env_var_name - default: "UNITY_PASSWORD" - description: | - Enter the name of the environment variable containing your Unity password. - This is only necessary if you have a Plus or Pro license. - unity-serial-var-name: - type: env_var_name - default: "UNITY_SERIAL" - description: | - Enter the name of the environment variable containing your Unity serial number. - This is only necessary if you have a Plus or Pro license. - unity-license-var-name: - type: env_var_name - default: "UNITY_ENCODED_LICENSE" - description: | - Enter the name of the environment variable containing your Unity license file encoded in base64. - A different license must be provided for every Unity major version. - This is only necessary if you have a Personal license. - project-path: - type: string - default: "." - description: | - Enter the path of your Unity project. - This should be the directory that has an "Assets" folder inside it. - test-platform: - type: string - default: "editmode" - description: | - Specify the test platform to run tests on. - Valid values are "editmode", "playmode" and Unity's target builds. - More information can be found on: https://docs.unity3d.com/Packages/com.unity.test-framework@2.0/manual/reference-command-line.html - - executor: << parameters.executor >> - - steps: - - run: - name: "Clone CircleCI demo repository" - command: | - git clone https://github.com/EricRibeiro/Unity2D-Demo-Game-CI-CD.git - - unity/prepare-env: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> - unity-serial-var-name: << parameters.unity-serial-var-name >> - unity-license-var-name: << parameters.unity-license-var-name >> - project-path: <> - - unity/test: - step-name: << parameters.step-name >> - test-platform: << parameters.test-platform >> - project-path: << parameters.project-path >> - - unity/return-license: - unity-username-var-name: << parameters.unity-username-var-name >> - unity-password-var-name: << parameters.unity-password-var-name >> + # Move the demo project to the project folder + mv ../Unity2D-Demo-Game-CI-CD ./Unity2D-Demo-Game-CI-CD workflows: test-build: @@ -356,7 +45,7 @@ workflows: editor_version: 2022.1.11f1 # Tests - - test: + - unity/test: name: "test-linux" step-name: "Check if the tests run and results are uploaded" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -371,7 +60,8 @@ workflows: test-platform: "playmode" filters: *filters context: orb-testing-unity - - test: + pre-steps: *mono + - unity/test: name: "test-windows" step-name: "Check if the tests run and results are uploaded" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -386,7 +76,8 @@ workflows: test-platform: "playmode" filters: *filters context: orb-testing-unity - - test: + pre-steps: *mono + - unity/test: name: "test-osx" step-name: "Check if the tests run and results are uploaded" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -400,9 +91,10 @@ workflows: test-platform: "playmode" filters: *filters context: orb-testing-unity + pre-steps: *mono # IL2CPP Builds - - build-il2cpp: + - unity/build: name: "build-linux64-il2cpp" step-name: "Build StandaloneLinux64" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -418,7 +110,8 @@ workflows: compress: true filters: *filters context: orb-testing-unity - - build-il2cpp: + pre-steps: *il2cpp + - unity/build: name: "build-Windows64-il2cpp" step-name: "Build StandaloneWindows64 il2cpp" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -434,7 +127,8 @@ workflows: compress: true filters: *filters context: orb-testing-unity - - build-il2cpp: + pre-steps: *il2cpp + - unity/build: name: "build-osx-il2cpp" step-name: "Build macOS IL2CPP" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -449,9 +143,10 @@ workflows: compress: true filters: *filters context: orb-testing-unity + pre-steps: *il2cpp # Mono Builds - - build-mono: + - unity/build: name: "build-linux64-mono" step-name: "Build StandaloneLinux64" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -467,7 +162,8 @@ workflows: compress: true filters: *filters context: orb-testing-unity - - build-mono: + pre-steps: *mono + - unity/build: name: "build-Windows64-mono" step-name: "Build StandaloneWindows64" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -482,7 +178,8 @@ workflows: build-target: "StandaloneWindows64" filters: *filters context: orb-testing-unity - - build-mono: + pre-steps: *mono + - unity/build: name: "build-osx-mono" step-name: "Build StandaloneOSX" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -497,9 +194,10 @@ workflows: build-target: "StandaloneOSX" filters: *filters context: orb-testing-unity + pre-steps: *mono # Other Builds - - build: + - unity/build: name: "build-webgl" step-name: "Build WebGL" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -515,7 +213,8 @@ workflows: compress: false filters: *filters context: orb-testing-unity - - build: + pre-steps: *mono + - unity/build: name: "build-android" step-name: "Build Android" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -530,7 +229,8 @@ workflows: build-target: "Android" filters: *filters context: orb-testing-unity - - build: + pre-steps: *mono + - unity/build: name: "build-ios" step-name: "Build iOS" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -545,7 +245,8 @@ workflows: build-target: "iOS" filters: *filters context: orb-testing-unity - - build: + pre-steps: *mono + - unity/build: name: "build-tvOS" step-name: "Build Apple's tvOS" unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" @@ -561,6 +262,26 @@ workflows: compress: true filters: *filters context: orb-testing-unity + pre-steps: *mono + + # Other Tests + - unity/build: + name: "build-without-artifacts" + step-name: "Build StandaloneLinux64 with no artifacts" + unity-license-var-name: "UNITY_ENCODED_LICENSE_2021" + unity-username-var-name: "UNITY_USERNAME" + unity-password-var-name: "UNITY_PASSWORD" + executor: + name: "unity/ubuntu" + target_platform: "base" + editor_version: "2021.3.1f1" + resource_class: "large" + project-path: "Unity2D-Demo-Game-CI-CD/src" + build-target: StandaloneLinux64 + store-artifacts: false + filters: *filters + context: orb-testing-unity + pre-steps: *mono - orb-tools/pack: filters: *filters @@ -583,6 +304,7 @@ workflows: - build-android - build-ios - build-tvOS + - build-without-artifacts context: orb-publishing filters: branches: diff --git a/src/commands/build.yml b/src/commands/build.yml index d446954..9b92024 100644 --- a/src/commands/build.yml +++ b/src/commands/build.yml @@ -30,17 +30,23 @@ parameters: description: | Change the default cache version if you need to clear the cache for any reason. include-branch-in-cache-key: - type: boolean - default: true - description: > - If true, this cache bucket will only apply to jobs within the same branch. + type: boolean + default: true + description: > + If true, this cache bucket will only apply to jobs within the same branch. + store-artifacts: + type: boolean + default: true + description: | + Whether to store the build output. + If left to "false" you won't be able to download the build from the job's artifacts. compress: type: boolean default: true description: | Whether to compress the build output to a ".tar.gz" archive. - This is recommended if you want to download the built artifacts from the GameCI dashboard. - If left to "false" for decompressed WebGL builds, the built project can be run directly from the GameCI dashboard. + This is recommended if you want to download the built artifacts from the CircleCI web app. + If left to "false" for decompressed WebGL builds, you can run the project directly from the CircleCI web app. steps: - run: @@ -61,12 +67,19 @@ steps: paths: - << parameters.project-path >>/Library/ - when: - condition: << parameters.compress >> + condition: + and: + - << parameters.store-artifacts >> + - << parameters.compress >> steps: - store_artifacts: path: << parameters.build-target >>.tar.gz - - unless: - condition: << parameters.compress >> + + - when: + condition: + and: + - << parameters.store-artifacts >> + - not: << parameters.compress >> steps: - store_artifacts: path: << parameters.project-path >>/Builds/<< parameters.build-target >> diff --git a/src/jobs/build.yml b/src/jobs/build.yml index 46fc300..21752fb 100755 --- a/src/jobs/build.yml +++ b/src/jobs/build.yml @@ -50,13 +50,19 @@ parameters: description: | Enter the name for this build. If left blank, the build will be named after the target platform. + store-artifacts: + type: boolean + default: true + description: | + Whether to store the build output. + If left to "false" you won't be able to download the build from the job's artifacts. compress: type: boolean default: true description: | Whether to compress the build output to a ".tar.gz" archive. - This is recommended if you want to download the build artifacts from the GameCI dashboard. - If left to "false" for decompressed WebGL builds, the built project can be run directly from the GameCI dashboard. + This is recommended if you want to download the built artifacts from the CircleCI web app. + If left to "false" for decompressed WebGL builds, you can run the project directly from the CircleCI web app. executor: << parameters.executor >> @@ -73,6 +79,7 @@ steps: build-name: <> build-target: <> project-path: <> + store-artifacts: <> compress: <> - return-license: unity-username-var-name: << parameters.unity-username-var-name >>