Gentoo Archives: gentoo-commits

From: Joonas Niilola <juippis@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-python/elasticsearch-curator/
Date: Mon, 28 Oct 2019 14:43:48
Message-Id: 1572273723.72d28af74ed0c18fa72cc49733e28a3b2720faca.juippis@gentoo
1 commit: 72d28af74ed0c18fa72cc49733e28a3b2720faca
2 Author: Tomas Mozes <hydrapolic <AT> gmail <DOT> com>
3 AuthorDate: Fri Oct 25 09:48:11 2019 +0000
4 Commit: Joonas Niilola <juippis <AT> gentoo <DOT> org>
5 CommitDate: Mon Oct 28 14:42:03 2019 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=72d28af7
7
8 dev-python/elasticsearch-curator: bump to 5.8.1
9
10 Closes: https://bugs.gentoo.org/696632
11 Package-Manager: Portage-2.3.77, Repoman-2.3.17
12 Signed-off-by: Tomáš Mózes <hydrapolic <AT> gmail.com>
13 Closes: https://github.com/gentoo/gentoo/pull/13424
14 Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>
15
16 dev-python/elasticsearch-curator/Manifest | 2 +
17 .../elasticsearch-curator-5.8.1.ebuild | 159 +++++++++++++++++++++
18 2 files changed, 161 insertions(+)
19
20 diff --git a/dev-python/elasticsearch-curator/Manifest b/dev-python/elasticsearch-curator/Manifest
21 index 3d7731c867f..cc3cbecf2ab 100644
22 --- a/dev-python/elasticsearch-curator/Manifest
23 +++ b/dev-python/elasticsearch-curator/Manifest
24 @@ -1,4 +1,6 @@
25 +DIST elasticsearch-7.3.2-linux-x86_64.tar.gz 285050383 BLAKE2B 730d8550f5887facae3075ce3b0bdb96b49350782fe7e687b8f4477bb363ce7c1595f2b1ece2b7d59d18539886b6e4806f56b0f5674bc417528232a92f1c00a8 SHA512 08e89347797ec6f008fb76cda17ec3e0dbc553fc992d07f4944fd99d17d5bc934849d9e534724d1541432c9844d3da57d875bc08a0c4cd95ba4251e2b03f833b
26 DIST elasticsearch-curator-5.5.4.tar.gz 221161 BLAKE2B 41828800dd9237142767d3163b3d87770ea5b904858991598cce2feb7c3a22d85c0d73275a2f232099ea82e7346fc20080a3bfef692ee808b730d3e4e6de405d SHA512 99ed18592105d19791513ad713115b6e2a6b589ab8b4e3fc4435b2878e25f552e0bda8d63cb6279970afc6ba39d9f3db17af1b4fb44500fe8a14b060e1530258
27 DIST elasticsearch-curator-5.6.0.tar.gz 221555 BLAKE2B cbf1f645b266d2d08914ff74fd5c63bcd5661ef68a8b9286ed59b05d52d50e18e8d18e00b3a0e037f8e6452ce79213280b5ecffaf6af0a3fb70ef92458c80efa SHA512 7dc02b5d15228ea96254dc7dd8069d8396c5d3df883b7ab42936c7612b0f16f5399131563703ccd05469facee7ddf20a720daf62a2713943a4b9a0c9448dd676
28 +DIST elasticsearch-curator-5.8.1.tar.gz 231233 BLAKE2B d2369c18be69cc5c8e17a6d7a72660bd7165c349cdb06c740c8db9dd2b583f181a09ba7d53ee0f4692cb6e31d373274f0610f2a654ba4a6da2d0ca0ff22c7c97 SHA512 500767967f423629f34d42ee088a9c007e193216c42f5590364ffcacc9e1efeba65dd4d333f806250e3b7fe0bea8b5501d1e6f3bf6fb0b8c46a46954e92c4a65
29 DIST elasticsearch-oss-6.3.2.tar.gz 29418577 BLAKE2B 152640dc01a10f44ba43f87f68361cc0dd5e1cf54d0ff92377f3acd1a12a247f002ffe2d003cc53760e891278249c10b1d6d4eb978b0bb1c1ebf8879a2cfcb9a SHA512 3c51a860414f7e55900b1d9a350bdbc3e673c8445e316454c2480315b4b9fc08df58090c6281cecc3ae63d12d78d6bd58e228b3371aa325db799ce18758a21f4
30 DIST elasticsearch-oss-6.4.3.tar.gz 33727639 BLAKE2B b4f4821af7a2447a6a16158c32bf676ebbfd8598fde8af558dd19d6e365df66be17d0984e3acb9380a0d5e0cff486b85f6edf96312bd3bb3fc5ae52c270306f3 SHA512 b1147baa95119a8a96779125351358b4c62f2a546b65a9750c11d1d1b9270f06db6da8ff1d9ad11efade1eaea8487087e2d8839b0edfc5da6d9b54da6c6df4e7
31
32 diff --git a/dev-python/elasticsearch-curator/elasticsearch-curator-5.8.1.ebuild b/dev-python/elasticsearch-curator/elasticsearch-curator-5.8.1.ebuild
33 new file mode 100644
34 index 00000000000..f822977ef92
35 --- /dev/null
36 +++ b/dev-python/elasticsearch-curator/elasticsearch-curator-5.8.1.ebuild
37 @@ -0,0 +1,159 @@
38 +# Copyright 1999-2019 Gentoo Authors
39 +# Distributed under the terms of the GNU General Public License v2
40 +
41 +EAPI=7
42 +
43 +PYTHON_COMPAT=( python{2_7,3_5,3_6,3_7} )
44 +
45 +MY_PN="curator"
46 +ES_VERSION="7.3.2"
47 +
48 +inherit distutils-r1
49 +
50 +DESCRIPTION="Tending time-series indices in Elasticsearch"
51 +HOMEPAGE="https://github.com/elasticsearch/curator"
52 +SRC_URI="https://github.com/elasticsearch/${MY_PN}/archive/v${PV}.tar.gz -> ${P}.tar.gz
53 + test? ( https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-${ES_VERSION}-linux-x86_64.tar.gz )"
54 +
55 +LICENSE="Apache-2.0"
56 +SLOT="0"
57 +KEYWORDS="~amd64 ~x86"
58 +# tests fail in chroot
59 +# https://github.com/elastic/elasticsearch/issues/12018
60 +RESTRICT="test"
61 +IUSE="doc test"
62 +
63 +# vulnerable pyyaml
64 +# https://github.com/elastic/curator/issues/1415
65 +RDEPEND="
66 + >=dev-python/elasticsearch-py-7.0.4[${PYTHON_USEDEP}]
67 + <dev-python/elasticsearch-py-8.0.0[${PYTHON_USEDEP}]
68 + >=dev-python/click-6.7[${PYTHON_USEDEP}]
69 + <dev-python/click-7.0[${PYTHON_USEDEP}]
70 + >=dev-python/certifi-2019.9.11[${PYTHON_USEDEP}]
71 + >=dev-python/requests-2.20.0[${PYTHON_USEDEP}]
72 + >=dev-python/urllib3-1.24.2[${PYTHON_USEDEP}]
73 + <dev-python/urllib3-1.25[${PYTHON_USEDEP}]
74 + >=dev-python/voluptuous-0.9.3[${PYTHON_USEDEP}]"
75 +DEPEND="dev-python/setuptools[${PYTHON_USEDEP}]
76 + >=dev-python/six-1.11.0[${PYTHON_USEDEP}]
77 + dev-python/sphinx
78 + ~dev-python/pyyaml-3.13[${PYTHON_USEDEP}]
79 + test? ( ${RDEPEND}
80 + virtual/jre
81 + dev-python/mock[${PYTHON_USEDEP}]
82 + dev-python/nose[${PYTHON_USEDEP}]
83 + dev-python/six[${PYTHON_USEDEP}] )"
84 +
85 +S="${WORKDIR}/${MY_PN}-${PV}"
86 +
87 +python_prepare_all() {
88 + # avoid downloading from net
89 + sed -e '/^intersphinx_mapping/,+3d' -i docs/conf.py || die
90 +
91 + # requests_aws4auth not in portage
92 + sed -e '/boto3/d' \
93 + -e '/requests_aws4auth/d' \
94 + -e '/tests_require/s/, "coverage", "nosexcover"//g' \
95 + -i setup.cfg setup.py || die
96 +
97 + distutils-r1_python_prepare_all
98 +}
99 +
100 +python_compile_all() {
101 + emake -C docs -j1 man $(usex doc html "")
102 +}
103 +
104 +# running tests in non-chroot environments:
105 +# FEATURES="test -usersandbox" emerge dev-python/elasticsearch-curator
106 +python_test_all() {
107 + # starts two ES instances (local,remote) and runs the tests
108 + # https://github.com/elastic/curator/blob/master/travis-run.sh
109 + local ES_INSTANCES="local remote"
110 + local ES_PATH="${WORKDIR}/elasticsearch-${ES_VERSION}"
111 +
112 + declare -A ES_PORT
113 + ES_PORT[local]=9200
114 + ES_PORT[remote]=9201
115 +
116 + local i transport
117 + declare -A ES_CONFIG_DIR ES_CONFIG_PATH ES_INSTANCE ES_LOG ES_PID
118 + for i in ${ES_INSTANCES}; do
119 + ES_CONFIG_DIR[$i]="${ES_PATH}/$i"
120 + ES_CONFIG_PATH[$i]="${ES_CONFIG_DIR[$i]}/elasticsearch.yml"
121 + ES_PID[$i]="${ES_PATH}/$i.pid"
122 + ES_LOG[$i]="${ES_PATH}/logs/$i.log"
123 + done
124 +
125 + # configure ES instances
126 + for i in ${ES_INSTANCES}; do
127 + mkdir -p "${ES_CONFIG_DIR[$i]}" || die
128 + cp ${ES_PATH}/config/{jvm.options,log4j2.properties} "${ES_CONFIG_DIR[$i]}"/ || die
129 + echo 'network.host: 127.0.0.1' > "${ES_CONFIG_PATH[$i]}" || die
130 + echo "http.port: ${ES_PORT[$i]}" >> "${ES_CONFIG_PATH[$i]}" || die
131 + echo "cluster.name: $i" >> "${ES_CONFIG_PATH[$i]}" || die
132 + echo "node.name: $i" >> "${ES_CONFIG_PATH[$i]}" || die
133 + echo 'node.max_local_storage_nodes: 2' >> "${ES_CONFIG_PATH[$i]}" || die
134 + transport=$((${ES_PORT[$i]}+100))
135 + echo "transport.port: ${transport}" >> "${ES_CONFIG_PATH[$i]}" || die
136 + echo "discovery.seed_hosts: [\"localhost:${transport}\"]" >> "${ES_CONFIG_PATH[$i]}" || die
137 + echo "discovery.type: single-node" >> "${ES_CONFIG_PATH[$i]}" || die
138 + done
139 +
140 + echo 'path.repo: /' >> "${ES_CONFIG_PATH[local]}" || die
141 + echo "reindex.remote.whitelist: localhost:${ES_PORT[remote]}" >> "${ES_CONFIG_PATH[local]}" || die
142 +
143 + # start ES instances
144 + for i in ${ES_INSTANCES}; do
145 + ES_PATH_CONF=${ES_CONFIG_DIR[$i]} "${ES_PATH}/bin/elasticsearch" -d -p "${ES_PID[$i]}" || die
146 +
147 + local j
148 + local es_started=0
149 + for j in {1..30}; do
150 + grep -q "started" "${ES_LOG[$i]}" 2> /dev/null
151 + if [[ $? -eq 0 ]]; then
152 + einfo "Elasticsearch $i started"
153 + es_started=1
154 + eend 0
155 + break
156 + elif grep -q 'BindException\[Address already in use\]' "${ES_LOG[$i]}" 2>/dev/null; then
157 + eend 1
158 + eerror "Elasticsearch $i already running"
159 + die "Cannot start Elasticsearch $i for tests"
160 + else
161 + einfo "Waiting for Elasticsearch $i"
162 + eend 1
163 + sleep 2
164 + continue
165 + fi
166 + done
167 +
168 + [[ $es_started -eq 0 ]] && die "Elasticsearch failed to start"
169 + done
170 +
171 + export TEST_ES_SERVER="localhost:${ES_PORT[local]}"
172 + export REMOTE_ES_SERVER="localhost:${ES_PORT[remote]}"
173 +
174 + # run tests
175 + nosetests -v || die
176 +
177 + for i in ${ES_INSTANCES}; do
178 + pkill -F ${ES_PID[$i]}
179 + done
180 +}
181 +
182 +python_install_all() {
183 + use doc && local HTML_DOCS=( docs/_build/html/. )
184 + doman docs/_build/man/*
185 + distutils-r1_python_install_all
186 +}
187 +
188 +pkg_postinst() {
189 + ewarn ""
190 + ewarn "For Python 3 support information please read: http://click.pocoo.org/latest/python3/"
191 + ewarn ""
192 + ewarn "Example usage on Python 3:"
193 + ewarn "export LC_ALL=en_US.UTF-8"
194 + ewarn "export LANG=en_US.UTF-8"
195 + ewarn "curator ..."
196 +}