From 4ee72bbcca67449109cdc353b2b2eb5ff2ef48b7 Mon Sep 17 00:00:00 2001
From: Joscha <34318751+josxha@users.noreply.github.com>
Date: Fri, 13 Sep 2024 22:46:11 +0200
Subject: [PATCH] chore: setup integration tests (#10)
- [x] ci
- [x] test app
- [x] android
- [x] web
- [x] ~controller tests~
- [x] ~codecov~
---
.github/workflows/ci.yml | 204 ++++++++++++++++++++
.github/workflows/flutter-beta.yml | 44 ++---
.github/workflows/flutter-ci.yml | 116 -----------
.gitignore | 3 +
README.md | 14 +-
docs/docs/getting-started/add-dependency.md | 3 +-
docs/docs/getting-started/setup-android.md | 31 ++-
docs/docs/getting-started/setup-web.md | 4 +-
docs/docs/getting-started/use-widget.md | 5 +-
docs/docs/map-styles.md | 11 +-
docs/src/css/custom.css | 2 +
example/android/app/build.gradle | 5 +-
example/integration_test/app.dart | 31 +++
example/integration_test/smoke_test.dart | 26 +++
example/pubspec.yaml | 4 +
example/test_driver/integration_test.dart | 3 +
16 files changed, 352 insertions(+), 154 deletions(-)
create mode 100644 .github/workflows/ci.yml
delete mode 100644 .github/workflows/flutter-ci.yml
create mode 100644 example/integration_test/app.dart
create mode 100644 example/integration_test/smoke_test.dart
create mode 100644 example/test_driver/integration_test.dart
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
new file mode 100644
index 00000000..c787c707
--- /dev/null
+++ b/.github/workflows/ci.yml
@@ -0,0 +1,204 @@
+name: CI
+
+on:
+ push:
+ branches: [ main ]
+ pull_request:
+ workflow_dispatch:
+
+# Ensure that new pushes/updates cancel running jobs
+concurrency:
+ group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
+ cancel-in-progress: true
+
+jobs:
+ format:
+ name: "Check formatting"
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v4
+ - uses: subosito/flutter-action@v2
+ with:
+ cache: true
+ - name: Lint analysis
+ run: dart format --set-exit-if-changed .
+ lint:
+ name: "Static code analysis"
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v4
+ - uses: subosito/flutter-action@v2
+ with:
+ cache: true
+ - name: "Get Flutter dependencies"
+ run: dart pub get
+ - name: Lint analysis
+ run: dart analyze --fatal-warnings --fatal-infos
+# integration-test-ios:
+# name: "Integration Tests on iOS"
+# runs-on: macOS-latest
+# defaults:
+# run:
+# working-directory: example
+# steps:
+# - uses: actions/checkout@v4
+# - uses: futureware-tech/simulator-action@v3
+# with:
+# model: 'iPhone 15'
+# - uses: subosito/flutter-action@v2
+# with:
+# cache: true
+# - run: flutter pub get
+# - run: flutter test integration_test --no-pub -r expanded
+ integration-test-android:
+ name: "Integration Tests on Android"
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ api-level: [ 23 ] # TODO add 34
+ timeout-minutes: 30
+ defaults:
+ run:
+ working-directory: example
+ steps:
+ - uses: actions/checkout@v4
+ - name: Setup Flutter SDK
+ uses: subosito/flutter-action@v2
+ with:
+ cache: true
+ - uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'temurin'
+ cache: 'gradle'
+ - name: "Get Flutter dependencies"
+ run: flutter pub get
+ - name: Run integration tests
+ uses: reactivecircus/android-emulator-runner@v2
+ with:
+ api-level: ${{ matrix.api-level }}
+ arch: x86_64
+ emulator-boot-timeout: 1800 # 30 minutes
+ script: cd example && flutter test integration_test -r expanded --timeout=none
+ integration-test-web:
+ name: "Integration Tests on Web"
+ runs-on: ubuntu-latest
+ timeout-minutes: 30
+ defaults:
+ run:
+ working-directory: example
+ steps:
+ - uses: actions/checkout@v4
+ - name: Setup Flutter SDK
+ uses: subosito/flutter-action@v2
+ with:
+ cache: true
+ - name: "Get Flutter dependencies"
+ run: flutter pub get
+ - name: "Start chromedriver"
+ run: |
+ sudo chromedriver --enable --port=4444 &
+ - name: "Run integration tests"
+ run: |
+ flutter drive \
+ --driver=test_driver/integration_test.dart \
+ --target=integration_test/smoke_test.dart \
+ -d web-server \
+ --release \
+ --browser-name=chrome
+ score:
+ name: "Package score"
+ runs-on: ubuntu-latest
+ steps:
+ - name: Checkout project
+ uses: actions/checkout@v4
+ - name: Setup Flutter
+ uses: subosito/flutter-action@v2
+ with:
+ cache: true
+ - name: Install pana
+ run: dart pub global activate pana
+ - name: Check package score
+ run: pana --exit-code-threshold 0 --no-dartdoc .
+ build-android:
+ name: "Build Android APK"
+ runs-on: ubuntu-latest
+ defaults:
+ run:
+ working-directory: example
+ strategy:
+ fail-fast: false
+ matrix:
+ sdk: [ '3.22.3', '' ]
+ steps:
+ - uses: actions/checkout@v4
+ - uses: subosito/flutter-action@v2
+ with:
+ flutter-version: ${{ matrix.sdk }}
+ cache: true
+ - uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'temurin'
+ cache: 'gradle'
+ - name: "Get Flutter dependencies"
+ run: dart pub get
+ - name: Build example APK
+ run: flutter build apk
+ - name: Upload apk as artifact
+ uses: actions/upload-artifact@v4
+ if: ${{ matrix.sdk == '' }}
+ with:
+ name: maplibre-flutter-demo.apk
+ path: example/build/app/outputs/flutter-apk/app-release.apk
+# build-iOS:
+# name: Build iOS package
+# runs-on: macos-latest
+# timeout-minutes: 30
+# defaults:
+# run:
+# working-directory: example
+# strategy:
+# fail-fast: false
+# matrix:
+# sdk: [ '3.22.3', '' ]
+# steps:
+# - uses: actions/checkout@v4
+# - uses: subosito/flutter-action@v2
+# with:
+# flutter-version: ${{ matrix.sdk }}
+# cache: true
+# - uses: maxim-lobanov/setup-cocoapods@v1
+# with:
+# podfile-path: example/ios/Podfile.lock
+# - name: "Get Flutter dependencies"
+# run: dart pub get
+# - name: Build iOS package
+# run: flutter build ios --simulator
+# - name: Upload Runner.app as artifact
+# if: ${{ matrix.sdk == '' }}
+# uses: actions/upload-artifact@v4
+# with:
+# name: maplibre-flutter-demo.app
+# path: example/build/ios/iphonesimulator
+ build-web:
+ name: "Build web"
+ runs-on: ubuntu-latest
+ defaults:
+ run:
+ working-directory: example
+ strategy:
+ fail-fast: false
+ matrix:
+ sdk: [ '3.22.3', '' ]
+ steps:
+ - uses: actions/checkout@v4
+ - uses: subosito/flutter-action@v2
+ with:
+ flutter-version: ${{ matrix.sdk }}
+ cache: true
+ - name: "Get Flutter dependencies"
+ run: dart pub get
+ - name: Build web
+ run: flutter build web
diff --git a/.github/workflows/flutter-beta.yml b/.github/workflows/flutter-beta.yml
index fb0aa6bc..d7e6f2c4 100644
--- a/.github/workflows/flutter-beta.yml
+++ b/.github/workflows/flutter-beta.yml
@@ -32,28 +32,28 @@ jobs:
with:
name: maplibre-flutter-demo.apk
path: example/build/app/outputs/flutter-apk/app-release.apk
- build-iOS:
- name: Build iOS package
- runs-on: macos-latest
- defaults:
- run:
- working-directory: example
- steps:
- - uses: actions/checkout@v4
- - uses: subosito/flutter-action@v2
- with:
- channel: ${{ env.FLUTTER_CHANNEL }}
- cache: true
- - uses: maxim-lobanov/setup-cocoapods@v1
- with:
- podfile-path: example/ios/Podfile.lock
- - name: Build iOS package
- run: flutter build ios --simulator
- - name: Upload Runner.app as artifact
- uses: actions/upload-artifact@v4
- with:
- name: maplibre-flutter-demo.app
- path: example/build/ios/iphonesimulator
+# build-iOS:
+# name: Build iOS package
+# runs-on: macos-latest
+# defaults:
+# run:
+# working-directory: example
+# steps:
+# - uses: actions/checkout@v4
+# - uses: subosito/flutter-action@v2
+# with:
+# channel: ${{ env.FLUTTER_CHANNEL }}
+# cache: true
+# - uses: maxim-lobanov/setup-cocoapods@v1
+# with:
+# podfile-path: example/ios/Podfile.lock
+# - name: Build iOS package
+# run: flutter build ios --simulator
+# - name: Upload Runner.app as artifact
+# uses: actions/upload-artifact@v4
+# with:
+# name: maplibre-flutter-demo.app
+# path: example/build/ios/iphonesimulator
build-web:
name: "Build web"
runs-on: ubuntu-latest
diff --git a/.github/workflows/flutter-ci.yml b/.github/workflows/flutter-ci.yml
deleted file mode 100644
index 8e760e52..00000000
--- a/.github/workflows/flutter-ci.yml
+++ /dev/null
@@ -1,116 +0,0 @@
-name: Flutter CI
-
-on:
- push:
- branches: [ main ]
- pull_request:
- workflow_dispatch:
-
-# Ensure that new pushes/updates cancel running jobs
-concurrency:
- group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
- cancel-in-progress: true
-
-jobs:
- format:
- name: "Check formatting"
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v4
- - uses: subosito/flutter-action@v2
- with:
- cache: true
- - name: Lint analysis
- run: dart format --set-exit-if-changed .
- lint:
- name: "Static code analysis"
- runs-on: ubuntu-latest
- steps:
- - uses: actions/checkout@v4
- - uses: subosito/flutter-action@v2
- with:
- cache: true
- - name: "Get flutter dependencies"
- run: dart pub get
- - name: Lint analysis
- run: dart analyze --fatal-warnings --fatal-infos
- build-android:
- name: "Build Android APK"
- runs-on: ubuntu-latest
- defaults:
- run:
- working-directory: example
-# strategy:
-# fail-fast: false
-# matrix:
-# sdk: [ '3.22.3', '' ]
- steps:
- - uses: actions/checkout@v4
- - uses: subosito/flutter-action@v2
- with:
- flutter-version: ${{ matrix.sdk }}
- cache: true
- - uses: actions/setup-java@v4
- with:
- java-version: '17'
- distribution: 'temurin'
- cache: 'gradle'
- - name: "Get flutter dependencies"
- run: dart pub get
- - name: Build example APK
- run: flutter build apk
- - name: Upload apk as artifact
- uses: actions/upload-artifact@v4
- if: ${{ matrix.sdk == '' }}
- with:
- name: maplibre-flutter-demo.apk
- path: example/build/app/outputs/flutter-apk/app-release.apk
-# build-iOS:
-# name: Build iOS package
-# runs-on: macos-latest
-# defaults:
-# run:
-# working-directory: example
-# strategy:
-# fail-fast: false
-# matrix:
-# sdk: [ '3.22.3', '' ]
-# steps:
-# - uses: actions/checkout@v4
-# - uses: subosito/flutter-action@v2
-# with:
-# flutter-version: ${{ matrix.sdk }}
-# cache: true
-# - uses: maxim-lobanov/setup-cocoapods@v1
-# with:
-# podfile-path: example/ios/Podfile.lock
-# - name: "Get flutter dependencies"
-# run: dart pub get
-# - name: Build iOS package
-# run: flutter build ios --simulator
-# - name: Upload Runner.app as artifact
-# if: ${{ matrix.sdk == '' }}
-# uses: actions/upload-artifact@v4
-# with:
-# name: maplibre-flutter-demo.app
-# path: example/build/ios/iphonesimulator
- build-web:
- name: "Build web"
- runs-on: ubuntu-latest
- defaults:
- run:
- working-directory: example
-# strategy:
-# fail-fast: false
-# matrix:
-# sdk: [ '3.22.3', '' ]
- steps:
- - uses: actions/checkout@v4
- - uses: subosito/flutter-action@v2
- with:
- flutter-version: ${{ matrix.sdk }}
- cache: true
- - name: "Get flutter dependencies"
- run: dart pub get
- - name: Build web
- run: flutter build web
diff --git a/.gitignore b/.gitignore
index 0299f8f7..6fcf232e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -27,3 +27,6 @@ pubspec.lock
**/doc/api/
.dart_tool/
build/
+
+# converage
+**/coverage/
\ No newline at end of file
diff --git a/README.md b/README.md
index 71bda0c3..effcb29e 100644
--- a/README.md
+++ b/README.md
@@ -4,6 +4,7 @@
[data:image/s3,"s3://crabby-images/dd1be/dd1be38fffb9d95a7b0836120b6945f937c8bd15" alt="likes"](https://pub.dev/packages/maplibre)
[data:image/s3,"s3://crabby-images/9504d/9504d8b2c38890f7fdd097a10ad425c591195ec5" alt="Pub Points"](https://pub.dev/packages/maplibre/score)
[data:image/s3,"s3://crabby-images/5e99c/5e99cb2e89d39277926a01aa1bc5cc83dfbc1718" alt="Pub Popularity"](https://pub.dev/packages/maplibre)
+[data:image/s3,"s3://crabby-images/cb934/cb9345abc425fe2ea680d3029b548e5366a46fe7" alt="style: very good analysis"](https://pub.dev/packages/very_good_analysis)
[data:image/s3,"s3://crabby-images/67f8a/67f8a34ba1d3e56ce7a43d128ca7700b24e05c2c" alt="GitHub last commit"](https://github.com/josxha/flutter-maplibre)
[data:image/s3,"s3://crabby-images/99e98/99e985376facab58f50680639879efe192306166" alt="stars"](https://github.com/josxha/flutter-maplibre/stargazers)
@@ -42,7 +43,7 @@ Check out the [hosted demo application](https://flutter-maplibre.pages.dev/demo)
or dive into
the [example app code](https://github.com/josxha/flutter-maplibre/tree/main/example/lib).
-### Get started & Documentation
+### Get Started & Documentation
Visit the docs to learn how to get started with maplibre in your
project: [Get Started](https://flutter-maplibre.pages.dev/docs/category/getting-started)
@@ -51,7 +52,7 @@ If you want to know more about the classes and properties of the package, have
a look at
the [API docs](https://pub.dev/documentation/maplibre/latest/maplibre/maplibre-library.html).
-### State of implementation
+### State of Implementation
This package is still a young package and in an early stage.
While it offers a modern implementation, it currently lacks some
@@ -62,14 +63,17 @@ functionality. [See our documentation to learn more.](https://flutter-maplibre.p
If you need a feature or experience a bug you want to fix contributions are
welcome.
-### Run code generation
+#### Run Code Generation
```bash
+flutter pub global activate pigeon # only once
dart run pigeon --input pigeons/pigeon.dart
cp ios/Classes/Pigeon.g.swift macos/Classes/Pigeon.g.swift
```
-### Test with WebAssembly
+#### Test with WebAssembly
+
+This package supports WebAssembly builds! 🥳
```bash
flutter pub global activate dhttpd # only once
@@ -80,4 +84,4 @@ dhttpd '--headers=Cross-Origin-Embedder-Policy=credentialless;Cross-Origin-Opene
or follow
the [flutter documentation](https://docs.flutter.dev/platform-integration/web/wasm#serving-wasm-locally)
-about WebAssembly builds.
\ No newline at end of file
+about Flutter WASM builds.
\ No newline at end of file
diff --git a/docs/docs/getting-started/add-dependency.md b/docs/docs/getting-started/add-dependency.md
index 46574eee..587f7590 100644
--- a/docs/docs/getting-started/add-dependency.md
+++ b/docs/docs/getting-started/add-dependency.md
@@ -15,10 +15,11 @@ or add it directly as a dependency to your `pubspec.yaml` file and run
```yaml title="pubspec.yaml"
dependencies:
+ # highlight-next-line
maplibre: ^0.0.1 # use the latest version found on pub.dev
```
You can find the latest version of the package on
-[pub.dev](https://pub.dev/packages/maplibre) or here:
+[pub.dev](https://pub.dev/packages/maplibre) or here:
[data:image/s3,"s3://crabby-images/d6f53/d6f53a5884385574184b6977c29beddd9364e083" alt="Pub Version"](https://pub.dev/packages/maplibre)
diff --git a/docs/docs/getting-started/setup-android.md b/docs/docs/getting-started/setup-android.md
index 8413ad60..d4ab1d91 100644
--- a/docs/docs/getting-started/setup-android.md
+++ b/docs/docs/getting-started/setup-android.md
@@ -10,13 +10,14 @@ Ensure that you are using Kotlin version
**1.9.0** or newer. You can check the most recent Kotlin version on
[kotlinlang.org](https://kotlinlang.org/docs/releases.html#release-details).
-#### (new) Gradle with a declarative plugins block
+### (new) Gradle with a declarative plugins block
Open `android/settings.gradle` and set the Kotlin version like this:
```gradle title="android/settings.gradle"
plugins {
// ...
+ // highlight-next-line
id "org.jetbrains.kotlin.android" version "1.9.0" apply false
}
```
@@ -24,18 +25,40 @@ plugins {
In case you can't find the `plugins {}` block your app still uses the old apply
script method.
-#### (old) In a legacy apply script gradle file:
+### (old) In a legacy apply script gradle file
Open `android/app/build.gradle` and set the Kotlin version like this:
```gradle title="android/app/build.gradle"
buildscript {
+ // highlight-next-line
ext.kotlin_version = '1.9.0'
// ...
}
```
-## Use the location feature
+## Adjust the minSdk version of Android
+
+The `maplibre` package on Flutter
+uses [platform views](https://docs.flutter.dev/platform-integration/android/platform-views)
+to display the native map. This requires an Android SDK version of at least 23
+(Android 6.0).
+
+Open your `android/app/build.gradle` file and ensure that it is set to 23 or
+higher.
+
+```gradle title="android/app/build.gradle"
+android {
+ defaultConfig {
+ // ...
+ // highlight-next-line
+ minSdk = 23 // previously flutter.minSdkVersion
+ // ...
+ }
+}
+```
+
+## Set the permissions
If you want to show the user's location on the map you need to add
the `ACCESS_COARSE_LOCATION` or `ACCESS_FINE_LOCATION` permission in the
@@ -44,8 +67,10 @@ application manifest `android/app/src/main/AndroidManifest.xml`.
```xml title="android/app/src/main/AndroidManifest.xml"