Skip to content

Commit b612b3e

Browse files
committed
Use overrides for using the same branchname over multiple repos
1 parent 56574ef commit b612b3e

File tree

5 files changed

+138
-43
lines changed

5 files changed

+138
-43
lines changed

.github/workflows/coverage.yml

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,21 @@ jobs:
2525
- name: Set up PDM
2626
uses: pdm-project/setup-pdm@v4
2727

28+
- name: Generate overrides to use current branch if PR
29+
if: github.event_name == 'pull_request'
30+
run: |
31+
pdm run tools/gen_overrides.py ${{github.head_ref}} > overrides.txt
32+
echo "Generated overrides:"
33+
cat overrides.txt
34+
35+
- name: Relock PDM
36+
if: github.event_name != 'pull_request'
37+
run: pdm lock -d
38+
39+
- name: Relock PDM (PR)
40+
if: github.event_name == 'pull_request'
41+
run: pdm lock -d --override overrides.txt
42+
2843
- name: Install dependencies
2944
run: |
3045
pdm install

.github/workflows/main.yaml

Lines changed: 50 additions & 43 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,22 @@ jobs:
1919
fetch-depth: 0
2020
- name: Set up PDM
2121
uses: pdm-project/setup-pdm@v4
22+
23+
- name: Generate overrides to use current branch if PR
24+
if: github.event_name == 'pull_request'
25+
run: |
26+
pdm run tools/gen_overrides.py ${{github.head_ref}} > overrides.txt
27+
echo "Generated overrides:"
28+
cat overrides.txt
29+
30+
- name: Relock PDM
31+
if: github.event_name != 'pull_request'
32+
run: pdm lock -d
33+
34+
- name: Relock PDM (PR)
35+
if: github.event_name == 'pull_request'
36+
run: pdm lock -d --override overrides.txt
37+
2238
- name: Install dependencies
2339
run: |
2440
pdm install
@@ -39,75 +55,66 @@ jobs:
3955
with:
4056
fetch-depth: 0
4157
- name: Check source code licenses
42-
run: |
43-
docker run --platform=linux/amd64 -v ${PWD}:/src ghcr.io/google/addlicense -v -check -l BSD-2-Clause -c "ChipFlow" -s=only -ignore **/__init__.py **/*.py
58+
run: ./tools/license_check.sh
4459

4560
test-submit:
4661
runs-on: ubuntu-latest
62+
strategy:
63+
matrix:
64+
dry: [true, false]
65+
env:
66+
DRY: ${{ matrix.dry && '--dry-run' || '' }}
67+
IS_DRY: ${{ matrix.dry && '(dry run)' || '' }}
68+
name: ${{ matrix.dry && 'Test Submit - Dry run' || 'Test submit' }}
69+
4770
steps:
48-
- name: Check out source code
49-
uses: actions/checkout@v4
50-
with:
51-
fetch-depth: 0
52-
path: chipflow-lib
5371
- name: Check out chipflow-examples
5472
uses: actions/checkout@v4
5573
with:
5674
repository: ChipFlow/chipflow-examples
5775
fetch-depth: 0
5876
path: chipflow-examples
77+
ref: ${{ github.head_ref || 'refs/heads/main' }}
5978

6079
- name: Set up PDM
6180
uses: pdm-project/setup-pdm@v4
6281
with:
63-
python-version: "3.10"
82+
python-version: '3.10'
6483
cache: true
65-
cache-dependency-path: "./**/pyproject.toml"
66-
- name: Install dependencies
84+
cache-dependency-path: './**/pyproject.toml'
85+
86+
- name: Generate overrides to use current branch if PR
6787
working-directory: ./chipflow-examples
88+
if: github.event_name == 'pull_request'
6889
run: |
69-
pdm install
70-
pdm run python -m ensurepip
71-
pdm run python -m pip install -e ../chipflow-lib
72-
- name: Run tests
90+
pdm run tools/gen_overrides.py ${{github.head_ref}} > overrides.txt
91+
echo "Generated overrides:"
92+
cat overrides.txt
93+
94+
- name: Relock PDM
7395
working-directory: ./chipflow-examples
74-
run: |
75-
pdm test
76-
pdm run chipflow pin lock
77-
pdm run chipflow silicon submit --wait
78-
env:
79-
CHIPFLOW_API_KEY: ${{ secrets.CHIPFLOW_API_KEY}}
96+
if: github.event_name != 'pull_request'
97+
run: pdm lock -d
8098

81-
test-submit-dry:
82-
runs-on: ubuntu-latest
83-
steps:
84-
- name: Check out source code
85-
uses: actions/checkout@v4
86-
with:
87-
fetch-depth: 0
88-
path: chipflow-lib
89-
- name: Check out chipflow-examples
90-
uses: actions/checkout@v4
91-
with:
92-
repository: ChipFlow/chipflow-examples
93-
fetch-depth: 0
94-
path: chipflow-examples
99+
- name: Relock PDM (PR)
100+
working-directory: ./chipflow-examples
101+
if: github.event_name == 'pull_request'
102+
run: pdm lock -d --override overrides.txt
95103

96-
- name: Set up PDM
97-
uses: pdm-project/setup-pdm@v4
98-
with:
99-
python-version: "3.10"
100-
cache: true
101-
cache-dependency-path: "./**/pyproject.toml"
102104
- name: Install dependencies
103105
working-directory: ./chipflow-examples
104106
run: |
105107
pdm install
106-
pdm run python -m ensurepip
107-
pdm run python -m pip install -e ../chipflow-lib
108+
108109
- name: Run tests
109110
working-directory: ./chipflow-examples
110111
run: |
111112
pdm test
113+
114+
- name: Submit build ${{ env.is_dry }}
115+
working-directory: ./chipflow-examples/minimal
116+
run: |
112117
pdm run chipflow pin lock
113-
pdm run chipflow silicon submit --dry-run
118+
pdm run chipflow silicon submit --wait $DRY
119+
env:
120+
CHIPFLOW_API_KEY: ${{ secrets.CHIPFLOW_API_KEY}}

.github/workflows/preview-docs.yml

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,21 @@ jobs:
2020
python-version: 3.12
2121
cache: true
2222

23+
- name: Generate overrides to use current branch if PR
24+
if: github.event_name == 'pull_request'
25+
run: |
26+
pdm run tools/gen_overrides.py ${{github.head_ref}} > overrides.txt
27+
echo "Generated overrides:"
28+
cat overrides.txt
29+
30+
- name: Relock PDM
31+
if: github.event_name != 'pull_request'
32+
run: pdm lock -d
33+
34+
- name: Relock PDM (PR)
35+
if: github.event_name == 'pull_request'
36+
run: pdm lock -d --override overrides.txt
37+
2338
- name: Install dependencies
2439
run: pdm install
2540

tools/gen_overrides.py

Lines changed: 54 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
# gen-overrides.py
2+
# /// script
3+
# requires-python = ">=3.10"
4+
# dependencies = [
5+
# "pyproject-parser",
6+
# "requirements-parser",
7+
# ]
8+
# ///
9+
# SPDX-License-Identifier: BSD-2-Clause
10+
import os
11+
import subprocess
12+
import sys
13+
import urllib
14+
from pathlib import Path
15+
16+
from pyproject_parser import PyProject
17+
from requirements.requirement import Requirement
18+
19+
20+
rootdir = Path(os.environ["PDM_PROJECT_ROOT"])
21+
22+
def get_branch(repo_dir):
23+
"""Get the current git branch"""
24+
return subprocess.check_output(['git', 'branch', '--show-current'], text=True).strip()
25+
26+
def get_remote_branch(repo, branch):
27+
return subprocess.call(
28+
['git', 'ls-remote', '--exit-code', '--heads', repo, f'refs/heads/{branch}'],
29+
stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL) == 0
30+
31+
def gen_overrides():
32+
if len(sys.argv) > 1:
33+
branch = sys.argv[1]
34+
if branch.startswith("refs/heads/"):
35+
branch = branch[11:]
36+
else:
37+
branch = get_branch(rootdir)
38+
prj = PyProject.load(rootdir / "pyproject.toml")
39+
reqs = prj.project['dependencies']
40+
git_reqs = [r for r in reqs if r.url and r.url.startswith('git+')]
41+
for r in git_reqs:
42+
parts = urllib.parse.urlparse(r.url, allow_fragments=True)
43+
# remove any branches that might already be there
44+
base = parts.path.rsplit(sep="@",maxsplit=1)[0]
45+
clone_url = urllib.parse.urlunparse(parts._replace(path=base, scheme="https"))
46+
if get_remote_branch(clone_url, branch):
47+
path = f"{parts.path}@{branch}"
48+
else:
49+
path = parts.path
50+
r.url = urllib.parse.urlunparse(parts._replace(path=path))
51+
print(str(r))
52+
53+
if __name__ == "__main__":
54+
gen_overrides()

tools/license_check.sh

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
#!/bin/bash
2+
docker run --platform=linux/amd64 -v ${PWD}:/src ghcr.io/google/addlicense -v -check -l BSD-2-Clause -c "ChipFlow" -s=only -ignore **/__init__.py **/*.py
3+
4+

0 commit comments

Comments
 (0)