Drop Python 2 support in middleware/gateway

... because Swift is finally removing its support for Python 2.

Change-Id: I1913e7ceeaf06f7bd2ae1d69d5d1ecf8ddc71e35
This commit is contained in:
Takashi Kajinami 2022-03-16 09:45:28 +09:00
parent 132d3509f2
commit 302b73ca17
12 changed files with 18 additions and 171 deletions

View File

@ -16,14 +16,6 @@ shift
ant build_storlets ant build_storlets
if [ ${USE_PYTHON3} == "False" ]; then
# TODO(takashi): We should use python-swiftclent 3.8.1 to avoid connection
# leak on py2.7(lp#1873435). Remove this once we get a fixed
# version released.
pip uninstall python-swiftclient
pip install python-swiftclient==3.8.1
fi
SRC_DIR=$(cd $(dirname $0); pwd) SRC_DIR=$(cd $(dirname $0); pwd)
cd ${SRC_DIR}/tests/functional cd ${SRC_DIR}/tests/functional
if [ "$FLAVOR" == "jenkins" ]; then if [ "$FLAVOR" == "jenkins" ]; then

View File

@ -1,17 +1,14 @@
- project: - project:
templates: templates:
- openstack-python-jobs
- openstack-python3-zed-jobs - openstack-python3-zed-jobs
- publish-openstack-docs-pti - publish-openstack-docs-pti
- release-notes-jobs-python3 - release-notes-jobs-python3
check: check:
jobs: jobs:
- storlets-functional - storlets-functional
- storlets-functional-py3
gate: gate:
jobs: jobs:
- storlets-functional - storlets-functional
- storlets-functional-py3
- job: - job:
name: storlets-functional name: storlets-functional
@ -20,19 +17,6 @@
post-run: playbooks/storlets-functional/post.yaml post-run: playbooks/storlets-functional/post.yaml
nodeset: ubuntu-focal nodeset: ubuntu-focal
timeout: 2400 timeout: 2400
voting: false
irrelevant-files:
- ^(api-ref|doc|releasenotes)/.*$
- ^(.gitreview|.mailmap|AUTHORS|CHANGELOG)$
- ^tests/unit/.*$
- job:
name: storlets-functional-py3
pre-run: playbooks/storlets-functional/pre-py3.yaml
run: playbooks/storlets-functional/run-py3.yaml
post-run: playbooks/storlets-functional/post-py3.yaml
nodeset: ubuntu-focal
timeout: 2400
irrelevant-files: irrelevant-files:
- ^(api-ref|doc|releasenotes)/.*$ - ^(api-ref|doc|releasenotes)/.*$
- ^(.gitreview|.mailmap|AUTHORS|CHANGELOG)$ - ^(.gitreview|.mailmap|AUTHORS|CHANGELOG)$

View File

@ -1,18 +0,0 @@
ENABLE_HTTPD_MOD_WSGI_SERVICES=False
ENABLED_SERVICES=key,swift,mysql
# We need stable/train keystone to run it on python2
KEYSTONE_BRANCH=stable/train
HOST_IP=127.0.0.1
ADMIN_PASSWORD=admin
MYSQL_PASSWORD=$ADMIN_PASSWORD
RABBIT_PASSWORD=$ADMIN_PASSWORD
SERVICE_PASSWORD=$ADMIN_PASSWORD
SWIFT_SERVICE_PROTOCOL=${SWIFT_SERVICE_PROTOCOL:-http}
SWIFT_DEFAULT_BIND_PORT=${SWIFT_DEFAULT_BIND_PORT:-8080}
# service local host is used for ring building
SWIFT_SERVICE_LOCAL_HOST=$HOST_IP
# service listen address for prox
SWIFT_SERVICE_LISTEN_ADDRESS=$HOST_IP
SWIFT_LOOPBACK_DISK_SIZE=20G
SWIFT_MAX_FILE_SIZE=5368709122
SWIFT_HASH=1234567890

View File

@ -125,11 +125,7 @@ function configure_swift_and_keystone_for_storlets {
_generate_swift_middleware_conf _generate_swift_middleware_conf
_generate_storlet-docker-gateway _generate_storlet-docker-gateway
if [ "${USE_PYTHON3}" == "False" ]; then sudo python3 devstack/swift_config.py install /tmp/swift_middleware_conf $STORLETS_SWIFT_RUNTIME_USER
sudo python2 devstack/swift_config.py install /tmp/swift_middleware_conf $STORLETS_SWIFT_RUNTIME_USER
else
sudo python3 devstack/swift_config.py install /tmp/swift_middleware_conf $STORLETS_SWIFT_RUNTIME_USER
fi
rm /tmp/swift_middleware_conf rm /tmp/swift_middleware_conf
rm /tmp/storlet-docker-gateway.conf rm /tmp/storlet-docker-gateway.conf

View File

@ -1,52 +0,0 @@
---
- hosts: all
tasks:
- name: Create log directory to pull
file:
path: '{{ zuul.project.src_dir }}/logs'
state: directory
- name: Prepare the logs into user space
shell: "egrep {{ item }} /var/log/syslog > {{ zuul.project.src_dir }}/logs/{{ item }}.log"
with_items:
- "account-server"
- "container-server"
- "object-server"
- "proxy-server"
- "ansible"
- "storlets-daemon"
- "daemon-factory"
become: yes
- name: Change log permisson as readable
file:
path: "{{ zuul.project.src_dir }}/logs/{{ item }}.log"
mode: 0644
with_items:
- "account-server"
- "container-server"
- "object-server"
- "proxy-server"
- "ansible"
- "storlets-daemon"
- "daemon-factory"
become: yes
- name: Copy logs from worker nodes to executor node
synchronize:
# TODO: make it sort of tox_envdir
src: '{{ zuul.project.src_dir }}/logs'
dest: '{{ zuul.executor.log_root }}'
mode: pull
copy_links: true
verify_host: true
ignore_errors: yes
- name: Copy conf files from worker nodes to executor node
synchronize:
src: '/etc/swift'
dest: '{{ zuul.executor.log_root }}'
mode: pull
copy_links: true
verify_host: true
ignore_errors: yes

View File

@ -1,24 +0,0 @@
---
- hosts: all
tasks:
- name: installing python3 packages
package: name={{ item }} state=present
with_items:
- python3
- python3-venv
- python3-nose
- python3-pip
become: yes
- shell:
cmd: |
set -e
set -x
./s2aio.sh install
executable: /bin/bash
chdir: 'src/{{ zuul.project.canonical_name }}'
environment:
USE_PYTHON3: "True"
roles:
- ensure-tox

View File

@ -1,6 +1,15 @@
--- ---
- hosts: all - hosts: all
tasks: tasks:
- name: installing python3 packages
package: name={{ item }} state=present
with_items:
- python3
- python3-venv
- python3-nose
- python3-pip
become: yes
- shell: - shell:
cmd: | cmd: |
set -e set -e
@ -8,8 +17,6 @@
./s2aio.sh install ./s2aio.sh install
executable: /bin/bash executable: /bin/bash
chdir: 'src/{{ zuul.project.canonical_name }}' chdir: 'src/{{ zuul.project.canonical_name }}'
environment:
USE_PYTHON3: "False"
roles: roles:
- ensure-tox - ensure-tox

View File

@ -1,6 +0,0 @@
---
- hosts: all
roles:
- tox
vars:
- tox_envlist: func-py3

View File

@ -3,6 +3,4 @@
roles: roles:
- tox - tox
vars: vars:
- tox_envlist: func-py3 - tox_envlist: func
environment:
USE_PYTHON3: "False"

View File

@ -33,12 +33,8 @@ function usage {
function _prepare_devstack_env { function _prepare_devstack_env {
# Checkout devstack # Checkout devstack
if [ ! -e $DEVSTACK_DIR ]; then if [ ! -e $DEVSTACK_DIR ]; then
git clone https://github.com/openstack/devstack.git $DEVSTACK_DIR git clone https://github.com/openstack-dev/devstack.git $DEVSTACK_DIR
if [ ${USE_PYTHON3} == "False" ]; then cp devstack/localrc.sample $DEVSTACK_DIR/localrc
cp devstack/localrc.py2.sample $DEVSTACK_DIR/localrc
else
cp devstack/localrc.sample $DEVSTACK_DIR/localrc
fi
fi fi
source $DEVSTACK_DIR/stackrc source $DEVSTACK_DIR/stackrc

View File

@ -6,6 +6,7 @@ description_file =
author = OpenStack author = OpenStack
author_email = openstack-discuss@lists.openstack.org author_email = openstack-discuss@lists.openstack.org
home_page = https://docs.openstack.org/storlets/latest/ home_page = https://docs.openstack.org/storlets/latest/
python_requires = >=3.6
classifier = classifier =
Environment :: OpenStack Environment :: OpenStack
Intended Audience :: Information Technology Intended Audience :: Information Technology
@ -13,13 +14,12 @@ classifier =
License :: OSI Approved :: Apache Software License License :: OSI Approved :: Apache Software License
Operating System :: POSIX :: Linux Operating System :: POSIX :: Linux
Programming Language :: Python Programming Language :: Python
Programming Language :: Python :: 2
Programming Language :: Python :: 2.7
Programming Language :: Python :: 3 Programming Language :: Python :: 3
Programming Language :: Python :: 3.6 Programming Language :: Python :: 3.6
Programming Language :: Python :: 3.7 Programming Language :: Python :: 3.7
Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.8
Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.9
Programming Language :: Python :: 3 :: Only
[pbr] [pbr]
skip_authors = True skip_authors = True

32
tox.ini
View File

@ -1,11 +1,12 @@
[tox] [tox]
minversion = 3.2.0 minversion = 3.2.0
envlist = py27,py36,py38,py39,pep8 envlist = py36,py38,py39,pep8
skipsdist = True skipsdist = True
ignore_basepython_conflict = True ignore_basepython_conflict = True
[testenv] [testenv]
basepython = python3
usedevelop = True usedevelop = True
setenv = setenv =
VIRTUAL_ENV={envdir} VIRTUAL_ENV={envdir}
@ -27,46 +28,24 @@ whitelist_externals = bash
rm rm
[testenv:pep8python] [testenv:pep8python]
basepython = python3
commands = commands =
flake8 flake8
flake8 --filename=* bin --exclude=bin/*.sh flake8 --filename=* bin --exclude=bin/*.sh
[testenv:py27] [testenv:func]
deps = deps =
-c{toxinidir}/py2-constraints.txt
-r{toxinidir}/requirements.txt
-r{toxinidir}/test-requirements.txt -r{toxinidir}/test-requirements.txt
git+https://github.com/openstack/swift.git git+https://github.com/openstack/swift.git
[testenv:func]
basepython = python2.7
deps = {[testenv:py27]deps}
setenv = setenv =
VIRTUAL_ENV={envdir} VIRTUAL_ENV={envdir}
STORLET_SAMPLE_PATH={toxinidir}/StorletSamples STORLET_SAMPLE_PATH={toxinidir}/StorletSamples
CLUSTER_CONF_DIR={toxinidir} CLUSTER_CONF_DIR={toxinidir}
commands = {toxinidir}/.functests jenkins commands = {toxinidir}/.functests jenkins
passenv = USE_PYTHON3
[testenv:func-py3]
basepython = python3
deps =
-r{toxinidir}/test-requirements.txt
git+https://github.com/openstack/swift.git
setenv =
VIRTUAL_ENV={envdir}
STORLET_SAMPLE_PATH={toxinidir}/StorletSamples
CLUSTER_CONF_DIR={toxinidir}
commands = {[testenv:func]commands}
passenv = {[testenv:func]passenv}
[testenv:venv] [testenv:venv]
basepython = python3
commands = {posargs} commands = {posargs}
[testenv:cover] [testenv:cover]
basepython = python3
setenv = setenv =
{[testenv]setenv} {[testenv]setenv}
PYTHON=coverage run --source storlets --parallel-mode PYTHON=coverage run --source storlets --parallel-mode
@ -77,7 +56,6 @@ commands =
coverage xml -o cover/coverage.xml coverage xml -o cover/coverage.xml
[testenv:docs] [testenv:docs]
basepython = python3
deps = deps =
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master} -c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
-r{toxinidir}/requirements.txt -r{toxinidir}/requirements.txt
@ -87,11 +65,9 @@ commands =
sphinx-build -a -W -E -b html doc/source doc/build/html sphinx-build -a -W -E -b html doc/source doc/build/html
[testenv:debug] [testenv:debug]
basepython = python3
commands = oslo_debug_helper {posargs} commands = oslo_debug_helper {posargs}
[testenv:bashate] [testenv:bashate]
basepython = python3
# Run bashate check for all bash scripts # Run bashate check for all bash scripts
# Ignores the following rules: # Ignores the following rules:
# E003: Indent not multiple of 4 (we prefer to use multiples of 2) # E003: Indent not multiple of 4 (we prefer to use multiples of 2)
@ -117,7 +93,6 @@ builtins = _
exclude=.venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,build exclude=.venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,build
[testenv:pep8] [testenv:pep8]
basepython = python3
commands = commands =
{[testenv:pep8python]commands} {[testenv:pep8python]commands}
{[testenv:bashate]commands} {[testenv:bashate]commands}
@ -125,6 +100,5 @@ passenv =
HOME HOME
[testenv:releasenotes] [testenv:releasenotes]
basepython = python3
deps = {[testenv:docs]deps} deps = {[testenv:docs]deps}
commands = sphinx-build -a -W -E -d releasenotes/build/doctrees -b html releasenotes/source releasenotes/build/html commands = sphinx-build -a -W -E -d releasenotes/build/doctrees -b html releasenotes/source releasenotes/build/html