X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=modules%2Fprivate%2Fbuildbot%2Fprojects%2Fdenise%2F__init__.py;h=2a19ef57c9627a9b53370b24b424a25d7cea32a9;hb=ecd9a3060bdcc4309e4fad6c046b72b880618774;hp=e91e17a4a2c392c0ceece592546c3283a3cbbf66;hpb=31ed973b234259d3487292cd58e1b4289b4acb11;p=perso%2FImmae%2FConfig%2FNix.git diff --git a/modules/private/buildbot/projects/denise/__init__.py b/modules/private/buildbot/projects/denise/__init__.py index e91e17a..2a19ef5 100644 --- a/modules/private/buildbot/projects/denise/__init__.py +++ b/modules/private/buildbot/projects/denise/__init__.py @@ -15,6 +15,7 @@ class E(): SSH_HOST_KEY = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIFbhFTl2A2RJn5L51yxJM4XfCS2ZaiSX/jo9jFSdghF" OMS_RELEASE_PATH = "/var/lib/buildbot/outputs/denise/oms" + OMS_BETA_PATH = "/var/lib/buildbot/outputs/denise/oms_beta" OMS_GIT_URL = "gitolite@git.immae.eu:perso/Denise/oms" AVENTURIERS_RELEASE_PATH = "/var/lib/buildbot/outputs/denise/aventuriers" @@ -63,22 +64,51 @@ def configure(c): c['builders'].append(denise_aventuriers_factory()) def denise_oms_factory(): + @util.renderer + def oms_run_path(props): + if props.hasProperty("branch") and len(props["branch"]) > 0 and props["branch"] == "master": + return "/run/denise_oms/gunicorn.pid" + else: + return "/run/denise_oms_beta/gunicorn.pid" + + @util.renderer + def oms_systemd_service(props): + if props.hasProperty("branch") and len(props["branch"]) > 0 and props["branch"] == "master": + return "denise-oms" + else: + return "denise-oms-beta" + + @util.renderer + def oms_url(props): + if props.hasProperty("branch") and len(props["branch"]) > 0 and props["branch"] == "master": + return "https://oms.syanni.eu" + else: + return "https://beta.oms.syanni.eu" + + @util.renderer + def oms_path(props): + if props.hasProperty("branch") and len(props["branch"]) > 0 and props["branch"] == "master": + return E.OMS_RELEASE_PATH + else: + return E.OMS_BETA_PATH + factory = util.BuildFactory() factory.addStep(steps.Git(logEnviron=False, repourl=E.OMS_GIT_URL, submodules=True, sshPrivateKey=open(E.SSH_KEY_PATH).read().rstrip(), sshHostKey=E.SSH_HOST_KEY, mode="full", method="copy")) - factory.addStep(steps.MasterShellCommand(command="rm -rf {}".format(E.OMS_RELEASE_PATH))) + factory.addStep(steps.MasterShellCommand(command=util.Interpolate("rm -rf %(kw:oms_path)s", oms_path=oms_path))) factory.addStep(steps.DirectoryUpload(workersrc="../source", - masterdest=E.OMS_RELEASE_PATH, - url="https://oms.syanni.eu")) - factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.OMS_RELEASE_PATH))) - factory.addStep(steps.MasterShellCommand(command="kill $(cat /run/denise_oms/gunicorn.pid)")) + masterdest=oms_path, + url=oms_url)) + factory.addStep(steps.MasterShellCommand(command=util.Interpolate("chmod -R a+rX %(kw:oms_path)s", oms_path=oms_path))) + factory.addStep(steps.MasterShellCommand(command=util.Interpolate("/run/wrappers/bin/sudo systemctl restart %(kw:oms_service)s.service", oms_service=oms_systemd_service))) return util.BuilderConfig(name="DeniseOMS_build", workernames=["generic-worker-denise"], factory=factory) def denise_aventuriers_factory(): path_env = { - "PATH": os.environ["BUILDBOT_PATH_Aventuriers"] + ":${PATH}" + "PATH": os.environ["BUILDBOT_PATH_Aventuriers"] + ":${PATH}", + "TZ": "Europe/Paris", } factory = util.BuildFactory()