From: Ismaƫl Bouya Date: Sat, 30 Nov 2019 19:05:11 +0000 (+0100) Subject: Add normalesup website to CI X-Git-Url: https://git.immae.eu/?p=perso%2FImmae%2FConfig%2FNix.git;a=commitdiff_plain;h=573e17101354432a4167c21d832bb2873d6ad220 Add normalesup website to CI --- diff --git a/modules/private/buildbot/projects/immaeEu/__init__.py b/modules/private/buildbot/projects/immaeEu/__init__.py index f611a6f..437af72 100644 --- a/modules/private/buildbot/projects/immaeEu/__init__.py +++ b/modules/private/buildbot/projects/immaeEu/__init__.py @@ -12,11 +12,13 @@ class E(): SOCKET = "unix:/run/buildbot/{}.sock".format(PROJECT) PB_SOCKET = "unix:address=/run/buildbot/{}_pb.sock".format(PROJECT) RELEASE_PATH = "/var/lib/buildbot/outputs/immaeEu" - GIT_URL = "gitolite@git.immae.eu:perso/Immae/Sites/Blog" SSH_KEY_PATH = "/var/lib/buildbot/buildbot_key" SSH_HOST_KEY = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIFbhFTl2A2RJn5L51yxJM4XfCS2ZaiSX/jo9jFSdghF" XMPP_RECIPIENTS = os.environ["BUILDBOT_XMPP_RECIPIENTS"].split(" ") + IMMAE_EU_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Sites/Blog" + NORMALESUP_GIT_URL = "gitolite@git.immae.eu:perso/Immae/Projets/Sites/Normalesup" + # master.cfg SECRETS_FILE = os.getcwd() + "/secrets" LDAP_URL = "ldaps://ldap.immae.eu:636" @@ -51,23 +53,25 @@ def configure(c): c['workers'].append(worker.LocalWorker("generic-worker-immae-eu")) c['schedulers'].append(hook_scheduler("ImmaeEu", timer=1)) - c['schedulers'].append(force_scheduler("force_immae_eu", ["ImmaeEu_build"])) + c['schedulers'].append(hook_scheduler("Normalesup", timer=1)) + c['schedulers'].append(force_scheduler("force_immae_eu", ["ImmaeEu_build", "Normalesup_build"])) - c['builders'].append(factory()) + c['builders'].append(immae_eu_factory()) + c['builders'].append(normalesup_factory()) c['services'].append(SlackStatusPush( name="slack_status_immae_eu_project", - builders=["ImmaeEu_build"], + builders=["ImmaeEu_build", "Normalesup_build"], serverUrl=open(E.SECRETS_FILE + "/slack_webhook", "r").read().rstrip())) c['services'].append(XMPPStatusPush( name="xmpp_status_immae_eu_project", - builders=["ImmaeEu_build"], + builders=["ImmaeEu_build", "Normalesup_build"], recipients=E.XMPP_RECIPIENTS, password=open(E.SECRETS_FILE + "/notify_xmpp_password", "r").read().rstrip())) -def factory(): +def immae_eu_factory(): factory = util.BuildFactory() - factory.addStep(steps.Git(logEnviron=False, repourl=E.GIT_URL, + factory.addStep(steps.Git(logEnviron=False, repourl=E.IMMAE_EU_GIT_URL, submodules=True, sshPrivateKey=open(E.SSH_KEY_PATH).read().rstrip(), sshHostKey=E.SSH_HOST_KEY, mode="full", method="copy")) factory.addStep(steps.ShellCommand(name="build website", @@ -80,3 +84,25 @@ def factory(): factory.addStep(steps.MasterShellCommand(command="chmod -R a+rX {}".format(E.RELEASE_PATH))) return util.BuilderConfig(name="ImmaeEu_build", workernames=["generic-worker-immae-eu"], factory=factory) + +def normalesup_factory(): + factory = util.BuildFactory() + factory.addStep(steps.Git(logEnviron=False, repourl=E.NORMALESUP_GIT_URL, + submodules=True, sshPrivateKey=open(E.SSH_KEY_PATH).read().rstrip(), + sshHostKey=E.SSH_HOST_KEY, mode="full", method="copy")) + factory.addStep(steps.ShellCommand(name="build website", + logEnviron=False, haltOnFailure=True, workdir="source", + command=["make", "build"])) + factory.addStep(steps.ShellCommand(name="give read access to all files", + logEnviron=False, haltOnFailure=True, workdir="source", + command="chmod -R a+rX build")) + factory.addStep(steps.ShellCommand(name="synchronize with phare", + logEnviron=False, haltOnFailure=True, workdir="source", + command=[ + "rsync", "-av", "--delete", + "-e", "ssh -i {} -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o CheckHostIP=no".format(E.SSH_KEY_PATH), + "build/", + "bouya@phare.normalesup.org:" + ])) + + return util.BuilderConfig(name="Normalesup_build", workernames=["generic-worker-immae-eu"], factory=factory)