86>May 31 00:46:39 userdel[2922540]: delete user 'rooter'
<86>May 31 00:46:39 userdel[2922540]: removed group 'rooter' owned by 'rooter'
<86>May 31 00:46:39 userdel[2922540]: removed shadow group 'rooter' owned by 'rooter'
<86>May 31 00:46:39 groupadd[2922555]: group added to /etc/group: name=rooter, GID=942
<86>May 31 00:46:39 groupadd[2922555]: group added to /etc/gshadow: name=rooter
<86>May 31 00:46:39 groupadd[2922555]: new group: name=rooter, GID=942
<86>May 31 00:46:39 useradd[2922567]: new user: name=rooter, UID=942, GID=942, home=/root, shell=/bin/bash
<86>May 31 00:46:39 userdel[2922580]: delete user 'builder'
<86>May 31 00:46:39 userdel[2922580]: removed group 'builder' owned by 'builder'
<86>May 31 00:46:39 userdel[2922580]: removed shadow group 'builder' owned by 'builder'
<86>May 31 00:46:39 groupadd[2922595]: group added to /etc/group: name=builder, GID=943
<86>May 31 00:46:39 groupadd[2922595]: group added to /etc/gshadow: name=builder
<86>May 31 00:46:39 groupadd[2922595]: new group: name=builder, GID=943
<86>May 31 00:46:39 useradd[2922601]: new user: name=builder, UID=943, GID=943, home=/usr/src, shell=/bin/bash
/usr/src/in/srpm/python3-module-pyresttest-1.7.1-alt1.src.rpm: license not found in '/usr/share/license' directory: ASLv2.0
<13>May 31 00:46:40 rpmi: mpdecimal-2.5.1-alt1 sisyphus+291245.40.54.1 1643293433 installed
<13>May 31 00:46:40 rpmi: libgdbm-1.8.3-alt10 sisyphus+278100.1600.1.1 1626058413 installed
<13>May 31 00:46:40 rpmi: libexpat-2.4.7-alt1 sisyphus+296417.100.1.1 1646812525 installed
<13>May 31 00:46:40 rpmi: libp11-kit-0.24.1-alt1 sisyphus+293720.100.1.1 1642535264 installed
<13>May 31 00:46:40 rpmi: libtasn1-4.18.0-alt1 sisyphus+294217.100.3.1 1643755522 installed
<13>May 31 00:46:40 rpmi: rpm-macros-alternatives-0.5.2-alt1 sisyphus+300869.100.1.1 1653844113 installed
<13>May 31 00:46:40 rpmi: alternatives-0.5.2-alt1 sisyphus+300869.100.1.1 1653844113 installed
<13>May 31 00:46:40 rpmi: ca-certificates-2022.04.01-alt1 sisyphus+297635.100.1.1 1648830809 installed
<13>May 31 00:46:40 rpmi: ca-trust-0.1.3-alt1 sisyphus+299449.100.1.1 1651660001 installed
<13>May 31 00:46:40 rpmi: p11-kit-trust-0.24.1-alt1 sisyphus+293720.100.1.1 1642535264 installed
<13>May 31 00:46:40 rpmi: libcrypto1.1-1.1.1n-alt2 sisyphus+297394.100.2.1 1648745095 installed
<13>May 31 00:46:40 rpmi: libssl1.1-1.1.1n-alt2 sisyphus+297394.100.2.1 1648745095 installed
<13>May 31 00:46:40 rpmi: python3-3.10.4-alt1 sisyphus+297487.100.1.1 1648620051 installed
<13>May 31 00:46:41 rpmi: python3-base-3.10.4-alt1 sisyphus+297487.100.1.1 1648620051 installed
<13>May 31 00:46:41 rpmi: tests-for-installed-python3-pkgs-0.1.18-alt1 sisyphus+290420.100.1.1 1637593698 installed
<13>May 31 00:46:41 rpmi: rpm-build-python3-0.1.18-alt1 sisyphus+290420.100.1.1 1637593698 installed
<13>May 31 00:46:42 rpmi: python3-module-attrs-21.4.0-alt1 sisyphus+295177.100.1.1 1644522092 installed
<13>May 31 00:46:42 rpmi: python3-module-pkg_resources-1:62.0.0-alt1 sisyphus+297628.2400.4.1 1649344501 installed
<13>May 31 00:46:42 rpmi: python3-module-six-1.16.0-alt1 sisyphus+283489.100.2.1 1629527308 installed
<13>May 31 00:46:42 rpmi: python3-module-idna-3.3-alt1 sisyphus+288800.100.1.1 1635936399 installed
<13>May 31 00:46:42 rpmi: python3-module-zope.interface-5.4.0-alt2 sisyphus+291245.43540.56.1 1643370969 installed
<13>May 31 00:46:42 rpmi: python3-module-greenlet-1.1.2-alt1 sisyphus+291245.12740.54.1 1643301952 installed
<13>May 31 00:46:42 rpmi: python3-module-multidict-4.5.2-alt2 sisyphus+291245.31300.55.1 1643340893 installed
<13>May 31 00:46:42 rpmi: python3-module-frozenlist-1.3.0-alt1 sisyphus+295017.1200.2.1 1644497931 installed
<13>May 31 00:46:42 rpmi: python3-module-charset-normalizer-2.0.6-alt1 sisyphus+286375.600.1.1 1633362792 installed
<13>May 31 00:46:42 rpmi: libidn2-2.3.2-alt1 sisyphus+281238.100.1.2 1627476321 installed
<13>May 31 00:46:42 rpmi: python3-module-aiosignal-1.2.0-alt1 sisyphus+295017.1300.2.1 1644497946 installed
<13>May 31 00:46:42 rpmi: python3-module-yarl-1.7.2-alt1 sisyphus+295017.100.2.1 1644497764 installed
<13>May 31 00:46:42 rpmi: python3-module-idna_ssl-1.1.0-alt2 sisyphus+272418.100.1.1 1621876529 installed
<13>May 31 00:46:42 rpmi: python3-module-hyperlink-19.0.0-alt2 sisyphus+281997.100.1.1 1628173385 installed
<13>May 31 00:46:42 rpmi: python3-module-outcome-1.0.0-alt1 sisyphus+275966.100.1.1 1624808278 installed
<13>May 31 00:46:42 rpmi: python3-module-pyrsistent-0.18.1-alt1 sisyphus+297870.100.1.1 1649148541 installed
<13>May 31 00:46:42 rpmi: python3-module-sqlparse-0.4.2-alt1 sisyphus+286926.100.1.1 1634051262 installed
<13>May 31 00:46:42 rpmi: python3-module-pytz-1:2021.1-alt1 sisyphus+267903.400.1.1 1615896636 installed
<13>May 31 00:46:42 rpmi: python3-module-asgiref-3.4.1-alt1 sisyphus+283297.40.2.1 1629315886 installed
<13>May 31 00:46:42 rpmi: python3-module-click-8.1.2-alt1 sisyphus+297628.100.4.1 1649343929 installed
<13>May 31 00:46:42 rpmi: python3-module-incremental-21.3.0-alt1 sisyphus+277407.100.1.1 1625535091 installed
<13>May 31 00:46:42 rpmi: python3-module-constantly-15.1.0-alt6 sisyphus+284854.100.1.1 1631108193 installed
<13>May 31 00:46:42 rpmi: python3-module-pygobject-2.28.6-alt12 sisyphus+291245.50660.59.1 1643600793 installed
<13>May 31 00:46:42 rpmi: python3-module-appdirs-1.4.4-alt1 sisyphus+267613.300.2.1 1620039159 installed
<13>May 31 00:46:43 rpmi: python3-module-pycares-2.3.0-alt2 sisyphus+291245.47700.56.1 1643373706 installed
<13>May 31 00:46:43 rpmi: python3-module-certifi-2021.5.30-alt1 sisyphus+286375.2700.3.1 1633434210 installed
<13>May 31 00:46:43 rpmi: python3-module-openid-3.2.0-alt1 sisyphus+278049.100.2.1 1625998936 installed
<13>May 31 00:46:43 rpmi: python3-module-z3c-3.0.0-alt4 sisyphus+284857.200.1.1 1631109149 installed
<13>May 31 00:46:43 rpmi: python3-module-zc-1.0.0-alt7 sisyphus+284857.100.1.1 1631109117 installed
<13>May 31 00:46:43 rpmi: python3-module-zope-3.3.0-alt9 sisyphus+281937.200.4.1 1628175900 installed
<13>May 31 00:46:43 rpmi: python3-module-zope.event-4.4-alt2 sisyphus+281937.400.4.1 1628175930 installed
<13>May 31 00:46:43 rpmi: python3-module-sortedcontainers-2.4.0-alt1 sisyphus+272042.100.1.1 1621262424 installed
<13>May 31 00:46:43 rpmi: python3-module-sniffio-1.2.0-alt1 sisyphus+295017.1600.2.1 1644498020 installed
<13>May 31 00:46:43 rpmi: python3-module-pycparser-2.20-alt2 sisyphus+278697.200.1.1 1626167452 installed
<13>May 31 00:46:43 rpmi: python3-module-cffi-1.15.0-alt1 sisyphus+291245.7540.54.1 1643301220 installed
<13>May 31 00:46:43 rpmi: python3-module-cryptography-37.0.2-alt1 sisyphus+299462.200.1.1 1651672022 installed
<13>May 31 00:46:43 rpmi: python3-module-openssl-22.0.0-alt1 sisyphus+297852.100.1.1 1649097500 installed
<13>May 31 00:46:43 rpmi: python3-module-urllib3-2:1.26.6-alt3 sisyphus+283224.100.2.2 1629257365 installed
<13>May 31 00:46:43 rpmi: python3-module-requests-2.27.1-alt1 sisyphus+295017.300.2.1 1644497798 installed
<13>May 31 00:46:43 rpmi: python3-module-async_generator-1.10-alt2 sisyphus+274601.674.9.1 1623852161 installed
<13>May 31 00:46:43 rpmi: python3-module-astor-0.8.1-alt1 sisyphus+295365.100.1.1 1644847432 installed
<13>May 31 00:46:43 rpmi: python3-module-trio-0.19.0-alt1 sisyphus+295365.200.1.1 1644847449 installed
<13>May 31 00:46:43 rpmi: python3-module-dns-1:2.2.0-alt1 sisyphus+294114.1200.10.1 1646418229 installed
<13>May 31 00:46:43 rpmi: python3-module-async-timeout-4.0.2-alt1 sisyphus+295017.1100.2.1 1644497909 installed
<13>May 31 00:46:43 rpmi: python3-module-Cheetah-3.2.6-alt2 sisyphus+291245.53000.56.1 1643375128 installed
<13>May 31 00:46:43 rpmi: python3-module-paste-3.5.0-alt1 sisyphus+278050.10.9.1 1625992949 installed
<13>May 31 00:46:43 rpmi: python3-module-PasteDeploy-1:2.0.1-alt2 sisyphus+272419.200.2.1 1621909319 installed
<13>May 31 00:46:43 rpmi: python3-module-PasteScript-1:2.0.2-alt2 sisyphus+272468.100.1.1 1621939313 installed
<13>May 31 00:46:43 rpmi: libyaml2-0.2.5-alt1 sisyphus+278391.100.1.1 1626094928 installed
<13>May 31 00:46:43 rpmi: python3-module-yaml-6.0-alt1 sisyphus+295017.400.2.1 1644497823 installed
<13>May 31 00:46:43 rpmi: libuv-1.44.1-alt1 sisyphus+297750.100.1.1 1648981565 installed
<13>May 31 00:46:43 rpmi: libpython-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python2-base-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-encodings-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-compiler-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-email-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-unittest-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-ctypes-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-multiprocessing-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: python-modules-logging-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:43 rpmi: libmaxminddb-1.6.0-alt1 sisyphus+279468.100.1.1 1626548147 installed
<13>May 31 00:46:43 rpmi: python3-module-MaxMindDB-2.2.0-alt1 sisyphus+291245.47100.56.1 1643373447 installed
<13>May 31 00:46:43 rpmi: libusb-1.0.26-alt1 sisyphus+298877.100.1.1 1650636948 installed
<13>May 31 00:46:43 rpmi: libhidapi-0.11.2-alt1_1 sisyphus+293914.100.1.1 1642796337 installed
<13>May 31 00:46:43 rpmi: python3-module-cython-hidapi-0.10.1-alt1 sisyphus+291245.27500.54.1 1643306551 installed
<13>May 31 00:46:43 rpmi: python3-module-serial-3.5-alt2 sisyphus+281995.100.1.1 1628172783 installed
<13>May 31 00:46:43 rpmi: python3-module-automat-20.2.0-alt2 sisyphus+275898.100.1.2 1624826834 installed
<13>May 31 00:46:43 rpmi: python3-module-twisted-logger-20.3.0-alt3 sisyphus+291245.44300.56.1 1643371282 installed
<13>May 31 00:46:43 rpmi: python3-module-twisted-words-20.3.0-alt3 sisyphus+291245.44300.56.1 1643371282 installed
<13>May 31 00:46:43 rpmi: python3-module-twisted-core-20.3.0-alt3 sisyphus+291245.44300.56.1 1643371282 installed
<13>May 31 00:46:43 rpmi: python3-module-twisted-names-20.3.0-alt3 sisyphus+291245.44300.56.1 1643371282 installed
<13>May 31 00:46:43 rpmi: python3-module-tornado-6.1.0-alt2.1 sisyphus+295257.100.1.1 1644644183 installed
<13>May 31 00:46:43 rpmi: libev4-4.33-alt2 sisyphus+286828.100.2.3 1634005197 installed
<13>May 31 00:46:43 rpmi: publicsuffix-list-dafsa-20220406-alt1 sisyphus+297986.100.1.1 1649274774 installed
<13>May 31 00:46:43 rpmi: libpsl-0.21.1-alt2 sisyphus+279461.100.1.1 1626547547 installed
<13>May 31 00:46:43 rpmi: libnghttp2-1.47.0-alt1 sisyphus+297351.100.1.1 1648403625 installed
<13>May 31 00:46:43 rpmi: openldap-common-2.4.59-alt1 sisyphus+282933.100.1.1 1629124747 installed
<13>May 31 00:46:43 rpmi: libverto-0.3.2-alt1_1 sisyphus+279289.100.1.3 1626493868 installed
<13>May 31 00:46:43 rpmi: liblmdb-0.9.23-alt1 sisyphus+275369.100.1.2 1624493869 installed
<13>May 31 00:46:43 rpmi: libkeyutils-1.6.3-alt1 sisyphus+266061.100.1.1 1612919566 installed
<13>May 31 00:46:43 rpmi: libcom_err-1.46.4.0.5.4cda-alt1 sisyphus+283826.100.1.1 1629975345 installed
<86>May 31 00:46:43 groupadd[2948843]: group added to /etc/group: name=_keytab, GID=499
<86>May 31 00:46:43 groupadd[2948843]: group added to /etc/gshadow: name=_keytab
<86>May 31 00:46:43 groupadd[2948843]: new group: name=_keytab, GID=499
<13>May 31 00:46:43 rpmi: libkrb5-1.19.3-alt1 sisyphus+296671.100.1.1 1647339827 installed
<86>May 31 00:46:43 groupadd[2949333]: group added to /etc/group: name=sasl, GID=498
<86>May 31 00:46:43 groupadd[2949333]: group added to /etc/gshadow: name=sasl
<86>May 31 00:46:43 groupadd[2949333]: new group: name=sasl, GID=498
<13>May 31 00:46:43 rpmi: libsasl2-3-2.1.27-alt2.2 sisyphus+282040.40.2.1 1628929840 installed
<13>May 31 00:46:43 rpmi: libldap-2.4.59-alt1 sisyphus+282933.100.1.1 1629124747 installed
<13>May 31 00:46:43 rpmi: libpq5-14.3-alt1 sisyphus+299761.100.1.1 1652255400 installed
<13>May 31 00:46:43 rpmi: python3-module-psycopg2-2.9.3-alt1 sisyphus+298449.100.1.1 1649956329 installed
<13>May 31 00:46:43 rpmi: python3-module-eventlet-0.33.0-alt1 sisyphus+294114.1300.10.1 1646418303 installed
<13>May 31 00:46:43 rpmi: libcares-1.18.1-alt1 sisyphus+290569.100.1.1 1637850388 installed
<13>May 31 00:46:43 rpmi: python3-module-gevent-21.12.0-alt1 sisyphus+291245.44020.58.1 1643518687 installed
<13>May 31 00:46:44 rpmi: python3-module-gunicorn-20.1.0-alt2 sisyphus+297766.100.1.1 1649054912 installed
<13>May 31 00:46:44 rpmi: python3-module-aiohttp-3.8.1-alt2 sisyphus+295203.100.1.1 1644579839 installed
<13>May 31 00:46:44 rpmi: python3-module-GeoIP2-4.5.0-alt1 sisyphus+290966.100.1.1 1638195969 installed
<13>May 31 00:46:44 rpmi: libbrotlicommon-1.0.9-alt2 sisyphus+278430.100.1.2 1626213212 installed
<13>May 31 00:46:44 rpmi: libbrotlidec-1.0.9-alt2 sisyphus+278430.100.1.2 1626213212 installed
<13>May 31 00:46:44 rpmi: libcurl-7.83.1-alt1 sisyphus+299767.100.1.1 1652258369 installed
<13>May 31 00:46:44 rpmi: python3-module-pycurl-7.43.0.6-alt3 sisyphus+291245.17600.54.1 1643303211 installed
<13>May 31 00:46:44 rpmi: python3-module-django-3.2.13-alt1 sisyphus+298293.100.1.1 1649741323 installed
<13>May 31 00:46:44 rpmi: python-tools-2to3-2.7.18-alt9 sisyphus+296565.100.1.1 1647092059 installed
<13>May 31 00:46:44 rpmi: python3-module-jsonschema-4.5.1-alt1 sisyphus+299579.100.1.1 1651858598 installed
Building target platforms: x86_64
Building for target x86_64
Wrote: /usr/src/in/nosrpm/python3-module-pyresttest-1.7.1-alt1.nosrc.rpm (w1.gzdio)
<13>May 31 00:46:45 rpmi: libpython3-3.10.4-alt1 sisyphus+297487.100.1.1 1648620051 installed
<13>May 31 00:46:45 rpmi: libncurses-6.3.20211106-alt2 sisyphus+294456.100.3.1 1643966445 installed
<13>May 31 00:46:45 rpmi: libtinfo-devel-6.3.20211106-alt2 sisyphus+294456.100.3.1 1643966445 installed
<13>May 31 00:46:45 rpmi: libncurses-devel-6.3.20211106-alt2 sisyphus+294456.100.3.1 1643966445 installed
<13>May 31 00:46:46 rpmi: python3-dev-3.10.4-alt1 sisyphus+297487.100.1.1 1648620051 installed
<13>May 31 00:46:46 rpmi: python3-module-setuptools-1:62.0.0-alt1 sisyphus+297628.2400.4.1 1649344501 installed
Installing python3-module-pyresttest-1.7.1-alt1.src.rpm
Building target platforms: x86_64
Building for target x86_64
Executing(%prep): /bin/sh -e /usr/src/tmp/rpm-tmp.15027
+ umask 022
+ /bin/mkdir -p /usr/src/RPM/BUILD
+ cd /usr/src/RPM/BUILD
+ cd /usr/src/RPM/BUILD
+ rm -rf python3-module-pyresttest-1.7.1
+ echo 'Source #0 (python3-module-pyresttest-1.7.1.tar):'
Source #0 (python3-module-pyresttest-1.7.1.tar):
+ /bin/tar -xf /usr/src/RPM/SOURCES/python3-module-pyresttest-1.7.1.tar
+ cd python3-module-pyresttest-1.7.1
+ /bin/chmod -c -Rf u+rwX,go-w .
+ chmod +x run_tests.sh
+ find ./ -type f -name '*.py' -exec 2to3 -w -n '{}' +
RefactoringTool: Skipping optional fixer: buffer
RefactoringTool: Skipping optional fixer: idioms
RefactoringTool: Skipping optional fixer: set_literal
RefactoringTool: Skipping optional fixer: ws_comma
RefactoringTool: No changes to ./util/profile_basic_test.py
RefactoringTool: No changes to ./setup.py
RefactoringTool: Refactored ./sample_extension.py
RefactoringTool: Refactored ./pyresttest/validators.py
--- ./sample_extension.py (original)
+++ ./sample_extension.py (refactored)
@@ -5,7 +5,7 @@
# Python 3 compatibility
if sys.version_info[0] > 2:
- from past.builtins import basestring
+ from past.builtins import str
from pyresttest.six import text_type
from pyresttest.six import binary_type
@@ -28,7 +28,7 @@
@staticmethod
def parse(config):
""" Parse a contains validator, which takes as the config a simple string to find """
- if not isinstance(config, basestring):
+ if not isinstance(config, str):
raise TypeError("Contains input must be a simple string")
validator = ContainsValidator()
validator.contains_string = config
--- ./pyresttest/validators.py (original)
+++ ./pyresttest/validators.py (refactored)
@@ -18,8 +18,8 @@
# Python 3 compatibility
PYTHON_MAJOR_VERSION = sys.version_info[0]
if PYTHON_MAJOR_VERSION > 2:
- from past.builtins import basestring
- from past.builtins import long
+ from past.builtins import str
+ from past.builtins import int
"""
Validator/Extractor logic for utility use
@@ -70,16 +70,16 @@
TYPES = {
'null': type(None),
'none': type(None),
- 'number': (int, long, float),
- 'int': (int, long),
+ 'number': (int, int, float),
+ 'int': (int, int),
'float': float,
'boolean': bool,
- 'string': basestring,
+ 'string': str,
'array': list,
'list': list,
'dict': dict,
'map': dict,
- 'scalar': (bool, int, long, float, basestring, type(None)),
+ 'scalar': (bool, int, int, float, str, type(None)),
'collection': (list, dict, set)
}
@@ -143,7 +143,7 @@
details = None
validator = None
- def __nonzero__(self):
+ def __bool__(self):
""" Failure objects test as False, simplifies coding with them """
return False
@@ -215,7 +215,7 @@
except KeyError:
raise ValueError(
"Cannot define a dictionary config for abstract extractor without it having template key")
- elif isinstance(config, basestring):
+ elif isinstance(config, str):
extractor_base.query = config
extractor_base.is_templated = False
else:
@@ -275,7 +275,7 @@
def extract_internal(self, query=None, args=None, body=None, headers=None):
low = query.lower()
# Value for all matching key names
- extracted = [y[1] for y in filter(lambda x: x[0] == low, headers)]
+ extracted = [y[1] for y in [x for x in headers if x[0] == low]]
if len(extracted) == 0:
raise ValueError("Invalid header name {0}".format(query))
elif len(extracted) == 1:
@@ -310,7 +310,7 @@
and error if more than one or none """
extractor = None
extract_config = None
- for key, value in config_dict.items():
+ for key, value in list(config_dict.items()):
if key in EXTRACTORS:
return parse_extractor(key, value)
else: # No valid extractor
@@ -429,13 +429,13 @@
# Expected value can be another extractor query, or a single value, or
# a templated value
- if isinstance(expected, basestring) or isinstance(expected, (int, long, float, complex)):
+ if isinstance(expected, str) or isinstance(expected, (int, float, complex)):
output.expected = expected
elif isinstance(expected, dict):
expected = parsing.lowercase_keys(expected)
template = expected.get('template')
if template: # Templated string
- if not isinstance(template, basestring):
+ if not isinstance(template, str):
raise ValueError(
"Can't template a comparator-validator unless template value is a string")
output.isTemplateExpected = True
@@ -556,7 +556,7 @@
def register_extractor(extractor_name, parse_function):
""" Register a new body extraction function """
- if not isinstance(extractor_name, basestring):
+ if not isinstance(extractor_RefactoringTool: Refactored ./pyresttest/tests.py
name, str):
raise TypeError("Cannot register a non-string extractor name")
if extractor_name.lower() == 'comparator':
raise ValueError(
@@ -575,7 +575,7 @@
def register_test(test_name, test_function):
""" Register a new one-argument test function """
- if not isinstance(test_name, basestring):
+ if not isinstance(test_name, str):
raise TypeError("Cannot register a non-string test name")
elif test_name in VALIDATOR_TESTS:
raise ValueError(
@@ -585,7 +585,7 @@
def register_comparator(comparator_name, comparator_function):
""" Register a new twpo-argument comparator function returning true or false """
- if not isinstance(comparator_name, basestring):
+ if not isinstance(comparator_name, str):
raise TypeError("Cannot register a non-string comparator name")
elif comparator_name in COMPARATORS:
raise ValueError(
--- ./pyresttest/tests.py (original)
+++ ./pyresttest/tests.py (refactored)
@@ -14,10 +14,10 @@
# Find the best implementation available on this platform
try:
- from cStringIO import StringIO as MyIO
+ from io import StringIO as MyIO
except:
try:
- from StringIO import StringIO as MyIO
+ from io import StringIO as MyIO
except ImportError:
from io import BytesIO as MyIO
@@ -25,9 +25,9 @@
PYTHON_MAJOR_VERSION = sys.version_info[0]
if PYTHON_MAJOR_VERSION > 2:
import urllib.parse as urlparse
- from past.builtins import basestring
+ from past.builtins import str
else:
- import urlparse
+ import urllib.parse
# Python 3 compatibility shims
from . import six
@@ -50,11 +50,11 @@
# Map HTTP method names to curl methods
# Kind of obnoxious that it works this way...
-HTTP_METHODS = {u'GET': pycurl.HTTPGET,
- u'PUT': pycurl.UPLOAD,
- u'PATCH': pycurl.POSTFIELDS,
- u'POST': pycurl.POST,
- u'DELETE': 'DELETE'}
+HTTP_METHODS = {'GET': pycurl.HTTPGET,
+ 'PUT': pycurl.UPLOAD,
+ 'PATCH': pycurl.POSTFIELDS,
+ 'POST': pycurl.POST,
+ 'DELETE': 'DELETE'}
# Parsing helper functions
def coerce_to_string(val):
@@ -77,7 +77,7 @@
def coerce_http_method(val):
myval = val
- if not isinstance(myval, basestring) or len(val) == 0:
+ if not isinstance(myval, str) or len(val) == 0:
raise TypeError("Invalid HTTP method name: input {0} is not a string or has 0 length".format(val))
if isinstance(myval, binary_type):
myval = myval.decode('utf-8')
@@ -96,9 +96,9 @@
expected_status = [200] # expected HTTP status code or codes
_body = None
_headers = dict() # HTTP Headers
- method = u'GET'
- group = u'Default'
- name = u'Unnamed'
+ method = 'GET'
+ group = 'Default'
+ name = 'Unnamed'
validators = None # Validators for response body, IE regexes, etc
stop_on_failure = False
failures = None
@@ -157,7 +157,7 @@
""" Read body from file, applying template if pertinent """
if self._body is None:
return None
- elif isinstance(self._body, basestring):
+ elif isinstance(self._body, str):
return self._body
else:
return self._body.get_content(context=context)
@@ -204,7 +204,7 @@
def template_tuple(tuple_input):
return (string.Template(str(tuple_item)).safe_substitute(vals) for tuple_item in tuple_input)
- return dict(map(template_tuple, self._headers.items()))
+ return dict(list(map(template_tuple, list(self._headers.items()))))
headers = property(get_headers, set_headers, None,
'Headers dictionary for request')
@@ -214,13 +214,13 @@
if self.variable_binds:
context.bind_variables(self.variable_binds)
if self.generator_binds:
- for key, value in self.generator_binds.items():
+ for key, value in list(self.generator_binds.items()):
context.bind_generator_next(key, value)
def update_context_after(self, response_body, headers, context):
""" Run the extraction routines to update variables based on HTTP response body """
if self.extract_binds:
- for key, value in self.extract_binds.items():
+ for key, value in list(self.extract_binds.items()):
result = value.extract(
body=response_body, headers=headers, context=context)
context.bind_variable(key, result)
@@ -325,21 +325,21 @@
if self.auth_type:
curl.setopt(pycurl.HTTPAUTH, self.auth_type)
- if self.method == u'POST':
- curl.setopt(HTTP_METHODS[u'POST'], 1)
+ if self.method == 'POST':
+ curl.setopt(HTTP_METHODS['POST'], 1)
# Required for some servers
if bod is not None:
curl.setopt(pycurl.POSTFIELDSIZE, len(bod))
else:
curl.setopt(pycurl.POSTFIELDSIZE, 0)
- elif self.method == u'PUT':
- curl.setopt(HTTP_METHODS[u'PUT'], 1)
+ elif self.method == 'PUT':
+ curl.setopt(HTTP_METHODS['PUT'], 1)
# Required for some servers
if bod is not None:
curl.setopt(pycurl.INFILESIZE, len(bod))
else:
curl.setopt(pycurl.INFILESIZE, 0)
- elif self.method == u'PATCH':
+ elif self.method == 'PATCH':
curl.setopt(curl.POSTFIELDS, bod)
curl.setopt(curl.CUSTOMREQUEST, 'PATCH')
# Required for some servers
@@ -348,12 +348,12 @@
curl.setopt(pycurl.INFILESIZE, len(bod))
else:
curl.setopt(pycurl.INFILESIZE, 0)
- elif self.method == u'DELETE':
+ elif self.method == 'DELETE':
curl.setopt(curl.CUSTOMREQUEST, 'DELETE')
if bod is not None:
curl.setopt(pycurl.POSTFIELDS, bod)
curl.setopt(pycurl.POSTFIELDSIZE, len(bod))
- elif self.method == u'HEAD':
+ elif self.method == 'HEAD':
curl.setopt(curl.NOBODY, 1)
curl.setopt(curl.CUSTOMREQUEST, 'HEAD')
elif self.method and self.method.upper() != 'GET': # Alternate HTTP methods
@@ -368,14 +368,14 @@
# Set charset if doing unicode conversion and not set explicitly
# TESTME
- if is_unicoded and u'content-type' in head.keys():
- content = head[u'content-type']
- if u'charset' not in content:
- head[u'content-type'] = content + u' ; charset=UTF-8'
+ if is_unicoded and 'content-type' in list(head.keys()):
+ content = head['content-type']
+ if 'charset' not in content:
+ head['content-type'] = content + ' ; charset=UTF-8'
if head:
headers = [str(headername) + ':' + str(headervalue)
- for headername, headervalue in head.items()]
+ for headername, headervalue in list(head.items())]
else:
headers = list()
# Fix for expecting 100-continue from server, which not all servers
@@ -388,7 +388,7 @@
# And the key/value pairs are set
if self.curl_options:
filterfunc = lambda x: x[0] is not None and x[1] is not None # Must have key and value
- for (key, value) in ifilter(filterfunc, self.curl_options.items()):
+ for (key, value) in filter(filterfunc, list(self.curl_options.items())):
# getattr to look up constant for variable name
curl.setopt(getattr(curl, key), value)
return curl
@@ -419,19 +419,19 @@
# Simple table of variable name, coerce function, and optionally special store function
CONFIG_ELEMENTS = {
# Simple variables
- u'auth_username': [coerce_string_to_ascii],
- u'auth_password': [coerce_string_to_ascii],
- u'method': [coerce_http_method], # HTTP METHOD
- u'delay': [lambda x: int(x)], # Delay before running
- u'group': [coerce_to_string], # Test group name
- u'name': [coerce_to_string], # Test name
- u'expected_status': [coerce_list_of_ints],
- u'delay': [lambda x: int(x)],
- u'stop_on_failure': [safe_to_bool],
+ 'auth_username': [coerce_string_to_ascii],
+ 'auth_password': [coerce_string_to_ascii],
+ 'method': [coerce_http_method], # HTTP METHOD
+ 'delay': [lambda x: int(x)], # Delay before running
+ 'group': [coerce_to_string], # Test group name
+ 'name': [coerce_to_string], # Test name
+ 'expected_status': [coerce_list_of_ints],
+ 'delay': [lambda x: int(x)],
+ 'stop_on_failure': [safe_to_bool],
# Templated / special handling
#u'url': [coerce_templatable, set_templated), # TODO: special handling for templated content, sigh
- u'body': [ContentHandler.parse_content]
+ 'body': [ContentHandler.parse_content]
#u'headers': [],
# COMPLEX PARSE OPTIONS
@@ -457,31 +457,31 @@
return False
# Copy/convert input elements into appropriate form for a test object
- for configelement, configvalue in node.items():
+ for configelement, configvalue in list(node.items()):
if use_config_parser(mytest, configelement, configvalue):
continue
# Configure test using configuration elements
- if configelement == u'url':
+ if configelement == 'url':
temp = configvalue
if isinstance(configvalue, dict):
# Template is used for URL
- val = lowercase_keys(configvalue)[u'template']
- assert isinstance(val, basestring) or isinstance(val, int)
- url = urlparse.urljoin(base_url, coerce_to_string(val))
+ val = lowercase_keys(configvalue)['template']
+ assert isinstance(val, str) or isinstance(val, int)
+ url = urllib.parse.urljoin(base_url, coerce_to_string(val))
mytest.set_url(url, isTemplate=True)
else:
- assert isinstance(configvalue, basestring) or isinstance(
+ assert isinstance(configvalue, str) or isinstance(
configvalue, int)
- mytest.url = urlparse.urljoin(base_url, coerce_to_string(configvalue))
- elif configelement == u'extract_binds':
+ mytest.url = urllib.parse.urljoin(base_url, coerce_to_string(configvalue))
+ elif configelement == 'extract_binds':
# Add a list of extractors, of format:
# {variable_name: {extractor_type: extractor_config}, ... }
binds = flatten_dictionaries(configvalue)
if mytest.extract_binds is None:
mytest.extract_binds = dict()
- for variable_name, extractor in binds.items():
+ for variable_name, extractor in list(binds.items()):
if not isinstance(extractor, dict) or len(extractor) == 0:
raise TypeError(
"Extractors must be defined as maps of extractorType:{configs} with 1 entry")
@@ -490,11 +490,11 @@
"Cannot define multiple extractors for given variable name")
# Safe because length can only be 1
- for extractor_type, extractor_config in extractor.items():
+ for extractor_type, extractor_config in list(extractor.items()):
mytest.extract_binds[variable_name] = validators.parse_extractor(extractor_type, extractor_config)
- elif configelement == u'validators':
+ elif configelement == 'validators':
# Add a list of validators
if not isinstance(configvalue, list):
raise Exception(
@@ -507,7 +507,7 @RefactoringTool: No changes to ./pyresttest/testapp/testapp/wsgi.py
RefactoringTool: No changes to ./pyresttest/testapp/testapp/urls.py
RefactoringTool: No changes to ./pyresttest/testapp/testapp/settings.py
RefactoringTool: No changes to ./pyresttest/testapp/testapp/models.py
RefactoringTool: No changes to ./pyresttest/testapp/testapp/api.py
RefactoringTool: No changes to ./pyresttest/testapp/manage.py
RefactoringTool: Refactored ./pyresttest/test_validators.py
WARNING: couldn't encode ./pyresttest/test_validators.py's diff for your terminal
RefactoringTool: Refactored ./pyresttest/test_tests.py
@
if not isinstance(var, dict):
raise TypeError(
"Validators must be defined as validatorType:{configs} ")
- for validator_type, validator_config in var.items():
+ for validator_type, validator_config in list(var.items()):
validator = validators.parse_validator(
validator_type, validator_config)
mytest.validators.append(validator)
@@ -518,7 +518,7 @@
if isinstance(configvalue, dict):
filterfunc = lambda x: str(x[0]).lower() == 'template' # Templated items
- templates = [x for x in ifilter(filterfunc, configvalue.items())]
+ templates = [x for x in filter(filterfunc, list(configvalue.items()))]
else:
templates = None
@@ -535,7 +535,7 @@
elif configelement == 'generator_binds':
output = flatten_dictionaries(configvalue)
output2 = dict()
- for key, value in output.items():
+ for key, value in list(output.items()):
output2[str(key)] = str(value)
mytest.generator_binds = output2
elif configelement.startswith('curl_option_'):
@@ -552,7 +552,7 @@
# (but only if not expected statuses are not explicitly specified)
# this is per HTTP spec:
# http://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html#sec9.5
- if 'expected_status' not in node.keys():
+ if 'expected_status' not in list(node.keys()):
if mytest.method == 'POST':
mytest.expected_status = [200, 201, 204]
elif mytest.method == 'PUT':
--- ./pyresttest/test_validators.py (original)
+++ ./pyresttest/test_validators.py (refactored)
@@ -21,7 +21,7 @@
self.assertTrue(cont_func('abagooberab23', 'goob'))
self.assertTrue(cont_by_func('goob', 'abagooberab23'))
- myarray = ['math', 1, None, u'lest']
+ myarray = ['math', 1, None, 'lest']
self.assertTrue(cont_func(myarray, 1))
self.assertTrue(cont_func(myarray, None))
self.assertTrue(cont_by_func(None, myarray))
@@ -55,12 +55,12 @@
}
# Check for basic types that they pass expected values
- for mytype, myinstance in instances.items():
+ for mytype, myinstance in list(instances.items()):
try:
self.assertTrue(type_test(myinstance, mytype))
except AssertionError:
- print('Type test operator failed where should pass for type {0} and value {1}'.format(
- mytype, myinstance))
+ print(('Type test operator failed where should pass for type {0} and value {1}'.format(
+ mytype, myinstance)))
hasFailed = True
if hasFailed:
@@ -86,12 +86,12 @@
}
# Check for complex types that they don't pass expected values
- for mytype, myinstance in failing_instances.items():
+ for mytype, myinstance in list(failing_instances.items()):
try:
self.assertFalse(type_test(myinstance, mytype))
except AssertionError:
- print('Type test operator passed where should fail for type {0} and value {1}'.format(
- mytype, myinstance))
+ print(('Type test operator passed where should fail for type {0} and value {1}'.format(
+ mytype, myinstance)))
hasFailed = True
if hasFailed:
self.fail("Type test operator failed testing, see reasons above!")
@@ -177,12 +177,12 @@
self.assertEqual('val', val)
def test_jsonpathmini_unicode(self):
--- ./pyresttest/test_tests.py (original)
+++ ./pyresttest/test_tests.py (refactored)
@@ -27,25 +27,25 @@
# Parsing methods
def test_coerce_to_string(self):
- self.assertEqual(u'1', coerce_to_stringWARNING: couldn't encode ./pyresttest/test_tests.py's diff for your terminal
RefactoringTool: Refactored ./pyresttest/test_resttest.py
RefactoringTool: Refactored ./pyresttest/test_parsing.py
WARNING: couldn't encode ./pyresttest/test_parsing.py's diff for your terminal
RefactoringTool: Refactored ./pyresttest/test_generators.py
(1))
- self.assertEqual(u'stuff', coerce_to_string(u'stuff'))
- self.assertEqual(u'stuff', coerce_to_string('stuff'))
--- ./pyresttest/test_resttest.py (original)
+++ ./pyresttest/test_resttest.py (refactored)
@@ -29,7 +29,7 @@
analyzed = analyze_benchmark_results(
benchmark_result, benchmark_config)
- self.assertEqual(2, len(analyzed.results.keys()))
+ self.assertEqual(2, len(list(analyzed.results.keys())))
# Check that number of measurements is sane
distinct_metrics = set([x[0] for x in analyzed.aggregates])
@@ -50,11 +50,11 @@
headers = packed[0]
# Check header generation
- for x in xrange(0, len(keys)):
+ for x in range(0, len(keys)):
self.assertEqual(keys[x], headers[x])
# Check data was correctly converted to 2D format, in order of input
- for x in xrange(1, len(array1) + 1):
+ for x in range(1, len(array1) + 1):
my_tuple = packed[x]
self.assertEqual(array1[x - 1], my_tuple[0])
self.assertEqual(array2[x - 1], my_tuple[1])
@@ -62,7 +62,7 @@
def test_parse_headers(self):
""" Basic header parsing tests """
- headerstring = u'HTTP/1.1 200 OK\r\nDate: Mon, 29 Dec 2014 02:42:33 GMT\r\nExpires: -1\r\nCache-Control: private, max-age=0\r\nContent-Type: text/html; charset=ISO-8859-1\r\nX-XSS-Protection: 1; mode=block\r\nX-Frame-Options: SAMEORIGIN\r\nAlternate-Protocol: 80:quic,p=0.02\r\nTransfer-Encoding: chunked\r\n\r\n'
+ headerstring = 'HTTP/1.1 200 OK\r\nDate: Mon, 29 Dec 2014 02:42:33 GMT\r\nExpires: -1\r\nCache-Control: private, max-age=0\r\nContent-Type: text/html; charset=ISO-8859-1\r\nX-XSS-Protection: 1; mode=block\r\nX-Frame-Options: SAMEORIGIN\r\nAlternate-Protocol: 80:quic,p=0.02\r\nTransfer-Encoding: chunked\r\n\r\n'
header_list = resttest.parse_headers(headerstring)
header_dict = dict(header_list)
@@ -85,7 +85,7 @@
def test_parse_headers_multiples(self):
""" Test headers where there are duplicate values set """
- headerstring = u'HTTP/1.1 200 OK\r\nDate: Mon, 29 Dec 2014 02:42:33 GMT\r\nAccept: text/html\r\nAccept: application/json\r\n\r\n'
+ headerstring = 'HTTP/1.1 200 OK\r\nDate: Mon, 29 Dec 2014 02:42:33 GMT\r\nAccept: text/html\r\nAccept: application/json\r\n\r\n'
headers = resttest.parse_headers(headerstring)
self.assertTrue(isinstance(headers, list))
--- ./pyresttest/test_parsing.py (original)
+++ ./pyresttest/test_parsing.py (refactored)
@@ -12,7 +12,7 @@
def test_encode_unicode_bytes(self):
val = 8
--- ./pyresttest/test_generators.py (original)
+++ ./pyresttest/test_generators.py (refactored)
@@ -18,7 +18,7 @@
""" Basic test for a generator, checks values and applies test function """
self.assertTrue(isinstance(generator, types.GeneratorType))
- for x in xrange(0, 100):
+ for x in range(0, 100):
val = next(generator)
self.assertTrue(val is not None)
if value_test_function:
@@ -30,7 +30,7 @@
val = next(generator_input)
# Check for not repeating easily
- for x in xrange(0, 5):
+ for x in range(0, 5):
val2 = next(generator_input)
self.assertTrue(val)
self.assertTrue(val != val2)
@@ -66,7 +66,7 @@
def test_random_ids(self):
""" Test random in ids generator """
gen = generators.generator_random_int32()
- print(next(gen))
+ print((next(gen)))
self.generator_repeat_test(gen)
def test_system_variables(self):
@@ -95,10 +95,10 @@
# Test multiple charsets and string lengths
for charset in charsets:
# Test different lengths for charset
- for my_length in xrange(1, 17):
+ for my_length in range(1, 17):
gen = generators.factory_generate_text(
legal_characters=charset, min_length=my_length, max_length=my_length)()
- for x RefactoringTool: Refactored ./pyresttest/test_contenthandling.py
WARNING: couldn't encode ./pyresttest/test_contenthandling.py's diff for your terminal
RefactoringTool: No changes to ./pyresttest/test_binding.py
RefactoringTool: Refactored ./pyresttest/test_benchmarks.py
RefactoringTool: Refactored ./pyresttest/six.py
in xrange(0, 10):
+ for x in range(0, 10):
val = next(gen)
self.assertEqual(my_length, len(val))
@@ -157,7 +157,7 @@
def test_character_sets(self):
""" Verify all charsets are valid """
sets = generators.CHARACTER_SETS
- for key, value in sets.items():
+ for key, value in list(sets.items()):
self.assertTrue(value)
def test_parse_text_generator(self):
@@ -179,11 +179,11 @@
config['character_set'] = charset
gen = generators.parse_generator(config)
myset = set(generators.CHARACTER_SETS[charset])
- for x in xrange(0, 50):
+ for x in range(0, 50):
val = next(gen)
self.assertTrue(set(val).issubset(set(myset)))
except Exception as e:
- print('Exception occurred with charset: ' + charset)
+ print(('Exception occurred with charset: ' + charset))
raise e
my_min = 1
--- ./pyresttest/test_contenthandling.py (original)
+++ ./pyresttest/test_contenthandling.py (refactored)
@@ -36,23 +36,23 @@
# ASCII body, unicode data
body = '$variable value'
--- ./pyresttest/test_benchmarks.py (original)
+++ ./pyresttest/test_benchmarks.py (refactored)
@@ -77,7 +77,7 @@
def test_aggregate_computations(self):
""" Test running all the aggregates, just to see if they error """
array = [-1, 5, 2.245, 7]
- for function in AGGREGATES.values():
+ for function in list(AGGREGATES.values()):
value = function(array)
self.assertTrue(isinstance(value, int) or isinstance(value, float))
@@ -102,7 +102,7 @@
# Check that we don't add raw metrics if we do not have to
benchmark_config.add_metric('connect_time', 'mean')
self.assertEqual(1, len(benchmark_config.raw_metrics))
- self.assertEqual(2, len(benchmark_config.aggregated_metrics.keys()))
+ self.assertEqual(2, len(list(benchmark_config.aggregated_metrics.keys())))
self.assertEqual(
1, len(benchmark_config.aggregated_metrics['connect_time']))
@@ -110,7 +110,7 @@
benchmark_config.add_metric('redirect_time')
self.assertEqual(3, len(benchmark_config.metrics))
self.assertEqual(2, len(benchmark_config.raw_metrics))
- self.assertEqual(2, len(benchmark_config.aggregated_metrics.keys()))
+ self.assertEqual(2, len(list(benchmark_config.aggregated_metrics.keys())))
if __name__ == '__main__':
--- ./pyresttest/six.py (original)
+++ ./pyresttest/six.py (refactored)
@@ -20,7 +20,7 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
-from __future__ import absolute_import
+
import functools
import itertools
@@ -46,10 +46,10 @@
MAXSIZE = sys.maxsize
else:
- string_types = basestring,
- integer_types = (int, long)
- class_types = (type, types.ClassType)
- text_type = unicode
+ string_types = str,
+ integer_types = (int, int)
+ class_types = (type, type)
+ text_type = str
binary_type = str
if sys.platform.startswith("java"):
@@ -521,7 +521,7 @@
advance_iterator = next
except NameError:
def advance_iterator(it):
- return it.next()
+ return it.__next__()
next = advance_iterator
@@ -544,7 +544,7 @@
Iterator = object
else:
def get_unbound_function(unbound):
- return unbound.im_func
+ return unbound.__func__
def create_bound_method(func, obj):
return types.MethodType(func, obj, obj.__class__)
@@ -554,7 +554,7 @@
class Iterator(object):
- def next(self):
+ def __next__(self):
return type(self).__next__(self)
callable = callable
@@ -621,7 +621,7 @@
def u(s):
return s
- unichr = chr
+ chr = chr
import struct
int2byte = struct.Struct(">B").pack
del struct
@@ -644,8 +644,8 @@
# Workaround for standalRefactoringTool: Refactored ./pyresttest/resttest.py
one backslash
def u(s):
- return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape")
- unichr = unichr
+ return str(s.replace(r'\\', r'\\\\'), "unicode_escape")
+ chr = chr
int2byte = chr
def byte2int(bs):
@@ -654,8 +654,8 @@
def indexbytes(buf, i):
return ord(buf[i])
iterbytes = functools.partial(itertools.imap, ord)
- import StringIO
- StringIO = BytesIO = StringIO.StringIO
+ import io
+ StringIO = BytesIO = io.StringIO
_assertCountEqual = "assertItemsEqual"
_assertRaisesRegex = "assertRaisesRegexp"
_assertRegex = "assertRegexpMatches"
@@ -727,11 +727,11 @@
return
def write(data):
- if not isinstance(data, basestring):
+ if not isinstance(data, str):
data = str(data)
# If the file has an encoding, encode unicode with it.
if (isinstance(fp, file) and
- isinstance(data, unicode) and
+ isinstance(data, str) and
fp.encoding is not None):
errors = getattr(fp, "errors", None)
if errors is None:
@@ -741,13 +741,13 @@
want_unicode = False
sep = kwargs.pop("sep", None)
if sep is not None:
- if isinstance(sep, unicode):
+ if isinstance(sep, str):
want_unicode = True
elif not isinstance(sep, str):
raise TypeError("sep must be None or a string")
end = kwargs.pop("end", None)
if end is not None:
- if isinstance(end, unicode):
+ if isinstance(end, str):
want_unicode = True
elif not isinstance(end, str):
raise TypeError("end must be None or a string")
@@ -755,12 +755,12 @@
raise TypeError("invalid keyword arguments to print()")
if not want_unicode:
for arg in args:
- if isinstance(arg, unicode):
+ if isinstance(arg, str):
want_unicode = True
break
if want_unicode:
- newline = unicode("\n")
- space = unicode(" ")
+ newline = str("\n")
+ space = str(" ")
else:
newline = "\n"
space = " "
--- ./pyresttest/resttest.py (original)
+++ ./pyresttest/resttest.py (refactored)
@@ -13,17 +13,17 @@
import time
try:
- from cStringIO import StringIO as MyIO
+ from io import StringIO as MyIO
except:
try:
- from StringIO import StringIO as MyIO
+ from io import StringIO as MyIO
except ImportError:
from io import BytesIO as MyIO
ESCAPE_DECODING = 'string-escape'
# Python 3 compatibility
if sys.version_info[0] > 2:
- from past.builtins import basestring
+ from past.builtins import str
from builtins import range as xrange
ESCAPE_DECODING = 'unicode_escape'
@@ -135,7 +135,7 @@
class BenchmarkResult:
""" Stores results from a benchmark for reporting use """
group = None
- name = u'unnamed'
+ name = 'unnamed'
results = dict() # Benchmark output, map the metric to the result array for that metric
aggregates = list() # List of aggregates, as tuples of (metricname, aggregate, result)
@@ -193,11 +193,11 @@
if sys.version_info < (2,7):
header_msg = message_from_string(headers.encode(HEADER_ENCODING))
return [(text_type(k.lower(), HEADER_ENCODING), text_type(v, HEADER_ENCODING))
- for k, v in header_msg.items()]
+ for k, v in list(header_msg.items())]
else:
header_msg = message_from_string(headers)
# Note: HTTP headers are *case-insensitive* per RFC 2616
- return [(k.lower(), v) for k, v in header_msg.items()]
+ return [(k.lower(), v) for k, v in list(header_msg.items())]
def parse_testsets(base_url, test_structure, test_files=set(), working_directory=None, vars=None):
@@ -230,7 +230,7 @@
if isinstance(node, dict): # Each config element is a miniature key-value dictionary
node = lowercase_keys(node)
for key in node:
- if key == u'import':
+ if key == 'import':
importfile = node[key] # import another file
if importfile not in test_files:
logger.debug("Importing test sets: " + importfile)
@@ -240,21 +240,21 @@
import_testsets = parse_testsets(
base_url, import_test_structure, test_files, vars=vars)
testsets.extend(import_testsets)
- elif key == u'url': # Simple test, just a GET to a URL
+ elif key == 'url': # Simple test, just a GET to a URL
mytest = Test()
val = node[key]
- assert isinstance(val, basestring)
+ assert isinstance(val, str)
mytest.url = base_url + val
tests_out.append(mytest)
- elif key == u'test': # Complex test with additional parameters
+ elif key == 'test': # Complex test with additional parameters
with cd(working_directory):
child = node[key]
mytest = Test.parse_test(base_url, child)
tests_out.append(mytest)
- elif key == u'benchmark':
+ elif key == 'benchmark':
benchmark = parse_benchmark(base_url, node[key])
benchmarks.append(benchmark)
- elif key == u'config' or key == u'configuration':
+ elif key == 'config' or key == 'configuration':
test_config = parse_configuration(
node[key], base_config=test_config)
testset = TestSet()
@@ -273,21 +273,21 @@
node = lowercase_keys(flatten_dictionaries(node)) # Make it usable
- for key, value in node.items():
- if key == u'timeout':
+ for key, value in list(node.items()):
+ if key == 'timeout':
test_config.timeout = int(value)
- elif key == u'print_bodies':
+ elif key == 'print_bodies':
test_config.print_bodies = safe_to_bool(value)
- elif key == u'retries':
+ elif key == 'retries':
test_config.retries = int(value)
- elif key == u'variable_binds':
+ elif key == 'variable_binds':
if not test_config.variable_binds:
test_config.variable_binds = dict()
test_config.variable_binds.update(flatten_dictionaries(value))
- elif key == u'generators':
+ elif key == 'generators':
flat = flatten_dictionaries(value)
gen_map = dict()
- for generator_name, generator_config in flat.items():
+ for generator_name, generator_config in list(flat.items()):
gen = parse_generator(generator_config)
gen_map[str(generator_name)] = gen
test_config.generators = gen_map
@@ -333,18 +333,18 @@
if test_config.interactive:
print("===================================")
- print("%s" % mytest.name)
+ print(("%s" % mytest.name))
print("-----------------------------------")
print("REQUEST:")
- print("%s %s" % (templated_test.method, templated_test.url))
+ print(("%s %s" % (templated_test.method, templated_test.url)))
print("HEADERS:")
- print("%s" % (templated_test.headers))
+ print(("%s" % (templated_test.headers)))
if mytest.body is not None:
- print("\n%s" % templated_test.body)
- raw_input("Press ENTER when ready (%d): " % (mytest.delay))
+ print(("\n%s" % templated_test.body))
+ input("Press ENTER when ready (%d): " % (mytest.delay))
if mytest.delay > 0:
- print("Delaying for %ds" % mytest.delay)
+ print(("Delaying for %ds" % mytest.delay))
time.sleep(mytest.delay)
try:
@@ -425,12 +425,12 @@
if test_config.print_bodies or not result.passed:
if test_config.interactive:
print("RESPONSE:")
- print(result.body.decode(ESCAPE_DECODING))
+ print((result.body.decode(ESCAPE_DECODING)))
if test_config.print_headers or not result.passed:
if test_config.interactive:
print("RESPONSE HEADERS:")
- print(result.response_headers)
+ print((result.response_headers))
# TODO add string escape on body output
logger.debug(result)
@@ -474,12 +474,12 @@
# Metric variable for curl, to avoid hash lookup for every metric name
metricvalues = [METRICS[name] for name in metricnames]
# Initialize arrays to store results for each metric
- results = [list() for x in xrange(0, len(metricnames))]
+ results = [list() for x in range(0, len(metricnames))]
curl = pycurl.Curl()
# Benchmark warm-up to allow for caching, JIT compiling, on client
logger.info('Warmup: ' + message + ' started')
- for x in xrange(0, warmup_runs):
+ for x in range(0, warmup_runs):
benchmark.update_context_before(my_context)
templated = benchmark.realize(my_context)
curl = templated.configure_curl(
@@ -492,7 +492,7 @@
logger.info('Benchmark: ' + message + ' starting')
- for x in xrange(0, benchmark_runs): # Run the actual benchmarks
+ for x in range(0, benchmark_runs): # Run the actual benchmarks
# Setup benchmark
benchmark.update_context_before(my_context)
templated = benchmark.realize(my_context)
@@ -510,13 +510,13 @@
continue # Skip metrics collection
# Get all metrics values for this run, and store to metric lists
- for i in xrange(0, len(metricnames)):
+ for i in range(0, len(metricnames)):
results[i].append(curl.getinfo(metricvalues[i]))
logger.info('Benchmark: ' + message + ' ending')
temp_results = dict()
- for i in xrange(0, len(metricnames)):
+ for i in range(0, len(metricnames)):
temp_results[metricnames[i]] = results[i]
output.results = temp_results
return analyze_benchmark_results(output, benchmark)
@@ -542,7 +542,7 @@
# Compute aggregates for each metric, and add tuples to aggregate results
aggregate_results = list()
- for metricname, aggregate_list in benchmark.aggregated_metrics.items():
+ for metricname, aggregate_list in list(benchmark.aggregated_metrics.items()):
numbers = raw_results[metricname]
for aggregate_name in aggregate_list:
if numbers: # Only compute aggregates if numbers exist
@@ -577,8 +577,8 @@
output.append(tuple(metrics)) # Add headers
# Create list of tuples mimicking 2D array from input
- for row in xrange(0, num_rows):
- new_row = tuple([arrays[col][row] for col in xrange(0, len(arrays))])
+ for row in range(0, num_rows):
+ new_row = tuple([arrays[col][row] for col in range(0, len(arrays))])
output.append(new_row)
return output
@@ -604,7 +604,7 @@
writer.writerows(benchmark_result.aggregates)
# Method to call when writing benchmark file
-OUTPUT_METHODS = {u'csv': write_benchmark_csv, u'json': write_benchmark_json}
+OUTPUT_METHODS = {'csv': write_benchmark_csv, 'json': write_benchmark_json}
def log_failure(failure, context=None, test_config=TestConfig()):
@@ -633,7 +633,7 @@
if myconfig.variable_binds:
context.bind_variables(myconfig.variable_binds)
if myconfig.generators:
- for key, value in myconfig.generators.items():
+ for key, value in list(myconfig.generators.items()):
context.add_generator(key, value)
# Make sure we actually have tests to execute
@@ -718,23 +718,23 @@
failures = group_failure_counts[group]
total_failures = total_failures + failures
- passfail = {True: u'SUCCEEDED: ', False: u'FAILED: '}
+ passfail = {True: 'SUCCEEDED: ', False: 'FAILED: '}
output_string = "Test Group {0} {1}: {2}/{3} Tests Passed!".format(group, passfail[failures == 0], str(test_count - failures), str(test_count))
if myconfig.skip_term_colors:
print(output_string)
else:
if failures > 0:
- print('\033[91m' + output_string + '\033[0m')
+ print(('\033[91m' + output_string + '\033[0m'))
else:
- print('\033[92m' + output_string + '\033[0m')
+ print(('\033[92m' + output_string + '\033[0m'))
return total_failures
def register_extensions(modules):
""" Import the modules and register their respective extensions """
- if isinstance(modules, basestring): # Catch supplying just a string arg
+ if isinstance(modules, str): # Catch supplying just a string arg
modules = [modules]
for ext in modules:
# Get the package prefix and final module name
@@ -755,10 +755,10 @@
}
has_registry = False
- for registry_name, register_function in extension_applies.items():
+ for registry_name, register_function in list(extension_applies.items()):
if hasattr(module, registry_name):
registry = getattr(module, registry_name)
- for key, val in registry.items():
+ for key, val in list(registry.items()):
register_function(key, val)
if registry:
has_registry = True
@@ -859,29 +859,29 @@
""" Runs everything needed to execute from the command line, so main method is callable without arg parsing """
parser = OptionParser(
usage="usage: %prog base_url test_filename.yaml [options] ")
- parser.add_option(u"--print-bodies", help="Print all response bodies",
+ parser.add_option("--print-bodies", help="Print all response bodies",
action="store", type="string", dest="print_bodies")
- parser.add_option(u"--print-headers", help="Print all response headers",
+ parser.add_option("--print-headers", help="Print all response headers",
action="store", type="string", dest="print_headers")
- parser.add_option(u"--log", help="Logging level",
+ parser.add_option("--log", help="Logging level",
action="store", type="string")
- parser.add_option(u"--interactive", help="Interactive mode",
+ parser.add_option("--interactive", help="Interactive mode",
action="store", type="string")
parser.add_option(
- u"--url", help="Base URL to run tests against", action="store", type="string")
- parser.add_option(u"--test", help="Test file to use",
+ "--url", help="Base URL to run tests against", action="store", type="string")
+ parser.add_option("--test", help="Test file to use",
action="store", type="string")
- parser.add_option(u'--import_extensions',
+ parser.add_option('--import_extensions',
help='Extensions to import, separated by semicolons', action="store", type="string")
parser.add_option(
- u'--vars', help='Variables to set, as a YAML dictionary', action="store", type="string")
- parser.add_option(u'--verbose', help='Put cURL into verbose mode for extra debugging power',
+ '--vars', help='Variables to set, as a YAML dictionary', action="store", type="string")
+ parser.add_option('--verbose', help='Put cURL into verbose mode for extra debugging power',
action='store_true', default=False, dest="verbose")
- parser.add_option(u'--ssl-insecure', help='Disable cURL host and peer cert verification',
+ parser.add_option('--ssl-insecure', help='Disable cURL host and peer cert verification',
action='store_true', default=False, dest="ssl_insecure")
- parser.add_option(u'--absolute-urls', help='Enable absolute URLs in tests instead of relative paths',
+ parser.add_option('--absolute-urls', help='Enable absolute URLs in tests instead of relative paths',
actiRefactoringTool: Refactored ./pyresttest/parsing.py
RefactoringTool: Refactored ./pyresttest/generators.py
on="store_true", dest="absolute_urls")
- parser.add_option(u'--skip_term_colors', help='Turn off the output term colors',
+ parser.add_option('--skip_term_colors', help='Turn off the output term colors',
action='store_true', default=False, dest="skip_term_colors")
(args, unparsed_args) = parser.parse_args(args_in)
@@ -890,8 +890,8 @@
# Handle url/test as named, or, failing that, positional arguments
if not args['url'] or not args['test']:
if len(unparsed_args) == 2:
- args[u'url'] = unparsed_args[0]
- args[u'test'] = unparsed_args[1]
+ args['url'] = unparsed_args[0]
+ args['test'] = unparsed_args[1]
elif len(unparsed_args) == 1 and args['url']:
args['test'] = unparsed_args[0]
elif len(unparsed_args) == 1 and args['test']:
--- ./pyresttest/parsing.py (original)
+++ ./pyresttest/parsing.py (refactored)
@@ -1,4 +1,4 @@
-from __future__ import absolute_import
+
import sys
import string
@@ -11,7 +11,7 @@
# Python 2/3 switches
PYTHON_MAJOR_VERSION = sys.version_info[0]
if PYTHON_MAJOR_VERSION > 2:
- from past.builtins import basestring
+ from past.builtins import str
"""
Parsing utilities, pulled out so they can be used in multiple modules
@@ -21,14 +21,14 @@
""" Shim function, converts Unicode to UTF-8 encoded bytes regardless of the source format
Intended for python 3 compatibility mode, and b/c PyCurl only takes raw bytes
"""
- if not isinstance(my_string, basestring):
+ if not isinstance(my_string, str):
my_string = repr(my_string)
# TODO refactor this to use six types
if PYTHON_MAJOR_VERSION == 2:
if isinstance(my_string, str):
return my_string
- elif isinstance(my_string, unicode):
+ elif isinstance(my_string, str):
return my_string.encode('utf-8')
else:
if isinstance(my_string, str):
@@ -47,7 +47,7 @@
return string.Template(templated_string).safe_substitute(variable_map)
my_template = string.Template(encode_unicode_bytes(templated_string))
- my_escaped_dict = dict(map(lambda x: (x[0], encode_unicode_bytes(x[1])), variable_map.items()))
+ my_escaped_dict = dict([(x[0], encode_unicode_bytes(x[1])) for x in list(variable_map.items())])
templated = my_template.safe_substitute(my_escaped_dict)
return text_type(templated, 'utf-8')
@@ -81,7 +81,7 @@
if not isinstance(input_dict, dict):
return input_dict
safe = dict()
- for key, value in input_dict.items():
+ for key, value in list(input_dict.items()):
safe[str(key).lower()] = value
return safe
@@ -92,9 +92,9 @@
If it's not a boolean or string that matches 'false' or 'true' when ignoring case, throws an exception """
if isinstance(input, bool):
return input
- elif isinstance(input, basestring) and input.lower() == u'false':
+ elif isinstance(input, str) and input.lower() == 'false':
return False
- elif isinstance(input, basestring) and input.lower() == u'true':
+ elif isinstance(input, str) and input.lower() == 'true':
return True
else:
raise TypeError(
@@ -128,7 +128,7 @@
def configure(self, configs, configurable, handler, *args, **kwargs):
""" Use the configs and configurable to parse"""
- for key, value in configs.items():
+ for key, value in list(configs.items()):
# Read handler arguments and use them to call the configurator
handler[key] = config_options
self.run_configure(value, configurable)
--- ./pyresttest/generators.py (original)
+++ ./pyresttest/generators.py (refactored)
@@ -10,7 +10,7 @@
# Python 3 compatibility
if sys.version_info[0] > 2:
from builtins import range as xrange
- from past.builtins import basestring
+ from past.builtins import str
""" Collection of generators to be used in templating for test data
@@ -83,7 +83,7 @@
while(True):
length = random.randint(locRefactoringTool: Refactored ./pyresttest/functionaltest.py
al_min_len, local_max_len)
array = [random.choice(legal_characters)
- for x in xrange(0, length)]
+ for x in range(0, length)]
yield ''.join(array)
return generate_text
@@ -159,7 +159,7 @@
def parse_random_text_generator(configuration):
""" Parses configuration options for a random text generator """
- character_set = configuration.get(u'character_set')
+ character_set = configuration.get('character_set')
characters = None
if character_set:
character_set = character_set.lower()
@@ -168,18 +168,18 @@
"Illegal character set name, is not defined: {0}".format(character_set))
characters = CHARACTER_SETS[character_set]
else: # Custom characters listing, not a character set
- characters = str(configuration.get(u'characters'))
+ characters = str(configuration.get('characters'))
min_length = 8
max_length = 8
- if configuration.get(u'min_length'):
- min_length = int(configuration.get(u'min_length'))
- if configuration.get(u'max_length'):
- max_length = int(configuration.get(u'max_length'))
-
- if configuration.get(u'length'):
- length = int(configuration.get(u'length'))
+ if configuration.get('min_length'):
+ min_length = int(configuration.get('min_length'))
+ if configuration.get('max_length'):
+ max_length = int(configuration.get('max_length'))
+
+ if configuration.get('length'):
+ length = int(configuration.get('length'))
min_length = length
max_length = length
@@ -206,7 +206,7 @@
typename is the new generator type name (must not already exist)
parse_function will parse a configuration object (dict)
"""
- if not isinstance(typename, basestring):
+ if not isinstance(typename, str):
raise TypeError(
'Generator type name {0} is invalid, must be a string'.format(typename))
if typename in GENERATOR_TYPES:
@@ -225,18 +225,18 @@
"""
configuration = lowercase_keys(flatten_dictionaries(configuration))
- gen_type = str(configuration.get(u'type')).lower()
+ gen_type = str(configuration.get('type')).lower()
if gen_type not in GENERATOR_TYPES:
raise ValueError(
'Generator type given {0} is not valid '.format(gen_type))
# Do the easy parsing, delegate more complex logic to parsing functions
- if gen_type == u'env_variable':
- return factory_env_variable(configuration[u'variable_name'])()
- elif gen_type == u'env_string':
- return factory_env_string(configuration[u'string'])()
- elif gen_type == u'number_sequence':
+ if gen_type == 'env_variable':
+ return factory_env_variable(configuration['variable_name'])()
+ elif gen_type == 'env_string':
+ return factory_env_string(configuration['string'])()
+ elif gen_type == 'number_sequence':
start = configuration.get('start')
increment = configuration.get('increment')
if not start:
@@ -248,9 +248,9 @@
else:
increment = int(increment)
return factory_generate_ids(start, increment)()
- elif gen_type == u'random_int':
+ elif gen_type == 'random_int':
return generator_random_int32()
- elif gen_type == u'random_text':
+ elif gen_type == 'random_text':
return parse_random_text_generator(configuration)
elif gen_type in GENERATOR_TYPES:
return GENERATOR_PARSING[gen_type](configuration)
--- ./pyresttest/functionaltest.py (original)
+++ ./pyresttest/functionaltest.py (refactored)
@@ -65,7 +65,7 @@
test_response = resttest.run_test(test)
self.assertTrue(test_response.passed)
self.assertEqual(200, test_response.response_code)
- print("Github API response headers: \n{0}".format(test_response.response_headers))
+ print(("Github API response headers: \n{0}".format(test_response.response_headers)))
self.assertTrue(test_response.response_headers)
def test_patch(self):
@@ -74,8 +74,8 @@
test.url = self.prefix + '/api/person/2/'
test.method = 'PATCH'
test.body = '{"login":"special"}'
- test.headers = {u'Content-Type': u'application/json',
- u'X-HTTP-Method-Override': u'PATCH'}
+ test.headers = {'Content-Type': 'application/json',
+ 'X-HTTP-Method-Override': 'PATCH'}
test.expected_status = [202] # Django returns 202
test_response = resttest.run_test(test)
self.assertTrue(test_response.passed)
@@ -118,10 +118,10 @@
test_response = resttest.run_test(test)
for failure in test_response.failures:
print("REAL FAILURE")
- print("Test Failure, failure type: {0}, Reason: {1}".format(
- failure.failure_type, failure.message))
+ print(("Test Failure, failure type: {0}, Reason: {1}".format(
+ failure.failure_type, failure.message)))
if failure.details:
- print("Validator/Error details: " + str(failure.details))
+ print(("Validator/Error details: " + str(failure.details)))
self.assertFalse(test_response.failures)
self.assertTrue(test_response.passed)
@@ -201,9 +201,9 @@
""" Test PUT where item already exists """
test = Test()
test.url = self.prefix + '/api/person/1/'
- test.method = u'PUT'
+ test.method = 'PUT'
test.body = '{"first_name": "Gaius","id": 1,"last_name": "Baltar","login": "gbaltar"}'
- test.headers = {u'Content-Type': u'application/json'}
+ test.headers = {'Content-Type': 'application/json'}
test_response = resttest.run_test(test)
self.assertEqual(True, test_response.passed)
self.assertEqual(200, test_response.response_code)
@@ -212,10 +212,10 @@
""" Test PUT where item DOES NOT already exist """
test = Test()
test.url = self.prefix + '/api/person/100/'
- test.method = u'PUT'
+ test.method = 'PUT'
test.expected_status = [200, 201, 204]
test.body = '{"first_name": "Willim","last_name": "Adama","login":"theadmiral", "id": 100}'
- test.headers = {u'Content-Type': u'application/json'}
+ test.headers = {'Content-Type': 'application/json'}
test_response = resttest.run_test(test)
self.assertEqual(True, test_response.passed)
self.assertEqual(201, test_response.response_code)
@@ -226,18 +226,18 @@
test_response2 = resttest.run_test(test2)
self.assertTrue(test_response2.passed)
self.assertTrue(
- u'"last_name": "Adama"' in test_response2.body.decode('UTF-8'))
+ '"last_name": "Adama"' in test_response2.body.decode('UTF-8'))
self.assertTrue(
- u'"login": "theadmiral"' in test_response2.body.decode('UTF-8'))
+ '"login": "theadmiral"' in test_response2.body.decode('UTF-8'))
def test_post(self):
""" Test POST to create an item """
test = Test()
test.url = self.prefix + '/api/person/'
- test.method = u'POST'
+ test.method = 'POST'
test.expected_status = [200, 201, 204]
test.body = '{"first_name": "Willim","last_name": "Adama","login": "theadmiral"}'
- test.headers = {u'Content-Type': u'application/json'}
+ test.headers = {'Content-Type': 'application/json'}
test_response = resttest.run_test(test)
self.assertEqual(True, test_response.passed)
self.assertEqual(201, test_response.response_code)
@@ -252,7 +252,7 @@
bod = test_response2.body
if isinstance(bod, binary_type):
bod = text_type(bod, 'utf-8')
- print(json.dumps(json.loads(bod)))
+ print((json.dumps(json.loads(bod))))
def test_delete(self):
@@ -260,13 +260,13 @@
test = Test()
test.url = self.prefix + '/api/person/1/'
test.expected_status = [200, 202, 204]
- test.method = u'DELETE'
+ test.method = 'DELETE'
test_response RefactoringTool: No changes to ./pyresttest/ext/validator_jsonschema.py
RefactoringTool: No changes to ./pyresttest/ext/extractor_jmespath.py
RefactoringTool: No changes to ./pyresttest/ext/__init__.py
RefactoringTool: Refactored ./pyresttest/contenthandling.py
= resttest.run_test(test)
self.assertEqual(True, test_response.passed)
self.assertEqual(204, test_response.response_code)
# Verify it's really gone
- test.method = u'GET'
+ test.method = 'GET'
test.expected_status = [404]
test_response = resttest.run_test(test)
self.assertEqual(True, test_response.passed)
@@ -277,7 +277,7 @@
test2.url = self.prefix + '/api/person/?first_name__contains=Gaius'
test_response2 = resttest.run_test(test2)
self.assertTrue(test_response2.passed)
- self.assertTrue(u'"objects": []' in test_response2.body.decode('UTF-8'))
+ self.assertTrue('"objects": []' in test_response2.body.decode('UTF-8'))
def test_full_context_use(self):
""" Read and execute test set with context use, from file """
@@ -312,8 +312,8 @@
benchmark_config.add_metric(
'total_time').add_metric('total_time', 'median')
benchmark_result = resttest.run_benchmark(benchmark_config)
- print("Benchmark - median request time: " +
- str(benchmark_result.aggregates[0]))
+ print(("Benchmark - median request time: " +
+ str(benchmark_result.aggregates[0])))
self.assertTrue(benchmark_config.benchmark_runs, len(
benchmark_result.results['total_time']))
@@ -388,10 +388,10 @@
test_response = resttest.run_test(test)
for failure in test_response.failures:
print("REAL FAILURE")
- print("Test Failure, failure type: {0}, Reason: {1}".format(
- failure.failure_type, failure.message))
+ print(("Test Failure, failure type: {0}, Reason: {1}".format(
+ failure.failure_type, failure.message)))
if failure.details:
- print("Validator/Error details: " + str(failure.details))
+ print(("Validator/Error details: " + str(failure.details)))
self.assertFalse(test_response.failures)
self.assertTrue(test_response.passed)
--- ./pyresttest/contenthandling.py (original)
+++ ./pyresttest/contenthandling.py (refactored)
@@ -7,7 +7,7 @@
# Python 2/3 switches
PYTHON_MAJOR_VERSION = sys.version_info[0]
if PYTHON_MAJOR_VERSION > 2:
- from past.builtins import basestring
+ from past.builtins import str
"""
@@ -72,7 +72,7 @@
def setup(self, input, is_file=False, is_template_path=False, is_template_content=False):
""" Self explanatory, input is inline content or file path. """
- if not isinstance(input, basestring):
+ if not isinstance(input, str):
raise TypeError("Input is not a string")
if is_file:
input = os.path.abspath(input)
@@ -103,7 +103,7 @@
while (node and not is_done): # Dive through the configuration tree
# Finally we've found the value!
- if isinstance(node, basestring):
+ if isinstance(node, str):
output.content = node
output.setup(node, is_file=is_file, is_template_path=is_template_path,
is_template_content=is_template_content)
@@ -116,9 +116,9 @@
# Dictionary or list of dictionaries
flat = lowercase_keys(flatten_dictionaries(node))
- for key, value in flat.items():
- if key == u'template':
- if isinstance(value, basestring):
+ for key, value in list(flat.items()):
+ if key == 'template':
+ if isinstance(value, str):
if is_file:
value = os.path.abspath(value)
output.content = value
@@ -134,7 +134,7 @@
break
elif key == 'file':
- if isinstance(value, basestring):
+ if isinstance(value, str):
output.content = os.path.abspath(value)
output.is_file = True
output.is_template_cRefactoringTool: Refactored ./pyresttest/binding.py
RefactoringTool: Refactored ./pyresttest/benchmarks.py
ontent = is_template_content
--- ./pyresttest/binding.py (original)
+++ ./pyresttest/binding.py (refactored)
@@ -26,7 +26,7 @@
#logging.debug('Context: altered variable named {0} to value {1}'.format(str_name, variable_value))
def bind_variables(self, variable_map):
- for key, value in variable_map.items():
+ for key, value in list(variable_map.items()):
self.bind_variable(key, value)
def add_generator(self, generator_name, generator):
--- ./pyresttest/benchmarks.py (original)
+++ ./pyresttest/benchmarks.py (refactored)
@@ -10,7 +10,7 @@
# Python 2/3 switches
if sys.version_info[0] > 2:
- from past.builtins import basestring
+ from past.builtins import str
# Python 3 compatibility shims
from . import six
@@ -88,7 +88,7 @@
'total': lambda x: sum(x)
}
-OUTPUT_FORMATS = [u'csv', u'json']
+OUTPUT_FORMATS = ['csv', 'json']
def median(array):
@@ -108,7 +108,7 @@
return 0
average = AGGREGATES['mean_arithmetic'](array)
- variance = map(lambda x: (x - average)**2, array)
+ variance = [(x - average)**2 for x in array]
try:
len(variance)
except TypeError: # Python 3.3 workaround until can use the statistics module from 3.4
@@ -129,7 +129,7 @@
"""
warmup_runs = 10 # Times call is executed to warm up
benchmark_runs = 100 # Times call is executed to generate benchmark results
- output_format = u'csv'
+ output_format = 'csv'
output_file = None
# Metrics to gather, both raw and aggregated
@@ -217,23 +217,23 @@
benchmark = Test.parse_test(base_url, node, benchmark)
# Complex parsing because of list/dictionary/singleton legal cases
- for key, value in node.items():
- if key == u'warmup_runs':
+ for key, value in list(node.items()):
+ if key == 'warmup_runs':
benchmark.warmup_runs = int(value)
- elif key == u'benchmark_runs':
+ elif key == 'benchmark_runs':
benchmark.benchmark_runs = int(value)
- elif key == u'output_format':
+ elif key == 'output_format':
format = value.lower()
if format in OUTPUT_FORMATS:
benchmark.output_format = format
else:
raise ValueError('Invalid benchmark output format: ' + format)
- elif key == u'output_file':
- if not isinstance(value, basestring):
+ elif key == 'output_file':
+ if not isinstance(value, str):
raise ValueError("Invalid output file format")
benchmark.output_file = value
- elif key == u'metrics':
- if isinstance(value, basestring):
+ elif key == 'metrics':
+ if isinstance(value, str):
# Single value
benchmark.add_metric(tests.coerce_to_string(value))
# FIXME refactor the parsing of metrics here, lots of duplicated logic
@@ -241,26 +241,26 @@
# List of single values or list of {metric:aggregate, ...}
for metric in value:
if isinstance(metric, dict):
- for metricname, aggregate in metric.items():
- if not isinstance(metricname, basestring):
+ for metricname, aggregate in list(metric.items()):
+ if not isinstance(metricname, str):
raise TypeError(
"Invalid metric input: non-string metric name")
- if not isinstance(aggregate, basestring):
+ if not isinstance(aggregate, str):
raise TypeError(
"Invalid aggregate input: non-string aggregate name")
# TODO unicode-safe this
benchmark.add_metric(tests.coerce_to_string(metricname),
tests.coerce_to_string(aggregate))
- elif isinstance(metric, basestriRefactoringTool: Refactored ./pyresttest/benchmark_framework_mini.py
RefactoringTool: Refactored ./profile_benchmark.py
RefactoringTool: No changes to ./docker/ubuntu14-py27/verify_image.py
RefactoringTool: No changes to ./docker/python3/verify_image.py
RefactoringTool: No changes to ./docker/centos6-py26/verify_image.py
RefactoringTool: Files that were modified:
RefactoringTool: ./util/profile_basic_test.py
RefactoringTool: ./setup.py
RefactoringTool: ./sample_extension.py
RefactoringTool: ./pyresttest/validators.py
RefactoringTool: ./pyresttest/tests.py
RefactoringTool: ./pyresttest/testapp/testapp/wsgi.py
RefactoringTool: ./pyresttest/testapp/testapp/urls.py
RefactoringTool: ./pyresttest/testapp/testapp/settings.py
RefactoringTool: ./pyresttest/testapp/testapp/models.py
RefactoringTool: ./pyresttest/testapp/testapp/api.py
RefactoringTool: ./pyresttest/testapp/manage.py
RefactoringTool: ./pyresttest/test_validators.py
RefactoringTool: ./pyresttest/test_tests.py
RefactoringTool: ./pyresttest/test_resttest.py
RefactoringTool: ./pyresttest/test_parsing.py
RefactoringTool: ./pyresttest/test_generators.py
RefactoringTool: ./pyresttest/test_contenthandling.py
RefactoringTool: ./pyresttest/test_binding.py
RefactoringTool: ./pyresttest/test_benchmarks.py
RefactoringTool: ./pyresttest/six.py
RefactoringTool: ./pyresttest/resttest.py
RefactoringTool: ./pyresttest/parsing.py
RefactoringTool: ./pyresttest/generators.py
RefactoringTool: ./pyresttest/functionaltest.py
RefactoringTool: ./pyresttest/ext/validator_jsonschema.py
RefactoringTool: ./pyresttest/ext/extractor_jmespath.py
RefactoringTool: ./pyresttest/ext/__init__.py
RefactoringTool: ./pyresttest/contenthandling.py
RefactoringTool: ./pyresttest/binding.py
RefactoringTool: ./pyresttest/benchmarks.py
RefactoringTool: ./pyresttest/benchmark_framework_mini.py
RefactoringTool: ./profile_benchmark.py
RefactoringTool: ./docker/ubuntu14-py27/verify_image.py
RefactoringTool: ./docker/python3/verify_image.py
RefactoringTool: ./docker/centos6-py26/verify_image.py
RefactoringTool: Warnings/messages while refactoring:
RefactoringTool: ### In file ./pyresttest/six.py ###
RefactoringTool: Line 525: Calls to builtin next() possibly shadowed by global binding
ng):
+ elif isinstance(metric, str):
benchmark.add_metric(tests.coerce_to_string(metric))
elif isinstance(value, dict):
# Dictionary of metric-aggregate pairs
- for metricname, aggregate in value.items():
- if not isinstance(metricname, basestring):
+ for metricname, aggregate in list(value.items()):
+ if not isinstance(metricname, str):
raise TypeError(
"Invalid metric input: non-string metric name")
- if not isinstance(aggregate, basestring):
+ if not isinstance(aggregate, str):
raise TypeError(
"Invalid aggregate input: non-string aggregate name")
benchmark.add_metric(tests.coerce_to_string(metricname),
--- ./pyresttest/benchmark_framework_mini.py (original)
+++ ./pyresttest/benchmark_framework_mini.py (refactored)
@@ -5,21 +5,21 @@
# Test basic pycurl create/delete, time is ~2.5 microseconds
time = timeit.timeit("mycurl=Curl(); mycurl.close()",
setup="from pycurl import Curl", number=1000000)
-print('Curl create/destroy runtime for 1M runs (s)' + str(time))
+print(('Curl create/destroy runtime for 1M runs (s)' + str(time)))
# Test test interpret/build & configuration speeds for resttest
# Runtime is 36.29 sec, so 36 microseconds per run, or 0.036 ms
time = timeit.timeit("mytest=Test.parse_test('', input); mycurl=mytest.configure_curl(); mycurl.close()",
setup='from resttest import Test; input = {"url": "/ping", "method": "DELETE", "NAME":"foo", "group":"bar", "body":"input","headers":{"Accept":"Application/json"}}',
number=1000000)
-print('Test interpret/configure test config for 1M runs (s)' + str(time))
+print(('Test interpret/configure test config for 1M runs (s)' + str(time)))
# Just configuring the curl object from a pre-built test
# 10s/1M runs, or 0.01 ms per
time = timeit.timeit("mycurl=mytest.configure_curl(); mycurl.close()",
setup='from resttest import Test; input = {"url": "/ping", "method": "DELETE", "NAME":"foo", "group":"bar", "body":"input","headers":{"Accept":"Application/json"}}; mytest=Test.parse_test("", input);',
number=1000000)
-print('Test configure curl for 1M runs (s)' + str(time))
+print(('Test configure curl for 1M runs (s)' + str(time)))
# Time for full curl execution on Django testing rest app
# Time: 41.4s for 10k runs, or about 4.14 ms per
--- ./profile_benchmark.py (original)
+++ ./profile_benchmark.py (refactored)
@@ -18,7 +18,7 @@
# Basic get test
test.url = 'http://localhost:8000/api/person/'
test.name = 'Basic GET'
-print 'Basic GET test'
+print('Basic GET test')
#cProfile.run('resttest.run_benchmark(test)', sort='cumtime')
@@ -33,5 +33,5 @@
context = Context()
context.add_generator('gen', factory_generate_ids(starting_id=10)())
test.generator_binds = {'id': 'gen'}
-print 'Running templated PUT test'
+print('Running templated PUT test')
cProfile.run('resttest.run_benchmark(test, context=context)', sort='cumtime')
++ find ./ -name '*.py'
+ sed -i 's|#!/usr/bin/env python|#!/usr/bin/env python3|' ./util/resttest.py ./util/profile_basic_test.py ./test_schema_validation.py ./setup.py ./sample_extension.py ./pyresttest/validators.py ./pyresttest/tests.py ./pyresttest/testapp/testapp/wsgi.py ./pyresttest/testapp/testapp/urls.py ./pyresttest/testapp/testapp/settings.py ./pyresttest/testapp/testapp/models.py ./pyresttest/testapp/testapp/api.py ./pyresttest/testapp/testapp/admin.py ./pyresttest/testapp/testapp/__init__.py ./pyresttest/testapp/manage.py ./pyresttest/test_validators.py ./pyresttest/test_tests.py ./pyresttest/test_resttest.py ./pyresttest/test_parsing.py ./pyresttest/test_generators.py ./pyresttest/test_contenthandling.py ./pyresttest/test_binding.py ./pyresttest/test_benchmarks.py ./pyresttest/six.py ./pyresttest/resttest.py ./pyresttest/parsing.py ./pyresttest/generators.py ./pyresttest/functionaltest.py ./pyresttest/ext/validator_jsonschema.py ./pyresttest/ext/extractor_jmespath.py ./pyresttest/ext/__init__.py ./pyresttest/contenthandling.py ./pyresttest/binding.py ./pyresttest/benchmarks.py ./pyresttest/benchmark_framework_mini.py ./pyresttest/__init__.py ./profile_benchmark.py ./docker/ubuntu14-py27/verify_image.py ./docker/python3/verify_image.py ./docker/centos6-py26/verify_image.py
+ exit 0
Executing(%build): /bin/sh -e /usr/src/tmp/rpm-tmp.10776
+ umask 022
+ /bin/mkdir -p /usr/src/RPM/BUILD
+ cd /usr/src/RPM/BUILD
+ cd python3-module-pyresttest-1.7.1
+ CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export CFLAGS
+ CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export CXXFLAGS
+ FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export FFLAGS
+ /usr/bin/python3 setup.py build --debug
/usr/lib64/python3/site-packages/setuptools/dist.py:758: UserWarning: Usage of dash-separated 'description-file' will not be supported in future versions. Please use the underscore name 'description_file' instead
warnings.warn(
running build
running build_py
creating build
creating build/lib
creating build/lib/pyresttest
copying pyresttest/__init__.py -> build/lib/pyresttest
copying pyresttest/resttest.py -> build/lib/pyresttest
copying pyresttest/generators.py -> build/lib/pyresttest
copying pyresttest/binding.py -> build/lib/pyresttest
copying pyresttest/parsing.py -> build/lib/pyresttest
copying pyresttest/validators.py -> build/lib/pyresttest
copying pyresttest/contenthandling.py -> build/lib/pyresttest
copying pyresttest/benchmarks.py -> build/lib/pyresttest
copying pyresttest/tests.py -> build/lib/pyresttest
copying pyresttest/six.py -> build/lib/pyresttest
creating build/lib/pyresttest/ext
copying pyresttest/ext/__init__.py -> build/lib/pyresttest/ext
copying pyresttest/ext/validator_jsonschema.py -> build/lib/pyresttest/ext
copying pyresttest/ext/extractor_jmespath.py -> build/lib/pyresttest/ext
running build_scripts
creating build/scripts-3.10
copying and adjusting util/pyresttest -> build/scripts-3.10
copying and adjusting util/resttest.py -> build/scripts-3.10
changing mode of build/scripts-3.10/pyresttest from 644 to 755
changing mode of build/scripts-3.10/resttest.py from 644 to 755
+ exit 0
Executing(%install): /bin/sh -e /usr/src/tmp/rpm-tmp.10776
+ umask 022
+ /bin/mkdir -p /usr/src/RPM/BUILD
+ cd /usr/src/RPM/BUILD
+ /bin/chmod -Rf u+rwX -- /usr/src/tmp/python3-module-pyresttest-buildroot
+ :
+ /bin/rm -rf -- /usr/src/tmp/python3-module-pyresttest-buildroot
+ PATH=/usr/libexec/rpm-build:/usr/src/bin:/bin:/usr/bin:/usr/X11R6/bin:/usr/games
+ cd python3-module-pyresttest-1.7.1
+ CFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export CFLAGS
+ CXXFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export CXXFLAGS
+ FFLAGS='-pipe -frecord-gcc-switches -Wall -g -O2 -flto=auto'
+ export FFLAGS
+ /usr/bin/python3 setup.py install --skip-build --root=/usr/src/tmp/python3-module-pyresttest-buildroot --force
/usr/lib64/python3/site-packages/setuptools/dist.py:758: UserWarning: Usage of dash-separated 'description-file' will not be supported in future versions. Please use the underscore name 'description_file' instead
warnings.warn(
running install
/usr/lib64/python3/site-packages/setuptools/command/install.py:34: SetuptoolsDeprecationWarning: setup.py install is deprecated. Use build and pip and other standards-based tools.
warnings.warn(
running install_lib
creating /usr/src/tmp/python3-module-pyresttest-buildroot
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext
copying build/lib/pyresttest/ext/extractor_jmespath.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext
copying build/lib/pyresttest/ext/validator_jsonschema.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext
copying build/lib/pyresttest/ext/__init__.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext
copying build/lib/pyresttest/six.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/tests.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/benchmarks.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/contenthandling.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/validators.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/parsing.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/binding.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/generators.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/resttest.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
copying build/lib/pyresttest/__init__.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py to extractor_jmespath.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py to validator_jsonschema.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py to __init__.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py to six.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py to tests.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py to benchmarks.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py to contenthandling.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py to validators.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py to parsing.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/binding.py to binding.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py to generators.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py to resttest.cpython-310.pyc
byte-compiling /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__init__.py to __init__.cpython-310.pyc
running install_egg_info
running egg_info
creating pyresttest.egg-info
writing pyresttest.egg-info/PKG-INFO
writing dependency_links to pyresttest.egg-info/dependency_links.txt
writing requirements to pyresttest.egg-info/requires.txt
writing top-level names to pyresttest.egg-info/top_level.txt
writing manifest file 'pyresttest.egg-info/SOURCES.txt'
reading manifest file 'pyresttest.egg-info/SOURCES.txt'
reading manifest template 'MANIFEST.in'
warning: no previously-included files matching '*.pyc' found anywhere in distribution
warning: no previously-included files matching 'test_*.py' found anywhere in distribution
adding license file 'LICENSE'
adding license file 'LICENSE.txt'
writing manifest file 'pyresttest.egg-info/SOURCES.txt'
Copying pyresttest.egg-info to /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info
running install_scripts
creating /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin
copying build/scripts-3.10/resttest.py -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin
copying build/scripts-3.10/pyresttest -> /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin
changing mode of /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin/resttest.py to 755
changing mode of /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin/pyresttest to 755
+ /usr/lib/rpm/brp-alt
egrep: warning: egrep is obsolescent; using grep -E
Cleaning files in /usr/src/tmp/python3-module-pyresttest-buildroot (auto)
Verifying and fixing files in /usr/src/tmp/python3-module-pyresttest-buildroot (binconfig,pkgconfig,libtool,desktop,gnuconfig)
Checking contents of files in /usr/src/tmp/python3-module-pyresttest-buildroot/ (default)
Compressing files in /usr/src/tmp/python3-module-pyresttest-buildroot (auto)
Adjusting library links in /usr/src/tmp/python3-module-pyresttest-buildroot
./usr/lib: (from :0)
Verifying ELF objects in /usr/src/tmp/python3-module-pyresttest-buildroot (arch=normal,fhs=normal,lfs=relaxed,lint=relaxed,rpath=normal,stack=normal,textrel=normal,unresolved=normal)
Bytecompiling python3 modules in /usr/src/tmp/python3-module-pyresttest-buildroot using /usr/bin/python3
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.pyc
unlink /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.pyc
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/binding.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py
Bytecompiling python3 modules with optimization in /usr/src/tmp/python3-module-pyresttest-buildroot using /usr/bin/python3 -O
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/binding.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py
Bytecompiling python3 modules with optimization-2 in /usr/src/tmp/python3-module-pyresttest-buildroot using /usr/bin/python3 -OO
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/__init__.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/binding.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py
compile /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py
Hardlinking identical .pyc and .opt-?.pyc files
'./usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-2.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-1.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-2.pyc' => './usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-1.pyc'
'./usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.pyc'
'./usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.opt-1.pyc' => './usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.pyc'
Executing(%check): /bin/sh -e /usr/src/tmp/rpm-tmp.95079
Check is turned off by --disable check
Processing files: python3-module-pyresttest-1.7.1-alt1
Executing(%doc): /bin/sh -e /usr/src/tmp/rpm-tmp.95079
+ umask 022
+ /bin/mkdir -p /usr/src/RPM/BUILD
+ cd /usr/src/RPM/BUILD
+ cd python3-module-pyresttest-1.7.1
+ DOCDIR=/usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ export DOCDIR
+ rm -rf /usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ /bin/mkdir -p /usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ cp -prL CHANGELOG.md README.md advanced_guide.md building.md extensions.md lessons.md quickstart.md /usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ chmod -R go-w /usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ chmod -R a+rX /usr/src/tmp/python3-module-pyresttest-buildroot/usr/share/doc/python3-module-pyresttest-1.7.1
+ exit 0
Finding Provides (using /usr/lib/rpm/find-provides)
Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.hF3EeA
find-provides: running scripts (alternatives,debuginfo,lib,pam,perl,pkgconfig,python,python3,shell)
Finding Requires (using /usr/lib/rpm/find-requires)
Executing: /bin/sh -e /usr/src/tmp/rpm-tmp.FEYVBu
find-requires: running scripts (cpp,debuginfo,files,lib,pam,perl,pkgconfig,pkgconfiglib,python,python3,rpmlib,shebang,shell,static,symlinks,systemd-services)
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin/pyresttest: skipping sys
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/bin/resttest.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: possible relative import from pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/benchmarks.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py: possible relative import from pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/contenthandling.py: skipping sys
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py: Ignore for REQ=slight module=pyresttest
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/__init__.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: possible relative import from pyresttest.ext
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: Ignore for REQ=slight module=pyresttest
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: possible relative import from pyresttest.ext
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: possible relative import from pyresttest.ext
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: Ignore for REQ=slight module=pyresttest
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/ext/validator_jsonschema.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py: possible relative import from pyresttest
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py: skipping builtins
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/generators.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py: possible relative import from pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/parsing.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: possible relative import from pyresttest
'Name' object has no attribute 'value'
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: skipping builtins
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=io
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=jmespath
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=jsonschema
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=past.builtins
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.benchmarks
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.binding
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.generators
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.parsing
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.six
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.tests
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: Ignore for REQ=slight module=pyresttest.validators
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: skipping sys
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py: skipping time
'Name' object has no attribute 'value'
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py: Ignore for REQ=slight module=io
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py: skipping itertools
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py: Ignore for REQ=slight module=struct
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/six.py: skipping sys
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: possible relative import from pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: Ignore for REQ=slight module=io
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: skipping sys
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/tests.py: Ignore for REQ=slight module=urllib.parse
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: possible relative import from pyresttest
python3.req.py:/usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: possible relative import from pyresttest
/usr/lib/rpm/python3.req.py: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: Ignore for REQ=slight module=past.builtins
python3.req: /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/validators.py: skipping sys
shebang.req.files: executable script /usr/src/tmp/python3-module-pyresttest-buildroot/usr/lib/python3/site-packages/pyresttest/resttest.py is not executable
Provides: python3(pyresttest), python3(pyresttest.benchmarks), python3(pyresttest.binding), python3(pyresttest.contenthandling), python3(pyresttest.ext), python3(pyresttest.ext.extractor_jmespath), python3(pyresttest.ext.validator_jsonschema), python3(pyresttest.generators), python3(pyresttest.parsing), python3(pyresttest.resttest), python3(pyresttest.six), python3(pyresttest.tests), python3(pyresttest.validators)
Requires: /usr/bin/python3, /usr/lib/python3/site-packages, python3(ast) < 0, python3(copy) < 0, python3(csv) < 0, python3(email) < 0, python3(functools) < 0, python3(inspect) < 0, python3(jmespath) < 0, python3(json) < 0, python3(jsonschema) < 0, python3(logging) < 0, python3(math) < 0, python3(operator) < 0, python3(optparse) < 0, python3(os) < 0, python3(pycurl) < 0, python3(random) < 0, python3(re) < 0, python3(string) < 0, python3(traceback) < 0, python3(types) < 0, python3(yaml) < 0
Wrote: /usr/src/RPM/RPMS/noarch/python3-module-pyresttest-1.7.1-alt1.noarch.rpm (w2.lzdio)
5.43user 0.57system 0:07.58elapsed 79%CPU (0avgtext+0avgdata 56668maxresident)k
0inputs+0outputs (0major+232048minor)pagefaults 0swaps
/.out/python3-module-pyresttest-1.7.1-alt1.noarch.rpm: license not found in '/usr/share/license' directory: ASLv2.0
11.93user 4.54system 0:17.28elapsed 95%CPU (0avgtext+0avgdata 104236maxresident)k
200inputs+0outputs (46524major+663314minor)pagefaults 0swaps
--- python3-module-pyresttest-1.7.1-alt1.noarch.rpm.repo 2019-11-07 14:46:42.000000000 +0000
+++ python3-module-pyresttest-1.7.1-alt1.noarch.rpm.hasher 2022-05-31 00:46:55.001487765 +0000
@@ -3,40 +3,40 @@
/usr/lib/python3/site-packages/pyresttest 40755 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info 40755 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/PKG-INFO 100644 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/SOURCES.txt 100644 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/dependency_links.txt 100644 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/requires.txt 100644 root:root
-/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/top_level.txt 100644 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info 40755 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/PKG-INFO 100644 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/SOURCES.txt 100644 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/dependency_links.txt 100644 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/requires.txt 100644 root:root
+/usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/top_level.txt 100644 root:root
/usr/lib/python3/site-packages/pyresttest/__init__.py 100644 root:root
/usr/lib/python3/site-packages/pyresttest/__pycache__ 40755 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.pyc 100644 root:root
/usr/lib/python3/site-packages/pyresttest/benchmarks.py 100644 root:root
@@ -47,11 +47,11 @@
/usr/lib/python3/site-packages/pyresttest/ext/__pycache__ 40755 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.opt-1.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.opt-2.pyc 100644 root:root
-/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.opt-1.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.opt-2.pyc 100644 root:root
+/usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.pyc 100644 root:root
/usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py 100644 root:root
@@ -113,40 +113,40 @@
File: /usr/lib/python3/site-packages/pyresttest 40755 root:root
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info 40755 root:root
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/PKG-INFO 100644 root:root 1223aedbe4e34337bc05e7bc5b4773c6
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/SOURCES.txt 100644 root:root fe8e83a4429a79235e8e3de6530ed14c
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/dependency_links.txt 100644 root:root 68b329da9893e34099c7d8ad5cb9c940
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/requires.txt 100644 root:root 362724bf78d9d065b85a5cf3687514d0
-File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.7.egg-info/top_level.txt 100644 root:root 8de91c4e151677b7386d45ab3d968480
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info 40755 root:root
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/PKG-INFO 100644 root:root 5482bc3fddd00735df009b5838e67430
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/SOURCES.txt 100644 root:root ae84971b022b67119c2d79b2f471e633
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/dependency_links.txt 100644 root:root 68b329da9893e34099c7d8ad5cb9c940
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/requires.txt 100644 root:root 362724bf78d9d065b85a5cf3687514d0
+File: /usr/lib/python3/site-packages/pyresttest-1.7.1-py3.10.egg-info/top_level.txt 100644 root:root 8de91c4e151677b7386d45ab3d968480
File: /usr/lib/python3/site-packages/pyresttest/__init__.py 100644 root:root 9be1d98023a6747d8da327012aa2ad05
File: /usr/lib/python3/site-packages/pyresttest/__pycache__ 40755 root:root
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.opt-1.pyc 100644 root:root 94f6a95653b44e79db1774c6e2fd4553
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.opt-2.pyc 100644 root:root 94f6a95653b44e79db1774c6e2fd4553
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-37.pyc 100644 root:root 94f6a95653b44e79db1774c6e2fd4553
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.opt-1.pyc 100644 root:root 2679df128e99466e68c606ec653b5ce6
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.opt-2.pyc 100644 root:root daa2d4afd1a95000ac32c8d90bfed69e
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-37.pyc 100644 root:root 2679df128e99466e68c606ec653b5ce6
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.opt-1.pyc 100644 root:root 15c60a420825e71d9201168bc4d235a7
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.opt-2.pyc 100644 root:root 8c748aa5824ad2ce9e21558b55ee63ca
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-37.pyc 100644 root:root 15c60a420825e71d9201168bc4d235a7
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.opt-1.pyc 100644 root:root 6fb840cf9df8f0db2f97dc4ff4379c6a
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.opt-2.pyc 100644 root:root 805d443f9722049a5b5f05ba41c33bbc
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-37.pyc 100644 root:root 6fb840cf9df8f0db2f97dc4ff4379c6a
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.opt-1.pyc 100644 root:root f48a04d080c8a0714db363502bbb16f3
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.opt-2.pyc 100644 root:root 9fd540a5cfb8894fb56e833712acd6d6
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-37.pyc 100644 root:root f48a04d080c8a0714db363502bbb16f3
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.opt-1.pyc 100644 root:root f9f8c912060f1669c941c0f2d02bb302
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.opt-2.pyc 100644 root:root bcb47962d6de230d9176f45bc046b02c
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-37.pyc 100644 root:root f9f8c912060f1669c941c0f2d02bb302
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.opt-1.pyc 100644 root:root 9255d4a988bd4312463ab218ade04330
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.opt-2.pyc 100644 root:root 158c05b007a9f433f9b841e6c4ccba86
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-37.pyc 100644 root:root 7b2ddae5c8963e95103a9f55c678e32c
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.opt-1.pyc 100644 root:root 90f5f09f054a53277a05a3b16150d42d
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.opt-2.pyc 100644 root:root 40d1d9f92441ffb7db7ea435c42b3e96
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-37.pyc 100644 root:root 90f5f09f054a53277a05a3b16150d42d
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.opt-1.pyc 100644 root:root f50c94acae13bac70d4b595c4649dc41
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.opt-2.pyc 100644 root:root 0a5fcc2f258aad1d0f23d2b62f045ba2
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-37.pyc 100644 root:root fc6c8e8c5240f697977ee468c7dc150d
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.opt-1.pyc 100644 root:root 505fa56646333dba2f3de77a84408fe6
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.opt-2.pyc 100644 root:root e757a73fda4db78032475691deb24cbc
-File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-37.pyc 100644 root:root 505fa56646333dba2f3de77a84408fe6
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-1.pyc 100644 root:root 78b8115d72b46cbe1eb13169b4d574fe
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.opt-2.pyc 100644 root:root 78b8115d72b46cbe1eb13169b4d574fe
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/__init__.cpython-310.pyc 100644 root:root 78b8115d72b46cbe1eb13169b4d574fe
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.opt-1.pyc 100644 root:root ad2aaf41318794d43043640957ced64f
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.opt-2.pyc 100644 root:root 88090c34a61341fdcdaf26bd51c690e5
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/benchmarks.cpython-310.pyc 100644 root:root ad2aaf41318794d43043640957ced64f
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.opt-1.pyc 100644 root:root cb4de0cb2a209a932dba441106e0dd99
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.opt-2.pyc 100644 root:root efda11098a0616533fed722e7d2e416c
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/binding.cpython-310.pyc 100644 root:root cb4de0cb2a209a932dba441106e0dd99
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.opt-1.pyc 100644 root:root 96c9fd34fd4f70ad6b561efd4ecb835b
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.opt-2.pyc 100644 root:root d1e74d1be5f8612c001843e6885787d8
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/contenthandling.cpython-310.pyc 100644 root:root 96c9fd34fd4f70ad6b561efd4ecb835b
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.opt-1.pyc 100644 root:root 54188da9982ef0e9d49720c3330c74a3
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.opt-2.pyc 100644 root:root beb091820a57fd9d3562f4ec97911333
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/generators.cpython-310.pyc 100644 root:root 54188da9982ef0e9d49720c3330c74a3
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.opt-1.pyc 100644 root:root 343b45c7acfbbfd8810f2cf6337440f3
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.opt-2.pyc 100644 root:root 98f8cd1d00ddd05302dbaf29d44ffc50
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/parsing.cpython-310.pyc 100644 root:root 343b45c7acfbbfd8810f2cf6337440f3
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.opt-1.pyc 100644 root:root 83f83bd99279bd65a6fdb48541b1f00e
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.opt-2.pyc 100644 root:root 9dc4f7c5cf45c80a2eba9e8e60941fef
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/resttest.cpython-310.pyc 100644 root:root cbbcd5e03a30195b5a4e28b59876bdf4
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.opt-1.pyc 100644 root:root 33b2b57bb1d2d5d727d4895b652fbde0
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.opt-2.pyc 100644 root:root 8987bdb77afaf020bd1bb9685e6a5188
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/six.cpython-310.pyc 100644 root:root 33b2b57bb1d2d5d727d4895b652fbde0
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.opt-1.pyc 100644 root:root f8ae27e6a57673cf21b05869ec2f0b18
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.opt-2.pyc 100644 root:root 8546647a0092a3a1c1d4d51c53b425b7
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/tests.cpython-310.pyc 100644 root:root d646f1b8c406cdad603c27448beba773
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.opt-1.pyc 100644 root:root 056c1bb5e65a33cdeed4a8eb971ff441
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.opt-2.pyc 100644 root:root 3ded9787d8f0eaadf3f93b7bf5cb5ab8
+File: /usr/lib/python3/site-packages/pyresttest/__pycache__/validators.cpython-310.pyc 100644 root:root 056c1bb5e65a33cdeed4a8eb971ff441
File: /usr/lib/python3/site-packages/pyresttest/benchmarks.py 100644 root:root e9d8715f3b94f91a7b90a6bb472e454f
@@ -157,11 +157,11 @@
File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__ 40755 root:root
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.opt-1.pyc 100644 root:root f869a827f5b97ff818144ecfff177668
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.opt-2.pyc 100644 root:root f869a827f5b97ff818144ecfff177668
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-37.pyc 100644 root:root f869a827f5b97ff818144ecfff177668
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.opt-1.pyc 100644 root:root f34a4023987c49cc6cfc9b29ed69faf2
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.opt-2.pyc 100644 root:root 0231240329ce92452d46a9b30139e2d7
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-37.pyc 100644 root:root f34a4023987c49cc6cfc9b29ed69faf2
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.opt-1.pyc 100644 root:root 10fdc61505852cfa671c3e6ca7f2dbbe
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.opt-2.pyc 100644 root:root a55db341ed71a17eae4dc9ee2ba6575d
-File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-37.pyc 100644 root:root 10fdc61505852cfa671c3e6ca7f2dbbe
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-1.pyc 100644 root:root b6755200a1655e03dc12907ded606371
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.opt-2.pyc 100644 root:root b6755200a1655e03dc12907ded606371
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/__init__.cpython-310.pyc 100644 root:root b6755200a1655e03dc12907ded606371
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.opt-1.pyc 100644 root:root 9ea7867806cff455e2ad727a232cbf55
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.opt-2.pyc 100644 root:root ed375d27ff4855465023360ed2e27447
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/extractor_jmespath.cpython-310.pyc 100644 root:root 9ea7867806cff455e2ad727a232cbf55
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.opt-1.pyc 100644 root:root 3006551880b9a9b3d88ea58ee819b296
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.opt-2.pyc 100644 root:root 5846ab225ec9c59cc7763a1c09edb6f2
+File: /usr/lib/python3/site-packages/pyresttest/ext/__pycache__/validator_jsonschema.cpython-310.pyc 100644 root:root 3006551880b9a9b3d88ea58ee819b296
File: /usr/lib/python3/site-packages/pyresttest/ext/extractor_jmespath.py 100644 root:root 6b3a1b2b369a1dddf2dcd0cf07d91fdf
@@ -182,2 +182,2 @@
File: /usr/share/doc/python3-module-pyresttest-1.7.1/quickstart.md 100644 root:root 5dba27f82bc229f90a6916763ee1e17f
-RPMIdentity: a054dff96bb64e539af235df58bf7593da980bf8772848c2c4b36e4b0287a34dab306874c7c1a755be865b7ee8b3f13bdf8fb6b2490d984dc57524b8664d6dc7
+RPMIdentity: a10058f2c85049a9547655cb2aa5181e10127c5d91b6b30e6f507bb404e0340af7c71a5eca95ed49d2fc219f6fac044ae571c6480e82395dfc520e1f4a1bfbbb