add(ci): Check that dependencies have all been published to crates.io on release PRs (#8992)
* Adds a test to check for crates in the Cargo.lock file that are being pulled in from a git source. * add `check_no_git_refs_in_cargo_lock` to CI * try skip instead of exclude --------- Co-authored-by: Alfredo Garcia <oxarbitrage@gmail.com>
This commit is contained in:
parent
0af0742613
commit
8cfb61f52c
|
@ -197,3 +197,12 @@ jobs:
|
|||
# If there is already an open issue with this label, any failures become comments on that issue.
|
||||
always-create-new-issue: false
|
||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
run-check-no-git-refs:
|
||||
if: contains(github.event.pull_request.labels.*.name, 'A-release')
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Run check_no_git_refs_in_cargo_lock
|
||||
run: |
|
||||
docker pull ${{ vars.GAR_BASE }}/${{ vars.CI_IMAGE_NAME }}@${{ inputs.image_digest }}
|
||||
docker run --tty -e NETWORK -e RUN_CHECK_NO_GIT_REFS=1 ${{ vars.GAR_BASE }}/${{ vars.CI_IMAGE_NAME }}@${{ inputs.image_digest }}
|
||||
|
|
|
@ -224,12 +224,16 @@ case "$1" in
|
|||
if [[ "${RUN_ALL_TESTS}" -eq "1" ]]; then
|
||||
# Run unit, basic acceptance tests, and ignored tests, only showing command output if the test fails.
|
||||
# If the lightwalletd environmental variables are set, we will also run those tests.
|
||||
exec cargo test --locked --release --features "${ENTRYPOINT_FEATURES}" --workspace -- --nocapture --include-ignored
|
||||
exec cargo test --locked --release --features "${ENTRYPOINT_FEATURES}" --workspace -- --nocapture --include-ignored --skip check_no_git_refs_in_cargo_lock
|
||||
|
||||
elif [[ "${RUN_ALL_EXPERIMENTAL_TESTS}" -eq "1" ]]; then
|
||||
# Run unit, basic acceptance tests, and ignored tests with experimental features.
|
||||
# If the lightwalletd environmental variables are set, we will also run those tests.
|
||||
exec cargo test --locked --release --features "${ENTRYPOINT_FEATURES_EXPERIMENTAL}" --workspace -- --nocapture --include-ignored
|
||||
exec cargo test --locked --release --features "${ENTRYPOINT_FEATURES_EXPERIMENTAL}" --workspace -- --nocapture --include-ignored --skip check_no_git_refs_in_cargo_lock
|
||||
|
||||
elif [[ "${RUN_CHECK_NO_GIT_REFS}" -eq "1" ]]; then
|
||||
# Run the check_no_git_refs_in_cargo_lock test.
|
||||
exec cargo test --locked --release --features "${ENTRYPOINT_FEATURES}" --workspace -- --nocapture --include-ignored check_no_git_refs_in_cargo_lock
|
||||
|
||||
elif [[ "${TEST_FAKE_ACTIVATION_HEIGHTS}" -eq "1" ]]; then
|
||||
# Run state tests with fake activation heights.
|
||||
|
|
|
@ -3538,3 +3538,15 @@ async fn nu6_funding_streams_and_coinbase_balance() -> Result<()> {
|
|||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Check that Zebra does not depend on any crates from git sources.
|
||||
#[test]
|
||||
#[ignore]
|
||||
fn check_no_git_refs_in_cargo_lock() {
|
||||
let cargo_lock_contents =
|
||||
fs::read_to_string("../Cargo.lock").expect("should have Cargo.lock file in root dir");
|
||||
|
||||
if cargo_lock_contents.contains(r#"source = "git+"#) {
|
||||
panic!("Cargo.lock includes git sources")
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue