Compare commits
25 Commits
Author | SHA1 | Date | |
---|---|---|---|
108c1aae2f | |||
b82184b9e7 | |||
b6a43c3f3b | |||
18b692a62e | |||
c2d6f6b259 | |||
60b90ec9e5 | |||
1fc30ae3e1 | |||
dfa6bfe926 | |||
ed3f58436b | |||
68f7b429f7 | |||
e5030902c7 | |||
60f01d9dd8 | |||
bd429393a5 | |||
9e3ffd6230 | |||
bdc71f15c1 | |||
c3398ef4e5 | |||
9b33f1152b | |||
dc1f2a92cc | |||
e9ae52bb60 | |||
982887ab85 | |||
19e934e873 | |||
8604d695c6 | |||
a55295829f | |||
4181d597a8 | |||
c4869fb0cd |
53
.gitea/workflows/deploy.yaml
Normal file
53
.gitea/workflows/deploy.yaml
Normal file
@ -0,0 +1,53 @@
|
||||
name: pyzebra CI/CD pipeline
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
tags:
|
||||
- '*'
|
||||
|
||||
env:
|
||||
CONDA: /opt/miniforge3
|
||||
|
||||
jobs:
|
||||
prepare:
|
||||
runs-on: pyzebra
|
||||
steps:
|
||||
- run: $CONDA/bin/conda config --add channels conda-forge
|
||||
- run: $CONDA/bin/conda config --set solver libmamba
|
||||
|
||||
test-env:
|
||||
runs-on: pyzebra
|
||||
needs: prepare
|
||||
if: github.ref == 'refs/heads/main'
|
||||
env:
|
||||
BUILD_DIR: ${{ runner.temp }}/conda_build
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
- run: $CONDA/bin/conda build --no-anaconda-upload --output-folder $BUILD_DIR ./conda-recipe
|
||||
- run: $CONDA/bin/conda remove --name test --all --keep-env -y
|
||||
- run: $CONDA/bin/conda install --name test --channel $BUILD_DIR python=3.8 pyzebra -y
|
||||
- run: sudo systemctl restart pyzebra-test.service
|
||||
|
||||
prod-env:
|
||||
runs-on: pyzebra
|
||||
needs: prepare
|
||||
if: startsWith(github.ref, 'refs/tags/')
|
||||
env:
|
||||
BUILD_DIR: ${{ runner.temp }}/conda_build
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
- run: $CONDA/bin/conda build --token ${{ secrets.ANACONDA_TOKEN }} --output-folder $BUILD_DIR ./conda-recipe
|
||||
- run: $CONDA/bin/conda remove --name prod --all --keep-env -y
|
||||
- run: $CONDA/bin/conda install --name prod --channel $BUILD_DIR python=3.8 pyzebra -y
|
||||
- run: sudo systemctl restart pyzebra-prod.service
|
||||
|
||||
cleanup:
|
||||
runs-on: pyzebra
|
||||
needs: [test-env, prod-env]
|
||||
if: always()
|
||||
steps:
|
||||
- run: $CONDA/bin/conda build purge-all
|
@ -1,43 +0,0 @@
|
||||
stages:
|
||||
- build-and-publish
|
||||
- deploy
|
||||
|
||||
build-and-publish:
|
||||
stage: build-and-publish
|
||||
rules:
|
||||
- if: $CI_COMMIT_TAG
|
||||
script:
|
||||
- source /opt/miniconda3/etc/profile.d/conda.sh
|
||||
- conda config --add channels conda-forge
|
||||
- conda config --set solver libmamba
|
||||
- conda config --set anaconda_upload yes
|
||||
- conda build --token $ANACONDA_TOKEN /opt/pyzebra/conda-recipe
|
||||
|
||||
deploy-test:
|
||||
stage: deploy
|
||||
environment: testing
|
||||
rules:
|
||||
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
|
||||
script:
|
||||
- cd /opt/pyzebra
|
||||
- git pull origin main --tags
|
||||
- source /opt/miniconda3/etc/profile.d/conda.sh
|
||||
- conda activate test
|
||||
- conda build ./conda-recipe
|
||||
- conda install --use-local --only-deps pyzebra -y
|
||||
- conda build purge-all
|
||||
- sudo systemctl restart pyzebra-test.service
|
||||
|
||||
deploy-prod:
|
||||
stage: deploy
|
||||
environment: production
|
||||
needs: ["build-and-publish"]
|
||||
rules:
|
||||
- if: $CI_COMMIT_TAG
|
||||
when: delayed
|
||||
start_in: 5 seconds
|
||||
script:
|
||||
- source /opt/miniconda3/etc/profile.d/conda.sh
|
||||
- conda activate prod
|
||||
- conda update pyzebra -y
|
||||
- sudo systemctl restart pyzebra-prod.service
|
@ -28,7 +28,7 @@ requirements:
|
||||
|
||||
|
||||
about:
|
||||
home: https://github.com/paulscherrerinstitute/pyzebra
|
||||
home: https://gitlab.psi.ch/zebra/pyzebra
|
||||
summary: {{ data['description'] }}
|
||||
license: GNU GPLv3
|
||||
license_file: LICENSE
|
||||
|
@ -7,18 +7,19 @@ import subprocess
|
||||
|
||||
|
||||
def main():
|
||||
default_branch = "main"
|
||||
branch = subprocess.check_output("git rev-parse --abbrev-ref HEAD", shell=True).decode().strip()
|
||||
if branch != "main":
|
||||
print("Aborting, not on 'main' branch.")
|
||||
if branch != default_branch:
|
||||
print(f"Aborting, not on '{default_branch}' branch.")
|
||||
return
|
||||
|
||||
filepath = "pyzebra/__init__.py"
|
||||
version_filepath = os.path.join(os.path.basename(os.path.dirname(__file__)), "__init__.py")
|
||||
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument("level", type=str, choices=["patch", "minor", "major"])
|
||||
args = parser.parse_args()
|
||||
|
||||
with open(filepath) as f:
|
||||
with open(version_filepath) as f:
|
||||
file_content = f.read()
|
||||
|
||||
version = re.search(r'__version__ = "(.*?)"', file_content).group(1)
|
||||
@ -36,11 +37,12 @@ def main():
|
||||
|
||||
new_version = f"{major}.{minor}.{patch}"
|
||||
|
||||
with open(filepath, "w") as f:
|
||||
with open(version_filepath, "w") as f:
|
||||
f.write(re.sub(r'__version__ = "(.*?)"', f'__version__ = "{new_version}"', file_content))
|
||||
|
||||
os.system(f"git commit {filepath} -m 'Updating for version {new_version}'")
|
||||
os.system(f"git commit {version_filepath} -m 'Updating for version {new_version}'")
|
||||
os.system(f"git tag -a {new_version} -m 'Release {new_version}'")
|
||||
os.system("git push --follow-tags")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
@ -6,4 +6,4 @@ from pyzebra.sxtal_refgen import *
|
||||
from pyzebra.utils import *
|
||||
from pyzebra.xtal import *
|
||||
|
||||
__version__ = "0.7.9"
|
||||
__version__ = "0.7.11"
|
||||
|
@ -1,11 +0,0 @@
|
||||
[Unit]
|
||||
Description=pyzebra-test web server
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
User=pyzebra
|
||||
ExecStart=/bin/bash /usr/local/sbin/pyzebra-test.sh
|
||||
Restart=always
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
@ -1,4 +0,0 @@
|
||||
source /opt/miniconda3/etc/profile.d/conda.sh
|
||||
|
||||
conda activate test
|
||||
python /opt/pyzebra/pyzebra/app/cli.py --port=5010 --allow-websocket-origin=pyzebra.psi.ch:5010 --args --spind-path=/opt/spind
|
@ -1,10 +0,0 @@
|
||||
[Unit]
|
||||
Description=pyzebra web server
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
ExecStart=/bin/bash /usr/local/sbin/pyzebra.sh
|
||||
Restart=always
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
@ -1,4 +0,0 @@
|
||||
source /opt/miniconda3/etc/profile.d/conda.sh
|
||||
|
||||
conda activate prod
|
||||
pyzebra --port=80 --allow-websocket-origin=pyzebra.psi.ch:80 --args --spind-path=/opt/spind
|
Loading…
x
Reference in New Issue
Block a user