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"
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",
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)