Gentoo Archives: gentoo-commits

From: Arthur Zamarin <arthurzam@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-util/buildbot/
Date: Fri, 28 Jan 2022 11:16:45
Message-Id: 1643368582.b9785d1d6bcf56b6ab16efbd102b2b5ac2187c92.arthurzam@gentoo
1 commit: b9785d1d6bcf56b6ab16efbd102b2b5ac2187c92
2 Author: Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
3 AuthorDate: Thu Jan 27 21:42:12 2022 +0000
4 Commit: Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
5 CommitDate: Fri Jan 28 11:16:22 2022 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b9785d1d
7
8 dev-util/buildbot: add 3.4.0, enable py3.10, cleanup
9
10 Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
11
12 dev-util/buildbot/Manifest | 1 +
13 dev-util/buildbot/buildbot-3.4.0.ebuild | 177 ++++++++++++++++++++++++++++++++
14 2 files changed, 178 insertions(+)
15
16 diff --git a/dev-util/buildbot/Manifest b/dev-util/buildbot/Manifest
17 index 3fd48216350f..fc618f8f8586 100644
18 --- a/dev-util/buildbot/Manifest
19 +++ b/dev-util/buildbot/Manifest
20 @@ -8,3 +8,4 @@ DIST buildbot-3.1.0.tar.gz 2229027 BLAKE2B 27eaed470f18c4fe8cae1730ca92918352518
21 DIST buildbot-3.1.1.tar.gz 2229124 BLAKE2B c384b897a5f8816b7d6a52070cb1cce7e9b70d41a5837990af3474d3063a4906600f82c1bc6e6c48d826ac1f95dc36dcc15ebca10c9249615d25f547e0216dad SHA512 4f4194fab83bb80cff15366fb6461624b75c5a2d0e473ac9cb6a8abb372ccd7ee9208a944f198d874e8cd1a87358239ba3e8314d54ef35a641ff83510c48de37
22 DIST buildbot-3.2.0.tar.gz 2245261 BLAKE2B ccb1dc5e6a6bf5c9e06a7b05cc1baa605b09cf65ad4f9beff2a40e9f52a3065363960a990c288ed181cc5cc5cf5af1ce06dd4df561ddfe9819165ebe32760887 SHA512 5730126786880eb48da140cbbaaac2df95e6d04d22268fb305c1a228969bd096cd18959779f6101af73c41fecb07a7c1e2bb276271bede53989323a46fb06962
23 DIST buildbot-3.3.0.tar.gz 2255464 BLAKE2B 9b4cfdd948bdf4b183dc45973f26b41ec5b390740c92f3b29c460c8fba4f35b71eaf848b026b21e1ba1e213b18d6d91e3736b69aa8c3e6dbb847b04b644e2c54 SHA512 da0d26257964df40a470b00e2cd0f3f2230d3224bf8ae7c2b896fc8ec739e5d3ce7988ab07f6c66dcb13b0d4b6916e839f53a025cac637ccd4bcd3f442e12b1d
24 +DIST buildbot-3.4.0.tar.gz 2446868 BLAKE2B a58b268fd4569105f1c0ba48c9ed86210a3fee4725f167d6b6847960bbb56a092d0c0db427ecf5932a91d44065da8843fbb4046d289800a019b0b1d8b1f53fea SHA512 92e5085862ac37a6c3c059870a3998fbaac2019c48384295f3e209788ea14bddff6704f1b987a8f3b1550c1b0255d228f8a0b2a20b5cb760b22a513db465863b
25
26 diff --git a/dev-util/buildbot/buildbot-3.4.0.ebuild b/dev-util/buildbot/buildbot-3.4.0.ebuild
27 new file mode 100644
28 index 000000000000..b06b7fb40d3f
29 --- /dev/null
30 +++ b/dev-util/buildbot/buildbot-3.4.0.ebuild
31 @@ -0,0 +1,177 @@
32 +# Copyright 1999-2022 Gentoo Authors
33 +# Distributed under the terms of the GNU General Public License v2
34 +
35 +EAPI=8
36 +
37 +PYTHON_REQ_USE="sqlite"
38 +PYTHON_COMPAT=( python3_{8..10} )
39 +inherit readme.gentoo-r1 systemd distutils-r1
40 +
41 +MY_PV="${PV/_p/.post}"
42 +MY_P="${PN}-${MY_PV}"
43 +
44 +DESCRIPTION="BuildBot build automation system"
45 +HOMEPAGE="https://buildbot.net/
46 + https://github.com/buildbot/buildbot
47 + https://pypi.org/project/buildbot/"
48 +SRC_URI="mirror://pypi/${PN:0:1}/${PN}/${MY_P}.tar.gz"
49 +S=${WORKDIR}/${MY_P}
50 +
51 +LICENSE="GPL-2"
52 +SLOT="0"
53 +KEYWORDS="~amd64 ~arm64 ~amd64-linux ~x86-linux"
54 +
55 +IUSE="crypt docker examples irc test"
56 +RESTRICT="!test? ( test )"
57 +
58 +RDEPEND="
59 + acct-user/buildbot
60 + >=dev-python/twisted-17.9.0[${PYTHON_USEDEP},crypt?]
61 + >=dev-python/jinja-2.1[${PYTHON_USEDEP}]
62 + >=dev-python/zope-interface-4.1.1[${PYTHON_USEDEP}]
63 + >=dev-python/sqlalchemy-1.2.0[${PYTHON_USEDEP}]
64 + <dev-python/sqlalchemy-1.5.0[${PYTHON_USEDEP}]
65 + >=dev-python/alembic-1.6.0[${PYTHON_USEDEP}]
66 + >=dev-python/python-dateutil-1.5[${PYTHON_USEDEP}]
67 + >=dev-python/txaio-2.2.2[${PYTHON_USEDEP}]
68 + >=dev-python/autobahn-0.16.0[${PYTHON_USEDEP}]
69 + dev-python/pyjwt[${PYTHON_USEDEP}]
70 + dev-python/pyyaml[${PYTHON_USEDEP}]
71 + ~dev-util/buildbot-worker-${PV}[${PYTHON_USEDEP}]
72 + crypt? (
73 + >=dev-python/pyopenssl-16.0.0[${PYTHON_USEDEP}]
74 + dev-python/service_identity[${PYTHON_USEDEP}]
75 + dev-python/idna[${PYTHON_USEDEP}]
76 + )
77 + irc? (
78 + dev-python/txrequests[${PYTHON_USEDEP}]
79 + )
80 + docker? (
81 + >=dev-python/docker-py-2.2.0[${PYTHON_USEDEP}]
82 + dev-python/requests[${PYTHON_USEDEP}]
83 + )
84 +"
85 +BDEPEND="
86 + test? (
87 + ${RDEPEND}
88 + dev-python/treq[${PYTHON_USEDEP}]
89 + dev-python/txrequests[${PYTHON_USEDEP}]
90 + dev-python/pypugjs[${PYTHON_USEDEP}]
91 + >=dev-python/boto3-1.12.48[${PYTHON_USEDEP}]
92 + dev-python/moto[${PYTHON_USEDEP}]
93 + >=dev-python/mock-2.0.0[${PYTHON_USEDEP}]
94 + dev-python/parameterized[${PYTHON_USEDEP}]
95 + dev-python/lz4[${PYTHON_USEDEP}]
96 + dev-python/ldap3[${PYTHON_USEDEP}]
97 + ~dev-util/buildbot-pkg-${PV}[${PYTHON_USEDEP}]
98 + ~dev-util/buildbot-worker-${PV}[${PYTHON_USEDEP}]
99 + ~dev-util/buildbot-www-${PV}[${PYTHON_USEDEP}]
100 + )"
101 +
102 +DOC_CONTENTS="The \"buildbot\" user and the \"buildmaster\" init script has been added
103 +to support starting buildbot through Gentoo's init system. To use this,
104 +execute \"emerge --config =${CATEGORY}/${PF}\" to create a new instance.
105 +The scripts can run as a different user if desired."
106 +
107 +src_prepare() {
108 + # disable all warnings as errors
109 + sed -e "/warnings.filterwarnings('error')/d" -i buildbot/test/__init__.py || die
110 +
111 + distutils-r1_src_prepare
112 +}
113 +
114 +python_test() {
115 + distutils_install_for_testing
116 + "${EPYTHON}" -m twisted.trial buildbot || die "Tests failed with ${EPYTHON}"
117 +}
118 +
119 +src_install() {
120 + distutils-r1_src_install
121 +
122 + doman docs/buildbot.1
123 +
124 + if use examples; then
125 + dodoc -r docs/examples
126 + fi
127 +
128 + newconfd "${FILESDIR}/buildmaster.confd" buildmaster
129 + newinitd "${FILESDIR}/buildmaster.initd" buildmaster
130 + systemd_dounit "${FILESDIR}/buildmaster.target"
131 + systemd_newunit "${FILESDIR}/buildmaster_at.service" "buildmaster@.service"
132 + systemd_install_serviced "${FILESDIR}/buildmaster_at.service.conf" "buildmaster@.service"
133 +
134 + readme.gentoo_create_doc
135 +}
136 +
137 +pkg_postinst() {
138 + readme.gentoo_print_elog
139 +
140 + if [[ -n ${REPLACING_VERSIONS} ]]; then
141 + ewarn
142 + ewarn "Starting with buildbot-0.8.12-r2, more than one instance of buildmaster"
143 + ewarn "can be run simultaneously. Note that \"BASEDIR\" in the buildbot configuration file"
144 + ewarn "is now the common base directory for all instances. If you are migrating from an older"
145 + ewarn "version, make sure that you copy the current contents of \"BASEDIR\" to a subdirectory."
146 + ewarn "The name of the subdirectory corresponds to the name of the buildmaster instance."
147 + ewarn "In order to start the service running OpenRC-based systems need to link to the init file:"
148 + ewarn " ln --symbolic --relative /etc/init.d/buildmaster /etc/init.d/buildmaster.myinstance"
149 + ewarn " rc-update add buildmaster.myinstance default"
150 + ewarn " /etc/init.d/buildmaster.myinstance start"
151 + ewarn "Systems using systemd can do the following:"
152 + ewarn " systemctl enable buildmaster@××××××××××.service"
153 + ewarn " systemctl enable buildmaster.target"
154 + ewarn " systemctl start buildmaster.target"
155 + elog
156 + elog "Upstream recommends the following when upgrading:"
157 + elog "Each time you install a new version of Buildbot, you should run the"
158 + elog "\"buildbot upgrade-master\" command on each of your pre-existing build masters."
159 + elog "This will add files and fix (or at least detect) incompatibilities between"
160 + elog "your old config and the new code."
161 + fi
162 + elog
163 + elog "In order to create a new instance of buildmaster, execute:"
164 + elog " emerge --config =${CATEGORY}/${PF}"
165 +}
166 +
167 +pkg_config() {
168 + local buildmaster_path="/var/lib/buildmaster"
169 + local log_path="/var/log/buildmaster"
170 +
171 + einfo "This will prepare a new buildmaster instance in ${buildmaster_path}."
172 + einfo "Press Control-C to abort."
173 +
174 + einfo "Enter the name for the new instance: "
175 + read instance_name
176 + [[ -z "${instance_name}" ]] && die "Invalid instance name"
177 +
178 + local instance_path="${buildmaster_path}/${instance_name}"
179 + local instance_log_path="${log_path}/${instance_name}"
180 +
181 + if [[ -e "${instance_path}" ]]; then
182 + eerror "The instance with the specified name already exists:"
183 + eerror "${instance_path}"
184 + die "Instance already exists"
185 + fi
186 +
187 + local buildbot="/usr/bin/buildbot"
188 + if [[ ! -d "${buildmaster_path}" ]]; then
189 + mkdir --parents "${buildmaster_path}" || die "Unable to create directory ${buildmaster_path}"
190 + fi
191 + "${buildbot}" create-master "${instance_path}" &>/dev/null || die "Creating instance failed"
192 + chown --recursive buildbot:buildbot "${instance_path}" || die "Setting permissions for instance failed"
193 + mv "${instance_path}/master.cfg.sample" "${instance_path}/master.cfg" \
194 + || die "Moving sample configuration failed"
195 + ln --symbolic --relative "/etc/init.d/buildmaster" "/etc/init.d/buildmaster.${instance_name}" \
196 + || die "Unable to create link to init file"
197 +
198 + if [[ ! -d "${instance_log_path}" ]]; then
199 + mkdir --parents "${instance_log_path}" || die "Unable to create directory ${instance_log_path}"
200 + chown --recursive buildbot:buildbot "${instance_log_path}" \
201 + || die "Setting permissions for instance failed"
202 + fi
203 + ln --symbolic --relative "${instance_log_path}/twistd.log" "${instance_path}/twistd.log" \
204 + || die "Unable to create link to log file"
205 +
206 + einfo "Successfully created a buildmaster instance at ${instance_path}."
207 + einfo "To change the default settings edit the master.cfg file in this directory."
208 +}