Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matejkob/swift-macro-compatibility-check
GitHub Action that verifies compatibility of a Swift package with macros against all swift-syntax versions
https://github.com/matejkob/swift-macro-compatibility-check
ci-cd swift testing xcode
Last synced: about 2 months ago
JSON representation
GitHub Action that verifies compatibility of a Swift package with macros against all swift-syntax versions
- Host: GitHub
- URL: https://github.com/matejkob/swift-macro-compatibility-check
- Owner: Matejkob
- License: mit
- Created: 2024-06-29T16:16:39.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-09-27T19:11:22.000Z (3 months ago)
- Last Synced: 2024-10-12T21:10:50.735Z (3 months ago)
- Topics: ci-cd, swift, testing, xcode
- Language: Shell
- Homepage:
- Size: 40 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Swift Macro Compatibility Check
This GitHub Action verifies compatibility of a Swift package with macros against all `swift-syntax` versions.
## Motivation
The introduction of macros in Swift 5.9 has significantly changed how many Swift libraries interact with `swift-syntax`. As pointed out by Point-Free in their article [Being a good citizen in the land of SwiftSyntax](https://www.pointfree.co/blog/posts/116-being-a-good-citizen-in-the-land-of-swiftsyntax) this change has brought about several challenges:
1. **Versioning Complexity**: `swift-syntax` uses a versioning scheme where major versions correspond to minor versions of Swift (e.g., SwiftSyntax 509.0 corresponds to Swift 5.9). This complicates dependency management.
1. **Breaking Changes**: `swift-syntax` has had breaking changes in minor releases, which causes compatibility issues.
1. **Dependency Resolution**: With more libraries using `swift-syntax` for macros, there's an increased likelihood of unresolvable dependency graphs due to multiple libraries needing different major versions of the package.
This action aims to address these challenges by:
- Ensuring your macros are compatible with multiple versions of `swift-syntax`.
- Allowing you to easily test against both major versions and all minor versions.
- Helping you catch potential compatibility issues early in your development process.By using this action, you're taking a step towards being a **good citizen in the Swift ecosystem**, helping to prevent dependency conflicts and ensuring your library works across a range of `swift-syntax` versions.
## Usage
To use this action in your workflow, add the following step:
```yaml
- name: Run Swift Macro Compatibility Check
uses: Matejkob/swift-macro-compatibility-check@v1
```> [!IMPORTANT]
> Make sure to run this action on a macOS runner:```yaml
jobs:
check-macro-compatibility:
runs-on: macos-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Run Swift Macro Compatibility Check
uses: Matejkob/swift-macro-compatibility-check@v1
```## Inputs
| Input | Description | Required | Default |
|-----------------------|---------------------------------------------------------------|----------|---------|
| `run-tests` | Whether to run tests (true/false) | false | false |
| `major-versions-only` | Whether to test only against major versions (true/false) | false | false |
| `verbose` | Whether to use verbose output for Swift commands (true/false) | false | false |## `swift-syntax` Versions
The action tests against the following `swift-syntax` versions:
- `509.0.0`
- `509.0.1`
- `509.0.2`
- `509.1.0`
- `509.1.1`
- `510.0.0`
- `510.0.1`
- `510.0.2`
- `510.0.3`
- `600.0.0`
- `600.0.1`When `major-versions-only` is set to `true`, only versions `509.0.0`, `510.0.0`, and `600.0.0` are tested.
## Running the Script Locally
If you'd like to run the compatibility check script locally without GitHub Actions, you can do so by executing the provided bash script [`swift-macro-compatibility-check.sh`](swift-macro-compatibility-check.sh) in your terminal.
### Usage
```bash
./swift-macro-compatibility-check.sh [--run-tests] [--major-versions-only] [--verbose]
```### Script Overview
The script checks the compatibility of a Swift package with multiple versions of `swift-syntax`. It can be configured to run tests and provide verbose output. The script performs the following steps for each version of `swift-syntax`:
1. Resolves package dependencies for the specific `swift-syntax` version.
2. Builds the Swift package.
3. Optionally runs tests.
4. Outputs a summary indicating which versions succeeded and which failed.## Examples
### Basic Usage in GitHub Actions
```yaml
name: Swift Macro Compatibilityon: [push, pull_request]
jobs:
check-compatibility:
runs-on: macos-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Run Swift Macro Compatibility Check
uses: Matejkob/swift-macro-compatibility-check@v1
```### With All Options
```yaml
name: Swift Macro Compatibilityon: [push, pull_request]
jobs:
check-compatibility:
runs-on: macos-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Run Swift Macro Compatibility Check
uses: Matejkob/swift-macro-compatibility-check@v1
with:
run-tests: 'true'
major-versions-only: 'false'
verbose: 'true'
```## Contributing
Contributions to improve the action or script are welcome. Please feel free to submit issues or pull requests.
## License
This GitHub Action and the associated script are released under the [MIT License](LICENSE).