]> git.immae.eu Git - perso/Immae/Config/Nix.git/commitdiff
Add normalesup website to CI
authorIsmaël Bouya <ismael.bouya@normalesup.org>
Sat, 30 Nov 2019 19:05:11 +0000 (20:05 +0100)
committerIsmaël Bouya <ismael.bouya@normalesup.org>
Sat, 30 Nov 2019 19:05:11 +0000 (20:05 +0100)
modules/private/buildbot/projects/immaeEu/__init__.py

index f611a6f9c436f109305583760720d9507d373159..437af723f7f761b182aa4da10017d0048cf429b1 100644 (file)
@@ -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)