update josh scripts

- support pulling specific commit
- make rust-version update a separate commit to avoid confusing josh
- after pushing, check that we have a clear round-trip
This commit is contained in:
Ralf Jung 2022-11-17 12:00:33 +01:00
parent 3de7c2834f
commit da4eb351bd

View File

@ -48,10 +48,10 @@ Update and activate the rustup toolchain 'miri' to the commit given in the
`rustup-toolchain-install-master` must be installed for this to work. Any extra `rustup-toolchain-install-master` must be installed for this to work. Any extra
flags are passed to `rustup-toolchain-install-master`. flags are passed to `rustup-toolchain-install-master`.
./miri rustc-pull: ./miri rustc-pull <commit>:
Pull and merge Miri changes from the rustc repo. The fetched commit is stored in Pull and merge Miri changes from the rustc repo. Defaults to fetching the latest
the `rust-version` file, so the next `./miri toolchain` will install the rustc rustc commit. The fetched commit is stored in the `rust-version` file, so the
we just pulled. next `./miri toolchain` will install the rustc that just got pulled.
./miri rustc-push <github user> <branch>: ./miri rustc-push <github user> <branch>:
Push Miri changes back to the rustc repo. This will pull a copy of the rustc Push Miri changes back to the rustc repo. This will pull a copy of the rustc
@ -113,18 +113,17 @@ toolchain)
;; ;;
rustc-pull) rustc-pull)
cd "$MIRIDIR" cd "$MIRIDIR"
FETCH_COMMIT=$(git ls-remote https://github.com/rust-lang/rust/ HEAD | cut -f 1) FETCH_COMMIT="$1"
# We can't pull from a commit with josh if [ -z "$FETCH_COMMIT" ]; then
# (https://github.com/josh-project/josh/issues/1034), so we just hope that FETCH_COMMIT=$(git ls-remote https://github.com/rust-lang/rust/ HEAD | cut -f 1)
# nothing gets merged into rustc *during* this pull.
git fetch http://localhost:8000/rust-lang/rust.git$JOSH_FILTER.git master
# Just verify that `master` didn't move.
if [[ $FETCH_COMMIT != $(git ls-remote https://github.com/rust-lang/rust/ HEAD | cut -f 1) ]]; then
echo "Looks like something got merged into Rust *while we were pulling*. Aborting. Please try again."
fi fi
echo "$FETCH_COMMIT" > rust-version # do this *before* merging as merging will fail in case of conflicts # Update rust-version file. As a separate commit, since making it part of
# the merge has confused the heck out of josh in the past.
echo "$FETCH_COMMIT" > rust-version
git commit rust-version -m "Preparing for merge from rustc"
# Fetch given rustc commit and note down which one that was
git fetch http://localhost:8000/rust-lang/rust.git@$FETCH_COMMIT$JOSH_FILTER.git
git merge FETCH_HEAD --no-ff -m "Merge from rustc" git merge FETCH_HEAD --no-ff -m "Merge from rustc"
git commit rust-version --amend -m "Merge from rustc"
exit 0 exit 0
;; ;;
rustc-push) rustc-push)
@ -157,11 +156,22 @@ rustc-push)
fi fi
git fetch https://github.com/rust-lang/rust $BASE git fetch https://github.com/rust-lang/rust $BASE
git push https://github.com/$USER/rust $BASE:refs/heads/$BRANCH -f git push https://github.com/$USER/rust $BASE:refs/heads/$BRANCH -f
echo
# Do the actual push. # Do the actual push.
cd "$MIRIDIR" cd "$MIRIDIR"
echo "Pushing Miri changes..." echo "Pushing Miri changes..."
git push http://localhost:8000/$USER/rust.git$JOSH_FILTER.git HEAD:$BRANCH git push http://localhost:8000/$USER/rust.git$JOSH_FILTER.git HEAD:$BRANCH
exit 0 # Do a round-trip check to make sure the push worked as expected.
echo
git fetch http://localhost:8000/$USER/rust.git@$JOSH_FILTER.git $BRANCH &>/dev/null
if [[ $(git rev-parse HEAD) != $(git rev-parse FETCH_HEAD) ]]; then
echo "ERROR: Josh created a non-roundtrip push! Do NOT merge this into rustc!"
exit 1
else
echo "Confirmed that the push round-trips back to Miri properly. Please create a rustc PR:"
echo " https://github.com/$USER/rust/pull/new/$BRANCH"
exit 0
fi
;; ;;
many-seeds) many-seeds)
for SEED in $({ echo obase=16; seq 0 255; } | bc); do for SEED in $({ echo obase=16; seq 0 255; } | bc); do