Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Make "Test with:" support branches also #198

Open
axel-h opened this issue Feb 18, 2022 · 3 comments
Open

Make "Test with:" support branches also #198

axel-h opened this issue Feb 18, 2022 · 3 comments
Labels
enhancement New feature or request

Comments

@axel-h
Copy link
Member

axel-h commented Feb 18, 2022

When working on forks and feature-branches, having "Test with:" support branches also besides just PRs would be nice. That avoids having to create PRs for every affected repo during the development cycle, but still allows using the github CI. The short syntax could be <org>/<repo>@<branch>, the long syntax is https://github.com/<org>/<repo>/tree/<branch>.

@axel-h axel-h added the enhancement New feature or request label Feb 18, 2022
@lsf37
Copy link
Member

lsf37 commented Feb 18, 2022

That is probably easy to add, and would be useful, yes.

Does this add any new security considerations? So far, a PR must have been raised for the target to be included. Pretty much anyone can do that (apart from blocked users). So the new scope is someone pointing to some branch in a different org they control, but if they are a first-time contributor the tests have to be manually approved first anyway, so I think this is fine.

@axel-h
Copy link
Member Author

axel-h commented Jul 11, 2022

Looking at https://github.com/seL4/ci-actions/pull/217/files, this could also support hashes. This feature might come for free if this is implemented with the standard git tools. Otherwise is should implement the same behavior, that matching a branch name take preference over matching a commit id.

@lsf37
Copy link
Member

lsf37 commented Jul 11, 2022

It'll not be entirely free, because constructing the ref for a PR is a bit special, but it could be done relatively easily. The relevant lines in scripts/fetch-extra-prs.sh are these:

REF="refs/pull/${ID}/head"
cd $(repo-util path ${REPO})
echo "Fetching ${REF} from ${REPO_PATH}"
git fetch -q --depth 1 ${URL} ${REF}:${REF}
git checkout -q ${REF}

We'd need to do something similar as in fetch-branch.sh to distinguish pulling a sha from pulling a ref:

elif [ -n "${GITHUB_SHA}" ]
then
REF=${GITHUB_SHA}
FETCH=${REF}
# if nothing better is available, use GITHUB_REF
else
REF=${GITHUB_REF}
FETCH=${REF}:${REF}
fi
echo "Fetching ${REF} from ${REPO_PATH}"
git fetch -q --depth 1 ${URL} ${FETCH}
git checkout -q ${REF}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants