From 10341ddedc48a668766ac02ba4535f8294b9ca7b Mon Sep 17 00:00:00 2001 From: charafau Date: Tue, 20 Aug 2024 02:08:40 +0900 Subject: [PATCH 1/3] update java runner to v2 remove tuneup and replace it with dart analyze --- .github/workflows/examples.yml | 5 +++-- .github/workflows/format.yml | 3 +-- .github/workflows/test.yml | 14 ++++++++------ 3 files changed, 12 insertions(+), 10 deletions(-) diff --git a/.github/workflows/examples.yml b/.github/workflows/examples.yml index 66b4ef0..614d068 100644 --- a/.github/workflows/examples.yml +++ b/.github/workflows/examples.yml @@ -11,9 +11,10 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - uses: actions/setup-java@v1 + - uses: actions/setup-java@v4 with: - java-version: 17 + distribution: 'temurin' + java-version: 21 - uses: subosito/flutter-action@v2 with: channel: "stable" diff --git a/.github/workflows/format.yml b/.github/workflows/format.yml index 04ca605..f52d6e3 100644 --- a/.github/workflows/format.yml +++ b/.github/workflows/format.yml @@ -52,5 +52,4 @@ jobs: cd workmanager flutter pub get flutter pub publish -n - flutter pub global activate tuneup - flutter pub global run tuneup check \ No newline at end of file + flutter pub dart analyze \ No newline at end of file diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 9063cdd..87c2dee 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -36,10 +36,11 @@ jobs: runs-on: macos-latest steps: - uses: actions/checkout@v4 - - uses: actions/setup-java@v1 + - uses: actions/setup-java@v4 with: - java-version: 17 - - uses: subosito/flutter-action@v1 + distribution: 'temurin' + java-version: 21 + - uses: subosito/flutter-action@v2 with: channel: 'stable' - name: Build Android App @@ -55,7 +56,7 @@ jobs: fail-fast: false runs-on: macos-latest steps: - - uses: futureware-tech/simulator-action@v1 + - uses: futureware-tech/simulator-action@v2 with: model: '${{ matrix.device }}' - uses: actions/checkout@v4 @@ -78,9 +79,10 @@ jobs: target: [default] steps: - uses: actions/checkout@v4 - - uses: actions/setup-java@v1 + - uses: actions/setup-java@v4 with: - java-version: 17 + distribution: 'temurin' + java-version: 21 - uses: subosito/flutter-action@v2 with: channel: 'stable' From 8b978e35aaf6fae61a14ca5ee1ef08a883168b40 Mon Sep 17 00:00:00 2001 From: charafau Date: Wed, 21 Aug 2024 01:48:59 +0900 Subject: [PATCH 2/3] ci fixes --- .github/workflows/test.yml | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 87c2dee..0cd4690 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -16,6 +16,8 @@ jobs: channel: 'stable' - name: Test run: | + dart pub global activate melos + melos bootstrap cd workmanager flutter pub get flutter test @@ -43,6 +45,8 @@ jobs: - uses: subosito/flutter-action@v2 with: channel: 'stable' + - name: Activate melos + run: dart pub global activate melos && melos bootstrap - name: Build Android App run: cd example && flutter build apk --debug - name: Run native Android tests @@ -52,11 +56,11 @@ jobs: strategy: matrix: device: - - "iPhone 12 Pro" + - "iPhone 15" fail-fast: false runs-on: macos-latest steps: - - uses: futureware-tech/simulator-action@v2 + - uses: futureware-tech/simulator-action@v3 with: model: '${{ matrix.device }}' - uses: actions/checkout@v4 @@ -64,19 +68,22 @@ jobs: with: channel: 'stable' # Run flutter integrate tests + - name: Activate melos + run: dart pub global activate melos && melos bootstrap - name: Run Flutter integration tests run: cd example && flutter test integration_test/workmanager_integration_test.dart drive_android: - runs-on: macos-latest + runs-on: ubuntu-latest #creates a build matrix for your jobs + timeout-minutes: 30 strategy: #set of different configurations of the virtual environment. matrix: - api-level: [29] + api-level: [31] # api-level: [21, 29] - target: [default] + target: [google_apis] steps: - uses: actions/checkout@v4 - uses: actions/setup-java@v4 @@ -86,9 +93,18 @@ jobs: - uses: subosito/flutter-action@v2 with: channel: 'stable' + - name: Activate melos + run: dart pub global activate melos && melos bootstrap + - name: Enable KVM + run: | + echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules + sudo udevadm control --reload-rules + sudo udevadm trigger --name-match=kvm - name: Run Flutter Driver tests uses: reactivecircus/android-emulator-runner@v2 with: + arch: x86_64 + profile: Nexus 6 api-level: ${{ matrix.api-level }} target: ${{ matrix.target }} script: cd example && flutter test integration_test/workmanager_integration_test.dart From 0810dedfb3aaa564d6cf7a2e86828b569089b74d Mon Sep 17 00:00:00 2001 From: charafau Date: Wed, 21 Aug 2024 03:06:54 +0900 Subject: [PATCH 3/3] refactor test workflow to use script --- .github/workflows/scripts/install-flutter.sh | 6 +++ .github/workflows/scripts/install-tools.sh | 10 ++++ .github/workflows/test.yml | 57 ++++++++++++-------- 3 files changed, 50 insertions(+), 23 deletions(-) create mode 100755 .github/workflows/scripts/install-flutter.sh create mode 100755 .github/workflows/scripts/install-tools.sh diff --git a/.github/workflows/scripts/install-flutter.sh b/.github/workflows/scripts/install-flutter.sh new file mode 100755 index 0000000..753aea7 --- /dev/null +++ b/.github/workflows/scripts/install-flutter.sh @@ -0,0 +1,6 @@ +#!/bin/bash + +BRANCH=$1 + +git clone https://github.com/flutter/flutter.git --depth 1 -b $BRANCH _flutter +echo "$GITHUB_WORKSPACE/_flutter/bin" >>$GITHUB_PATH diff --git a/.github/workflows/scripts/install-tools.sh b/.github/workflows/scripts/install-tools.sh new file mode 100755 index 0000000..c5e4ddf --- /dev/null +++ b/.github/workflows/scripts/install-tools.sh @@ -0,0 +1,10 @@ +#!/bin/bash + +set -e + +flutter config --no-analytics +flutter pub global activate melos 3.0.0 +echo "$HOME/.pub-cache/bin" >>$GITHUB_PATH +echo "$HOME/AppData/Local/Pub/Cache/bin" >>$GITHUB_PATH +echo "$GITHUB_WORKSPACE/_flutter/.pub-cache/bin" >>$GITHUB_PATH +echo "$GITHUB_WORKSPACE/_flutter/bin/cache/dart-sdk/bin" >>$GITHUB_PATH diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 0cd4690..9cc1a56 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -11,12 +11,13 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - - uses: subosito/flutter-action@v2 - with: - channel: 'stable' + - name: "Install Flutter" + run: ./.github/workflows/scripts/install-flutter.sh stable + - name: "Install Tools" + run: | + ./.github/workflows/scripts/install-tools.sh - name: Test run: | - dart pub global activate melos melos bootstrap cd workmanager flutter pub get @@ -26,27 +27,37 @@ jobs: runs-on: macos-latest steps: - uses: actions/checkout@v4 - - uses: subosito/flutter-action@v2 - with: - channel: 'stable' + - name: "Install Flutter" + run: ./.github/workflows/scripts/install-flutter.sh stable + - name: "Install Tools" + run: | + ./.github/workflows/scripts/install-tools.sh - name: Build iOS App run: cd example && flutter build ios --debug --no-codesign - name: Run native iOS tests run: cd example/ios && xcodebuild -workspace Runner.xcworkspace -scheme Runner -sdk iphonesimulator -destination 'platform=iOS Simulator,name=iPhone 12,OS=16.2' test native_android_tests: - runs-on: macos-latest + runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-java@v4 with: distribution: 'temurin' java-version: 21 - - uses: subosito/flutter-action@v2 + - name: "Install Flutter" + run: ./.github/workflows/scripts/install-flutter.sh stable + - name: "Install Tools" + run: | + ./.github/workflows/scripts/install-tools.sh + - name: Run Flutter Driver tests + uses: reactivecircus/android-emulator-runner@v2 with: - channel: 'stable' - - name: Activate melos - run: dart pub global activate melos && melos bootstrap + arch: x86_64 + profile: Nexus 6 + api-level: 34 + target: google_apis + script: cd example && flutter test integration_test/workmanager_integration_test.dart - name: Build Android App run: cd example && flutter build apk --debug - name: Run native Android tests @@ -64,12 +75,12 @@ jobs: with: model: '${{ matrix.device }}' - uses: actions/checkout@v4 - - uses: subosito/flutter-action@v2 - with: - channel: 'stable' + - name: "Install Flutter" + run: ./.github/workflows/scripts/install-flutter.sh stable + - name: "Install Tools" + run: | + ./.github/workflows/scripts/install-tools.sh # Run flutter integrate tests - - name: Activate melos - run: dart pub global activate melos && melos bootstrap - name: Run Flutter integration tests run: cd example && flutter test integration_test/workmanager_integration_test.dart @@ -90,11 +101,11 @@ jobs: with: distribution: 'temurin' java-version: 21 - - uses: subosito/flutter-action@v2 - with: - channel: 'stable' - - name: Activate melos - run: dart pub global activate melos && melos bootstrap + - name: "Install Flutter" + run: ./.github/workflows/scripts/install-flutter.sh stable + - name: "Install Tools" + run: | + ./.github/workflows/scripts/install-tools.sh - name: Enable KVM run: | echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules @@ -103,7 +114,7 @@ jobs: - name: Run Flutter Driver tests uses: reactivecircus/android-emulator-runner@v2 with: - arch: x86_64 + # arch: x86_64 profile: Nexus 6 api-level: ${{ matrix.api-level }} target: ${{ matrix.target }}