2019-08-13 12:11:30 +02:00
|
|
|
# flutter-action
|
|
|
|
|
2022-01-06 17:00:13 +01:00
|
|
|
Flutter environment for use in GitHub Actions. It works on Linux, Windows, and macOS.
|
2019-08-13 12:11:30 +02:00
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
The following sections show how to configure this action.
|
|
|
|
|
|
|
|
## Flutter version
|
2019-08-13 12:11:30 +02:00
|
|
|
|
2022-01-06 10:55:43 +01:00
|
|
|
Use specific version and channel:
|
|
|
|
|
2019-08-13 12:11:30 +02:00
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2019-08-13 12:11:30 +02:00
|
|
|
with:
|
2024-02-13 01:52:27 +01:00
|
|
|
flutter-version: '3.16.9'
|
2022-01-06 10:55:43 +01:00
|
|
|
channel: 'stable'
|
|
|
|
- run: flutter --version
|
2020-04-09 14:40:15 +02:00
|
|
|
```
|
|
|
|
|
2021-04-26 16:56:05 +02:00
|
|
|
Use latest release for particular channel:
|
2020-04-09 14:40:15 +02:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2020-04-09 14:40:15 +02:00
|
|
|
with:
|
2023-11-20 10:29:45 +01:00
|
|
|
channel: 'stable' # or: 'beta', 'dev', 'master' (or 'main')
|
2022-01-06 10:55:43 +01:00
|
|
|
- run: flutter --version
|
2020-04-09 14:40:15 +02:00
|
|
|
```
|
|
|
|
|
2021-04-26 16:56:05 +02:00
|
|
|
Use latest release for particular version and/or channel:
|
2020-06-19 16:13:08 +02:00
|
|
|
|
|
|
|
```yaml
|
2021-04-26 16:24:54 +02:00
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2021-04-26 16:24:54 +02:00
|
|
|
with:
|
2023-03-21 15:37:50 +01:00
|
|
|
flutter-version: '1.22.x'
|
2021-04-26 16:56:05 +02:00
|
|
|
channel: 'dev'
|
2022-01-06 10:55:43 +01:00
|
|
|
- run: flutter --version
|
2020-06-19 16:13:08 +02:00
|
|
|
```
|
|
|
|
|
2021-04-26 16:56:05 +02:00
|
|
|
Use particular version on any channel:
|
2020-11-25 10:07:49 +01:00
|
|
|
|
|
|
|
```yaml
|
2021-04-26 16:56:05 +02:00
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2021-04-26 16:56:05 +02:00
|
|
|
with:
|
2024-02-13 01:52:27 +01:00
|
|
|
flutter-version: '3.x'
|
2021-04-26 16:56:05 +02:00
|
|
|
channel: 'any'
|
2022-01-06 10:55:43 +01:00
|
|
|
- run: flutter --version
|
2020-11-25 10:07:49 +01:00
|
|
|
```
|
|
|
|
|
2023-10-11 10:55:21 +02:00
|
|
|
Use particular git reference on master channel:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2023-10-11 10:55:21 +02:00
|
|
|
- uses: subosito/flutter-action@v2
|
|
|
|
with:
|
|
|
|
flutter-version: '5b12b74' # tag, commit or branch
|
|
|
|
channel: 'master'
|
|
|
|
- run: flutter --version
|
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
## Build Target
|
|
|
|
|
|
|
|
Build **Android** APK and app bundle:
|
2019-08-16 14:02:42 +02:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2019-08-16 14:02:42 +02:00
|
|
|
with:
|
2024-02-13 01:52:27 +01:00
|
|
|
flutter-version: '3.16.9'
|
2019-08-16 14:02:42 +02:00
|
|
|
- run: flutter pub get
|
|
|
|
- run: flutter test
|
|
|
|
- run: flutter build apk
|
2021-04-26 16:56:05 +02:00
|
|
|
- run: flutter build appbundle
|
2019-08-16 14:02:42 +02:00
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
Build for **iOS** (macOS only):
|
2021-04-26 16:56:05 +02:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
runs-on: macos-latest
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2021-04-26 16:56:05 +02:00
|
|
|
with:
|
2022-07-25 14:35:02 +02:00
|
|
|
channel: 'stable'
|
2021-04-26 16:56:05 +02:00
|
|
|
- run: flutter pub get
|
|
|
|
- run: flutter test
|
|
|
|
- run: flutter build ios --release --no-codesign
|
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
Build for the **web**:
|
2019-08-16 14:02:42 +02:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:23:09 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
2019-08-16 14:02:42 +02:00
|
|
|
with:
|
2022-07-25 14:35:02 +02:00
|
|
|
channel: 'stable'
|
2019-08-16 14:02:42 +02:00
|
|
|
- run: flutter pub get
|
|
|
|
- run: flutter test
|
2021-04-26 16:56:05 +02:00
|
|
|
- run: flutter build web
|
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
Build for **Windows**:
|
2021-04-26 16:56:05 +02:00
|
|
|
|
|
|
|
```yaml
|
2022-01-06 10:55:43 +01:00
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
runs-on: windows-latest
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 10:55:43 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
|
|
|
with:
|
2024-02-13 01:52:27 +01:00
|
|
|
channel: 'stable'
|
2022-01-06 10:55:43 +01:00
|
|
|
- run: flutter build windows
|
2019-08-16 14:02:42 +02:00
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
Build for **Linux** desktop:
|
2022-01-06 12:16:06 +01:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 12:16:06 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
|
|
|
with:
|
2022-07-25 14:35:02 +02:00
|
|
|
channel: 'stable'
|
2022-01-06 12:45:16 +01:00
|
|
|
- run: |
|
|
|
|
sudo apt-get update -y
|
|
|
|
sudo apt-get install -y ninja-build libgtk-3-dev
|
2022-01-06 12:16:06 +01:00
|
|
|
- run: flutter build linux
|
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
Build for **macOS** desktop:
|
2022-01-06 12:16:06 +01:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
runs-on: macos-latest
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-06 12:16:06 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
|
|
|
with:
|
2022-07-25 14:35:02 +02:00
|
|
|
channel: 'stable'
|
2022-01-06 12:16:06 +01:00
|
|
|
- run: flutter build macos
|
|
|
|
```
|
|
|
|
|
2024-03-31 18:24:22 +02:00
|
|
|
## Caching
|
|
|
|
|
2022-01-08 15:55:41 +01:00
|
|
|
Integration with `actions/cache`:
|
2022-01-07 05:47:25 +01:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-01-07 05:47:25 +01:00
|
|
|
- uses: subosito/flutter-action@v2
|
|
|
|
with:
|
2022-02-04 12:04:07 +01:00
|
|
|
channel: 'stable'
|
2022-01-08 15:55:41 +01:00
|
|
|
cache: true
|
2024-03-31 18:24:22 +02:00
|
|
|
# optional parameters follow
|
2022-07-26 07:08:35 +02:00
|
|
|
cache-key: 'flutter-:os:-:channel:-:version:-:arch:-:hash:' # optional, change this to force refresh cache
|
2023-06-24 11:31:51 +02:00
|
|
|
cache-path: '${{ runner.tool_cache }}/flutter/:channel:-:version:-:arch:' # optional, change this to specify the cache path
|
2024-02-13 01:13:38 +01:00
|
|
|
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
|
2022-01-07 05:47:25 +01:00
|
|
|
- run: flutter --version
|
|
|
|
```
|
2022-07-25 14:35:02 +02:00
|
|
|
|
2024-02-13 01:13:38 +01:00
|
|
|
Note: `cache-key`, `pub-cache-key`, and `cache-path` has support for several dynamic values:
|
2022-07-25 14:35:02 +02:00
|
|
|
|
|
|
|
- `:os:`
|
|
|
|
- `:channel:`
|
|
|
|
- `:version:`
|
2022-07-26 07:08:35 +02:00
|
|
|
- `:arch:`
|
2022-07-25 14:35:02 +02:00
|
|
|
- `:hash:`
|
|
|
|
- `:sha256:`
|
2022-09-08 03:41:22 +02:00
|
|
|
|
|
|
|
Use outputs from `flutter-action`:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
steps:
|
2024-02-13 01:52:27 +01:00
|
|
|
- uses: actions/checkout@v4
|
2022-09-08 03:41:22 +02:00
|
|
|
- id: flutter-action
|
|
|
|
uses: subosito/flutter-action@v2
|
|
|
|
with:
|
|
|
|
channel: 'stable'
|
|
|
|
- run: |
|
2022-10-13 01:31:27 +02:00
|
|
|
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 }}
|
2024-02-13 01:13:38 +01:00
|
|
|
echo PUB-CACHE-PATH=${{ steps.flutter-action.outputs.PUB-CACHE-PATH }}
|
|
|
|
echo PUB-CACHE-KEY=${{ steps.flutter-action.outputs.PUB-CACHE-KEY }}
|
2022-09-08 03:41:22 +02:00
|
|
|
shell: bash
|
|
|
|
```
|