Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/113427 Running as SYSTEM [EnvInject] - Loading node environment variables. Building remotely on prd-ubuntu2004-docker-4c-16g-21405 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master [ssh-agent] Looking for ssh-agent implementation... [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) $ ssh-agent SSH_AUTH_SOCK=/tmp/ssh-Bc4Y75YvtsIc/agent.13387 SSH_AGENT_PID=13389 [ssh-agent] Started. Running ssh-add (command line suppressed) Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_11670485467617310480.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_11670485467617310480.key) [ssh-agent] Using credentials jenkins (jenkins-ssh) The recommended git tool is: NONE using credential jenkins-ssh Wiping out workspace first. Cloning the remote Git repository Cloning repository git://devvexx.opendaylight.org/mirror/transportpce > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce > git --version # timeout=10 > git --version # 'git version 2.25.1' using GIT_SSH to set credentials jenkins-ssh Verifying host key using known hosts file You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce using GIT_SSH to set credentials jenkins-ssh Verifying host key using known hosts file You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/27/113427/8 # timeout=10 > git rev-parse 5785a50f98f92e9ec75b11f4a14fcf8aed95675c^{commit} # timeout=10 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script Checking out Revision 5785a50f98f92e9ec75b11f4a14fcf8aed95675c (refs/changes/27/113427/8) > git config core.sparsecheckout # timeout=10 > git checkout -f 5785a50f98f92e9ec75b11f4a14fcf8aed95675c # timeout=10 Commit message: "Update portmapping model" > git rev-parse FETCH_HEAD^{commit} # timeout=10 > git rev-list --no-walk ee77c94d73171d4eb7a8f85abdfd387dc14ffd3a # timeout=10 > git remote # timeout=10 > git submodule init # timeout=10 > git submodule sync # timeout=10 > git config --get remote.origin.url # timeout=10 > git submodule init # timeout=10 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 ERROR: No submodules found. provisioning config files... copy managed file [npmrc] to file:/home/jenkins/.npmrc copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12283157468764187510.sh ---> python-tools-install.sh Setup pyenv: * system (set by /opt/pyenv/version) * 3.8.13 (set by /opt/pyenv/version) * 3.9.13 (set by /opt/pyenv/version) * 3.10.13 (set by /opt/pyenv/version) * 3.11.7 (set by /opt/pyenv/version) lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-85VX lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv lf-activate-venv(): INFO: Installing: lftools lf-activate-venv(): INFO: Adding /tmp/venv-85VX/bin to PATH Generating Requirements File Python 3.11.7 pip 24.2 from /tmp/venv-85VX/lib/python3.11/site-packages/pip (python 3.11) appdirs==1.4.4 argcomplete==3.5.0 aspy.yaml==1.3.0 attrs==24.2.0 autopage==0.5.2 beautifulsoup4==4.12.3 boto3==1.35.17 botocore==1.35.17 bs4==0.0.2 cachetools==5.5.0 certifi==2024.8.30 cffi==1.17.1 cfgv==3.4.0 chardet==5.2.0 charset-normalizer==3.3.2 click==8.1.7 cliff==4.7.0 cmd2==2.4.3 cryptography==3.3.2 debtcollector==3.0.0 decorator==5.1.1 defusedxml==0.7.1 Deprecated==1.2.14 distlib==0.3.8 dnspython==2.6.1 docker==4.2.2 dogpile.cache==1.3.3 email_validator==2.2.0 filelock==3.16.0 future==1.0.0 gitdb==4.0.11 GitPython==3.1.43 google-auth==2.34.0 httplib2==0.22.0 identify==2.6.0 idna==3.8 importlib-resources==1.5.0 iso8601==2.1.0 Jinja2==3.1.4 jmespath==1.0.1 jsonpatch==1.33 jsonpointer==3.0.0 jsonschema==4.23.0 jsonschema-specifications==2023.12.1 keystoneauth1==5.8.0 kubernetes==30.1.0 lftools==0.37.10 lxml==5.3.0 MarkupSafe==2.1.5 msgpack==1.1.0 multi_key_dict==2.0.3 munch==4.0.0 netaddr==1.3.0 netifaces==0.11.0 niet==1.4.2 nodeenv==1.9.1 oauth2client==4.1.3 oauthlib==3.2.2 openstacksdk==4.0.0 os-client-config==2.1.0 os-service-types==1.7.0 osc-lib==3.1.0 oslo.config==9.6.0 oslo.context==5.6.0 oslo.i18n==6.4.0 oslo.log==6.1.2 oslo.serialization==5.5.0 oslo.utils==7.3.0 packaging==24.1 pbr==6.1.0 platformdirs==4.3.2 prettytable==3.11.0 pyasn1==0.6.1 pyasn1_modules==0.4.1 pycparser==2.22 pygerrit2==2.0.15 PyGithub==2.4.0 PyJWT==2.9.0 PyNaCl==1.5.0 pyparsing==2.4.7 pyperclip==1.9.0 pyrsistent==0.20.0 python-cinderclient==9.6.0 python-dateutil==2.9.0.post0 python-heatclient==4.0.0 python-jenkins==1.8.2 python-keystoneclient==5.5.0 python-magnumclient==4.7.0 python-openstackclient==7.1.0 python-swiftclient==4.6.0 PyYAML==6.0.2 referencing==0.35.1 requests==2.32.3 requests-oauthlib==2.0.0 requestsexceptions==1.4.0 rfc3986==2.0.0 rpds-py==0.20.0 rsa==4.9 ruamel.yaml==0.18.6 ruamel.yaml.clib==0.2.8 s3transfer==0.10.2 simplejson==3.19.3 six==1.16.0 smmap==5.0.1 soupsieve==2.6 stevedore==5.3.0 tabulate==0.9.0 toml==0.10.2 tomlkit==0.13.2 tqdm==4.66.5 typing_extensions==4.12.2 tzdata==2024.1 urllib3==1.26.20 virtualenv==20.26.4 wcwidth==0.2.13 websocket-client==1.8.0 wrapt==1.16.0 xdg==6.0.0 xmltodict==0.13.0 yq==3.4.3 [EnvInject] - Injecting environment variables from a build step. [EnvInject] - Injecting as environment variables the properties content PYTHON=python3 [EnvInject] - Variables injected successfully. [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins9818288388158612325.sh ---> tox-install.sh + source /home/jenkins/lf-env.sh + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 ++ mktemp -d /tmp/venv-XXXX + lf_venv=/tmp/venv-GRIC + local venv_file=/tmp/.os_lf_venv + local python=python3 + local options + local set_path=true + local install_args= ++ getopt -o np:v: -l no-path,system-site-packages,python:,venv-file: -n lf-activate-venv -- --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 + true + case $1 in + venv_file=/tmp/.toxenv + shift 2 + true + case $1 in + shift + break + case $python in + local pkg_list= + [[ -d /opt/pyenv ]] + echo 'Setup pyenv:' Setup pyenv: + export PYENV_ROOT=/opt/pyenv + PYENV_ROOT=/opt/pyenv + export PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + pyenv versions system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) + command -v pyenv ++ pyenv init - --no-rehash + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); for i in ${!paths[@]}; do if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; fi; done; echo "${paths[*]}"'\'')" export PATH="/opt/pyenv/shims:${PATH}" export PYENV_SHELL=bash source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' pyenv() { local command command="${1:-}" if [ "$#" -gt 0 ]; then shift fi case "$command" in rehash|shell) eval "$(pyenv "sh-$command" "$@")" ;; *) command pyenv "$command" "$@" ;; esac }' +++ bash --norc -ec 'IFS=:; paths=($PATH); for i in ${!paths[@]}; do if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; fi; done; echo "${paths[*]}"' ++ PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ export PYENV_SHELL=bash ++ PYENV_SHELL=bash ++ source /opt/pyenv/libexec/../completions/pyenv.bash +++ complete -F _pyenv pyenv ++ lf-pyver python3 ++ local py_version_xy=python3 ++ local py_version_xyz= ++ pyenv versions ++ local command ++ awk '{ print $1 }' ++ grep -E '^[0-9.]*[0-9]$' ++ sed 's/^[ *]* //' ++ command=versions ++ '[' 1 -gt 0 ']' ++ shift ++ case "$command" in ++ command pyenv versions ++ pyenv versions ++ [[ ! -s /tmp/.pyenv_versions ]] +++ grep '^3' /tmp/.pyenv_versions +++ sort -V +++ tail -n 1 ++ py_version_xyz=3.11.7 ++ [[ -z 3.11.7 ]] ++ echo 3.11.7 ++ return 0 + pyenv local 3.11.7 + local command + command=local + '[' 2 -gt 0 ']' + shift + case "$command" in + command pyenv local 3.11.7 + pyenv local 3.11.7 + for arg in "$@" + case $arg in + pkg_list+='tox ' + for arg in "$@" + case $arg in + pkg_list+='virtualenv ' + for arg in "$@" + case $arg in + pkg_list+='urllib3~=1.26.15 ' + [[ -f /tmp/.toxenv ]] + [[ ! -f /tmp/.toxenv ]] + [[ -n '' ]] + python3 -m venv /tmp/venv-GRIC + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-GRIC' lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-GRIC + echo /tmp/venv-GRIC + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv + /tmp/venv-GRIC/bin/python3 -m pip install --upgrade --quiet pip virtualenv + [[ -z tox virtualenv urllib3~=1.26.15 ]] + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 + /tmp/venv-GRIC/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 + type python3 + true + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-GRIC/bin to PATH' lf-activate-venv(): INFO: Adding /tmp/venv-GRIC/bin to PATH + PATH=/tmp/venv-GRIC/bin:/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + return 0 + python3 --version Python 3.11.7 + python3 -m pip --version pip 24.2 from /tmp/venv-GRIC/lib/python3.11/site-packages/pip (python 3.11) + python3 -m pip freeze cachetools==5.5.0 chardet==5.2.0 colorama==0.4.6 distlib==0.3.8 filelock==3.16.0 packaging==24.1 platformdirs==4.3.2 pluggy==1.5.0 pyproject-api==1.7.1 tox==4.18.1 urllib3==1.26.20 virtualenv==20.26.4 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins5200284874510320455.sh [EnvInject] - Injecting environment variables from a build step. [EnvInject] - Injecting as environment variables the properties content PARALLEL=True [EnvInject] - Variables injected successfully. [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins12006255371890734371.sh ---> tox-run.sh + PATH=/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox + cd /w/workspace/transportpce-tox-verify-transportpce-master/. + source /home/jenkins/lf-env.sh + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 ++ mktemp -d /tmp/venv-XXXX + lf_venv=/tmp/venv-rwBK + local venv_file=/tmp/.os_lf_venv + local python=python3 + local options + local set_path=true + local install_args= ++ getopt -o np:v: -l no-path,system-site-packages,python:,venv-file: -n lf-activate-venv -- --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 + true + case $1 in + venv_file=/tmp/.toxenv + shift 2 + true + case $1 in + shift + break + case $python in + local pkg_list= + [[ -d /opt/pyenv ]] + echo 'Setup pyenv:' Setup pyenv: + export PYENV_ROOT=/opt/pyenv + PYENV_ROOT=/opt/pyenv + export PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + pyenv versions system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) + command -v pyenv ++ pyenv init - --no-rehash + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); for i in ${!paths[@]}; do if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; fi; done; echo "${paths[*]}"'\'')" export PATH="/opt/pyenv/shims:${PATH}" export PYENV_SHELL=bash source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' pyenv() { local command command="${1:-}" if [ "$#" -gt 0 ]; then shift fi case "$command" in rehash|shell) eval "$(pyenv "sh-$command" "$@")" ;; *) command pyenv "$command" "$@" ;; esac }' +++ bash --norc -ec 'IFS=:; paths=($PATH); for i in ${!paths[@]}; do if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; fi; done; echo "${paths[*]}"' ++ PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ export PYENV_SHELL=bash ++ PYENV_SHELL=bash ++ source /opt/pyenv/libexec/../completions/pyenv.bash +++ complete -F _pyenv pyenv ++ lf-pyver python3 ++ local py_version_xy=python3 ++ local py_version_xyz= ++ pyenv versions ++ local command ++ command=versions ++ '[' 1 -gt 0 ']' ++ shift ++ case "$command" in ++ command pyenv versions ++ pyenv versions ++ sed 's/^[ *]* //' ++ awk '{ print $1 }' ++ grep -E '^[0-9.]*[0-9]$' ++ [[ ! -s /tmp/.pyenv_versions ]] +++ grep '^3' /tmp/.pyenv_versions +++ tail -n 1 +++ sort -V ++ py_version_xyz=3.11.7 ++ [[ -z 3.11.7 ]] ++ echo 3.11.7 ++ return 0 + pyenv local 3.11.7 + local command + command=local + '[' 2 -gt 0 ']' + shift + case "$command" in + command pyenv local 3.11.7 + pyenv local 3.11.7 + for arg in "$@" + case $arg in + pkg_list+='tox ' + for arg in "$@" + case $arg in + pkg_list+='virtualenv ' + for arg in "$@" + case $arg in + pkg_list+='urllib3~=1.26.15 ' + [[ -f /tmp/.toxenv ]] ++ cat /tmp/.toxenv + lf_venv=/tmp/venv-GRIC + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-GRIC from' file:/tmp/.toxenv lf-activate-venv(): INFO: Reuse venv:/tmp/venv-GRIC from file:/tmp/.toxenv + /tmp/venv-GRIC/bin/python3 -m pip install --upgrade --quiet pip virtualenv + [[ -z tox virtualenv urllib3~=1.26.15 ]] + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 + /tmp/venv-GRIC/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 + type python3 + true + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-GRIC/bin to PATH' lf-activate-venv(): INFO: Adding /tmp/venv-GRIC/bin to PATH + PATH=/tmp/venv-GRIC/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + return 0 + [[ -d /opt/pyenv ]] + echo '---> Setting up pyenv' ---> Setting up pyenv + export PYENV_ROOT=/opt/pyenv + PYENV_ROOT=/opt/pyenv + export PATH=/opt/pyenv/bin:/tmp/venv-GRIC/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin + PATH=/opt/pyenv/bin:/tmp/venv-GRIC/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin ++ pwd + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master + export PYTHONPATH + export TOX_TESTENV_PASSENV=PYTHONPATH + TOX_TESTENV_PASSENV=PYTHONPATH + tox --version 4.18.1 from /tmp/venv-GRIC/lib/python3.11/site-packages/tox/__init__.py + PARALLEL=True + TOX_OPTIONS_LIST= + [[ -n '' ]] + case ${PARALLEL,,} in + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' + tox --parallel auto --parallel-live + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt buildcontroller: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt docs: install_deps> python -I -m pip install -r docs/requirements.txt checkbashisms: freeze> python -m pip freeze --all checkbashisms: pip==24.2,setuptools==74.1.2,wheel==0.44.0 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh checkbashisms: commands[1] /w/workspace/transportpce-tox-verify-transportpce-master/tests> sh -c 'command checkbashisms>/dev/null || sudo yum install -y devscripts-checkbashisms || sudo yum install -y devscripts-minimal || sudo yum install -y devscripts || sudo yum install -y https://archives.fedoraproject.org/pub/archive/fedora/linux/releases/31/Everything/x86_64/os/Packages/d/devscripts-checkbashisms-2.19.6-2.fc31.x86_64.rpm || (echo "checkbashisms command not found - please install it (e.g. sudo apt-get install devscripts | yum install devscripts-minimal )" >&2 && exit 1)' checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + script ./reflectwarn.sh does not appear to have a #! interpreter line; you may get strange results checkbashisms: OK ✔ in 2.74 seconds pre-commit: install_deps> python -I -m pip install pre-commit pre-commit: freeze> python -m pip freeze --all pre-commit: cfgv==3.4.0,distlib==0.3.8,filelock==3.16.0,identify==2.6.0,nodeenv==1.9.1,pip==24.2,platformdirs==4.3.2,pre-commit==3.8.0,PyYAML==6.0.2,setuptools==74.1.2,virtualenv==20.26.4,wheel==0.44.0 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh pre-commit: commands[1] /w/workspace/transportpce-tox-verify-transportpce-master/tests> sh -c 'which cpan || sudo yum install -y perl-CPAN || (echo "cpan command not found - please install it (e.g. sudo apt-get install perl-modules | yum install perl-CPAN )" >&2 && exit 1)' /usr/bin/cpan pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. buildcontroller: freeze> python -m pip freeze --all [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. buildcontroller: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh + update-java-alternatives -l java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 [INFO] Initializing environment for https://github.com/perltidy/perltidy. + java -version + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 21 + JAVA_VER=21 + echo 21 + javac -version + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; + JAVAC_VER=21 + echo 21 21 ok, java is 21 or newer + [ 21 -ge 21 ] + [ 21 -ge 21 ] + echo ok, java is 21 or newer + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. [INFO] Once installed this environment will be reused. [INFO] This may take a few minutes... 2024-09-12 14:20:10 URL:https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz [9083702/9083702] -> "/tmp/apache-maven-3.9.8-bin.tar.gz" [1] + sudo mkdir -p /opt + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn + mvn --version Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) Maven home: /opt/maven Java version: 21.0.4, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 Default locale: en, platform encoding: UTF-8 OS name: "linux", version: "5.4.0-190-generic", arch: "amd64", family: "unix" NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.nio.file=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.jar=ALL-UNNAMED --add-opens=java.base/java.util.stream=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED --add-opens java.base/sun.nio.fs=ALL-UNNAMED -Xlog:disable [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. [INFO] Once installed this environment will be reused. [INFO] This may take a few minutes... [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. [INFO] Once installed this environment will be reused. [INFO] This may take a few minutes... [INFO] Installing environment for https://github.com/perltidy/perltidy. [INFO] Once installed this environment will be reused. [INFO] This may take a few minutes... docs: freeze> python -m pip freeze --all docs: alabaster==0.7.16,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.3.2,contourpy==1.3.0,cycler==0.12.1,docutils==0.20.1,fonttools==4.53.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.8,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==2.1.5,matplotlib==3.9.2,numpy==2.1.1,nwdiag==3.0.0,packaging==24.1,pillow==10.4.0,pip==24.2,Pygments==2.18.0,pyparsing==3.1.4,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==74.1.2,six==1.16.0,snowballstemmer==2.2.0,Sphinx==7.4.7,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==2.0.0,sphinx-tabs==3.4.5,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 docs: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> sphinx-build -q -W --keep-going -b html -n -d /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs/tmp/doctrees ../docs/ /w/workspace/transportpce-tox-verify-transportpce-master/docs/_build/html docs-linkcheck: freeze> python -m pip freeze --all docs-linkcheck: alabaster==0.7.16,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.3.2,contourpy==1.3.0,cycler==0.12.1,docutils==0.20.1,fonttools==4.53.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.8,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==2.1.5,matplotlib==3.9.2,numpy==2.1.1,nwdiag==3.0.0,packaging==24.1,pillow==10.4.0,pip==24.2,Pygments==2.18.0,pyparsing==3.1.4,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==74.1.2,six==1.16.0,snowballstemmer==2.2.0,Sphinx==7.4.7,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==2.0.0,sphinx-tabs==3.4.5,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 docs-linkcheck: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> sphinx-build -q -b linkcheck -d /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs-linkcheck/tmp/doctrees ../docs/ /w/workspace/transportpce-tox-verify-transportpce-master/docs/_build/linkcheck /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs-linkcheck/lib/python3.11/site-packages/sphinx/builders/linkcheck.py:86: RemovedInSphinx80Warning: The default value for 'linkcheck_report_timeouts_as_broken' will change to False in Sphinx 8, meaning that request timeouts will be reported with a new 'timeout' status, instead of as 'broken'. This is intended to provide more detail as to the failure mode. See https://github.com/sphinx-doc/sphinx/issues/11868 for details. warnings.warn(deprecation_msg, RemovedInSphinx80Warning, stacklevel=1) docs: OK ✔ in 30.57 seconds pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' trim trailing whitespace.................................................Passed Tabs remover.............................................................Passed autopep8.................................................................docs-linkcheck: OK ✔ in 32.78 seconds pylint: freeze> python -m pip freeze --all pylint: astroid==3.2.4,dill==0.3.8,isort==5.13.2,mccabe==0.7.0,pip==24.2,platformdirs==4.3.2,pylint==3.2.7,setuptools==74.1.2,tomlkit==0.13.2,wheel==0.44.0 pylint: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find transportpce_tests/ -name '*.py' -exec pylint --fail-under=10 --max-line-length=120 --disable=missing-docstring,import-error --disable=fixme --disable=duplicate-code '--module-rgx=([a-z0-9_]+$)|([0-9.]{1,30}$)' '--method-rgx=(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$' '--variable-rgx=[a-zA-Z_][a-zA-Z0-9_]{1,30}$' '{}' + Passed perltidy.................................................................Passed pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual [INFO] Installing environment for https://github.com/jorisroovers/gitlint. [INFO] Once installed this environment will be reused. [INFO] This may take a few minutes... gitlint..................................................................Passed ------------------------------------ Your code has been rated at 10.00/10 pre-commit: OK ✔ in 42.94 seconds pylint: OK ✔ in 26.3 seconds buildcontroller: OK ✔ in 1 minute 43.21 seconds build_karaf_tests121: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt sims: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt build_karaf_tests221: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt testsPCE: install_deps> python -I -m pip install gnpy4tpce==2.4.7 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt sims: freeze> python -m pip freeze --all build_karaf_tests221: freeze> python -m pip freeze --all build_karaf_tests121: freeze> python -m pip freeze --all sims: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh Using lighynode version 20.1.0.2 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory build_karaf_tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.nio.file=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.jar=ALL-UNNAMED --add-opens=java.base/java.util.stream=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED --add-opens java.base/sun.nio.fs=ALL-UNNAMED -Xlog:disable build_karaf_tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.nio.file=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.jar=ALL-UNNAMED --add-opens=java.base/java.util.stream=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED --add-opens java.base/sun.nio.fs=ALL-UNNAMED -Xlog:disable sims: OK ✔ in 11.27 seconds build_karaf_tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt build_karaf_tests71: freeze> python -m pip freeze --all build_karaf_tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.nio.file=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.jar=ALL-UNNAMED --add-opens=java.base/java.util.stream=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED --add-opens java.base/sun.nio.fs=ALL-UNNAMED -Xlog:disable build_karaf_tests221: OK ✔ in 55.37 seconds build_karaf_tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt build_karaf_tests121: OK ✔ in 56.9 seconds tests_tapi: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt build_karaf_tests_hybrid: freeze> python -m pip freeze --all build_karaf_tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.invoke=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.net=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED --add-opens=java.base/java.nio.charset=ALL-UNNAMED --add-opens=java.base/java.nio.file=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.jar=ALL-UNNAMED --add-opens=java.base/java.util.stream=ALL-UNNAMED --add-opens=java.base/java.util.zip=ALL-UNNAMED --add-opens java.base/sun.nio.ch=ALL-UNNAMED --add-opens java.base/sun.nio.fs=ALL-UNNAMED -Xlog:disable tests_tapi: freeze> python -m pip freeze --all tests_tapi: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi using environment variables from ./karaf221.env pytest -q transportpce_tests/tapi/test01_abstracted_topology.py build_karaf_tests71: OK ✔ in 53.56 seconds testsPCE: freeze> python -m pip freeze --all testsPCE: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,click==8.1.7,contourpy==1.3.0,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.6,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.53.1,gnpy4tpce==2.4.7,idna==3.8,iniconfig==2.0.0,injector==0.22.0,itsdangerous==2.2.0,Jinja2==3.1.4,kiwisolver==1.4.7,lxml==5.3.0,MarkupSafe==2.1.5,matplotlib==3.9.2,netconf-client==3.1.1,networkx==2.8.8,numpy==1.26.4,packaging==24.1,pandas==1.5.3,paramiko==3.4.1,pbr==5.11.1,pillow==10.4.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pyparsing==3.1.4,pytest==8.3.3,python-dateutil==2.9.0.post0,pytz==2024.2,requests==2.32.3,scipy==1.14.1,setuptools==50.3.2,six==1.16.0,urllib3==2.2.3,Werkzeug==2.0.3,wheel==0.44.0,xlrd==1.2.0 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce pytest -q transportpce_tests/pce/test01_pce.py .............................. [100%] 20 passed in 123.87s (0:02:03) pytest -q transportpce_tests/pce/test02_pce_400G.py ............................... [100%] 9 passed in 42.38s pytest -q transportpce_tests/pce/test03_gnpy.py ............. [100%] 8 passed in 39.14s pytest -q transportpce_tests/pce/test04_pce_bug_fix.py ............... [100%] 3 passed in 37.31s build_karaf_tests_hybrid: OK ✔ in 1 minute 0.69 seconds testsPCE: OK ✔ in 5 minutes 14.66 seconds tests121: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt tests121: freeze> python -m pip freeze --all tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 using environment variables from ./karaf121.env pytest -q transportpce_tests/1.2.1/test01_portmapping.py . [100%] 50 passed in 420.40s (0:07:00) pytest -q transportpce_tests/tapi/test02_full_topology.py .FFFFF...........F.FFFFFFFFFFF...... [100%] =================================== FAILURES =================================== _____________ TransportPCEtesting.test_12_check_openroadm_topology _____________ self = def test_12_check_openroadm_topology(self): response = test_utils.get_ietf_network_request('openroadm-topology', 'config') self.assertEqual(response['status_code'], requests.codes.ok) > self.assertEqual(len(response['network'][0]['node']), 13, 'There should be 13 openroadm nodes') E AssertionError: 14 != 13 : There should be 13 openroadm nodes transportpce_tests/tapi/test02_full_topology.py:272: AssertionError ________________ TransportPCEtesting.test_14_check_sip_details _________________ self = def test_14_check_sip_details(self): response = test_utils.transportpce_api_rpc_request( 'tapi-common', 'get-service-interface-point-list', None) > self.assertEqual(len(response['output']['sip']), 72, 'There should be 72 service interface point') E AssertionError: 28 != 72 : There should be 72 service interface point transportpce_tests/tapi/test02_full_topology.py:291: AssertionError ____ TransportPCEtesting.test_15_create_connectivity_service_PhotonicMedia _____ self = def test_15_create_connectivity_service_PhotonicMedia(self): self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sAOTS self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZOTS response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) time.sleep(self.WAITING) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 500 != 200 transportpce_tests/tapi/test02_full_topology.py:300: AssertionError ____________ TransportPCEtesting.test_16_get_service_PhotonicMedia _____________ self = def test_16_get_service_PhotonicMedia(self): response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.pm)) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/tapi/test02_full_topology.py:330: AssertionError _________ TransportPCEtesting.test_17_create_connectivity_service_ODU __________ self = def test_17_create_connectivity_service_ODU(self): # pylint: disable=line-too-long self.cr_serv_input_data["layer-protocol-name"] = "ODU" self.cr_serv_input_data["end-point"][0]["layer-protocol-name"] = "ODU" self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sAeODU self.cr_serv_input_data["end-point"][1]["layer-protocol-name"] = "ODU" self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZeODU # self.cr_serv_input_data["connectivity-constraint"]["service-layer"] = "ODU" self.cr_serv_input_data["connectivity-constraint"]["service-level"] = self.uuid_services.pm response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) time.sleep(self.WAITING) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 500 != 200 transportpce_tests/tapi/test02_full_topology.py:351: AssertionError _________________ TransportPCEtesting.test_18_get_service_ODU __________________ self = def test_18_get_service_ODU(self): response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.odu)) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/tapi/test02_full_topology.py:379: AssertionError _________ TransportPCEtesting.test_19_create_connectivity_service_DSR __________ self = def test_19_create_connectivity_service_DSR(self): # pylint: disable=line-too-long self.cr_serv_input_data["layer-protocol-name"] = "DSR" self.cr_serv_input_data["end-point"][0]["layer-protocol-name"] = "DSR" self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sADSR self.cr_serv_input_data["end-point"][1]["layer-protocol-name"] = "DSR" self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZDSR # self.cr_serv_input_data["connectivity-constraint"]["service-layer"] = "DSR" self.cr_serv_input_data["connectivity-constraint"]["requested-capacity"]["total-size"]["value"] = "10" self.cr_serv_input_data["connectivity-constraint"]["service-level"] = self.uuid_services.odu response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) time.sleep(self.WAITING) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 500 != 200 transportpce_tests/tapi/test02_full_topology.py:401: AssertionError _________________ TransportPCEtesting.test_20_get_service_DSR __________________ self = def test_20_get_service_DSR(self): response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.dsr)) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/tapi/test02_full_topology.py:432: AssertionError __________ TransportPCEtesting.test_21_get_connectivity_service_list ___________ self = def test_21_get_connectivity_service_list(self): response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'get-connectivity-service-list', None) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 500 != 200 transportpce_tests/tapi/test02_full_topology.py:442: AssertionError _________ TransportPCEtesting.test_22_delete_connectivity_service_DSR __________ self = def test_22_delete_connectivity_service_DSR(self): self.del_serv_input_data["uuid"] = str(self.uuid_services.dsr) response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) E AssertionError: 500 not found in (200, 204) transportpce_tests/tapi/test02_full_topology.py:471: AssertionError _________ TransportPCEtesting.test_23_delete_connectivity_service_ODU __________ self = def test_23_delete_connectivity_service_ODU(self): self.del_serv_input_data["uuid"] = str(self.uuid_services.odu) response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) E AssertionError: 500 not found in (200, 204) transportpce_tests/tapi/test02_full_topology.py:478: AssertionError ____ TransportPCEtesting.test_24_delete_connectivity_service_PhotonicMedia _____ self = def test_24_delete_connectivity_service_PhotonicMedia(self): self.del_serv_input_data["uuid"] = str(self.uuid_services.pm) response = test_utils.transportpce_api_rpc_request( 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) E AssertionError: 500 not found in (200, 204) transportpce_tests/tapi/test02_full_topology.py:485: AssertionError =========================== short test summary info ============================ FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_12_check_openroadm_topology FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_14_check_sip_details FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_15_create_connectivity_service_PhotonicMedia FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_16_get_service_PhotonicMedia FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_17_create_connectivity_service_ODU FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_18_get_service_ODU FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_19_create_connectivity_service_DSR FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_20_get_service_DSR FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_21_get_connectivity_service_list FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_22_delete_connectivity_service_DSR FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_23_delete_connectivity_service_ODU FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_24_delete_connectivity_service_PhotonicMedia 12 failed, 18 passed in 211.44s (0:03:31) tests_tapi: exit 1 (632.35 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=30679 tests_tapi: FAIL ✖ in 10 minutes 39.48 seconds tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt tests71: freeze> python -m pip freeze --all tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 using environment variables from ./karaf71.env pytest -q transportpce_tests/7.1/test01_portmapping.py .FFFFFFFF............ [100%] 12 passed in 42.87s pytest -q transportpce_tests/7.1/test02_otn_renderer.py .............................................................. [100%] 62 passed in 157.41s (0:02:37) pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py FFFFF. [100%] =================================== FAILURES =================================== _________ TransportPCEPortMappingTesting.test_02_rdm_device_connected __________ self = def test_02_rdm_device_connected(self): response = test_utils.check_device_connection("ROADMA01") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:54: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_02_rdm_device_connected _________ TransportPCEPortMappingTesting.test_03_rdm_portmapping_info __________ self = def test_03_rdm_portmapping_info(self): response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:60: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_03_rdm_portmapping_info _____ TransportPCEPortMappingTesting.test_04_rdm_portmapping_DEG1_TTP_TXRX _____ self = def test_04_rdm_portmapping_DEG1_TTP_TXRX(self): response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "DEG1-TTP-TXRX") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:73: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_04_rdm_portmapping_DEG1_TTP_TXRX _____ TransportPCEPortMappingTesting.test_05_rdm_portmapping_SRG1_PP7_TXRX _____ self = def test_05_rdm_portmapping_SRG1_PP7_TXRX(self): response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG1-PP7-TXRX") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:82: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_05_rdm_portmapping_SRG1_PP7_TXRX _____ TransportPCEPortMappingTesting.test_06_rdm_portmapping_SRG3_PP1_TXRX _____ self = def test_06_rdm_portmapping_SRG3_PP1_TXRX(self): response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG3-PP1-TXRX") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:91: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_06_rdm_portmapping_SRG3_PP1_TXRX _________ TransportPCEPortMappingTesting.test_08_xpdr_device_connected _________ self = def test_08_xpdr_device_connected(self): response = test_utils.check_device_connection("XPDRA01") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:104: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_08_xpdr_device_connected _________ TransportPCEPortMappingTesting.test_09_xpdr_portmapping_info _________ self = def test_09_xpdr_portmapping_info(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:110: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_09_xpdr_portmapping_info _______ TransportPCEPortMappingTesting.test_10_xpdr_portmapping_NETWORK1 _______ self = def test_10_xpdr_portmapping_NETWORK1(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK1") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:123: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_10_xpdr_portmapping_NETWORK1 _______ TransportPCEPortMappingTesting.test_11_xpdr_portmapping_NETWORK2 _______ self = def test_11_xpdr_portmapping_NETWORK2(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK2") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:134: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_11_xpdr_portmapping_NETWORK2 _______ TransportPCEPortMappingTesting.test_12_xpdr_portmapping_CLIENT1 ________ self = def test_12_xpdr_portmapping_CLIENT1(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT1") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:145: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_12_xpdr_portmapping_CLIENT1 _______ TransportPCEPortMappingTesting.test_13_xpdr_portmapping_CLIENT2 ________ self = def test_13_xpdr_portmapping_CLIENT2(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT2") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:157: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_13_xpdr_portmapping_CLIENT2 _______ TransportPCEPortMappingTesting.test_14_xpdr_portmapping_CLIENT3 ________ self = def test_14_xpdr_portmapping_CLIENT3(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT3") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:169: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_14_xpdr_portmapping_CLIENT3 _______ TransportPCEPortMappingTesting.test_15_xpdr_portmapping_CLIENT4 ________ self = def test_15_xpdr_portmapping_CLIENT4(self): response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT4") > self.assertEqual(response['status_code'], requests.codes.ok) E AssertionError: 409 != 200 transportpce_tests/1.2.1/test01_portmapping.py:181: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_15_xpdr_portmapping_CLIENT4 _______ TransportPCEPortMappingTesting.test_16_xpdr_device_disconnection _______ self = def test_16_xpdr_device_disconnection(self): response = test_utils.unmount_device("XPDRA01") > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) E AssertionError: 409 not found in (200, 204) transportpce_tests/1.2.1/test01_portmapping.py:192: AssertionError ----------------------------- Captured stdout call ----------------------------- execution of test_16_xpdr_device_disconnection Searching for pattern 'onDeviceDisConnected:\ XPDRA01' in karaf.log... Pattern not found after 180 seconds! Node XPDRA01 still not deleted from tpce topology... _______ TransportPCEPortMappingTesting.test_17_xpdr_device_disconnected ________ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: > sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection raise err _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ address = ('localhost', 8182), timeout = 10, source_address = None socket_options = [(6, 1, 1)] def create_connection( address: tuple[str, int], timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, source_address: tuple[str, int] | None = None, socket_options: _TYPE_SOCKET_OPTIONS | None = None, ) -> socket.socket: """Connect to *address* and return the socket object. Convenience function. Connect to *address* (a 2-tuple ``(host, port)``) and return the socket object. Passing the optional *timeout* parameter will set the timeout on the socket instance before attempting to connect. If no *timeout* is supplied, the global default timeout setting returned by :func:`socket.getdefaulttimeout` is used. If *source_address* is set it must be a tuple of (host, port) for the socket to bind as a source address before making the connection. An host of '' or port 0 tells the OS to use the default. """ host, port = address if host.startswith("["): host = host.strip("[]") err = None # Using the value from allowed_gai_family() in the context of getaddrinfo lets # us select whether to work with IPv4 DNS records, IPv6 records, or both. # The original create_connection function always returns all records. family = allowed_gai_family() try: host.encode("idna") except UnicodeError: raise LocationParseError(f"'{host}', label empty or too long") from None for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): af, socktype, proto, canonname, sa = res sock = None try: sock = socket.socket(af, socktype, proto) # If provided, set socket level options before connecting. _set_socket_options(sock, socket_options) if timeout is not _DEFAULT_TIMEOUT: sock.settimeout(timeout) if source_address: sock.bind(source_address) > sock.connect(sa) E ConnectionRefusedError: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError The above exception was the direct cause of the following exception: self = method = 'GET' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' body = None headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) redirect = False, assert_same_host = False timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None release_conn = False, chunked = False, body_pos = None, preload_content = False decode_content = False, response_kw = {} parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01', query='content=nonconfig', fragment=None) destination_scheme = None, conn = None, release_this_conn = True http_tunnel_required = False, err = None, clean_exit = False def urlopen( # type: ignore[override] self, method: str, url: str, body: _TYPE_BODY | None = None, headers: typing.Mapping[str, str] | None = None, retries: Retry | bool | int | None = None, redirect: bool = True, assert_same_host: bool = True, timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, pool_timeout: int | None = None, release_conn: bool | None = None, chunked: bool = False, body_pos: _TYPE_BODY_POSITION | None = None, preload_content: bool = True, decode_content: bool = True, **response_kw: typing.Any, ) -> BaseHTTPResponse: """ Get a connection from the pool and perform an HTTP request. This is the lowest level call for making a request, so you'll need to specify all the raw details. .. note:: More commonly, it's appropriate to use a convenience method such as :meth:`request`. .. note:: `release_conn` will only behave as expected if `preload_content=False` because we want to make `preload_content=False` the default behaviour someday soon without breaking backwards compatibility. :param method: HTTP request method (such as GET, POST, PUT, etc.) :param url: The URL to perform the request on. :param body: Data to send in the request body, either :class:`str`, :class:`bytes`, an iterable of :class:`str`/:class:`bytes`, or a file-like object. :param headers: Dictionary of custom headers to send, such as User-Agent, If-None-Match, etc. If None, pool headers are used. If provided, these headers completely replace any pool-specific headers. :param retries: Configure the number of retries to allow before raising a :class:`~urllib3.exceptions.MaxRetryError` exception. If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a :class:`~urllib3.util.retry.Retry` object for fine-grained control over different types of retries. Pass an integer number to retry connection errors that many times, but no other types of errors. Pass zero to never retry. If ``False``, then retries are disabled and any exception is raised immediately. Also, instead of raising a MaxRetryError on redirects, the redirect response will be returned. :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. :param redirect: If True, automatically handle redirects (status codes 301, 302, 303, 307, 308). Each redirect counts as a retry. Disabling retries will disable redirect, too. :param assert_same_host: If ``True``, will make sure that the host of the pool requests is consistent else will raise HostChangedError. When ``False``, you can use the pool on an HTTP proxy and request foreign hosts. :param timeout: If specified, overrides the default timeout for this one request. It may be a float (in seconds) or an instance of :class:`urllib3.util.Timeout`. :param pool_timeout: If set and the pool is set to block=True, then this method will block for ``pool_timeout`` seconds and raise EmptyPoolError if no connection is available within the time period. :param bool preload_content: If True, the response's body will be preloaded into memory. :param bool decode_content: If True, will attempt to decode the body based on the 'content-encoding' header. :param release_conn: If False, then the urlopen call will not release the connection back into the pool once a response is received (but will release if you read the entire contents of the response such as when `preload_content=True`). This is useful if you're not preloading the response's content immediately. You will need to call ``r.release_conn()`` on the response ``r`` to return the connection back into the pool. If None, it takes the value of ``preload_content`` which defaults to ``True``. :param bool chunked: If True, urllib3 will send the body using chunked transfer encoding. Otherwise, urllib3 will send the body using the standard content-length form. Defaults to False. :param int body_pos: Position to seek to in file-like body in the event of a retry or redirect. Typically this won't need to be set because urllib3 will auto-populate the value when needed. """ parsed_url = parse_url(url) destination_scheme = parsed_url.scheme if headers is None: headers = self.headers if not isinstance(retries, Retry): retries = Retry.from_int(retries, redirect=redirect, default=self.retries) if release_conn is None: release_conn = preload_content # Check host if assert_same_host and not self.is_same_host(url): raise HostChangedError(self, url, retries) # Ensure that the URL we're connecting to is properly encoded if url.startswith("/"): url = to_str(_encode_target(url)) else: url = to_str(parsed_url.url) conn = None # Track whether `conn` needs to be released before # returning/raising/recursing. Update this variable if necessary, and # leave `release_conn` constant throughout the function. That way, if # the function recurses, the original value of `release_conn` will be # passed down into the recursive call, and its value will be respected. # # See issue #651 [1] for details. # # [1] release_this_conn = release_conn http_tunnel_required = connection_requires_http_tunnel( self.proxy, self.proxy_config, destination_scheme ) # Merge the proxy headers. Only done when not using HTTP CONNECT. We # have to copy the headers dict so we can safely change it without those # changes being reflected in anyone else's copy. if not http_tunnel_required: headers = headers.copy() # type: ignore[attr-defined] headers.update(self.proxy_headers) # type: ignore[union-attr] # Must keep the exception bound to a separate variable or else Python 3 # complains about UnboundLocalError. err = None # Keep track of whether we cleanly exited the except block. This # ensures we do proper cleanup in finally. clean_exit = False # Rewind body position, if needed. Record current position # for future rewinds in the event of a redirect/retry. body_pos = set_file_position(body, body_pos) try: # Request a connection from the queue. timeout_obj = self._get_timeout(timeout) conn = self._get_conn(timeout=pool_timeout) conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] # Is this a closed/new connection that requires CONNECT tunnelling? if self.proxy is not None and http_tunnel_required and conn.is_closed: try: self._prepare_proxy(conn) except (BaseSSLError, OSError, SocketTimeout) as e: self._raise_timeout( err=e, url=self.proxy.url, timeout_value=conn.timeout ) raise # If we're going to release the connection in ``finally:``, then # the response doesn't need to know about the connection. Otherwise # it will also try to release it and we'll have a double-release # mess. response_conn = conn if not release_conn else None # Make the request on the HTTPConnection object > response = self._make_request( conn, method, url, timeout=timeout_obj, body=body, headers=headers, chunked=chunked, retries=retries, response_conn=response_conn, preload_content=preload_content, decode_content=decode_content, **response_kw, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request conn.request( ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request self.endheaders() /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders self._send_output(message_body, encode_chunked=encode_chunked) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output self.send(msg) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send self.connect() ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect self.sock = self._new_conn() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) except socket.gaierror as e: raise NameResolutionError(self.host, self, e) from e except SocketTimeout as e: raise ConnectTimeoutError( self, f"Connection to {self.host} timed out. (connect timeout={self.timeout})", ) from e except OSError as e: > raise NewConnectionError( self, f"Failed to establish a new connection: {e}" ) from e E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError The above exception was the direct cause of the following exception: self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: > resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen retries = retries.increment( _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = Retry(total=0, connect=None, read=False, redirect=None, status=None) method = 'GET' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' response = None error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') _pool = _stacktrace = def increment( self, method: str | None = None, url: str | None = None, response: BaseHTTPResponse | None = None, error: Exception | None = None, _pool: ConnectionPool | None = None, _stacktrace: TracebackType | None = None, ) -> Self: """Return a new Retry object with incremented retry counters. :param response: A response object, or None, if the server did not return a response. :type response: :class:`~urllib3.response.BaseHTTPResponse` :param Exception error: An error encountered during the request, or None if the response was received successfully. :return: A new ``Retry`` object. """ if self.total is False and error: # Disabled, indicate to re-raise the error. raise reraise(type(error), error, _stacktrace) total = self.total if total is not None: total -= 1 connect = self.connect read = self.read redirect = self.redirect status_count = self.status other = self.other cause = "unknown" status = None redirect_location = None if error and self._is_connection_error(error): # Connect retry? if connect is False: raise reraise(type(error), error, _stacktrace) elif connect is not None: connect -= 1 elif error and self._is_read_error(error): # Read retry? if read is False or method is None or not self._is_method_retryable(method): raise reraise(type(error), error, _stacktrace) elif read is not None: read -= 1 elif error: # Other retry? if other is not None: other -= 1 elif response and response.get_redirect_location(): # Redirect retry? if redirect is not None: redirect -= 1 cause = "too many redirects" response_redirect_location = response.get_redirect_location() if response_redirect_location: redirect_location = response_redirect_location status = response.status else: # Incrementing because of a server error like a 500 in # status_forcelist and the given method is in the allowed_methods cause = ResponseError.GENERIC_ERROR if response and response.status: if status_count is not None: status_count -= 1 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) status = response.status history = self.history + ( RequestHistory(method, url, error, status, redirect_location), ) new_retry = self.new( total=total, connect=connect, read=read, redirect=redirect, status=status_count, other=other, history=history, ) if new_retry.is_exhausted(): reason = error or ResponseError(cause) > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError During handling of the above exception, another exception occurred: self = def test_17_xpdr_device_disconnected(self): > response = test_utils.check_device_connection("XPDRA01") transportpce_tests/1.2.1/test01_portmapping.py:195: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ transportpce_tests/common/test_utils.py:369: in check_device_connection response = get_request(url[RESTCONF_VERSION].format('{}', node)) transportpce_tests/common/test_utils.py:116: in get_request return requests.request( ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request return session.request(method=method, url=url, **kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request resp = self.send(prep, **send_kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send r = adapter.send(request, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) except (ProtocolError, OSError) as err: raise ConnectionError(err, request=request) except MaxRetryError as e: if isinstance(e.reason, ConnectTimeoutError): # TODO: Remove this in 3.0.0: see #2811 if not isinstance(e.reason, NewConnectionError): raise ConnectTimeout(e, request=request) if isinstance(e.reason, ResponseError): raise RetryError(e, request=request) if isinstance(e.reason, _ProxyError): raise ProxyError(e, request=request) if isinstance(e.reason, _SSLError): # This branch is for urllib3 v1.22 and later. raise SSLError(e, request=request) > raise ConnectionError(e, request=request) E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError ----------------------------- Captured stdout call ----------------------------- execution of test_17_xpdr_device_disconnected _______ TransportPCEPortMappingTesting.test_18_xpdr_device_not_connected _______ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: > sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection raise err _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ address = ('localhost', 8182), timeout = 10, source_address = None socket_options = [(6, 1, 1)] def create_connection( address: tuple[str, int], timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, source_address: tuple[str, int] | None = None, socket_options: _TYPE_SOCKET_OPTIONS | None = None, ) -> socket.socket: """Connect to *address* and return the socket object. Convenience function. Connect to *address* (a 2-tuple ``(host, port)``) and return the socket object. Passing the optional *timeout* parameter will set the timeout on the socket instance before attempting to connect. If no *timeout* is supplied, the global default timeout setting returned by :func:`socket.getdefaulttimeout` is used. If *source_address* is set it must be a tuple of (host, port) for the socket to bind as a source address before making the connection. An host of '' or port 0 tells the OS to use the default. """ host, port = address if host.startswith("["): host = host.strip("[]") err = None # Using the value from allowed_gai_family() in the context of getaddrinfo lets # us select whether to work with IPv4 DNS records, IPv6 records, or both. # The original create_connection function always returns all records. family = allowed_gai_family() try: host.encode("idna") except UnicodeError: raise LocationParseError(f"'{host}', label empty or too long") from None for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): af, socktype, proto, canonname, sa = res sock = None try: sock = socket.socket(af, socktype, proto) # If provided, set socket level options before connecting. _set_socket_options(sock, socket_options) if timeout is not _DEFAULT_TIMEOUT: sock.settimeout(timeout) if source_address: sock.bind(source_address) > sock.connect(sa) E ConnectionRefusedError: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError The above exception was the direct cause of the following exception: self = method = 'GET' url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' body = None headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) redirect = False, assert_same_host = False timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None release_conn = False, chunked = False, body_pos = None, preload_content = False decode_content = False, response_kw = {} parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info', query=None, fragment=None) destination_scheme = None, conn = None, release_this_conn = True http_tunnel_required = False, err = None, clean_exit = False def urlopen( # type: ignore[override] self, method: str, url: str, body: _TYPE_BODY | None = None, headers: typing.Mapping[str, str] | None = None, retries: Retry | bool | int | None = None, redirect: bool = True, assert_same_host: bool = True, timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, pool_timeout: int | None = None, release_conn: bool | None = None, chunked: bool = False, body_pos: _TYPE_BODY_POSITION | None = None, preload_content: bool = True, decode_content: bool = True, **response_kw: typing.Any, ) -> BaseHTTPResponse: """ Get a connection from the pool and perform an HTTP request. This is the lowest level call for making a request, so you'll need to specify all the raw details. .. note:: More commonly, it's appropriate to use a convenience method such as :meth:`request`. .. note:: `release_conn` will only behave as expected if `preload_content=False` because we want to make `preload_content=False` the default behaviour someday soon without breaking backwards compatibility. :param method: HTTP request method (such as GET, POST, PUT, etc.) :param url: The URL to perform the request on. :param body: Data to send in the request body, either :class:`str`, :class:`bytes`, an iterable of :class:`str`/:class:`bytes`, or a file-like object. :param headers: Dictionary of custom headers to send, such as User-Agent, If-None-Match, etc. If None, pool headers are used. If provided, these headers completely replace any pool-specific headers. :param retries: Configure the number of retries to allow before raising a :class:`~urllib3.exceptions.MaxRetryError` exception. If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a :class:`~urllib3.util.retry.Retry` object for fine-grained control over different types of retries. Pass an integer number to retry connection errors that many times, but no other types of errors. Pass zero to never retry. If ``False``, then retries are disabled and any exception is raised immediately. Also, instead of raising a MaxRetryError on redirects, the redirect response will be returned. :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. :param redirect: If True, automatically handle redirects (status codes 301, 302, 303, 307, 308). Each redirect counts as a retry. Disabling retries will disable redirect, too. :param assert_same_host: If ``True``, will make sure that the host of the pool requests is consistent else will raise HostChangedError. When ``False``, you can use the pool on an HTTP proxy and request foreign hosts. :param timeout: If specified, overrides the default timeout for this one request. It may be a float (in seconds) or an instance of :class:`urllib3.util.Timeout`. :param pool_timeout: If set and the pool is set to block=True, then this method will block for ``pool_timeout`` seconds and raise EmptyPoolError if no connection is available within the time period. :param bool preload_content: If True, the response's body will be preloaded into memory. :param bool decode_content: If True, will attempt to decode the body based on the 'content-encoding' header. :param release_conn: If False, then the urlopen call will not release the connection back into the pool once a response is received (but will release if you read the entire contents of the response such as when `preload_content=True`). This is useful if you're not preloading the response's content immediately. You will need to call ``r.release_conn()`` on the response ``r`` to return the connection back into the pool. If None, it takes the value of ``preload_content`` which defaults to ``True``. :param bool chunked: If True, urllib3 will send the body using chunked transfer encoding. Otherwise, urllib3 will send the body using the standard content-length form. Defaults to False. :param int body_pos: Position to seek to in file-like body in the event of a retry or redirect. Typically this won't need to be set because urllib3 will auto-populate the value when needed. """ parsed_url = parse_url(url) destination_scheme = parsed_url.scheme if headers is None: headers = self.headers if not isinstance(retries, Retry): retries = Retry.from_int(retries, redirect=redirect, default=self.retries) if release_conn is None: release_conn = preload_content # Check host if assert_same_host and not self.is_same_host(url): raise HostChangedError(self, url, retries) # Ensure that the URL we're connecting to is properly encoded if url.startswith("/"): url = to_str(_encode_target(url)) else: url = to_str(parsed_url.url) conn = None # Track whether `conn` needs to be released before # returning/raising/recursing. Update this variable if necessary, and # leave `release_conn` constant throughout the function. That way, if # the function recurses, the original value of `release_conn` will be # passed down into the recursive call, and its value will be respected. # # See issue #651 [1] for details. # # [1] release_this_conn = release_conn http_tunnel_required = connection_requires_http_tunnel( self.proxy, self.proxy_config, destination_scheme ) # Merge the proxy headers. Only done when not using HTTP CONNECT. We # have to copy the headers dict so we can safely change it without those # changes being reflected in anyone else's copy. if not http_tunnel_required: headers = headers.copy() # type: ignore[attr-defined] headers.update(self.proxy_headers) # type: ignore[union-attr] # Must keep the exception bound to a separate variable or else Python 3 # complains about UnboundLocalError. err = None # Keep track of whether we cleanly exited the except block. This # ensures we do proper cleanup in finally. clean_exit = False # Rewind body position, if needed. Record current position # for future rewinds in the event of a redirect/retry. body_pos = set_file_position(body, body_pos) try: # Request a connection from the queue. timeout_obj = self._get_timeout(timeout) conn = self._get_conn(timeout=pool_timeout) conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] # Is this a closed/new connection that requires CONNECT tunnelling? if self.proxy is not None and http_tunnel_required and conn.is_closed: try: self._prepare_proxy(conn) except (BaseSSLError, OSError, SocketTimeout) as e: self._raise_timeout( err=e, url=self.proxy.url, timeout_value=conn.timeout ) raise # If we're going to release the connection in ``finally:``, then # the response doesn't need to know about the connection. Otherwise # it will also try to release it and we'll have a double-release # mess. response_conn = conn if not release_conn else None # Make the request on the HTTPConnection object > response = self._make_request( conn, method, url, timeout=timeout_obj, body=body, headers=headers, chunked=chunked, retries=retries, response_conn=response_conn, preload_content=preload_content, decode_content=decode_content, **response_kw, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request conn.request( ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request self.endheaders() /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders self._send_output(message_body, encode_chunked=encode_chunked) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output self.send(msg) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send self.connect() ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect self.sock = self._new_conn() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) except socket.gaierror as e: raise NameResolutionError(self.host, self, e) from e except SocketTimeout as e: raise ConnectTimeoutError( self, f"Connection to {self.host} timed out. (connect timeout={self.timeout})", ) from e except OSError as e: > raise NewConnectionError( self, f"Failed to establish a new connection: {e}" ) from e E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError The above exception was the direct cause of the following exception: self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: > resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen retries = retries.increment( _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = Retry(total=0, connect=None, read=False, redirect=None, status=None) method = 'GET' url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' response = None error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') _pool = _stacktrace = def increment( self, method: str | None = None, url: str | None = None, response: BaseHTTPResponse | None = None, error: Exception | None = None, _pool: ConnectionPool | None = None, _stacktrace: TracebackType | None = None, ) -> Self: """Return a new Retry object with incremented retry counters. :param response: A response object, or None, if the server did not return a response. :type response: :class:`~urllib3.response.BaseHTTPResponse` :param Exception error: An error encountered during the request, or None if the response was received successfully. :return: A new ``Retry`` object. """ if self.total is False and error: # Disabled, indicate to re-raise the error. raise reraise(type(error), error, _stacktrace) total = self.total if total is not None: total -= 1 connect = self.connect read = self.read redirect = self.redirect status_count = self.status other = self.other cause = "unknown" status = None redirect_location = None if error and self._is_connection_error(error): # Connect retry? if connect is False: raise reraise(type(error), error, _stacktrace) elif connect is not None: connect -= 1 elif error and self._is_read_error(error): # Read retry? if read is False or method is None or not self._is_method_retryable(method): raise reraise(type(error), error, _stacktrace) elif read is not None: read -= 1 elif error: # Other retry? if other is not None: other -= 1 elif response and response.get_redirect_location(): # Redirect retry? if redirect is not None: redirect -= 1 cause = "too many redirects" response_redirect_location = response.get_redirect_location() if response_redirect_location: redirect_location = response_redirect_location status = response.status else: # Incrementing because of a server error like a 500 in # status_forcelist and the given method is in the allowed_methods cause = ResponseError.GENERIC_ERROR if response and response.status: if status_count is not None: status_count -= 1 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) status = response.status history = self.history + ( RequestHistory(method, url, error, status, redirect_location), ) new_retry = self.new( total=total, connect=connect, read=read, redirect=redirect, status=status_count, other=other, history=history, ) if new_retry.is_exhausted(): reason = error or ResponseError(cause) > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError During handling of the above exception, another exception occurred: self = def test_18_xpdr_device_not_connected(self): > response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) transportpce_tests/1.2.1/test01_portmapping.py:203: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ transportpce_tests/common/test_utils.py:470: in get_portmapping_node_attr response = get_request(target_url) transportpce_tests/common/test_utils.py:116: in get_request return requests.request( ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request return session.request(method=method, url=url, **kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request resp = self.send(prep, **send_kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send r = adapter.send(request, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) except (ProtocolError, OSError) as err: raise ConnectionError(err, request=request) except MaxRetryError as e: if isinstance(e.reason, ConnectTimeoutError): # TODO: Remove this in 3.0.0: see #2811 if not isinstance(e.reason, NewConnectionError): raise ConnectTimeout(e, request=request) if isinstance(e.reason, ResponseError): raise RetryError(e, request=request) if isinstance(e.reason, _ProxyError): raise ProxyError(e, request=request) if isinstance(e.reason, _SSLError): # This branch is for urllib3 v1.22 and later. raise SSLError(e, request=request) > raise ConnectionError(e, request=request) E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError ----------------------------- Captured stdout call ----------------------------- execution of test_18_xpdr_device_not_connected _______ TransportPCEPortMappingTesting.test_19_rdm_device_disconnection ________ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: > sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection raise err _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ address = ('localhost', 8182), timeout = 10, source_address = None socket_options = [(6, 1, 1)] def create_connection( address: tuple[str, int], timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, source_address: tuple[str, int] | None = None, socket_options: _TYPE_SOCKET_OPTIONS | None = None, ) -> socket.socket: """Connect to *address* and return the socket object. Convenience function. Connect to *address* (a 2-tuple ``(host, port)``) and return the socket object. Passing the optional *timeout* parameter will set the timeout on the socket instance before attempting to connect. If no *timeout* is supplied, the global default timeout setting returned by :func:`socket.getdefaulttimeout` is used. If *source_address* is set it must be a tuple of (host, port) for the socket to bind as a source address before making the connection. An host of '' or port 0 tells the OS to use the default. """ host, port = address if host.startswith("["): host = host.strip("[]") err = None # Using the value from allowed_gai_family() in the context of getaddrinfo lets # us select whether to work with IPv4 DNS records, IPv6 records, or both. # The original create_connection function always returns all records. family = allowed_gai_family() try: host.encode("idna") except UnicodeError: raise LocationParseError(f"'{host}', label empty or too long") from None for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): af, socktype, proto, canonname, sa = res sock = None try: sock = socket.socket(af, socktype, proto) # If provided, set socket level options before connecting. _set_socket_options(sock, socket_options) if timeout is not _DEFAULT_TIMEOUT: sock.settimeout(timeout) if source_address: sock.bind(source_address) > sock.connect(sa) E ConnectionRefusedError: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError The above exception was the direct cause of the following exception: self = method = 'DELETE' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01' body = None headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) redirect = False, assert_same_host = False timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None release_conn = False, chunked = False, body_pos = None, preload_content = False decode_content = False, response_kw = {} parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01', query=None, fragment=None) destination_scheme = None, conn = None, release_this_conn = True http_tunnel_required = False, err = None, clean_exit = False def urlopen( # type: ignore[override] self, method: str, url: str, body: _TYPE_BODY | None = None, headers: typing.Mapping[str, str] | None = None, retries: Retry | bool | int | None = None, redirect: bool = True, assert_same_host: bool = True, timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, pool_timeout: int | None = None, release_conn: bool | None = None, chunked: bool = False, body_pos: _TYPE_BODY_POSITION | None = None, preload_content: bool = True, decode_content: bool = True, **response_kw: typing.Any, ) -> BaseHTTPResponse: """ Get a connection from the pool and perform an HTTP request. This is the lowest level call for making a request, so you'll need to specify all the raw details. .. note:: More commonly, it's appropriate to use a convenience method such as :meth:`request`. .. note:: `release_conn` will only behave as expected if `preload_content=False` because we want to make `preload_content=False` the default behaviour someday soon without breaking backwards compatibility. :param method: HTTP request method (such as GET, POST, PUT, etc.) :param url: The URL to perform the request on. :param body: Data to send in the request body, either :class:`str`, :class:`bytes`, an iterable of :class:`str`/:class:`bytes`, or a file-like object. :param headers: Dictionary of custom headers to send, such as User-Agent, If-None-Match, etc. If None, pool headers are used. If provided, these headers completely replace any pool-specific headers. :param retries: Configure the number of retries to allow before raising a :class:`~urllib3.exceptions.MaxRetryError` exception. If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a :class:`~urllib3.util.retry.Retry` object for fine-grained control over different types of retries. Pass an integer number to retry connection errors that many times, but no other types of errors. Pass zero to never retry. If ``False``, then retries are disabled and any exception is raised immediately. Also, instead of raising a MaxRetryError on redirects, the redirect response will be returned. :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. :param redirect: If True, automatically handle redirects (status codes 301, 302, 303, 307, 308). Each redirect counts as a retry. Disabling retries will disable redirect, too. :param assert_same_host: If ``True``, will make sure that the host of the pool requests is consistent else will raise HostChangedError. When ``False``, you can use the pool on an HTTP proxy and request foreign hosts. :param timeout: If specified, overrides the default timeout for this one request. It may be a float (in seconds) or an instance of :class:`urllib3.util.Timeout`. :param pool_timeout: If set and the pool is set to block=True, then this method will block for ``pool_timeout`` seconds and raise EmptyPoolError if no connection is available within the time period. :param bool preload_content: If True, the response's body will be preloaded into memory. :param bool decode_content: If True, will attempt to decode the body based on the 'content-encoding' header. :param release_conn: If False, then the urlopen call will not release the connection back into the pool once a response is received (but will release if you read the entire contents of the response such as when `preload_content=True`). This is useful if you're not preloading the response's content immediately. You will need to call ``r.release_conn()`` on the response ``r`` to return the connection back into the pool. If None, it takes the value of ``preload_content`` which defaults to ``True``. :param bool chunked: If True, urllib3 will send the body using chunked transfer encoding. Otherwise, urllib3 will send the body using the standard content-length form. Defaults to False. :param int body_pos: Position to seek to in file-like body in the event of a retry or redirect. Typically this won't need to be set because urllib3 will auto-populate the value when needed. """ parsed_url = parse_url(url) destination_scheme = parsed_url.scheme if headers is None: headers = self.headers if not isinstance(retries, Retry): retries = Retry.from_int(retries, redirect=redirect, default=self.retries) if release_conn is None: release_conn = preload_content # Check host if assert_same_host and not self.is_same_host(url): raise HostChangedError(self, url, retries) # Ensure that the URL we're connecting to is properly encoded if url.startswith("/"): url = to_str(_encode_target(url)) else: url = to_str(parsed_url.url) conn = None # Track whether `conn` needs to be released before # returning/raising/recursing. Update this variable if necessary, and # leave `release_conn` constant throughout the function. That way, if # the function recurses, the original value of `release_conn` will be # passed down into the recursive call, and its value will be respected. # # See issue #651 [1] for details. # # [1] release_this_conn = release_conn http_tunnel_required = connection_requires_http_tunnel( self.proxy, self.proxy_config, destination_scheme ) # Merge the proxy headers. Only done when not using HTTP CONNECT. We # have to copy the headers dict so we can safely change it without those # changes being reflected in anyone else's copy. if not http_tunnel_required: headers = headers.copy() # type: ignore[attr-defined] headers.update(self.proxy_headers) # type: ignore[union-attr] # Must keep the exception bound to a separate variable or else Python 3 # complains about UnboundLocalError. err = None # Keep track of whether we cleanly exited the except block. This # ensures we do proper cleanup in finally. clean_exit = False # Rewind body position, if needed. Record current position # for future rewinds in the event of a redirect/retry. body_pos = set_file_position(body, body_pos) try: # Request a connection from the queue. timeout_obj = self._get_timeout(timeout) conn = self._get_conn(timeout=pool_timeout) conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] # Is this a closed/new connection that requires CONNECT tunnelling? if self.proxy is not None and http_tunnel_required and conn.is_closed: try: self._prepare_proxy(conn) except (BaseSSLError, OSError, SocketTimeout) as e: self._raise_timeout( err=e, url=self.proxy.url, timeout_value=conn.timeout ) raise # If we're going to release the connection in ``finally:``, then # the response doesn't need to know about the connection. Otherwise # it will also try to release it and we'll have a double-release # mess. response_conn = conn if not release_conn else None # Make the request on the HTTPConnection object > response = self._make_request( conn, method, url, timeout=timeout_obj, body=body, headers=headers, chunked=chunked, retries=retries, response_conn=response_conn, preload_content=preload_content, decode_content=decode_content, **response_kw, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request conn.request( ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request self.endheaders() /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders self._send_output(message_body, encode_chunked=encode_chunked) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output self.send(msg) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send self.connect() ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect self.sock = self._new_conn() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) except socket.gaierror as e: raise NameResolutionError(self.host, self, e) from e except SocketTimeout as e: raise ConnectTimeoutError( self, f"Connection to {self.host} timed out. (connect timeout={self.timeout})", ) from e except OSError as e: > raise NewConnectionError( self, f"Failed to establish a new connection: {e}" ) from e E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError The above exception was the direct cause of the following exception: self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: > resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen retries = retries.increment( _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = Retry(total=0, connect=None, read=False, redirect=None, status=None) method = 'DELETE' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01' response = None error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') _pool = _stacktrace = def increment( self, method: str | None = None, url: str | None = None, response: BaseHTTPResponse | None = None, error: Exception | None = None, _pool: ConnectionPool | None = None, _stacktrace: TracebackType | None = None, ) -> Self: """Return a new Retry object with incremented retry counters. :param response: A response object, or None, if the server did not return a response. :type response: :class:`~urllib3.response.BaseHTTPResponse` :param Exception error: An error encountered during the request, or None if the response was received successfully. :return: A new ``Retry`` object. """ if self.total is False and error: # Disabled, indicate to re-raise the error. raise reraise(type(error), error, _stacktrace) total = self.total if total is not None: total -= 1 connect = self.connect read = self.read redirect = self.redirect status_count = self.status other = self.other cause = "unknown" status = None redirect_location = None if error and self._is_connection_error(error): # Connect retry? if connect is False: raise reraise(type(error), error, _stacktrace) elif connect is not None: connect -= 1 elif error and self._is_read_error(error): # Read retry? if read is False or method is None or not self._is_method_retryable(method): raise reraise(type(error), error, _stacktrace) elif read is not None: read -= 1 elif error: # Other retry? if other is not None: other -= 1 elif response and response.get_redirect_location(): # Redirect retry? if redirect is not None: redirect -= 1 cause = "too many redirects" response_redirect_location = response.get_redirect_location() if response_redirect_location: redirect_location = response_redirect_location status = response.status else: # Incrementing because of a server error like a 500 in # status_forcelist and the given method is in the allowed_methods cause = ResponseError.GENERIC_ERROR if response and response.status: if status_count is not None: status_count -= 1 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) status = response.status history = self.history + ( RequestHistory(method, url, error, status, redirect_location), ) new_retry = self.new( total=total, connect=connect, read=read, redirect=redirect, status=status_count, other=other, history=history, ) if new_retry.is_exhausted(): reason = error or ResponseError(cause) > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError During handling of the above exception, another exception occurred: self = def test_19_rdm_device_disconnection(self): > response = test_utils.unmount_device("ROADMA01") transportpce_tests/1.2.1/test01_portmapping.py:211: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ transportpce_tests/common/test_utils.py:358: in unmount_device response = delete_request(url[RESTCONF_VERSION].format('{}', node)) transportpce_tests/common/test_utils.py:133: in delete_request return requests.request( ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request return session.request(method=method, url=url, **kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request resp = self.send(prep, **send_kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send r = adapter.send(request, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) except (ProtocolError, OSError) as err: raise ConnectionError(err, request=request) except MaxRetryError as e: if isinstance(e.reason, ConnectTimeoutError): # TODO: Remove this in 3.0.0: see #2811 if not isinstance(e.reason, NewConnectionError): raise ConnectTimeout(e, request=request) if isinstance(e.reason, ResponseError): raise RetryError(e, request=request) if isinstance(e.reason, _ProxyError): raise ProxyError(e, request=request) if isinstance(e.reason, _SSLError): # This branch is for urllib3 v1.22 and later. raise SSLError(e, request=request) > raise ConnectionError(e, request=request) E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError ----------------------------- Captured stdout call ----------------------------- execution of test_19_rdm_device_disconnection ________ TransportPCEPortMappingTesting.test_20_rdm_device_disconnected ________ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: > sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection raise err _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ address = ('localhost', 8182), timeout = 10, source_address = None socket_options = [(6, 1, 1)] def create_connection( address: tuple[str, int], timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, source_address: tuple[str, int] | None = None, socket_options: _TYPE_SOCKET_OPTIONS | None = None, ) -> socket.socket: """Connect to *address* and return the socket object. Convenience function. Connect to *address* (a 2-tuple ``(host, port)``) and return the socket object. Passing the optional *timeout* parameter will set the timeout on the socket instance before attempting to connect. If no *timeout* is supplied, the global default timeout setting returned by :func:`socket.getdefaulttimeout` is used. If *source_address* is set it must be a tuple of (host, port) for the socket to bind as a source address before making the connection. An host of '' or port 0 tells the OS to use the default. """ host, port = address if host.startswith("["): host = host.strip("[]") err = None # Using the value from allowed_gai_family() in the context of getaddrinfo lets # us select whether to work with IPv4 DNS records, IPv6 records, or both. # The original create_connection function always returns all records. family = allowed_gai_family() try: host.encode("idna") except UnicodeError: raise LocationParseError(f"'{host}', label empty or too long") from None for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): af, socktype, proto, canonname, sa = res sock = None try: sock = socket.socket(af, socktype, proto) # If provided, set socket level options before connecting. _set_socket_options(sock, socket_options) if timeout is not _DEFAULT_TIMEOUT: sock.settimeout(timeout) if source_address: sock.bind(source_address) > sock.connect(sa) E ConnectionRefusedError: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError The above exception was the direct cause of the following exception: self = method = 'GET' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' body = None headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) redirect = False, assert_same_host = False timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None release_conn = False, chunked = False, body_pos = None, preload_content = False decode_content = False, response_kw = {} parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01', query='content=nonconfig', fragment=None) destination_scheme = None, conn = None, release_this_conn = True http_tunnel_required = False, err = None, clean_exit = False def urlopen( # type: ignore[override] self, method: str, url: str, body: _TYPE_BODY | None = None, headers: typing.Mapping[str, str] | None = None, retries: Retry | bool | int | None = None, redirect: bool = True, assert_same_host: bool = True, timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, pool_timeout: int | None = None, release_conn: bool | None = None, chunked: bool = False, body_pos: _TYPE_BODY_POSITION | None = None, preload_content: bool = True, decode_content: bool = True, **response_kw: typing.Any, ) -> BaseHTTPResponse: """ Get a connection from the pool and perform an HTTP request. This is the lowest level call for making a request, so you'll need to specify all the raw details. .. note:: More commonly, it's appropriate to use a convenience method such as :meth:`request`. .. note:: `release_conn` will only behave as expected if `preload_content=False` because we want to make `preload_content=False` the default behaviour someday soon without breaking backwards compatibility. :param method: HTTP request method (such as GET, POST, PUT, etc.) :param url: The URL to perform the request on. :param body: Data to send in the request body, either :class:`str`, :class:`bytes`, an iterable of :class:`str`/:class:`bytes`, or a file-like object. :param headers: Dictionary of custom headers to send, such as User-Agent, If-None-Match, etc. If None, pool headers are used. If provided, these headers completely replace any pool-specific headers. :param retries: Configure the number of retries to allow before raising a :class:`~urllib3.exceptions.MaxRetryError` exception. If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a :class:`~urllib3.util.retry.Retry` object for fine-grained control over different types of retries. Pass an integer number to retry connection errors that many times, but no other types of errors. Pass zero to never retry. If ``False``, then retries are disabled and any exception is raised immediately. Also, instead of raising a MaxRetryError on redirects, the redirect response will be returned. :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. :param redirect: If True, automatically handle redirects (status codes 301, 302, 303, 307, 308). Each redirect counts as a retry. Disabling retries will disable redirect, too. :param assert_same_host: If ``True``, will make sure that the host of the pool requests is consistent else will raise HostChangedError. When ``False``, you can use the pool on an HTTP proxy and request foreign hosts. :param timeout: If specified, overrides the default timeout for this one request. It may be a float (in seconds) or an instance of :class:`urllib3.util.Timeout`. :param pool_timeout: If set and the pool is set to block=True, then this method will block for ``pool_timeout`` seconds and raise EmptyPoolError if no connection is available within the time period. :param bool preload_content: If True, the response's body will be preloaded into memory. :param bool decode_content: If True, will attempt to decode the body based on the 'content-encoding' header. :param release_conn: If False, then the urlopen call will not release the connection back into the pool once a response is received (but will release if you read the entire contents of the response such as when `preload_content=True`). This is useful if you're not preloading the response's content immediately. You will need to call ``r.release_conn()`` on the response ``r`` to return the connection back into the pool. If None, it takes the value of ``preload_content`` which defaults to ``True``. :param bool chunked: If True, urllib3 will send the body using chunked transfer encoding. Otherwise, urllib3 will send the body using the standard content-length form. Defaults to False. :param int body_pos: Position to seek to in file-like body in the event of a retry or redirect. Typically this won't need to be set because urllib3 will auto-populate the value when needed. """ parsed_url = parse_url(url) destination_scheme = parsed_url.scheme if headers is None: headers = self.headers if not isinstance(retries, Retry): retries = Retry.from_int(retries, redirect=redirect, default=self.retries) if release_conn is None: release_conn = preload_content # Check host if assert_same_host and not self.is_same_host(url): raise HostChangedError(self, url, retries) # Ensure that the URL we're connecting to is properly encoded if url.startswith("/"): url = to_str(_encode_target(url)) else: url = to_str(parsed_url.url) conn = None # Track whether `conn` needs to be released before # returning/raising/recursing. Update this variable if necessary, and # leave `release_conn` constant throughout the function. That way, if # the function recurses, the original value of `release_conn` will be # passed down into the recursive call, and its value will be respected. # # See issue #651 [1] for details. # # [1] release_this_conn = release_conn http_tunnel_required = connection_requires_http_tunnel( self.proxy, self.proxy_config, destination_scheme ) # Merge the proxy headers. Only done when not using HTTP CONNECT. We # have to copy the headers dict so we can safely change it without those # changes being reflected in anyone else's copy. if not http_tunnel_required: headers = headers.copy() # type: ignore[attr-defined] headers.update(self.proxy_headers) # type: ignore[union-attr] # Must keep the exception bound to a separate variable or else Python 3 # complains about UnboundLocalError. err = None # Keep track of whether we cleanly exited the except block. This # ensures we do proper cleanup in finally. clean_exit = False # Rewind body position, if needed. Record current position # for future rewinds in the event of a redirect/retry. body_pos = set_file_position(body, body_pos) try: # Request a connection from the queue. timeout_obj = self._get_timeout(timeout) conn = self._get_conn(timeout=pool_timeout) conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] # Is this a closed/new connection that requires CONNECT tunnelling? if self.proxy is not None and http_tunnel_required and conn.is_closed: try: self._prepare_proxy(conn) except (BaseSSLError, OSError, SocketTimeout) as e: self._raise_timeout( err=e, url=self.proxy.url, timeout_value=conn.timeout ) raise # If we're going to release the connection in ``finally:``, then # the response doesn't need to know about the connection. Otherwise # it will also try to release it and we'll have a double-release # mess. response_conn = conn if not release_conn else None # Make the request on the HTTPConnection object > response = self._make_request( conn, method, url, timeout=timeout_obj, body=body, headers=headers, chunked=chunked, retries=retries, response_conn=response_conn, preload_content=preload_content, decode_content=decode_content, **response_kw, ) ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request conn.request( ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request self.endheaders() /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders self._send_output(message_body, encode_chunked=encode_chunked) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output self.send(msg) /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send self.connect() ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect self.sock = self._new_conn() _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def _new_conn(self) -> socket.socket: """Establish a socket connection and set nodelay settings on it. :return: New socket connection. """ try: sock = connection.create_connection( (self._dns_host, self.port), self.timeout, source_address=self.source_address, socket_options=self.socket_options, ) except socket.gaierror as e: raise NameResolutionError(self.host, self, e) from e except SocketTimeout as e: raise ConnectTimeoutError( self, f"Connection to {self.host} timed out. (connect timeout={self.timeout})", ) from e except OSError as e: > raise NewConnectionError( self, f"Failed to establish a new connection: {e}" ) from e E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError The above exception was the direct cause of the following exception: self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: > resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen retries = retries.increment( _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = Retry(total=0, connect=None, read=False, redirect=None, status=None) method = 'GET' url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' response = None error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') _pool = _stacktrace = def increment( self, method: str | None = None, url: str | None = None, response: BaseHTTPResponse | None = None, error: Exception | None = None, _pool: ConnectionPool | None = None, _stacktrace: TracebackType | None = None, ) -> Self: """Return a new Retry object with incremented retry counters. :param response: A response object, or None, if the server did not return a response. :type response: :class:`~urllib3.response.BaseHTTPResponse` :param Exception error: An error encountered during the request, or None if the response was received successfully. :return: A new ``Retry`` object. """ if self.total is False and error: # Disabled, indicate to re-raise the error. raise reraise(type(error), error, _stacktrace) total = self.total if total is not None: total -= 1 connect = self.connect read = self.read redirect = self.redirect status_count = self.status other = self.other cause = "unknown" status = None redirect_location = None if error and self._is_connection_error(error): # Connect retry? if connect is False: raise reraise(type(error), error, _stacktrace) elif connect is not None: connect -= 1 elif error and self._is_read_error(error): # Read retry? if read is False or method is None or not self._is_method_retryable(method): raise reraise(type(error), error, _stacktrace) elif read is not None: read -= 1 elif error: # Other retry? if other is not None: other -= 1 elif response and response.get_redirect_location(): # Redirect retry? if redirect is not None: redirect -= 1 cause = "too many redirects" response_redirect_location = response.get_redirect_location() if response_redirect_location: redirect_location = response_redirect_location status = response.status else: # Incrementing because of a server error like a 500 in # status_forcelist and the given method is in the allowed_methods cause = ResponseError.GENERIC_ERROR if response and response.status: if status_count is not None: status_count -= 1 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) status = response.status history = self.history + ( RequestHistory(method, url, error, status, redirect_location), ) new_retry = self.new( total=total, connect=connect, read=read, redirect=redirect, status=status_count, other=other, history=history, ) if new_retry.is_exhausted(): reason = error or ResponseError(cause) > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError During handling of the above exception, another exception occurred: self = def test_20_rdm_device_disconnected(self): > response = test_utils.check_device_connection("ROADMA01") transportpce_tests/1.2.1/test01_portmapping.py:215: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ transportpce_tests/common/test_utils.py:369: in check_device_connection response = get_request(url[RESTCONF_VERSION].format('{}', node)) transportpce_tests/common/test_utils.py:116: in get_request return requests.request( ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request return session.request(method=method, url=url, **kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request resp = self.send(prep, **send_kwargs) ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send r = adapter.send(request, **kwargs) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = request = , stream = False timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None proxies = OrderedDict() def send( self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest ` being sent. :param stream: (optional) Whether to stream the request content. :param timeout: (optional) How long to wait for the server to send data before giving up, as a float, or a :ref:`(connect timeout, read timeout) ` tuple. :type timeout: float or tuple or urllib3 Timeout object :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use :param cert: (optional) Any user-provided SSL certificate to be trusted. :param proxies: (optional) The proxies dictionary to apply to the request. :rtype: requests.Response """ try: conn = self.get_connection_with_tls_context( request, verify, proxies=proxies, cert=cert ) except LocationValueError as e: raise InvalidURL(e, request=request) self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) self.add_headers( request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies, ) chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) except ValueError: raise ValueError( f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " f"or a single float to set both timeouts to the same value." ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: resp = conn.urlopen( method=request.method, url=url, body=request.body, headers=request.headers, redirect=False, assert_same_host=False, preload_content=False, decode_content=False, retries=self.max_retries, timeout=timeout, chunked=chunked, ) except (ProtocolError, OSError) as err: raise ConnectionError(err, request=request) except MaxRetryError as e: if isinstance(e.reason, ConnectTimeoutError): # TODO: Remove this in 3.0.0: see #2811 if not isinstance(e.reason, NewConnectionError): raise ConnectTimeout(e, request=request) if isinstance(e.reason, ResponseError): raise RetryError(e, request=request) if isinstance(e.reason, _ProxyError): raise ProxyError(e, request=request) if isinstance(e.reason, _SSLError): # This branch is for urllib3 v1.22 and later. raise SSLError(e, request=request) > raise ConnectionError(e, request=request) E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError ----------------------------- Captured stdout call ----------------------------- execution of test_20_rdm_device_disconnected =========================== short test summary info ============================ FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_02_rdm_device_connected FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_03_rdm_portmapping_info FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_04_rdm_portmapping_DEG1_TTP_TXRX FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_05_rdm_portmapping_SRG1_PP7_TXRX FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_06_rdm_portmapping_SRG3_PP1_TXRX FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_08_xpdr_device_connected FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_09_xpdr_portmapping_info FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_10_xpdr_portmapping_NETWORK1 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_11_xpdr_portmapping_NETWORK2 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_12_xpdr_portmapping_CLIENT1 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_13_xpdr_portmapping_CLIENT2 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_14_xpdr_portmapping_CLIENT3 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_15_xpdr_portmapping_CLIENT4 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_16_xpdr_device_disconnection FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_17_xpdr_device_disconnected FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_18_xpdr_device_not_connected FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_19_rdm_device_disconnection FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_20_rdm_device_disconnected 18 failed, 3 passed in 600.44s (0:10:00) tests121: exit 1 (600.68 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=35406 ................................................ [100%] 48 passed in 135.96s (0:02:15) pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py ...................... [100%] 22 passed in 71.97s (0:01:11) tests121: FAIL ✖ in 10 minutes 7.28 seconds tests71: OK ✔ in 6 minutes 55.69 seconds tests221: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt tests221: freeze> python -m pip freeze --all tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 using environment variables from ./karaf221.env pytest -q transportpce_tests/2.2.1/test01_portmapping.py ................................... [100%] 35 passed in 78.23s (0:01:18) pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py ...... [100%] 6 passed in 47.61s pytest -q transportpce_tests/2.2.1/test03_topology.py ............................................ [100%] 44 passed in 320.88s (0:05:20) pytest -q transportpce_tests/2.2.1/test04_otn_topology.py ............ [100%] 12 passed in 60.83s (0:01:00) pytest -q transportpce_tests/2.2.1/test05_flex_grid.py ................ [100%] 16 passed in 115.85s (0:01:55) pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py ............................... [100%] 31 passed in 38.60s pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py .......................... [100%] 26 passed in 93.39s (0:01:33) pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py ...................... [100%] 22 passed in 102.98s (0:01:42) pytest -q transportpce_tests/2.2.1/test09_olm.py ........................................ [100%] 40 passed in 186.33s (0:03:06) pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py ........................................................................ [ 74%] ......................... [100%] 97 passed in 494.38s (0:08:14) pytest -q transportpce_tests/2.2.1/test12_end2end.py ...................................................... [100%] 54 passed in 447.90s (0:07:27) pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py ........................................................................ [ 71%] ............................. [100%] 101 passed in 496.50s (0:08:16) pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py ........................................................................ [ 67%] ................................... [100%] 107 passed in 786.44s (0:13:06) tests221: OK ✔ in 54 minutes 38.96 seconds tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt tests_hybrid: freeze> python -m pip freeze --all tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid using environment variables from ./karaf121.env pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py ................................................... [100%] 51 passed in 332.31s (0:05:32) pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py ........................................................................ [ 66%] ..................................... [100%] 109 passed in 430.54s (0:07:10) pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py ..................................................... [100%] 53 passed in 260.86s (0:04:20) tests_hybrid: OK ✔ in 17 minutes 10.04 seconds buildlighty: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt buildlighty: freeze> python -m pip freeze --all buildlighty: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.8,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.4.1,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==74.1.2,urllib3==2.2.3,wheel==0.44.0 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED [ERROR] COMPILATION ERROR : [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol symbol: class YangModuleInfo location: package org.opendaylight.yangtools.binding [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol symbol: class YangModuleInfo location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol symbol: class YangModuleInfo location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol symbol: class YangModuleInfo location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0:compile (default-compile) on project tpce: Compilation failure: Compilation failure: [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol [ERROR] symbol: class YangModuleInfo [ERROR] location: package org.opendaylight.yangtools.binding [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol [ERROR] symbol: class YangModuleInfo [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol [ERROR] symbol: class YangModuleInfo [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol [ERROR] symbol: class YangModuleInfo [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils [ERROR] -> [Help 1] [ERROR] [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. [ERROR] Re-run Maven using the -X switch to enable full debug logging. [ERROR] [ERROR] For more information about the errors and possible solutions, please read the following articles: [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException unzip: cannot find or open target/tpce-bin.zip, target/tpce-bin.zip.zip or target/tpce-bin.zip.ZIP. buildlighty: exit 9 (15.32 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh pid=59693 buildlighty: command failed but is marked ignore outcome so handling it as success buildcontroller: OK (103.21=setup[7.62]+cmd[95.59] seconds) testsPCE: OK (314.66=setup[70.83]+cmd[243.83] seconds) sims: OK (11.27=setup[7.50]+cmd[3.77] seconds) build_karaf_tests121: OK (56.90=setup[7.77]+cmd[49.13] seconds) tests121: FAIL code 1 (607.28=setup[6.60]+cmd[600.68] seconds) build_karaf_tests221: OK (55.37=setup[7.58]+cmd[47.78] seconds) tests_tapi: FAIL code 1 (639.48=setup[7.13]+cmd[632.35] seconds) tests221: OK (3278.96=setup[5.95]+cmd[3273.01] seconds) build_karaf_tests71: OK (53.56=setup[12.66]+cmd[40.89] seconds) tests71: OK (415.69=setup[6.55]+cmd[409.14] seconds) build_karaf_tests_hybrid: OK (60.69=setup[6.64]+cmd[54.05] seconds) tests_hybrid: OK (1030.04=setup[5.63]+cmd[1024.41] seconds) buildlighty: OK (21.55=setup[6.23]+cmd[15.32] seconds) docs: OK (30.57=setup[28.07]+cmd[2.51] seconds) docs-linkcheck: OK (32.78=setup[29.16]+cmd[3.61] seconds) checkbashisms: OK (2.74=setup[1.85]+cmd[0.02,0.05,0.82] seconds) pre-commit: OK (42.94=setup[3.14]+cmd[0.00,0.00,32.27,7.52] seconds) pylint: OK (26.30=setup[5.64]+cmd[20.66] seconds) evaluation failed :( (5545.90 seconds) + tox_status=255 + echo '---> Completed tox runs' ---> Completed tox runs + for i in .tox/*/log ++ echo .tox/build_karaf_tests121/log ++ awk -F/ '{print $2}' + tox_env=build_karaf_tests121 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 + for i in .tox/*/log ++ echo .tox/build_karaf_tests221/log ++ awk -F/ '{print $2}' + tox_env=build_karaf_tests221 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 + for i in .tox/*/log ++ echo .tox/build_karaf_tests71/log ++ awk -F/ '{print $2}' + tox_env=build_karaf_tests71 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 + for i in .tox/*/log ++ awk -F/ '{print $2}' ++ echo .tox/build_karaf_tests_hybrid/log + tox_env=build_karaf_tests_hybrid + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid + for i in .tox/*/log ++ echo .tox/buildcontroller/log ++ awk -F/ '{print $2}' + tox_env=buildcontroller + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller + for i in .tox/*/log ++ echo .tox/buildlighty/log ++ awk -F/ '{print $2}' + tox_env=buildlighty + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty + for i in .tox/*/log ++ echo .tox/checkbashisms/log ++ awk -F/ '{print $2}' + tox_env=checkbashisms + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms + for i in .tox/*/log ++ echo .tox/docs-linkcheck/log ++ awk -F/ '{print $2}' + tox_env=docs-linkcheck + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck + for i in .tox/*/log ++ echo .tox/docs/log ++ awk -F/ '{print $2}' + tox_env=docs + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs + for i in .tox/*/log ++ echo .tox/pre-commit/log ++ awk -F/ '{print $2}' + tox_env=pre-commit + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit + for i in .tox/*/log ++ echo .tox/pylint/log ++ awk -F/ '{print $2}' + tox_env=pylint + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint + for i in .tox/*/log ++ echo .tox/sims/log ++ awk -F/ '{print $2}' + tox_env=sims + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims + for i in .tox/*/log ++ echo .tox/tests121/log ++ awk -F/ '{print $2}' + tox_env=tests121 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 + for i in .tox/*/log ++ echo .tox/tests221/log ++ awk -F/ '{print $2}' + tox_env=tests221 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 + for i in .tox/*/log ++ echo .tox/tests71/log ++ awk -F/ '{print $2}' + tox_env=tests71 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 + for i in .tox/*/log ++ echo .tox/testsPCE/log ++ awk -F/ '{print $2}' + tox_env=testsPCE + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE + for i in .tox/*/log ++ echo .tox/tests_hybrid/log ++ awk -F/ '{print $2}' + tox_env=tests_hybrid + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid + for i in .tox/*/log ++ echo .tox/tests_tapi/log ++ awk -F/ '{print $2}' + tox_env=tests_tapi + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi + DOC_DIR=docs/_build/html + [[ -d docs/_build/html ]] + echo '---> Archiving generated docs' ---> Archiving generated docs + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs + echo '---> tox-run.sh ends' ---> tox-run.sh ends + test 255 -eq 0 + exit 255 ++ '[' 1 = 1 ']' ++ '[' -x /usr/bin/clear_console ']' ++ /usr/bin/clear_console -q Build step 'Execute shell' marked build as failure $ ssh-agent -k unset SSH_AUTH_SOCK; unset SSH_AGENT_PID; echo Agent pid 13389 killed; [ssh-agent] Stopped. [PostBuildScript] - [INFO] Executing post build scripts. [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3698255228828851894.sh ---> sysstat.sh [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13860440497761716510.sh ---> package-listing.sh ++ facter osfamily ++ tr '[:upper:]' '[:lower:]' + OS_FAMILY=debian + workspace=/w/workspace/transportpce-tox-verify-transportpce-master + START_PACKAGES=/tmp/packages_start.txt + END_PACKAGES=/tmp/packages_end.txt + DIFF_PACKAGES=/tmp/packages_diff.txt + PACKAGES=/tmp/packages_start.txt + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' + PACKAGES=/tmp/packages_end.txt + case "${OS_FAMILY}" in + dpkg -l + grep '^ii' + '[' -f /tmp/packages_start.txt ']' + '[' -f /tmp/packages_end.txt ']' + diff /tmp/packages_start.txt /tmp/packages_end.txt + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6833677102879570013.sh ---> capture-instance-metadata.sh Setup pyenv: system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) lf-activate-venv(): INFO: Reuse venv:/tmp/venv-85VX from file:/tmp/.os_lf_venv lf-activate-venv(): INFO: Installing: lftools lf-activate-venv(): INFO: Adding /tmp/venv-85VX/bin to PATH INFO: Running in OpenStack, capturing instance metadata [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7261617703982269861.sh provisioning config files... Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #1988 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config4394944869252237506tmp Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] Run condition [Regular expression match] enabling perform for step [Provide Configuration files] provisioning config files... copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials [EnvInject] - Injecting environment variables from a build step. [EnvInject] - Injecting as environment variables the properties content SERVER_ID=logs [EnvInject] - Variables injected successfully. [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2199616713275712081.sh ---> create-netrc.sh WARN: Log server credential not found. [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9460968224414736296.sh ---> python-tools-install.sh Setup pyenv: system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) lf-activate-venv(): INFO: Reuse venv:/tmp/venv-85VX from file:/tmp/.os_lf_venv lf-activate-venv(): INFO: Installing: lftools lf-activate-venv(): INFO: Adding /tmp/venv-85VX/bin to PATH [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5709311307387125082.sh ---> sudo-logs.sh Archiving 'sudo' log.. [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16996365616211936999.sh ---> job-cost.sh Setup pyenv: system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) lf-activate-venv(): INFO: Reuse venv:/tmp/venv-85VX from file:/tmp/.os_lf_venv lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 lf-activate-venv(): INFO: Adding /tmp/venv-85VX/bin to PATH INFO: No Stack... INFO: Retrieving Pricing Info for: v3-standard-4 INFO: Archiving Costs [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins8824800278403133796.sh ---> logs-deploy.sh Setup pyenv: system 3.8.13 3.9.13 3.10.13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) lf-activate-venv(): INFO: Reuse venv:/tmp/venv-85VX from file:/tmp/.os_lf_venv lf-activate-venv(): INFO: Installing: lftools lf-activate-venv(): INFO: Adding /tmp/venv-85VX/bin to PATH WARNING: Nexus logging server not set INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/1988/ INFO: archiving logs to S3 ---> uname -a: Linux prd-ubuntu2004-docker-4c-16g-21405 5.4.0-190-generic #210-Ubuntu SMP Fri Jul 5 17:03:38 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux ---> lscpu: Architecture: x86_64 CPU op-mode(s): 32-bit, 64-bit Byte Order: Little Endian Address sizes: 40 bits physical, 48 bits virtual CPU(s): 4 On-line CPU(s) list: 0-3 Thread(s) per core: 1 Core(s) per socket: 1 Socket(s): 4 NUMA node(s): 1 Vendor ID: AuthenticAMD CPU family: 23 Model: 49 Model name: AMD EPYC-Rome Processor Stepping: 0 CPU MHz: 2799.998 BogoMIPS: 5599.99 Virtualization: AMD-V Hypervisor vendor: KVM Virtualization type: full L1d cache: 128 KiB L1i cache: 128 KiB L2 cache: 2 MiB L3 cache: 64 MiB NUMA node0 CPU(s): 0-3 Vulnerability Gather data sampling: Not affected Vulnerability Itlb multihit: Not affected Vulnerability L1tf: Not affected Vulnerability Mds: Not affected Vulnerability Meltdown: Not affected Vulnerability Mmio stale data: Not affected Vulnerability Retbleed: Vulnerable Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected Vulnerability Srbds: Not affected Vulnerability Tsx async abort: Not affected Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm rep_good nopl cpuid extd_apicid tsc_known_freq pni pclmulqdq ssse3 fma cx16 sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm cmp_legacy svm cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw topoext perfctr_core ssbd ibrs ibpb stibp vmmcall fsgsbase tsc_adjust bmi1 avx2 smep bmi2 rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 clzero xsaveerptr wbnoinvd arat npt nrip_save umip rdpid arch_capabilities ---> nproc: 4 ---> df -h: Filesystem Size Used Avail Use% Mounted on udev 7.8G 0 7.8G 0% /dev tmpfs 1.6G 1.1M 1.6G 1% /run /dev/vda1 78G 17G 62G 21% / tmpfs 7.9G 0 7.9G 0% /dev/shm tmpfs 5.0M 0 5.0M 0% /run/lock tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup /dev/loop0 62M 62M 0 100% /snap/core20/1405 /dev/loop1 68M 68M 0 100% /snap/lxd/22753 /dev/vda15 105M 6.1M 99M 6% /boot/efi tmpfs 1.6G 0 1.6G 0% /run/user/1001 /dev/loop3 39M 39M 0 100% /snap/snapd/21759 /dev/loop4 64M 64M 0 100% /snap/core20/2318 /dev/loop5 92M 92M 0 100% /snap/lxd/29619 ---> free -m: total used free shared buff/cache available Mem: 15997 686 7021 1 8289 14972 Swap: 1023 0 1023 ---> ip addr: 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo valid_lft forever preferred_lft forever inet6 ::1/128 scope host valid_lft forever preferred_lft forever 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 link/ether fa:16:3e:f8:5e:4e brd ff:ff:ff:ff:ff:ff inet 10.30.171.252/23 brd 10.30.171.255 scope global dynamic ens3 valid_lft 80676sec preferred_lft 80676sec inet6 fe80::f816:3eff:fef8:5e4e/64 scope link valid_lft forever preferred_lft forever 3: docker0: mtu 1458 qdisc noqueue state DOWN group default link/ether 02:42:eb:78:d9:72 brd ff:ff:ff:ff:ff:ff inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 valid_lft forever preferred_lft forever ---> sar -b -r -n DEV: Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-21405) 09/12/24 _x86_64_ (4 CPU) 14:17:49 LINUX RESTART (4 CPU) 14:18:01 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 14:19:01 339.46 156.61 182.85 0.00 11672.32 44980.37 0.00 14:20:01 94.67 23.98 70.69 0.00 1141.41 10808.62 0.00 14:21:01 258.66 41.19 217.46 0.00 2735.01 53889.82 0.00 14:22:01 70.34 1.62 68.72 0.00 88.52 30485.05 0.00 14:23:01 211.93 8.77 203.17 0.00 342.74 154346.81 0.00 14:24:01 220.58 7.93 212.65 0.00 4606.03 61742.38 0.00 14:25:01 61.40 3.07 58.34 0.00 206.43 1074.66 0.00 14:26:01 137.16 0.32 136.84 0.00 17.46 2411.60 0.00 14:27:01 70.24 0.08 70.16 0.00 3.07 1171.61 0.00 14:28:01 59.96 2.57 57.39 0.00 461.39 9163.94 0.00 14:29:01 3.43 0.00 3.43 0.00 0.00 95.58 0.00 14:30:01 23.93 0.22 23.71 0.00 17.19 373.74 0.00 14:31:01 76.29 0.22 76.07 0.00 4.67 1529.09 0.00 14:32:01 2.60 0.00 2.60 0.00 0.00 57.99 0.00 14:33:01 2.23 0.00 2.23 0.00 0.00 36.66 0.00 14:34:01 74.67 0.93 73.74 0.00 22.13 4425.40 0.00 14:35:01 69.32 0.00 69.32 0.00 0.00 6570.90 0.00 14:36:01 2.70 0.00 2.70 0.00 0.00 51.72 0.00 14:37:01 24.98 0.05 24.93 0.00 1.87 394.87 0.00 14:38:01 62.14 0.00 62.14 0.00 0.00 894.38 0.00 14:39:01 1.50 0.00 1.50 0.00 0.00 34.39 0.00 14:40:01 69.09 0.00 69.09 0.00 0.00 1026.23 0.00 14:41:01 81.14 0.02 81.12 0.00 0.13 3370.24 0.00 14:42:01 23.36 0.00 23.36 0.00 0.00 404.93 0.00 14:43:01 61.32 0.00 61.32 0.00 0.00 1125.01 0.00 14:44:01 48.32 0.00 48.32 0.00 0.00 696.57 0.00 14:45:01 1.83 0.00 1.83 0.00 0.00 31.86 0.00 14:46:01 1.92 0.00 1.92 0.00 0.00 24.66 0.00 14:47:01 1.42 0.00 1.42 0.00 0.00 17.86 0.00 14:48:01 15.61 0.00 15.61 0.00 0.00 355.69 0.00 14:49:01 60.46 0.00 60.46 0.00 0.00 905.56 0.00 14:50:01 43.48 0.00 43.48 0.00 0.00 633.76 0.00 14:51:01 22.46 0.00 22.46 0.00 0.00 351.94 0.00 14:52:01 114.31 0.00 114.31 0.00 0.00 1667.72 0.00 14:53:01 2.47 0.00 2.47 0.00 0.00 153.44 0.00 14:54:01 71.16 0.00 71.16 0.00 0.00 926.76 0.00 14:55:01 16.21 0.00 16.21 0.00 0.00 270.89 0.00 14:56:01 48.78 0.00 48.78 0.00 0.00 714.95 0.00 14:57:01 2.87 0.00 2.87 0.00 0.00 58.12 0.00 14:58:01 16.96 0.00 16.96 0.00 0.00 285.10 0.00 14:59:01 47.36 0.00 47.36 0.00 0.00 697.75 0.00 15:00:01 2.65 0.00 2.65 0.00 0.00 55.46 0.00 15:01:01 1.77 0.00 1.77 0.00 0.00 30.66 0.00 15:02:01 3.08 0.00 3.08 0.00 0.00 48.93 0.00 15:03:01 2.67 0.00 2.67 0.00 0.00 59.72 0.00 15:04:01 2.52 0.00 2.52 0.00 0.00 45.59 0.00 15:05:01 2.05 0.00 2.05 0.00 0.00 33.72 0.00 15:06:01 1.82 0.00 1.82 0.00 0.00 39.86 0.00 15:07:01 58.34 0.00 58.34 0.00 0.00 883.45 0.00 15:08:01 3.25 0.00 3.25 0.00 0.00 82.51 0.00 15:09:01 2.60 0.00 2.60 0.00 0.00 55.86 0.00 15:10:01 3.77 0.00 3.77 0.00 0.00 73.45 0.00 15:11:01 1.87 0.00 1.87 0.00 0.00 45.99 0.00 15:12:01 1.93 0.00 1.93 0.00 0.00 40.93 0.00 15:13:01 2.20 0.00 2.20 0.00 0.00 62.92 0.00 15:14:01 16.05 0.00 16.05 0.00 0.00 284.75 0.00 15:15:01 46.50 0.00 46.50 0.00 0.00 688.17 0.00 15:16:01 3.27 0.00 3.27 0.00 0.00 69.19 0.00 15:17:01 2.48 0.05 2.43 0.00 1.07 45.99 0.00 15:18:01 3.38 0.00 3.38 0.00 0.00 56.91 0.00 15:19:01 3.32 0.00 3.32 0.00 0.00 64.26 0.00 15:20:01 3.22 0.00 3.22 0.00 0.00 52.26 0.00 15:21:01 2.37 0.00 2.37 0.00 0.00 50.52 0.00 15:22:01 22.86 0.00 22.86 0.00 0.00 568.57 0.00 15:23:01 55.42 0.00 55.42 0.00 0.00 796.13 0.00 15:24:01 3.88 0.00 3.88 0.00 0.00 82.92 0.00 15:25:01 2.22 0.00 2.22 0.00 0.00 48.25 0.00 15:26:01 1.97 0.00 1.97 0.00 0.00 43.86 0.00 15:27:01 2.10 0.00 2.10 0.00 0.00 39.19 0.00 15:28:01 2.12 0.00 2.12 0.00 0.00 35.58 0.00 15:29:01 2.07 0.00 2.07 0.00 0.00 37.59 0.00 15:30:01 2.48 0.00 2.48 0.00 0.00 49.45 0.00 15:31:01 1.85 0.00 1.85 0.00 0.00 33.59 0.00 15:32:01 2.05 0.00 2.05 0.00 0.00 47.73 0.00 15:33:01 2.25 0.00 2.25 0.00 0.00 27.86 0.00 15:34:01 1.54 0.00 1.54 0.00 0.00 20.74 0.00 15:35:01 6.02 0.02 6.00 0.00 0.13 272.35 0.00 15:36:01 110.06 0.02 110.05 0.00 0.13 9826.72 0.00 15:37:01 3.45 0.00 3.45 0.00 0.00 147.44 0.00 15:38:01 4.70 0.48 4.22 0.00 29.72 65.84 0.00 15:39:01 1.27 0.00 1.27 0.00 0.00 16.40 0.00 15:40:01 2.22 0.00 2.22 0.00 0.00 25.60 0.00 15:41:01 23.31 0.00 23.31 0.00 0.00 674.42 0.00 15:42:01 47.69 0.00 47.69 0.00 0.00 704.95 0.00 15:43:01 2.03 0.00 2.03 0.00 0.00 37.73 0.00 15:44:01 3.53 0.00 3.53 0.00 0.00 62.66 0.00 15:45:01 2.13 0.00 2.13 0.00 0.00 33.86 0.00 15:46:01 2.15 0.00 2.15 0.00 0.00 45.46 0.00 15:47:01 2.33 0.00 2.33 0.00 0.00 48.79 0.00 15:48:01 16.13 0.00 16.13 0.00 0.00 372.07 0.00 15:49:01 36.61 0.00 36.61 0.00 0.00 536.98 0.00 15:50:01 3.05 0.00 3.05 0.00 0.00 180.61 0.00 15:51:01 1.63 0.00 1.63 0.00 0.00 50.12 0.00 15:52:01 1.87 0.00 1.87 0.00 0.00 49.19 0.00 15:53:01 59.84 13.41 46.43 0.00 573.64 7612.60 0.00 Average: 33.93 2.75 31.17 0.00 230.82 4460.87 0.00 14:18:01 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 14:19:01 13501976 15370624 619968 3.78 54380 2021360 1357416 7.79 834964 1788924 99004 14:20:01 13197056 15433212 535264 3.27 79308 2342356 1390872 7.98 824592 2062476 171012 14:21:01 10314276 14148652 1810348 11.05 137636 3762168 2515908 14.43 2294672 3341724 194308 14:22:01 8559372 14049252 1908528 11.65 163152 5315964 2798268 16.05 2724680 4588852 926732 14:23:01 5847876 14286268 1662024 10.15 209576 8088560 2505192 14.37 3366020 6515776 449632 14:24:01 4374336 13837056 2107300 12.86 229760 9060904 2863512 16.43 4348096 6967920 2288 14:25:01 971504 9794736 6147408 37.53 225900 8437488 7547308 43.30 8276152 6439580 332 14:26:01 234280 8757280 7183868 43.85 230444 8135908 8570440 49.17 9306404 6145832 1756 14:27:01 957448 9489752 6451704 39.38 233844 8140012 7451600 42.75 8574224 6154720 25448 14:28:01 167028 7454044 8486412 51.81 239984 6907788 9628384 55.24 10527136 5004136 1968 14:29:01 167220 7454200 8486252 51.80 240004 6907796 9628384 55.24 10527060 5003848 100 14:30:01 5232888 12520944 3421900 20.89 240440 6908268 4413740 25.32 5488868 4995308 736 14:31:01 2379436 9670280 6271528 38.28 242492 6908972 7397280 42.44 8337868 4992404 568 14:32:01 2061316 9352332 6589304 40.22 242524 6909120 7463460 42.82 8653552 4992400 324 14:33:01 2048388 9339524 6602180 40.30 242560 6909188 7463460 42.82 8666000 4992468 148 14:34:01 4058756 11590508 4351980 26.57 249992 7135744 5261616 30.19 6497580 5149964 158660 14:35:01 4111092 11645140 4297336 26.23 251904 7136080 5183736 29.74 6468428 5128372 152 14:36:01 4092228 11626472 4316040 26.35 251944 7136236 5199760 29.83 6486868 5128488 196 14:37:01 4844384 12379240 3563460 21.75 252380 7136376 5002932 28.70 5747912 5117696 584 14:38:01 5517380 13053940 2889516 17.64 253788 7136628 3647164 20.92 5079220 5117420 40 14:39:01 5482780 13019604 2923784 17.85 253812 7136872 3663200 21.02 5113564 5117652 168 14:40:01 6228824 13767496 2176528 13.29 255336 7137128 2927740 16.80 4371648 5117060 316 14:41:01 4986944 12593172 3350052 20.45 258540 7197540 4327120 24.83 5546808 5175920 1004 14:42:01 6326040 13932760 2011076 12.28 258784 7197784 3455300 19.82 4217440 5171064 300 14:43:01 5120444 12728796 3214564 19.62 260000 7198184 4809860 27.60 5426516 5162884 528 14:44:01 4040920 11650476 4292456 26.20 260868 7198480 5087204 29.19 6501692 5163180 380 14:45:01 4037072 11646672 4296232 26.23 260876 7198512 5087204 29.19 6505884 5163212 60 14:46:01 4036144 11645756 4297092 26.23 260888 7198516 5087204 29.19 6505868 5163216 84 14:47:01 4035940 11645568 4297228 26.23 260896 7198524 5087204 29.19 6506008 5163224 64 14:48:01 7011144 14621052 1323412 8.08 260932 7198760 2198456 12.61 3544728 5162420 588 14:49:01 7013948 14624964 1319532 8.06 261696 7199088 2126180 12.20 3541988 5162432 400 14:50:01 6148000 13760332 2183484 13.33 262740 7199344 2960336 16.98 4404292 5162680 104 14:51:01 6910608 14523500 1420848 8.67 263036 7199600 2755016 15.81 3645428 5162544 480 14:52:01 6234336 13849216 2094744 12.79 264460 7200128 2863592 16.43 4316212 5162964 336 14:53:01 7526836 15141772 803172 4.90 264472 7200152 1903260 10.92 3031564 5162932 200 14:54:01 5331292 12947460 2995976 18.29 265180 7200660 3778824 21.68 5214144 5163396 108 14:55:01 6378124 13994612 1949484 11.90 265212 7200952 2922212 16.77 4173164 5163520 616 14:56:01 3788604 11406020 4536492 27.69 265708 7201364 5272904 30.25 6752068 5163916 92 14:57:01 3770956 11388668 4553836 27.80 265728 7201640 5288908 30.34 6768764 5164192 212 14:58:01 6919312 14537280 1407012 8.59 265736 7201880 2218032 12.73 3634744 5164392 656 14:59:01 3877444 11496468 4446444 27.14 266268 7202208 5208384 29.88 6663708 5164716 276 15:00:01 3808812 11427964 4514452 27.56 266272 7202528 5289764 30.35 6731328 5164804 32 15:01:01 3782776 11402144 4540240 27.72 266284 7202732 5305780 30.44 6756400 5165000 432 15:02:01 3771104 11390556 4551868 27.79 266296 7202788 5305780 30.44 6768540 5165056 124 15:03:01 3746084 11365992 4576376 27.94 266308 7203240 5305780 30.44 6792292 5165500 348 15:04:01 3732452 11352608 4589684 28.02 266316 7203468 5305780 30.44 6804696 5165732 80 15:05:01 3684792 11305068 4637204 28.31 266332 7203568 5372916 30.83 6852524 5165832 112 15:06:01 5348376 12968848 2973804 18.15 266336 7203760 4395184 25.22 5191848 5166032 308 15:07:01 4157800 11779064 4163436 25.42 266872 7204004 5067200 29.07 6382228 5166196 244 15:08:01 3920224 11542120 4400020 26.86 266872 7204632 5214308 29.92 6617136 5166824 136 15:09:01 3892944 11515304 4426804 27.02 266872 7205100 5214308 29.92 6642528 5167288 172 15:10:01 3860404 11483292 4458808 27.22 266880 7205616 5214308 29.92 6675728 5167808 224 15:11:01 3852356 11475696 4466380 27.27 266884 7206080 5214308 29.92 6682996 5168252 220 15:12:01 3847552 11471372 4470704 27.29 266892 7206536 5231040 30.01 6687376 5168724 360 15:13:01 3808768 11433436 4508580 27.52 266892 7207392 5231040 30.01 6725012 5169572 392 15:14:01 5303304 12928268 3014784 18.40 266900 7207668 4224408 24.24 5237436 5169788 860 15:15:01 2472576 10097640 5843988 35.67 267236 7207428 6564728 37.66 8059488 5169540 164 15:16:01 2323300 9948812 5992600 36.58 267244 7207864 6663116 38.23 8207468 5169972 156 15:17:01 2302400 9928216 6013088 36.71 267256 7208156 6727380 38.60 8227664 5170268 264 15:18:01 2291792 9917780 6023484 36.77 267264 7208320 6727380 38.60 8238500 5170416 148 15:19:01 2265804 9892120 6049088 36.93 267268 7208668 6743368 38.69 8264544 5170740 56 15:20:01 2258032 9884584 6056572 36.97 267268 7208880 6743368 38.69 8272268 5170976 56 15:21:01 2245904 9872844 6068312 37.04 267272 7209264 6743368 38.69 8284008 5171360 128 15:22:01 7001480 14628656 1315452 8.03 267392 7209360 2108656 12.10 3543984 5171524 720 15:23:01 2700092 10327780 5613800 34.27 267732 7209472 6455772 37.04 7831844 5171524 776 15:24:01 2483188 10111144 5830296 35.59 267740 7209732 6624484 38.01 8048112 5171784 264 15:25:01 2258472 9887124 6054116 36.96 267740 7210428 6769772 38.84 8270480 5172480 712 15:26:01 2250416 9879180 6062004 37.01 267744 7210540 6769772 38.84 8278216 5172592 380 15:27:01 2237304 9866172 6075068 37.09 267744 7210640 6769772 38.84 8290512 5172692 176 15:28:01 2223600 9852764 6088412 37.17 267748 7210952 6769772 38.84 8303820 5172984 360 15:29:01 2204732 9834128 6107016 37.28 267748 7211164 6769772 38.84 8322552 5173216 308 15:30:01 2174184 9803776 6137268 37.46 267756 7211352 6803080 39.03 8352760 5173404 312 15:31:01 2159384 9789228 6151816 37.55 267756 7211604 6819136 39.12 8366308 5173656 532 15:32:01 2135272 9765344 6175596 37.70 267764 7211828 6851604 39.31 8390596 5173876 332 15:33:01 2135084 9765160 6175768 37.70 267776 7211824 6851604 39.31 8389544 5173880 256 15:34:01 2134928 9765016 6175888 37.70 267788 7211832 6851604 39.31 8389536 5173884 216 15:35:01 7617504 15313668 630600 3.85 269904 7271696 1709124 9.81 2866448 5232640 62552 15:36:01 3567228 11437928 4503696 27.49 274336 7438644 5250332 30.12 6786912 5342788 3384 15:37:01 3491596 11362300 4579356 27.95 274344 7438744 5303936 30.43 6862324 5342572 48 15:38:01 3418344 11290304 4651348 28.39 274476 7439720 5424840 31.12 6933108 5341196 52 15:39:01 3418552 11290516 4651124 28.39 274480 7439720 5408696 31.03 6933016 5341196 64 15:40:01 3418780 11290752 4650960 28.39 274480 7439728 5408696 31.03 6933272 5341204 24 15:41:01 5087312 12959508 2983168 18.21 274556 7439792 4174924 23.95 5292144 5322892 704 15:42:01 3679232 11552040 4389624 26.80 274868 7440088 5174704 29.69 6697508 5319700 288 15:43:01 3669356 11542328 4399316 26.86 274872 7440248 5174704 29.69 6707268 5319684 140 15:44:01 3649440 11522700 4418908 26.98 274888 7440524 5174704 29.69 6726388 5319948 120 15:45:01 3642992 11516432 4425164 27.01 274892 7440704 5174704 29.69 6732548 5320124 176 15:46:01 3623824 11497544 4444040 27.13 274892 7440980 5190716 29.78 6749880 5320404 288 15:47:01 3597024 11471076 4470456 27.29 274892 7441308 5190716 29.78 6777516 5320716 104 15:48:01 6291116 14165396 1777888 10.85 274900 7441472 2821796 16.19 4106912 5309784 532 15:49:01 2910452 10784884 5156380 31.48 275032 7441476 5933632 34.04 7475888 5309700 780 15:50:01 2826544 10701564 5239608 31.99 275044 7442036 6000660 34.43 7558136 5310104 136 15:51:01 2762056 10637816 5303336 32.37 275048 7442772 6000660 34.43 7620804 5310836 160 15:52:01 2731304 10607760 5333432 32.56 275064 7443440 6016664 34.52 7651048 5311492 508 15:53:01 7263428 15373660 570348 3.48 280648 7656752 1294912 7.43 2939068 5495204 15480 Average: 4160902 11685816 4257656 25.99 256266 7128342 5107022 29.30 6396284 5159591 22493 14:18:01 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 14:19:01 ens3 403.43 250.24 1705.72 69.98 0.00 0.00 0.00 0.00 14:19:01 lo 1.70 1.70 0.16 0.16 0.00 0.00 0.00 0.00 14:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:20:01 ens3 50.37 40.51 497.46 7.21 0.00 0.00 0.00 0.00 14:20:01 lo 0.87 0.87 0.08 0.08 0.00 0.00 0.00 0.00 14:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:21:01 ens3 512.38 404.77 7651.61 42.28 0.00 0.00 0.00 0.00 14:21:01 lo 5.87 5.87 0.60 0.60 0.00 0.00 0.00 0.00 14:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:22:01 ens3 368.81 264.77 5648.85 26.86 0.00 0.00 0.00 0.00 14:22:01 lo 1.07 1.07 0.10 0.10 0.00 0.00 0.00 0.00 14:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:23:01 ens3 101.20 51.57 2435.83 6.56 0.00 0.00 0.00 0.00 14:23:01 lo 1.20 1.20 0.12 0.12 0.00 0.00 0.00 0.00 14:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:24:01 ens3 116.88 62.12 2063.96 4.44 0.00 0.00 0.00 0.00 14:24:01 lo 5.45 5.45 1.27 1.27 0.00 0.00 0.00 0.00 14:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:25:01 ens3 1.67 1.50 0.27 0.25 0.00 0.00 0.00 0.00 14:25:01 lo 26.77 26.77 29.00 29.00 0.00 0.00 0.00 0.00 14:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:26:01 ens3 1.20 1.13 0.23 0.21 0.00 0.00 0.00 0.00 14:26:01 lo 32.66 32.66 25.21 25.21 0.00 0.00 0.00 0.00 14:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:27:01 ens3 1.47 1.58 0.55 0.49 0.00 0.00 0.00 0.00 14:27:01 lo 35.75 35.75 16.92 16.92 0.00 0.00 0.00 0.00 14:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:28:01 ens3 0.97 1.00 0.36 0.32 0.00 0.00 0.00 0.00 14:28:01 lo 7.98 7.98 6.44 6.44 0.00 0.00 0.00 0.00 14:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:29:01 ens3 0.42 0.08 0.15 0.06 0.00 0.00 0.00 0.00 14:29:01 lo 0.12 0.12 0.01 0.01 0.00 0.00 0.00 0.00 14:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:30:01 ens3 0.25 0.25 0.04 0.04 0.00 0.00 0.00 0.00 14:30:01 lo 1.37 1.37 0.12 0.12 0.00 0.00 0.00 0.00 14:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:31:01 ens3 0.83 0.62 0.10 0.09 0.00 0.00 0.00 0.00 14:31:01 lo 9.18 9.18 12.32 12.32 0.00 0.00 0.00 0.00 14:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:32:01 ens3 0.90 0.73 0.36 0.30 0.00 0.00 0.00 0.00 14:32:01 lo 13.73 13.73 7.93 7.93 0.00 0.00 0.00 0.00 14:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:33:01 ens3 0.40 0.30 0.07 0.06 0.00 0.00 0.00 0.00 14:33:01 lo 2.10 2.10 0.29 0.29 0.00 0.00 0.00 0.00 14:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:34:01 ens3 3.67 2.92 1.22 1.14 0.00 0.00 0.00 0.00 14:34:01 lo 11.80 11.80 16.04 16.04 0.00 0.00 0.00 0.00 14:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:35:01 ens3 1.37 1.08 0.44 0.36 0.00 0.00 0.00 0.00 14:35:01 lo 13.40 13.40 6.87 6.87 0.00 0.00 0.00 0.00 14:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:36:01 ens3 1.22 1.03 0.23 0.21 0.00 0.00 0.00 0.00 14:36:01 lo 28.21 28.21 9.18 9.18 0.00 0.00 0.00 0.00 14:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:37:01 ens3 1.35 1.12 0.25 0.22 0.00 0.00 0.00 0.00 14:37:01 lo 16.05 16.05 4.86 4.86 0.00 0.00 0.00 0.00 14:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:38:01 ens3 5.30 4.15 1.13 3.01 0.00 0.00 0.00 0.00 14:38:01 lo 22.98 22.98 13.19 13.19 0.00 0.00 0.00 0.00 14:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:39:01 ens3 1.33 1.68 0.36 0.31 0.00 0.00 0.00 0.00 14:39:01 lo 37.88 37.88 12.28 12.28 0.00 0.00 0.00 0.00 14:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:40:01 ens3 0.95 1.07 0.16 0.16 0.00 0.00 0.00 0.00 14:40:01 lo 26.30 26.30 11.50 11.50 0.00 0.00 0.00 0.00 14:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:41:01 ens3 1.92 2.32 0.82 0.75 0.00 0.00 0.00 0.00 14:41:01 lo 8.33 8.33 2.89 2.89 0.00 0.00 0.00 0.00 14:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:42:01 ens3 1.72 2.05 0.31 0.32 0.00 0.00 0.00 0.00 14:42:01 lo 10.46 10.46 7.60 7.60 0.00 0.00 0.00 0.00 14:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:43:01 ens3 0.65 0.72 0.10 0.10 0.00 0.00 0.00 0.00 14:43:01 lo 13.06 13.06 4.62 4.62 0.00 0.00 0.00 0.00 14:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:44:01 ens3 1.28 1.45 0.33 0.26 0.00 0.00 0.00 0.00 14:44:01 lo 20.94 20.94 10.10 10.10 0.00 0.00 0.00 0.00 14:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:45:01 ens3 1.70 1.05 0.45 0.33 0.00 0.00 0.00 0.00 14:45:01 lo 8.17 8.17 3.08 3.08 0.00 0.00 0.00 0.00 14:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:46:01 ens3 0.72 0.32 0.32 0.23 0.00 0.00 0.00 0.00 14:46:01 lo 0.38 0.38 0.04 0.04 0.00 0.00 0.00 0.00 14:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:47:01 ens3 0.13 0.00 0.01 0.00 0.00 0.00 0.00 0.00 14:47:01 lo 0.13 0.13 0.01 0.01 0.00 0.00 0.00 0.00 14:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:48:01 ens3 0.68 0.57 0.11 0.10 0.00 0.00 0.00 0.00 14:48:01 lo 3.23 3.23 0.92 0.92 0.00 0.00 0.00 0.00 14:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:49:01 ens3 1.02 0.73 0.26 0.18 0.00 0.00 0.00 0.00 14:49:01 lo 5.51 5.51 6.26 6.26 0.00 0.00 0.00 0.00 14:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:50:01 ens3 0.47 0.37 0.07 0.06 0.00 0.00 0.00 0.00 14:50:01 lo 8.37 8.37 3.12 3.12 0.00 0.00 0.00 0.00 14:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:51:01 ens3 1.22 0.53 0.17 0.10 0.00 0.00 0.00 0.00 14:51:01 lo 3.53 3.53 0.59 0.59 0.00 0.00 0.00 0.00 14:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:52:01 ens3 1.23 1.03 0.41 0.34 0.00 0.00 0.00 0.00 14:52:01 lo 30.88 30.88 14.77 14.77 0.00 0.00 0.00 0.00 14:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:53:01 ens3 1.27 1.05 0.23 0.21 0.00 0.00 0.00 0.00 14:53:01 lo 20.10 20.10 8.36 8.36 0.00 0.00 0.00 0.00 14:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:54:01 ens3 0.68 0.53 0.20 0.13 0.00 0.00 0.00 0.00 14:54:01 lo 12.40 12.40 14.88 14.88 0.00 0.00 0.00 0.00 14:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:55:01 ens3 1.00 0.77 0.16 0.15 0.00 0.00 0.00 0.00 14:55:01 lo 11.40 11.40 5.44 5.44 0.00 0.00 0.00 0.00 14:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:56:01 ens3 0.97 0.87 0.16 0.14 0.00 0.00 0.00 0.00 14:56:01 lo 35.53 35.53 14.40 14.40 0.00 0.00 0.00 0.00 14:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:57:01 ens3 0.60 0.47 0.11 0.09 0.00 0.00 0.00 0.00 14:57:01 lo 39.81 39.81 11.92 11.92 0.00 0.00 0.00 0.00 14:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:58:01 ens3 0.70 0.60 0.12 0.11 0.00 0.00 0.00 0.00 14:58:01 lo 19.49 19.49 5.77 5.77 0.00 0.00 0.00 0.00 14:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 14:59:01 ens3 0.98 0.77 0.25 0.18 0.00 0.00 0.00 0.00 14:59:01 lo 17.43 17.43 15.98 15.98 0.00 0.00 0.00 0.00 14:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:00:01 ens3 0.55 0.45 0.10 0.08 0.00 0.00 0.00 0.00 15:00:01 lo 18.31 18.31 8.74 8.74 0.00 0.00 0.00 0.00 15:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:01:01 ens3 0.70 0.63 0.14 0.13 0.00 0.00 0.00 0.00 15:01:01 lo 18.86 18.86 9.95 9.95 0.00 0.00 0.00 0.00 15:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:01 ens3 0.57 0.47 0.09 0.09 0.00 0.00 0.00 0.00 15:02:01 lo 6.38 6.38 3.52 3.52 0.00 0.00 0.00 0.00 15:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:03:01 ens3 0.58 0.48 0.11 0.10 0.00 0.00 0.00 0.00 15:03:01 lo 31.83 31.83 12.49 12.49 0.00 0.00 0.00 0.00 15:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:04:01 ens3 0.50 0.33 0.17 0.10 0.00 0.00 0.00 0.00 15:04:01 lo 10.65 10.65 4.77 4.77 0.00 0.00 0.00 0.00 15:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:05:01 ens3 0.80 0.65 0.15 0.14 0.00 0.00 0.00 0.00 15:05:01 lo 15.41 15.41 6.96 6.96 0.00 0.00 0.00 0.00 15:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:06:01 ens3 0.55 0.38 0.08 0.07 0.00 0.00 0.00 0.00 15:06:01 lo 25.30 25.30 8.85 8.85 0.00 0.00 0.00 0.00 15:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:07:01 ens3 0.87 0.75 0.13 0.13 0.00 0.00 0.00 0.00 15:07:01 lo 16.60 16.60 7.08 7.08 0.00 0.00 0.00 0.00 15:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:08:01 ens3 0.73 0.60 0.13 0.12 0.00 0.00 0.00 0.00 15:08:01 lo 37.72 37.72 12.42 12.42 0.00 0.00 0.00 0.00 15:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:09:01 ens3 0.47 0.33 0.17 0.11 0.00 0.00 0.00 0.00 15:09:01 lo 45.41 45.41 13.65 13.65 0.00 0.00 0.00 0.00 15:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:10:01 ens3 0.53 0.47 0.09 0.09 0.00 0.00 0.00 0.00 15:10:01 lo 29.46 29.46 8.82 8.82 0.00 0.00 0.00 0.00 15:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:11:01 ens3 0.27 0.18 0.04 0.04 0.00 0.00 0.00 0.00 15:11:01 lo 33.06 33.06 9.69 9.69 0.00 0.00 0.00 0.00 15:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:12:01 ens3 0.23 0.12 0.02 0.01 0.00 0.00 0.00 0.00 15:12:01 lo 22.21 22.21 6.00 6.00 0.00 0.00 0.00 0.00 15:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:13:01 ens3 0.08 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:13:01 lo 58.34 58.34 18.63 18.63 0.00 0.00 0.00 0.00 15:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:14:01 ens3 0.83 0.92 0.23 0.17 0.00 0.00 0.00 0.00 15:14:01 lo 25.38 25.38 6.94 6.94 0.00 0.00 0.00 0.00 15:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:15:01 ens3 0.70 0.70 0.10 0.10 0.00 0.00 0.00 0.00 15:15:01 lo 23.16 23.16 22.60 22.60 0.00 0.00 0.00 0.00 15:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:16:01 ens3 0.65 0.83 0.12 0.13 0.00 0.00 0.00 0.00 15:16:01 lo 33.38 33.38 14.08 14.08 0.00 0.00 0.00 0.00 15:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:17:01 ens3 0.60 0.72 0.11 0.12 0.00 0.00 0.00 0.00 15:17:01 lo 17.01 17.01 7.20 7.20 0.00 0.00 0.00 0.00 15:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:18:01 ens3 0.72 1.00 0.14 0.15 0.00 0.00 0.00 0.00 15:18:01 lo 11.80 11.80 4.83 4.83 0.00 0.00 0.00 0.00 15:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:19:01 ens3 0.68 0.77 0.22 0.16 0.00 0.00 0.00 0.00 15:19:01 lo 36.44 36.44 14.26 14.26 0.00 0.00 0.00 0.00 15:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:20:01 ens3 0.63 0.83 0.12 0.13 0.00 0.00 0.00 0.00 15:20:01 lo 20.20 20.20 7.07 7.07 0.00 0.00 0.00 0.00 15:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:21:01 ens3 0.47 0.47 0.08 0.07 0.00 0.00 0.00 0.00 15:21:01 lo 21.79 21.79 8.97 8.97 0.00 0.00 0.00 0.00 15:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:22:01 ens3 0.58 0.75 0.11 0.11 0.00 0.00 0.00 0.00 15:22:01 lo 17.30 17.30 7.21 7.21 0.00 0.00 0.00 0.00 15:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:23:01 ens3 0.78 0.68 0.09 0.09 0.00 0.00 0.00 0.00 15:23:01 lo 17.01 17.01 20.28 20.28 0.00 0.00 0.00 0.00 15:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:24:01 ens3 0.93 0.93 0.28 0.21 0.00 0.00 0.00 0.00 15:24:01 lo 24.70 24.70 9.08 9.08 0.00 0.00 0.00 0.00 15:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:25:01 ens3 0.45 0.28 0.07 0.05 0.00 0.00 0.00 0.00 15:25:01 lo 32.86 32.86 16.80 16.80 0.00 0.00 0.00 0.00 15:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:26:01 ens3 0.47 0.42 0.09 0.08 0.00 0.00 0.00 0.00 15:26:01 lo 8.55 8.55 5.17 5.17 0.00 0.00 0.00 0.00 15:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:27:01 ens3 0.73 0.67 0.15 0.14 0.00 0.00 0.00 0.00 15:27:01 lo 15.33 15.33 8.83 8.83 0.00 0.00 0.00 0.00 15:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:28:01 ens3 0.52 0.40 0.08 0.07 0.00 0.00 0.00 0.00 15:28:01 lo 14.71 14.71 8.00 8.00 0.00 0.00 0.00 0.00 15:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:29:01 ens3 0.55 0.38 0.20 0.12 0.00 0.00 0.00 0.00 15:29:01 lo 11.16 11.16 5.97 5.97 0.00 0.00 0.00 0.00 15:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:30:01 ens3 0.70 0.58 0.12 0.11 0.00 0.00 0.00 0.00 15:30:01 lo 23.26 23.26 12.69 12.69 0.00 0.00 0.00 0.00 15:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:31:01 ens3 0.17 0.12 0.03 0.02 0.00 0.00 0.00 0.00 15:31:01 lo 23.00 23.00 8.87 8.87 0.00 0.00 0.00 0.00 15:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:32:01 ens3 0.82 0.67 0.33 0.27 0.00 0.00 0.00 0.00 15:32:01 lo 20.18 20.18 7.52 7.52 0.00 0.00 0.00 0.00 15:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:33:01 ens3 0.10 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:33:01 lo 0.62 0.62 0.06 0.06 0.00 0.00 0.00 0.00 15:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:34:01 ens3 0.93 0.32 0.21 0.08 0.00 0.00 0.00 0.00 15:34:01 lo 1.03 1.03 0.11 0.11 0.00 0.00 0.00 0.00 15:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:35:01 ens3 2.00 2.07 1.04 0.89 0.00 0.00 0.00 0.00 15:35:01 lo 1.73 1.73 0.17 0.17 0.00 0.00 0.00 0.00 15:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:36:01 ens3 0.68 0.57 0.08 0.07 0.00 0.00 0.00 0.00 15:36:01 lo 36.14 36.14 32.60 32.60 0.00 0.00 0.00 0.00 15:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:37:01 ens3 1.33 1.15 0.27 0.24 0.00 0.00 0.00 0.00 15:37:01 lo 17.65 17.65 9.34 9.34 0.00 0.00 0.00 0.00 15:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:38:01 ens3 0.57 0.47 0.12 0.07 0.00 0.00 0.00 0.00 15:38:01 lo 19.68 19.68 5.61 5.61 0.00 0.00 0.00 0.00 15:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:39:01 ens3 0.30 0.13 0.14 0.07 0.00 0.00 0.00 0.00 15:39:01 lo 0.13 0.13 0.01 0.01 0.00 0.00 0.00 0.00 15:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:40:01 ens3 0.17 0.08 0.01 0.01 0.00 0.00 0.00 0.00 15:40:01 lo 0.38 0.38 0.04 0.04 0.00 0.00 0.00 0.00 15:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:01 ens3 0.60 0.45 0.07 0.06 0.00 0.00 0.00 0.00 15:41:01 lo 1.63 1.63 0.15 0.15 0.00 0.00 0.00 0.00 15:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:42:01 ens3 0.95 0.82 0.17 0.16 0.00 0.00 0.00 0.00 15:42:01 lo 35.39 35.39 17.95 17.95 0.00 0.00 0.00 0.00 15:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:43:01 ens3 0.93 0.65 0.16 0.14 0.00 0.00 0.00 0.00 15:43:01 lo 11.40 11.40 4.90 4.90 0.00 0.00 0.00 0.00 15:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:44:01 ens3 0.58 0.42 0.20 0.12 0.00 0.00 0.00 0.00 15:44:01 lo 25.48 25.48 9.65 9.65 0.00 0.00 0.00 0.00 15:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:45:01 ens3 0.87 0.72 0.17 0.15 0.00 0.00 0.00 0.00 15:45:01 lo 18.38 18.38 7.56 7.56 0.00 0.00 0.00 0.00 15:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:46:01 ens3 0.48 0.38 0.08 0.07 0.00 0.00 0.00 0.00 15:46:01 lo 28.71 28.71 8.74 8.74 0.00 0.00 0.00 0.00 15:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:47:01 ens3 0.73 0.52 0.13 0.11 0.00 0.00 0.00 0.00 15:47:01 lo 21.36 21.36 8.05 8.05 0.00 0.00 0.00 0.00 15:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:48:01 ens3 1.05 0.98 0.19 0.19 0.00 0.00 0.00 0.00 15:48:01 lo 37.89 37.89 12.00 12.00 0.00 0.00 0.00 0.00 15:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:49:01 ens3 1.05 1.07 0.26 0.19 0.00 0.00 0.00 0.00 15:49:01 lo 42.09 42.09 20.98 20.98 0.00 0.00 0.00 0.00 15:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:50:01 ens3 0.93 1.15 0.17 0.18 0.00 0.00 0.00 0.00 15:50:01 lo 41.67 41.67 15.18 15.18 0.00 0.00 0.00 0.00 15:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:51:01 ens3 0.32 0.32 0.05 0.05 0.00 0.00 0.00 0.00 15:51:01 lo 56.29 56.29 19.88 19.88 0.00 0.00 0.00 0.00 15:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:52:01 ens3 1.15 0.85 0.18 0.13 0.00 0.00 0.00 0.00 15:52:01 lo 75.32 75.32 24.62 24.62 0.00 0.00 0.00 0.00 15:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:53:01 ens3 179.60 143.16 1965.16 31.36 0.00 0.00 0.00 0.00 15:53:01 lo 1.07 1.07 0.11 0.11 0.00 0.00 0.00 0.00 15:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 Average: ens3 19.06 13.52 231.47 2.17 0.00 0.00 0.00 0.00 Average: lo 19.08 19.08 8.75 8.75 0.00 0.00 0.00 0.00 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 ---> sar -P ALL: Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-21405) 09/12/24 _x86_64_ (4 CPU) 14:17:49 LINUX RESTART (4 CPU) 14:18:01 CPU %user %nice %system %iowait %steal %idle 14:19:01 all 15.96 17.45 14.27 5.79 0.14 46.39 14:19:01 0 13.52 18.21 14.85 10.10 0.13 43.18 14:19:01 1 15.77 17.93 13.68 3.17 0.14 49.31 14:19:01 2 18.65 16.52 13.12 4.98 0.14 46.59 14:19:01 3 15.95 17.13 15.41 4.83 0.14 46.55 14:20:01 all 16.33 2.44 3.27 3.91 0.07 73.98 14:20:01 0 11.33 2.64 2.94 1.79 0.05 81.25 14:20:01 1 37.33 3.12 5.19 2.47 0.08 51.80 14:20:01 2 7.56 1.58 2.30 5.75 0.08 82.73 14:20:01 3 9.06 2.41 2.64 5.64 0.05 80.20 14:21:01 all 82.62 0.00 4.40 5.14 0.12 7.73 14:21:01 0 84.28 0.00 4.14 3.92 0.13 7.53 14:21:01 1 84.68 0.00 4.21 3.42 0.10 7.59 14:21:01 2 81.03 0.00 4.28 4.47 0.12 10.10 14:21:01 3 80.47 0.00 4.95 8.77 0.13 5.68 14:22:01 all 54.61 0.00 3.17 1.98 0.10 40.14 14:22:01 0 39.07 0.00 3.66 2.88 0.12 54.26 14:22:01 1 78.63 0.00 3.08 1.79 0.10 16.40 14:22:01 2 50.31 0.00 2.46 0.67 0.08 46.47 14:22:01 3 50.20 0.00 3.48 2.59 0.10 43.62 14:23:01 all 84.86 0.00 4.88 7.41 0.14 2.71 14:23:01 0 86.50 0.00 5.20 4.86 0.15 3.28 14:23:01 1 83.86 0.00 4.39 9.28 0.13 2.34 14:23:01 2 86.16 0.00 5.21 4.74 0.14 3.75 14:23:01 3 83.00 0.00 4.75 10.64 0.12 1.50 14:24:01 all 88.49 0.00 4.18 1.55 0.11 5.68 14:24:01 0 85.42 0.00 4.24 1.42 0.08 8.83 14:24:01 1 89.02 0.00 4.33 1.33 0.12 5.21 14:24:01 2 89.57 0.00 4.08 2.27 0.10 3.99 14:24:01 3 89.94 0.00 4.06 1.19 0.13 4.68 14:25:01 all 58.62 0.00 2.55 0.33 0.10 38.41 14:25:01 0 55.26 0.00 1.86 0.07 0.10 42.70 14:25:01 1 59.60 0.00 3.19 0.67 0.10 36.44 14:25:01 2 57.17 0.00 2.63 0.45 0.08 39.65 14:25:01 3 62.44 0.00 2.50 0.12 0.10 34.83 14:26:01 all 51.40 0.00 1.74 0.62 0.09 46.15 14:26:01 0 49.14 0.00 1.66 0.34 0.10 48.77 14:26:01 1 50.59 0.00 2.17 1.72 0.08 45.44 14:26:01 2 51.64 0.00 1.62 0.08 0.10 46.55 14:26:01 3 54.25 0.00 1.50 0.34 0.08 43.84 14:27:01 all 28.29 0.00 1.31 0.35 0.10 69.95 14:27:01 0 31.64 0.00 1.43 0.03 0.10 66.80 14:27:01 1 28.46 0.00 1.45 0.91 0.10 69.08 14:27:01 2 27.61 0.00 1.11 0.02 0.10 71.16 14:27:01 3 25.47 0.00 1.26 0.44 0.10 72.73 14:28:01 all 36.97 0.00 1.78 0.79 0.10 60.36 14:28:01 0 40.06 0.00 1.51 0.02 0.08 58.33 14:28:01 1 38.14 0.00 1.68 1.74 0.10 58.34 14:28:01 2 25.34 0.00 1.80 0.74 0.12 72.00 14:28:01 3 44.32 0.00 2.14 0.66 0.12 52.77 14:29:01 all 1.04 0.00 0.32 0.03 0.09 98.52 14:29:01 0 1.27 0.00 0.27 0.00 0.10 98.36 14:29:01 1 1.02 0.00 0.17 0.05 0.08 98.68 14:29:01 2 0.87 0.00 0.37 0.02 0.10 98.64 14:29:01 3 1.01 0.00 0.47 0.05 0.08 98.39 14:29:01 CPU %user %nice %system %iowait %steal %idle 14:30:01 all 18.77 0.00 1.08 0.04 0.10 80.02 14:30:01 0 18.40 0.00 1.11 0.00 0.08 80.42 14:30:01 1 19.80 0.00 1.17 0.05 0.10 78.88 14:30:01 2 18.81 0.00 0.94 0.05 0.10 80.10 14:30:01 3 18.05 0.00 1.10 0.05 0.10 80.69 14:31:01 all 61.07 0.00 2.11 0.12 0.10 36.59 14:31:01 0 61.36 0.00 2.08 0.05 0.10 36.41 14:31:01 1 59.72 0.00 2.24 0.19 0.10 37.76 14:31:01 2 60.81 0.00 2.02 0.02 0.12 37.04 14:31:01 3 62.41 0.00 2.11 0.23 0.08 35.17 14:32:01 all 6.86 0.00 0.37 0.03 0.09 92.65 14:32:01 0 7.16 0.00 0.39 0.03 0.08 92.33 14:32:01 1 7.10 0.00 0.30 0.00 0.08 92.52 14:32:01 2 6.38 0.00 0.45 0.02 0.08 93.06 14:32:01 3 6.80 0.00 0.32 0.08 0.10 92.69 14:33:01 all 1.59 0.00 0.26 0.02 0.09 98.04 14:33:01 0 1.62 0.00 0.28 0.02 0.08 97.99 14:33:01 1 2.04 0.00 0.25 0.00 0.08 97.62 14:33:01 2 1.69 0.00 0.25 0.00 0.10 97.96 14:33:01 3 1.01 0.00 0.27 0.05 0.08 98.59 14:34:01 all 39.25 0.00 1.54 0.73 0.10 58.38 14:34:01 0 33.80 0.00 1.26 0.27 0.10 64.57 14:34:01 1 39.75 0.00 1.27 0.05 0.10 58.83 14:34:01 2 36.92 0.00 1.58 2.11 0.10 59.29 14:34:01 3 46.51 0.00 2.05 0.50 0.12 50.82 14:35:01 all 34.87 0.00 1.20 0.71 0.10 63.13 14:35:01 0 34.91 0.00 1.18 0.28 0.08 63.55 14:35:01 1 37.03 0.00 1.22 0.00 0.10 61.65 14:35:01 2 33.42 0.00 0.96 0.12 0.10 65.40 14:35:01 3 34.11 0.00 1.43 2.45 0.10 61.92 14:36:01 all 4.45 0.00 0.35 0.03 0.10 95.07 14:36:01 0 6.04 0.00 0.30 0.03 0.10 93.53 14:36:01 1 3.82 0.00 0.37 0.08 0.10 95.63 14:36:01 2 4.33 0.00 0.37 0.00 0.10 95.20 14:36:01 3 3.58 0.00 0.39 0.00 0.10 95.94 14:37:01 all 21.71 0.00 0.89 0.02 0.08 77.29 14:37:01 0 22.28 0.00 1.10 0.05 0.08 76.48 14:37:01 1 22.05 0.00 0.96 0.02 0.08 76.89 14:37:01 2 19.80 0.00 0.88 0.02 0.08 79.21 14:37:01 3 22.72 0.00 0.64 0.00 0.08 76.56 14:38:01 all 24.08 0.00 0.75 0.05 0.09 75.03 14:38:01 0 25.66 0.00 0.80 0.15 0.10 73.29 14:38:01 1 24.17 0.00 0.85 0.05 0.10 74.82 14:38:01 2 22.40 0.00 0.91 0.02 0.07 76.60 14:38:01 3 24.09 0.00 0.44 0.00 0.08 75.39 14:39:01 all 4.47 0.00 0.23 0.02 0.09 95.20 14:39:01 0 4.29 0.00 0.25 0.05 0.10 95.30 14:39:01 1 4.05 0.00 0.23 0.00 0.08 95.63 14:39:01 2 4.17 0.00 0.17 0.02 0.08 95.56 14:39:01 3 5.36 0.00 0.25 0.00 0.08 94.30 14:40:01 all 32.01 0.00 1.06 0.27 0.10 66.56 14:40:01 0 32.31 0.00 1.26 0.64 0.08 65.72 14:40:01 1 30.42 0.00 0.87 0.02 0.10 68.59 14:40:01 2 32.38 0.00 1.34 0.42 0.10 65.76 14:40:01 3 32.94 0.00 0.77 0.00 0.10 66.19 14:40:01 CPU %user %nice %system %iowait %steal %idle 14:41:01 all 44.04 0.00 1.72 0.47 0.10 53.67 14:41:01 0 43.27 0.00 1.50 0.25 0.12 54.87 14:41:01 1 39.77 0.00 1.64 0.05 0.08 58.46 14:41:01 2 42.24 0.00 1.69 1.29 0.08 54.69 14:41:01 3 50.91 0.00 2.06 0.30 0.10 46.63 14:42:01 all 30.44 0.00 1.23 0.04 0.09 68.19 14:42:01 0 31.17 0.00 1.37 0.02 0.08 67.35 14:42:01 1 28.94 0.00 1.36 0.00 0.10 69.60 14:42:01 2 31.64 0.00 1.15 0.08 0.08 67.03 14:42:01 3 30.02 0.00 1.04 0.07 0.08 68.79 14:43:01 all 50.03 0.00 1.89 0.29 0.10 47.70 14:43:01 0 50.61 0.00 2.06 0.12 0.08 47.13 14:43:01 1 44.54 0.00 1.85 0.32 0.10 53.19 14:43:01 2 52.02 0.00 1.31 0.47 0.10 46.10 14:43:01 3 52.96 0.00 2.33 0.25 0.12 44.34 14:44:01 all 18.12 0.00 0.61 0.32 0.10 80.86 14:44:01 0 17.86 0.00 0.54 0.02 0.12 81.47 14:44:01 1 18.13 0.00 0.45 0.10 0.10 81.22 14:44:01 2 18.24 0.00 0.50 0.05 0.10 81.11 14:44:01 3 18.23 0.00 0.94 1.13 0.08 79.62 14:45:01 all 0.98 0.00 0.17 0.01 0.10 98.74 14:45:01 0 0.89 0.00 0.12 0.00 0.07 98.93 14:45:01 1 1.14 0.00 0.13 0.00 0.10 98.62 14:45:01 2 0.92 0.00 0.23 0.02 0.10 98.73 14:45:01 3 0.97 0.00 0.18 0.03 0.12 98.69 14:46:01 all 0.31 0.00 0.12 0.01 0.08 99.48 14:46:01 0 0.17 0.00 0.10 0.00 0.08 99.65 14:46:01 1 0.44 0.00 0.20 0.00 0.10 99.26 14:46:01 2 0.27 0.00 0.07 0.02 0.08 99.56 14:46:01 3 0.35 0.00 0.12 0.02 0.07 99.45 14:47:01 all 0.26 0.00 0.12 0.01 0.09 99.52 14:47:01 0 0.17 0.00 0.07 0.00 0.08 99.68 14:47:01 1 0.49 0.00 0.20 0.00 0.08 99.23 14:47:01 2 0.18 0.00 0.08 0.02 0.10 99.61 14:47:01 3 0.22 0.00 0.12 0.03 0.08 99.55 14:48:01 all 17.75 0.00 0.77 0.03 0.08 81.37 14:48:01 0 18.41 0.00 0.79 0.05 0.08 80.66 14:48:01 1 16.58 0.00 0.77 0.02 0.08 82.55 14:48:01 2 18.63 0.00 0.77 0.00 0.07 80.53 14:48:01 3 17.38 0.00 0.75 0.05 0.08 81.73 14:49:01 all 29.97 0.00 0.94 0.32 0.09 68.67 14:49:01 0 30.15 0.00 0.92 0.00 0.08 68.85 14:49:01 1 30.25 0.00 0.99 0.07 0.08 68.61 14:49:01 2 28.71 0.00 0.91 0.49 0.10 69.80 14:49:01 3 30.80 0.00 0.96 0.74 0.08 67.43 14:50:01 all 16.28 0.00 0.75 0.30 0.08 82.59 14:50:01 0 17.79 0.00 0.68 0.45 0.07 81.01 14:50:01 1 15.45 0.00 0.68 0.00 0.10 83.77 14:50:01 2 15.51 0.00 0.65 0.05 0.08 83.70 14:50:01 3 16.35 0.00 0.97 0.72 0.08 81.89 14:51:01 all 22.00 0.00 0.91 0.03 0.08 76.99 14:51:01 0 20.57 0.00 1.04 0.07 0.08 78.24 14:51:01 1 23.01 0.00 0.95 0.05 0.08 75.90 14:51:01 2 21.59 0.00 0.86 0.00 0.07 77.48 14:51:01 3 22.81 0.00 0.79 0.00 0.08 76.32 14:51:01 CPU %user %nice %system %iowait %steal %idle 14:52:01 all 53.07 0.00 1.73 0.59 0.10 44.51 14:52:01 0 54.40 0.00 2.06 0.27 0.10 43.18 14:52:01 1 55.65 0.00 1.80 1.59 0.10 40.86 14:52:01 2 52.48 0.00 1.88 0.45 0.10 45.09 14:52:01 3 49.76 0.00 1.20 0.05 0.10 48.89 14:53:01 all 9.04 0.00 0.56 0.02 0.10 90.29 14:53:01 0 8.80 0.00 0.62 0.02 0.10 90.47 14:53:01 1 8.35 0.00 0.50 0.05 0.08 91.01 14:53:01 2 10.01 0.00 0.73 0.00 0.12 89.14 14:53:01 3 8.99 0.00 0.38 0.00 0.08 90.54 14:54:01 all 40.18 0.00 1.20 0.21 0.09 58.32 14:54:01 0 38.29 0.00 1.27 0.43 0.08 59.93 14:54:01 1 38.86 0.00 1.11 0.42 0.10 59.51 14:54:01 2 41.12 0.00 1.16 0.00 0.08 57.64 14:54:01 3 42.47 0.00 1.26 0.00 0.08 56.19 14:55:01 all 27.86 0.00 1.11 0.02 0.09 70.91 14:55:01 0 29.29 0.00 1.51 0.02 0.10 69.08 14:55:01 1 27.35 0.00 0.90 0.05 0.08 71.61 14:55:01 2 27.86 0.00 0.97 0.02 0.08 71.07 14:55:01 3 26.95 0.00 1.06 0.00 0.10 71.89 14:56:01 all 33.77 0.00 1.16 0.27 0.10 64.70 14:56:01 0 34.98 0.00 1.17 0.00 0.10 63.75 14:56:01 1 33.88 0.00 1.02 0.65 0.10 64.35 14:56:01 2 34.98 0.00 1.35 0.33 0.10 63.23 14:56:01 3 31.25 0.00 1.11 0.10 0.10 67.44 14:57:01 all 5.19 0.00 0.37 0.01 0.08 94.35 14:57:01 0 4.50 0.00 0.47 0.02 0.08 94.93 14:57:01 1 5.81 0.00 0.35 0.03 0.08 93.73 14:57:01 2 5.27 0.00 0.30 0.00 0.07 94.37 14:57:01 3 5.18 0.00 0.37 0.00 0.08 94.37 14:58:01 all 20.01 0.00 0.97 0.03 0.08 78.91 14:58:01 0 21.34 0.00 0.82 0.05 0.08 77.71 14:58:01 1 21.46 0.00 0.98 0.07 0.08 77.42 14:58:01 2 17.19 0.00 1.10 0.00 0.08 81.63 14:58:01 3 20.04 0.00 0.99 0.00 0.08 78.89 14:59:01 all 38.29 0.00 1.13 0.27 0.10 60.21 14:59:01 0 38.34 0.00 1.17 0.69 0.08 59.72 14:59:01 1 40.01 0.00 1.07 0.30 0.10 58.52 14:59:01 2 39.39 0.00 1.32 0.05 0.10 59.14 14:59:01 3 35.42 0.00 0.97 0.03 0.10 63.48 15:00:01 all 6.88 0.00 0.28 0.02 0.08 92.73 15:00:01 0 6.68 0.00 0.28 0.05 0.08 92.90 15:00:01 1 6.74 0.00 0.27 0.00 0.08 92.91 15:00:01 2 7.24 0.00 0.23 0.00 0.08 92.44 15:00:01 3 6.86 0.00 0.33 0.03 0.08 92.69 15:01:01 all 3.61 0.00 0.23 0.01 0.08 96.07 15:01:01 0 3.70 0.00 0.23 0.02 0.08 95.97 15:01:01 1 3.73 0.00 0.25 0.00 0.08 95.93 15:01:01 2 3.45 0.00 0.23 0.00 0.08 96.23 15:01:01 3 3.54 0.00 0.20 0.03 0.07 96.16 15:02:01 all 1.33 0.00 0.15 0.03 0.08 98.43 15:02:01 0 1.32 0.00 0.13 0.05 0.07 98.43 15:02:01 1 1.52 0.00 0.18 0.00 0.08 98.22 15:02:01 2 1.12 0.00 0.13 0.00 0.08 98.66 15:02:01 3 1.35 0.00 0.13 0.05 0.07 98.40 15:02:01 CPU %user %nice %system %iowait %steal %idle 15:03:01 all 3.23 0.00 0.22 0.02 0.07 96.46 15:03:01 0 3.41 0.00 0.20 0.05 0.08 96.26 15:03:01 1 3.39 0.00 0.24 0.00 0.08 96.29 15:03:01 2 2.96 0.00 0.23 0.00 0.05 96.75 15:03:01 3 3.16 0.00 0.22 0.02 0.07 96.53 15:04:01 all 1.62 0.00 0.15 0.02 0.08 98.13 15:04:01 0 1.39 0.00 0.17 0.00 0.08 98.36 15:04:01 1 1.98 0.00 0.17 0.03 0.08 97.74 15:04:01 2 1.47 0.00 0.18 0.05 0.08 98.21 15:04:01 3 1.62 0.00 0.08 0.00 0.07 98.23 15:05:01 all 2.05 0.00 0.15 0.01 0.07 97.73 15:05:01 0 1.67 0.00 0.13 0.00 0.07 98.12 15:05:01 1 2.57 0.00 0.20 0.03 0.08 97.11 15:05:01 2 2.37 0.00 0.12 0.00 0.07 97.44 15:05:01 3 1.57 0.00 0.13 0.00 0.07 98.23 15:06:01 all 2.79 0.00 0.25 0.01 0.08 96.88 15:06:01 0 2.13 0.00 0.22 0.00 0.08 97.57 15:06:01 1 2.73 0.00 0.15 0.03 0.07 97.02 15:06:01 2 4.26 0.00 0.25 0.00 0.08 95.41 15:06:01 3 2.02 0.00 0.38 0.00 0.07 97.52 15:07:01 all 49.89 0.00 1.59 0.29 0.09 48.13 15:07:01 0 49.84 0.00 1.44 0.07 0.10 48.55 15:07:01 1 51.52 0.00 1.61 0.69 0.10 46.09 15:07:01 2 51.50 0.00 1.86 0.40 0.08 46.16 15:07:01 3 46.69 0.00 1.46 0.02 0.08 51.74 15:08:01 all 9.11 0.00 0.34 0.02 0.09 90.43 15:08:01 0 9.19 0.00 0.30 0.00 0.08 90.42 15:08:01 1 9.21 0.00 0.40 0.07 0.08 90.24 15:08:01 2 8.76 0.00 0.35 0.02 0.10 90.78 15:08:01 3 9.28 0.00 0.32 0.00 0.10 90.30 15:09:01 all 4.60 0.00 0.26 0.01 0.09 95.04 15:09:01 0 4.64 0.00 0.34 0.00 0.08 94.94 15:09:01 1 4.38 0.00 0.24 0.05 0.10 95.23 15:09:01 2 4.79 0.00 0.18 0.00 0.08 94.95 15:09:01 3 4.59 0.00 0.27 0.00 0.08 95.05 15:10:01 all 2.81 0.00 0.23 0.02 0.08 96.87 15:10:01 0 2.86 0.00 0.25 0.02 0.07 96.80 15:10:01 1 3.08 0.00 0.17 0.03 0.08 96.63 15:10:01 2 2.78 0.00 0.18 0.02 0.07 96.96 15:10:01 3 2.51 0.00 0.30 0.00 0.10 97.09 15:11:01 all 2.21 0.00 0.19 0.02 0.08 97.51 15:11:01 0 2.34 0.00 0.13 0.02 0.07 97.44 15:11:01 1 2.03 0.00 0.25 0.05 0.08 97.58 15:11:01 2 2.21 0.00 0.17 0.02 0.08 97.52 15:11:01 3 2.24 0.00 0.20 0.00 0.07 97.49 15:12:01 all 1.58 0.00 0.15 0.01 0.09 98.16 15:12:01 0 1.39 0.00 0.18 0.00 0.07 98.36 15:12:01 1 2.24 0.00 0.13 0.03 0.10 97.49 15:12:01 2 1.16 0.00 0.15 0.00 0.08 98.61 15:12:01 3 1.56 0.00 0.13 0.02 0.10 98.19 15:13:01 all 4.27 0.00 0.29 0.02 0.08 95.34 15:13:01 0 4.55 0.00 0.35 0.00 0.08 95.02 15:13:01 1 3.93 0.00 0.28 0.05 0.07 95.67 15:13:01 2 4.70 0.00 0.22 0.02 0.08 94.98 15:13:01 3 3.92 0.00 0.32 0.00 0.08 95.68 15:13:01 CPU %user %nice %system %iowait %steal %idle 15:14:01 all 36.30 0.00 1.30 0.07 0.08 62.26 15:14:01 0 34.27 0.00 1.02 0.00 0.07 64.64 15:14:01 1 36.39 0.00 1.53 0.05 0.08 61.95 15:14:01 2 38.21 0.00 1.47 0.02 0.07 60.23 15:14:01 3 36.32 0.00 1.17 0.20 0.08 62.23 15:15:01 all 36.20 0.00 1.28 0.26 0.09 62.17 15:15:01 0 34.99 0.00 0.98 0.30 0.10 63.63 15:15:01 1 36.25 0.00 1.62 0.47 0.10 61.56 15:15:01 2 35.11 0.00 1.35 0.02 0.08 63.43 15:15:01 3 38.43 0.00 1.18 0.25 0.08 60.05 15:16:01 all 9.12 0.00 0.50 0.02 0.09 90.27 15:16:01 0 8.90 0.00 0.53 0.03 0.08 90.45 15:16:01 1 8.58 0.00 0.53 0.00 0.10 90.79 15:16:01 2 9.50 0.00 0.50 0.03 0.08 89.88 15:16:01 3 9.49 0.00 0.45 0.00 0.10 89.96 15:17:01 all 3.99 0.00 0.37 0.02 0.07 95.56 15:17:01 0 3.61 0.00 0.43 0.03 0.08 95.84 15:17:01 1 4.34 0.00 0.30 0.00 0.07 95.30 15:17:01 2 4.36 0.00 0.42 0.03 0.07 95.12 15:17:01 3 3.65 0.00 0.32 0.00 0.07 95.97 15:18:01 all 3.20 0.00 0.31 0.02 0.08 96.39 15:18:01 0 3.09 0.00 0.35 0.03 0.08 96.45 15:18:01 1 3.28 0.00 0.40 0.00 0.08 96.23 15:18:01 2 3.52 0.00 0.33 0.05 0.10 96.00 15:18:01 3 2.90 0.00 0.17 0.00 0.07 96.87 15:19:01 all 5.05 0.00 0.41 0.01 0.08 94.45 15:19:01 0 4.76 0.00 0.32 0.03 0.08 94.81 15:19:01 1 4.50 0.00 0.40 0.00 0.08 95.02 15:19:01 2 4.99 0.00 0.57 0.02 0.08 94.35 15:19:01 3 5.93 0.00 0.36 0.00 0.07 93.64 15:20:01 all 2.21 0.00 0.32 0.02 0.08 97.36 15:20:01 0 2.04 0.00 0.35 0.02 0.08 97.51 15:20:01 1 1.95 0.00 0.35 0.03 0.08 97.58 15:20:01 2 2.86 0.00 0.23 0.03 0.08 96.79 15:20:01 3 2.00 0.00 0.35 0.00 0.08 97.56 15:21:01 all 2.76 0.00 0.38 0.02 0.08 96.76 15:21:01 0 3.00 0.00 0.38 0.02 0.08 96.52 15:21:01 1 2.60 0.00 0.35 0.03 0.07 96.95 15:21:01 2 2.72 0.00 0.35 0.02 0.10 96.81 15:21:01 3 2.74 0.00 0.42 0.00 0.08 96.76 15:22:01 all 20.99 0.00 1.19 0.07 0.08 77.67 15:22:01 0 19.54 0.00 1.54 0.20 0.07 78.66 15:22:01 1 21.07 0.00 0.92 0.03 0.08 77.89 15:22:01 2 20.17 0.00 1.07 0.03 0.07 78.66 15:22:01 3 23.18 0.00 1.22 0.02 0.10 75.48 15:23:01 all 49.91 0.00 1.63 0.26 0.12 48.08 15:23:01 0 49.71 0.00 1.74 0.20 0.12 48.23 15:23:01 1 52.74 0.00 1.54 0.17 0.12 45.43 15:23:01 2 48.32 0.00 1.76 0.10 0.12 49.70 15:23:01 3 48.88 0.00 1.47 0.57 0.12 48.96 15:24:01 all 7.31 0.00 0.33 0.04 0.08 92.23 15:24:01 0 7.30 0.00 0.25 0.00 0.07 92.38 15:24:01 1 6.68 0.00 0.40 0.10 0.08 92.73 15:24:01 2 7.04 0.00 0.34 0.00 0.08 92.54 15:24:01 3 8.23 0.00 0.33 0.07 0.08 91.29 15:24:01 CPU %user %nice %system %iowait %steal %idle 15:25:01 all 9.67 0.00 0.33 0.02 0.08 89.90 15:25:01 0 9.66 0.00 0.25 0.03 0.07 89.99 15:25:01 1 9.22 0.00 0.28 0.00 0.08 90.42 15:25:01 2 10.16 0.00 0.50 0.00 0.08 89.25 15:25:01 3 9.66 0.00 0.29 0.03 0.08 89.94 15:26:01 all 1.78 0.00 0.19 0.01 0.07 97.95 15:26:01 0 1.74 0.00 0.20 0.02 0.08 97.96 15:26:01 1 1.71 0.00 0.17 0.00 0.08 98.04 15:26:01 2 1.81 0.00 0.28 0.00 0.07 97.84 15:26:01 3 1.85 0.00 0.10 0.03 0.05 97.97 15:27:01 all 2.36 0.00 0.21 0.01 0.08 97.34 15:27:01 0 2.38 0.00 0.25 0.00 0.08 97.28 15:27:01 1 2.16 0.00 0.15 0.00 0.07 97.62 15:27:01 2 2.27 0.00 0.25 0.02 0.10 97.36 15:27:01 3 2.63 0.00 0.18 0.03 0.08 97.07 15:28:01 all 2.04 0.00 0.18 0.03 0.09 97.66 15:28:01 0 1.95 0.00 0.13 0.03 0.07 97.81 15:28:01 1 1.93 0.00 0.18 0.00 0.10 97.79 15:28:01 2 2.29 0.00 0.17 0.03 0.10 97.40 15:28:01 3 1.99 0.00 0.25 0.03 0.08 97.64 15:29:01 all 1.82 0.00 0.18 0.03 0.08 97.89 15:29:01 0 1.65 0.00 0.13 0.02 0.07 98.13 15:29:01 1 1.56 0.00 0.15 0.00 0.08 98.21 15:29:01 2 2.52 0.00 0.15 0.00 0.08 97.24 15:29:01 3 1.56 0.00 0.27 0.10 0.10 97.97 15:30:01 all 2.60 0.00 0.19 0.02 0.07 97.13 15:30:01 0 2.48 0.00 0.22 0.02 0.07 97.22 15:30:01 1 2.28 0.00 0.24 0.00 0.07 97.41 15:30:01 2 3.66 0.00 0.15 0.02 0.07 96.10 15:30:01 3 1.96 0.00 0.17 0.03 0.07 97.78 15:31:01 all 1.94 0.00 0.20 0.01 0.08 97.77 15:31:01 0 1.81 0.00 0.20 0.02 0.07 97.90 15:31:01 1 1.89 0.00 0.17 0.00 0.10 97.84 15:31:01 2 2.36 0.00 0.30 0.00 0.10 97.24 15:31:01 3 1.69 0.00 0.12 0.03 0.07 98.09 15:32:01 all 1.88 0.00 0.19 0.02 0.09 97.82 15:32:01 0 1.89 0.00 0.18 0.03 0.08 97.81 15:32:01 1 1.71 0.00 0.15 0.00 0.10 98.04 15:32:01 2 2.20 0.00 0.20 0.00 0.08 97.52 15:32:01 3 1.73 0.00 0.23 0.05 0.08 97.91 15:33:01 all 0.26 0.00 0.09 0.01 0.07 99.56 15:33:01 0 0.18 0.00 0.07 0.00 0.07 99.68 15:33:01 1 0.27 0.00 0.10 0.02 0.07 99.55 15:33:01 2 0.30 0.00 0.12 0.00 0.08 99.49 15:33:01 3 0.28 0.00 0.08 0.03 0.07 99.53 15:34:01 all 0.32 0.00 0.12 0.01 0.09 99.45 15:34:01 0 0.32 0.00 0.19 0.00 0.10 99.39 15:34:01 1 0.46 0.00 0.12 0.02 0.10 99.30 15:34:01 2 0.22 0.00 0.09 0.00 0.09 99.61 15:34:01 3 0.29 0.00 0.10 0.03 0.07 99.51 15:35:01 all 3.10 0.00 0.47 0.07 0.08 96.29 15:35:01 0 1.36 0.00 0.55 0.00 0.07 98.02 15:35:01 1 1.44 0.00 0.42 0.02 0.08 98.04 15:35:01 2 1.45 0.00 0.25 0.00 0.07 98.23 15:35:01 3 8.13 0.00 0.67 0.25 0.08 90.87 15:35:01 CPU %user %nice %system %iowait %steal %idle 15:36:01 all 61.34 0.00 1.97 0.57 0.11 36.00 15:36:01 0 63.30 0.00 2.36 0.39 0.12 33.83 15:36:01 1 61.06 0.00 1.88 1.51 0.12 35.44 15:36:01 2 59.53 0.00 1.22 0.15 0.12 38.98 15:36:01 3 61.48 0.00 2.41 0.25 0.10 35.76 15:37:01 all 3.30 0.00 0.26 0.03 0.08 96.32 15:37:01 0 2.83 0.00 0.25 0.00 0.07 96.85 15:37:01 1 3.27 0.00 0.30 0.13 0.08 96.21 15:37:01 2 3.76 0.00 0.27 0.00 0.07 95.90 15:37:01 3 3.36 0.00 0.23 0.00 0.08 96.33 15:38:01 all 2.99 0.00 0.28 0.03 0.07 96.64 15:38:01 0 3.15 0.00 0.30 0.02 0.07 96.47 15:38:01 1 2.78 0.00 0.23 0.03 0.07 96.88 15:38:01 2 2.67 0.00 0.17 0.03 0.07 97.06 15:38:01 3 3.35 0.00 0.40 0.02 0.08 96.14 15:39:01 all 0.39 0.00 0.16 0.01 0.08 99.36 15:39:01 0 0.18 0.00 0.15 0.00 0.08 99.58 15:39:01 1 0.49 0.00 0.25 0.02 0.08 99.16 15:39:01 2 0.30 0.00 0.10 0.03 0.07 99.50 15:39:01 3 0.60 0.00 0.15 0.00 0.07 99.18 15:40:01 all 0.36 0.00 0.15 0.01 0.08 99.41 15:40:01 0 0.32 0.00 0.13 0.00 0.08 99.46 15:40:01 1 0.25 0.00 0.12 0.02 0.07 99.55 15:40:01 2 0.33 0.00 0.10 0.03 0.07 99.47 15:40:01 3 0.52 0.00 0.24 0.00 0.08 99.16 15:41:01 all 33.23 0.00 1.38 0.03 0.08 65.28 15:41:01 0 32.53 0.00 1.72 0.02 0.10 65.63 15:41:01 1 33.46 0.00 1.44 0.03 0.08 64.98 15:41:01 2 33.56 0.00 1.23 0.03 0.05 65.12 15:41:01 3 33.38 0.00 1.12 0.02 0.08 65.39 15:42:01 all 27.77 0.00 0.82 0.28 0.10 71.03 15:42:01 0 28.85 0.00 1.08 0.00 0.10 69.97 15:42:01 1 28.77 0.00 0.68 0.07 0.10 70.38 15:42:01 2 27.62 0.00 0.82 0.05 0.10 71.41 15:42:01 3 25.84 0.00 0.70 1.00 0.10 72.36 15:43:01 all 2.69 0.00 0.28 0.01 0.08 96.93 15:43:01 0 2.16 0.00 0.22 0.00 0.07 97.55 15:43:01 1 2.89 0.00 0.32 0.00 0.10 96.70 15:43:01 2 3.04 0.00 0.32 0.02 0.10 96.52 15:43:01 3 2.66 0.00 0.28 0.03 0.07 96.96 15:44:01 all 3.14 0.00 0.30 0.02 0.07 96.48 15:44:01 0 2.93 0.00 0.33 0.00 0.07 96.67 15:44:01 1 3.42 0.00 0.35 0.00 0.08 96.15 15:44:01 2 2.86 0.00 0.27 0.05 0.07 96.76 15:44:01 3 3.34 0.00 0.23 0.03 0.07 96.33 15:45:01 all 2.23 0.00 0.25 0.01 0.09 97.42 15:45:01 0 1.99 0.00 0.28 0.00 0.10 97.62 15:45:01 1 2.20 0.00 0.18 0.00 0.07 97.54 15:45:01 2 2.54 0.00 0.28 0.02 0.10 97.06 15:45:01 3 2.19 0.00 0.25 0.03 0.08 97.45 15:46:01 all 3.00 0.00 0.30 0.02 0.08 96.61 15:46:01 0 3.18 0.00 0.45 0.00 0.08 96.28 15:46:01 1 3.10 0.00 0.33 0.00 0.10 96.46 15:46:01 2 2.83 0.00 0.22 0.03 0.07 96.85 15:46:01 3 2.87 0.00 0.18 0.03 0.05 96.86 15:46:01 CPU %user %nice %system %iowait %steal %idle 15:47:01 all 2.49 0.00 0.25 0.02 0.07 97.16 15:47:01 0 2.63 0.00 0.45 0.00 0.08 96.83 15:47:01 1 2.05 0.00 0.18 0.00 0.07 97.69 15:47:01 2 2.85 0.00 0.23 0.03 0.07 96.82 15:47:01 3 2.44 0.00 0.15 0.03 0.07 97.31 15:48:01 all 24.84 0.00 0.99 0.05 0.10 74.03 15:48:01 0 22.97 0.00 0.93 0.10 0.10 75.90 15:48:01 1 26.10 0.00 1.04 0.02 0.08 72.76 15:48:01 2 24.44 0.00 1.05 0.02 0.10 74.39 15:48:01 3 25.84 0.00 0.93 0.05 0.10 73.08 15:49:01 all 44.73 0.00 1.20 0.20 0.09 53.78 15:49:01 0 43.72 0.00 1.22 0.12 0.10 54.83 15:49:01 1 44.37 0.00 1.37 0.33 0.10 53.82 15:49:01 2 45.45 0.00 1.12 0.00 0.08 53.35 15:49:01 3 45.37 0.00 1.07 0.37 0.08 53.11 15:50:01 all 6.78 0.00 0.40 0.03 0.08 92.71 15:50:01 0 6.64 0.00 0.40 0.03 0.08 92.84 15:50:01 1 6.46 0.00 0.47 0.00 0.10 92.98 15:50:01 2 7.56 0.00 0.42 0.00 0.08 91.94 15:50:01 3 6.47 0.00 0.30 0.07 0.07 93.10 15:51:01 all 6.61 0.00 0.38 0.03 0.08 92.90 15:51:01 0 7.39 0.00 0.37 0.05 0.07 92.13 15:51:01 1 5.95 0.00 0.27 0.00 0.07 93.72 15:51:01 2 6.40 0.00 0.42 0.00 0.10 93.08 15:51:01 3 6.70 0.00 0.48 0.07 0.08 92.67 15:52:01 all 5.23 0.00 0.40 0.01 0.08 94.28 15:52:01 0 4.75 0.00 0.38 0.02 0.07 94.79 15:52:01 1 5.22 0.00 0.38 0.00 0.08 94.31 15:52:01 2 6.10 0.00 0.42 0.00 0.08 93.40 15:52:01 3 4.86 0.00 0.40 0.02 0.08 94.64 15:53:01 all 26.41 0.00 1.57 1.56 0.07 70.39 15:53:01 0 17.00 0.00 1.37 2.57 0.07 78.99 15:53:01 1 15.36 0.00 1.42 0.12 0.07 83.03 15:53:01 2 17.26 0.00 1.29 0.18 0.07 81.21 15:53:01 3 56.00 0.00 2.22 3.36 0.08 38.34 Average: all 18.76 0.21 1.00 0.39 0.09 79.55 Average: 0 18.33 0.22 1.02 0.36 0.09 79.99 Average: 1 19.11 0.22 1.01 0.37 0.09 79.20 Average: 2 18.37 0.19 0.96 0.33 0.09 80.06 Average: 3 19.21 0.20 1.01 0.52 0.09 78.97