Test #86
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test | |
on: | |
schedule: | |
- cron: "0 11 * * *" # 11am UTC = 3`am PST | |
pull_request: | |
types: [ labeled, closed ] | |
workflow_dispatch: | |
inputs: | |
unity_version: | |
description: 'Unity version (value: 2018, 2019, 2020)' | |
default: '2019' | |
required: true | |
include_test_types: | |
description: 'Specify the only types of tests to run, separated by comma. See TestTypesEnum in build.gradle for options.' | |
default: '' | |
required: false | |
exclude_test_types: | |
description: 'Specify the types of tests to exclude, separated by comma. See TestTypesEnum in build.gradle for options.' | |
default: '' | |
required: false | |
include_test_modules: | |
description: 'Specify the only modules to test against, separated by comma. See TestModulesEnum in build.gradle for options.' | |
default: '' | |
required: false | |
exclude_test_modules: | |
description: 'Specify the modules to exclude from testing against, separated by comma. See TestModulesEnum in build.gradle for options.' | |
default: '' | |
required: false | |
exclude_tests: | |
description: 'Specify the tests to exclude, separated by comma. See the tasks in build.gradle for options.' | |
default: '' | |
required: false | |
env: | |
pythonVersion: '3.7' | |
artifactRetentionDays: 2 | |
jobs: | |
check_and_prepare: | |
runs-on: ubuntu-latest | |
outputs: | |
unity_version: ${{ steps.set_outputs.outputs.unity_version }} | |
include_test_types: ${{ steps.set_outputs.outputs.include_test_types }} | |
exclude_test_types: ${{ steps.set_outputs.outputs.exclude_test_types }} | |
include_test_modules: ${{ steps.set_outputs.outputs.include_test_modules }} | |
exclude_test_modules: ${{ steps.set_outputs.outputs.exclude_test_modules }} | |
exclude_tests: ${{ steps.set_outputs.outputs.exclude_tests }} | |
steps: | |
- id: set_outputs | |
run: | | |
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then | |
echo "unity_version=${{ github.event.inputs.unity_version }}" >> $GITHUB_OUTPUT | |
echo "include_test_types=${{ github.event.inputs.include_test_types }}" >> $GITHUB_OUTPUT | |
echo "exclude_test_types=${{ github.event.inputs.exclude_test_types }}" >> $GITHUB_OUTPUT | |
echo "include_test_modules=${{ github.event.inputs.include_test_modules }}" >> $GITHUB_OUTPUT | |
echo "exclude_test_modules=${{ github.event.inputs.exclude_test_modules }}" >> $GITHUB_OUTPUT | |
echo "exclude_tests=${{ github.event.inputs.exclude_tests }}" >> $GITHUB_OUTPUT | |
else | |
# inputs are not available for non "workflow_dispatch" events. Therefore, set default value here. | |
echo "unity_version=2019" >> $GITHUB_OUTPUT | |
echo "include_test_types=" >> $GITHUB_OUTPUT | |
echo "exclude_test_types=" >> $GITHUB_OUTPUT | |
echo "include_test_modules=" >> $GITHUB_OUTPUT | |
echo "exclude_test_modules=" >> $GITHUB_OUTPUT | |
echo "exclude_tests=" >> $GITHUB_OUTPUT | |
# This is currently checking for invalid trigger only. | |
if [[ "${{ github.event_name }}" == "schedule" ]]; then | |
# Do nothing for now | |
: | |
elif [[ "${{ github.event_name }}" == "pull_request" ]]; then | |
if [[ "${{ github.event.action }}" == "labeled" && "${{ github.event.label.name }}" == "tests-requested" ]]; then | |
# Do nothing for now | |
: | |
elif [[ "${{ github.event.action }}" == "closed" && "${{ github.event.pull_request.merged == true}}" == "true" ]]; then | |
# Do nothing for now | |
: | |
else | |
echo "invalid_trigger=1" >> $GITHUB_OUTPUT | |
fi | |
else | |
echo "invalid_trigger=1" >> $GITHUB_OUTPUT | |
fi | |
fi | |
- name: Cancel workflow | |
if: ${{ steps.set_outputs.outputs.invalid_trigger }} | |
uses: andymckay/[email protected] | |
- name: Wait for workflow cancellation | |
if: ${{ steps.set_outputs.outputs.invalid_trigger }} | |
run: | | |
sleep 300 | |
exit 1 # fail out if the cancellation above somehow failed. | |
- name: Print output | |
run: | | |
echo outputs.unity_version : ${{ steps.set_outputs.outputs.unity_version }} | |
echo outputs.include_test_types : ${{ steps.set_outputs.outputs.include_test_types }} | |
echo outputs.exclude_test_types : ${{ steps.set_outputs.outputs.exclude_test_types }} | |
echo outputs.include_test_modules : ${{ steps.set_outputs.outputs.include_test_modules }} | |
echo outputs.exclude_test_modules : ${{ steps.set_outputs.outputs.exclude_test_modules }} | |
echo outputs.exclude_tests : ${{ steps.set_outputs.outputs.exclude_tests }} | |
test_on_macos: | |
name: test-macOS-unity${{ needs.check_and_prepare.outputs.unity_version }} | |
runs-on: macos-latest | |
needs: [check_and_prepare] | |
strategy: | |
fail-fast: false | |
steps: | |
- uses: actions/checkout@v3 | |
- id: build_setup | |
uses: ./gha/build_setup | |
timeout-minutes: 30 | |
with: | |
unity_version: ${{ needs.check_and_prepare.outputs.unity_version }} | |
platform: macOS | |
python_version: ${{ env.pythonVersion }} | |
unity_username: ${{ secrets.UNITY_USERNAME }} | |
unity_password: ${{ secrets.UNITY_PASSWORD }} | |
unity_serial_id: ${{ secrets.SERIAL_ID }} | |
- name: Set Unity Env for EDM4U build script | |
shell: bash | |
run: echo "UNITY_EXE=${{ env.UNITY_ROOT_DIR }}/Unity.app/Contents/MacOS/Unity" >> $GITHUB_ENV | |
- name: Run tests | |
shell: bash | |
timeout-minutes: 60 | |
run: | | |
./gradlew test -q \ | |
-PINTERACTIVE_MODE_TESTS_ENABLED=0 \ | |
-PINCLUDE_TEST_TYPES="${{ needs.check_and_prepare.outputs.include_test_types }}" \ | |
-PEXCLUDE_TEST_TYPES="${{ needs.check_and_prepare.outputs.exclude_test_types }}" \ | |
-PINCLUDE_TEST_MODULES="${{ needs.check_and_prepare.outputs.include_test_modules }}" \ | |
-PEXCLUDE_TEST_MODULES="${{ needs.check_and_prepare.outputs.exclude_test_modules }}" \ | |
-PEXCLUDE_TESTS="${{ needs.check_and_prepare.outputs.exclude_tests }}" | |
- name: Print test log | |
if: always() | |
shell: bash | |
continue-on-error: true | |
run: cat test_output/test*IntegrationTestsBatchMode/*.log | |
- name: Obtain Failed tests from Integration tests and NUnit tests | |
if: always() | |
shell: bash | |
continue-on-error: true | |
run: | | |
# Quick and dirty way to get all failed tests in granular level. | |
# TODO: better parser for more information, ex. error message. | |
{ cat test_output/test*/*_test.log || true; } | { grep "^Test .* FAILED$" || true; } | |
{ cat test_output/test*/test*/results.xml || true; } | { grep '^ *<test-case.*result="Failed"' || true; } | sed 's/^.* name="\([^\"]*\)".*$/Test \1: FAILED/' | |
- name: Return Unity license | |
if: always() | |
uses: firebase/firebase-unity-sdk/gha/unity@main | |
with: | |
version: ${{ needs.check_and_prepare.outputs.unity_version }} | |
release_license: "true" | |
- name: Upload build logs | |
uses: actions/upload-artifact@v3 | |
if: ${{ !cancelled() }} | |
with: | |
name: logs | |
path: test_output/test*/*.log | |
retention-days: ${{ env.artifactRetentionDays }} |