diff options
author | jaseg <git@jaseg.de> | 2023-03-19 23:41:16 +0100 |
---|---|---|
committer | jaseg <git@jaseg.de> | 2023-03-19 23:41:16 +0100 |
commit | 98bce2478f022a2eb15c3df909c7825ae050f3bf (patch) | |
tree | 41b113f606ebd5eec72a0f133d8297d0a0454968 /deploy.py | |
parent | aa54c194ff5e3fa2f42909f4eb5c27d1b1366dc4 (diff) | |
parent | 41e6fd94a73162ecfd3afdc30879dfeac509cfb5 (diff) | |
download | blog-98bce2478f022a2eb15c3df909c7825ae050f3bf.tar.gz blog-98bce2478f022a2eb15c3df909c7825ae050f3bf.tar.bz2 blog-98bce2478f022a2eb15c3df909c7825ae050f3bf.zip |
deploy.py auto-commit
Diffstat (limited to 'deploy.py')
-rw-r--r-- | deploy.py | 29 |
1 files changed, 0 insertions, 29 deletions
diff --git a/deploy.py b/deploy.py deleted file mode 100644 index c960fbc..0000000 --- a/deploy.py +++ /dev/null @@ -1,29 +0,0 @@ -#!/usr/bin/env python3 - -import os -import tempfile -import subprocess -from pathlib import Path - -if __name__ == '__main__': - with tempfile.TemporaryDirectory() as tmpdir: - - current_branch = subprocess.run(['git', 'symbolic-ref', '-q', 'HEAD'], check=False, capture_output=True).stdout.strip() - if current_branch == 'refs/heads/deploy': - raise SystemError('This script cannot be run from the deploy branch (run from main instead)') - - subprocess.run(['git', 'worktree', 'add', '--detach', tmpdir], check=True) - try: - env = dict(os.environ) - env['PATH'] = f'{Path("hack").absolute()}:{env["PATH"]}' - subprocess.run(['hugo'], cwd=tmpdir, check=True, env=env) - subprocess.run(['git', 'add', '--force', 'public'], cwd=tmpdir, check=True) - write_tree = subprocess.run(['git', 'write-tree', '--prefix=public/'], cwd=tmpdir, check=True, capture_output=True) - tree = write_tree.stdout.strip() - - commit = subprocess.run(['git', 'commit-tree', '-p', 'HEAD', '-p', 'refs/heads/deploy', '-m', 'deploy.py auto-commit', tree], cwd=tmpdir, check=True, capture_output=True).stdout.strip() - subprocess.run(['git', 'update-ref', '-m', f'deploy.sh update deploy branch to {commit}', 'refs/heads/deploy', commit], cwd=tmpdir, check=True) - - subprocess.run(['git', 'push', 'git@git.jaseg.de:blog.git', 'deploy'], cwd=tmpdir, check=True) - finally: - subprocess.run(['git', 'worktree', 'remove', '-f', tmpdir], check=True) |