summaryrefslogtreecommitdiffstats
path: root/maintainers/scripts/update.py
diff options
context:
space:
mode:
authorJan Tojnar <jtojnar@gmail.com>2021-03-21 04:23:04 +0100
committerJan Tojnar <jtojnar@gmail.com>2021-05-05 22:42:30 +0200
commit416cd66e296d9bd726fc5fe426bcd2bdf7922117 (patch)
tree63a4fe2dcab4310d9774d93b1358040842f4b7e5 /maintainers/scripts/update.py
parenta7afb378d5c2928d7ef7574eb30c74970f15f2cc (diff)
maintainers/scripts/update.nix: Ensure the worktree is clean
When an update script fails, it might still modify the source tree. These changes would then be committed in the next update attempt. Let’s make sure the worktree is clean before updating to avoid that.
Diffstat (limited to 'maintainers/scripts/update.py')
-rw-r--r--maintainers/scripts/update.py3
1 files changed, 3 insertions, 0 deletions
diff --git a/maintainers/scripts/update.py b/maintainers/scripts/update.py
index 8cc2bcbd67c9..eb26a472e926 100644
--- a/maintainers/scripts/update.py
+++ b/maintainers/scripts/update.py
@@ -39,6 +39,9 @@ async def run_update_script(nixpkgs_root: str, merge_lock: asyncio.Lock, temp_di
if temp_dir is not None:
worktree, _branch = temp_dir
+ # Ensure the worktree is clean before update.
+ await check_subprocess('git', 'reset', '--hard', '--quiet', 'HEAD', cwd=worktree)
+
# Update scripts can use $(dirname $0) to get their location but we want to run
# their clones in the git worktree, not in the main nixpkgs repo.
update_script_command = map(lambda arg: re.sub(r'^{0}'.format(re.escape(nixpkgs_root)), worktree, arg), update_script_command)