13:23:34 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/114246 13:23:34 Running as SYSTEM 13:23:34 [EnvInject] - Loading node environment variables. 13:23:34 Building remotely on prd-ubuntu2004-docker-4c-16g-2872 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 13:23:35 [ssh-agent] Looking for ssh-agent implementation... 13:23:35 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 13:23:35 $ ssh-agent 13:23:35 SSH_AUTH_SOCK=/tmp/ssh-0eM4p6uBDU9n/agent.12415 13:23:35 SSH_AGENT_PID=12417 13:23:35 [ssh-agent] Started. 13:23:35 Running ssh-add (command line suppressed) 13:23:35 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_1221023002013628238.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_1221023002013628238.key) 13:23:35 [ssh-agent] Using credentials jenkins (jenkins-ssh) 13:23:35 The recommended git tool is: NONE 13:23:38 using credential jenkins-ssh 13:23:38 Wiping out workspace first. 13:23:38 Cloning the remote Git repository 13:23:38 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 13:23:38 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 13:23:38 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:23:38 > git --version # timeout=10 13:23:38 > git --version # 'git version 2.25.1' 13:23:38 using GIT_SSH to set credentials jenkins-ssh 13:23:38 Verifying host key using known hosts file 13:23:38 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. 13:23:38 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 13:23:41 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:23:41 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 13:23:41 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:23:41 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:23:41 using GIT_SSH to set credentials jenkins-ssh 13:23:41 Verifying host key using known hosts file 13:23:41 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. 13:23:41 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/46/114246/3 # timeout=10 13:23:42 > git rev-parse 18ec2f37e1c9f3c8514d19160d6b258b4176399a^{commit} # timeout=10 13:23:42 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 13:23:42 Checking out Revision 18ec2f37e1c9f3c8514d19160d6b258b4176399a (refs/changes/46/114246/3) 13:23:42 > git config core.sparsecheckout # timeout=10 13:23:42 > git checkout -f 18ec2f37e1c9f3c8514d19160d6b258b4176399a # timeout=10 13:23:42 Commit message: "Adjust tox ini tests sequencing" 13:23:42 > git rev-parse FETCH_HEAD^{commit} # timeout=10 13:23:42 > git rev-list --no-walk b132bd7ef5627451803c7684c19859419c2e2d50 # timeout=10 13:23:42 > git remote # timeout=10 13:23:42 > git submodule init # timeout=10 13:23:42 > git submodule sync # timeout=10 13:23:42 > git config --get remote.origin.url # timeout=10 13:23:42 > git submodule init # timeout=10 13:23:42 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 13:23:42 ERROR: No submodules found. 13:23:46 provisioning config files... 13:23:46 copy managed file [npmrc] to file:/home/jenkins/.npmrc 13:23:46 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 13:23:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1814374950198894916.sh 13:23:46 ---> python-tools-install.sh 13:23:46 Setup pyenv: 13:23:46 * system (set by /opt/pyenv/version) 13:23:46 * 3.8.13 (set by /opt/pyenv/version) 13:23:46 * 3.9.13 (set by /opt/pyenv/version) 13:23:46 * 3.10.13 (set by /opt/pyenv/version) 13:23:46 * 3.11.7 (set by /opt/pyenv/version) 13:23:51 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-WCHm 13:23:51 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 13:23:53 lf-activate-venv(): INFO: Installing: lftools 13:24:42 lf-activate-venv(): INFO: Adding /tmp/venv-WCHm/bin to PATH 13:24:42 Generating Requirements File 13:25:02 Python 3.11.7 13:25:02 pip 24.3.1 from /tmp/venv-WCHm/lib/python3.11/site-packages/pip (python 3.11) 13:25:02 appdirs==1.4.4 13:25:02 argcomplete==3.5.1 13:25:02 aspy.yaml==1.3.0 13:25:02 attrs==24.2.0 13:25:02 autopage==0.5.2 13:25:02 beautifulsoup4==4.12.3 13:25:02 boto3==1.35.51 13:25:02 botocore==1.35.51 13:25:02 bs4==0.0.2 13:25:02 cachetools==5.5.0 13:25:02 certifi==2024.8.30 13:25:02 cffi==1.17.1 13:25:02 cfgv==3.4.0 13:25:02 chardet==5.2.0 13:25:02 charset-normalizer==3.4.0 13:25:02 click==8.1.7 13:25:02 cliff==4.7.0 13:25:02 cmd2==2.5.0 13:25:02 cryptography==3.3.2 13:25:02 debtcollector==3.0.0 13:25:02 decorator==5.1.1 13:25:02 defusedxml==0.7.1 13:25:02 Deprecated==1.2.14 13:25:02 distlib==0.3.9 13:25:02 dnspython==2.7.0 13:25:02 docker==4.2.2 13:25:02 dogpile.cache==1.3.3 13:25:02 durationpy==0.9 13:25:02 email_validator==2.2.0 13:25:02 filelock==3.16.1 13:25:02 future==1.0.0 13:25:02 gitdb==4.0.11 13:25:02 GitPython==3.1.43 13:25:02 google-auth==2.35.0 13:25:02 httplib2==0.22.0 13:25:02 identify==2.6.1 13:25:02 idna==3.10 13:25:02 importlib-resources==1.5.0 13:25:02 iso8601==2.1.0 13:25:02 Jinja2==3.1.4 13:25:02 jmespath==1.0.1 13:25:02 jsonpatch==1.33 13:25:02 jsonpointer==3.0.0 13:25:02 jsonschema==4.23.0 13:25:02 jsonschema-specifications==2024.10.1 13:25:02 keystoneauth1==5.8.0 13:25:02 kubernetes==31.0.0 13:25:02 lftools==0.37.10 13:25:02 lxml==5.3.0 13:25:02 MarkupSafe==3.0.2 13:25:02 msgpack==1.1.0 13:25:02 multi_key_dict==2.0.3 13:25:02 munch==4.0.0 13:25:02 netaddr==1.3.0 13:25:02 netifaces==0.11.0 13:25:02 niet==1.4.2 13:25:02 nodeenv==1.9.1 13:25:02 oauth2client==4.1.3 13:25:02 oauthlib==3.2.2 13:25:02 openstacksdk==4.1.0 13:25:02 os-client-config==2.1.0 13:25:02 os-service-types==1.7.0 13:25:02 osc-lib==3.1.0 13:25:02 oslo.config==9.6.0 13:25:02 oslo.context==5.6.0 13:25:02 oslo.i18n==6.4.0 13:25:02 oslo.log==6.1.2 13:25:02 oslo.serialization==5.5.0 13:25:02 oslo.utils==7.3.0 13:25:02 packaging==24.1 13:25:02 pbr==6.1.0 13:25:02 platformdirs==4.3.6 13:25:02 prettytable==3.12.0 13:25:02 pyasn1==0.6.1 13:25:02 pyasn1_modules==0.4.1 13:25:02 pycparser==2.22 13:25:02 pygerrit2==2.0.15 13:25:02 PyGithub==2.4.0 13:25:02 PyJWT==2.9.0 13:25:02 PyNaCl==1.5.0 13:25:02 pyparsing==2.4.7 13:25:02 pyperclip==1.9.0 13:25:02 pyrsistent==0.20.0 13:25:02 python-cinderclient==9.6.0 13:25:02 python-dateutil==2.9.0.post0 13:25:02 python-heatclient==4.0.0 13:25:02 python-jenkins==1.8.2 13:25:02 python-keystoneclient==5.5.0 13:25:02 python-magnumclient==4.7.0 13:25:02 python-openstackclient==7.2.1 13:25:02 python-swiftclient==4.6.0 13:25:02 PyYAML==6.0.2 13:25:02 referencing==0.35.1 13:25:02 requests==2.32.3 13:25:02 requests-oauthlib==2.0.0 13:25:02 requestsexceptions==1.4.0 13:25:02 rfc3986==2.0.0 13:25:02 rpds-py==0.20.0 13:25:02 rsa==4.9 13:25:02 ruamel.yaml==0.18.6 13:25:02 ruamel.yaml.clib==0.2.12 13:25:02 s3transfer==0.10.3 13:25:02 simplejson==3.19.3 13:25:02 six==1.16.0 13:25:02 smmap==5.0.1 13:25:02 soupsieve==2.6 13:25:02 stevedore==5.3.0 13:25:02 tabulate==0.9.0 13:25:02 toml==0.10.2 13:25:02 tomlkit==0.13.2 13:25:02 tqdm==4.66.6 13:25:02 typing_extensions==4.12.2 13:25:02 tzdata==2024.2 13:25:02 urllib3==1.26.20 13:25:02 virtualenv==20.27.1 13:25:02 wcwidth==0.2.13 13:25:02 websocket-client==1.8.0 13:25:02 wrapt==1.16.0 13:25:02 xdg==6.0.0 13:25:02 xmltodict==0.14.2 13:25:02 yq==3.4.3 13:25:02 [EnvInject] - Injecting environment variables from a build step. 13:25:02 [EnvInject] - Injecting as environment variables the properties content 13:25:02 PYTHON=python3 13:25:02 13:25:02 [EnvInject] - Variables injected successfully. 13:25:02 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins3073594800150781037.sh 13:25:02 ---> tox-install.sh 13:25:02 + source /home/jenkins/lf-env.sh 13:25:02 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:25:02 ++ mktemp -d /tmp/venv-XXXX 13:25:02 + lf_venv=/tmp/venv-MMmI 13:25:02 + local venv_file=/tmp/.os_lf_venv 13:25:02 + local python=python3 13:25:02 + local options 13:25:02 + local set_path=true 13:25:02 + local install_args= 13:25:02 ++ 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 13:25:02 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:25:02 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:25:02 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:25:02 + true 13:25:02 + case $1 in 13:25:02 + venv_file=/tmp/.toxenv 13:25:02 + shift 2 13:25:02 + true 13:25:02 + case $1 in 13:25:02 + shift 13:25:02 + break 13:25:02 + case $python in 13:25:02 + local pkg_list= 13:25:02 + [[ -d /opt/pyenv ]] 13:25:02 + echo 'Setup pyenv:' 13:25:02 Setup pyenv: 13:25:02 + export PYENV_ROOT=/opt/pyenv 13:25:02 + PYENV_ROOT=/opt/pyenv 13:25:02 + 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 13:25:02 + 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 13:25:02 + pyenv versions 13:25:02 system 13:25:02 3.8.13 13:25:02 3.9.13 13:25:02 3.10.13 13:25:02 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:25:02 + command -v pyenv 13:25:02 ++ pyenv init - --no-rehash 13:25:02 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:25:02 for i in ${!paths[@]}; do 13:25:02 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:25:02 fi; done; 13:25:02 echo "${paths[*]}"'\'')" 13:25:02 export PATH="/opt/pyenv/shims:${PATH}" 13:25:02 export PYENV_SHELL=bash 13:25:02 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:25:02 pyenv() { 13:25:02 local command 13:25:02 command="${1:-}" 13:25:02 if [ "$#" -gt 0 ]; then 13:25:02 shift 13:25:02 fi 13:25:02 13:25:02 case "$command" in 13:25:02 rehash|shell) 13:25:02 eval "$(pyenv "sh-$command" "$@")" 13:25:02 ;; 13:25:02 *) 13:25:02 command pyenv "$command" "$@" 13:25:02 ;; 13:25:02 esac 13:25:02 }' 13:25:02 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:25:02 for i in ${!paths[@]}; do 13:25:02 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:25:02 fi; done; 13:25:02 echo "${paths[*]}"' 13:25:02 ++ 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 13:25:02 ++ 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 13:25:02 ++ 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 13:25:02 ++ export PYENV_SHELL=bash 13:25:02 ++ PYENV_SHELL=bash 13:25:02 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:25:02 +++ complete -F _pyenv pyenv 13:25:02 ++ lf-pyver python3 13:25:02 ++ local py_version_xy=python3 13:25:02 ++ local py_version_xyz= 13:25:02 ++ pyenv versions 13:25:02 ++ local command 13:25:02 ++ command=versions 13:25:02 ++ '[' 1 -gt 0 ']' 13:25:02 ++ shift 13:25:02 ++ case "$command" in 13:25:02 ++ command pyenv versions 13:25:02 ++ pyenv versions 13:25:02 ++ awk '{ print $1 }' 13:25:02 ++ grep -E '^[0-9.]*[0-9]$' 13:25:02 ++ sed 's/^[ *]* //' 13:25:02 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:25:03 +++ grep '^3' /tmp/.pyenv_versions 13:25:03 +++ sort -V 13:25:03 +++ tail -n 1 13:25:03 ++ py_version_xyz=3.11.7 13:25:03 ++ [[ -z 3.11.7 ]] 13:25:03 ++ echo 3.11.7 13:25:03 ++ return 0 13:25:03 + pyenv local 3.11.7 13:25:03 + local command 13:25:03 + command=local 13:25:03 + '[' 2 -gt 0 ']' 13:25:03 + shift 13:25:03 + case "$command" in 13:25:03 + command pyenv local 3.11.7 13:25:03 + pyenv local 3.11.7 13:25:03 + for arg in "$@" 13:25:03 + case $arg in 13:25:03 + pkg_list+='tox ' 13:25:03 + for arg in "$@" 13:25:03 + case $arg in 13:25:03 + pkg_list+='virtualenv ' 13:25:03 + for arg in "$@" 13:25:03 + case $arg in 13:25:03 + pkg_list+='urllib3~=1.26.15 ' 13:25:03 + [[ -f /tmp/.toxenv ]] 13:25:03 + [[ ! -f /tmp/.toxenv ]] 13:25:03 + [[ -n '' ]] 13:25:03 + python3 -m venv /tmp/venv-MMmI 13:25:07 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-MMmI' 13:25:07 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-MMmI 13:25:07 + echo /tmp/venv-MMmI 13:25:07 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 13:25:07 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 13:25:07 + /tmp/venv-MMmI/bin/python3 -m pip install --upgrade --quiet pip virtualenv 13:25:10 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:25:10 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 13:25:10 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 13:25:10 + /tmp/venv-MMmI/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 13:25:12 + type python3 13:25:12 + true 13:25:12 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-MMmI/bin to PATH' 13:25:12 lf-activate-venv(): INFO: Adding /tmp/venv-MMmI/bin to PATH 13:25:12 + PATH=/tmp/venv-MMmI/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 13:25:12 + return 0 13:25:12 + python3 --version 13:25:12 Python 3.11.7 13:25:12 + python3 -m pip --version 13:25:12 pip 24.3.1 from /tmp/venv-MMmI/lib/python3.11/site-packages/pip (python 3.11) 13:25:12 + python3 -m pip freeze 13:25:12 cachetools==5.5.0 13:25:12 chardet==5.2.0 13:25:12 colorama==0.4.6 13:25:12 distlib==0.3.9 13:25:12 filelock==3.16.1 13:25:12 packaging==24.1 13:25:12 platformdirs==4.3.6 13:25:12 pluggy==1.5.0 13:25:12 pyproject-api==1.8.0 13:25:12 tox==4.23.2 13:25:12 urllib3==1.26.20 13:25:12 virtualenv==20.27.1 13:25:12 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins14826013945157944079.sh 13:25:12 [EnvInject] - Injecting environment variables from a build step. 13:25:12 [EnvInject] - Injecting as environment variables the properties content 13:25:12 PARALLEL=True 13:25:12 13:25:12 [EnvInject] - Variables injected successfully. 13:25:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins7961661188306705130.sh 13:25:12 ---> tox-run.sh 13:25:12 + 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 13:25:12 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:25:12 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:25:12 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:25:12 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 13:25:12 + source /home/jenkins/lf-env.sh 13:25:12 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:25:12 ++ mktemp -d /tmp/venv-XXXX 13:25:12 + lf_venv=/tmp/venv-6Q1E 13:25:12 + local venv_file=/tmp/.os_lf_venv 13:25:12 + local python=python3 13:25:12 + local options 13:25:12 + local set_path=true 13:25:12 + local install_args= 13:25:12 ++ 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 13:25:12 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:25:12 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:25:12 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:25:12 + true 13:25:12 + case $1 in 13:25:12 + venv_file=/tmp/.toxenv 13:25:12 + shift 2 13:25:12 + true 13:25:12 + case $1 in 13:25:12 + shift 13:25:12 + break 13:25:12 + case $python in 13:25:12 + local pkg_list= 13:25:12 + [[ -d /opt/pyenv ]] 13:25:12 + echo 'Setup pyenv:' 13:25:12 Setup pyenv: 13:25:12 + export PYENV_ROOT=/opt/pyenv 13:25:12 + PYENV_ROOT=/opt/pyenv 13:25:12 + 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 13:25:12 + 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 13:25:12 + pyenv versions 13:25:12 system 13:25:12 3.8.13 13:25:12 3.9.13 13:25:12 3.10.13 13:25:12 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:25:12 + command -v pyenv 13:25:12 ++ pyenv init - --no-rehash 13:25:12 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:25:12 for i in ${!paths[@]}; do 13:25:12 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:25:12 fi; done; 13:25:12 echo "${paths[*]}"'\'')" 13:25:12 export PATH="/opt/pyenv/shims:${PATH}" 13:25:12 export PYENV_SHELL=bash 13:25:12 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:25:12 pyenv() { 13:25:12 local command 13:25:12 command="${1:-}" 13:25:12 if [ "$#" -gt 0 ]; then 13:25:12 shift 13:25:12 fi 13:25:12 13:25:12 case "$command" in 13:25:12 rehash|shell) 13:25:12 eval "$(pyenv "sh-$command" "$@")" 13:25:12 ;; 13:25:12 *) 13:25:12 command pyenv "$command" "$@" 13:25:12 ;; 13:25:12 esac 13:25:12 }' 13:25:12 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:25:12 for i in ${!paths[@]}; do 13:25:12 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:25:12 fi; done; 13:25:12 echo "${paths[*]}"' 13:25:12 ++ 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 13:25:12 ++ 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 13:25:12 ++ 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 13:25:12 ++ export PYENV_SHELL=bash 13:25:12 ++ PYENV_SHELL=bash 13:25:12 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:25:12 +++ complete -F _pyenv pyenv 13:25:12 ++ lf-pyver python3 13:25:12 ++ local py_version_xy=python3 13:25:12 ++ local py_version_xyz= 13:25:12 ++ pyenv versions 13:25:12 ++ local command 13:25:12 ++ command=versions 13:25:12 ++ '[' 1 -gt 0 ']' 13:25:12 ++ shift 13:25:12 ++ case "$command" in 13:25:12 ++ command pyenv versions 13:25:12 ++ awk '{ print $1 }' 13:25:12 ++ pyenv versions 13:25:12 ++ grep -E '^[0-9.]*[0-9]$' 13:25:12 ++ sed 's/^[ *]* //' 13:25:12 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:25:12 +++ grep '^3' /tmp/.pyenv_versions 13:25:12 +++ sort -V 13:25:12 +++ tail -n 1 13:25:12 ++ py_version_xyz=3.11.7 13:25:12 ++ [[ -z 3.11.7 ]] 13:25:12 ++ echo 3.11.7 13:25:12 ++ return 0 13:25:12 + pyenv local 3.11.7 13:25:12 + local command 13:25:12 + command=local 13:25:12 + '[' 2 -gt 0 ']' 13:25:12 + shift 13:25:12 + case "$command" in 13:25:12 + command pyenv local 3.11.7 13:25:12 + pyenv local 3.11.7 13:25:12 + for arg in "$@" 13:25:12 + case $arg in 13:25:12 + pkg_list+='tox ' 13:25:12 + for arg in "$@" 13:25:12 + case $arg in 13:25:12 + pkg_list+='virtualenv ' 13:25:12 + for arg in "$@" 13:25:12 + case $arg in 13:25:12 + pkg_list+='urllib3~=1.26.15 ' 13:25:12 + [[ -f /tmp/.toxenv ]] 13:25:12 ++ cat /tmp/.toxenv 13:25:12 + lf_venv=/tmp/venv-MMmI 13:25:12 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-MMmI from' file:/tmp/.toxenv 13:25:12 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-MMmI from file:/tmp/.toxenv 13:25:12 + /tmp/venv-MMmI/bin/python3 -m pip install --upgrade --quiet pip virtualenv 13:25:13 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:25:13 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 13:25:13 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 13:25:13 + /tmp/venv-MMmI/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 13:25:15 + type python3 13:25:15 + true 13:25:15 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-MMmI/bin to PATH' 13:25:15 lf-activate-venv(): INFO: Adding /tmp/venv-MMmI/bin to PATH 13:25:15 + PATH=/tmp/venv-MMmI/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 13:25:15 + return 0 13:25:15 + [[ -d /opt/pyenv ]] 13:25:15 + echo '---> Setting up pyenv' 13:25:15 ---> Setting up pyenv 13:25:15 + export PYENV_ROOT=/opt/pyenv 13:25:15 + PYENV_ROOT=/opt/pyenv 13:25:15 + export PATH=/opt/pyenv/bin:/tmp/venv-MMmI/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 13:25:15 + PATH=/opt/pyenv/bin:/tmp/venv-MMmI/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 13:25:15 ++ pwd 13:25:15 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 13:25:15 + export PYTHONPATH 13:25:15 + export TOX_TESTENV_PASSENV=PYTHONPATH 13:25:15 + TOX_TESTENV_PASSENV=PYTHONPATH 13:25:15 + tox --version 13:25:15 4.23.2 from /tmp/venv-MMmI/lib/python3.11/site-packages/tox/__init__.py 13:25:15 + PARALLEL=True 13:25:15 + TOX_OPTIONS_LIST= 13:25:15 + [[ -n '' ]] 13:25:15 + case ${PARALLEL,,} in 13:25:15 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 13:25:15 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 13:25:15 + tox --parallel auto --parallel-live 13:25:17 docs: install_deps> python -I -m pip install -r docs/requirements.txt 13:25:17 tests_network: 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 13:25:17 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 13:25:17 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 13:25:22 buildcontroller: freeze> python -m pip freeze --all 13:25:22 tests_network: freeze> python -m pip freeze --all 13:25:22 buildcontroller: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:25:22 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 13:25:23 + update-java-alternatives -l 13:25:23 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 13:25:23 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 13:25:23 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 13:25:23 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 13:25:23 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 13:25:23 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 13:25:23 tests_network: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:25:23 tests_network: OK ✔ in 7.25 seconds 13:25:23 checkbashisms: freeze> python -m pip freeze --all 13:25:23 + java -version 13:25:23 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 13:25:23 + JAVA_VER=21 13:25:23 21 13:25:23 + echo 21 13:25:23 + javac -version 13:25:23 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 13:25:24 checkbashisms: pip==24.3.1,setuptools==75.2.0,wheel==0.44.0 13:25:24 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:25:24 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)' 13:25:24 + JAVAC_VER=21 13:25:24 + echo 21 13:25:24 21 13:25:24 ok, java is 21 or newer 13:25:24 + [ 21 -ge 21 ] 13:25:24 + [ 21 -ge 21 ] 13:25:24 + echo ok, java is 21 or newer 13:25:24 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp 13:25:24 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 13:25:24 2024-10-30 13:25:24 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] 13:25:24 + sudo mkdir -p /opt 13:25:24 + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt 13:25:24 + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven 13:25:24 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 13:25:24 + mvn --version 13:25:24 Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) 13:25:24 Maven home: /opt/maven 13:25:24 Java version: 21.0.4, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 13:25:24 Default locale: en, platform encoding: UTF-8 13:25:24 OS name: "linux", version: "5.4.0-190-generic", arch: "amd64", family: "unix" 13:25:24 NOTE: Picked up JDK_JAVA_OPTIONS: 13:25:24 --add-opens=java.base/java.io=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.lang=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.net=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.nio=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.util=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:25:24 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:25:24 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:25:24 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:25:24 -Xlog:disable 13:25:24 script ./reflectwarn.sh does not appear to have a #! interpreter line; 13:25:24 you may get strange results 13:25:25 checkbashisms: OK ✔ in 2.01 seconds 13:25:25 pre-commit: install_deps> python -I -m pip install pre-commit 13:25:28 pre-commit: freeze> python -m pip freeze --all 13:25:28 pre-commit: cfgv==3.4.0,distlib==0.3.9,filelock==3.16.1,identify==2.6.1,nodeenv==1.9.1,pip==24.3.1,platformdirs==4.3.6,pre_commit==4.0.1,PyYAML==6.0.2,setuptools==75.2.0,virtualenv==20.27.1,wheel==0.44.0 13:25:28 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:25:28 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)' 13:25:28 /usr/bin/cpan 13:25:28 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 13:25:28 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 13:25:28 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 13:25:28 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 13:25:29 [WARNING] repo `https://github.com/pre-commit/pre-commit-hooks` uses deprecated stage names (commit, push) which will be removed in a future version. Hint: often `pre-commit autoupdate --repo https://github.com/pre-commit/pre-commit-hooks` will fix this. if it does not -- consider reporting an issue to that repo. 13:25:29 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 13:25:29 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 13:25:30 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:25:30 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 13:25:31 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 13:25:32 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 13:25:32 [INFO] Once installed this environment will be reused. 13:25:32 [INFO] This may take a few minutes... 13:25:38 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:25:38 [INFO] Once installed this environment will be reused. 13:25:38 [INFO] This may take a few minutes... 13:25:44 docs-linkcheck: freeze> python -m pip freeze --all 13:25:44 docs-linkcheck: alabaster==1.0.0,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.4.0,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.3.1,Pygments==2.18.0,pyparsing==3.2.0,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==75.2.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.1.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.1,sphinx-tabs==3.4.7,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 13:25:44 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 13:25:45 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 13:25:45 [INFO] Once installed this environment will be reused. 13:25:45 [INFO] This may take a few minutes... 13:25:46 docs: freeze> python -m pip freeze --all 13:25:46 docs: alabaster==1.0.0,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.4.0,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.3.1,Pygments==2.18.0,pyparsing==3.2.0,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==75.2.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.1.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.1,sphinx-tabs==3.4.7,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 13:25:46 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 13:25:48 [INFO] Installing environment for https://github.com/perltidy/perltidy. 13:25:48 [INFO] Once installed this environment will be reused. 13:25:48 [INFO] This may take a few minutes... 13:25:49 docs: OK ✔ in 32.99 seconds 13:25:49 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 13:25:52 docs-linkcheck: OK ✔ in 33.27 seconds 13:25:52 pylint: freeze> python -m pip freeze --all 13:25:52 pylint: astroid==3.3.5,dill==0.3.9,isort==5.13.2,mccabe==0.7.0,pip==24.3.1,platformdirs==4.3.6,pylint==3.3.1,setuptools==75.2.0,tomlkit==0.13.2,wheel==0.44.0 13:25:52 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}$' '{}' + 13:26:00 trim trailing whitespace.................................................Passed 13:26:00 Tabs remover.............................................................Passed 13:26:00 autopep8.................................................................Passed 13:26:05 perltidy.................................................................Passed 13:26:06 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 13:26:07 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 13:26:07 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 13:26:07 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 13:26:07 [INFO] Once installed this environment will be reused. 13:26:07 [INFO] This may take a few minutes... 13:26:15 13:26:15 ------------------------------------ 13:26:15 Your code has been rated at 10.00/10 13:26:15 13:26:16 gitlint..................................................................Passed 13:27:03 pylint: OK ✔ in 28.32 seconds 13:27:03 pre-commit: OK ✔ in 52.07 seconds 13:27:03 buildcontroller: OK ✔ in 1 minute 46.26 seconds 13:27:03 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 13:27:03 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 13:27:03 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 13:27:03 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 13:27:09 sims: freeze> python -m pip freeze --all 13:27:09 build_karaf_tests221: freeze> python -m pip freeze --all 13:27:09 build_karaf_tests121: freeze> python -m pip freeze --all 13:27:09 sims: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:27:09 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 13:27:09 Using lighynode version 20.1.0.2 13:27:09 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 13:27:09 build_karaf_tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:27:09 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:27:09 build_karaf_tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:27:09 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:27:09 NOTE: Picked up JDK_JAVA_OPTIONS: 13:27:09 --add-opens=java.base/java.io=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.net=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:27:09 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:27:09 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:27:09 -Xlog:disable 13:27:09 NOTE: Picked up JDK_JAVA_OPTIONS: 13:27:09 --add-opens=java.base/java.io=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.net=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:27:09 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:27:09 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:27:09 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:27:09 -Xlog:disable 13:27:13 sims: OK ✔ in 11.41 seconds 13:27:13 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 13:27:32 build_karaf_tests71: freeze> python -m pip freeze --all 13:27:33 build_karaf_tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:27:33 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:27:33 NOTE: Picked up JDK_JAVA_OPTIONS: 13:27:33 --add-opens=java.base/java.io=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.lang=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.net=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.nio=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.util=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:27:33 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:27:33 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:27:33 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:27:33 -Xlog:disable 13:27:58 build_karaf_tests121: OK ✔ in 56.03 seconds 13:27:58 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 13:28:04 build_karaf_tests221: OK ✔ in 57.15 seconds 13:28:04 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 13:28:04 build_karaf_tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:28:04 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:28:04 NOTE: Picked up JDK_JAVA_OPTIONS: 13:28:04 --add-opens=java.base/java.io=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.lang=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.net=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.nio=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.util=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:28:04 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:28:04 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:28:04 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:28:04 -Xlog:disable 13:28:13 build_karaf_tests71: OK ✔ in 59.26 seconds 13:28:13 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 13:28:19 testsPCE: freeze> python -m pip freeze --all 13:28:20 testsPCE: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,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.54.1,gnpy4tpce==2.4.7,idna==3.10,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==3.0.2,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.5.0,pbr==5.11.1,pillow==11.0.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pyparsing==3.2.0,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 13:28:20 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 13:28:20 pytest -q transportpce_tests/pce/test01_pce.py 13:28:22 tests71: freeze> python -m pip freeze --all 13:28:22 tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:28:22 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 13:28:22 using environment variables from ./karaf71.env 13:28:22 pytest -q transportpce_tests/7.1/test01_portmapping.py 13:29:17 .................. [100%] 13:29:30 12 passed in 67.45s (0:01:07) 13:29:30 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 13:29:32 .......................... [100%] 13:30:20 20 passed in 120.49s (0:02:00) 13:30:20 pytest -q transportpce_tests/pce/test02_pce_400G.py 13:30:22 ........................... [100%] 13:30:59 9 passed in 37.99s 13:30:59 pytest -q transportpce_tests/pce/test03_gnpy.py 13:31:00 .......................... [100%] 13:31:36 8 passed in 37.34s 13:31:36 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 13:31:38 .............. [100%] 13:32:06 62 passed in 156.02s (0:02:36) 13:32:06 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 13:32:07 ... [100%] 13:32:12 3 passed in 35.33s 13:32:12 build_karaf_tests_hybrid: OK ✔ in 53.91 seconds 13:32:12 testsPCE: OK ✔ in 5 minutes 10.25 seconds 13:32:12 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 13:32:19 tests121: freeze> python -m pip freeze --all 13:32:19 tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:32:19 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 13:32:19 using environment variables from ./karaf121.env 13:32:19 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 13:32:46 ................................................ [100%] 13:34:30 48 passed in 143.52s (0:02:23) 13:34:30 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 13:34:54 ...................... [100%] 13:35:42 22 passed in 71.50s (0:01:11) 13:35:42 tests71: OK ✔ in 7 minutes 29.58 seconds 13:35:42 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 13:35:48 tests221: freeze> python -m pip freeze --all 13:35:48 tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 13:35:48 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 13:35:48 using environment variables from ./karaf221.env 13:35:48 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 13:35:59 .FFFFFFFFFFFFFF................................F..... [100%] 13:40:09 35 passed in 260.81s (0:04:20) 13:40:09 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 13:40:39 ...... [100%] 13:40:53 6 passed in 43.53s 13:40:53 pytest -q transportpce_tests/2.2.1/test03_topology.py 13:41:35 .....................F.... [100%] 13:42:24 =================================== FAILURES =================================== 13:42:24 _________ TransportPCEPortMappingTesting.test_02_rdm_device_connected __________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 13:42:24 body = None 13:42:24 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='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 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) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 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')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_02_rdm_device_connected(self): 13:42:24 > response = test_utils.check_device_connection("ROADMA01") 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:53: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:382: in check_device_connection 13:42:24 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 13:42:24 transportpce_tests/common/test_utils.py:116: in get_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 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')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_02_rdm_device_connected 13:42:24 _________ TransportPCEPortMappingTesting.test_03_rdm_portmapping_info __________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info' 13:42:24 body = None 13:42:24 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='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info', query=None, fragment=None) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_03_rdm_portmapping_info(self): 13:42:24 > response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:59: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:483: in get_portmapping_node_attr 13:42:24 response = get_request(target_url) 13:42:24 transportpce_tests/common/test_utils.py:116: in get_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_03_rdm_portmapping_info 13:42:24 _____ TransportPCEPortMappingTesting.test_04_rdm_portmapping_DEG1_TTP_TXRX _____ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=DEG1-TTP-TXRX' 13:42:24 body = None 13:42:24 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='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=DEG1-TTP-TXRX', query=None, fragment=None) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=DEG1-TTP-TXRX' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=DEG1-TTP-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_04_rdm_portmapping_DEG1_TTP_TXRX(self): 13:42:24 > response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "DEG1-TTP-TXRX") 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:72: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:483: in get_portmapping_node_attr 13:42:24 response = get_request(target_url) 13:42:24 transportpce_tests/common/test_utils.py:116: in get_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=DEG1-TTP-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_04_rdm_portmapping_DEG1_TTP_TXRX 13:42:24 _____ TransportPCEPortMappingTesting.test_05_rdm_portmapping_SRG1_PP7_TXRX _____ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG1-PP7-TXRX' 13:42:24 body = None 13:42:24 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='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG1-PP7-TXRX', query=None, fragment=None) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG1-PP7-TXRX' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG1-PP7-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_05_rdm_portmapping_SRG1_PP7_TXRX(self): 13:42:24 > response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG1-PP7-TXRX") 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:81: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:483: in get_portmapping_node_attr 13:42:24 response = get_request(target_url) 13:42:24 transportpce_tests/common/test_utils.py:116: in get_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG1-PP7-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_05_rdm_portmapping_SRG1_PP7_TXRX 13:42:24 _____ TransportPCEPortMappingTesting.test_06_rdm_portmapping_SRG3_PP1_TXRX _____ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG3-PP1-TXRX' 13:42:24 body = None 13:42:24 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='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG3-PP1-TXRX', query=None, fragment=None) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'GET' 13:42:24 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG3-PP1-TXRX' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG3-PP1-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_06_rdm_portmapping_SRG3_PP1_TXRX(self): 13:42:24 > response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG3-PP1-TXRX") 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:90: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:483: in get_portmapping_node_attr 13:42:24 response = get_request(target_url) 13:42:24 transportpce_tests/common/test_utils.py:116: in get_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/mapping=SRG3-PP1-TXRX (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_06_rdm_portmapping_SRG3_PP1_TXRX 13:42:24 ________ TransportPCEPortMappingTesting.test_07_xpdr_device_connection _________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 > sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 13:42:24 raise err 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 address = ('localhost', 8182), timeout = 10, source_address = None 13:42:24 socket_options = [(6, 1, 1)] 13:42:24 13:42:24 def create_connection( 13:42:24 address: tuple[str, int], 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 source_address: tuple[str, int] | None = None, 13:42:24 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 13:42:24 ) -> socket.socket: 13:42:24 """Connect to *address* and return the socket object. 13:42:24 13:42:24 Convenience function. Connect to *address* (a 2-tuple ``(host, 13:42:24 port)``) and return the socket object. Passing the optional 13:42:24 *timeout* parameter will set the timeout on the socket instance 13:42:24 before attempting to connect. If no *timeout* is supplied, the 13:42:24 global default timeout setting returned by :func:`socket.getdefaulttimeout` 13:42:24 is used. If *source_address* is set it must be a tuple of (host, port) 13:42:24 for the socket to bind as a source address before making the connection. 13:42:24 An host of '' or port 0 tells the OS to use the default. 13:42:24 """ 13:42:24 13:42:24 host, port = address 13:42:24 if host.startswith("["): 13:42:24 host = host.strip("[]") 13:42:24 err = None 13:42:24 13:42:24 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 13:42:24 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 13:42:24 # The original create_connection function always returns all records. 13:42:24 family = allowed_gai_family() 13:42:24 13:42:24 try: 13:42:24 host.encode("idna") 13:42:24 except UnicodeError: 13:42:24 raise LocationParseError(f"'{host}', label empty or too long") from None 13:42:24 13:42:24 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 13:42:24 af, socktype, proto, canonname, sa = res 13:42:24 sock = None 13:42:24 try: 13:42:24 sock = socket.socket(af, socktype, proto) 13:42:24 13:42:24 # If provided, set socket level options before connecting. 13:42:24 _set_socket_options(sock, socket_options) 13:42:24 13:42:24 if timeout is not _DEFAULT_TIMEOUT: 13:42:24 sock.settimeout(timeout) 13:42:24 if source_address: 13:42:24 sock.bind(source_address) 13:42:24 > sock.connect(sa) 13:42:24 E ConnectionRefusedError: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 method = 'PUT' 13:42:24 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01' 13:42:24 body = '{"node": [{"node-id": "XPDRA01", "netconf-node-topology:host": "127.0.0.1", "netconf-node-topology:port": "17830", "n...lis": "60000", "netconf-node-topology:max-connection-attempts": "0", "netconf-node-topology:keepalive-delay": "120"}]}' 13:42:24 headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '588', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 13:42:24 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 redirect = False, assert_same_host = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 13:42:24 release_conn = False, chunked = False, body_pos = None, preload_content = False 13:42:24 decode_content = False, response_kw = {} 13:42:24 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01', query=None, fragment=None) 13:42:24 destination_scheme = None, conn = None, release_this_conn = True 13:42:24 http_tunnel_required = False, err = None, clean_exit = False 13:42:24 13:42:24 def urlopen( # type: ignore[override] 13:42:24 self, 13:42:24 method: str, 13:42:24 url: str, 13:42:24 body: _TYPE_BODY | None = None, 13:42:24 headers: typing.Mapping[str, str] | None = None, 13:42:24 retries: Retry | bool | int | None = None, 13:42:24 redirect: bool = True, 13:42:24 assert_same_host: bool = True, 13:42:24 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:24 pool_timeout: int | None = None, 13:42:24 release_conn: bool | None = None, 13:42:24 chunked: bool = False, 13:42:24 body_pos: _TYPE_BODY_POSITION | None = None, 13:42:24 preload_content: bool = True, 13:42:24 decode_content: bool = True, 13:42:24 **response_kw: typing.Any, 13:42:24 ) -> BaseHTTPResponse: 13:42:24 """ 13:42:24 Get a connection from the pool and perform an HTTP request. This is the 13:42:24 lowest level call for making a request, so you'll need to specify all 13:42:24 the raw details. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 More commonly, it's appropriate to use a convenience method 13:42:24 such as :meth:`request`. 13:42:24 13:42:24 .. note:: 13:42:24 13:42:24 `release_conn` will only behave as expected if 13:42:24 `preload_content=False` because we want to make 13:42:24 `preload_content=False` the default behaviour someday soon without 13:42:24 breaking backwards compatibility. 13:42:24 13:42:24 :param method: 13:42:24 HTTP request method (such as GET, POST, PUT, etc.) 13:42:24 13:42:24 :param url: 13:42:24 The URL to perform the request on. 13:42:24 13:42:24 :param body: 13:42:24 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:24 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:24 13:42:24 :param headers: 13:42:24 Dictionary of custom headers to send, such as User-Agent, 13:42:24 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:24 these headers completely replace any pool-specific headers. 13:42:24 13:42:24 :param retries: 13:42:24 Configure the number of retries to allow before raising a 13:42:24 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:24 13:42:24 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 13:42:24 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:24 over different types of retries. 13:42:24 Pass an integer number to retry connection errors that many times, 13:42:24 but no other types of errors. Pass zero to never retry. 13:42:24 13:42:24 If ``False``, then retries are disabled and any exception is raised 13:42:24 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:24 the redirect response will be returned. 13:42:24 13:42:24 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:24 13:42:24 :param redirect: 13:42:24 If True, automatically handle redirects (status codes 301, 302, 13:42:24 303, 307, 308). Each redirect counts as a retry. Disabling retries 13:42:24 will disable redirect, too. 13:42:24 13:42:24 :param assert_same_host: 13:42:24 If ``True``, will make sure that the host of the pool requests is 13:42:24 consistent else will raise HostChangedError. When ``False``, you can 13:42:24 use the pool on an HTTP proxy and request foreign hosts. 13:42:24 13:42:24 :param timeout: 13:42:24 If specified, overrides the default timeout for this one 13:42:24 request. It may be a float (in seconds) or an instance of 13:42:24 :class:`urllib3.util.Timeout`. 13:42:24 13:42:24 :param pool_timeout: 13:42:24 If set and the pool is set to block=True, then this method will 13:42:24 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 13:42:24 connection is available within the time period. 13:42:24 13:42:24 :param bool preload_content: 13:42:24 If True, the response's body will be preloaded into memory. 13:42:24 13:42:24 :param bool decode_content: 13:42:24 If True, will attempt to decode the body based on the 13:42:24 'content-encoding' header. 13:42:24 13:42:24 :param release_conn: 13:42:24 If False, then the urlopen call will not release the connection 13:42:24 back into the pool once a response is received (but will release if 13:42:24 you read the entire contents of the response such as when 13:42:24 `preload_content=True`). This is useful if you're not preloading 13:42:24 the response's content immediately. You will need to call 13:42:24 ``r.release_conn()`` on the response ``r`` to return the connection 13:42:24 back into the pool. If None, it takes the value of ``preload_content`` 13:42:24 which defaults to ``True``. 13:42:24 13:42:24 :param bool chunked: 13:42:24 If True, urllib3 will send the body using chunked transfer 13:42:24 encoding. Otherwise, urllib3 will send the body using the standard 13:42:24 content-length form. Defaults to False. 13:42:24 13:42:24 :param int body_pos: 13:42:24 Position to seek to in file-like body in the event of a retry or 13:42:24 redirect. Typically this won't need to be set because urllib3 will 13:42:24 auto-populate the value when needed. 13:42:24 """ 13:42:24 parsed_url = parse_url(url) 13:42:24 destination_scheme = parsed_url.scheme 13:42:24 13:42:24 if headers is None: 13:42:24 headers = self.headers 13:42:24 13:42:24 if not isinstance(retries, Retry): 13:42:24 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 13:42:24 13:42:24 if release_conn is None: 13:42:24 release_conn = preload_content 13:42:24 13:42:24 # Check host 13:42:24 if assert_same_host and not self.is_same_host(url): 13:42:24 raise HostChangedError(self, url, retries) 13:42:24 13:42:24 # Ensure that the URL we're connecting to is properly encoded 13:42:24 if url.startswith("/"): 13:42:24 url = to_str(_encode_target(url)) 13:42:24 else: 13:42:24 url = to_str(parsed_url.url) 13:42:24 13:42:24 conn = None 13:42:24 13:42:24 # Track whether `conn` needs to be released before 13:42:24 # returning/raising/recursing. Update this variable if necessary, and 13:42:24 # leave `release_conn` constant throughout the function. That way, if 13:42:24 # the function recurses, the original value of `release_conn` will be 13:42:24 # passed down into the recursive call, and its value will be respected. 13:42:24 # 13:42:24 # See issue #651 [1] for details. 13:42:24 # 13:42:24 # [1] 13:42:24 release_this_conn = release_conn 13:42:24 13:42:24 http_tunnel_required = connection_requires_http_tunnel( 13:42:24 self.proxy, self.proxy_config, destination_scheme 13:42:24 ) 13:42:24 13:42:24 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 13:42:24 # have to copy the headers dict so we can safely change it without those 13:42:24 # changes being reflected in anyone else's copy. 13:42:24 if not http_tunnel_required: 13:42:24 headers = headers.copy() # type: ignore[attr-defined] 13:42:24 headers.update(self.proxy_headers) # type: ignore[union-attr] 13:42:24 13:42:24 # Must keep the exception bound to a separate variable or else Python 3 13:42:24 # complains about UnboundLocalError. 13:42:24 err = None 13:42:24 13:42:24 # Keep track of whether we cleanly exited the except block. This 13:42:24 # ensures we do proper cleanup in finally. 13:42:24 clean_exit = False 13:42:24 13:42:24 # Rewind body position, if needed. Record current position 13:42:24 # for future rewinds in the event of a redirect/retry. 13:42:24 body_pos = set_file_position(body, body_pos) 13:42:24 13:42:24 try: 13:42:24 # Request a connection from the queue. 13:42:24 timeout_obj = self._get_timeout(timeout) 13:42:24 conn = self._get_conn(timeout=pool_timeout) 13:42:24 13:42:24 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 13:42:24 13:42:24 # Is this a closed/new connection that requires CONNECT tunnelling? 13:42:24 if self.proxy is not None and http_tunnel_required and conn.is_closed: 13:42:24 try: 13:42:24 self._prepare_proxy(conn) 13:42:24 except (BaseSSLError, OSError, SocketTimeout) as e: 13:42:24 self._raise_timeout( 13:42:24 err=e, url=self.proxy.url, timeout_value=conn.timeout 13:42:24 ) 13:42:24 raise 13:42:24 13:42:24 # If we're going to release the connection in ``finally:``, then 13:42:24 # the response doesn't need to know about the connection. Otherwise 13:42:24 # it will also try to release it and we'll have a double-release 13:42:24 # mess. 13:42:24 response_conn = conn if not release_conn else None 13:42:24 13:42:24 # Make the request on the HTTPConnection object 13:42:24 > response = self._make_request( 13:42:24 conn, 13:42:24 method, 13:42:24 url, 13:42:24 timeout=timeout_obj, 13:42:24 body=body, 13:42:24 headers=headers, 13:42:24 chunked=chunked, 13:42:24 retries=retries, 13:42:24 response_conn=response_conn, 13:42:24 preload_content=preload_content, 13:42:24 decode_content=decode_content, 13:42:24 **response_kw, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 13:42:24 conn.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 13:42:24 self.endheaders() 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 13:42:24 self._send_output(message_body, encode_chunked=encode_chunked) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 13:42:24 self.send(msg) 13:42:24 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 13:42:24 self.connect() 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 13:42:24 self.sock = self._new_conn() 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def _new_conn(self) -> socket.socket: 13:42:24 """Establish a socket connection and set nodelay settings on it. 13:42:24 13:42:24 :return: New socket connection. 13:42:24 """ 13:42:24 try: 13:42:24 sock = connection.create_connection( 13:42:24 (self._dns_host, self.port), 13:42:24 self.timeout, 13:42:24 source_address=self.source_address, 13:42:24 socket_options=self.socket_options, 13:42:24 ) 13:42:24 except socket.gaierror as e: 13:42:24 raise NameResolutionError(self.host, self, e) from e 13:42:24 except SocketTimeout as e: 13:42:24 raise ConnectTimeoutError( 13:42:24 self, 13:42:24 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 13:42:24 ) from e 13:42:24 13:42:24 except OSError as e: 13:42:24 > raise NewConnectionError( 13:42:24 self, f"Failed to establish a new connection: {e}" 13:42:24 ) from e 13:42:24 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 13:42:24 13:42:24 The above exception was the direct cause of the following exception: 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 > resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 13:42:24 retries = retries.increment( 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:24 method = 'PUT' 13:42:24 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01' 13:42:24 response = None 13:42:24 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 13:42:24 _pool = 13:42:24 _stacktrace = 13:42:24 13:42:24 def increment( 13:42:24 self, 13:42:24 method: str | None = None, 13:42:24 url: str | None = None, 13:42:24 response: BaseHTTPResponse | None = None, 13:42:24 error: Exception | None = None, 13:42:24 _pool: ConnectionPool | None = None, 13:42:24 _stacktrace: TracebackType | None = None, 13:42:24 ) -> Self: 13:42:24 """Return a new Retry object with incremented retry counters. 13:42:24 13:42:24 :param response: A response object, or None, if the server did not 13:42:24 return a response. 13:42:24 :type response: :class:`~urllib3.response.BaseHTTPResponse` 13:42:24 :param Exception error: An error encountered during the request, or 13:42:24 None if the response was received successfully. 13:42:24 13:42:24 :return: A new ``Retry`` object. 13:42:24 """ 13:42:24 if self.total is False and error: 13:42:24 # Disabled, indicate to re-raise the error. 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 13:42:24 total = self.total 13:42:24 if total is not None: 13:42:24 total -= 1 13:42:24 13:42:24 connect = self.connect 13:42:24 read = self.read 13:42:24 redirect = self.redirect 13:42:24 status_count = self.status 13:42:24 other = self.other 13:42:24 cause = "unknown" 13:42:24 status = None 13:42:24 redirect_location = None 13:42:24 13:42:24 if error and self._is_connection_error(error): 13:42:24 # Connect retry? 13:42:24 if connect is False: 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif connect is not None: 13:42:24 connect -= 1 13:42:24 13:42:24 elif error and self._is_read_error(error): 13:42:24 # Read retry? 13:42:24 if read is False or method is None or not self._is_method_retryable(method): 13:42:24 raise reraise(type(error), error, _stacktrace) 13:42:24 elif read is not None: 13:42:24 read -= 1 13:42:24 13:42:24 elif error: 13:42:24 # Other retry? 13:42:24 if other is not None: 13:42:24 other -= 1 13:42:24 13:42:24 elif response and response.get_redirect_location(): 13:42:24 # Redirect retry? 13:42:24 if redirect is not None: 13:42:24 redirect -= 1 13:42:24 cause = "too many redirects" 13:42:24 response_redirect_location = response.get_redirect_location() 13:42:24 if response_redirect_location: 13:42:24 redirect_location = response_redirect_location 13:42:24 status = response.status 13:42:24 13:42:24 else: 13:42:24 # Incrementing because of a server error like a 500 in 13:42:24 # status_forcelist and the given method is in the allowed_methods 13:42:24 cause = ResponseError.GENERIC_ERROR 13:42:24 if response and response.status: 13:42:24 if status_count is not None: 13:42:24 status_count -= 1 13:42:24 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 13:42:24 status = response.status 13:42:24 13:42:24 history = self.history + ( 13:42:24 RequestHistory(method, url, error, status, redirect_location), 13:42:24 ) 13:42:24 13:42:24 new_retry = self.new( 13:42:24 total=total, 13:42:24 connect=connect, 13:42:24 read=read, 13:42:24 redirect=redirect, 13:42:24 status=status_count, 13:42:24 other=other, 13:42:24 history=history, 13:42:24 ) 13:42:24 13:42:24 if new_retry.is_exhausted(): 13:42:24 reason = error or ResponseError(cause) 13:42:24 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 13:42:24 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 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 13:42:24 13:42:24 During handling of the above exception, another exception occurred: 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_07_xpdr_device_connection(self): 13:42:24 > response = test_utils.mount_device("XPDRA01", ('xpdra', self.NODE_VERSION)) 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:99: 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 transportpce_tests/common/test_utils.py:357: in mount_device 13:42:24 response = put_request(url[RESTCONF_VERSION].format('{}', node), body) 13:42:24 transportpce_tests/common/test_utils.py:124: in put_request 13:42:24 return requests.request( 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:24 return session.request(method=method, url=url, **kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:24 resp = self.send(prep, **send_kwargs) 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:24 r = adapter.send(request, **kwargs) 13:42:24 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:24 13:42:24 self = 13:42:24 request = , stream = False 13:42:24 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 13:42:24 proxies = OrderedDict() 13:42:24 13:42:24 def send( 13:42:24 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:24 ): 13:42:24 """Sends PreparedRequest object. Returns Response object. 13:42:24 13:42:24 :param request: The :class:`PreparedRequest ` being sent. 13:42:24 :param stream: (optional) Whether to stream the request content. 13:42:24 :param timeout: (optional) How long to wait for the server to send 13:42:24 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:24 read timeout) ` tuple. 13:42:24 :type timeout: float or tuple or urllib3 Timeout object 13:42:24 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:24 we verify the server's TLS certificate, or a string, in which case it 13:42:24 must be a path to a CA bundle to use 13:42:24 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:24 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:24 :rtype: requests.Response 13:42:24 """ 13:42:24 13:42:24 try: 13:42:24 conn = self.get_connection_with_tls_context( 13:42:24 request, verify, proxies=proxies, cert=cert 13:42:24 ) 13:42:24 except LocationValueError as e: 13:42:24 raise InvalidURL(e, request=request) 13:42:24 13:42:24 self.cert_verify(conn, request.url, verify, cert) 13:42:24 url = self.request_url(request, proxies) 13:42:24 self.add_headers( 13:42:24 request, 13:42:24 stream=stream, 13:42:24 timeout=timeout, 13:42:24 verify=verify, 13:42:24 cert=cert, 13:42:24 proxies=proxies, 13:42:24 ) 13:42:24 13:42:24 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:24 13:42:24 if isinstance(timeout, tuple): 13:42:24 try: 13:42:24 connect, read = timeout 13:42:24 timeout = TimeoutSauce(connect=connect, read=read) 13:42:24 except ValueError: 13:42:24 raise ValueError( 13:42:24 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:24 f"or a single float to set both timeouts to the same value." 13:42:24 ) 13:42:24 elif isinstance(timeout, TimeoutSauce): 13:42:24 pass 13:42:24 else: 13:42:24 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:24 13:42:24 try: 13:42:24 resp = conn.urlopen( 13:42:24 method=request.method, 13:42:24 url=url, 13:42:24 body=request.body, 13:42:24 headers=request.headers, 13:42:24 redirect=False, 13:42:24 assert_same_host=False, 13:42:24 preload_content=False, 13:42:24 decode_content=False, 13:42:24 retries=self.max_retries, 13:42:24 timeout=timeout, 13:42:24 chunked=chunked, 13:42:24 ) 13:42:24 13:42:24 except (ProtocolError, OSError) as err: 13:42:24 raise ConnectionError(err, request=request) 13:42:24 13:42:24 except MaxRetryError as e: 13:42:24 if isinstance(e.reason, ConnectTimeoutError): 13:42:24 # TODO: Remove this in 3.0.0: see #2811 13:42:24 if not isinstance(e.reason, NewConnectionError): 13:42:24 raise ConnectTimeout(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, ResponseError): 13:42:24 raise RetryError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _ProxyError): 13:42:24 raise ProxyError(e, request=request) 13:42:24 13:42:24 if isinstance(e.reason, _SSLError): 13:42:24 # This branch is for urllib3 v1.22 and later. 13:42:24 raise SSLError(e, request=request) 13:42:24 13:42:24 > raise ConnectionError(e, request=request) 13:42:24 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 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 13:42:24 13:42:24 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_07_xpdr_device_connection 13:42:24 _________ TransportPCEPortMappingTesting.test_08_xpdr_device_connected _________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_08_xpdr_device_connected(self): 13:42:24 response = test_utils.check_device_connection("XPDRA01") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:104: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_08_xpdr_device_connected 13:42:24 _________ TransportPCEPortMappingTesting.test_09_xpdr_portmapping_info _________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_09_xpdr_portmapping_info(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:110: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_09_xpdr_portmapping_info 13:42:24 _______ TransportPCEPortMappingTesting.test_10_xpdr_portmapping_NETWORK1 _______ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_10_xpdr_portmapping_NETWORK1(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK1") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:123: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_10_xpdr_portmapping_NETWORK1 13:42:24 _______ TransportPCEPortMappingTesting.test_11_xpdr_portmapping_NETWORK2 _______ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_11_xpdr_portmapping_NETWORK2(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK2") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:134: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_11_xpdr_portmapping_NETWORK2 13:42:24 _______ TransportPCEPortMappingTesting.test_12_xpdr_portmapping_CLIENT1 ________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_12_xpdr_portmapping_CLIENT1(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT1") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:145: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_12_xpdr_portmapping_CLIENT1 13:42:24 _______ TransportPCEPortMappingTesting.test_13_xpdr_portmapping_CLIENT2 ________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_13_xpdr_portmapping_CLIENT2(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT2") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:157: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_13_xpdr_portmapping_CLIENT2 13:42:24 _______ TransportPCEPortMappingTesting.test_14_xpdr_portmapping_CLIENT3 ________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_14_xpdr_portmapping_CLIENT3(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT3") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:169: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_14_xpdr_portmapping_CLIENT3 13:42:24 _______ TransportPCEPortMappingTesting.test_15_xpdr_portmapping_CLIENT4 ________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_15_xpdr_portmapping_CLIENT4(self): 13:42:24 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT4") 13:42:24 > self.assertEqual(response['status_code'], requests.codes.ok) 13:42:24 E AssertionError: 409 != 200 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:181: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_15_xpdr_portmapping_CLIENT4 13:42:24 _______ TransportPCEPortMappingTesting.test_16_xpdr_device_disconnection _______ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_16_xpdr_device_disconnection(self): 13:42:24 response = test_utils.unmount_device("XPDRA01") 13:42:24 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 13:42:24 E AssertionError: 409 not found in (200, 204) 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:192: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_16_xpdr_device_disconnection 13:42:24 Searching for pattern 'onDeviceDisConnected:\ XPDRA01' in karaf.log... Pattern not found after 180 seconds! Node XPDRA01 still not deleted from tpce topology... 13:42:24 _______ TransportPCEPortMappingTesting.test_19_rdm_device_disconnection ________ 13:42:24 13:42:24 self = 13:42:24 13:42:24 def test_19_rdm_device_disconnection(self): 13:42:24 response = test_utils.unmount_device("ROADMA01") 13:42:24 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 13:42:24 E AssertionError: 409 not found in (200, 204) 13:42:24 13:42:24 transportpce_tests/1.2.1/test01_portmapping.py:212: AssertionError 13:42:24 ----------------------------- Captured stdout call ----------------------------- 13:42:24 execution of test_19_rdm_device_disconnection 13:42:24 Searching for pattern 'onDeviceDisConnected:\ ROADMA01' in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not deleted from tpce topology... 13:42:24 =========================== short test summary info ============================ 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_02_rdm_device_connected 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_03_rdm_portmapping_info 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_04_rdm_portmapping_DEG1_TTP_TXRX 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_05_rdm_portmapping_SRG1_PP7_TXRX 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_06_rdm_portmapping_SRG3_PP1_TXRX 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_07_xpdr_device_connection 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_08_xpdr_device_connected 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_09_xpdr_portmapping_info 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_10_xpdr_portmapping_NETWORK1 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_11_xpdr_portmapping_NETWORK2 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_12_xpdr_portmapping_CLIENT1 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_13_xpdr_portmapping_CLIENT2 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_14_xpdr_portmapping_CLIENT3 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_15_xpdr_portmapping_CLIENT4 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_16_xpdr_device_disconnection 13:42:24 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_19_rdm_device_disconnection 13:42:24 16 failed, 5 passed in 604.51s (0:10:04) 13:42:24 tests121: exit 1 (604.89 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=35584 13:42:25 ..................... [100%] 13:43:09 44 passed in 136.30s (0:02:16) 13:43:09 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 13:43:43 ............ [100%] 13:44:08 12 passed in 57.98s 13:44:08 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 13:44:32 ................ [100%] 13:46:01 16 passed in 113.44s (0:01:53) 13:46:01 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 13:46:31 ............................... [100%] 13:46:37 31 passed in 35.89s 13:46:37 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 13:47:12 .......................... [100%] 13:48:08 26 passed in 90.00s (0:01:30) 13:48:08 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 13:48:43 ...................... [100%] 13:49:47 22 passed in 98.80s (0:01:38) 13:49:47 pytest -q transportpce_tests/2.2.1/test09_olm.py 13:50:27 ........................................ [100%] 13:52:49 40 passed in 181.89s (0:03:01) 13:52:49 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 13:53:31 ........................................................................ [ 74%] 13:59:07 ......................... [100%] 14:00:59 97 passed in 490.35s (0:08:10) 14:00:59 pytest -q transportpce_tests/2.2.1/test12_end2end.py 14:01:40 ...................................................... [100%] 14:08:27 54 passed in 447.18s (0:07:27) 14:08:27 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 14:09:21 ........................................................................ [ 71%] 14:14:29 ............................. [100%] 14:16:38 101 passed in 491.08s (0:08:11) 14:16:38 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 14:17:31 ........................................................................ [ 67%] 14:23:17 ................................... [100%] 14:29:37 107 passed in 779.15s (0:12:59) 14:29:38 tests121: FAIL ✖ in 10 minutes 12.37 seconds 14:29:38 tests221: OK ✔ in 53 minutes 55.69 seconds 14:29:38 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 14:29:43 tests_hybrid: freeze> python -m pip freeze --all 14:29:43 tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 14:29:43 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 14:29:43 using environment variables from ./karaf121.env 14:29:43 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 14:30:28 ................................................... [100%] 14:32:14 51 passed in 150.98s (0:02:30) 14:32:14 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 14:32:56 ........................................................................ [ 66%] 14:37:16 ..................................... [100%] 14:39:22 109 passed in 427.97s (0:07:07) 14:39:22 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 14:40:10 ..................................................... [100%] 14:43:42 53 passed in 259.31s (0:04:19) 14:43:43 tests_hybrid: OK ✔ in 14 minutes 4.52 seconds 14:43:43 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 14:43:43 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 14:43:48 buildlighty: freeze> python -m pip freeze --all 14:43:48 tests_tapi: freeze> python -m pip freeze --all 14:43:49 buildlighty: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 14:43:49 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 14:43:49 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 14:43:49 tests_tapi: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 14:43:49 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 14:43:49 using environment variables from ./karaf221.env 14:43:49 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 14:44:06 [ERROR] COMPILATION ERROR : 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 14:44:06 symbol: class YangModuleInfo 14:44:06 location: package org.opendaylight.yangtools.binding 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 14:44:06 symbol: class YangModuleInfo 14:44:06 location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 14:44:06 symbol: class YangModuleInfo 14:44:06 location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 14:44:06 symbol: class YangModuleInfo 14:44:06 location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [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: 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 14:44:06 [ERROR] symbol: class YangModuleInfo 14:44:06 [ERROR] location: package org.opendaylight.yangtools.binding 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 14:44:06 [ERROR] symbol: class YangModuleInfo 14:44:06 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 14:44:06 [ERROR] symbol: class YangModuleInfo 14:44:06 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 14:44:06 [ERROR] symbol: class YangModuleInfo 14:44:06 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 14:44:06 [ERROR] -> [Help 1] 14:44:06 [ERROR] 14:44:06 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 14:44:06 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 14:44:06 [ERROR] 14:44:06 [ERROR] For more information about the errors and possible solutions, please read the following articles: 14:44:06 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException 14:44:07 unzip: cannot find or open target/tpce-bin.zip, target/tpce-bin.zip.zip or target/tpce-bin.zip.ZIP. 14:44:07 buildlighty: exit 9 (17.87 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh pid=56619 14:44:07 buildlighty: command failed but is marked ignore outcome so handling it as success 14:45:13 .................................................. [100%] 14:47:09 50 passed in 199.95s (0:03:19) 14:47:09 pytest -q transportpce_tests/tapi/test02_full_topology.py 14:48:13 .............................. [100%] 14:54:41 30 passed in 451.58s (0:07:31) 14:54:41 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 14:55:43 ...................................................................... [100%] 14:59:14 70 passed in 273.51s (0:04:33) 14:59:15 pytest -q transportpce_tests/tapi/test04_topo_extension.py 15:00:19 ................... [100%] 15:01:33 19 passed in 138.73s (0:02:18) 15:01:34 buildlighty: OK ✔ in 24.57 seconds 15:01:34 buildcontroller: OK (106.26=setup[7.22]+cmd[99.03] seconds) 15:01:34 testsPCE: OK (310.25=setup[78.01]+cmd[232.24] seconds) 15:01:34 sims: OK (11.40=setup[7.38]+cmd[4.02] seconds) 15:01:34 build_karaf_tests121: OK (56.02=setup[7.42]+cmd[48.60] seconds) 15:01:34 tests121: FAIL code 1 (612.37=setup[7.47]+cmd[604.89] seconds) 15:01:34 build_karaf_tests221: OK (57.15=setup[7.40]+cmd[49.75] seconds) 15:01:34 tests_tapi: OK (1071.54=setup[6.77]+cmd[1064.77] seconds) 15:01:34 tests_network: OK (7.25 seconds) 15:01:34 tests221: OK (3235.69=setup[6.17]+cmd[3229.52] seconds) 15:01:34 build_karaf_tests71: OK (59.26=setup[19.74]+cmd[39.52] seconds) 15:01:34 tests71: OK (449.58=setup[10.14]+cmd[439.43] seconds) 15:01:34 build_karaf_tests_hybrid: OK (53.91=setup[6.29]+cmd[47.61] seconds) 15:01:34 tests_hybrid: OK (844.52=setup[5.55]+cmd[838.97] seconds) 15:01:34 buildlighty: OK (24.57=setup[6.70]+cmd[17.87] seconds) 15:01:34 docs: OK (32.99=setup[30.89]+cmd[2.10] seconds) 15:01:34 docs-linkcheck: OK (33.27=setup[28.99]+cmd[4.28] seconds) 15:01:34 checkbashisms: OK (2.00=setup[1.13]+cmd[0.00,0.06,0.82] seconds) 15:01:34 pre-commit: OK (52.07=setup[3.53]+cmd[0.01,0.01,38.31,10.22] seconds) 15:01:34 pylint: OK (28.32=setup[3.73]+cmd[24.59] seconds) 15:01:34 evaluation failed :( (5778.33 seconds) 15:01:34 + tox_status=255 15:01:34 + echo '---> Completed tox runs' 15:01:34 ---> Completed tox runs 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/build_karaf_tests121/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=build_karaf_tests121 15:01:34 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/build_karaf_tests221/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=build_karaf_tests221 15:01:34 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/build_karaf_tests71/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=build_karaf_tests71 15:01:34 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/build_karaf_tests_hybrid/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=build_karaf_tests_hybrid 15:01:34 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/buildcontroller/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=buildcontroller 15:01:34 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/buildlighty/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=buildlighty 15:01:34 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/checkbashisms/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=checkbashisms 15:01:34 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/docs-linkcheck/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=docs-linkcheck 15:01:34 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/docs/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=docs 15:01:34 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/pre-commit/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=pre-commit 15:01:34 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/pylint/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=pylint 15:01:34 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/sims/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=sims 15:01:34 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests121/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests121 15:01:34 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests221/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests221 15:01:34 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests71/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests71 15:01:34 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/testsPCE/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=testsPCE 15:01:34 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests_hybrid/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests_hybrid 15:01:34 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests_network/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests_network 15:01:34 + cp -r .tox/tests_network/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_network 15:01:34 + for i in .tox/*/log 15:01:34 ++ echo .tox/tests_tapi/log 15:01:34 ++ awk -F/ '{print $2}' 15:01:34 + tox_env=tests_tapi 15:01:34 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 15:01:34 + DOC_DIR=docs/_build/html 15:01:34 + [[ -d docs/_build/html ]] 15:01:34 + echo '---> Archiving generated docs' 15:01:34 ---> Archiving generated docs 15:01:34 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 15:01:34 + echo '---> tox-run.sh ends' 15:01:34 ---> tox-run.sh ends 15:01:34 + test 255 -eq 0 15:01:34 + exit 255 15:01:34 ++ '[' 1 = 1 ']' 15:01:34 ++ '[' -x /usr/bin/clear_console ']' 15:01:34 ++ /usr/bin/clear_console -q 15:01:34 Build step 'Execute shell' marked build as failure 15:01:34 $ ssh-agent -k 15:01:34 unset SSH_AUTH_SOCK; 15:01:34 unset SSH_AGENT_PID; 15:01:34 echo Agent pid 12417 killed; 15:01:34 [ssh-agent] Stopped. 15:01:34 [PostBuildScript] - [INFO] Executing post build scripts. 15:01:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9059377683029943141.sh 15:01:34 ---> sysstat.sh 15:01:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10468742586705592.sh 15:01:35 ---> package-listing.sh 15:01:35 ++ facter osfamily 15:01:35 ++ tr '[:upper:]' '[:lower:]' 15:01:35 + OS_FAMILY=debian 15:01:35 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 15:01:35 + START_PACKAGES=/tmp/packages_start.txt 15:01:35 + END_PACKAGES=/tmp/packages_end.txt 15:01:35 + DIFF_PACKAGES=/tmp/packages_diff.txt 15:01:35 + PACKAGES=/tmp/packages_start.txt 15:01:35 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 15:01:35 + PACKAGES=/tmp/packages_end.txt 15:01:35 + case "${OS_FAMILY}" in 15:01:35 + dpkg -l 15:01:35 + grep '^ii' 15:01:35 + '[' -f /tmp/packages_start.txt ']' 15:01:35 + '[' -f /tmp/packages_end.txt ']' 15:01:35 + diff /tmp/packages_start.txt /tmp/packages_end.txt 15:01:35 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 15:01:35 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 15:01:35 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 15:01:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15353760137405756791.sh 15:01:35 ---> capture-instance-metadata.sh 15:01:35 Setup pyenv: 15:01:35 system 15:01:35 3.8.13 15:01:35 3.9.13 15:01:35 3.10.13 15:01:35 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:01:35 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-WCHm from file:/tmp/.os_lf_venv 15:01:36 lf-activate-venv(): INFO: Installing: lftools 15:01:48 lf-activate-venv(): INFO: Adding /tmp/venv-WCHm/bin to PATH 15:01:48 INFO: Running in OpenStack, capturing instance metadata 15:01:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7756093862052703489.sh 15:01:48 provisioning config files... 15:01:49 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #2131 15:01:49 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config4743200119364623647tmp 15:01:49 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 15:01:49 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 15:01:49 provisioning config files... 15:01:49 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 15:01:49 [EnvInject] - Injecting environment variables from a build step. 15:01:49 [EnvInject] - Injecting as environment variables the properties content 15:01:49 SERVER_ID=logs 15:01:49 15:01:49 [EnvInject] - Variables injected successfully. 15:01:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10011281277545215250.sh 15:01:49 ---> create-netrc.sh 15:01:49 WARN: Log server credential not found. 15:01:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17039430609350926365.sh 15:01:49 ---> python-tools-install.sh 15:01:49 Setup pyenv: 15:01:49 system 15:01:49 3.8.13 15:01:49 3.9.13 15:01:49 3.10.13 15:01:49 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:01:49 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-WCHm from file:/tmp/.os_lf_venv 15:01:50 lf-activate-venv(): INFO: Installing: lftools 15:01:59 lf-activate-venv(): INFO: Adding /tmp/venv-WCHm/bin to PATH 15:01:59 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12214514577446855828.sh 15:01:59 ---> sudo-logs.sh 15:01:59 Archiving 'sudo' log.. 15:01:59 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4730439590838969311.sh 15:01:59 ---> job-cost.sh 15:01:59 Setup pyenv: 15:02:00 system 15:02:00 3.8.13 15:02:00 3.9.13 15:02:00 3.10.13 15:02:00 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:02:00 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-WCHm from file:/tmp/.os_lf_venv 15:02:01 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 15:02:05 lf-activate-venv(): INFO: Adding /tmp/venv-WCHm/bin to PATH 15:02:05 INFO: No Stack... 15:02:05 INFO: Retrieving Pricing Info for: v3-standard-4 15:02:06 INFO: Archiving Costs 15:02:06 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins9616392634113289669.sh 15:02:06 ---> logs-deploy.sh 15:02:06 Setup pyenv: 15:02:06 system 15:02:06 3.8.13 15:02:06 3.9.13 15:02:06 3.10.13 15:02:06 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:02:06 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-WCHm from file:/tmp/.os_lf_venv 15:02:07 lf-activate-venv(): INFO: Installing: lftools 15:02:15 lf-activate-venv(): INFO: Adding /tmp/venv-WCHm/bin to PATH 15:02:15 WARNING: Nexus logging server not set 15:02:15 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/2131/ 15:02:15 INFO: archiving logs to S3 15:02:17 ---> uname -a: 15:02:17 Linux prd-ubuntu2004-docker-4c-16g-2872 5.4.0-190-generic #210-Ubuntu SMP Fri Jul 5 17:03:38 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 15:02:17 15:02:17 15:02:17 ---> lscpu: 15:02:17 Architecture: x86_64 15:02:17 CPU op-mode(s): 32-bit, 64-bit 15:02:17 Byte Order: Little Endian 15:02:17 Address sizes: 40 bits physical, 48 bits virtual 15:02:17 CPU(s): 4 15:02:17 On-line CPU(s) list: 0-3 15:02:17 Thread(s) per core: 1 15:02:17 Core(s) per socket: 1 15:02:17 Socket(s): 4 15:02:17 NUMA node(s): 1 15:02:17 Vendor ID: AuthenticAMD 15:02:17 CPU family: 23 15:02:17 Model: 49 15:02:17 Model name: AMD EPYC-Rome Processor 15:02:17 Stepping: 0 15:02:17 CPU MHz: 2799.996 15:02:17 BogoMIPS: 5599.99 15:02:17 Virtualization: AMD-V 15:02:17 Hypervisor vendor: KVM 15:02:17 Virtualization type: full 15:02:17 L1d cache: 128 KiB 15:02:17 L1i cache: 128 KiB 15:02:17 L2 cache: 2 MiB 15:02:17 L3 cache: 64 MiB 15:02:17 NUMA node0 CPU(s): 0-3 15:02:17 Vulnerability Gather data sampling: Not affected 15:02:17 Vulnerability Itlb multihit: Not affected 15:02:17 Vulnerability L1tf: Not affected 15:02:17 Vulnerability Mds: Not affected 15:02:17 Vulnerability Meltdown: Not affected 15:02:17 Vulnerability Mmio stale data: Not affected 15:02:17 Vulnerability Retbleed: Vulnerable 15:02:17 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 15:02:17 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 15:02:17 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 15:02:17 Vulnerability Srbds: Not affected 15:02:17 Vulnerability Tsx async abort: Not affected 15:02:17 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 15:02:17 15:02:17 15:02:17 ---> nproc: 15:02:17 4 15:02:17 15:02:17 15:02:17 ---> df -h: 15:02:17 Filesystem Size Used Avail Use% Mounted on 15:02:17 udev 7.8G 0 7.8G 0% /dev 15:02:17 tmpfs 1.6G 1.1M 1.6G 1% /run 15:02:17 /dev/vda1 78G 17G 62G 21% / 15:02:17 tmpfs 7.9G 0 7.9G 0% /dev/shm 15:02:17 tmpfs 5.0M 0 5.0M 0% /run/lock 15:02:17 tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup 15:02:17 /dev/loop0 62M 62M 0 100% /snap/core20/1405 15:02:17 /dev/loop2 68M 68M 0 100% /snap/lxd/22753 15:02:17 /dev/vda15 105M 6.1M 99M 6% /boot/efi 15:02:17 tmpfs 1.6G 0 1.6G 0% /run/user/1001 15:02:17 /dev/loop3 39M 39M 0 100% /snap/snapd/21759 15:02:17 /dev/loop4 64M 64M 0 100% /snap/core20/2434 15:02:17 /dev/loop5 92M 92M 0 100% /snap/lxd/29619 15:02:17 15:02:17 15:02:17 ---> free -m: 15:02:17 total used free shared buff/cache available 15:02:17 Mem: 15997 663 5709 0 9624 14994 15:02:17 Swap: 1023 0 1023 15:02:17 15:02:17 15:02:17 ---> ip addr: 15:02:17 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 15:02:17 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 15:02:17 inet 127.0.0.1/8 scope host lo 15:02:17 valid_lft forever preferred_lft forever 15:02:17 inet6 ::1/128 scope host 15:02:17 valid_lft forever preferred_lft forever 15:02:17 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 15:02:17 link/ether fa:16:3e:34:c7:2c brd ff:ff:ff:ff:ff:ff 15:02:17 inet 10.30.170.233/23 brd 10.30.171.255 scope global dynamic ens3 15:02:17 valid_lft 80441sec preferred_lft 80441sec 15:02:17 inet6 fe80::f816:3eff:fe34:c72c/64 scope link 15:02:17 valid_lft forever preferred_lft forever 15:02:17 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 15:02:17 link/ether 02:42:86:96:f2:34 brd ff:ff:ff:ff:ff:ff 15:02:17 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 15:02:17 valid_lft forever preferred_lft forever 15:02:17 15:02:17 15:02:17 ---> sar -b -r -n DEV: 15:02:17 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-2872) 10/30/24 _x86_64_ (4 CPU) 15:02:17 15:02:17 13:23:01 LINUX RESTART (4 CPU) 15:02:17 15:02:17 13:24:01 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 15:02:17 13:25:01 106.85 44.89 61.96 0.00 1392.87 6584.36 0.00 15:02:17 13:26:01 235.84 36.26 199.58 0.00 2521.85 31588.47 0.00 15:02:17 13:27:01 99.38 6.75 92.63 0.00 287.55 40236.09 0.00 15:02:17 13:28:01 171.19 0.40 170.79 0.00 34.79 134271.22 0.00 15:02:17 13:29:01 189.59 16.19 173.39 0.00 4927.02 85867.51 0.00 15:02:17 13:30:01 199.23 1.93 197.30 0.00 64.26 18676.89 0.00 15:02:17 13:31:01 87.72 0.05 87.67 0.00 3.47 1600.53 0.00 15:02:17 13:32:01 108.20 0.00 108.20 0.00 0.00 1844.30 0.00 15:02:17 13:33:01 186.95 0.02 186.94 0.00 0.27 11220.93 0.00 15:02:17 13:34:01 3.77 0.00 3.77 0.00 0.00 291.82 0.00 15:02:17 13:35:01 82.79 0.00 82.79 0.00 0.00 1191.40 0.00 15:02:17 13:36:01 12.85 0.08 12.77 0.00 2.13 1567.07 0.00 15:02:17 13:37:01 106.83 0.00 106.83 0.00 0.00 8605.90 0.00 15:02:17 13:38:01 2.18 0.00 2.18 0.00 0.00 33.46 0.00 15:02:17 13:39:01 2.53 0.02 2.52 0.00 0.13 34.66 0.00 15:02:17 13:40:01 2.73 0.00 2.73 0.00 0.00 35.33 0.00 15:02:17 13:41:01 95.85 0.00 95.85 0.00 0.00 1717.98 0.00 15:02:17 13:42:01 43.10 0.35 42.75 0.00 15.73 619.79 0.00 15:02:17 13:43:01 3.42 0.27 3.15 0.00 26.27 65.33 0.00 15:02:17 13:44:01 78.82 1.48 77.34 0.00 185.17 1116.08 0.00 15:02:17 13:45:01 79.15 0.02 79.14 0.00 0.13 1228.33 0.00 15:02:17 13:46:01 2.50 0.00 2.50 0.00 0.00 38.13 0.00 15:02:17 13:47:01 136.29 0.00 136.29 0.00 0.00 1975.47 0.00 15:02:17 13:48:01 2.00 0.02 1.98 0.00 0.13 41.73 0.00 15:02:17 13:49:01 38.28 0.02 38.26 0.00 0.13 590.83 0.00 15:02:17 13:50:01 16.68 0.00 16.68 0.00 0.00 272.62 0.00 15:02:17 13:51:01 45.66 0.00 45.66 0.00 0.00 656.56 0.00 15:02:17 13:52:01 2.98 0.02 2.97 0.00 0.13 62.92 0.00 15:02:17 13:53:01 15.71 0.00 15.71 0.00 0.00 458.86 0.00 15:02:17 13:54:01 12.68 0.00 12.68 0.00 0.00 210.50 0.00 15:02:17 13:55:01 1.90 0.00 1.90 0.00 0.00 35.19 0.00 15:02:17 13:56:01 1.88 0.00 1.88 0.00 0.00 35.73 0.00 15:02:17 13:57:01 1.37 0.00 1.37 0.00 0.00 24.26 0.00 15:02:17 13:58:01 2.08 0.00 2.08 0.00 0.00 39.99 0.00 15:02:17 13:59:01 1.88 0.00 1.88 0.00 0.00 39.46 0.00 15:02:17 14:00:01 1.78 0.00 1.78 0.00 0.00 33.33 0.00 15:02:17 14:01:01 2.20 0.00 2.20 0.00 0.00 144.64 0.00 15:02:17 14:02:01 39.81 0.00 39.81 0.00 0.00 606.17 0.00 15:02:17 14:03:01 2.63 0.00 2.63 0.00 0.00 62.66 0.00 15:02:17 14:04:01 2.80 0.00 2.80 0.00 0.00 56.52 0.00 15:02:17 14:05:01 2.62 0.00 2.62 0.00 0.00 54.92 0.00 15:02:17 14:06:01 2.68 0.00 2.68 0.00 0.00 47.59 0.00 15:02:17 14:07:01 2.03 0.00 2.03 0.00 0.00 45.33 0.00 15:02:17 14:08:01 1.92 0.00 1.92 0.00 0.00 47.06 0.00 15:02:17 14:09:01 17.69 0.00 17.69 0.00 0.00 317.76 0.00 15:02:17 14:10:01 57.31 0.00 57.31 0.00 0.00 802.53 0.00 15:02:17 14:11:01 1.60 0.00 1.60 0.00 0.00 32.79 0.00 15:02:17 14:12:01 2.12 0.00 2.12 0.00 0.00 53.46 0.00 15:02:17 14:13:01 1.95 0.00 1.95 0.00 0.00 37.99 0.00 15:02:17 14:14:01 2.32 0.00 2.32 0.00 0.00 42.66 0.00 15:02:17 14:15:01 2.07 0.00 2.07 0.00 0.00 44.66 0.00 15:02:17 14:16:01 1.82 0.00 1.82 0.00 0.00 41.46 0.00 15:02:17 14:17:01 16.41 0.02 16.40 0.00 0.53 270.89 0.00 15:02:17 14:18:01 51.33 0.03 51.30 0.00 0.53 744.55 0.00 15:02:17 14:19:01 2.50 0.00 2.50 0.00 0.00 53.46 0.00 15:02:17 14:20:01 3.70 0.00 3.70 0.00 0.00 67.06 0.00 15:02:17 14:21:01 2.42 0.00 2.42 0.00 0.00 40.39 0.00 15:02:17 14:22:01 2.70 0.00 2.70 0.00 0.00 47.19 0.00 15:02:17 14:23:01 2.25 0.00 2.25 0.00 0.00 36.66 0.00 15:02:17 14:24:01 1.93 0.00 1.93 0.00 0.00 38.66 0.00 15:02:17 14:25:01 2.02 0.00 2.02 0.00 0.00 32.93 0.00 15:02:17 14:26:01 1.85 0.00 1.85 0.00 0.00 43.19 0.00 15:02:17 14:27:01 2.12 0.00 2.12 0.00 0.00 35.33 0.00 15:02:17 14:28:01 2.08 0.00 2.08 0.00 0.00 26.40 0.00 15:02:17 14:29:01 1.63 0.00 1.63 0.00 0.00 21.46 0.00 15:02:17 14:30:01 49.14 0.15 48.99 0.00 7.60 1794.10 0.00 15:02:17 14:31:01 72.64 0.00 72.64 0.00 0.00 8348.82 0.00 15:02:17 14:32:01 4.40 0.00 4.40 0.00 0.00 110.38 0.00 15:02:17 14:33:01 81.92 0.00 81.92 0.00 0.00 1495.20 0.00 15:02:17 14:34:01 2.03 0.00 2.03 0.00 0.00 47.33 0.00 15:02:17 14:35:01 1.45 0.00 1.45 0.00 0.00 25.86 0.00 15:02:17 14:36:01 2.07 0.00 2.07 0.00 0.00 42.13 0.00 15:02:17 14:37:01 1.63 0.00 1.63 0.00 0.00 26.93 0.00 15:02:17 14:38:01 1.93 0.00 1.93 0.00 0.00 52.12 0.00 15:02:17 14:39:01 1.80 0.00 1.80 0.00 0.00 27.99 0.00 15:02:17 14:40:01 25.50 0.00 25.50 0.00 0.00 425.40 0.00 15:02:17 14:41:01 50.42 0.00 50.42 0.00 0.00 823.73 0.00 15:02:17 14:42:01 3.48 0.00 3.48 0.00 0.00 84.79 0.00 15:02:17 14:43:01 2.87 0.00 2.87 0.00 0.00 69.99 0.00 15:02:17 14:44:01 26.67 0.15 26.52 0.00 1.20 1119.12 0.00 15:02:17 14:45:01 54.71 1.33 53.37 0.00 34.53 9134.34 0.00 15:02:17 14:46:01 52.78 0.12 52.67 0.00 12.13 788.00 0.00 15:02:17 14:47:01 2.70 0.00 2.70 0.00 0.00 62.79 0.00 15:02:17 14:48:01 41.13 0.43 40.69 0.00 43.19 680.42 0.00 15:02:17 14:49:01 57.66 0.00 57.66 0.00 0.00 813.60 0.00 15:02:17 14:50:01 3.02 0.00 3.02 0.00 0.00 65.86 0.00 15:02:17 14:51:01 2.05 0.00 2.05 0.00 0.00 35.59 0.00 15:02:17 14:52:01 2.78 0.00 2.78 0.00 0.00 45.73 0.00 15:02:17 14:53:01 1.42 0.00 1.42 0.00 0.00 18.40 0.00 15:02:17 14:54:01 1.70 0.00 1.70 0.00 0.00 23.60 0.00 15:02:17 14:55:01 26.10 0.02 26.08 0.00 0.13 407.13 0.00 15:02:17 14:56:01 78.39 0.00 78.39 0.00 0.00 1147.68 0.00 15:02:17 14:57:01 2.10 0.00 2.10 0.00 0.00 59.72 0.00 15:02:17 14:58:01 2.27 0.00 2.27 0.00 0.00 37.99 0.00 15:02:17 14:59:01 2.63 0.00 2.63 0.00 0.00 56.92 0.00 15:02:17 15:00:01 52.28 0.00 52.28 0.00 0.00 826.39 0.00 15:02:17 15:01:01 61.29 0.00 61.29 0.00 0.00 863.19 0.00 15:02:17 15:02:02 34.66 5.70 28.96 0.00 327.41 1391.10 0.00 15:02:17 Average: 32.91 1.19 31.72 0.00 100.94 3957.24 0.00 15:02:17 15:02:17 13:24:01 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 15:02:17 13:25:01 13260416 15400944 575836 3.52 73864 2257960 1311772 7.53 834900 2000820 229560 15:02:17 13:26:01 10738364 14550604 1409076 8.60 136076 3743104 2215988 12.71 1871596 3344088 998548 15:02:17 13:27:01 9027836 14174720 1784204 10.89 154964 5004836 2530992 14.52 2556136 4311908 1131816 15:02:17 13:28:01 6573528 14463064 1493568 9.12 195788 7584392 2353212 13.50 3095916 6104072 601100 15:02:17 13:29:01 4144176 13668568 2275832 13.89 228160 9117552 3573808 20.50 4470772 7069552 456272 15:02:17 13:30:01 3247776 12783492 3160736 19.29 235328 9121376 3917392 22.48 5435776 6994848 1016 15:02:17 13:31:01 3935808 13478924 2465440 15.05 239120 9124696 3609020 20.71 4777368 6968012 2852 15:02:17 13:32:01 3403660 12947636 2996620 18.29 241912 9122828 3803940 21.82 5310384 6964680 612 15:02:17 13:33:01 1216852 11015084 4926652 30.07 253312 9351416 5921252 33.97 7310820 7130964 1708 15:02:17 13:34:01 1156076 10951560 4991248 30.47 253348 9348804 5937324 34.06 7375180 7128132 188 15:02:17 13:35:01 1906872 11704108 4239212 25.88 254908 9348940 5222008 29.96 6626508 7127872 140 15:02:17 13:36:01 2651876 12690728 3252744 19.86 260980 9570696 4283628 24.58 5681208 7318428 205500 15:02:17 13:37:01 290112 10336436 5605696 34.22 263912 9575056 6684908 38.35 8056068 7296600 152 15:02:17 13:38:01 288476 10334852 5607372 34.23 263948 9575076 6684908 38.35 8057572 7296604 56 15:02:17 13:39:01 283588 10329968 5612016 34.26 263964 9575052 6721460 38.56 8058536 7296556 76 15:02:17 13:40:01 284156 10330572 5611360 34.25 263972 9575056 6721460 38.56 8058700 7296560 88 15:02:17 13:41:01 2770564 12819216 3123740 19.07 265692 9575320 4119916 23.64 5618620 7264728 444 15:02:17 13:42:01 173268 9880516 6061560 37.00 258892 9247568 7307108 41.92 8433772 7043584 144 15:02:17 13:43:01 2260648 11756260 4186068 25.55 256016 9043140 5168972 29.66 6532788 6864640 136 15:02:17 13:44:01 4332128 13834744 2109644 12.88 257364 9048776 2946464 16.90 4471308 6864916 116 15:02:17 13:45:01 4397600 13901788 2042580 12.47 258724 9048976 2857516 16.39 4405948 6863312 96 15:02:17 13:46:01 4387316 13891556 2052756 12.53 258732 9049020 2857516 16.39 4416628 6863240 92 15:02:17 13:47:01 4392208 13898772 2045708 12.49 260508 9049516 2892504 16.60 4413552 6863112 356 15:02:17 13:48:01 4236792 13743636 2200644 13.43 260540 9049756 2990288 17.16 4568044 6863220 156 15:02:17 13:49:01 3572720 13080020 2863852 17.48 260788 9050012 3657248 20.98 5229636 6863068 28 15:02:17 13:50:01 4970556 14478076 1466524 8.95 260816 9050196 2726208 15.64 3837248 6863164 532 15:02:17 13:51:01 2039852 11548088 4395044 26.83 261236 9050484 5207772 29.88 6759940 6863376 232 15:02:17 13:52:01 2024836 11533380 4409736 26.92 261264 9050760 5223776 29.97 6773776 6863624 52 15:02:17 13:53:01 5175836 14684652 1260188 7.69 261288 9050992 2091836 12.00 3632820 6863720 532 15:02:17 13:54:01 2088620 11597892 4345112 26.52 261516 9051200 5155876 29.58 6709876 6863244 408 15:02:17 13:55:01 2083740 11593140 4349844 26.55 261524 9051320 5155876 29.58 6714028 6863352 132 15:02:17 13:56:01 2065084 11574672 4368300 26.67 261528 9051504 5155876 29.58 6732468 6863516 156 15:02:17 13:57:01 2061280 11570948 4372020 26.69 261548 9051560 5171892 29.67 6736508 6863572 220 15:02:17 13:58:01 2040024 11550176 4392772 26.82 261556 9052012 5187892 29.76 6756120 6864020 424 15:02:17 13:59:01 2025108 11535424 4407416 26.91 261572 9052164 5187892 29.76 6771352 6864176 168 15:02:17 14:00:01 1994372 11504808 4438036 27.09 261592 9052260 5221408 29.96 6802080 6864264 96 15:02:17 14:01:01 5768364 15278948 666104 4.07 261616 9052376 1745336 10.01 3043584 6864356 308 15:02:17 14:02:01 2274260 11785488 4157612 25.38 262092 9052564 5061224 29.04 6525872 6864292 204 15:02:17 14:03:01 2076768 11588484 4354272 26.58 262092 9053044 5159404 29.60 6720008 6864780 80 15:02:17 14:04:01 2043788 11556092 4386652 26.78 262100 9053620 5191388 29.78 6751988 6865348 284 15:02:17 14:05:01 2031472 11544124 4398584 26.85 262116 9053960 5191388 29.78 6764160 6865684 96 15:02:17 14:06:01 2015036 11528240 4414560 26.95 262132 9054508 5191388 29.78 6780156 6866216 304 15:02:17 14:07:01 2005736 11519264 4423468 27.00 262140 9054812 5191388 29.78 6788584 6866532 112 15:02:17 14:08:01 1983896 11498216 4444456 27.13 262148 9055592 5207392 29.88 6809088 6867316 428 15:02:17 14:09:01 3025412 12539588 3403812 20.78 262200 9055392 4817672 27.64 5775012 6867084 368 15:02:17 14:10:01 753008 10267452 5674840 34.64 262676 9055164 6552372 37.59 8037232 6866840 144 15:02:17 14:11:01 589708 10104568 5837448 35.63 262684 9055572 6681848 38.34 8198452 6867248 504 15:02:17 14:12:01 498972 10014108 5927800 36.19 262692 9055840 6714324 38.52 8288528 6867516 140 15:02:17 14:13:01 483584 9998848 5943028 36.28 262704 9055956 6714324 38.52 8303868 6867628 344 15:02:17 14:14:01 456400 9972036 5969904 36.44 262716 9056316 6762656 38.80 8330580 6867992 348 15:02:17 14:15:01 441184 9957204 5984636 36.53 262724 9056720 6762656 38.80 8344940 6868360 412 15:02:17 14:16:01 417048 9933308 6008544 36.68 262724 9056928 6779260 38.89 8368052 6868596 276 15:02:17 14:17:01 4065004 13581320 2362792 14.42 262748 9056956 3497344 20.07 4734744 6868584 820 15:02:17 14:18:01 791168 10307764 5634492 34.40 263184 9056784 6501984 37.30 7997188 6868384 136 15:02:17 14:19:01 633036 10150068 5791928 35.36 263212 9057188 6598972 37.86 8153912 6868792 420 15:02:17 14:20:01 542944 10060348 5881468 35.90 263220 9057552 6648556 38.14 8244312 6869152 72 15:02:17 14:21:01 533360 10050868 5891036 35.96 263224 9057652 6648556 38.14 8253776 6869252 140 15:02:17 14:22:01 519036 10036736 5905120 36.05 263240 9057840 6664636 38.24 8267088 6869428 64 15:02:17 14:23:01 497836 10015680 5926180 36.18 263244 9057972 6664636 38.24 8288080 6869568 84 15:02:17 14:24:01 490220 10008320 5933640 36.22 263252 9058220 6696656 38.42 8296180 6869816 496 15:02:17 14:25:01 452972 9971168 5970772 36.45 263264 9058312 6712644 38.51 8332900 6869900 236 15:02:17 14:26:01 421500 9940068 6001680 36.64 263280 9058672 6746132 38.70 8361636 6870252 192 15:02:17 14:27:01 421360 9940112 6001648 36.64 263300 9058824 6746132 38.70 8362560 6870412 112 15:02:17 14:28:01 421368 9940148 6001556 36.64 263320 9058828 6746132 38.70 8362044 6870424 84 15:02:17 14:29:01 421116 9939920 6001772 36.64 263336 9058828 6746132 38.70 8362200 6870424 56 15:02:17 14:30:01 4680736 14443748 1500352 9.16 269612 9284164 2857760 16.40 3931092 7045680 220640 15:02:17 14:31:01 1755272 11520952 4421436 26.99 270272 9285956 5259348 30.17 6852828 7038868 1572 15:02:17 14:32:01 1628820 11394788 4547496 27.76 270284 9286236 5342720 30.65 6978444 7038984 324 15:02:17 14:33:01 2060056 11826792 4115940 25.13 270752 9286296 5025696 28.83 6572936 7017580 432 15:02:17 14:34:01 1858860 11625976 4316408 26.35 270752 9286676 5139448 29.49 6771660 7017428 316 15:02:17 14:35:01 1845740 11613052 4329324 26.43 270760 9286864 5139448 29.49 6783960 7017556 220 15:02:17 14:36:01 1826644 11594220 4348084 26.54 270760 9287132 5155472 29.58 6802676 7017812 168 15:02:17 14:37:01 1821572 11589308 4353104 26.57 270776 9287272 5171464 29.67 6807184 7017956 396 15:02:17 14:38:01 1790756 11559048 4383364 26.76 270796 9287820 5203688 29.85 6836120 7018476 420 15:02:17 14:39:01 1785180 11553772 4388604 26.79 270796 9288104 5203688 29.85 6841308 7018768 628 15:02:17 14:40:01 1972052 11740296 4202508 25.65 270868 9287708 5611316 32.19 6672188 7007424 176 15:02:17 14:41:01 1003016 10772016 5170044 31.56 271088 9288252 5958776 34.19 7634564 7007800 152 15:02:17 14:42:01 894552 10664340 5277524 32.22 271104 9289032 6006844 34.46 7742376 7008508 104 15:02:17 14:43:01 837624 10608156 5333748 32.56 271132 9289740 6038864 34.65 7797284 7009224 204 15:02:17 14:44:01 4519336 14557084 1386536 8.46 277752 9530360 2242404 12.87 3871828 7243920 242632 15:02:17 14:45:01 1322476 11363360 4578552 27.95 277932 9532896 6258968 35.91 7077164 7225480 104 15:02:17 14:46:01 164984 9633428 6307328 38.50 274008 8971536 7325112 42.03 8737076 6723492 100 15:02:17 14:47:01 152824 9621876 6318896 38.57 274012 8972160 7325112 42.03 8748968 6723900 132 15:02:17 14:48:01 3023492 12470212 3472296 21.20 274084 8949888 4869968 27.94 5917336 6696320 344 15:02:17 14:49:01 2166312 11613680 4328472 26.42 274372 8950284 5138416 29.48 6771620 6696620 264 15:02:17 14:50:01 1989412 11437436 4504360 27.50 274372 8950920 5268932 30.23 6946296 6697152 100 15:02:17 14:51:01 1983812 11431992 4509748 27.53 274372 8951088 5284924 30.32 6950092 6697276 96 15:02:17 14:52:01 1973616 11422040 4519716 27.59 274372 8951324 5284924 30.32 6961428 6697520 88 15:02:17 14:53:01 1973268 11421700 4520044 27.59 274372 8951328 5284924 30.32 6960696 6697528 60 15:02:17 14:54:01 1973104 11421536 4520176 27.59 274372 8951328 5284924 30.32 6960396 6697528 72 15:02:17 14:55:01 4006392 13455116 2488152 15.19 274416 8951560 4023036 23.08 4944124 6687812 780 15:02:17 14:56:01 2257984 11707504 4234492 25.85 274752 8951972 5145376 29.52 6686848 6688208 312 15:02:17 14:57:01 2028000 11478064 4463644 27.25 274752 8952516 5313764 30.49 6914900 6688656 96 15:02:17 14:58:01 2002000 11452276 4489496 27.41 274760 8952720 5330960 30.59 6941104 6688848 216 15:02:17 14:59:01 1965224 11415888 4525788 27.63 274764 8953100 5350624 30.70 6976832 6689232 292 15:02:17 15:00:01 3682908 13133908 2808756 17.15 274860 8953276 4160956 23.87 5263892 6689380 192 15:02:17 15:01:01 2174772 11626312 4315592 26.34 275148 8953512 5165132 29.63 6769568 6689608 140 15:02:17 15:02:02 5931244 15408140 536128 3.27 275848 8977960 1268220 7.28 3009508 6707360 1316 15:02:17 Average: 2343160 11742301 4201174 25.65 259477 8945779 5097558 29.25 6532398 6788588 41985 15:02:17 15:02:17 13:24:01 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 15:02:17 13:25:01 ens3 78.31 62.33 790.39 7.43 0.00 0.00 0.00 0.00 15:02:17 13:25:01 lo 0.60 0.60 0.06 0.06 0.00 0.00 0.00 0.00 15:02:17 13:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:26:01 ens3 448.89 367.46 7086.06 41.12 0.00 0.00 0.00 0.00 15:02:17 13:26:01 lo 6.40 6.40 0.65 0.65 0.00 0.00 0.00 0.00 15:02:17 13:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:27:01 ens3 264.31 209.02 4089.53 21.70 0.00 0.00 0.00 0.00 15:02:17 13:27:01 lo 0.40 0.40 0.04 0.04 0.00 0.00 0.00 0.00 15:02:17 13:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:28:01 ens3 208.00 116.85 3964.99 13.06 0.00 0.00 0.00 0.00 15:02:17 13:28:01 lo 1.27 1.27 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 13:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:29:01 ens3 224.19 106.88 2771.18 8.16 0.00 0.00 0.00 0.00 15:02:17 13:29:01 lo 2.92 2.92 0.28 0.28 0.00 0.00 0.00 0.00 15:02:17 13:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:30:01 ens3 2.07 1.77 0.56 0.48 0.00 0.00 0.00 0.00 15:02:17 13:30:01 lo 19.96 19.96 34.67 34.67 0.00 0.00 0.00 0.00 15:02:17 13:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:31:01 ens3 1.97 1.77 0.38 0.35 0.00 0.00 0.00 0.00 15:02:17 13:31:01 lo 28.36 28.36 9.84 9.84 0.00 0.00 0.00 0.00 15:02:17 13:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:32:01 ens3 2.17 1.51 0.38 0.30 0.00 0.00 0.00 0.00 15:02:17 13:32:01 lo 35.16 35.16 14.14 14.14 0.00 0.00 0.00 0.00 15:02:17 13:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:33:01 ens3 2.77 2.67 1.62 0.98 0.00 0.00 0.00 0.00 15:02:17 13:33:01 lo 24.13 24.13 17.30 17.30 0.00 0.00 0.00 0.00 15:02:17 13:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:34:01 ens3 1.30 1.12 0.30 0.27 0.00 0.00 0.00 0.00 15:02:17 13:34:01 lo 34.39 34.39 11.88 11.88 0.00 0.00 0.00 0.00 15:02:17 13:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:35:01 ens3 0.92 0.80 0.17 0.15 0.00 0.00 0.00 0.00 15:02:17 13:35:01 lo 18.75 18.75 8.12 8.12 0.00 0.00 0.00 0.00 15:02:17 13:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:36:01 ens3 2.25 2.38 0.96 0.81 0.00 0.00 0.00 0.00 15:02:17 13:36:01 lo 25.28 25.28 8.04 8.04 0.00 0.00 0.00 0.00 15:02:17 13:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:37:01 ens3 2.08 2.40 0.40 0.42 0.00 0.00 0.00 0.00 15:02:17 13:37:01 lo 17.55 17.55 17.25 17.25 0.00 0.00 0.00 0.00 15:02:17 13:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:38:01 ens3 0.43 0.23 0.04 0.03 0.00 0.00 0.00 0.00 15:02:17 13:38:01 lo 0.92 0.92 0.10 0.10 0.00 0.00 0.00 0.00 15:02:17 13:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:39:01 ens3 0.23 0.17 0.08 0.07 0.00 0.00 0.00 0.00 15:02:17 13:39:01 lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:40:01 ens3 0.40 0.28 0.04 0.03 0.00 0.00 0.00 0.00 15:02:17 13:40:01 lo 0.65 0.65 0.07 0.07 0.00 0.00 0.00 0.00 15:02:17 13:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:41:01 ens3 0.87 0.98 0.14 0.14 0.00 0.00 0.00 0.00 15:02:17 13:41:01 lo 14.16 14.16 4.66 4.66 0.00 0.00 0.00 0.00 15:02:17 13:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:42:01 ens3 1.05 1.05 0.14 0.16 0.00 0.00 0.00 0.00 15:02:17 13:42:01 lo 10.30 10.30 4.59 4.59 0.00 0.00 0.00 0.00 15:02:17 13:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:43:01 ens3 7.98 7.20 1.66 4.44 0.00 0.00 0.00 0.00 15:02:17 13:43:01 lo 20.58 20.58 9.13 9.13 0.00 0.00 0.00 0.00 15:02:17 13:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:44:01 ens3 1.00 0.93 0.21 0.20 0.00 0.00 0.00 0.00 15:02:17 13:44:01 lo 5.70 5.70 6.35 6.35 0.00 0.00 0.00 0.00 15:02:17 13:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:45:01 ens3 0.58 0.68 0.10 0.10 0.00 0.00 0.00 0.00 15:02:17 13:45:01 lo 7.25 7.25 2.60 2.60 0.00 0.00 0.00 0.00 15:02:17 13:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:46:01 ens3 0.62 0.63 0.10 0.10 0.00 0.00 0.00 0.00 15:02:17 13:46:01 lo 4.63 4.63 1.04 1.04 0.00 0.00 0.00 0.00 15:02:17 13:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:47:01 ens3 0.87 0.88 0.12 0.13 0.00 0.00 0.00 0.00 15:02:17 13:47:01 lo 30.02 30.02 9.92 9.92 0.00 0.00 0.00 0.00 15:02:17 13:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:48:01 ens3 1.45 1.27 0.24 0.20 0.00 0.00 0.00 0.00 15:02:17 13:48:01 lo 21.16 21.16 13.45 13.45 0.00 0.00 0.00 0.00 15:02:17 13:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:49:01 ens3 1.37 1.08 0.46 0.37 0.00 0.00 0.00 0.00 15:02:17 13:49:01 lo 12.43 12.43 15.02 15.02 0.00 0.00 0.00 0.00 15:02:17 13:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:50:01 ens3 1.65 1.80 0.66 0.45 0.00 0.00 0.00 0.00 15:02:17 13:50:01 lo 12.33 12.33 5.65 5.65 0.00 0.00 0.00 0.00 15:02:17 13:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:51:01 ens3 0.92 1.05 0.15 0.16 0.00 0.00 0.00 0.00 15:02:17 13:51:01 lo 35.26 35.26 14.28 14.28 0.00 0.00 0.00 0.00 15:02:17 13:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:52:01 ens3 0.63 0.75 0.11 0.11 0.00 0.00 0.00 0.00 15:02:17 13:52:01 lo 39.11 39.11 11.88 11.88 0.00 0.00 0.00 0.00 15:02:17 13:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:53:01 ens3 0.77 0.75 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 13:53:01 lo 18.98 18.98 5.79 5.79 0.00 0.00 0.00 0.00 15:02:17 13:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:54:01 ens3 0.97 0.87 0.20 0.18 0.00 0.00 0.00 0.00 15:02:17 13:54:01 lo 27.45 27.45 20.89 20.89 0.00 0.00 0.00 0.00 15:02:17 13:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:55:01 ens3 0.68 0.65 0.11 0.11 0.00 0.00 0.00 0.00 15:02:17 13:55:01 lo 7.92 7.92 3.44 3.44 0.00 0.00 0.00 0.00 15:02:17 13:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:56:01 ens3 1.07 0.95 0.18 0.15 0.00 0.00 0.00 0.00 15:02:17 13:56:01 lo 19.15 19.15 9.96 9.96 0.00 0.00 0.00 0.00 15:02:17 13:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:57:01 ens3 2.95 1.57 1.04 0.71 0.00 0.00 0.00 0.00 15:02:17 13:57:01 lo 6.47 6.47 4.00 4.00 0.00 0.00 0.00 0.00 15:02:17 13:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:58:01 ens3 1.32 0.95 0.66 0.52 0.00 0.00 0.00 0.00 15:02:17 13:58:01 lo 34.26 34.26 12.83 12.83 0.00 0.00 0.00 0.00 15:02:17 13:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 13:59:01 ens3 0.55 0.38 0.23 0.10 0.00 0.00 0.00 0.00 15:02:17 13:59:01 lo 8.58 8.58 4.18 4.18 0.00 0.00 0.00 0.00 15:02:17 13:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:00:01 ens3 0.90 1.12 0.17 0.17 0.00 0.00 0.00 0.00 15:02:17 14:00:01 lo 15.00 15.00 7.46 7.46 0.00 0.00 0.00 0.00 15:02:17 14:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:01:01 ens3 0.60 0.60 0.09 0.09 0.00 0.00 0.00 0.00 15:02:17 14:01:01 lo 24.20 24.20 8.25 8.25 0.00 0.00 0.00 0.00 15:02:17 14:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:02:01 ens3 0.87 1.00 0.13 0.15 0.00 0.00 0.00 0.00 15:02:17 14:02:01 lo 18.01 18.01 7.25 7.25 0.00 0.00 0.00 0.00 15:02:17 14:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:03:01 ens3 0.72 0.82 0.13 0.13 0.00 0.00 0.00 0.00 15:02:17 14:03:01 lo 37.24 37.24 12.33 12.33 0.00 0.00 0.00 0.00 15:02:17 14:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:04:01 ens3 1.55 0.97 0.47 0.36 0.00 0.00 0.00 0.00 15:02:17 14:04:01 lo 52.01 52.01 15.89 15.89 0.00 0.00 0.00 0.00 15:02:17 14:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:05:01 ens3 0.37 0.42 0.07 0.07 0.00 0.00 0.00 0.00 15:02:17 14:05:01 lo 22.46 22.46 6.56 6.56 0.00 0.00 0.00 0.00 15:02:17 14:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:06:01 ens3 0.75 0.33 0.10 0.05 0.00 0.00 0.00 0.00 15:02:17 14:06:01 lo 34.21 34.21 9.78 9.78 0.00 0.00 0.00 0.00 15:02:17 14:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:07:01 ens3 1.70 0.38 0.41 0.22 0.00 0.00 0.00 0.00 15:02:17 14:07:01 lo 20.80 20.80 5.91 5.91 0.00 0.00 0.00 0.00 15:02:17 14:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:08:01 ens3 2.45 0.88 1.13 0.79 0.00 0.00 0.00 0.00 15:02:17 14:08:01 lo 56.89 56.89 18.53 18.53 0.00 0.00 0.00 0.00 15:02:17 14:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:09:01 ens3 0.85 0.67 0.18 0.15 0.00 0.00 0.00 0.00 15:02:17 14:09:01 lo 24.89 24.89 6.91 6.91 0.00 0.00 0.00 0.00 15:02:17 14:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:10:01 ens3 0.83 0.83 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 14:10:01 lo 22.70 22.70 22.40 22.40 0.00 0.00 0.00 0.00 15:02:17 14:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:11:01 ens3 0.68 0.73 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 14:11:01 lo 32.06 32.06 13.74 13.74 0.00 0.00 0.00 0.00 15:02:17 14:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:12:01 ens3 1.02 1.12 0.26 0.18 0.00 0.00 0.00 0.00 15:02:17 14:12:01 lo 18.81 18.81 7.88 7.88 0.00 0.00 0.00 0.00 15:02:17 14:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:13:01 ens3 0.73 0.92 0.14 0.15 0.00 0.00 0.00 0.00 15:02:17 14:13:01 lo 10.50 10.50 5.31 5.31 0.00 0.00 0.00 0.00 15:02:17 14:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:14:01 ens3 0.58 0.62 0.15 0.14 0.00 0.00 0.00 0.00 15:02:17 14:14:01 lo 36.96 36.96 13.80 13.80 0.00 0.00 0.00 0.00 15:02:17 14:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:15:01 ens3 0.58 0.77 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 14:15:01 lo 31.01 31.01 12.37 12.37 0.00 0.00 0.00 0.00 15:02:17 14:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:16:01 ens3 0.55 0.55 0.09 0.08 0.00 0.00 0.00 0.00 15:02:17 14:16:01 lo 22.38 22.38 8.35 8.35 0.00 0.00 0.00 0.00 15:02:17 14:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:17:01 ens3 0.70 0.77 0.11 0.12 0.00 0.00 0.00 0.00 15:02:17 14:17:01 lo 4.57 4.57 2.13 2.13 0.00 0.00 0.00 0.00 15:02:17 14:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:18:01 ens3 0.73 0.83 0.11 0.11 0.00 0.00 0.00 0.00 15:02:17 14:18:01 lo 22.04 22.04 22.31 22.31 0.00 0.00 0.00 0.00 15:02:17 14:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:19:01 ens3 0.73 0.92 0.19 0.19 0.00 0.00 0.00 0.00 15:02:17 14:19:01 lo 33.83 33.83 14.14 14.14 0.00 0.00 0.00 0.00 15:02:17 14:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:20:01 ens3 0.40 0.38 0.06 0.06 0.00 0.00 0.00 0.00 15:02:17 14:20:01 lo 17.95 17.95 9.45 9.45 0.00 0.00 0.00 0.00 15:02:17 14:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:21:01 ens3 0.80 0.92 0.15 0.15 0.00 0.00 0.00 0.00 15:02:17 14:21:01 lo 10.26 10.26 5.93 5.93 0.00 0.00 0.00 0.00 15:02:17 14:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:22:01 ens3 0.53 0.63 0.09 0.10 0.00 0.00 0.00 0.00 15:02:17 14:22:01 lo 23.25 23.25 12.31 12.31 0.00 0.00 0.00 0.00 15:02:17 14:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:23:01 ens3 0.53 0.62 0.10 0.10 0.00 0.00 0.00 0.00 15:02:17 14:23:01 lo 8.08 8.08 5.71 5.71 0.00 0.00 0.00 0.00 15:02:17 14:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:24:01 ens3 0.78 0.87 0.28 0.17 0.00 0.00 0.00 0.00 15:02:17 14:24:01 lo 25.28 25.28 12.08 12.08 0.00 0.00 0.00 0.00 15:02:17 14:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:25:01 ens3 0.55 0.55 0.09 0.09 0.00 0.00 0.00 0.00 15:02:17 14:25:01 lo 10.15 10.15 6.14 6.14 0.00 0.00 0.00 0.00 15:02:17 14:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:26:01 ens3 0.42 0.33 0.10 0.04 0.00 0.00 0.00 0.00 15:02:17 14:26:01 lo 35.98 35.98 12.61 12.61 0.00 0.00 0.00 0.00 15:02:17 14:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:27:01 ens3 1.00 0.78 0.37 0.28 0.00 0.00 0.00 0.00 15:02:17 14:27:01 lo 3.80 3.80 2.48 2.48 0.00 0.00 0.00 0.00 15:02:17 14:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:28:01 ens3 0.18 0.08 0.01 0.01 0.00 0.00 0.00 0.00 15:02:17 14:28:01 lo 0.78 0.78 0.08 0.08 0.00 0.00 0.00 0.00 15:02:17 14:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:29:01 ens3 0.23 0.13 0.08 0.07 0.00 0.00 0.00 0.00 15:02:17 14:29:01 lo 0.38 0.38 0.03 0.03 0.00 0.00 0.00 0.00 15:02:17 14:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:30:01 ens3 1.85 2.07 1.02 0.89 0.00 0.00 0.00 0.00 15:02:17 14:30:01 lo 2.22 2.22 0.20 0.20 0.00 0.00 0.00 0.00 15:02:17 14:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:31:01 ens3 0.68 0.58 0.10 0.08 0.00 0.00 0.00 0.00 15:02:17 14:31:01 lo 37.15 37.15 33.22 33.22 0.00 0.00 0.00 0.00 15:02:17 14:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:32:01 ens3 1.92 1.83 0.39 0.28 0.00 0.00 0.00 0.00 15:02:17 14:32:01 lo 34.21 34.21 13.84 13.84 0.00 0.00 0.00 0.00 15:02:17 14:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:33:01 ens3 1.07 1.25 0.37 0.34 0.00 0.00 0.00 0.00 15:02:17 14:33:01 lo 13.62 13.62 10.10 10.10 0.00 0.00 0.00 0.00 15:02:17 14:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:34:01 ens3 1.00 1.18 0.23 0.23 0.00 0.00 0.00 0.00 15:02:17 14:34:01 lo 28.25 28.25 10.23 10.23 0.00 0.00 0.00 0.00 15:02:17 14:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:35:01 ens3 0.70 0.92 0.14 0.15 0.00 0.00 0.00 0.00 15:02:17 14:35:01 lo 12.21 12.21 5.31 5.31 0.00 0.00 0.00 0.00 15:02:17 14:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:36:01 ens3 0.75 0.83 0.12 0.13 0.00 0.00 0.00 0.00 15:02:17 14:36:01 lo 25.98 25.98 10.59 10.59 0.00 0.00 0.00 0.00 15:02:17 14:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:37:01 ens3 0.68 0.77 0.13 0.12 0.00 0.00 0.00 0.00 15:02:17 14:37:01 lo 16.05 16.05 5.77 5.77 0.00 0.00 0.00 0.00 15:02:17 14:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:38:01 ens3 0.92 1.02 0.20 0.15 0.00 0.00 0.00 0.00 15:02:17 14:38:01 lo 44.89 44.89 15.31 15.31 0.00 0.00 0.00 0.00 15:02:17 14:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:39:01 ens3 0.62 0.75 0.17 0.17 0.00 0.00 0.00 0.00 15:02:17 14:39:01 lo 33.56 33.56 11.11 11.11 0.00 0.00 0.00 0.00 15:02:17 14:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:40:01 ens3 1.22 1.22 0.18 0.17 0.00 0.00 0.00 0.00 15:02:17 14:40:01 lo 5.68 5.68 1.19 1.19 0.00 0.00 0.00 0.00 15:02:17 14:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:41:01 ens3 0.67 0.87 0.13 0.14 0.00 0.00 0.00 0.00 15:02:17 14:41:01 lo 45.31 45.31 22.28 22.28 0.00 0.00 0.00 0.00 15:02:17 14:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:42:01 ens3 0.73 1.00 0.15 0.15 0.00 0.00 0.00 0.00 15:02:17 14:42:01 lo 71.44 71.44 25.04 25.04 0.00 0.00 0.00 0.00 15:02:17 14:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:43:01 ens3 0.53 0.52 0.09 0.08 0.00 0.00 0.00 0.00 15:02:17 14:43:01 lo 57.76 57.76 20.27 20.27 0.00 0.00 0.00 0.00 15:02:17 14:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:44:01 ens3 136.08 106.36 1935.82 12.19 0.00 0.00 0.00 0.00 15:02:17 14:44:01 lo 43.77 43.77 13.41 13.41 0.00 0.00 0.00 0.00 15:02:17 14:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:45:01 ens3 2.27 1.75 12.59 0.24 0.00 0.00 0.00 0.00 15:02:17 14:45:01 lo 2.87 2.87 0.31 0.31 0.00 0.00 0.00 0.00 15:02:17 14:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:46:01 ens3 0.83 0.77 0.15 0.14 0.00 0.00 0.00 0.00 15:02:17 14:46:01 lo 45.83 45.83 30.59 30.59 0.00 0.00 0.00 0.00 15:02:17 14:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:47:01 ens3 0.32 0.17 0.04 0.03 0.00 0.00 0.00 0.00 15:02:17 14:47:01 lo 22.61 22.61 9.29 9.29 0.00 0.00 0.00 0.00 15:02:17 14:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:48:01 ens3 0.87 0.82 0.12 0.12 0.00 0.00 0.00 0.00 15:02:17 14:48:01 lo 8.07 8.07 2.54 2.54 0.00 0.00 0.00 0.00 15:02:17 14:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:49:01 ens3 0.72 0.58 0.19 0.17 0.00 0.00 0.00 0.00 15:02:17 14:49:01 lo 17.36 17.36 18.74 18.74 0.00 0.00 0.00 0.00 15:02:17 14:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:50:01 ens3 0.30 0.22 0.04 0.03 0.00 0.00 0.00 0.00 15:02:17 14:50:01 lo 23.98 23.98 11.67 11.67 0.00 0.00 0.00 0.00 15:02:17 14:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:51:01 ens3 0.90 0.30 0.11 0.06 0.00 0.00 0.00 0.00 15:02:17 14:51:01 lo 14.51 14.51 5.61 5.61 0.00 0.00 0.00 0.00 15:02:17 14:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:52:01 ens3 0.77 0.28 0.10 0.04 0.00 0.00 0.00 0.00 15:02:17 14:52:01 lo 18.78 18.78 5.72 5.72 0.00 0.00 0.00 0.00 15:02:17 14:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:53:01 ens3 0.38 0.35 0.26 0.21 0.00 0.00 0.00 0.00 15:02:17 14:53:01 lo 0.37 0.37 0.03 0.03 0.00 0.00 0.00 0.00 15:02:17 14:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:54:01 ens3 0.32 0.22 0.09 0.07 0.00 0.00 0.00 0.00 15:02:17 14:54:01 lo 0.78 0.78 0.08 0.08 0.00 0.00 0.00 0.00 15:02:17 14:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:55:01 ens3 0.32 0.38 0.06 0.06 0.00 0.00 0.00 0.00 15:02:17 14:55:01 lo 2.77 2.77 0.30 0.30 0.00 0.00 0.00 0.00 15:02:17 14:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:56:01 ens3 0.90 0.80 0.11 0.10 0.00 0.00 0.00 0.00 15:02:17 14:56:01 lo 16.11 16.11 7.00 7.00 0.00 0.00 0.00 0.00 15:02:17 14:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:57:01 ens3 0.55 0.70 0.10 0.12 0.00 0.00 0.00 0.00 15:02:17 14:57:01 lo 23.65 23.65 8.87 8.87 0.00 0.00 0.00 0.00 15:02:17 14:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:58:01 ens3 1.20 1.53 0.23 0.25 0.00 0.00 0.00 0.00 15:02:17 14:58:01 lo 9.95 9.95 7.84 7.84 0.00 0.00 0.00 0.00 15:02:17 14:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 14:59:01 ens3 0.70 0.93 0.19 0.20 0.00 0.00 0.00 0.00 15:02:17 14:59:01 lo 28.85 28.85 10.92 10.92 0.00 0.00 0.00 0.00 15:02:17 14:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 15:00:01 ens3 0.88 0.95 0.12 0.13 0.00 0.00 0.00 0.00 15:02:17 15:00:01 lo 6.61 6.61 1.36 1.36 0.00 0.00 0.00 0.00 15:02:17 15:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 15:01:01 ens3 0.65 0.78 0.37 0.11 0.00 0.00 0.00 0.00 15:02:17 15:01:01 lo 16.50 16.50 16.65 16.65 0.00 0.00 0.00 0.00 15:02:17 15:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 15:02:02 ens3 18.38 18.73 12.14 17.48 0.00 0.00 0.00 0.00 15:02:17 15:02:02 lo 3.88 3.88 1.94 1.94 0.00 0.00 0.00 0.00 15:02:17 15:02:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 Average: ens3 15.02 10.96 211.13 1.46 0.00 0.00 0.00 0.00 15:02:17 Average: lo 20.04 20.04 9.26 9.26 0.00 0.00 0.00 0.00 15:02:17 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:02:17 15:02:17 15:02:17 ---> sar -P ALL: 15:02:17 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-2872) 10/30/24 _x86_64_ (4 CPU) 15:02:17 15:02:17 13:23:01 LINUX RESTART (4 CPU) 15:02:17 15:02:17 13:24:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 13:25:01 all 15.57 6.86 6.83 2.11 0.08 68.55 15:02:17 13:25:01 0 4.63 6.87 6.21 1.03 0.08 81.18 15:02:17 13:25:01 1 12.37 7.12 6.82 0.82 0.08 72.77 15:02:17 13:25:01 2 3.39 7.42 6.25 3.86 0.07 79.01 15:02:17 13:25:01 3 41.98 6.04 8.03 2.73 0.10 41.11 15:02:17 13:26:01 all 69.41 0.00 5.00 3.85 0.09 21.64 15:02:17 13:26:01 0 68.63 0.00 4.85 3.21 0.08 23.23 15:02:17 13:26:01 1 66.17 0.00 4.67 4.27 0.10 24.79 15:02:17 13:26:01 2 68.38 0.00 5.42 4.43 0.08 21.69 15:02:17 13:26:01 3 74.46 0.00 5.05 3.51 0.10 16.88 15:02:17 13:27:01 all 60.21 0.00 2.28 1.15 0.13 36.23 15:02:17 13:27:01 0 57.73 0.00 2.22 0.25 0.13 39.67 15:02:17 13:27:01 1 59.39 0.00 2.19 3.40 0.15 34.87 15:02:17 13:27:01 2 64.13 0.00 2.03 0.59 0.13 33.11 15:02:17 13:27:01 3 59.62 0.00 2.67 0.37 0.10 37.25 15:02:17 13:28:01 all 76.45 0.00 4.48 8.95 0.13 9.99 15:02:17 13:28:01 0 76.76 0.00 4.63 13.01 0.14 5.46 15:02:17 13:28:01 1 75.13 0.00 5.10 7.54 0.12 12.12 15:02:17 13:28:01 2 78.51 0.00 4.36 10.97 0.10 6.06 15:02:17 13:28:01 3 75.40 0.00 3.84 4.31 0.15 16.31 15:02:17 13:29:01 all 79.03 0.00 4.53 9.46 0.15 6.82 15:02:17 13:29:01 0 77.33 0.00 4.60 8.71 0.15 9.21 15:02:17 13:29:01 1 78.43 0.00 4.57 8.61 0.14 8.25 15:02:17 13:29:01 2 79.29 0.00 4.70 10.72 0.12 5.17 15:02:17 13:29:01 3 81.09 0.00 4.27 9.82 0.20 4.63 15:02:17 13:30:01 all 51.48 0.00 1.76 1.88 0.12 44.76 15:02:17 13:30:01 0 51.79 0.00 1.56 2.40 0.12 44.14 15:02:17 13:30:01 1 52.83 0.00 2.17 0.69 0.12 44.20 15:02:17 13:30:01 2 52.36 0.00 1.90 3.84 0.13 41.76 15:02:17 13:30:01 3 48.94 0.00 1.39 0.60 0.12 48.94 15:02:17 13:31:01 all 26.64 0.00 1.19 0.36 0.09 71.71 15:02:17 13:31:01 0 27.60 0.00 1.26 1.22 0.08 69.84 15:02:17 13:31:01 1 26.22 0.00 1.06 0.00 0.10 72.62 15:02:17 13:31:01 2 28.14 0.00 1.22 0.17 0.10 70.37 15:02:17 13:31:01 3 24.60 0.00 1.24 0.07 0.08 74.01 15:02:17 13:32:01 all 37.39 0.00 1.24 0.39 0.11 60.87 15:02:17 13:32:01 0 37.34 0.00 1.26 1.29 0.12 59.99 15:02:17 13:32:01 1 37.85 0.00 1.25 0.07 0.12 60.71 15:02:17 13:32:01 2 39.48 0.00 1.14 0.00 0.10 59.28 15:02:17 13:32:01 3 34.89 0.00 1.32 0.20 0.12 63.47 15:02:17 13:33:01 all 74.45 0.00 2.35 0.47 0.10 22.63 15:02:17 13:33:01 0 75.66 0.00 2.16 1.19 0.10 20.89 15:02:17 13:33:01 1 73.56 0.00 2.04 0.38 0.10 23.92 15:02:17 13:33:01 2 75.42 0.00 2.62 0.12 0.12 21.73 15:02:17 13:33:01 3 73.16 0.00 2.58 0.19 0.10 23.97 15:02:17 13:34:01 all 5.64 0.00 0.29 0.02 0.10 93.95 15:02:17 13:34:01 0 5.75 0.00 0.34 0.03 0.10 93.78 15:02:17 13:34:01 1 5.70 0.00 0.22 0.05 0.10 93.94 15:02:17 13:34:01 2 5.76 0.00 0.32 0.00 0.10 93.82 15:02:17 13:34:01 3 5.36 0.00 0.27 0.00 0.10 94.27 15:02:17 13:35:01 all 28.80 0.00 1.08 0.28 0.10 69.73 15:02:17 13:35:01 0 27.85 0.00 1.29 0.47 0.10 70.29 15:02:17 13:35:01 1 30.02 0.00 1.07 0.60 0.10 68.21 15:02:17 13:35:01 2 29.51 0.00 0.94 0.02 0.12 69.42 15:02:17 13:35:01 3 27.84 0.00 1.01 0.03 0.10 71.01 15:02:17 15:02:17 13:35:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 13:36:01 all 22.97 0.00 0.94 0.26 0.10 75.73 15:02:17 13:36:01 0 18.96 0.00 1.07 0.12 0.10 79.75 15:02:17 13:36:01 1 21.59 0.00 0.84 0.40 0.10 77.07 15:02:17 13:36:01 2 26.68 0.00 0.89 0.10 0.10 72.23 15:02:17 13:36:01 3 24.64 0.00 0.95 0.44 0.12 73.86 15:02:17 13:37:01 all 31.32 0.00 1.18 0.51 0.11 66.88 15:02:17 13:37:01 0 30.90 0.00 1.14 0.18 0.12 67.66 15:02:17 13:37:01 1 30.25 0.00 1.00 1.62 0.10 67.02 15:02:17 13:37:01 2 31.20 0.00 1.25 0.20 0.12 67.23 15:02:17 13:37:01 3 32.92 0.00 1.33 0.02 0.12 65.62 15:02:17 13:38:01 all 0.82 0.00 0.28 0.01 0.08 98.81 15:02:17 13:38:01 0 1.04 0.00 0.42 0.00 0.07 98.47 15:02:17 13:38:01 1 0.92 0.00 0.34 0.03 0.10 98.61 15:02:17 13:38:01 2 0.64 0.00 0.23 0.00 0.10 99.03 15:02:17 13:38:01 3 0.67 0.00 0.13 0.00 0.07 99.13 15:02:17 13:39:01 all 0.64 0.00 0.24 0.01 0.10 99.01 15:02:17 13:39:01 0 0.96 0.00 0.37 0.00 0.10 98.57 15:02:17 13:39:01 1 0.56 0.00 0.27 0.03 0.10 99.04 15:02:17 13:39:01 2 0.62 0.00 0.20 0.00 0.10 99.08 15:02:17 13:39:01 3 0.42 0.00 0.13 0.02 0.08 99.35 15:02:17 13:40:01 all 0.59 0.00 0.26 0.01 0.10 99.02 15:02:17 13:40:01 0 0.57 0.00 0.25 0.00 0.10 99.08 15:02:17 13:40:01 1 0.69 0.00 0.27 0.02 0.12 98.91 15:02:17 13:40:01 2 0.54 0.00 0.20 0.00 0.08 99.18 15:02:17 13:40:01 3 0.59 0.00 0.34 0.03 0.12 98.93 15:02:17 13:41:01 all 44.48 0.00 1.62 0.31 0.10 53.48 15:02:17 13:41:01 0 44.93 0.00 1.69 0.05 0.10 53.23 15:02:17 13:41:01 1 42.24 0.00 1.38 0.10 0.10 56.18 15:02:17 13:41:01 2 48.05 0.00 1.64 0.64 0.12 49.56 15:02:17 13:41:01 3 42.69 0.00 1.78 0.47 0.10 54.96 15:02:17 13:42:01 all 31.73 0.00 1.08 0.89 0.13 66.17 15:02:17 13:42:01 0 29.98 0.00 0.93 0.00 0.13 68.95 15:02:17 13:42:01 1 35.10 0.00 1.04 1.09 0.12 62.65 15:02:17 13:42:01 2 33.46 0.00 1.31 2.39 0.12 62.73 15:02:17 13:42:01 3 28.41 0.00 1.05 0.08 0.13 70.32 15:02:17 13:43:01 all 4.80 0.00 0.39 0.02 0.08 94.70 15:02:17 13:43:01 0 4.19 0.00 0.37 0.00 0.07 95.38 15:02:17 13:43:01 1 4.43 0.00 0.44 0.00 0.08 95.05 15:02:17 13:43:01 2 5.46 0.00 0.39 0.05 0.08 94.02 15:02:17 13:43:01 3 5.13 0.00 0.39 0.03 0.08 94.37 15:02:17 13:44:01 all 27.54 0.00 0.96 0.38 0.09 71.03 15:02:17 13:44:01 0 27.71 0.00 0.83 0.15 0.08 71.22 15:02:17 13:44:01 1 28.81 0.00 0.77 0.05 0.10 70.27 15:02:17 13:44:01 2 26.95 0.00 1.34 1.26 0.10 70.35 15:02:17 13:44:01 3 26.68 0.00 0.90 0.05 0.08 72.29 15:02:17 13:45:01 all 28.11 0.00 0.96 0.35 0.10 70.49 15:02:17 13:45:01 0 26.55 0.00 1.16 1.18 0.10 71.01 15:02:17 13:45:01 1 28.72 0.00 1.09 0.00 0.10 70.09 15:02:17 13:45:01 2 29.01 0.00 0.84 0.00 0.08 70.07 15:02:17 13:45:01 3 28.16 0.00 0.74 0.20 0.10 70.80 15:02:17 13:46:01 all 1.73 0.00 0.14 0.02 0.08 98.04 15:02:17 13:46:01 0 2.13 0.00 0.20 0.03 0.07 97.57 15:02:17 13:46:01 1 1.57 0.00 0.08 0.00 0.07 98.28 15:02:17 13:46:01 2 1.58 0.00 0.13 0.02 0.10 98.17 15:02:17 13:46:01 3 1.64 0.00 0.15 0.02 0.07 98.13 15:02:17 15:02:17 13:46:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 13:47:01 all 63.33 0.00 2.14 0.71 0.13 33.70 15:02:17 13:47:01 0 62.61 0.00 2.42 1.69 0.14 33.15 15:02:17 13:47:01 1 64.23 0.00 2.13 0.51 0.14 33.00 15:02:17 13:47:01 2 63.65 0.00 1.77 0.02 0.12 34.45 15:02:17 13:47:01 3 62.82 0.00 2.24 0.61 0.14 34.20 15:02:17 13:48:01 all 7.14 0.00 0.26 0.02 0.07 92.52 15:02:17 13:48:01 0 7.15 0.00 0.30 0.00 0.07 92.48 15:02:17 13:48:01 1 7.16 0.00 0.28 0.02 0.08 92.46 15:02:17 13:48:01 2 6.81 0.00 0.22 0.00 0.07 92.90 15:02:17 13:48:01 3 7.42 0.00 0.22 0.05 0.07 92.24 15:02:17 13:49:01 all 37.57 0.00 1.19 0.49 0.10 60.64 15:02:17 13:49:01 0 36.09 0.00 1.12 0.10 0.10 62.59 15:02:17 13:49:01 1 37.75 0.00 1.56 0.05 0.10 60.54 15:02:17 13:49:01 2 37.84 0.00 1.06 0.00 0.10 61.00 15:02:17 13:49:01 3 38.63 0.00 1.00 1.82 0.10 58.44 15:02:17 13:50:01 all 21.63 0.00 0.86 0.08 0.09 77.34 15:02:17 13:50:01 0 22.38 0.00 0.87 0.03 0.08 76.63 15:02:17 13:50:01 1 22.23 0.00 0.72 0.00 0.08 76.97 15:02:17 13:50:01 2 19.71 0.00 0.99 0.17 0.10 79.03 15:02:17 13:50:01 3 22.19 0.00 0.87 0.10 0.10 76.74 15:02:17 13:51:01 all 33.36 0.00 1.25 0.28 0.12 64.99 15:02:17 13:51:01 0 34.18 0.00 1.62 0.27 0.13 63.80 15:02:17 13:51:01 1 33.67 0.00 0.87 0.13 0.12 65.20 15:02:17 13:51:01 2 30.64 0.00 1.33 0.20 0.12 67.72 15:02:17 13:51:01 3 34.96 0.00 1.17 0.54 0.10 63.23 15:02:17 13:52:01 all 4.82 0.00 0.40 0.03 0.08 94.66 15:02:17 13:52:01 0 4.92 0.00 0.42 0.00 0.07 94.60 15:02:17 13:52:01 1 4.73 0.00 0.38 0.03 0.12 94.74 15:02:17 13:52:01 2 4.96 0.00 0.52 0.00 0.08 94.44 15:02:17 13:52:01 3 4.69 0.00 0.28 0.08 0.07 94.87 15:02:17 13:53:01 all 18.50 0.00 0.86 0.02 0.09 80.53 15:02:17 13:53:01 0 19.50 0.00 0.87 0.00 0.12 79.51 15:02:17 13:53:01 1 18.30 0.00 0.93 0.02 0.07 80.68 15:02:17 13:53:01 2 17.74 0.00 0.85 0.00 0.07 81.34 15:02:17 13:53:01 3 18.46 0.00 0.78 0.08 0.10 80.58 15:02:17 13:54:01 all 37.73 0.00 1.14 0.56 0.10 60.47 15:02:17 13:54:01 0 34.60 0.00 0.94 0.13 0.10 64.23 15:02:17 13:54:01 1 36.88 0.00 1.16 0.72 0.10 61.14 15:02:17 13:54:01 2 39.82 0.00 0.91 0.00 0.10 59.17 15:02:17 13:54:01 3 39.63 0.00 1.57 1.39 0.08 57.32 15:02:17 13:55:01 all 2.47 0.00 0.25 0.03 0.08 97.16 15:02:17 13:55:01 0 2.56 0.00 0.32 0.00 0.08 97.04 15:02:17 13:55:01 1 2.13 0.00 0.27 0.00 0.08 97.52 15:02:17 13:55:01 2 2.40 0.00 0.22 0.00 0.08 97.29 15:02:17 13:55:01 3 2.81 0.00 0.20 0.13 0.07 96.79 15:02:17 13:56:01 all 3.76 0.00 0.28 0.03 0.08 95.85 15:02:17 13:56:01 0 3.87 0.00 0.35 0.00 0.10 95.67 15:02:17 13:56:01 1 3.16 0.00 0.25 0.00 0.05 96.54 15:02:17 13:56:01 2 3.88 0.00 0.28 0.03 0.08 95.72 15:02:17 13:56:01 3 4.12 0.00 0.25 0.10 0.07 95.46 15:02:17 13:57:01 all 1.37 0.00 0.25 0.04 0.08 98.26 15:02:17 13:57:01 0 1.83 0.00 0.42 0.00 0.08 97.67 15:02:17 13:57:01 1 1.18 0.00 0.23 0.00 0.08 98.50 15:02:17 13:57:01 2 1.35 0.00 0.10 0.02 0.07 98.47 15:02:17 13:57:01 3 1.12 0.00 0.23 0.15 0.08 98.42 15:02:17 15:02:17 13:57:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 13:58:01 all 3.63 0.00 0.30 0.05 0.07 95.95 15:02:17 13:58:01 0 3.74 0.00 0.28 0.00 0.08 95.89 15:02:17 13:58:01 1 4.47 0.00 0.37 0.00 0.08 95.08 15:02:17 13:58:01 2 3.27 0.00 0.28 0.02 0.07 96.36 15:02:17 13:58:01 3 3.02 0.00 0.27 0.20 0.05 96.46 15:02:17 13:59:01 all 1.47 0.00 0.24 0.03 0.06 98.21 15:02:17 13:59:01 0 1.47 0.00 0.32 0.00 0.07 98.15 15:02:17 13:59:01 1 1.25 0.00 0.17 0.00 0.05 98.53 15:02:17 13:59:01 2 1.59 0.00 0.20 0.02 0.05 98.14 15:02:17 13:59:01 3 1.57 0.00 0.27 0.08 0.07 98.01 15:02:17 14:00:01 all 2.31 0.00 0.27 0.01 0.08 97.33 15:02:17 14:00:01 0 2.15 0.00 0.30 0.00 0.08 97.47 15:02:17 14:00:01 1 2.07 0.00 0.32 0.00 0.08 97.53 15:02:17 14:00:01 2 1.52 0.00 0.30 0.02 0.08 98.08 15:02:17 14:00:01 3 3.47 0.00 0.18 0.03 0.07 96.25 15:02:17 14:01:01 all 4.31 0.00 0.45 0.07 0.07 95.09 15:02:17 14:01:01 0 4.49 0.00 0.68 0.00 0.10 94.72 15:02:17 14:01:01 1 3.64 0.00 0.48 0.00 0.07 95.81 15:02:17 14:01:01 2 3.93 0.00 0.40 0.02 0.08 95.57 15:02:17 14:01:01 3 5.18 0.00 0.23 0.26 0.05 94.27 15:02:17 14:02:01 all 46.69 0.00 1.45 0.43 0.10 51.33 15:02:17 14:02:01 0 40.93 0.00 1.26 0.00 0.10 57.71 15:02:17 14:02:01 1 48.89 0.00 1.17 0.02 0.10 49.82 15:02:17 14:02:01 2 48.78 0.00 1.76 0.49 0.10 48.87 15:02:17 14:02:01 3 48.14 0.00 1.60 1.23 0.12 48.91 15:02:17 14:03:01 all 7.86 0.00 0.50 0.12 0.09 91.44 15:02:17 14:03:01 0 6.92 0.00 0.45 0.03 0.05 92.54 15:02:17 14:03:01 1 8.10 0.00 0.47 0.02 0.08 91.33 15:02:17 14:03:01 2 8.19 0.00 0.69 0.20 0.12 90.81 15:02:17 14:03:01 3 8.21 0.00 0.38 0.23 0.10 91.07 15:02:17 14:04:01 all 5.49 0.00 0.40 0.03 0.17 93.91 15:02:17 14:04:01 0 5.09 0.00 0.45 0.00 0.45 94.02 15:02:17 14:04:01 1 5.33 0.00 0.28 0.00 0.07 94.32 15:02:17 14:04:01 2 6.14 0.00 0.49 0.00 0.08 93.29 15:02:17 14:04:01 3 5.41 0.00 0.37 0.12 0.08 94.03 15:02:17 14:05:01 all 2.65 0.00 0.32 0.07 0.07 96.90 15:02:17 14:05:01 0 2.83 0.00 0.38 0.00 0.07 96.72 15:02:17 14:05:01 1 2.73 0.00 0.35 0.00 0.07 96.85 15:02:17 14:05:01 2 2.43 0.00 0.22 0.00 0.07 97.28 15:02:17 14:05:01 3 2.59 0.00 0.32 0.27 0.07 96.75 15:02:17 14:06:01 all 2.58 0.00 0.28 0.02 0.08 97.05 15:02:17 14:06:01 0 3.08 0.00 0.20 0.00 0.07 96.65 15:02:17 14:06:01 1 2.23 0.00 0.27 0.00 0.07 97.44 15:02:17 14:06:01 2 2.72 0.00 0.33 0.02 0.08 96.85 15:02:17 14:06:01 3 2.29 0.00 0.30 0.07 0.08 97.26 15:02:17 14:07:01 all 1.96 0.00 0.30 0.01 0.07 97.67 15:02:17 14:07:01 0 3.45 0.00 0.26 0.00 0.07 96.22 15:02:17 14:07:01 1 1.32 0.00 0.27 0.00 0.07 98.35 15:02:17 14:07:01 2 1.62 0.00 0.43 0.00 0.07 97.88 15:02:17 14:07:01 3 1.42 0.00 0.23 0.03 0.07 98.25 15:02:17 14:08:01 all 4.28 0.00 0.38 0.05 0.09 95.20 15:02:17 14:08:01 0 4.52 0.00 0.40 0.00 0.08 94.99 15:02:17 14:08:01 1 4.19 0.00 0.40 0.00 0.08 95.32 15:02:17 14:08:01 2 4.30 0.00 0.47 0.02 0.10 95.12 15:02:17 14:08:01 3 4.10 0.00 0.25 0.20 0.08 95.37 15:02:17 15:02:17 14:08:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 14:09:01 all 37.31 0.00 1.42 0.07 0.10 61.10 15:02:17 14:09:01 0 38.35 0.00 1.61 0.00 0.10 59.94 15:02:17 14:09:01 1 34.29 0.00 1.28 0.17 0.10 64.17 15:02:17 14:09:01 2 38.89 0.00 1.60 0.00 0.10 59.41 15:02:17 14:09:01 3 37.77 0.00 1.19 0.10 0.10 60.84 15:02:17 14:10:01 all 27.51 0.00 0.88 0.24 0.10 71.27 15:02:17 14:10:01 0 26.21 0.00 1.20 0.42 0.10 72.07 15:02:17 14:10:01 1 27.56 0.00 0.70 0.52 0.10 71.12 15:02:17 14:10:01 2 27.51 0.00 0.77 0.02 0.08 71.62 15:02:17 14:10:01 3 28.74 0.00 0.87 0.00 0.13 70.26 15:02:17 14:11:01 all 8.63 0.00 0.34 0.04 0.08 90.91 15:02:17 14:11:01 0 8.34 0.00 0.30 0.00 0.07 91.29 15:02:17 14:11:01 1 9.08 0.00 0.35 0.15 0.10 90.32 15:02:17 14:11:01 2 7.78 0.00 0.40 0.00 0.08 91.74 15:02:17 14:11:01 3 9.33 0.00 0.30 0.00 0.07 90.30 15:02:17 14:12:01 all 4.29 0.00 0.35 0.00 0.08 95.28 15:02:17 14:12:01 0 4.35 0.00 0.43 0.00 0.10 95.12 15:02:17 14:12:01 1 4.13 0.00 0.37 0.02 0.08 95.41 15:02:17 14:12:01 2 4.36 0.00 0.23 0.00 0.07 95.34 15:02:17 14:12:01 3 4.32 0.00 0.35 0.00 0.07 95.26 15:02:17 14:13:01 all 2.69 0.00 0.30 0.05 0.08 96.89 15:02:17 14:13:01 0 2.50 0.00 0.28 0.00 0.07 97.14 15:02:17 14:13:01 1 2.26 0.00 0.32 0.12 0.08 97.22 15:02:17 14:13:01 2 2.87 0.00 0.30 0.00 0.07 96.76 15:02:17 14:13:01 3 3.11 0.00 0.30 0.07 0.10 96.42 15:02:17 14:14:01 all 4.25 0.00 0.33 0.03 0.08 95.31 15:02:17 14:14:01 0 3.95 0.00 0.30 0.00 0.08 95.66 15:02:17 14:14:01 1 4.22 0.00 0.35 0.07 0.07 95.29 15:02:17 14:14:01 2 4.53 0.00 0.23 0.03 0.08 95.12 15:02:17 14:14:01 3 4.29 0.00 0.45 0.00 0.08 95.18 15:02:17 14:15:01 all 2.56 0.00 0.33 0.03 0.06 97.01 15:02:17 14:15:01 0 2.33 0.00 0.27 0.00 0.07 97.34 15:02:17 14:15:01 1 2.69 0.00 0.38 0.00 0.07 96.86 15:02:17 14:15:01 2 2.61 0.00 0.35 0.10 0.05 96.88 15:02:17 14:15:01 3 2.62 0.00 0.33 0.00 0.07 96.98 15:02:17 14:16:01 all 2.17 0.00 0.30 0.01 0.06 97.46 15:02:17 14:16:01 0 1.62 0.00 0.18 0.00 0.03 98.17 15:02:17 14:16:01 1 2.14 0.00 0.32 0.00 0.07 97.48 15:02:17 14:16:01 2 2.89 0.00 0.35 0.03 0.07 96.66 15:02:17 14:16:01 3 2.04 0.00 0.35 0.00 0.08 97.52 15:02:17 14:17:01 all 26.13 0.00 1.01 0.05 0.09 72.72 15:02:17 14:17:01 0 25.60 0.00 0.75 0.03 0.10 73.51 15:02:17 14:17:01 1 25.53 0.00 1.27 0.00 0.10 73.10 15:02:17 14:17:01 2 26.08 0.00 1.11 0.18 0.08 72.54 15:02:17 14:17:01 3 27.29 0.00 0.90 0.00 0.08 71.72 15:02:17 14:18:01 all 35.98 0.00 1.11 0.27 0.10 62.53 15:02:17 14:18:01 0 36.48 0.00 0.92 0.27 0.10 62.23 15:02:17 14:18:01 1 36.40 0.00 1.12 0.00 0.08 62.39 15:02:17 14:18:01 2 34.47 0.00 0.94 0.27 0.10 64.22 15:02:17 14:18:01 3 36.59 0.00 1.47 0.54 0.12 61.28 15:02:17 14:19:01 all 8.59 0.00 0.29 0.06 0.08 90.97 15:02:17 14:19:01 0 8.99 0.00 0.32 0.05 0.10 90.54 15:02:17 14:19:01 1 8.32 0.00 0.30 0.00 0.08 91.29 15:02:17 14:19:01 2 7.68 0.00 0.30 0.00 0.07 91.96 15:02:17 14:19:01 3 9.40 0.00 0.25 0.20 0.07 90.08 15:02:17 15:02:17 14:19:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 14:20:01 all 4.12 0.00 0.19 0.03 0.08 95.58 15:02:17 14:20:01 0 4.08 0.00 0.20 0.02 0.07 95.64 15:02:17 14:20:01 1 3.82 0.00 0.15 0.00 0.07 95.96 15:02:17 14:20:01 2 4.24 0.00 0.20 0.00 0.08 95.47 15:02:17 14:20:01 3 4.34 0.00 0.22 0.08 0.10 95.26 15:02:17 14:21:01 all 2.28 0.00 0.17 0.01 0.08 97.46 15:02:17 14:21:01 0 1.95 0.00 0.20 0.02 0.08 97.75 15:02:17 14:21:01 1 2.28 0.00 0.17 0.00 0.10 97.45 15:02:17 14:21:01 2 2.60 0.00 0.13 0.00 0.08 97.18 15:02:17 14:21:01 3 2.29 0.00 0.18 0.02 0.07 97.44 15:02:17 14:22:01 all 2.68 0.00 0.20 0.02 0.07 97.04 15:02:17 14:22:01 0 2.64 0.00 0.20 0.00 0.08 97.07 15:02:17 14:22:01 1 2.87 0.00 0.18 0.00 0.05 96.90 15:02:17 14:22:01 2 2.45 0.00 0.20 0.02 0.07 97.27 15:02:17 14:22:01 3 2.77 0.00 0.20 0.05 0.07 96.91 15:02:17 14:23:01 all 1.10 0.00 0.13 0.03 0.08 98.66 15:02:17 14:23:01 0 1.41 0.00 0.15 0.00 0.08 98.36 15:02:17 14:23:01 1 1.21 0.00 0.15 0.05 0.08 98.51 15:02:17 14:23:01 2 0.79 0.00 0.13 0.00 0.07 99.01 15:02:17 14:23:01 3 1.01 0.00 0.08 0.05 0.08 98.78 15:02:17 14:24:01 all 2.83 0.00 0.20 0.06 0.08 96.83 15:02:17 14:24:01 0 3.13 0.00 0.18 0.00 0.07 96.62 15:02:17 14:24:01 1 3.13 0.00 0.25 0.00 0.07 96.55 15:02:17 14:24:01 2 2.34 0.00 0.13 0.18 0.08 97.26 15:02:17 14:24:01 3 2.70 0.00 0.23 0.07 0.08 96.91 15:02:17 14:25:01 all 0.98 0.00 0.13 0.01 0.07 98.81 15:02:17 14:25:01 0 1.05 0.00 0.13 0.00 0.05 98.76 15:02:17 14:25:01 1 1.09 0.00 0.10 0.00 0.08 98.72 15:02:17 14:25:01 2 0.80 0.00 0.12 0.02 0.05 99.01 15:02:17 14:25:01 3 0.96 0.00 0.18 0.02 0.08 98.76 15:02:17 14:26:01 all 3.15 0.00 0.21 0.01 0.09 96.54 15:02:17 14:26:01 0 2.63 0.00 0.17 0.00 0.10 97.10 15:02:17 14:26:01 1 3.77 0.00 0.25 0.00 0.08 95.90 15:02:17 14:26:01 2 3.02 0.00 0.15 0.02 0.08 96.73 15:02:17 14:26:01 3 3.18 0.00 0.27 0.03 0.08 96.44 15:02:17 14:27:01 all 0.60 0.00 0.11 0.04 0.07 99.17 15:02:17 14:27:01 0 0.64 0.00 0.10 0.00 0.07 99.19 15:02:17 14:27:01 1 0.40 0.00 0.10 0.00 0.08 99.41 15:02:17 14:27:01 2 0.55 0.00 0.13 0.15 0.07 99.09 15:02:17 14:27:01 3 0.82 0.00 0.12 0.00 0.07 99.00 15:02:17 14:28:01 all 0.23 0.00 0.11 0.06 0.07 99.52 15:02:17 14:28:01 0 0.32 0.00 0.13 0.02 0.07 99.46 15:02:17 14:28:01 1 0.25 0.00 0.12 0.00 0.07 99.56 15:02:17 14:28:01 2 0.12 0.00 0.08 0.23 0.08 99.48 15:02:17 14:28:01 3 0.23 0.00 0.12 0.00 0.07 99.58 15:02:17 14:29:01 all 0.22 0.00 0.12 0.02 0.07 99.57 15:02:17 14:29:01 0 0.22 0.00 0.03 0.00 0.05 99.70 15:02:17 14:29:01 1 0.28 0.00 0.12 0.00 0.05 99.55 15:02:17 14:29:01 2 0.17 0.00 0.20 0.08 0.08 99.46 15:02:17 14:29:01 3 0.22 0.00 0.12 0.00 0.08 99.58 15:02:17 14:30:01 all 26.12 0.00 1.13 0.20 0.09 72.46 15:02:17 14:30:01 0 25.82 0.00 1.43 0.12 0.10 72.53 15:02:17 14:30:01 1 20.34 0.00 1.17 0.30 0.10 78.08 15:02:17 14:30:01 2 25.23 0.00 1.12 0.30 0.08 73.26 15:02:17 14:30:01 3 33.09 0.00 0.81 0.08 0.08 65.93 15:02:17 15:02:17 14:30:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 14:31:01 all 36.86 0.00 1.13 0.64 0.11 61.25 15:02:17 14:31:01 0 38.52 0.00 1.17 0.27 0.10 59.93 15:02:17 14:31:01 1 35.33 0.00 1.04 1.07 0.10 62.45 15:02:17 14:31:01 2 35.17 0.00 1.06 1.21 0.12 62.45 15:02:17 14:31:01 3 38.41 0.00 1.25 0.03 0.12 60.19 15:02:17 14:32:01 all 4.96 0.00 0.38 0.03 0.07 94.56 15:02:17 14:32:01 0 5.04 0.00 0.40 0.03 0.07 94.46 15:02:17 14:32:01 1 4.83 0.00 0.33 0.08 0.07 94.68 15:02:17 14:32:01 2 5.08 0.00 0.47 0.02 0.08 94.35 15:02:17 14:32:01 3 4.90 0.00 0.30 0.00 0.07 94.73 15:02:17 14:33:01 all 48.47 0.00 1.51 0.30 0.10 49.61 15:02:17 14:33:01 0 43.39 0.00 1.25 0.05 0.12 55.20 15:02:17 14:33:01 1 46.27 0.00 1.54 0.67 0.12 51.40 15:02:17 14:33:01 2 52.31 0.00 1.81 0.45 0.10 45.33 15:02:17 14:33:01 3 51.95 0.00 1.46 0.02 0.08 46.49 15:02:17 14:34:01 all 8.92 0.00 0.32 0.01 0.08 90.68 15:02:17 14:34:01 0 8.69 0.00 0.32 0.00 0.07 90.92 15:02:17 14:34:01 1 8.71 0.00 0.40 0.03 0.08 90.77 15:02:17 14:34:01 2 9.11 0.00 0.22 0.00 0.07 90.60 15:02:17 14:34:01 3 9.18 0.00 0.34 0.00 0.08 90.40 15:02:17 14:35:01 all 2.32 0.00 0.16 0.00 0.08 97.44 15:02:17 14:35:01 0 2.45 0.00 0.13 0.00 0.08 97.34 15:02:17 14:35:01 1 2.49 0.00 0.17 0.00 0.08 97.26 15:02:17 14:35:01 2 1.91 0.00 0.18 0.00 0.07 97.84 15:02:17 14:35:01 3 2.43 0.00 0.13 0.02 0.07 97.35 15:02:17 14:36:01 all 3.08 0.00 0.24 0.12 0.06 96.50 15:02:17 14:36:01 0 3.09 0.00 0.27 0.28 0.05 96.31 15:02:17 14:36:01 1 3.19 0.00 0.24 0.12 0.08 96.37 15:02:17 14:36:01 2 2.93 0.00 0.25 0.05 0.07 96.70 15:02:17 14:36:01 3 3.11 0.00 0.20 0.02 0.05 96.62 15:02:17 14:37:01 all 2.00 0.00 0.20 0.03 0.07 97.70 15:02:17 14:37:01 0 1.74 0.00 0.17 0.02 0.07 98.00 15:02:17 14:37:01 1 2.14 0.00 0.25 0.12 0.08 97.41 15:02:17 14:37:01 2 2.20 0.00 0.17 0.00 0.05 97.59 15:02:17 14:37:01 3 1.91 0.00 0.20 0.00 0.08 97.80 15:02:17 14:38:01 all 4.58 0.00 0.26 0.15 0.08 94.94 15:02:17 14:38:01 0 4.55 0.00 0.20 0.43 0.07 94.75 15:02:17 14:38:01 1 4.59 0.00 0.25 0.17 0.07 94.92 15:02:17 14:38:01 2 4.77 0.00 0.30 0.00 0.08 94.84 15:02:17 14:38:01 3 4.41 0.00 0.27 0.00 0.08 95.24 15:02:17 14:39:01 all 2.11 0.00 0.23 0.04 0.07 97.55 15:02:17 14:39:01 0 2.12 0.00 0.25 0.00 0.07 97.56 15:02:17 14:39:01 1 1.96 0.00 0.17 0.15 0.08 97.64 15:02:17 14:39:01 2 1.96 0.00 0.17 0.00 0.05 97.82 15:02:17 14:39:01 3 2.40 0.00 0.34 0.00 0.08 97.18 15:02:17 14:40:01 all 41.70 0.00 1.27 0.05 0.09 56.89 15:02:17 14:40:01 0 41.20 0.00 1.37 0.00 0.08 57.34 15:02:17 14:40:01 1 39.95 0.00 0.99 0.22 0.08 58.76 15:02:17 14:40:01 2 41.67 0.00 1.26 0.00 0.10 56.97 15:02:17 14:40:01 3 43.97 0.00 1.44 0.00 0.08 54.51 15:02:17 14:41:01 all 24.39 0.00 0.64 0.26 0.10 74.61 15:02:17 14:41:01 0 24.53 0.00 0.74 0.10 0.10 74.53 15:02:17 14:41:01 1 24.70 0.00 0.53 0.63 0.10 74.03 15:02:17 14:41:01 2 24.66 0.00 0.52 0.05 0.10 74.67 15:02:17 14:41:01 3 23.66 0.00 0.77 0.25 0.12 75.20 15:02:17 15:02:17 14:41:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 14:42:01 all 8.93 0.00 0.41 0.05 0.11 90.50 15:02:17 14:42:01 0 9.27 0.00 0.39 0.12 0.08 90.14 15:02:17 14:42:01 1 9.40 0.00 0.39 0.10 0.12 89.99 15:02:17 14:42:01 2 8.29 0.00 0.49 0.00 0.10 91.12 15:02:17 14:42:01 3 8.75 0.00 0.37 0.00 0.13 90.75 15:02:17 14:43:01 all 5.49 0.00 0.33 0.05 0.08 94.06 15:02:17 14:43:01 0 5.63 0.00 0.32 0.00 0.08 93.97 15:02:17 14:43:01 1 5.56 0.00 0.34 0.18 0.08 93.83 15:02:17 14:43:01 2 5.36 0.00 0.30 0.00 0.07 94.27 15:02:17 14:43:01 3 5.41 0.00 0.37 0.00 0.07 94.16 15:02:17 14:44:01 all 25.59 0.00 1.50 0.29 0.09 72.54 15:02:17 14:44:01 0 21.85 0.00 1.46 0.07 0.10 76.52 15:02:17 14:44:01 1 22.71 0.00 1.22 0.74 0.10 75.22 15:02:17 14:44:01 2 28.65 0.00 1.71 0.17 0.08 69.39 15:02:17 14:44:01 3 29.13 0.00 1.61 0.17 0.08 69.00 15:02:17 14:45:01 all 66.98 0.00 2.16 0.82 0.12 29.93 15:02:17 14:45:01 0 63.78 0.00 2.27 2.87 0.12 30.96 15:02:17 14:45:01 1 69.64 0.00 2.13 0.27 0.12 27.84 15:02:17 14:45:01 2 69.00 0.00 2.06 0.07 0.13 28.73 15:02:17 14:45:01 3 65.48 0.00 2.16 0.07 0.12 32.18 15:02:17 14:46:01 all 28.21 0.00 1.01 0.20 0.10 70.48 15:02:17 14:46:01 0 29.46 0.00 1.47 0.42 0.12 68.53 15:02:17 14:46:01 1 31.95 0.00 0.58 0.38 0.10 66.99 15:02:17 14:46:01 2 26.82 0.00 0.99 0.02 0.08 72.09 15:02:17 14:46:01 3 24.59 0.00 0.99 0.00 0.10 74.32 15:02:17 14:47:01 all 3.74 0.00 0.32 0.03 0.06 95.85 15:02:17 14:47:01 0 4.89 0.00 0.38 0.00 0.07 94.67 15:02:17 14:47:01 1 3.35 0.00 0.35 0.07 0.05 96.18 15:02:17 14:47:01 2 3.61 0.00 0.25 0.07 0.07 96.01 15:02:17 14:47:01 3 3.11 0.00 0.30 0.00 0.05 96.54 15:02:17 14:48:01 all 60.32 0.00 2.11 0.08 0.12 37.39 15:02:17 14:48:01 0 57.32 0.00 2.14 0.02 0.12 40.41 15:02:17 14:48:01 1 57.30 0.00 2.04 0.25 0.12 40.30 15:02:17 14:48:01 2 64.31 0.00 1.79 0.02 0.12 33.77 15:02:17 14:48:01 3 62.35 0.00 2.46 0.02 0.12 35.06 15:02:17 14:49:01 all 15.31 0.00 0.54 0.25 0.08 83.82 15:02:17 14:49:01 0 14.57 0.00 0.60 0.07 0.10 84.66 15:02:17 14:49:01 1 16.27 0.00 0.47 0.52 0.08 82.66 15:02:17 14:49:01 2 14.95 0.00 0.47 0.38 0.08 84.12 15:02:17 14:49:01 3 15.45 0.00 0.61 0.02 0.07 83.85 15:02:17 14:50:01 all 7.99 0.00 0.40 0.01 0.08 91.52 15:02:17 14:50:01 0 8.35 0.00 0.42 0.00 0.08 91.15 15:02:17 14:50:01 1 7.95 0.00 0.50 0.02 0.10 91.43 15:02:17 14:50:01 2 7.59 0.00 0.25 0.02 0.05 92.09 15:02:17 14:50:01 3 8.08 0.00 0.42 0.00 0.08 91.41 15:02:17 14:51:01 all 2.61 0.00 0.28 0.01 0.07 97.03 15:02:17 14:51:01 0 2.29 0.00 0.15 0.00 0.05 97.51 15:02:17 14:51:01 1 2.79 0.00 0.40 0.03 0.07 96.71 15:02:17 14:51:01 2 2.69 0.00 0.22 0.02 0.08 96.99 15:02:17 14:51:01 3 2.66 0.00 0.33 0.00 0.08 96.92 15:02:17 14:52:01 all 2.66 0.00 0.29 0.03 0.08 96.94 15:02:17 14:52:01 0 2.54 0.00 0.32 0.00 0.10 97.05 15:02:17 14:52:01 1 2.63 0.00 0.23 0.05 0.07 97.02 15:02:17 14:52:01 2 2.59 0.00 0.28 0.05 0.07 97.01 15:02:17 14:52:01 3 2.90 0.00 0.34 0.00 0.08 96.68 15:02:17 15:02:17 14:52:01 CPU %user %nice %system %iowait %steal %idle 15:02:17 14:53:01 all 0.79 0.00 0.17 0.00 0.07 98.97 15:02:17 14:53:01 0 1.72 0.00 0.23 0.00 0.08 97.97 15:02:17 14:53:01 1 0.37 0.00 0.20 0.00 0.05 99.38 15:02:17 14:53:01 2 0.47 0.00 0.12 0.00 0.07 99.35 15:02:17 14:53:01 3 0.59 0.00 0.15 0.00 0.08 99.18 15:02:17 14:54:01 all 1.00 0.00 0.22 0.01 0.07 98.70 15:02:17 14:54:01 0 0.40 0.00 0.17 0.00 0.08 99.35 15:02:17 14:54:01 1 0.40 0.00 0.13 0.03 0.05 99.38 15:02:17 14:54:01 2 0.90 0.00 0.45 0.00 0.10 98.55 15:02:17 14:54:01 3 2.28 0.00 0.15 0.00 0.05 97.52 15:02:17 14:55:01 all 25.93 0.00 1.12 0.03 0.10 72.83 15:02:17 14:55:01 0 27.17 0.00 1.14 0.05 0.12 71.52 15:02:17 14:55:01 1 23.88 0.00 1.08 0.02 0.08 74.93 15:02:17 14:55:01 2 26.06 0.00 0.89 0.02 0.08 72.96 15:02:17 14:55:01 3 26.60 0.00 1.38 0.03 0.10 71.88 15:02:17 14:56:01 all 48.36 0.00 1.56 0.33 0.10 49.65 15:02:17 14:56:01 0 49.48 0.00 1.49 0.15 0.10 48.78 15:02:17 14:56:01 1 48.59 0.00 1.42 0.69 0.10 49.21 15:02:17 14:56:01 2 45.79 0.00 1.41 0.02 0.10 52.69 15:02:17 14:56:01 3 49.57 0.00 1.94 0.45 0.12 47.92 15:02:17 14:57:01 all 7.03 0.00 0.43 0.02 0.08 92.44 15:02:17 14:57:01 0 7.07 0.00 0.42 0.00 0.07 92.45 15:02:17 14:57:01 1 7.03 0.00 0.38 0.03 0.08 92.47 15:02:17 14:57:01 2 6.86 0.00 0.35 0.05 0.08 92.66 15:02:17 14:57:01 3 7.18 0.00 0.57 0.00 0.07 92.19 15:02:17 14:58:01 all 1.75 0.00 0.32 0.01 0.08 97.84 15:02:17 14:58:01 0 1.63 0.00 0.38 0.00 0.10 97.88 15:02:17 14:58:01 1 1.82 0.00 0.27 0.02 0.07 97.83 15:02:17 14:58:01 2 1.78 0.00 0.33 0.03 0.07 97.78 15:02:17 14:58:01 3 1.77 0.00 0.30 0.00 0.08 97.85 15:02:17 14:59:01 all 3.92 0.00 0.30 0.01 0.09 95.68 15:02:17 14:59:01 0 3.90 0.00 0.20 0.00 0.05 95.85 15:02:17 14:59:01 1 3.74 0.00 0.35 0.03 0.08 95.79 15:02:17 14:59:01 2 4.22 0.00 0.37 0.02 0.10 95.29 15:02:17 14:59:01 3 3.81 0.00 0.27 0.00 0.12 95.81 15:02:17 15:00:01 all 56.09 0.00 1.93 0.05 0.11 41.82 15:02:17 15:00:01 0 56.69 0.00 1.74 0.03 0.10 41.43 15:02:17 15:00:01 1 54.20 0.00 2.14 0.12 0.12 43.42 15:02:17 15:00:01 2 56.59 0.00 1.76 0.05 0.10 41.50 15:02:17 15:00:01 3 56.88 0.00 2.06 0.02 0.12 40.93 15:02:17 15:01:01 all 20.34 0.00 0.66 0.29 0.09 78.63 15:02:17 15:01:01 0 20.20 0.00 0.85 0.00 0.10 78.85 15:02:17 15:01:01 1 21.42 0.00 0.55 0.00 0.08 77.95 15:02:17 15:01:01 2 18.96 0.00 0.69 1.15 0.08 79.11 15:02:17 15:01:01 3 20.76 0.00 0.53 0.00 0.08 78.62 15:02:17 15:02:02 all 18.15 0.00 1.16 0.95 0.08 79.67 15:02:17 15:02:02 0 11.07 0.00 1.10 0.40 0.08 87.34 15:02:17 15:02:02 1 25.54 0.00 1.15 0.48 0.07 72.75 15:02:17 15:02:02 2 23.98 0.00 1.40 2.34 0.08 72.19 15:02:17 15:02:02 3 11.98 0.00 0.97 0.57 0.07 86.42 15:02:17 Average: all 18.63 0.07 0.87 0.42 0.09 79.91 15:02:17 Average: 0 18.17 0.07 0.89 0.44 0.09 80.34 15:02:17 Average: 1 18.49 0.07 0.85 0.41 0.09 80.09 15:02:17 Average: 2 18.79 0.08 0.87 0.49 0.09 79.68 15:02:17 Average: 3 19.08 0.06 0.89 0.34 0.09 79.54 15:02:17 15:02:17 15:02:17