Skip to content

Update main.yml

Update main.yml #155

Workflow file for this run

name: CI
on: push
env:
flutter: '3.x'
xcode: '14.2'
ios-simulator: iPhone 14
java: 11
jobs:
authorize:
name: Authorize
environment: ${{ github.event.pull_request.head.repo.fork && 'external' || 'internal' }}
runs-on: ubuntu-latest
steps:
- run: true
# analyze-auth0_flutter:
# name: Analyze auth0_flutter Flutter package
# needs: authorize
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Install Flutter
# uses: subosito/flutter-action@48cafc24713cca54bbe03cdc3a423187d413aafa
# with:
# flutter-version: ${{ env.flutter }}
# channel: stable
# cache: true
# - name: Add example/.env
# working-directory: auth0_flutter
# run: cp example/.env.example example/.env
# - name: Analize auth0_flutter package
# working-directory: auth0_flutter
# run: flutter analyze
# analyze-auth0_flutter_platform_interface:
# name: Analyze auth0_flutter_platform_interface Flutter package
# needs: authorize
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Install Flutter
# uses: subosito/flutter-action@48cafc24713cca54bbe03cdc3a423187d413aafa
# with:
# flutter-version: ${{ env.flutter }}
# channel: stable
# cache: true
# - name: Analize auth0_flutter_platform_interface package
# working-directory: auth0_flutter_platform_interface
# run: flutter analyze
# test-auth0_flutter:
# name: Test auth0_flutter Flutter package
# needs: authorize
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Install Flutter
# uses: subosito/flutter-action@48cafc24713cca54bbe03cdc3a423187d413aafa
# with:
# flutter-version: ${{ env.flutter }}
# channel: stable
# cache: true
# - name: Add example/.env
# working-directory: auth0_flutter
# run: cp example/.env.example example/.env
# - name: Test auth0_flutter package
# working-directory: auth0_flutter
# run: |
# flutter test --tags browser --platform chrome
# flutter test --coverage --exclude-tags browser
# - name: Upload coverage report for auth0_flutter
# uses: codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d
# with:
# name: Auth0 Flutter
# flags: auth0_flutter
# files: ./auth0_flutter/coverage/lcov.info
# test-auth0_flutter_platform_interface:
# name: Test auth0_flutter_platform_interface Flutter package
# needs: authorize
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Install Flutter
# uses: subosito/flutter-action@48cafc24713cca54bbe03cdc3a423187d413aafa
# with:
# flutter-version: ${{ env.flutter }}
# channel: stable
# cache: true
# - name: Test auth0_flutter_platform_interface package
# working-directory: auth0_flutter_platform_interface
# run: flutter test --coverage
# - name: Upload coverage report for auth0_flutter_platform_interface
# uses: codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d
# with:
# name: Auth0 Flutter
# flags: auth0_flutter_platform_interface
# files: ./auth0_flutter_platform_interface/coverage/lcov.info
# test-ios-unit:
# name: Run native iOS unit tests using Xcode ${{ matrix.xcode }}
# needs: authorize
# runs-on: macos-latest
# environment: ${{ github.event.pull_request.head.repo.fork && 'external' || 'internal' }}
# env:
# USER_EMAIL: ${{ secrets.USER_EMAIL }}
# USER_PASSWORD: ${{ secrets.USER_PASSWORD }}
# strategy:
# matrix:
# xcode:
# - '14.2'
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Set up environment
# uses: ./.github/actions/setup-ios
# with:
# flutter: ${{ env.flutter }}
# xcode: ${{ matrix.xcode }}
# auth0-domain: ${{ vars.AUTH0_DOMAIN }}
# auth0-client-id: ${{ vars.AUTH0_CLIENT_ID }}
# - name: Run iOS unit tests
# working-directory: auth0_flutter/example/ios
# run: xcodebuild test -scheme Runner -workspace Runner.xcworkspace -destination '${{ format('{0}{1}', 'platform=iOS Simulator,name=', env.ios-simulator) }}' -resultBundlePath unit-tests.xcresult -skip-testing:RunnerUITests
# - name: Convert coverage report
# working-directory: auth0_flutter/example/ios
# run: bundle exec slather coverage -x --scheme Runner Runner.xcodeproj
# - name: Upload coverage report
# uses: codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d
# with:
# directory: auth0_flutter/example/ios/cobertura
# - name: Upload xcresult bundles
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# if: ${{ failure() }}
# with:
# name: xcresult bundles
# path: 'auth0_flutter/example/ios/*.xcresult'
# test-ios-smoke:
# name: Run native iOS smoke tests using Xcode ${{ matrix.xcode }}
# needs: authorize
# runs-on: macos-latest
# environment: ${{ github.event.pull_request.head.repo.fork && 'external' || 'internal' }}
# env:
# USER_EMAIL: ${{ secrets.USER_EMAIL }}
# USER_PASSWORD: ${{ secrets.USER_PASSWORD }}
# strategy:
# matrix:
# xcode:
# - '14.2'
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Set up environment
# uses: ./.github/actions/setup-ios
# with:
# flutter: ${{ env.flutter }}
# xcode: ${{ matrix.xcode }}
# auth0-domain: ${{ vars.AUTH0_DOMAIN }}
# auth0-client-id: ${{ vars.AUTH0_CLIENT_ID }}
# - name: Run iOS smoke tests
# if: ${{ github.event.pull_request.head.repo.fork == false }}
# working-directory: auth0_flutter/example/ios
# run: |
# defaults write com.apple.iphonesimulator ConnectHardwareKeyboard 0
# xcodebuild test -scheme Runner -workspace Runner.xcworkspace -destination '${{ format('{0}{1}', 'platform=iOS Simulator,name=', env.ios-simulator) }}' -resultBundlePath smoke-tests.xcresult -only-testing:RunnerUITests
# - name: Upload xcresult bundles
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# if: ${{ failure() }}
# with:
# name: 'iOS - xcresult bundles'
# path: 'auth0_flutter/example/ios/*.xcresult'
# test-android-unit:
# name: Run native Android unit tests
# needs: authorize
# runs-on: ubuntu-latest
# environment: ${{ github.event.pull_request.head.repo.fork && 'external' || 'internal' }}
# steps:
# - name: Checkout
# uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
# - name: Set up environment
# uses: ./.github/actions/setup-android
# with:
# flutter: ${{ env.flutter }}
# java: ${{ env.java }}
# auth0-domain: ${{ vars.AUTH0_DOMAIN }}
# auth0-client-id: ${{ vars.AUTH0_CLIENT_ID }}
# - name: Build Android example app
# working-directory: auth0_flutter/example
# run: flutter build apk --split-per-abi
# - name: Run Android unit tests
# working-directory: auth0_flutter/example/android
# run: ./gradlew testDebugUnitTest createDebugCoverageReport
# - name: Upload coverage report
# uses: codecov/codecov-action@eaaf4bedf32dbdc6b720b63067d99c4d77d6047d
# with:
# directory: auth0_flutter/example/build/app/reports/coverage/androidTest/debug/connected
# - name: Upload test results
# uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
# if: ${{ failure() }}
# with:
# name: Test results
# path: 'auth0_flutter/example/build/app/reports/androidTests/*.xml'
test-android-smoke:
name: Run native Android smoke tests using API-level ${{ matrix.android-api }}
needs: authorize
runs-on: macos-latest-xl
environment: ${{ github.event.pull_request.head.repo.fork && 'external' || 'internal' }}
env:
USER_EMAIL: ${{ secrets.USER_EMAIL }}
USER_PASSWORD: ${{ secrets.USER_PASSWORD }}
ANDROID_EMULATOR_WAIT_TIME_BEFORE_KILL: 50
strategy:
matrix:
android-api:
- 32
steps:
- name: Checkout
uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9
- name: Gradle cache
uses: gradle/gradle-build-action@v2
- name: AVD cache
uses: actions/cache@v3
id: avd-cache
with:
path: |
~/.android/avd/*
~/.android/adb*
key: avd-${{ matrix.android-api }}
- name: Set up environment
uses: ./.github/actions/setup-android
with:
flutter: ${{ env.flutter }}
java: ${{ env.java }}
auth0-domain: ${{ vars.AUTH0_DOMAIN }}
auth0-client-id: ${{ vars.AUTH0_CLIENT_ID }}
- name: Build Android example app
working-directory: auth0_flutter/example
run: flutter build apk --split-per-abi
- name: Set up Appium tests
working-directory: appium-test
run: npm install
- name: Set up Appium driver
run: npx --yes appium@next driver install uiautomator2
- name: Start Appium server
run: npx --yes appium@next & # Appium recommends this until v2 is released
- name: Create AVD and generate snapshot for caching
if: steps.avd-cache.outputs.cache-hit != 'true'
uses: reactivecircus/android-emulator-runner@v2
with:
api-level: ${{ matrix.android-api }}
force-avd-creation: false
emulator-options: -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
disable-animations: false
script: echo "Generated AVD snapshot for caching."
- name: Run Appium tests
uses: reactivecircus/android-emulator-runner@v2
with:
api-level: ${{ matrix.android-api }}
target: playstore
arch: x86_64
profile: 5.4in FWVGA
ram-size: 10240M
heap-size: 4096M
force-avd-creation: false
emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
disable-animations: true
script: |
adb shell pm clear com.android.chrome
adb shell am set-debug-app --persistent com.android.chrome
adb shell 'echo "chrome --disable-fre --no-default-browser-check --no-first-run" > /data/local/tmp/chrome-command-line'
adb emu screenrecord start --time-limit 300 ./recording_video.webm
adb shell settings put system show_touches 1
USER_EMAIL=$USER_EMAIL USER_PASSWORD=$USER_PASSWORD node appium-test/test.js
- name: Upload recording
uses: actions/upload-artifact@0b7f8abb1508181956e8e162db84b466c27e18ce
if: ${{ failure() }}
with:
name: 'Android - smoke tests recording'
path: recording_video.webm