Gentoo Archives: gentoo-commits

From: Brian Dolbec <dolsen@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-util/buildbot/
Date: Sun, 28 Jun 2020 00:46:41
Message-Id: 1593305180.f7aac271d28efa01e25b6b87c8586e939ad8187b.dolsen@gentoo
1 commit: f7aac271d28efa01e25b6b87c8586e939ad8187b
2 Author: Brian Dolbec <dolsen <AT> gentoo <DOT> org>
3 AuthorDate: Sun Jun 28 00:03:17 2020 +0000
4 Commit: Brian Dolbec <dolsen <AT> gentoo <DOT> org>
5 CommitDate: Sun Jun 28 00:46:20 2020 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f7aac271
7
8 dev-util/buildbot: Version bump
9
10 Package-Manager: Portage-2.3.99, Repoman-2.3.22
11 Signed-off-by: Brian Dolbec <dolsen <AT> gentoo.org>
12
13 dev-util/buildbot/Manifest | 1 +
14 dev-util/buildbot/buildbot-2.8.2.ebuild | 210 ++++++++++++++++++++++++++++++++
15 2 files changed, 211 insertions(+)
16
17 diff --git a/dev-util/buildbot/Manifest b/dev-util/buildbot/Manifest
18 index 0b13398de21..cca8aec80ad 100644
19 --- a/dev-util/buildbot/Manifest
20 +++ b/dev-util/buildbot/Manifest
21 @@ -1,3 +1,4 @@
22 DIST buildbot-2.7.0.tar.gz 3175050 BLAKE2B 0a41eccaa4ca8df6396455049e8c09a1b2fe6cde3072da7fd3715f2769015944e8880f41dbe6750dd7b26bd863fb82f8e8d8c6540f9e1bf3ea4378f11adc973d SHA512 9946fe0b1591d51e5136d9458526918e872174afee79b5f1c333823ef1d2ddae66f017e9b57e26a2451da7ca7672720f32544c606ce5652d0825fae563779669
23 DIST buildbot-2.8.0-fakedb.tar.xz 16204 BLAKE2B 741676e2c9117b1ab174ce49747bdfcd07766ad3e471e308398dff476f167fd231b7772c2f02002cbafb27e2ef535242d84d5aa84f4bc8942d4d216b2d5bf1f6 SHA512 c2b00d8621b3a1e521f6c17e902ae331b606dda3d319187895f26629dbdaf50caefc5d49fb150fb780e682ae431515c7ded4950d62448e8a73b8efba821c0fa1
24 DIST buildbot-2.8.0.tar.gz 3162882 BLAKE2B 19789f1fe9f572c978a1843a98cd01d752a614d89eb29f2de9db750808d1f96d7893b39d703f37cc0e81e022267c08603c86d59a5902d65194e236f7170d6b30 SHA512 18af8fe1bda6f7014f514bfd112ccf9837194c0e42cbdabaaa6c6202660670964421feff3e92e9dca4cf960f69a4bde9b3666287b54ef7e912284a0471dcc2b6
25 +DIST buildbot-2.8.2.tar.gz 3181035 BLAKE2B 40a3e424cc03c982549f25993a4abd2fe04bdc089ad22288af4d25724972f9f3541ef32549d2761c808845df44a972b00cf631adfc564bf4852c4b6b6ab14404 SHA512 7d7f15becc7fc1803ae4e9f1906d547c89dfe1efaa51e8fda0674a3d9b060bafbaae4cb671ec844750313247edb73f17c9014c545bce58070df0ca322a0fd9a2
26
27 diff --git a/dev-util/buildbot/buildbot-2.8.2.ebuild b/dev-util/buildbot/buildbot-2.8.2.ebuild
28 new file mode 100644
29 index 00000000000..3a8aa883913
30 --- /dev/null
31 +++ b/dev-util/buildbot/buildbot-2.8.2.ebuild
32 @@ -0,0 +1,210 @@
33 +# Copyright 1999-2020 Gentoo Authors
34 +# Distributed under the terms of the GNU General Public License v2
35 +
36 +EAPI="7"
37 +PYTHON_REQ_USE="sqlite"
38 +PYTHON_COMPAT=( python3_{6,7,8} )
39 +
40 +DISTUTILS_USE_SETUPTOOLS="rdepend"
41 +
42 +inherit readme.gentoo-r1 systemd distutils-r1
43 +
44 +MY_PV="${PV/_p/.post}"
45 +MY_P="${PN}-${MY_PV}"
46 +
47 +DESCRIPTION="BuildBot build automation system"
48 +HOMEPAGE="https://buildbot.net/ https://github.com/buildbot/buildbot https://pypi.org/project/buildbot/"
49 +SRC_URI="mirror://pypi/${PN:0:1}/${PN}/${MY_P}.tar.gz
50 + https://dev.gentoo.org/~dolsen/distfiles/buildbot-2.8.0-fakedb.tar.xz
51 +"
52 +
53 +LICENSE="GPL-2"
54 +SLOT="0"
55 +KEYWORDS="~amd64 ~amd64-linux ~x86-linux"
56 +
57 +IUSE="crypt doc docker examples irc test"
58 +RESTRICT="!test? ( test )"
59 +
60 +RDEPEND="
61 + acct-user/buildbot
62 + >=dev-python/jinja-2.1[${PYTHON_USEDEP}]
63 + >=dev-python/twisted-17.9.0[${PYTHON_USEDEP}]
64 + >=dev-python/autobahn-0.16.0[${PYTHON_USEDEP}]
65 + >=dev-python/sqlalchemy-0.8[${PYTHON_USEDEP}]
66 + >=dev-python/sqlalchemy-migrate-0.9[${PYTHON_USEDEP}]
67 + dev-python/future[${PYTHON_USEDEP}]
68 + >=dev-python/python-dateutil-1.5[${PYTHON_USEDEP}]
69 + >=dev-python/txaio-2.2.2[${PYTHON_USEDEP}]
70 + dev-python/pyjwt[${PYTHON_USEDEP}]
71 + dev-python/pyyaml[${PYTHON_USEDEP}]
72 + >=dev-python/zope-interface-4.1.1[${PYTHON_USEDEP}]
73 + ~dev-util/buildbot-worker-${PV}[${PYTHON_USEDEP}]
74 + crypt? (
75 + >=dev-python/twisted-17.9.0[${PYTHON_USEDEP},crypt]
76 + >=dev-python/pyopenssl-16.0.0[${PYTHON_USEDEP}]
77 + <dev-python/idna-2.9[${PYTHON_USEDEP}]
78 + dev-python/service_identity[${PYTHON_USEDEP}]
79 + )
80 + irc? (
81 + dev-python/txrequests[${PYTHON_USEDEP}]
82 + )
83 + docker? (
84 + >=dev-python/docker-py-2.2.0[${PYTHON_USEDEP}]
85 + dev-python/requests[${PYTHON_USEDEP}]
86 + )
87 +"
88 +DEPEND="${RDEPEND}
89 + doc? (
90 + >=dev-python/sphinx-1.4.3[${PYTHON_USEDEP}]
91 + <dev-python/sphinx-2.1.0[${PYTHON_USEDEP}]
92 + dev-python/sphinxcontrib-blockdiag[${PYTHON_USEDEP}]
93 + dev-python/sphinxcontrib-spelling[${PYTHON_USEDEP}]
94 + dev-python/pyenchant[${PYTHON_USEDEP}]
95 + dev-python/docutils[${PYTHON_USEDEP}]
96 + dev-python/sphinx-jinja[${PYTHON_USEDEP}]
97 + dev-python/sphinx_rtd_theme[${PYTHON_USEDEP}]
98 + )
99 + test? (
100 + >=dev-python/mock-2.0.0[${PYTHON_USEDEP}]
101 + dev-python/moto[${PYTHON_USEDEP}]
102 + >=dev-python/boto3-1.12.48[${PYTHON_USEDEP}]
103 + dev-python/parameterized[${PYTHON_USEDEP}]
104 + dev-python/pypugjs[${PYTHON_USEDEP}]
105 + dev-python/txrequests[${PYTHON_USEDEP}]
106 + dev-python/lz4[${PYTHON_USEDEP}]
107 + dev-python/treq[${PYTHON_USEDEP}]
108 + dev-python/setuptools_trial[${PYTHON_USEDEP}]
109 + ~dev-util/buildbot-pkg-${PV}[${PYTHON_USEDEP}]
110 + ~dev-util/buildbot-worker-${PV}[${PYTHON_USEDEP}]
111 + ~dev-util/buildbot-www-${PV}[${PYTHON_USEDEP}]
112 + crypt? (
113 + >=dev-python/twisted-17.9.0[${PYTHON_USEDEP},crypt]
114 + >=dev-python/pyopenssl-16.0.0[${PYTHON_USEDEP}]
115 + <dev-python/idna-2.9[${PYTHON_USEDEP}]
116 + dev-python/service_identity[${PYTHON_USEDEP}]
117 + )
118 + )"
119 +
120 +S=${WORKDIR}/${MY_P}
121 +
122 +distutils_enable_tests setup.py
123 +
124 +PATCHES=(
125 + "${FILESDIR}/pypugjs-2.8.0.patch"
126 +)
127 +
128 +pkg_setup() {
129 + DOC_CONTENTS="The \"buildbot\" user and the \"buildmaster\" init script has been added
130 + to support starting buildbot through Gentoo's init system. To use this,
131 + execute \"emerge --config =${CATEGORY}/${PF}\" to create a new instance.
132 + The scripts can run as a different user if desired."
133 +}
134 +
135 +src_compile() {
136 + distutils-r1_src_compile
137 +
138 + if use doc; then
139 + einfo "Generation of documentation"
140 + pushd docs > /dev/null
141 + #'man' target is currently broken
142 + emake html
143 + popd > /dev/null
144 + fi
145 +}
146 +
147 +src_install() {
148 + distutils-r1_src_install
149 +
150 + doman docs/buildbot.1
151 +
152 + if use doc; then
153 + HTML_DOCS=( docs/_build/html/ )
154 + # TODO: install man pages
155 + fi
156 +
157 + if use examples; then
158 + insinto /usr/share/doc/${PF}
159 + doins -r docs/examples
160 + fi
161 +
162 + newconfd "${FILESDIR}/buildmaster.confd" buildmaster
163 + newinitd "${FILESDIR}/buildmaster.initd" buildmaster
164 + systemd_dounit "${FILESDIR}/buildmaster.target"
165 + systemd_newunit "${FILESDIR}/buildmaster_at.service" "buildmaster@.service"
166 + systemd_install_serviced "${FILESDIR}/buildmaster_at.service.conf" "buildmaster@.service"
167 +
168 + readme.gentoo_create_doc
169 +}
170 +
171 +pkg_postinst() {
172 + readme.gentoo_print_elog
173 +
174 + if [[ -n ${REPLACING_VERSIONS} ]]; then
175 + ewarn
176 + ewarn "Starting with buildbot-0.8.12-r2, more than one instance of buildmaster"
177 + ewarn "can be run simultaneously. Note that \"BASEDIR\" in the buildbot configuration file"
178 + ewarn "is now the common base directory for all instances. If you are migrating from an older"
179 + ewarn "version, make sure that you copy the current contents of \"BASEDIR\" to a subdirectory."
180 + ewarn "The name of the subdirectory corresponds to the name of the buildmaster instance."
181 + ewarn "In order to start the service running OpenRC-based systems need to link to the init file:"
182 + ewarn " ln --symbolic --relative /etc/init.d/buildmaster /etc/init.d/buildmaster.myinstance"
183 + ewarn " rc-update add buildmaster.myinstance default"
184 + ewarn " /etc/init.d/buildmaster.myinstance start"
185 + ewarn "Systems using systemd can do the following:"
186 + ewarn " systemctl enable buildmaster@××××××××××.service"
187 + ewarn " systemctl enable buildmaster.target"
188 + ewarn " systemctl start buildmaster.target"
189 + elog
190 + elog "Upstream recommends the following when upgrading:"
191 + elog "Each time you install a new version of Buildbot, you should run the"
192 + elog "\"buildbot upgrade-master\" command on each of your pre-existing build masters."
193 + elog "This will add files and fix (or at least detect) incompatibilities between"
194 + elog "your old config and the new code."
195 + fi
196 + elog
197 + elog "In order to create a new instance of buildmaster, execute:"
198 + elog " emerge --config =${CATEGORY}/${PF}"
199 +}
200 +
201 +pkg_config() {
202 + local buildmaster_path="/var/lib/buildmaster"
203 + local log_path="/var/log/buildmaster"
204 +
205 + einfo "This will prepare a new buildmaster instance in ${buildmaster_path}."
206 + einfo "Press Control-C to abort."
207 +
208 + einfo "Enter the name for the new instance: "
209 + read instance_name
210 + [[ -z "${instance_name}" ]] && die "Invalid instance name"
211 +
212 + local instance_path="${buildmaster_path}/${instance_name}"
213 + local instance_log_path="${log_path}/${instance_name}"
214 +
215 + if [[ -e "${instance_path}" ]]; then
216 + eerror "The instance with the specified name already exists:"
217 + eerror "${instance_path}"
218 + die "Instance already exists"
219 + fi
220 +
221 + local buildbot="/usr/bin/buildbot"
222 + if [[ ! -d "${buildmaster_path}" ]]; then
223 + mkdir --parents "${buildmaster_path}" || die "Unable to create directory ${buildmaster_path}"
224 + fi
225 + "${buildbot}" create-master "${instance_path}" &>/dev/null || die "Creating instance failed"
226 + chown --recursive buildbot:buildbot "${instance_path}" || die "Setting permissions for instance failed"
227 + mv "${instance_path}/master.cfg.sample" "${instance_path}/master.cfg" \
228 + || die "Moving sample configuration failed"
229 + ln --symbolic --relative "/etc/init.d/buildmaster" "/etc/init.d/buildmaster.${instance_name}" \
230 + || die "Unable to create link to init file"
231 +
232 + if [[ ! -d "${instance_log_path}" ]]; then
233 + mkdir --parents "${instance_log_path}" || die "Unable to create directory ${instance_log_path}"
234 + chown --recursive buildbot:buildbot "${instance_log_path}" \
235 + || die "Setting permissions for instance failed"
236 + fi
237 + ln --symbolic --relative "${instance_log_path}/twistd.log" "${instance_path}/twistd.log" \
238 + || die "Unable to create link to log file"
239 +
240 + einfo "Successfully created a buildmaster instance at ${instance_path}."
241 + einfo "To change the default settings edit the master.cfg file in this directory."
242 +}