| * add check to verify dist files * change src, without running git hooks (expect failure) * change src again, now do run commit hook (expect success) * cleanup before squash | ||
|---|---|---|
| .github/workflows | ||
| builder | ||
| src | ||
| test-project | ||
| .dockerignore | ||
| .editorconfig | ||
| .eslintignore | ||
| .eslintrc.json | ||
| .gitignore | ||
| .prettierignore | ||
| .prettierrc.json | ||
| .yarnrc | ||
| LICENSE | ||
| README.md | ||
| action.yml | ||
| babel.config.js | ||
| jest.config.js | ||
| package.json | ||
| yarn.lock | ||
		
			
				
				README.md
			
		
		
			
			
		
	
	Unity - Builder
GitHub Action to build Unity projects for different platforms.
Part of the Unity Actions collection.
Github Action to build Unity projects for different platforms.
It is recommended to run the Test action from the Unity Actions collection before running this action. This action also requires the Activation step.
Documentation
See the Unity Actions collection repository for workflow documentation and reference implementation.
Usage
Create or edit the file called .github/workflows/main.yml and add a job to it.
- uses: webbertakken/unity-builder@v0.5
  env:
    UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }}
  with:
    projectPath: path/to/your/project
    unityVersion: 2020.X.XXXX
    targetPlatform: WebGL
A complete workflow that builds every available platform could look like this:
name: Build project
on:
  pull_request: {}
  push: { branches: [master] }
env:
  UNITY_LICENSE: ${{ secrets.UNITY_LICENSE }}
jobs:
  buildForSomePlatforms:
    name: Build for ${{ matrix.targetPlatform }} on version ${{ matrix.unityVersion }}
    runs-on: ubuntu-latest
    strategy:
      fail-fast: false
      matrix:
        projectPath:
          - path/to/your/project
        unityVersion:
          - 2019.2.11f1
          - 2019.3.0f1
        targetPlatform:
          - StandaloneOSX # Build a macOS standalone (Intel 64-bit).
          - StandaloneWindows # Build a Windows standalone.
          - StandaloneWindows64 # Build a Windows 64-bit standalone.
          - StandaloneLinux64 # Build a Linux 64-bit standalone.
          - iOS # Build an iOS player.
          - Android # Build an Android .apk standalone app.
          - WebGL # WebGL.
          - WSAPlayer # Build an Windows Store Apps player.
          - PS4 # Build a PS4 Standalone.
          - XboxOne # Build a Xbox One Standalone.
          - tvOS # Build to Apple's tvOS platform.
          - Switch # Build a Nintendo Switch player.
    steps:
      - uses: actions/checkout@v1
      - uses: webbertakken/unity-builder@v0.5
        with:
          projectPath: ${{ matrix.projectPath }}
          unityVersion: ${{ matrix.unityVersion }}
          targetPlatform: ${{ matrix.targetPlatform }}
      - uses: actions/upload-artifact@v1
        with:
          name: Build
          path: build
Notes:
- Don't forget to replace <test-project> with your project name.
- By default the enabled scenes from the project's settings will be built.
Configuration options
Below options can be specified under with: for the unity-builder action.
projectPath
Specify the path to your Unity project to be built. The path should be relative to the root of your project.
required: false
default: <your project root>
unityVersion
Version of Unity to use for building the project.
required: false
default: 2019.2.1f11
targetPlatform
Platform that the build should target.
Must be one of the allowed values listed in the Unity scripting manual.
required: true
buildName
Name of the build.
required: false
default: testBuild
buildsPath
Path where the builds should be stored.
In this folder a folder will be created for every targetPlatform.
required: false
default: build
buildMethod
Custom command to run your build.
There are two conditions for a custom buildCommand:
- Must reference a valid path to a staticmethod.
- The class must reside in the Assets/Editordirectory.
example:
- uses: webbertakken/unity-builder@master
  with:
    buildMethod: EditorNamespace.BuilderClassName.StaticBulidMethod
required: false
default: Built-in script that will run a build out of the box.
More actions
Visit Unity Actions to find related actions for Unity.
Feel free to contribute.