423 lines
11 KiB
Markdown
423 lines
11 KiB
Markdown
# flutter-action
|
|
|
|
Flutter environment for use in GitHub Actions. It works on Linux, Windows, and
|
|
macOS.
|
|
|
|
Originally created by [Alif Rachmawadi]. Maintained by [Bartek Pacia].
|
|
|
|
The following sections show how to configure this action.
|
|
|
|
## Specifying Flutter version
|
|
|
|
### Use specific version and channel
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
flutter-version: 3.19.0
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use version from pubspec.yaml
|
|
|
|
This is inspired by [`actions/setup-go`](https://github.com/actions/setup-go).
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
flutter-version-file: pubspec.yaml # path to pubspec.yaml
|
|
- run: flutter --version
|
|
```
|
|
|
|
> [!IMPORTANT]
|
|
>
|
|
> For `flutter-version-file` to work, you need to have the exact Flutter version
|
|
> defined in your pubspec.yaml:
|
|
>
|
|
> **Good**
|
|
>
|
|
> ```yaml
|
|
> environment:
|
|
> sdk: ">=3.3.0 <4.0.0"
|
|
> flutter: 3.19.0
|
|
> ```
|
|
>
|
|
> **Bad**
|
|
>
|
|
> ```yaml
|
|
> environment:
|
|
> sdk: ">=3.3.0 <4.0.0"
|
|
> flutter: ">= 3.19.0 <4.0.0"
|
|
> ```
|
|
|
|
> [!NOTE]
|
|
>
|
|
> Using `flutter-version-file` requires [`yq`](https://github.com/mikefarah/yq),
|
|
> which is not pre-installed in `windows` runners. Fortunately, since version
|
|
> 2.18.0, this action installs `yq` automatically if `flutter-version-file`
|
|
> is specified, so no action is required from you.
|
|
|
|
### Use latest release for particular channel
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable # or: beta, master (or main)
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use latest release for particular version and/or channel
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: dev
|
|
flutter-version: 1.22.x
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use particular version on any channel
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: any
|
|
flutter-version: 3.x
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use particular git reference on master channel
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: master
|
|
flutter-version: 5b12b74 # tag, commit or branch
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use a Flutter mirror by set ENV
|
|
|
|
You can get more infomation from [Flutter official docs](https://docs.flutter.dev/community/china).
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
env:
|
|
FLUTTER_STORAGE_BASE_URL: https://storage.flutter-io.cn
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: master
|
|
flutter-version: 5b12b74 # tag, commit or branch
|
|
- run: flutter --version
|
|
```
|
|
|
|
### Use alternative Flutter repository
|
|
|
|
This action supports "alternative Flutters" in addition to the official
|
|
[`flutter/flutter`](https://github.com/flutter/flutter), for example:
|
|
- [Flock](https://github.com/join-the-flock/flock.git)
|
|
- [a Flutter fork that supports
|
|
HarmonyOS](https://gitee.com/harmonycommando_flutter/flutter.git)
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: master
|
|
flutter-version: 3.24.0
|
|
git-source: https://github.com/join-the-flock/flock.git
|
|
- run: flutter --version
|
|
```
|
|
|
|
> [!NOTE]
|
|
>
|
|
> This feature was implemented in
|
|
> [#344](https://github.com/subosito/flutter-action/pull/334) and is available
|
|
> since v2.18.0.
|
|
|
|
### Apply a patch
|
|
|
|
Sometimes you find a bug in Flutter and you fix it yourself (you're a
|
|
rockstar!), and then submit a patch/PR to Flutter repository. However, everyone
|
|
knows that code review takes time, but your app needs the fix _now_.
|
|
|
|
You can apply your patch like this:
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- uses: subosito/flutter-action@v2
|
|
with:
|
|
flutter-version: 3.22.2
|
|
channel: stable
|
|
- run: |
|
|
flutter --version
|
|
cd ${{ env.FLUTTER_ROOT }}
|
|
curl https://patch-diff.githubusercontent.com/raw/flutter/flutter/pull/137874.patch | git apply
|
|
git status
|
|
```
|
|
|
|
> [!NOTE]
|
|
>
|
|
> This was first discussed in [this issue](https://github.com/subosito/flutter-action/issues/310).
|
|
|
|
## Build targets
|
|
|
|
Build **Android** APK and app bundle:
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
flutter-version: 3.24.0
|
|
- run: flutter pub get
|
|
- run: flutter test
|
|
- run: flutter build apk
|
|
- run: flutter build appbundle
|
|
```
|
|
|
|
### Build for iOS
|
|
|
|
> [!NOTE]
|
|
>
|
|
> Building for iOS requires a macOS runner.
|
|
|
|
```yaml
|
|
jobs:
|
|
main:
|
|
runs-on: macos-latest
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
- run: flutter pub get
|
|
- run: flutter test
|
|
- run: flutter build ios --release --no-codesign
|
|
```
|
|
|
|
### Build for the web
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
- run: flutter pub get
|
|
- run: flutter test
|
|
- run: flutter build web
|
|
```
|
|
|
|
### Build for Windows
|
|
|
|
```yaml
|
|
jobs:
|
|
main:
|
|
runs-on: windows-latest
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
- run: flutter build windows
|
|
```
|
|
|
|
### Build for Linux desktop
|
|
|
|
```yaml
|
|
jobs:
|
|
main:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
- run: |
|
|
sudo apt-get update -y
|
|
sudo apt-get install -y ninja-build libgtk-3-dev
|
|
- run: flutter build linux
|
|
```
|
|
|
|
### Build for macOS desktop
|
|
|
|
> [!NOTE]
|
|
>
|
|
> Building for macOS requires a macOS runner.
|
|
|
|
```yaml
|
|
jobs:
|
|
main:
|
|
runs-on: macos-latest
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
- run: flutter build macos
|
|
```
|
|
|
|
## Caching
|
|
|
|
Integration with [`actions/cache`](https://github.com/actions/cache):
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
with:
|
|
channel: stable
|
|
cache: true
|
|
# optional parameters follow
|
|
cache-key: "flutter-:os:-:channel:-:version:-:arch:-:hash:" # optional, change this to force refresh cache
|
|
cache-path: "${{ runner.tool_cache }}/flutter/:channel:-:version:-:arch:" # optional, change this to specify the cache path
|
|
pub-cache-key: "flutter-pub-:os:-:channel:-:version:-:arch:-:hash:" # optional, change this to force refresh cache of dart pub get dependencies
|
|
pub-cache-path: "${{ runner.tool_cache }}/flutter/:channel:-:version:-:arch:" # optional, change this to specify the cache path
|
|
- run: flutter --version
|
|
```
|
|
|
|
Note: `cache-key`, `pub-cache-key`, and `cache-path` have support for several
|
|
dynamic values:
|
|
|
|
- `:os:`
|
|
- `:channel:`
|
|
- `:version:`
|
|
- `:arch:`
|
|
- `:hash:`
|
|
- `:sha256:`
|
|
|
|
### Using cache outputs
|
|
|
|
> [!NOTE]
|
|
> `PUB-CACHE-HIT` and `CACHE-HIT` directly use the `cache-hit` output from `actions/cache@v4`, which is the following:
|
|
> - `cache-hit` - A string value to indicate an exact match was found for the key.
|
|
> - If there's a cache hit, this will be 'true' or 'false' to indicate if there's an exact match for `key`.
|
|
> - If there's a cache miss, this will be an empty string.
|
|
|
|
Example usage (inspired by [actions/cache@v4](https://github.com/actions/cache/blob/c45d39173a637a28edbd526cb160189cc4e84f5a/README.md#skipping-steps-based-on-cache-hit) and [#346](https://github.com/subosito/flutter-action/pull/346)) to skip `melos bootstrap` if there was a pub cache hit:
|
|
|
|
```
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
id: flutter-action
|
|
with:
|
|
channel: stable
|
|
cache: true
|
|
|
|
- name: Conditionally run melos bootstrap
|
|
if: steps.flutter-action.outputs.PUB-CACHE-HIT != 'true'
|
|
run: melos bootstrap
|
|
|
|
- name: Continue with build
|
|
run: flutter build apk
|
|
```
|
|
|
|
## Outputs
|
|
|
|
Use outputs from `flutter-action`:
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
- uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
id: flutter-action
|
|
with:
|
|
channel: stable
|
|
- name: Print outputs
|
|
shell: bash
|
|
run: |
|
|
echo CACHE-PATH=${{ steps.flutter-action.outputs.CACHE-PATH }}
|
|
echo CACHE-KEY=${{ steps.flutter-action.outputs.CACHE-KEY }}
|
|
echo CHANNEL=${{ steps.flutter-action.outputs.CHANNEL }}
|
|
echo VERSION=${{ steps.flutter-action.outputs.VERSION }}
|
|
echo ARCHITECTURE=${{ steps.flutter-action.outputs.ARCHITECTURE }}
|
|
echo PUB-CACHE-PATH=${{ steps.flutter-action.outputs.PUB-CACHE-PATH }}
|
|
echo PUB-CACHE-KEY=${{ steps.flutter-action.outputs.PUB-CACHE-KEY }}
|
|
echo CACHE-HIT=${{ steps.flutter-action.outputs.CACHE-HIT }}
|
|
echo PUB-CACHE-HIT=${{ steps.flutter-action.outputs.PUB-CACHE-HIT }}
|
|
```
|
|
|
|
If you don't need to install Flutter and just want the outputs, you can use the
|
|
`dry-run` option:
|
|
|
|
```yaml
|
|
steps:
|
|
- name: Clone repository
|
|
- uses: actions/checkout@v4
|
|
- name: Set up Flutter
|
|
uses: subosito/flutter-action@v2
|
|
id: flutter-action
|
|
with:
|
|
channel: stable
|
|
dry-run: true
|
|
- run: |
|
|
echo CACHE-PATH=${{ steps.flutter-action.outputs.CACHE-PATH }}
|
|
echo CACHE-KEY=${{ steps.flutter-action.outputs.CACHE-KEY }}
|
|
echo CHANNEL=${{ steps.flutter-action.outputs.CHANNEL }}
|
|
echo VERSION=${{ steps.flutter-action.outputs.VERSION }}
|
|
echo ARCHITECTURE=${{ steps.flutter-action.outputs.ARCHITECTURE }}
|
|
echo PUB-CACHE-PATH=${{ steps.flutter-action.outputs.PUB-CACHE-PATH }}
|
|
echo PUB-CACHE-KEY=${{ steps.flutter-action.outputs.PUB-CACHE-KEY }}
|
|
echo CACHE-HIT=${{ steps.flutter-action.outputs.CACHE-HIT }}
|
|
echo PUB-CACHE-HIT=${{ steps.flutter-action.outputs.PUB-CACHE-HIT }}
|
|
shell: bash
|
|
```
|
|
|
|
[Alif Rachmawadi]: https://github.com/subosito
|
|
[Bartek Pacia]: https://github.com/bartekpacia
|