From 27ec6c8b1960cc7131670a0c8939513b28bf0ae2 Mon Sep 17 00:00:00 2001 From: Aayush Sabharwal Date: Thu, 4 Jun 2026 11:18:08 +0530 Subject: [PATCH 1/2] ci: avoid running MTK downstream on lts/pre --- .github/workflows/MTKDownstream.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/MTKDownstream.yml b/.github/workflows/MTKDownstream.yml index 5a783c4..5a4f305 100644 --- a/.github/workflows/MTKDownstream.yml +++ b/.github/workflows/MTKDownstream.yml @@ -27,8 +27,6 @@ jobs: matrix: version: - "1" - - "lts" - - "pre" group: - InterfaceI - InterfaceII From ad103d4ba3b45190ee29e7c09b2a9ee11f3bda8c Mon Sep 17 00:00:00 2001 From: Aayush Sabharwal Date: Thu, 4 Jun 2026 11:18:33 +0530 Subject: [PATCH 2/2] ci: test component libraries --- .github/workflows/Downstream.yml | 72 ++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 .github/workflows/Downstream.yml diff --git a/.github/workflows/Downstream.yml b/.github/workflows/Downstream.yml new file mode 100644 index 0000000..2ff7e78 --- /dev/null +++ b/.github/workflows/Downstream.yml @@ -0,0 +1,72 @@ +name: "Downstream" + +on: + pull_request: + branches: + - main + paths-ignore: + - 'docs/**' + push: + branches: + - main + paths-ignore: + - 'docs/**' + - 'benchmark/**' + +concurrency: + # Skip intermediate builds: always, but for the master branch. + # Cancel intermediate builds: always, but for the master branch. + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: ${{ github.ref != 'refs/heads/master' }} + +jobs: + tests: + name: ${{ matrix.package.repo }}/${{ matrix.package.group }}/${{ matrix.julia-version }} + runs-on: ${{ matrix.os }} + env: + GROUP: ${{ matrix.package.group }} + strategy: + fail-fast: false + matrix: + julia-version: [1] + os: [ubuntu-latest] + package: + - {user: JuliaComputing, repo: MultibodyComponents.jl, group: All} + steps: + - uses: actions/checkout@v6 + - uses: julia-actions/setup-julia@v2 + with: + version: ${{ matrix.julia-version }} + arch: x64 + - uses: julia-actions/julia-buildpkg@latest + - name: Clone Downstream + uses: actions/checkout@v6 + with: + repository: ${{ matrix.package.user }}/${{ matrix.package.repo }} + path: downstream + - name: Load this and run the downstream tests + shell: julia --color=yes --project=downstream {0} + run: | + using Pkg + try + # force it to use this PR's version of the package + Pkg.develop([PackageSpec(path="./lib/ModelingToolkitTearing"), PackageSpec(path=".")]) # resolver may fail with main deps + Pkg.update() + Pkg.test(coverage=true) # resolver may fail with test time deps + catch err + err isa Pkg.Resolve.ResolverError || rethrow() + # If we can't resolve that means this is incompatible by SemVer and this is fine + # It means we marked this as a breaking change, so we don't need to worry about + # Mistakenly introducing a breaking change, as we have intentionally made one + @info "Not compatible with this release. No problem." exception=err + exit(0) # Exit immediately, as a success + end + - uses: julia-actions/julia-processcoverage@v1 + with: + directories: "src,lib/ModelingToolkitTearing/src" + - name: "Report Coverage with Codecov" + uses: codecov/codecov-action@v5 + with: + files: lcov.info + token: "${{ secrets.CODECOV_TOKEN }}" + fail_ci_if_error: false