diff options
author | Harsh Shandilya <me@msfjarvis.dev> | 2021-10-03 18:09:24 +0530 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-10-03 12:39:24 +0000 |
commit | 99586970a1d80e45eee3f99324d1d8f250747f45 (patch) | |
tree | ff81e28b65f51bda49b75590300ed35d0fb5ea2d /.github/workflows | |
parent | 2cef6a5bb4cb4afb1b1f1b704f83c1565e441825 (diff) |
Cleanup and improve CI checks (#1511)
Diffstat (limited to '.github/workflows')
-rw-r--r-- | .github/workflows/pull_request.yml | 70 |
1 files changed, 22 insertions, 48 deletions
diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index 045a9124..ead79571 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -10,45 +10,35 @@ jobs: unit-tests: runs-on: ubuntu-latest steps: + - name: Checkout repository + uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f + with: + fetch-depth: 0 + - name: Check if relevant files have changed uses: actions/github-script@a3e7071a34d7e1f219a8a4de9a5e0a34d1ee1293 id: service-changed with: result-encoding: string script: | - const result = await github.pulls.listFiles({ - owner: context.payload.repository.owner.login, - repo: context.payload.repository.name, - pull_number: context.payload.number, - per_page: 100 - }) - const files = result.data.filter(file => - // We wanna run this if the PR workflow is modified - (file.filename.endsWith(".yml") && !file.filename.endsWith("pull_request.yml")) || - // Changes in Markdown files don't need tests - file.filename.endsWith(".md") || - // Changes to fastlane metadata aren't covered by tests - file.filename.startsWith("fastlane/") - ) - // If filtered file count and source file count is equal, it means all files - // in this PR are skip-worthy. - return files.length != result.data.length + const script = require('.github/check-changed-files.js') + return await script({github, context}) - uses: actions/setup-java@d202f5dbf7256730fb690ec59f6381650114feb2 if: ${{ steps.service-changed.outputs.result == 'true' }} with: java-version: '11' - - name: Checkout repository - if: ${{ steps.service-changed.outputs.result == 'true' }} - uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f - with: - fetch-depth: 0 - - name: Copy CI gradle.properties if: ${{ steps.service-changed.outputs.result == 'true' }} run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties + - name: Build debug APKs + if: ${{ steps.service-changed.outputs.result == 'true' }} + uses: burrunan/gradle-cache-action@03c71a8ba93d670980695505f48f49daf43704a6 + with: + arguments: assembleFreeDebug assembleNonFreeDebug + - name: Run unit tests if: ${{ steps.service-changed.outputs.result == 'true' }} uses: burrunan/gradle-cache-action@03c71a8ba93d670980695505f48f49daf43704a6 @@ -62,32 +52,22 @@ jobs: name: Test report path: app/build/reports - run-screenshot-tests: - runs-on: macOS-latest + instrumentation-tests: + runs-on: macos-11 steps: + - name: Checkout repository + uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f + with: + fetch-depth: 0 + - name: Check if relevant files have changed uses: actions/github-script@a3e7071a34d7e1f219a8a4de9a5e0a34d1ee1293 id: service-changed with: result-encoding: string script: | - const result = await github.pulls.listFiles({ - owner: context.payload.repository.owner.login, - repo: context.payload.repository.name, - pull_number: context.payload.number, - per_page: 100 - }) - const files = result.data.filter(file => - // We wanna run this if the PR workflow is modified - (file.filename.endsWith(".yml") && !file.filename.endsWith("pull_request.yml")) || - // Changes in Markdown files don't need tests - file.filename.endsWith(".md") || - // Changes to fastlane metadata aren't covered by tests - file.filename.startsWith("fastlane/") - ) - // If filtered file count and source file count is equal, it means all files - // in this PR are skip-worthy. - return files.length != result.data.length + const script = require('.github/check-changed-files.js') + return await script({github, context}) - uses: actions/cache@c64c572235d810460d0d6876e9c705ad5002b353 if: ${{ steps.service-changed.outputs.result == 'true' }} @@ -103,12 +83,6 @@ jobs: with: java-version: '11' - - name: Checkout repository - if: ${{ steps.service-changed.outputs.result == 'true' }} - uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f - with: - fetch-depth: 0 - - name: Copy CI gradle.properties if: ${{ steps.service-changed.outputs.result == 'true' }} run: mkdir -p ~/.gradle ; cp .github/ci-gradle.properties ~/.gradle/gradle.properties |