diff --git a/action.yml b/action.yml index bbdb4a0d..d0a36689 100644 --- a/action.yml +++ b/action.yml @@ -9,7 +9,7 @@ inputs: customImage: required: false default: '' - description: 'Specific docker image that should be used for testing the project. If packageMode is true, this image must be compatible with apt-get.' + description: 'Specific docker image that should be used for testing the project. If packageMode is true, this image must have jq installed.' projectPath: required: false description: 'Path to the Unity project or package to be tested.' diff --git a/dist/steps/run_tests.sh b/dist/steps/run_tests.sh index ae61545c..3f1318db 100755 --- a/dist/steps/run_tests.sh +++ b/dist/steps/run_tests.sh @@ -1,239 +1,246 @@ -#!/usr/bin/env bash - -# -# Set and display project path -# - -UNITY_PROJECT_PATH="$GITHUB_WORKSPACE/$PROJECT_PATH" -echo "Using project path \"$UNITY_PROJECT_PATH\"." - -# -# Set and display the artifacts path -# - -echo "Using artifacts path \"$ARTIFACTS_PATH\" to save test results." -FULL_ARTIFACTS_PATH=$GITHUB_WORKSPACE/$ARTIFACTS_PATH - -# -# Set and display the coverage results path -# - -echo "Using coverage results path \"$COVERAGE_RESULTS_PATH\" to save test coverage results." -FULL_COVERAGE_RESULTS_PATH=$GITHUB_WORKSPACE/$COVERAGE_RESULTS_PATH - -# -# Display custom parameters -# - -echo "Using custom parameters $CUSTOM_PARAMETERS." - -# The following tests are 2019 mode (requires Unity 2019.2.11f1 or later) -# Reference: https://docs.unity3d.com/2019.3/Documentation/Manual/CommandLineArguments.html - -# -# Display the unity version -# - -echo "Using Unity version \"$UNITY_VERSION\" to test." - -# -# Create an empty project for testing if in package mode -# - -if [ "$PACKAGE_MODE" = "true" ]; then - echo "Running tests on a Unity package rather than a Unity project." - - echo "" - echo "###########################" - echo "# Package Folder #" - echo "###########################" - echo "" - - ls -la "$UNITY_PROJECT_PATH" - echo "" - - echo "Creating an empty Unity project to add the package $PACKAGE_NAME to." - - TEMP_PROJECT_PATH="./TempProject" - - unity-editor \ - -batchmode \ - -createProject "$TEMP_PROJECT_PATH" \ - -quit - - # use jq to add the package to the temp project through manually modifying Packages/manifest.json - echo "Adding package to the temporary project's dependencies and testables..." - echo "" - - PACKAGE_MANIFEST_PATH="$TEMP_PROJECT_PATH/Packages/manifest.json" - if [ ! -f "$PACKAGE_MANIFEST_PATH" ]; then - echo "Packages/mainfest.json was not created properly. This indicates a problem with the Action, not with your package. Logging directories and aborting..." - - echo "" - echo "###########################" - echo "# Temp Project Folder #" - echo "###########################" - echo "" - - ls -a "$TEMP_PROJECT_PATH" - - echo "" - echo "################################" - echo "# Temp Project Packages Folder #" - echo "################################" - echo "" - - ls -a "$TEMP_PROJECT_PATH/Packages" - - exit 1 - fi - - PACKAGE_MANIFEST_JSON=$(cat "$PACKAGE_MANIFEST_PATH") - echo "$PACKAGE_MANIFEST_JSON" | \ - jq \ - --arg packageName "$PACKAGE_NAME" \ - --arg projectPath "$UNITY_PROJECT_PATH" \ - '.dependencies += {"com.unity.testtools.codecoverage": "1.1.1"} | .dependencies += {"\($packageName)": "file:\($projectPath)"} | . += {testables: ["\($packageName)"]}' \ - > "$PACKAGE_MANIFEST_PATH" - - UNITY_PROJECT_PATH="$TEMP_PROJECT_PATH" -fi - - -# -# Overall info -# - -echo "" -echo "###########################" -echo "# Artifacts folder #" -echo "###########################" -echo "" -echo "Creating \"$FULL_ARTIFACTS_PATH\" if it does not exist." -mkdir -p $FULL_ARTIFACTS_PATH - -echo "" -echo "###########################" -echo "# Project directory #" -echo "###########################" -echo "" -ls -alh $UNITY_PROJECT_PATH - -# -# Testing for each platform -# -for platform in ${TEST_PLATFORMS//;/ }; do - if [[ "$platform" == "standalone" ]]; then - echo "" - echo "###########################" - echo "# Building Standalone #" - echo "###########################" - echo "" - - # Create directories if they do not exist - mkdir -p "$UNITY_PROJECT_PATH/Assets/Editor/" - mkdir -p "$UNITY_PROJECT_PATH/Assets/Player/" - # Copy the scripts - cp -R "$ACTION_FOLDER/UnityStandaloneScripts/Assets/Editor/" "$UNITY_PROJECT_PATH/Assets/Editor/" - cp -R "$ACTION_FOLDER/UnityStandaloneScripts/Assets/Player/" "$UNITY_PROJECT_PATH/Assets/Player/" - # Verify recursive paths - ls -Ralph "$UNITY_PROJECT_PATH/Assets/Editor/" - ls -Ralph "$UNITY_PROJECT_PATH/Assets/Player/" - - runTests="-runTests -testPlatform StandaloneLinux64 -builtTestRunnerPath $UNITY_PROJECT_PATH/Build/UnityTestRunner-Standalone" - else - echo "" - echo "###########################" - echo "# Testing in $platform #" - echo "###########################" - echo "" - - if [[ "$platform" != "COMBINE_RESULTS" ]]; then - runTests="-runTests -testPlatform $platform -testResults $FULL_ARTIFACTS_PATH/$platform-results.xml" - else - runTests="-quit" - fi - fi - - unity-editor \ - -batchmode \ - -logFile "$FULL_ARTIFACTS_PATH/$platform.log" \ - -projectPath "$UNITY_PROJECT_PATH" \ - -coverageResultsPath "$FULL_COVERAGE_RESULTS_PATH" \ - $runTests \ - -enableCodeCoverage \ - -debugCodeOptimization \ - -coverageOptions "$COVERAGE_OPTIONS" \ - $CUSTOM_PARAMETERS - - # Catch exit code - TEST_EXIT_CODE=$? - - # Print unity log output - cat "$FULL_ARTIFACTS_PATH/$platform.log" - - if [[ $TEST_EXIT_CODE -eq 0 && "$platform" == "standalone" ]]; then - echo "" - echo "###########################" - echo "# Testing Standalone #" - echo "###########################" - echo "" - - # Code Coverage currently only supports code ran in the Editor and not in Standalone/Player. - # https://docs.unity.cn/Packages/com.unity.testtools.codecoverage@1.1/manual/TechnicalDetails.html#how-it-works - - xvfb-run -a -e /dev/stdout "$UNITY_PROJECT_PATH/Build/UnityTestRunner-Standalone" \ - -batchmode \ - -nographics \ - -logFile "$FULL_ARTIFACTS_PATH/$platform-player.log" \ - -testResults "$FULL_ARTIFACTS_PATH/$platform-results.xml" - - # Catch exit code - TEST_EXIT_CODE=$? - - # Print player log output - cat "$FULL_ARTIFACTS_PATH/$platform-player.log" - fi - - # Display results - if [ $TEST_EXIT_CODE -eq 0 ]; then - echo "Run succeeded, no failures occurred"; - elif [ $TEST_EXIT_CODE -eq 2 ]; then - echo "Run succeeded, some tests failed"; - elif [ $TEST_EXIT_CODE -eq 3 ]; then - echo "Run failure (other failure)"; - else - echo "Unexpected exit code $TEST_EXIT_CODE"; - fi - - if [ $TEST_EXIT_CODE -ne 0 ]; then - TEST_RUNNER_EXIT_CODE=$TEST_EXIT_CODE - fi - - echo "" - echo "###########################" - echo "# $platform Results #" - echo "###########################" - echo "" - - if [[ "$platform" != "COMBINE_RESULTS" ]]; then - cat "$FULL_ARTIFACTS_PATH/$platform-results.xml" - cat "$FULL_ARTIFACTS_PATH/$platform-results.xml" | grep test-run | grep Passed - fi -done - -# -# Permissions -# - -# Make a given user owner of all artifacts -if [[ -n "$CHOWN_FILES_TO" ]]; then - chown -R "$CHOWN_FILES_TO" "$UNITY_PROJECT_PATH" - chown -R "$CHOWN_FILES_TO" "$FULL_ARTIFACTS_PATH" - chown -R "$CHOWN_FILES_TO" "$FULL_COVERAGE_RESULTS_PATH" -fi - -# Add read permissions for everyone to all artifacts -chmod -R a+r "$UNITY_PROJECT_PATH" -chmod -R a+r "$FULL_ARTIFACTS_PATH" -chmod -R a+r "$FULL_COVERAGE_RESULTS_PATH" +#!/usr/bin/env bash + +# +# Set and display project path +# + +UNITY_PROJECT_PATH="$GITHUB_WORKSPACE/$PROJECT_PATH" +echo "Using project path \"$UNITY_PROJECT_PATH\"." + +# +# Set and display the artifacts path +# + +echo "Using artifacts path \"$ARTIFACTS_PATH\" to save test results." +FULL_ARTIFACTS_PATH=$GITHUB_WORKSPACE/$ARTIFACTS_PATH + +# +# Set and display the coverage results path +# + +echo "Using coverage results path \"$COVERAGE_RESULTS_PATH\" to save test coverage results." +FULL_COVERAGE_RESULTS_PATH=$GITHUB_WORKSPACE/$COVERAGE_RESULTS_PATH + +# +# Display custom parameters +# + +echo "Using custom parameters $CUSTOM_PARAMETERS." + +# The following tests are 2019 mode (requires Unity 2019.2.11f1 or later) +# Reference: https://docs.unity3d.com/2019.3/Documentation/Manual/CommandLineArguments.html + +# +# Display the unity version +# + +echo "Using Unity version \"$UNITY_VERSION\" to test." + +# +# Create an empty project for testing if in package mode +# + +if [ "$PACKAGE_MODE" = "true" ]; then + echo "Running tests on a Unity package rather than a Unity project." + + if ! command -v jq &> /dev/null + then + echo "jq could not be found. This is required for package mode, and is likely the result of using a custom Docker image. Please use the default image or install jq to your custom image." + exit + fi + + + echo "" + echo "###########################" + echo "# Package Folder #" + echo "###########################" + echo "" + + ls -la "$UNITY_PROJECT_PATH" + echo "" + + echo "Creating an empty Unity project to add the package $PACKAGE_NAME to." + + TEMP_PROJECT_PATH="./TempProject" + + unity-editor \ + -batchmode \ + -createProject "$TEMP_PROJECT_PATH" \ + -quit + + # use jq to add the package to the temp project through manually modifying Packages/manifest.json + echo "Adding package to the temporary project's dependencies and testables..." + echo "" + + PACKAGE_MANIFEST_PATH="$TEMP_PROJECT_PATH/Packages/manifest.json" + if [ ! -f "$PACKAGE_MANIFEST_PATH" ]; then + echo "Packages/mainfest.json was not created properly. This indicates a problem with the Action, not with your package. Logging directories and aborting..." + + echo "" + echo "###########################" + echo "# Temp Project Folder #" + echo "###########################" + echo "" + + ls -a "$TEMP_PROJECT_PATH" + + echo "" + echo "################################" + echo "# Temp Project Packages Folder #" + echo "################################" + echo "" + + ls -a "$TEMP_PROJECT_PATH/Packages" + + exit 1 + fi + + PACKAGE_MANIFEST_JSON=$(cat "$PACKAGE_MANIFEST_PATH") + echo "$PACKAGE_MANIFEST_JSON" | \ + jq \ + --arg packageName "$PACKAGE_NAME" \ + --arg projectPath "$UNITY_PROJECT_PATH" \ + '.dependencies += {"com.unity.testtools.codecoverage": "1.1.1"} | .dependencies += {"\($packageName)": "file:\($projectPath)"} | . += {testables: ["\($packageName)"]}' \ + > "$PACKAGE_MANIFEST_PATH" + + UNITY_PROJECT_PATH="$TEMP_PROJECT_PATH" +fi + + +# +# Overall info +# + +echo "" +echo "###########################" +echo "# Artifacts folder #" +echo "###########################" +echo "" +echo "Creating \"$FULL_ARTIFACTS_PATH\" if it does not exist." +mkdir -p $FULL_ARTIFACTS_PATH + +echo "" +echo "###########################" +echo "# Project directory #" +echo "###########################" +echo "" +ls -alh $UNITY_PROJECT_PATH + +# +# Testing for each platform +# +for platform in ${TEST_PLATFORMS//;/ }; do + if [[ "$platform" == "standalone" ]]; then + echo "" + echo "###########################" + echo "# Building Standalone #" + echo "###########################" + echo "" + + # Create directories if they do not exist + mkdir -p "$UNITY_PROJECT_PATH/Assets/Editor/" + mkdir -p "$UNITY_PROJECT_PATH/Assets/Player/" + # Copy the scripts + cp -R "$ACTION_FOLDER/UnityStandaloneScripts/Assets/Editor/" "$UNITY_PROJECT_PATH/Assets/Editor/" + cp -R "$ACTION_FOLDER/UnityStandaloneScripts/Assets/Player/" "$UNITY_PROJECT_PATH/Assets/Player/" + # Verify recursive paths + ls -Ralph "$UNITY_PROJECT_PATH/Assets/Editor/" + ls -Ralph "$UNITY_PROJECT_PATH/Assets/Player/" + + runTests="-runTests -testPlatform StandaloneLinux64 -builtTestRunnerPath $UNITY_PROJECT_PATH/Build/UnityTestRunner-Standalone" + else + echo "" + echo "###########################" + echo "# Testing in $platform #" + echo "###########################" + echo "" + + if [[ "$platform" != "COMBINE_RESULTS" ]]; then + runTests="-runTests -testPlatform $platform -testResults $FULL_ARTIFACTS_PATH/$platform-results.xml" + else + runTests="-quit" + fi + fi + + unity-editor \ + -batchmode \ + -logFile "$FULL_ARTIFACTS_PATH/$platform.log" \ + -projectPath "$UNITY_PROJECT_PATH" \ + -coverageResultsPath "$FULL_COVERAGE_RESULTS_PATH" \ + $runTests \ + -enableCodeCoverage \ + -debugCodeOptimization \ + -coverageOptions "$COVERAGE_OPTIONS" \ + $CUSTOM_PARAMETERS + + # Catch exit code + TEST_EXIT_CODE=$? + + # Print unity log output + cat "$FULL_ARTIFACTS_PATH/$platform.log" + + if [[ $TEST_EXIT_CODE -eq 0 && "$platform" == "standalone" ]]; then + echo "" + echo "###########################" + echo "# Testing Standalone #" + echo "###########################" + echo "" + + # Code Coverage currently only supports code ran in the Editor and not in Standalone/Player. + # https://docs.unity.cn/Packages/com.unity.testtools.codecoverage@1.1/manual/TechnicalDetails.html#how-it-works + + xvfb-run -a -e /dev/stdout "$UNITY_PROJECT_PATH/Build/UnityTestRunner-Standalone" \ + -batchmode \ + -nographics \ + -logFile "$FULL_ARTIFACTS_PATH/$platform-player.log" \ + -testResults "$FULL_ARTIFACTS_PATH/$platform-results.xml" + + # Catch exit code + TEST_EXIT_CODE=$? + + # Print player log output + cat "$FULL_ARTIFACTS_PATH/$platform-player.log" + fi + + # Display results + if [ $TEST_EXIT_CODE -eq 0 ]; then + echo "Run succeeded, no failures occurred"; + elif [ $TEST_EXIT_CODE -eq 2 ]; then + echo "Run succeeded, some tests failed"; + elif [ $TEST_EXIT_CODE -eq 3 ]; then + echo "Run failure (other failure)"; + else + echo "Unexpected exit code $TEST_EXIT_CODE"; + fi + + if [ $TEST_EXIT_CODE -ne 0 ]; then + TEST_RUNNER_EXIT_CODE=$TEST_EXIT_CODE + fi + + echo "" + echo "###########################" + echo "# $platform Results #" + echo "###########################" + echo "" + + if [[ "$platform" != "COMBINE_RESULTS" ]]; then + cat "$FULL_ARTIFACTS_PATH/$platform-results.xml" + cat "$FULL_ARTIFACTS_PATH/$platform-results.xml" | grep test-run | grep Passed + fi +done + +# +# Permissions +# + +# Make a given user owner of all artifacts +if [[ -n "$CHOWN_FILES_TO" ]]; then + chown -R "$CHOWN_FILES_TO" "$UNITY_PROJECT_PATH" + chown -R "$CHOWN_FILES_TO" "$FULL_ARTIFACTS_PATH" + chown -R "$CHOWN_FILES_TO" "$FULL_COVERAGE_RESULTS_PATH" +fi + +# Add read permissions for everyone to all artifacts +chmod -R a+r "$UNITY_PROJECT_PATH" +chmod -R a+r "$FULL_ARTIFACTS_PATH" +chmod -R a+r "$FULL_COVERAGE_RESULTS_PATH"