1
0
Fork 0
mirror of https://github.com/subosito/flutter-action.git synced 2024-08-16 10:19:50 +02:00
flutter/README.md

198 lines
4.2 KiB
Markdown
Raw Normal View History

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
2022-01-06 17:00:13 +01:00
## Usage
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:
- 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:
flutter-version: '3.16.9'
2022-01-06 10:55:43 +01:00
channel: 'stable'
- run: flutter --version
```
2021-04-26 16:56:05 +02:00
Use latest release for particular channel:
```yaml
steps:
- uses: actions/checkout@v4
2022-01-06 10:23:09 +01:00
- uses: subosito/flutter-action@v2
with:
channel: 'stable' # or: 'beta', 'dev', 'master' (or 'main')
2022-01-06 10:55:43 +01:00
- run: flutter --version
```
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:
- 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:
```yaml
2021-04-26 16:56:05 +02:00
steps:
- 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:
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
```
Use particular git reference on master channel:
```yaml
steps:
- uses: actions/checkout@v4
- uses: subosito/flutter-action@v2
with:
flutter-version: '5b12b74' # tag, commit or branch
channel: 'master'
- run: flutter --version
```
2021-04-26 16:56:05 +02:00
Build Android APK and app bundle:
2019-08-16 14:02:42 +02:00
```yaml
steps:
- 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:
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
```
2022-01-06 10:55:43 +01:00
Build for iOS (macOS only):
2021-04-26 16:56:05 +02:00
```yaml
jobs:
build:
runs-on: macos-latest
steps:
- 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
```
Build for the web:
2019-08-16 14:02:42 +02:00
```yaml
steps:
- 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
```
Build for Windows:
```yaml
2022-01-06 10:55:43 +01:00
jobs:
build:
runs-on: windows-latest
steps:
- uses: actions/checkout@v4
2022-01-06 10:55:43 +01:00
- uses: subosito/flutter-action@v2
with:
channel: 'stable'
2022-01-06 10:55:43 +01:00
- run: flutter build windows
2019-08-16 14:02:42 +02:00
```
Build for Linux desktop:
```yaml
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: subosito/flutter-action@v2
with:
2022-07-25 14:35:02 +02:00
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:
```yaml
jobs:
build:
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
- uses: subosito/flutter-action@v2
with:
2022-07-25 14:35:02 +02:00
channel: 'stable'
- run: flutter build macos
```
2022-01-08 15:55:41 +01:00
Integration with `actions/cache`:
2022-01-07 05:47:25 +01:00
```yaml
steps:
- 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
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
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
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:
- uses: actions/checkout@v4
2022-09-08 03:41:22 +02:00
- id: flutter-action
uses: subosito/flutter-action@v2
with:
channel: 'stable'
- 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 }}
2022-09-08 03:41:22 +02:00
shell: bash
```