Compare commits

...

33 Commits

Author SHA1 Message Date
3ed78b7570
Downgrade Automat
- python 3.6 compatiblity
2024-10-20 16:52:35 +08:00
fe9ea06316
Typos 2024-03-29 18:14:27 +08:00
9e28a6781d
Typos 2024-03-29 18:09:58 +08:00
4bfe5f2be8
Typos 2024-03-29 18:08:09 +08:00
1ac083f22d
Typo, missing commas 2024-03-29 17:58:45 +08:00
b6cbbed64e
Typo 2024-03-29 17:01:37 +08:00
ec69e113bf
Add signing and environment variables 2024-03-29 16:46:07 +08:00
970e2f1f0f
Update deps 2024-03-06 07:57:44 +08:00
d0f4dcb584
Update bionic deps 2024-03-06 07:14:31 +08:00
f0be34e191
Change deps versions
- pyopenssl, cryptography, buildbot worker
2024-03-06 00:16:05 +08:00
180854160f
Change cryptography and pyopenssl versions 2024-03-05 19:17:23 +08:00
bba9168f28
Downgrade python cryptography package 2024-03-05 13:06:56 +08:00
4d613d1c83
Downgrade pyOpenSSL on old ubuntu 2024-03-05 09:16:43 +08:00
8b99da077a
Typo 2024-03-05 07:10:04 +08:00
51fde19747
Fix buildbot deps for old ubuntu 2024-03-04 07:55:46 +08:00
d42e359732
Fix buildbot worker for older ubuntu 2024-03-04 07:09:22 +08:00
cd431f1891
Missing user/group for old buildbot 2024-03-03 23:28:31 +08:00
b62feb681e
Fix buildbot worker TLS for old ubuntu 2024-03-03 22:49:05 +08:00
a4e2b4e249
Partially revert last commit
- looks like BUILDMASTER variable name is hard coded into buildbot
  docker worker code
2024-03-03 21:35:28 +08:00
97c191b8e8
Certificate for PB buildbot connections
- add buildbot.bitmessage.org cert
- change BUILDMASTER to CONNECTIONSTRING
2024-03-03 20:20:36 +08:00
3316e2e9da
Bump build timeout to 2 hours 2023-11-21 07:50:11 +08:00
8eef0e0b5d
For xenial download buildbot_entrypoint.sh only if it's missing 2023-09-19 03:41:40 +03:00
d0ac191f52
Don't throw exception if base dir missing 2022-11-16 11:45:41 +08:00
07b4aeafe0
Repurpose project for job name
- `codebase` isn't really working as expected, and `project` appears to
  be unused in multibuild
2022-10-19 21:12:56 +08:00
0920807624
Attempt to differentiate children with codebase 2022-10-19 20:39:19 +08:00
514c584609
Upload even if tests fail
- we still may want either the build artifact or a video of the tests
  even if tests fail
2022-08-09 23:09:15 +08:00
4bf6fb73b2
Fix upload 2022-08-08 16:20:14 +08:00
f65acbc243
Typo 2022-08-08 11:40:59 +08:00
fa213e5733
Add uploading 2022-08-08 11:28:57 +08:00
85908702c9
Sleep between calling webhooks
Some checks failed
buildbot/multibuild_parent Build done.
buildbot/travis_bionic Build done.
2022-06-02 21:24:21 +08:00
7929e6dd37
Xenial entrypoint
Some checks failed
buildbot/multibuild_parent Build done.
buildbot/travis_bionic Build done.
2022-05-08 12:29:22 +08:00
37956d50af
Support dumb-init on xenial
Some checks failed
buildbot/multibuild_parent Build done.
buildbot/travis_bionic Build done.
2022-05-08 11:21:54 +08:00
ff87ae8ec5
Add xenial and jammy
Some checks failed
buildbot/multibuild_parent Build done.
buildbot/travis_bionic Build done.
2022-04-27 20:02:11 +05:30
3 changed files with 217 additions and 16 deletions

View File

@ -22,3 +22,58 @@ def is_test_script_available(props):
@util.renderer @util.renderer
def isnt_test_script_available(props): def isnt_test_script_available(props):
return not _is_test_script_available(props) return not _is_test_script_available(props)
def _files_to_upload(props):
try:
return ','.join(props.getProperty("files_to_upload", default="").rstrip().split("\n"))
except AttributeError:
return ""
@util.renderer
def files_to_upload(props):
return _files_to_upload(props)
@util.renderer
def has_files_to_upload(props):
return bool(_files_to_upload(props))
@util.renderer
def no_files_to_upload(props):
return not _files_to_upload(props)
def _should_build_sign(props):
if props.getProperty('branch') == 'v0.6' \
and props.getProperty('jobname') == 'android' \
and props.getProperty('repository') in (
'git@github.com:Bitmessage/PyBitmessage.git',
'https://github.com/Bitmessage/PyBitmessage'
):
return True
return False
@util.renderer
def should_build_sign(props):
return _is_build_script_available(props) and _should_build_sign(props)
@util.renderer
def shouldnt_build_sign(props):
return _is_build_script_available(props) and not _should_build_sign(props)
@util.renderer
def build_env(props):
default_envs = {
"BUILDBOT_REPOSITORY": props.getProperty("repository"),
"BUILDBOT_BRANCH": props.getProperty("branch"),
"BUILDBOT_JOBNAME": props.getProperty("jobname")
}
new_envs = {}
if props.getProperty("jobname", default="") == "android":
new_envs = {
"P4A_RELEASE_KEYSTORE": "/var/lib/buildbot/keystore",
"P4A_RELEASE_KEYSTORE_PASSWD": util.Secret("bitmessage-keystore"),
"P4A_RELEASE_KEYALIAS_PASSWD": util.Secret("bitmessage-keystore"),
"P4A_RELEASE_KEYALIAS": "bitmessagetest"
}
if _should_build_sign(props):
return {**default_envs, **new_envs}
return default_envs

View File

@ -3,6 +3,7 @@ from os.path import exists, isfile, islink, join, realpath
import requests import requests
import re import re
from subprocess import Popen, PIPE from subprocess import Popen, PIPE
from time import sleep
request_data = { request_data = {
@ -16,38 +17,104 @@ dockerfile_extra_contents = {}
dockerfile_extra_contents['focal'] = """ dockerfile_extra_contents['focal'] = """
# Buildbot # Buildbot
RUN apt-get install -yq --no-install-suggests --no-install-recommends \ RUN apt-get update -y && apt-get install -yq --no-install-suggests --no-install-recommends \
buildbot-worker git subversion python3-dev libffi-dev python3-setuptools \ python3-buildbot-worker git subversion python3-dev libffi-dev python3-setuptools \
python3-pip dumb-init curl openssh-client wget python3-pip dumb-init curl openssh-client wget
# buildbot entrypoint # buildbot entrypoint
RUN wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/entrypoint.sh RUN wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/entrypoint.sh
RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh
RUN wget -O /usr/local/share/ca-certificates/buildbot-ca.crt https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/buildbot-ca.crt
RUN update-ca-certificates
RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
USER buildbot USER buildbot
ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER" "$WORKERNAME" "$WORKERPASS" ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER:$BUILDMASTER_PORT" "$WORKERNAME" "$WORKERPASS"
""" """
dockerfile_extra_contents['bionic'] = """ dockerfile_extra_contents['bionic'] = """
# Buildbot # Buildbot
RUN apt-get install -yq --no-install-suggests --no-install-recommends \ RUN apt-get update -y && apt-get install -yq --no-install-suggests --no-install-recommends \
buildbot-slave git subversion python3-dev libffi-dev python3-setuptools \ git subversion python3-dev libffi-dev python3-setuptools \
python3-pip dumb-init curl openssh-client wget python3-pip dumb-init curl openssh-client wget python3-wheel \
pkg-config rustc cargo
RUN pip3 install setuptools_rust
RUN pip3 install 'buildbot-worker==3.1.1' \
'cryptography==2.1.4' \
'twisted==17.9.0' \
'Automat==20.2.0' \
'pyopenssl==17.5.0'
RUN groupadd buildbot
RUN useradd -d /var/lib/buildbot -m -g buildbot buildbot
# buildbot entrypoint # buildbot entrypoint
RUN wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/entrypoint.sh RUN wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/entrypoint.sh
RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh
RUN wget -O /usr/local/share/ca-certificates/buildbot-ca.crt https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/buildbot-ca.crt
RUN update-ca-certificates
RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
USER buildbot USER buildbot
ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER" "$WORKERNAME" "$WORKERPASS" ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER:$BUILDMASTER_PORT" "$WORKERNAME" "$WORKERPASS"
"""
dockerfile_extra_contents['jammy'] = """
# Buildbot
RUN apt-get update -y && apt-get install -yq --no-install-suggests --no-install-recommends \
python3-buildbot-worker git subversion python3-dev libffi-dev python3-setuptools \
python3-pip dumb-init curl openssh-client wget
# buildbot entrypoint
RUN wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/entrypoint.sh
RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh
RUN wget -O /usr/local/share/ca-certificates/buildbot-ca.crt https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/buildbot-ca.crt
RUN update-ca-certificates
RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
USER buildbot
ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER:$BUILDMASTER_PORT" "$WORKERNAME" "$WORKERPASS"
"""
dockerfile_extra_contents['xenial'] = """
# Buildbot
RUN apt-get update -y && apt-get install -yq --no-install-suggests --no-install-recommends \
git subversion python3-dev libffi-dev python3-setuptools \
python3-pip curl openssh-client wget \
python-setuptools python-psutil libssl-dev python-dev libgmp-dev \
python-virtualenv python3-wheel pkg-config rustc cargo \
python3-openssl
RUN pip3 install setuptools_rust
RUN pip3 install 'buildbot-worker<3.2.0' 'cryptography<35.0.0'
RUN groupadd buildbot
RUN useradd -d /var/lib/buildbot -m -g buildbot buildbot
# dumb-init
RUN wget https://github.com/Yelp/dumb-init/releases/download/v1.2.5/dumb-init_1.2.5_amd64.deb
RUN dpkg -i dumb-init_*.deb && rm -f dumb-init_*.deb
# buildbot entrypoint
RUN [ -f /usr/local/bin/buildbot_entrypoint.sh ] || wget -O /usr/local/bin/buildbot_entrypoint.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/xenial/entrypoint.sh
RUN chmod +x /usr/local/bin/buildbot_entrypoint.sh
RUN wget -O /usr/local/share/ca-certificates/buildbot-ca.crt https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/docker/bionic/buildbot-ca.crt
RUN update-ca-certificates
RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
USER buildbot
ENTRYPOINT /usr/local/bin/buildbot_entrypoint.sh "$BUILDMASTER:$BUILDMASTER_PORT" "$WORKERNAME" "$WORKERPASS"
""" """
@ -64,6 +131,8 @@ def list_jobs(directory=".buildbot"):
""" """
results = [] results = []
files = ["Dockerfile", "build.sh", "test.sh"] files = ["Dockerfile", "build.sh", "test.sh"]
if not exists(directory):
return results
for item in listdir(directory): for item in listdir(directory):
print("checking directory {}".format(item)) print("checking directory {}".format(item))
flag = False flag = False
@ -115,6 +184,7 @@ def _get_dockerfile_contents(dockerfile):
if m: if m:
inside_allowed_command = True inside_allowed_command = True
if m.group(1) == "FROM": if m.group(1) == "FROM":
os_codename = m.group().split()[1].split(":")[1]
has_from = True has_from = True
if inside_allowed_command: if inside_allowed_command:
res += line res += line
@ -124,7 +194,11 @@ def _get_dockerfile_contents(dockerfile):
if not has_from: if not has_from:
return None return None
return res + dockerfile_extra_contents[os_codename]
try:
return res + dockerfile_extra_contents[os_codename]
except KeyError:
return None
def trigger_child_hooks(buildbotUrl: str, repository, branch, revision, def trigger_child_hooks(buildbotUrl: str, repository, branch, revision,
@ -168,13 +242,14 @@ def trigger_child_hooks(buildbotUrl: str, repository, branch, revision,
request_data["changes"] = { request_data["changes"] = {
"author": "buildbot_multibuild", "author": "buildbot_multibuild",
"repository": repository, "repository": repository,
"project": "/".join(repository.split("/")[-2:]), "project": job,
} }
retval = requests.post(request_url, headers=request_headers, retval = requests.post(request_url, headers=request_headers,
json=request_data) json=request_data)
print("Triggered job for {} on {}: {}".format(job, request_url, print("Triggered job for {} on {}: {}".format(job, request_url,
retval.text)) retval.text))
sleep(1)
if __name__ == "__main__": if __name__ == "__main__":

View File

@ -13,6 +13,7 @@ Requires docker
from os import listdir from os import listdir
from os.path import isfile, join from os.path import isfile, join
from buildbot.plugins import steps, util from buildbot.plugins import steps, util
from buildbot.process.results import SUCCESS
from .lib.renderers import * from .lib.renderers import *
@ -53,19 +54,89 @@ def add_child_sh_steps(build_factory, directory=".buildbot"):
""" """
build_factory.addStep( build_factory.addStep(
steps.ShellCommand( steps.FileDownload(
name=util.Interpolate("build_%(prop:jobname)s"), name="Upload keystore",
command=util.Interpolate("%(kw:directory)s/%(prop:jobname)s/build.sh", directory=directory), workerdest="/var/lib/buildbot/keystore",
doStepIf=is_build_script_available, mastersrc=util.Interpolate("keystore/%(prop:jobname)s.keystore"),
hideStepIf=isnt_build_script_available, doStepIf=should_build_sign,
hideStepIf=True,
mode=0o600
) )
) )
build_factory.addStep( build_factory.addStep(
steps.ShellCommand( steps.ShellCommand(
name= util.Interpolate("test_%(prop:jobname)s"), name=util.Interpolate("build_%(prop:jobname)s"),
command=util.Interpolate("%(kw:directory)s/%(prop:jobname)s/test.sh", directory=directory), command=util.Interpolate("%(kw:directory)s/"
"%(prop:jobname)s/build.sh",
directory=directory),
env=build_env,
doStepIf=shouldnt_build_sign,
hideStepIf=isnt_build_script_available,
timeout=7200,
)
)
build_factory.addStep(
steps.ShellCommand(
name=util.Interpolate("build_and_sign_%(prop:jobname)s"),
command=util.Interpolate("%(kw:directory)s/"
"%(prop:jobname)s/build.sh",
directory=directory),
env=build_env,
doStepIf=should_build_sign,
hideStepIf=isnt_build_script_available,
timeout=7200,
)
)
build_factory.addStep(
steps.ShellCommand(
name="Delete keystore",
command="rm -f /var/lib/buildbot/keystore",
doStepIf=should_build_sign,
hideStepIf=True,
)
)
build_factory.addStep(
steps.ShellCommand(
name=util.Interpolate("test_%(prop:jobname)s"),
command=util.Interpolate("%(kw:directory)s/"
"%(prop:jobname)s/test.sh",
directory=directory),
haltOnFailure=False,
flunkOnFailure=True,
doStepIf=is_test_script_available, doStepIf=is_test_script_available,
hideStepIf=isnt_test_script_available, hideStepIf=isnt_test_script_available,
) )
) )
build_factory.addStep(
steps.SetPropertyFromCommand(
name="Find files to upload",
command="find . -maxdepth 1 -mindepth 1 "
"-type f -printf '%P\n'",
workdir="out",
hideStepIf=True,
decodeRC={0: SUCCESS, 1: SUCCESS},
property="files_to_upload"
)
)
build_factory.addStep(
steps.ShellCommand(
name="Upload files",
workdir="out",
doStepIf=has_files_to_upload,
hideStepIf=no_files_to_upload,
command=util.Interpolate(
"curl -T {%s} -u buildbot:%s "
"https://artifacts.bitmessage.at/%s/%s/",
files_to_upload,
util.Secret('artifact_upload'),
util.Property('jobname'),
util.Property('buildnumber'),
)
)
)