diff options
author | Peter Vielberth <code@peter-vielberth.de> | 2021-02-22 00:55:41 +0100 |
---|---|---|
committer | Sam James <sam@gentoo.org> | 2021-03-09 09:44:31 +0000 |
commit | 7cef5a3f63834ef9f07c7a5ec1b7336bdc6620ac (patch) | |
tree | aa5f88a44a8cc9821586c97bfeb5cea24768bf2b /dev-python/elasticsearch-py | |
parent | dev-python/elasticsearch-curator: upgrade to 5.8.3 (diff) | |
download | gentoo-7cef5a3f63834ef9f07c7a5ec1b7336bdc6620ac.tar.gz gentoo-7cef5a3f63834ef9f07c7a5ec1b7336bdc6620ac.tar.bz2 gentoo-7cef5a3f63834ef9f07c7a5ec1b7336bdc6620ac.zip |
dev-python/elasticsearch-py: added python 3.9 support
Package-Manager: Portage-3.0.14, Repoman-3.0.2
Signed-off-by: Peter Vielberth <code@peter-vielberth.de>
Signed-off-by: Sam James <sam@gentoo.org>
Diffstat (limited to 'dev-python/elasticsearch-py')
-rw-r--r-- | dev-python/elasticsearch-py/elasticsearch-py-7.7.0-r1.ebuild | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/dev-python/elasticsearch-py/elasticsearch-py-7.7.0-r1.ebuild b/dev-python/elasticsearch-py/elasticsearch-py-7.7.0-r1.ebuild new file mode 100644 index 000000000000..ad8b35583dab --- /dev/null +++ b/dev-python/elasticsearch-py/elasticsearch-py-7.7.0-r1.ebuild @@ -0,0 +1,109 @@ +# Copyright 1999-2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +PYTHON_COMPAT=( python3_{7..9} ) +DISTUTILS_USE_SETUPTOOLS=bdepend +ES_VERSION="7.7.0" + +inherit distutils-r1 + +MY_PN=${PN/-py/} +DESCRIPTION="Official Python low-level client for Elasticsearch" +HOMEPAGE="https://github.com/elastic/elasticsearch-py" +SRC_URI="https://github.com/elastic/${PN}/archive/${PV}.tar.gz -> ${P}.tar.gz + test? ( https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-oss-${ES_VERSION}-no-jdk-linux-x86_64.tar.gz )" + +LICENSE="Apache-2.0" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="doc test" + +# tests fail in chroot +# https://github.com/elastic/elasticsearch/issues/12018 +RESTRICT="test" + +RDEPEND="dev-python/certifi[${PYTHON_USEDEP}] + >=dev-python/urllib3-1.21.1[${PYTHON_USEDEP}]" +DEPEND="${RDEPEND} + dev-python/sphinx_rtd_theme[${PYTHON_USEDEP}] + test? ( + >=dev-python/requests-2.0.0[${PYTHON_USEDEP}] + <dev-python/requests-3.0.0[${PYTHON_USEDEP}] + dev-python/nose[${PYTHON_USEDEP}] + dev-python/mock[${PYTHON_USEDEP}] + dev-python/pretty-yaml[${PYTHON_USEDEP}] + virtual/jre:* + )" +BDEPEND=">=dev-python/sphinx-1.3.1-r1" + +python_prepare_all() { + # needs numpy/pandas + sed -e '/test_serializes_numpy_bool/,+79d' \ + -e '/import numpy/d' \ + -e '/import pandas/d' \ + -i test_elasticsearch/test_serializer.py || die + + sed -e '/coverage/d' \ + -e '/nosexcover/d' \ + -i setup.py || die + + distutils-r1_python_prepare_all +} + +python_compile_all() { + emake -C docs -j1 man $(usex doc html "") +} + +# FEATURES="test -usersandbox" emerge dev-python/elasticsearch-py +python_test() { + local es="${WORKDIR}/elasticsearch-${ES_VERSION}" + local es_port="25124" + local es_instance="gentoo-es-py-test" + local es_log="${es}/logs/${es_instance}.log" + local pid="${es}/elasticsearch.pid" + export JAVA_HOME=$(java-config -g JAVA_HOME || die) + + # run Elasticsearch instance on custom port + sed -i "s/#http.port: 9200/http.port: ${es_port}/g; \ + s/#cluster.name: my-application/cluster.name: ${es_instance}/g" \ + "${es}/config/elasticsearch.yml" || die + + # start local instance of elasticsearch + "${es}"/bin/elasticsearch -d -p "${pid}" -Epath.repo=/ || die + + local i + local es_started=0 + for i in {1..20}; do + grep -q "started" ${es_log} 2> /dev/null + if [[ $? -eq 0 ]]; then + einfo "Elasticsearch started" + es_started=1 + eend 0 + break + elif grep -q 'BindException\[Address already in use\]' "${es_log}" 2>/dev/null; then + eend 1 + eerror "Elasticsearch already running" + die "Cannot start Elasticsearch for tests" + else + einfo "Waiting for Elasticsearch" + eend 1 + sleep 2 + continue + fi + done + + [[ $es_started -eq 0 ]] && die "Elasticsearch failed to start" + + export ELASTICSEARCH_HOST="localhost:${es_port}" + nosetests -v || die + + pkill -F ${pid} || die +} + +python_install_all() { + use doc && HTML_DOCS=( docs/_build/html/. ) + doman docs/_build/man/* + distutils-r1_python_install_all +} |