Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/renancaraujo/has-dart-package-changed
https://github.com/renancaraujo/has-dart-package-changed
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/renancaraujo/has-dart-package-changed
- Owner: renancaraujo
- License: mit
- Created: 2022-05-12T09:29:36.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-07-11T14:22:35.000Z (over 2 years ago)
- Last Synced: 2023-03-02T01:56:57.673Z (almost 2 years ago)
- Language: Dart
- Size: 4.88 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Has dart package changed?
A github action to detect changes in a dart package with local dependencies. This action detects if
the given changes has affected the package itself and all fo its local dependencies, direct or
transitive.This differs from github's path filters since it is run in a step and dynamically filters workflow
runs given the dependencies of a package. Ideal for monorepos.### Requirements
This action requires either Dart or Flutter to be available. See Dart ann Flutter actions.
Since this action uses git command to check for changes, the repository must be checked out. See
checkout action.## Example
Example of usage in a pull request workflow:
```yaml
name: rooton:
pull_request:
branches:
- main
jobs:
root:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: dart-lang/setup-dart@v1 # Setup Dart or Flutter beforehand
with:
sdk: stable
- uses: renancaraujo/has-dart-package-changed@main
id: check-changes # Specify an id to retrieve the output
with:
package-path: 'packages/root_package'
- name: "runs only when root package changes"
if: steps.check-changes.outputs.changed == 'true' # Check for changes in that package
run: // ... do stuff
```In that example, if `packages/root_package` has its source or any of its local path dependencies
changed, the out put for `check-changes` will be `'true'`.## Usage
### Inputs
- `package-path` (required): the path to the package to be evaluated
### Outputs
- `changed`: Either `'true'` or `'false'`, defines if the changes affected the given package.