11:50:46 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/113906 11:50:46 Running as SYSTEM 11:50:46 [EnvInject] - Loading node environment variables. 11:50:46 Building remotely on prd-ubuntu2004-docker-4c-16g-43727 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 11:50:46 [ssh-agent] Looking for ssh-agent implementation... 11:50:46 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 11:50:46 $ ssh-agent 11:50:47 SSH_AUTH_SOCK=/tmp/ssh-eplh3vYfS4QG/agent.12373 11:50:47 SSH_AGENT_PID=12376 11:50:47 [ssh-agent] Started. 11:50:47 Running ssh-add (command line suppressed) 11:50:47 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_12281011902681021054.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_12281011902681021054.key) 11:50:47 [ssh-agent] Using credentials jenkins (jenkins-ssh) 11:50:47 The recommended git tool is: NONE 11:50:49 using credential jenkins-ssh 11:50:49 Wiping out workspace first. 11:50:49 Cloning the remote Git repository 11:50:49 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 11:50:49 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 11:50:49 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 11:50:49 > git --version # timeout=10 11:50:49 > git --version # 'git version 2.25.1' 11:50:49 using GIT_SSH to set credentials jenkins-ssh 11:50:49 Verifying host key using known hosts file 11:50:49 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. 11:50:49 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 11:50:54 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 11:50:54 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 11:50:54 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 11:50:54 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 11:50:54 using GIT_SSH to set credentials jenkins-ssh 11:50:54 Verifying host key using known hosts file 11:50:54 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. 11:50:54 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/06/113906/10 # timeout=10 11:50:54 > git rev-parse fc580132e0506837d64557e4ab9296915c933976^{commit} # timeout=10 11:50:54 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 11:50:54 Checking out Revision fc580132e0506837d64557e4ab9296915c933976 (refs/changes/06/113906/10) 11:50:54 > git config core.sparsecheckout # timeout=10 11:50:54 > git checkout -f fc580132e0506837d64557e4ab9296915c933976 # timeout=10 11:50:55 Commit message: "Add Tapi Abstracted Node to OR Topo" 11:50:55 > git rev-parse FETCH_HEAD^{commit} # timeout=10 11:50:55 > git rev-list --no-walk 9889c236444fdb4bb40abe9dc03a01d4dc69b802 # timeout=10 11:50:55 > git remote # timeout=10 11:50:55 > git submodule init # timeout=10 11:50:55 > git submodule sync # timeout=10 11:50:55 > git config --get remote.origin.url # timeout=10 11:50:55 > git submodule init # timeout=10 11:50:55 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 11:50:55 ERROR: No submodules found. 11:50:59 provisioning config files... 11:50:59 copy managed file [npmrc] to file:/home/jenkins/.npmrc 11:50:59 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 11:50:59 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins310939531827550551.sh 11:50:59 ---> python-tools-install.sh 11:50:59 Setup pyenv: 11:50:59 * system (set by /opt/pyenv/version) 11:50:59 * 3.8.13 (set by /opt/pyenv/version) 11:50:59 * 3.9.13 (set by /opt/pyenv/version) 11:50:59 * 3.10.13 (set by /opt/pyenv/version) 11:50:59 * 3.11.7 (set by /opt/pyenv/version) 11:51:04 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-2LOv 11:51:04 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 11:51:07 lf-activate-venv(): INFO: Installing: lftools 11:51:40 lf-activate-venv(): INFO: Adding /tmp/venv-2LOv/bin to PATH 11:51:40 Generating Requirements File 11:52:00 Python 3.11.7 11:52:01 pip 24.2 from /tmp/venv-2LOv/lib/python3.11/site-packages/pip (python 3.11) 11:52:01 appdirs==1.4.4 11:52:01 argcomplete==3.5.1 11:52:01 aspy.yaml==1.3.0 11:52:01 attrs==24.2.0 11:52:01 autopage==0.5.2 11:52:01 beautifulsoup4==4.12.3 11:52:01 boto3==1.35.43 11:52:01 botocore==1.35.43 11:52:01 bs4==0.0.2 11:52:01 cachetools==5.5.0 11:52:01 certifi==2024.8.30 11:52:01 cffi==1.17.1 11:52:01 cfgv==3.4.0 11:52:01 chardet==5.2.0 11:52:01 charset-normalizer==3.4.0 11:52:01 click==8.1.7 11:52:01 cliff==4.7.0 11:52:01 cmd2==2.4.3 11:52:01 cryptography==3.3.2 11:52:01 debtcollector==3.0.0 11:52:01 decorator==5.1.1 11:52:01 defusedxml==0.7.1 11:52:01 Deprecated==1.2.14 11:52:01 distlib==0.3.9 11:52:01 dnspython==2.7.0 11:52:01 docker==4.2.2 11:52:01 dogpile.cache==1.3.3 11:52:01 durationpy==0.9 11:52:01 email_validator==2.2.0 11:52:01 filelock==3.16.1 11:52:01 future==1.0.0 11:52:01 gitdb==4.0.11 11:52:01 GitPython==3.1.43 11:52:01 google-auth==2.35.0 11:52:01 httplib2==0.22.0 11:52:01 identify==2.6.1 11:52:01 idna==3.10 11:52:01 importlib-resources==1.5.0 11:52:01 iso8601==2.1.0 11:52:01 Jinja2==3.1.4 11:52:01 jmespath==1.0.1 11:52:01 jsonpatch==1.33 11:52:01 jsonpointer==3.0.0 11:52:01 jsonschema==4.23.0 11:52:01 jsonschema-specifications==2024.10.1 11:52:01 keystoneauth1==5.8.0 11:52:01 kubernetes==31.0.0 11:52:01 lftools==0.37.10 11:52:01 lxml==5.3.0 11:52:01 MarkupSafe==3.0.1 11:52:01 msgpack==1.1.0 11:52:01 multi_key_dict==2.0.3 11:52:01 munch==4.0.0 11:52:01 netaddr==1.3.0 11:52:01 netifaces==0.11.0 11:52:01 niet==1.4.2 11:52:01 nodeenv==1.9.1 11:52:01 oauth2client==4.1.3 11:52:01 oauthlib==3.2.2 11:52:01 openstacksdk==4.1.0 11:52:01 os-client-config==2.1.0 11:52:01 os-service-types==1.7.0 11:52:01 osc-lib==3.1.0 11:52:01 oslo.config==9.6.0 11:52:01 oslo.context==5.6.0 11:52:01 oslo.i18n==6.4.0 11:52:01 oslo.log==6.1.2 11:52:01 oslo.serialization==5.5.0 11:52:01 oslo.utils==7.3.0 11:52:01 packaging==24.1 11:52:01 pbr==6.1.0 11:52:01 platformdirs==4.3.6 11:52:01 prettytable==3.11.0 11:52:01 pyasn1==0.6.1 11:52:01 pyasn1_modules==0.4.1 11:52:01 pycparser==2.22 11:52:01 pygerrit2==2.0.15 11:52:01 PyGithub==2.4.0 11:52:01 PyJWT==2.9.0 11:52:01 PyNaCl==1.5.0 11:52:01 pyparsing==2.4.7 11:52:01 pyperclip==1.9.0 11:52:01 pyrsistent==0.20.0 11:52:01 python-cinderclient==9.6.0 11:52:01 python-dateutil==2.9.0.post0 11:52:01 python-heatclient==4.0.0 11:52:01 python-jenkins==1.8.2 11:52:01 python-keystoneclient==5.5.0 11:52:01 python-magnumclient==4.7.0 11:52:01 python-openstackclient==7.2.0 11:52:01 python-swiftclient==4.6.0 11:52:01 PyYAML==6.0.2 11:52:01 referencing==0.35.1 11:52:01 requests==2.32.3 11:52:01 requests-oauthlib==2.0.0 11:52:01 requestsexceptions==1.4.0 11:52:01 rfc3986==2.0.0 11:52:01 rpds-py==0.20.0 11:52:01 rsa==4.9 11:52:01 ruamel.yaml==0.18.6 11:52:01 ruamel.yaml.clib==0.2.8 11:52:01 s3transfer==0.10.3 11:52:01 simplejson==3.19.3 11:52:01 six==1.16.0 11:52:01 smmap==5.0.1 11:52:01 soupsieve==2.6 11:52:01 stevedore==5.3.0 11:52:01 tabulate==0.9.0 11:52:01 toml==0.10.2 11:52:01 tomlkit==0.13.2 11:52:01 tqdm==4.66.5 11:52:01 typing_extensions==4.12.2 11:52:01 tzdata==2024.2 11:52:01 urllib3==1.26.20 11:52:01 virtualenv==20.27.0 11:52:01 wcwidth==0.2.13 11:52:01 websocket-client==1.8.0 11:52:01 wrapt==1.16.0 11:52:01 xdg==6.0.0 11:52:01 xmltodict==0.14.2 11:52:01 yq==3.4.3 11:52:01 [EnvInject] - Injecting environment variables from a build step. 11:52:01 [EnvInject] - Injecting as environment variables the properties content 11:52:01 PYTHON=python3 11:52:01 11:52:01 [EnvInject] - Variables injected successfully. 11:52:01 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins10437980303972555748.sh 11:52:01 ---> tox-install.sh 11:52:01 + source /home/jenkins/lf-env.sh 11:52:01 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 11:52:01 ++ mktemp -d /tmp/venv-XXXX 11:52:01 + lf_venv=/tmp/venv-TgN4 11:52:01 + local venv_file=/tmp/.os_lf_venv 11:52:01 + local python=python3 11:52:01 + local options 11:52:01 + local set_path=true 11:52:01 + local install_args= 11:52:01 ++ 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 11:52:01 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:52:01 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:52:01 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 11:52:01 + true 11:52:01 + case $1 in 11:52:01 + venv_file=/tmp/.toxenv 11:52:01 + shift 2 11:52:01 + true 11:52:01 + case $1 in 11:52:01 + shift 11:52:01 + break 11:52:01 + case $python in 11:52:01 + local pkg_list= 11:52:01 + [[ -d /opt/pyenv ]] 11:52:01 + echo 'Setup pyenv:' 11:52:01 Setup pyenv: 11:52:01 + export PYENV_ROOT=/opt/pyenv 11:52:01 + PYENV_ROOT=/opt/pyenv 11:52:01 + 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 11:52:01 + 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 11:52:01 + pyenv versions 11:52:01 system 11:52:01 3.8.13 11:52:01 3.9.13 11:52:01 3.10.13 11:52:01 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:52:01 + command -v pyenv 11:52:01 ++ pyenv init - --no-rehash 11:52:01 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 11:52:01 for i in ${!paths[@]}; do 11:52:01 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 11:52:01 fi; done; 11:52:01 echo "${paths[*]}"'\'')" 11:52:01 export PATH="/opt/pyenv/shims:${PATH}" 11:52:01 export PYENV_SHELL=bash 11:52:01 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 11:52:01 pyenv() { 11:52:01 local command 11:52:01 command="${1:-}" 11:52:01 if [ "$#" -gt 0 ]; then 11:52:01 shift 11:52:01 fi 11:52:01 11:52:01 case "$command" in 11:52:01 rehash|shell) 11:52:01 eval "$(pyenv "sh-$command" "$@")" 11:52:01 ;; 11:52:01 *) 11:52:01 command pyenv "$command" "$@" 11:52:01 ;; 11:52:01 esac 11:52:01 }' 11:52:01 +++ bash --norc -ec 'IFS=:; paths=($PATH); 11:52:01 for i in ${!paths[@]}; do 11:52:01 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 11:52:01 fi; done; 11:52:01 echo "${paths[*]}"' 11:52:01 ++ 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 11:52:01 ++ 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 11:52:01 ++ 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 11:52:01 ++ export PYENV_SHELL=bash 11:52:01 ++ PYENV_SHELL=bash 11:52:01 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 11:52:01 +++ complete -F _pyenv pyenv 11:52:01 ++ lf-pyver python3 11:52:01 ++ local py_version_xy=python3 11:52:01 ++ local py_version_xyz= 11:52:01 ++ pyenv versions 11:52:01 ++ local command 11:52:01 ++ command=versions 11:52:01 ++ '[' 1 -gt 0 ']' 11:52:01 ++ sed 's/^[ *]* //' 11:52:01 ++ shift 11:52:01 ++ case "$command" in 11:52:01 ++ command pyenv versions 11:52:01 ++ pyenv versions 11:52:01 ++ awk '{ print $1 }' 11:52:01 ++ grep -E '^[0-9.]*[0-9]$' 11:52:01 ++ [[ ! -s /tmp/.pyenv_versions ]] 11:52:01 +++ grep '^3' /tmp/.pyenv_versions 11:52:01 +++ sort -V 11:52:01 +++ tail -n 1 11:52:01 ++ py_version_xyz=3.11.7 11:52:01 ++ [[ -z 3.11.7 ]] 11:52:01 ++ echo 3.11.7 11:52:01 ++ return 0 11:52:01 + pyenv local 3.11.7 11:52:01 + local command 11:52:01 + command=local 11:52:01 + '[' 2 -gt 0 ']' 11:52:01 + shift 11:52:01 + case "$command" in 11:52:01 + command pyenv local 3.11.7 11:52:01 + pyenv local 3.11.7 11:52:01 + for arg in "$@" 11:52:01 + case $arg in 11:52:01 + pkg_list+='tox ' 11:52:01 + for arg in "$@" 11:52:01 + case $arg in 11:52:01 + pkg_list+='virtualenv ' 11:52:01 + for arg in "$@" 11:52:01 + case $arg in 11:52:01 + pkg_list+='urllib3~=1.26.15 ' 11:52:01 + [[ -f /tmp/.toxenv ]] 11:52:01 + [[ ! -f /tmp/.toxenv ]] 11:52:01 + [[ -n '' ]] 11:52:01 + python3 -m venv /tmp/venv-TgN4 11:52:06 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-TgN4' 11:52:06 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-TgN4 11:52:06 + echo /tmp/venv-TgN4 11:52:06 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 11:52:06 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 11:52:06 + /tmp/venv-TgN4/bin/python3 -m pip install --upgrade --quiet pip virtualenv 11:52:09 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 11:52:09 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 11:52:09 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 11:52:09 + /tmp/venv-TgN4/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 11:52:11 + type python3 11:52:11 + true 11:52:11 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-TgN4/bin to PATH' 11:52:11 lf-activate-venv(): INFO: Adding /tmp/venv-TgN4/bin to PATH 11:52:11 + PATH=/tmp/venv-TgN4/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 11:52:11 + return 0 11:52:11 + python3 --version 11:52:11 Python 3.11.7 11:52:11 + python3 -m pip --version 11:52:11 pip 24.2 from /tmp/venv-TgN4/lib/python3.11/site-packages/pip (python 3.11) 11:52:11 + python3 -m pip freeze 11:52:12 cachetools==5.5.0 11:52:12 chardet==5.2.0 11:52:12 colorama==0.4.6 11:52:12 distlib==0.3.9 11:52:12 filelock==3.16.1 11:52:12 packaging==24.1 11:52:12 platformdirs==4.3.6 11:52:12 pluggy==1.5.0 11:52:12 pyproject-api==1.8.0 11:52:12 tox==4.23.0 11:52:12 urllib3==1.26.20 11:52:12 virtualenv==20.27.0 11:52:12 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins8259106859361588028.sh 11:52:12 [EnvInject] - Injecting environment variables from a build step. 11:52:12 [EnvInject] - Injecting as environment variables the properties content 11:52:12 PARALLEL=True 11:52:12 11:52:12 [EnvInject] - Variables injected successfully. 11:52:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins3784635389322796484.sh 11:52:12 ---> tox-run.sh 11:52: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 11:52:12 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 11:52:12 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 11:52:12 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 11:52:12 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 11:52:12 + source /home/jenkins/lf-env.sh 11:52:12 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 11:52:12 ++ mktemp -d /tmp/venv-XXXX 11:52:12 + lf_venv=/tmp/venv-dxwN 11:52:12 + local venv_file=/tmp/.os_lf_venv 11:52:12 + local python=python3 11:52:12 + local options 11:52:12 + local set_path=true 11:52:12 + local install_args= 11:52: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 11:52:12 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:52:12 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:52:12 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 11:52:12 + true 11:52:12 + case $1 in 11:52:12 + venv_file=/tmp/.toxenv 11:52:12 + shift 2 11:52:12 + true 11:52:12 + case $1 in 11:52:12 + shift 11:52:12 + break 11:52:12 + case $python in 11:52:12 + local pkg_list= 11:52:12 + [[ -d /opt/pyenv ]] 11:52:12 + echo 'Setup pyenv:' 11:52:12 Setup pyenv: 11:52:12 + export PYENV_ROOT=/opt/pyenv 11:52:12 + PYENV_ROOT=/opt/pyenv 11:52: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 11:52: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 11:52:12 + pyenv versions 11:52:12 system 11:52:12 3.8.13 11:52:12 3.9.13 11:52:12 3.10.13 11:52:12 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:52:12 + command -v pyenv 11:52:12 ++ pyenv init - --no-rehash 11:52:12 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 11:52:12 for i in ${!paths[@]}; do 11:52:12 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 11:52:12 fi; done; 11:52:12 echo "${paths[*]}"'\'')" 11:52:12 export PATH="/opt/pyenv/shims:${PATH}" 11:52:12 export PYENV_SHELL=bash 11:52:12 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 11:52:12 pyenv() { 11:52:12 local command 11:52:12 command="${1:-}" 11:52:12 if [ "$#" -gt 0 ]; then 11:52:12 shift 11:52:12 fi 11:52:12 11:52:12 case "$command" in 11:52:12 rehash|shell) 11:52:12 eval "$(pyenv "sh-$command" "$@")" 11:52:12 ;; 11:52:12 *) 11:52:12 command pyenv "$command" "$@" 11:52:12 ;; 11:52:12 esac 11:52:12 }' 11:52:12 +++ bash --norc -ec 'IFS=:; paths=($PATH); 11:52:12 for i in ${!paths[@]}; do 11:52:12 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 11:52:12 fi; done; 11:52:12 echo "${paths[*]}"' 11:52: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 11:52: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 11:52: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 11:52:12 ++ export PYENV_SHELL=bash 11:52:12 ++ PYENV_SHELL=bash 11:52:12 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 11:52:12 +++ complete -F _pyenv pyenv 11:52:12 ++ lf-pyver python3 11:52:12 ++ local py_version_xy=python3 11:52:12 ++ local py_version_xyz= 11:52:12 ++ pyenv versions 11:52:12 ++ sed 's/^[ *]* //' 11:52:12 ++ local command 11:52:12 ++ command=versions 11:52:12 ++ '[' 1 -gt 0 ']' 11:52:12 ++ shift 11:52:12 ++ case "$command" in 11:52:12 ++ command pyenv versions 11:52:12 ++ pyenv versions 11:52:12 ++ grep -E '^[0-9.]*[0-9]$' 11:52:12 ++ awk '{ print $1 }' 11:52:12 ++ [[ ! -s /tmp/.pyenv_versions ]] 11:52:12 +++ grep '^3' /tmp/.pyenv_versions 11:52:12 +++ sort -V 11:52:12 +++ tail -n 1 11:52:12 ++ py_version_xyz=3.11.7 11:52:12 ++ [[ -z 3.11.7 ]] 11:52:12 ++ echo 3.11.7 11:52:12 ++ return 0 11:52:12 + pyenv local 3.11.7 11:52:12 + local command 11:52:12 + command=local 11:52:12 + '[' 2 -gt 0 ']' 11:52:12 + shift 11:52:12 + case "$command" in 11:52:12 + command pyenv local 3.11.7 11:52:12 + pyenv local 3.11.7 11:52:12 + for arg in "$@" 11:52:12 + case $arg in 11:52:12 + pkg_list+='tox ' 11:52:12 + for arg in "$@" 11:52:12 + case $arg in 11:52:12 + pkg_list+='virtualenv ' 11:52:12 + for arg in "$@" 11:52:12 + case $arg in 11:52:12 + pkg_list+='urllib3~=1.26.15 ' 11:52:12 + [[ -f /tmp/.toxenv ]] 11:52:12 ++ cat /tmp/.toxenv 11:52:12 + lf_venv=/tmp/venv-TgN4 11:52:12 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-TgN4 from' file:/tmp/.toxenv 11:52:12 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-TgN4 from file:/tmp/.toxenv 11:52:12 + /tmp/venv-TgN4/bin/python3 -m pip install --upgrade --quiet pip virtualenv 11:52:13 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 11:52:13 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 11:52:13 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 11:52:13 + /tmp/venv-TgN4/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 11:52:14 + type python3 11:52:14 + true 11:52:14 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-TgN4/bin to PATH' 11:52:14 lf-activate-venv(): INFO: Adding /tmp/venv-TgN4/bin to PATH 11:52:14 + PATH=/tmp/venv-TgN4/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 11:52:14 + return 0 11:52:14 + [[ -d /opt/pyenv ]] 11:52:14 + echo '---> Setting up pyenv' 11:52:14 ---> Setting up pyenv 11:52:14 + export PYENV_ROOT=/opt/pyenv 11:52:14 + PYENV_ROOT=/opt/pyenv 11:52:14 + export PATH=/opt/pyenv/bin:/tmp/venv-TgN4/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 11:52:14 + PATH=/opt/pyenv/bin:/tmp/venv-TgN4/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 11:52:14 ++ pwd 11:52:14 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 11:52:14 + export PYTHONPATH 11:52:14 + export TOX_TESTENV_PASSENV=PYTHONPATH 11:52:14 + TOX_TESTENV_PASSENV=PYTHONPATH 11:52:14 + tox --version 11:52:15 4.23.0 from /tmp/venv-TgN4/lib/python3.11/site-packages/tox/__init__.py 11:52:15 + PARALLEL=True 11:52:15 + TOX_OPTIONS_LIST= 11:52:15 + [[ -n '' ]] 11:52:15 + case ${PARALLEL,,} in 11:52:15 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 11:52:15 + tox --parallel auto --parallel-live 11:52:15 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 11:52:16 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 11:52:17 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 11:52:17 docs: install_deps> python -I -m pip install -r docs/requirements.txt 11:52:17 checkbashisms: freeze> python -m pip freeze --all 11:52:17 checkbashisms: pip==24.2,setuptools==75.2.0,wheel==0.44.0 11:52:17 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 11:52:17 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)' 11:52:17 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 11:52:18 script ./reflectwarn.sh does not appear to have a #! interpreter line; 11:52:18 you may get strange results 11:52:18 checkbashisms: OK ✔ in 3.14 seconds 11:52:18 pre-commit: install_deps> python -I -m pip install pre-commit 11:52:21 pre-commit: freeze> python -m pip freeze --all 11:52:21 pre-commit: cfgv==3.4.0,distlib==0.3.9,filelock==3.16.1,identify==2.6.1,nodeenv==1.9.1,pip==24.2,platformdirs==4.3.6,pre_commit==4.0.1,PyYAML==6.0.2,setuptools==75.2.0,virtualenv==20.27.0,wheel==0.44.0 11:52:21 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 11:52:21 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)' 11:52:21 /usr/bin/cpan 11:52:21 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 11:52:22 [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. 11:52:22 [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. 11:52:22 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 11:52:24 buildcontroller: freeze> python -m pip freeze --all 11:52:24 buildcontroller: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:52:24 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 11:52:24 + update-java-alternatives -l 11:52:24 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 11:52:24 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 11:52:24 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 11:52:24 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 11:52:24 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 11:52:24 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 11:52:24 + java -version 11:52:24 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 11:52:25 + JAVA_VER=21 11:52:25 + echo 21 11:52:25 21 11:52:25 + javac -version 11:52:25 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 11:52:25 + JAVAC_VER=21 11:52:25 + echo 21 11:52:25 + [ 21 -ge 21 ] 11:52:25 + [ 21 -ge 21 ] 11:52:25 + echo ok, java is 21 or newer 11:52:25 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp 11:52:25 21 11:52:25 ok, java is 21 or newer 11:52:25 2024-10-18 11:52:25 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] 11:52:25 + sudo mkdir -p /opt 11:52:25 + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt 11:52:26 + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven 11:52:26 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 11:52:26 + mvn --version 11:52:26 Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) 11:52:26 Maven home: /opt/maven 11:52:26 Java version: 21.0.4, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 11:52:26 Default locale: en, platform encoding: UTF-8 11:52:26 OS name: "linux", version: "5.4.0-190-generic", arch: "amd64", family: "unix" 11:52:26 NOTE: Picked up JDK_JAVA_OPTIONS: 11:52:26 --add-opens=java.base/java.io=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.lang=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.net=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.nio=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.util=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:52:26 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:52:26 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:52:26 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:52:26 -Xlog:disable 11:52:27 [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. 11:52:27 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 11:52:28 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 11:52:28 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 11:52:29 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 11:52:29 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 11:52:30 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 11:52:30 [INFO] Once installed this environment will be reused. 11:52:30 [INFO] This may take a few minutes... 11:52:36 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 11:52:36 [INFO] Once installed this environment will be reused. 11:52:36 [INFO] This may take a few minutes... 11:52:43 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 11:52:43 [INFO] Once installed this environment will be reused. 11:52:43 [INFO] This may take a few minutes... 11:52:48 [INFO] Installing environment for https://github.com/perltidy/perltidy. 11:52:48 [INFO] Once installed this environment will be reused. 11:52:48 [INFO] This may take a few minutes... 11:52:54 docs: freeze> python -m pip freeze --all 11:52:55 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.1,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.2,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 11:52:55 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 11:52:56 docs-linkcheck: freeze> python -m pip freeze --all 11:52:56 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.1,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.2,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 11:52:56 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 11:52:58 docs: OK ✔ in 42.58 seconds 11:52:58 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 11:53:02 docs-linkcheck: OK ✔ in 44.78 seconds 11:53:02 pylint: freeze> python -m pip freeze --all 11:53:02 pylint: astroid==3.3.5,dill==0.3.9,isort==5.13.2,mccabe==0.7.0,pip==24.2,platformdirs==4.3.6,pylint==3.3.1,setuptools==75.2.0,tomlkit==0.13.2,wheel==0.44.0 11:53:02 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}$' '{}' + 11:53:03 trim trailing whitespace.................................................Passed 11:53:03 Tabs remover.............................................................Passed 11:53:04 autopep8.................................................................Passed 11:53:08 perltidy.................................................................Passed 11:53:09 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 11:53:09 [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. 11:53:09 [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. 11:53:09 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 11:53:09 [INFO] Once installed this environment will be reused. 11:53:09 [INFO] This may take a few minutes... 11:53:17 gitlint..................................................................Passed 11:53:25 ************* Module 1.2.1.test03_topology 11:53:25 transportpce_tests/1.2.1/test03_topology.py:430:4: R0912: Too many branches (13/12) (too-many-branches) 11:53:25 ************* Module tapi.test03_tapi_device_change_notifications 11:53:25 transportpce_tests/tapi/test03_tapi_device_change_notifications.py:14:0: C0302: Too many lines in module (1003/1000) (too-many-lines) 11:53:25 ************* Module 2.2.1.test04_otn_topology 11:53:25 transportpce_tests/2.2.1/test04_otn_topology.py:120:4: R0912: Too many branches (13/12) (too-many-branches) 11:53:25 11:53:25 ------------------------------------ 11:53:25 Your code has been rated at 10.00/10 11:53:25 11:53:27 pre-commit: OK ✔ in 59.17 seconds 11:53:27 pylint: exit 1 (24.95 seconds) /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}$' '{}' + pid=30022 11:54:13 pylint: FAIL ✖ in 29.55 seconds 11:54:13 buildcontroller: OK ✔ in 1 minute 56.85 seconds 11:54:13 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 11:54:13 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 11:54:13 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 11:54:13 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 11:54:20 build_karaf_tests121: freeze> python -m pip freeze --all 11:54:20 build_karaf_tests221: freeze> python -m pip freeze --all 11:54:20 sims: freeze> python -m pip freeze --all 11:54:20 build_karaf_tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:54:20 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 11:54:20 NOTE: Picked up JDK_JAVA_OPTIONS: 11:54:20 --add-opens=java.base/java.io=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.net=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:54:20 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:54:20 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:54:20 -Xlog:disable 11:54:20 sims: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:54:20 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 11:54:20 build_karaf_tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:54:20 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 11:54:20 Using lighynode version 20.1.0.2 11:54:20 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 11:54:20 NOTE: Picked up JDK_JAVA_OPTIONS: 11:54:20 --add-opens=java.base/java.io=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.net=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:54:20 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:54:20 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:54:20 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:54:20 -Xlog:disable 11:54:24 sims: OK ✔ in 11.72 seconds 11:54:24 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 11:54:35 build_karaf_tests71: freeze> python -m pip freeze --all 11:54:35 build_karaf_tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:54:35 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 11:54:36 NOTE: Picked up JDK_JAVA_OPTIONS: 11:54:36 --add-opens=java.base/java.io=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.lang=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.net=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.nio=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.util=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:54:36 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:54:36 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:54:36 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:54:36 -Xlog:disable 11:55:15 build_karaf_tests221: OK ✔ in 1 minute 3.08 seconds 11:55:15 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 11:55:17 build_karaf_tests121: OK ✔ in 1 minute 4.77 seconds 11:55:17 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 11:55:25 build_karaf_tests71: OK ✔ in 56.34 seconds 11:55:25 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 11:55:25 tests_tapi: freeze> python -m pip freeze --all 11:55:26 build_karaf_tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:55:26 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 11:55:26 NOTE: Picked up JDK_JAVA_OPTIONS: 11:55:26 --add-opens=java.base/java.io=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.lang=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.net=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.nio=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.util=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:55:26 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:55:26 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:55:26 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:55:26 -Xlog:disable 11:55:26 tests_tapi: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 11:55:26 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 11:55:26 using environment variables from ./karaf221.env 11:55:26 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 11:55:45 testsPCE: freeze> python -m pip freeze --all 11:55:46 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.1,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.2,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 11:55:46 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 11:55:46 pytest -q transportpce_tests/pce/test01_pce.py 11:56:50 ........................................... [100%] 11:57:53 20 passed in 127.13s (0:02:07) 11:57:53 pytest -q transportpce_tests/pce/test02_pce_400G.py 11:57:55 .................. [100%] 11:58:37 9 passed in 43.63s 11:58:37 pytest -q transportpce_tests/pce/test03_gnpy.py 11:58:42 .............. [100%] 11:59:18 8 passed in 40.79s 11:59:19 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 11:59:26 ............ [100%] 11:59:31 50 passed in 244.87s (0:04:04) 11:59:31 pytest -q transportpce_tests/tapi/test02_full_topology.py 12:00:00 ... [100%] 12:00:06 3 passed in 46.94s 12:00:06 build_karaf_tests_hybrid: OK ✔ in 1 minute 1.72 seconds 12:00:06 testsPCE: OK ✔ in 5 minutes 53.93 seconds 12:00:06 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 12:00:12 tests121: freeze> python -m pip freeze --all 12:00:13 tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 12:00:13 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 12:00:13 using environment variables from ./karaf121.env 12:00:13 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 12:01:07 ...........FF....................... [100%] 12:04:35 =================================== FAILURES =================================== 12:04:35 _____________ TransportPCEtesting.test_12_check_openroadm_topology _____________ 12:04:35 12:04:35 self = 12:04:35 12:04:35 def test_12_check_openroadm_topology(self): 12:04:35 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 12:04:35 self.assertEqual(response['status_code'], requests.codes.ok) 12:04:35 > self.assertEqual(len(response['network'][0]['node']), 14, 'There should be 14 openroadm nodes') 12:04:35 E AssertionError: 18 != 14 : There should be 14 openroadm nodes 12:04:35 12:04:35 transportpce_tests/tapi/test02_full_topology.py:272: AssertionError 12:04:35 ____________ TransportPCEtesting.test_13_get_tapi_topology_details _____________ 12:04:35 12:04:35 self = 12:04:35 12:04:35 def test_13_get_tapi_topology_details(self): 12:04:35 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 12:04:35 response = test_utils.transportpce_api_rpc_request( 12:04:35 'tapi-topology', 'get-topology-details', self.tapi_topo) 12:04:35 time.sleep(2) 12:04:35 self.assertEqual(response['status_code'], requests.codes.ok) 12:04:35 > self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 12:04:35 E AssertionError: 9 != 8 : There should be 8 TAPI nodes 12:04:35 12:04:35 transportpce_tests/tapi/test02_full_topology.py:282: AssertionError 12:04:35 =========================== short test summary info ============================ 12:04:35 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_12_check_openroadm_topology 12:04:35 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_13_get_tapi_topology_details 12:04:35 2 failed, 28 passed in 304.23s (0:05:04) 12:04:35 tests_tapi: exit 1 (549.68 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=30673 12:04:36 tests_tapi: FAIL ✖ in 9 minutes 18.82 seconds 12:04:36 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 12:04:42 tests71: freeze> python -m pip freeze --all 12:04:42 tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 12:04:42 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 12:04:42 using environment variables from ./karaf71.env 12:04:42 pytest -q transportpce_tests/7.1/test01_portmapping.py 12:05:15 ............ [100%] 12:05:28 12 passed in 45.47s 12:05:28 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 12:05:55 ..........................................F.FF.FF.FF.F................. [100%] 12:08:05 62 passed in 157.04s (0:02:37) 12:08:05 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 12:08:38 ................................................ [100%] 12:10:22 48 passed in 136.81s (0:02:16) 12:10:22 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 12:10:30 FFFFF. [100%] 12:10:40 =================================== FAILURES =================================== 12:10:40 _________ TransportPCEPortMappingTesting.test_08_xpdr_device_connected _________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_08_xpdr_device_connected(self): 12:10:40 response = test_utils.check_device_connection("XPDRA01") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:104: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_08_xpdr_device_connected 12:10:40 _________ TransportPCEPortMappingTesting.test_09_xpdr_portmapping_info _________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_09_xpdr_portmapping_info(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:110: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_09_xpdr_portmapping_info 12:10:40 _______ TransportPCEPortMappingTesting.test_10_xpdr_portmapping_NETWORK1 _______ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_10_xpdr_portmapping_NETWORK1(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK1") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:123: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_10_xpdr_portmapping_NETWORK1 12:10:40 _______ TransportPCEPortMappingTesting.test_11_xpdr_portmapping_NETWORK2 _______ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_11_xpdr_portmapping_NETWORK2(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK2") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:134: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_11_xpdr_portmapping_NETWORK2 12:10:40 _______ TransportPCEPortMappingTesting.test_12_xpdr_portmapping_CLIENT1 ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_12_xpdr_portmapping_CLIENT1(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT1") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:145: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_12_xpdr_portmapping_CLIENT1 12:10:40 _______ TransportPCEPortMappingTesting.test_13_xpdr_portmapping_CLIENT2 ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_13_xpdr_portmapping_CLIENT2(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT2") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:157: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_13_xpdr_portmapping_CLIENT2 12:10:40 _______ TransportPCEPortMappingTesting.test_14_xpdr_portmapping_CLIENT3 ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_14_xpdr_portmapping_CLIENT3(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT3") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:169: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_14_xpdr_portmapping_CLIENT3 12:10:40 _______ TransportPCEPortMappingTesting.test_15_xpdr_portmapping_CLIENT4 ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_15_xpdr_portmapping_CLIENT4(self): 12:10:40 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT4") 12:10:40 > self.assertEqual(response['status_code'], requests.codes.ok) 12:10:40 E AssertionError: 409 != 200 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:181: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_15_xpdr_portmapping_CLIENT4 12:10:40 _______ TransportPCEPortMappingTesting.test_16_xpdr_device_disconnection _______ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_16_xpdr_device_disconnection(self): 12:10:40 response = test_utils.unmount_device("XPDRA01") 12:10:40 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 12:10:40 E AssertionError: 409 not found in (200, 204) 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:192: AssertionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_16_xpdr_device_disconnection 12:10:40 Searching for pattern 'onDeviceDisConnected:\ XPDRA01' in karaf.log... Pattern not found after 180 seconds! Node XPDRA01 still not deleted from tpce topology... 12:10:40 _______ TransportPCEPortMappingTesting.test_17_xpdr_device_disconnected ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 > sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 12:10:40 raise err 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 address = ('localhost', 8182), timeout = 10, source_address = None 12:10:40 socket_options = [(6, 1, 1)] 12:10:40 12:10:40 def create_connection( 12:10:40 address: tuple[str, int], 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 source_address: tuple[str, int] | None = None, 12:10:40 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 12:10:40 ) -> socket.socket: 12:10:40 """Connect to *address* and return the socket object. 12:10:40 12:10:40 Convenience function. Connect to *address* (a 2-tuple ``(host, 12:10:40 port)``) and return the socket object. Passing the optional 12:10:40 *timeout* parameter will set the timeout on the socket instance 12:10:40 before attempting to connect. If no *timeout* is supplied, the 12:10:40 global default timeout setting returned by :func:`socket.getdefaulttimeout` 12:10:40 is used. If *source_address* is set it must be a tuple of (host, port) 12:10:40 for the socket to bind as a source address before making the connection. 12:10:40 An host of '' or port 0 tells the OS to use the default. 12:10:40 """ 12:10:40 12:10:40 host, port = address 12:10:40 if host.startswith("["): 12:10:40 host = host.strip("[]") 12:10:40 err = None 12:10:40 12:10:40 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 12:10:40 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 12:10:40 # The original create_connection function always returns all records. 12:10:40 family = allowed_gai_family() 12:10:40 12:10:40 try: 12:10:40 host.encode("idna") 12:10:40 except UnicodeError: 12:10:40 raise LocationParseError(f"'{host}', label empty or too long") from None 12:10:40 12:10:40 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 12:10:40 af, socktype, proto, canonname, sa = res 12:10:40 sock = None 12:10:40 try: 12:10:40 sock = socket.socket(af, socktype, proto) 12:10:40 12:10:40 # If provided, set socket level options before connecting. 12:10:40 _set_socket_options(sock, socket_options) 12:10:40 12:10:40 if timeout is not _DEFAULT_TIMEOUT: 12:10:40 sock.settimeout(timeout) 12:10:40 if source_address: 12:10:40 sock.bind(source_address) 12:10:40 > sock.connect(sa) 12:10:40 E ConnectionRefusedError: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 12:10:40 body = None 12:10:40 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='} 12:10:40 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 redirect = False, assert_same_host = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 12:10:40 release_conn = False, chunked = False, body_pos = None, preload_content = False 12:10:40 decode_content = False, response_kw = {} 12:10:40 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01', query='content=nonconfig', fragment=None) 12:10:40 destination_scheme = None, conn = None, release_this_conn = True 12:10:40 http_tunnel_required = False, err = None, clean_exit = False 12:10:40 12:10:40 def urlopen( # type: ignore[override] 12:10:40 self, 12:10:40 method: str, 12:10:40 url: str, 12:10:40 body: _TYPE_BODY | None = None, 12:10:40 headers: typing.Mapping[str, str] | None = None, 12:10:40 retries: Retry | bool | int | None = None, 12:10:40 redirect: bool = True, 12:10:40 assert_same_host: bool = True, 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 pool_timeout: int | None = None, 12:10:40 release_conn: bool | None = None, 12:10:40 chunked: bool = False, 12:10:40 body_pos: _TYPE_BODY_POSITION | None = None, 12:10:40 preload_content: bool = True, 12:10:40 decode_content: bool = True, 12:10:40 **response_kw: typing.Any, 12:10:40 ) -> BaseHTTPResponse: 12:10:40 """ 12:10:40 Get a connection from the pool and perform an HTTP request. This is the 12:10:40 lowest level call for making a request, so you'll need to specify all 12:10:40 the raw details. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 More commonly, it's appropriate to use a convenience method 12:10:40 such as :meth:`request`. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 `release_conn` will only behave as expected if 12:10:40 `preload_content=False` because we want to make 12:10:40 `preload_content=False` the default behaviour someday soon without 12:10:40 breaking backwards compatibility. 12:10:40 12:10:40 :param method: 12:10:40 HTTP request method (such as GET, POST, PUT, etc.) 12:10:40 12:10:40 :param url: 12:10:40 The URL to perform the request on. 12:10:40 12:10:40 :param body: 12:10:40 Data to send in the request body, either :class:`str`, :class:`bytes`, 12:10:40 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 12:10:40 12:10:40 :param headers: 12:10:40 Dictionary of custom headers to send, such as User-Agent, 12:10:40 If-None-Match, etc. If None, pool headers are used. If provided, 12:10:40 these headers completely replace any pool-specific headers. 12:10:40 12:10:40 :param retries: 12:10:40 Configure the number of retries to allow before raising a 12:10:40 :class:`~urllib3.exceptions.MaxRetryError` exception. 12:10:40 12:10:40 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 12:10:40 :class:`~urllib3.util.retry.Retry` object for fine-grained control 12:10:40 over different types of retries. 12:10:40 Pass an integer number to retry connection errors that many times, 12:10:40 but no other types of errors. Pass zero to never retry. 12:10:40 12:10:40 If ``False``, then retries are disabled and any exception is raised 12:10:40 immediately. Also, instead of raising a MaxRetryError on redirects, 12:10:40 the redirect response will be returned. 12:10:40 12:10:40 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 12:10:40 12:10:40 :param redirect: 12:10:40 If True, automatically handle redirects (status codes 301, 302, 12:10:40 303, 307, 308). Each redirect counts as a retry. Disabling retries 12:10:40 will disable redirect, too. 12:10:40 12:10:40 :param assert_same_host: 12:10:40 If ``True``, will make sure that the host of the pool requests is 12:10:40 consistent else will raise HostChangedError. When ``False``, you can 12:10:40 use the pool on an HTTP proxy and request foreign hosts. 12:10:40 12:10:40 :param timeout: 12:10:40 If specified, overrides the default timeout for this one 12:10:40 request. It may be a float (in seconds) or an instance of 12:10:40 :class:`urllib3.util.Timeout`. 12:10:40 12:10:40 :param pool_timeout: 12:10:40 If set and the pool is set to block=True, then this method will 12:10:40 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 12:10:40 connection is available within the time period. 12:10:40 12:10:40 :param bool preload_content: 12:10:40 If True, the response's body will be preloaded into memory. 12:10:40 12:10:40 :param bool decode_content: 12:10:40 If True, will attempt to decode the body based on the 12:10:40 'content-encoding' header. 12:10:40 12:10:40 :param release_conn: 12:10:40 If False, then the urlopen call will not release the connection 12:10:40 back into the pool once a response is received (but will release if 12:10:40 you read the entire contents of the response such as when 12:10:40 `preload_content=True`). This is useful if you're not preloading 12:10:40 the response's content immediately. You will need to call 12:10:40 ``r.release_conn()`` on the response ``r`` to return the connection 12:10:40 back into the pool. If None, it takes the value of ``preload_content`` 12:10:40 which defaults to ``True``. 12:10:40 12:10:40 :param bool chunked: 12:10:40 If True, urllib3 will send the body using chunked transfer 12:10:40 encoding. Otherwise, urllib3 will send the body using the standard 12:10:40 content-length form. Defaults to False. 12:10:40 12:10:40 :param int body_pos: 12:10:40 Position to seek to in file-like body in the event of a retry or 12:10:40 redirect. Typically this won't need to be set because urllib3 will 12:10:40 auto-populate the value when needed. 12:10:40 """ 12:10:40 parsed_url = parse_url(url) 12:10:40 destination_scheme = parsed_url.scheme 12:10:40 12:10:40 if headers is None: 12:10:40 headers = self.headers 12:10:40 12:10:40 if not isinstance(retries, Retry): 12:10:40 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 12:10:40 12:10:40 if release_conn is None: 12:10:40 release_conn = preload_content 12:10:40 12:10:40 # Check host 12:10:40 if assert_same_host and not self.is_same_host(url): 12:10:40 raise HostChangedError(self, url, retries) 12:10:40 12:10:40 # Ensure that the URL we're connecting to is properly encoded 12:10:40 if url.startswith("/"): 12:10:40 url = to_str(_encode_target(url)) 12:10:40 else: 12:10:40 url = to_str(parsed_url.url) 12:10:40 12:10:40 conn = None 12:10:40 12:10:40 # Track whether `conn` needs to be released before 12:10:40 # returning/raising/recursing. Update this variable if necessary, and 12:10:40 # leave `release_conn` constant throughout the function. That way, if 12:10:40 # the function recurses, the original value of `release_conn` will be 12:10:40 # passed down into the recursive call, and its value will be respected. 12:10:40 # 12:10:40 # See issue #651 [1] for details. 12:10:40 # 12:10:40 # [1] 12:10:40 release_this_conn = release_conn 12:10:40 12:10:40 http_tunnel_required = connection_requires_http_tunnel( 12:10:40 self.proxy, self.proxy_config, destination_scheme 12:10:40 ) 12:10:40 12:10:40 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 12:10:40 # have to copy the headers dict so we can safely change it without those 12:10:40 # changes being reflected in anyone else's copy. 12:10:40 if not http_tunnel_required: 12:10:40 headers = headers.copy() # type: ignore[attr-defined] 12:10:40 headers.update(self.proxy_headers) # type: ignore[union-attr] 12:10:40 12:10:40 # Must keep the exception bound to a separate variable or else Python 3 12:10:40 # complains about UnboundLocalError. 12:10:40 err = None 12:10:40 12:10:40 # Keep track of whether we cleanly exited the except block. This 12:10:40 # ensures we do proper cleanup in finally. 12:10:40 clean_exit = False 12:10:40 12:10:40 # Rewind body position, if needed. Record current position 12:10:40 # for future rewinds in the event of a redirect/retry. 12:10:40 body_pos = set_file_position(body, body_pos) 12:10:40 12:10:40 try: 12:10:40 # Request a connection from the queue. 12:10:40 timeout_obj = self._get_timeout(timeout) 12:10:40 conn = self._get_conn(timeout=pool_timeout) 12:10:40 12:10:40 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 12:10:40 12:10:40 # Is this a closed/new connection that requires CONNECT tunnelling? 12:10:40 if self.proxy is not None and http_tunnel_required and conn.is_closed: 12:10:40 try: 12:10:40 self._prepare_proxy(conn) 12:10:40 except (BaseSSLError, OSError, SocketTimeout) as e: 12:10:40 self._raise_timeout( 12:10:40 err=e, url=self.proxy.url, timeout_value=conn.timeout 12:10:40 ) 12:10:40 raise 12:10:40 12:10:40 # If we're going to release the connection in ``finally:``, then 12:10:40 # the response doesn't need to know about the connection. Otherwise 12:10:40 # it will also try to release it and we'll have a double-release 12:10:40 # mess. 12:10:40 response_conn = conn if not release_conn else None 12:10:40 12:10:40 # Make the request on the HTTPConnection object 12:10:40 > response = self._make_request( 12:10:40 conn, 12:10:40 method, 12:10:40 url, 12:10:40 timeout=timeout_obj, 12:10:40 body=body, 12:10:40 headers=headers, 12:10:40 chunked=chunked, 12:10:40 retries=retries, 12:10:40 response_conn=response_conn, 12:10:40 preload_content=preload_content, 12:10:40 decode_content=decode_content, 12:10:40 **response_kw, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 12:10:40 conn.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 12:10:40 self.endheaders() 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 12:10:40 self._send_output(message_body, encode_chunked=encode_chunked) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 12:10:40 self.send(msg) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 12:10:40 self.connect() 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 12:10:40 self.sock = self._new_conn() 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 except socket.gaierror as e: 12:10:40 raise NameResolutionError(self.host, self, e) from e 12:10:40 except SocketTimeout as e: 12:10:40 raise ConnectTimeoutError( 12:10:40 self, 12:10:40 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 12:10:40 ) from e 12:10:40 12:10:40 except OSError as e: 12:10:40 > raise NewConnectionError( 12:10:40 self, f"Failed to establish a new connection: {e}" 12:10:40 ) from e 12:10:40 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 > resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 12:10:40 retries = retries.increment( 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 12:10:40 response = None 12:10:40 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 12:10:40 _pool = 12:10:40 _stacktrace = 12:10:40 12:10:40 def increment( 12:10:40 self, 12:10:40 method: str | None = None, 12:10:40 url: str | None = None, 12:10:40 response: BaseHTTPResponse | None = None, 12:10:40 error: Exception | None = None, 12:10:40 _pool: ConnectionPool | None = None, 12:10:40 _stacktrace: TracebackType | None = None, 12:10:40 ) -> Self: 12:10:40 """Return a new Retry object with incremented retry counters. 12:10:40 12:10:40 :param response: A response object, or None, if the server did not 12:10:40 return a response. 12:10:40 :type response: :class:`~urllib3.response.BaseHTTPResponse` 12:10:40 :param Exception error: An error encountered during the request, or 12:10:40 None if the response was received successfully. 12:10:40 12:10:40 :return: A new ``Retry`` object. 12:10:40 """ 12:10:40 if self.total is False and error: 12:10:40 # Disabled, indicate to re-raise the error. 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 12:10:40 total = self.total 12:10:40 if total is not None: 12:10:40 total -= 1 12:10:40 12:10:40 connect = self.connect 12:10:40 read = self.read 12:10:40 redirect = self.redirect 12:10:40 status_count = self.status 12:10:40 other = self.other 12:10:40 cause = "unknown" 12:10:40 status = None 12:10:40 redirect_location = None 12:10:40 12:10:40 if error and self._is_connection_error(error): 12:10:40 # Connect retry? 12:10:40 if connect is False: 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif connect is not None: 12:10:40 connect -= 1 12:10:40 12:10:40 elif error and self._is_read_error(error): 12:10:40 # Read retry? 12:10:40 if read is False or method is None or not self._is_method_retryable(method): 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif read is not None: 12:10:40 read -= 1 12:10:40 12:10:40 elif error: 12:10:40 # Other retry? 12:10:40 if other is not None: 12:10:40 other -= 1 12:10:40 12:10:40 elif response and response.get_redirect_location(): 12:10:40 # Redirect retry? 12:10:40 if redirect is not None: 12:10:40 redirect -= 1 12:10:40 cause = "too many redirects" 12:10:40 response_redirect_location = response.get_redirect_location() 12:10:40 if response_redirect_location: 12:10:40 redirect_location = response_redirect_location 12:10:40 status = response.status 12:10:40 12:10:40 else: 12:10:40 # Incrementing because of a server error like a 500 in 12:10:40 # status_forcelist and the given method is in the allowed_methods 12:10:40 cause = ResponseError.GENERIC_ERROR 12:10:40 if response and response.status: 12:10:40 if status_count is not None: 12:10:40 status_count -= 1 12:10:40 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 12:10:40 status = response.status 12:10:40 12:10:40 history = self.history + ( 12:10:40 RequestHistory(method, url, error, status, redirect_location), 12:10:40 ) 12:10:40 12:10:40 new_retry = self.new( 12:10:40 total=total, 12:10:40 connect=connect, 12:10:40 read=read, 12:10:40 redirect=redirect, 12:10:40 status=status_count, 12:10:40 other=other, 12:10:40 history=history, 12:10:40 ) 12:10:40 12:10:40 if new_retry.is_exhausted(): 12:10:40 reason = error or ResponseError(cause) 12:10:40 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 12:10:40 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 12:10:40 12:10:40 During handling of the above exception, another exception occurred: 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_17_xpdr_device_disconnected(self): 12:10:40 > response = test_utils.check_device_connection("XPDRA01") 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:195: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 transportpce_tests/common/test_utils.py:369: in check_device_connection 12:10:40 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 12:10:40 transportpce_tests/common/test_utils.py:116: in get_request 12:10:40 return requests.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 12:10:40 return session.request(method=method, url=url, **kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 12:10:40 resp = self.send(prep, **send_kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 12:10:40 r = adapter.send(request, **kwargs) 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 except (ProtocolError, OSError) as err: 12:10:40 raise ConnectionError(err, request=request) 12:10:40 12:10:40 except MaxRetryError as e: 12:10:40 if isinstance(e.reason, ConnectTimeoutError): 12:10:40 # TODO: Remove this in 3.0.0: see #2811 12:10:40 if not isinstance(e.reason, NewConnectionError): 12:10:40 raise ConnectTimeout(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, ResponseError): 12:10:40 raise RetryError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _ProxyError): 12:10:40 raise ProxyError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _SSLError): 12:10:40 # This branch is for urllib3 v1.22 and later. 12:10:40 raise SSLError(e, request=request) 12:10:40 12:10:40 > raise ConnectionError(e, request=request) 12:10:40 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_17_xpdr_device_disconnected 12:10:40 _______ TransportPCEPortMappingTesting.test_18_xpdr_device_not_connected _______ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 > sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 12:10:40 raise err 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 address = ('localhost', 8182), timeout = 10, source_address = None 12:10:40 socket_options = [(6, 1, 1)] 12:10:40 12:10:40 def create_connection( 12:10:40 address: tuple[str, int], 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 source_address: tuple[str, int] | None = None, 12:10:40 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 12:10:40 ) -> socket.socket: 12:10:40 """Connect to *address* and return the socket object. 12:10:40 12:10:40 Convenience function. Connect to *address* (a 2-tuple ``(host, 12:10:40 port)``) and return the socket object. Passing the optional 12:10:40 *timeout* parameter will set the timeout on the socket instance 12:10:40 before attempting to connect. If no *timeout* is supplied, the 12:10:40 global default timeout setting returned by :func:`socket.getdefaulttimeout` 12:10:40 is used. If *source_address* is set it must be a tuple of (host, port) 12:10:40 for the socket to bind as a source address before making the connection. 12:10:40 An host of '' or port 0 tells the OS to use the default. 12:10:40 """ 12:10:40 12:10:40 host, port = address 12:10:40 if host.startswith("["): 12:10:40 host = host.strip("[]") 12:10:40 err = None 12:10:40 12:10:40 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 12:10:40 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 12:10:40 # The original create_connection function always returns all records. 12:10:40 family = allowed_gai_family() 12:10:40 12:10:40 try: 12:10:40 host.encode("idna") 12:10:40 except UnicodeError: 12:10:40 raise LocationParseError(f"'{host}', label empty or too long") from None 12:10:40 12:10:40 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 12:10:40 af, socktype, proto, canonname, sa = res 12:10:40 sock = None 12:10:40 try: 12:10:40 sock = socket.socket(af, socktype, proto) 12:10:40 12:10:40 # If provided, set socket level options before connecting. 12:10:40 _set_socket_options(sock, socket_options) 12:10:40 12:10:40 if timeout is not _DEFAULT_TIMEOUT: 12:10:40 sock.settimeout(timeout) 12:10:40 if source_address: 12:10:40 sock.bind(source_address) 12:10:40 > sock.connect(sa) 12:10:40 E ConnectionRefusedError: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 12:10:40 body = None 12:10:40 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='} 12:10:40 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 redirect = False, assert_same_host = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 12:10:40 release_conn = False, chunked = False, body_pos = None, preload_content = False 12:10:40 decode_content = False, response_kw = {} 12:10:40 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info', query=None, fragment=None) 12:10:40 destination_scheme = None, conn = None, release_this_conn = True 12:10:40 http_tunnel_required = False, err = None, clean_exit = False 12:10:40 12:10:40 def urlopen( # type: ignore[override] 12:10:40 self, 12:10:40 method: str, 12:10:40 url: str, 12:10:40 body: _TYPE_BODY | None = None, 12:10:40 headers: typing.Mapping[str, str] | None = None, 12:10:40 retries: Retry | bool | int | None = None, 12:10:40 redirect: bool = True, 12:10:40 assert_same_host: bool = True, 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 pool_timeout: int | None = None, 12:10:40 release_conn: bool | None = None, 12:10:40 chunked: bool = False, 12:10:40 body_pos: _TYPE_BODY_POSITION | None = None, 12:10:40 preload_content: bool = True, 12:10:40 decode_content: bool = True, 12:10:40 **response_kw: typing.Any, 12:10:40 ) -> BaseHTTPResponse: 12:10:40 """ 12:10:40 Get a connection from the pool and perform an HTTP request. This is the 12:10:40 lowest level call for making a request, so you'll need to specify all 12:10:40 the raw details. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 More commonly, it's appropriate to use a convenience method 12:10:40 such as :meth:`request`. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 `release_conn` will only behave as expected if 12:10:40 `preload_content=False` because we want to make 12:10:40 `preload_content=False` the default behaviour someday soon without 12:10:40 breaking backwards compatibility. 12:10:40 12:10:40 :param method: 12:10:40 HTTP request method (such as GET, POST, PUT, etc.) 12:10:40 12:10:40 :param url: 12:10:40 The URL to perform the request on. 12:10:40 12:10:40 :param body: 12:10:40 Data to send in the request body, either :class:`str`, :class:`bytes`, 12:10:40 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 12:10:40 12:10:40 :param headers: 12:10:40 Dictionary of custom headers to send, such as User-Agent, 12:10:40 If-None-Match, etc. If None, pool headers are used. If provided, 12:10:40 these headers completely replace any pool-specific headers. 12:10:40 12:10:40 :param retries: 12:10:40 Configure the number of retries to allow before raising a 12:10:40 :class:`~urllib3.exceptions.MaxRetryError` exception. 12:10:40 12:10:40 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 12:10:40 :class:`~urllib3.util.retry.Retry` object for fine-grained control 12:10:40 over different types of retries. 12:10:40 Pass an integer number to retry connection errors that many times, 12:10:40 but no other types of errors. Pass zero to never retry. 12:10:40 12:10:40 If ``False``, then retries are disabled and any exception is raised 12:10:40 immediately. Also, instead of raising a MaxRetryError on redirects, 12:10:40 the redirect response will be returned. 12:10:40 12:10:40 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 12:10:40 12:10:40 :param redirect: 12:10:40 If True, automatically handle redirects (status codes 301, 302, 12:10:40 303, 307, 308). Each redirect counts as a retry. Disabling retries 12:10:40 will disable redirect, too. 12:10:40 12:10:40 :param assert_same_host: 12:10:40 If ``True``, will make sure that the host of the pool requests is 12:10:40 consistent else will raise HostChangedError. When ``False``, you can 12:10:40 use the pool on an HTTP proxy and request foreign hosts. 12:10:40 12:10:40 :param timeout: 12:10:40 If specified, overrides the default timeout for this one 12:10:40 request. It may be a float (in seconds) or an instance of 12:10:40 :class:`urllib3.util.Timeout`. 12:10:40 12:10:40 :param pool_timeout: 12:10:40 If set and the pool is set to block=True, then this method will 12:10:40 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 12:10:40 connection is available within the time period. 12:10:40 12:10:40 :param bool preload_content: 12:10:40 If True, the response's body will be preloaded into memory. 12:10:40 12:10:40 :param bool decode_content: 12:10:40 If True, will attempt to decode the body based on the 12:10:40 'content-encoding' header. 12:10:40 12:10:40 :param release_conn: 12:10:40 If False, then the urlopen call will not release the connection 12:10:40 back into the pool once a response is received (but will release if 12:10:40 you read the entire contents of the response such as when 12:10:40 `preload_content=True`). This is useful if you're not preloading 12:10:40 the response's content immediately. You will need to call 12:10:40 ``r.release_conn()`` on the response ``r`` to return the connection 12:10:40 back into the pool. If None, it takes the value of ``preload_content`` 12:10:40 which defaults to ``True``. 12:10:40 12:10:40 :param bool chunked: 12:10:40 If True, urllib3 will send the body using chunked transfer 12:10:40 encoding. Otherwise, urllib3 will send the body using the standard 12:10:40 content-length form. Defaults to False. 12:10:40 12:10:40 :param int body_pos: 12:10:40 Position to seek to in file-like body in the event of a retry or 12:10:40 redirect. Typically this won't need to be set because urllib3 will 12:10:40 auto-populate the value when needed. 12:10:40 """ 12:10:40 parsed_url = parse_url(url) 12:10:40 destination_scheme = parsed_url.scheme 12:10:40 12:10:40 if headers is None: 12:10:40 headers = self.headers 12:10:40 12:10:40 if not isinstance(retries, Retry): 12:10:40 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 12:10:40 12:10:40 if release_conn is None: 12:10:40 release_conn = preload_content 12:10:40 12:10:40 # Check host 12:10:40 if assert_same_host and not self.is_same_host(url): 12:10:40 raise HostChangedError(self, url, retries) 12:10:40 12:10:40 # Ensure that the URL we're connecting to is properly encoded 12:10:40 if url.startswith("/"): 12:10:40 url = to_str(_encode_target(url)) 12:10:40 else: 12:10:40 url = to_str(parsed_url.url) 12:10:40 12:10:40 conn = None 12:10:40 12:10:40 # Track whether `conn` needs to be released before 12:10:40 # returning/raising/recursing. Update this variable if necessary, and 12:10:40 # leave `release_conn` constant throughout the function. That way, if 12:10:40 # the function recurses, the original value of `release_conn` will be 12:10:40 # passed down into the recursive call, and its value will be respected. 12:10:40 # 12:10:40 # See issue #651 [1] for details. 12:10:40 # 12:10:40 # [1] 12:10:40 release_this_conn = release_conn 12:10:40 12:10:40 http_tunnel_required = connection_requires_http_tunnel( 12:10:40 self.proxy, self.proxy_config, destination_scheme 12:10:40 ) 12:10:40 12:10:40 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 12:10:40 # have to copy the headers dict so we can safely change it without those 12:10:40 # changes being reflected in anyone else's copy. 12:10:40 if not http_tunnel_required: 12:10:40 headers = headers.copy() # type: ignore[attr-defined] 12:10:40 headers.update(self.proxy_headers) # type: ignore[union-attr] 12:10:40 12:10:40 # Must keep the exception bound to a separate variable or else Python 3 12:10:40 # complains about UnboundLocalError. 12:10:40 err = None 12:10:40 12:10:40 # Keep track of whether we cleanly exited the except block. This 12:10:40 # ensures we do proper cleanup in finally. 12:10:40 clean_exit = False 12:10:40 12:10:40 # Rewind body position, if needed. Record current position 12:10:40 # for future rewinds in the event of a redirect/retry. 12:10:40 body_pos = set_file_position(body, body_pos) 12:10:40 12:10:40 try: 12:10:40 # Request a connection from the queue. 12:10:40 timeout_obj = self._get_timeout(timeout) 12:10:40 conn = self._get_conn(timeout=pool_timeout) 12:10:40 12:10:40 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 12:10:40 12:10:40 # Is this a closed/new connection that requires CONNECT tunnelling? 12:10:40 if self.proxy is not None and http_tunnel_required and conn.is_closed: 12:10:40 try: 12:10:40 self._prepare_proxy(conn) 12:10:40 except (BaseSSLError, OSError, SocketTimeout) as e: 12:10:40 self._raise_timeout( 12:10:40 err=e, url=self.proxy.url, timeout_value=conn.timeout 12:10:40 ) 12:10:40 raise 12:10:40 12:10:40 # If we're going to release the connection in ``finally:``, then 12:10:40 # the response doesn't need to know about the connection. Otherwise 12:10:40 # it will also try to release it and we'll have a double-release 12:10:40 # mess. 12:10:40 response_conn = conn if not release_conn else None 12:10:40 12:10:40 # Make the request on the HTTPConnection object 12:10:40 > response = self._make_request( 12:10:40 conn, 12:10:40 method, 12:10:40 url, 12:10:40 timeout=timeout_obj, 12:10:40 body=body, 12:10:40 headers=headers, 12:10:40 chunked=chunked, 12:10:40 retries=retries, 12:10:40 response_conn=response_conn, 12:10:40 preload_content=preload_content, 12:10:40 decode_content=decode_content, 12:10:40 **response_kw, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 12:10:40 conn.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 12:10:40 self.endheaders() 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 12:10:40 self._send_output(message_body, encode_chunked=encode_chunked) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 12:10:40 self.send(msg) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 12:10:40 self.connect() 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 12:10:40 self.sock = self._new_conn() 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 except socket.gaierror as e: 12:10:40 raise NameResolutionError(self.host, self, e) from e 12:10:40 except SocketTimeout as e: 12:10:40 raise ConnectTimeoutError( 12:10:40 self, 12:10:40 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 12:10:40 ) from e 12:10:40 12:10:40 except OSError as e: 12:10:40 > raise NewConnectionError( 12:10:40 self, f"Failed to establish a new connection: {e}" 12:10:40 ) from e 12:10:40 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 > resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 12:10:40 retries = retries.increment( 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 12:10:40 response = None 12:10:40 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 12:10:40 _pool = 12:10:40 _stacktrace = 12:10:40 12:10:40 def increment( 12:10:40 self, 12:10:40 method: str | None = None, 12:10:40 url: str | None = None, 12:10:40 response: BaseHTTPResponse | None = None, 12:10:40 error: Exception | None = None, 12:10:40 _pool: ConnectionPool | None = None, 12:10:40 _stacktrace: TracebackType | None = None, 12:10:40 ) -> Self: 12:10:40 """Return a new Retry object with incremented retry counters. 12:10:40 12:10:40 :param response: A response object, or None, if the server did not 12:10:40 return a response. 12:10:40 :type response: :class:`~urllib3.response.BaseHTTPResponse` 12:10:40 :param Exception error: An error encountered during the request, or 12:10:40 None if the response was received successfully. 12:10:40 12:10:40 :return: A new ``Retry`` object. 12:10:40 """ 12:10:40 if self.total is False and error: 12:10:40 # Disabled, indicate to re-raise the error. 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 12:10:40 total = self.total 12:10:40 if total is not None: 12:10:40 total -= 1 12:10:40 12:10:40 connect = self.connect 12:10:40 read = self.read 12:10:40 redirect = self.redirect 12:10:40 status_count = self.status 12:10:40 other = self.other 12:10:40 cause = "unknown" 12:10:40 status = None 12:10:40 redirect_location = None 12:10:40 12:10:40 if error and self._is_connection_error(error): 12:10:40 # Connect retry? 12:10:40 if connect is False: 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif connect is not None: 12:10:40 connect -= 1 12:10:40 12:10:40 elif error and self._is_read_error(error): 12:10:40 # Read retry? 12:10:40 if read is False or method is None or not self._is_method_retryable(method): 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif read is not None: 12:10:40 read -= 1 12:10:40 12:10:40 elif error: 12:10:40 # Other retry? 12:10:40 if other is not None: 12:10:40 other -= 1 12:10:40 12:10:40 elif response and response.get_redirect_location(): 12:10:40 # Redirect retry? 12:10:40 if redirect is not None: 12:10:40 redirect -= 1 12:10:40 cause = "too many redirects" 12:10:40 response_redirect_location = response.get_redirect_location() 12:10:40 if response_redirect_location: 12:10:40 redirect_location = response_redirect_location 12:10:40 status = response.status 12:10:40 12:10:40 else: 12:10:40 # Incrementing because of a server error like a 500 in 12:10:40 # status_forcelist and the given method is in the allowed_methods 12:10:40 cause = ResponseError.GENERIC_ERROR 12:10:40 if response and response.status: 12:10:40 if status_count is not None: 12:10:40 status_count -= 1 12:10:40 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 12:10:40 status = response.status 12:10:40 12:10:40 history = self.history + ( 12:10:40 RequestHistory(method, url, error, status, redirect_location), 12:10:40 ) 12:10:40 12:10:40 new_retry = self.new( 12:10:40 total=total, 12:10:40 connect=connect, 12:10:40 read=read, 12:10:40 redirect=redirect, 12:10:40 status=status_count, 12:10:40 other=other, 12:10:40 history=history, 12:10:40 ) 12:10:40 12:10:40 if new_retry.is_exhausted(): 12:10:40 reason = error or ResponseError(cause) 12:10:40 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 12:10:40 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 12:10:40 12:10:40 During handling of the above exception, another exception occurred: 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_18_xpdr_device_not_connected(self): 12:10:40 > response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:203: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 transportpce_tests/common/test_utils.py:470: in get_portmapping_node_attr 12:10:40 response = get_request(target_url) 12:10:40 transportpce_tests/common/test_utils.py:116: in get_request 12:10:40 return requests.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 12:10:40 return session.request(method=method, url=url, **kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 12:10:40 resp = self.send(prep, **send_kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 12:10:40 r = adapter.send(request, **kwargs) 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 except (ProtocolError, OSError) as err: 12:10:40 raise ConnectionError(err, request=request) 12:10:40 12:10:40 except MaxRetryError as e: 12:10:40 if isinstance(e.reason, ConnectTimeoutError): 12:10:40 # TODO: Remove this in 3.0.0: see #2811 12:10:40 if not isinstance(e.reason, NewConnectionError): 12:10:40 raise ConnectTimeout(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, ResponseError): 12:10:40 raise RetryError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _ProxyError): 12:10:40 raise ProxyError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _SSLError): 12:10:40 # This branch is for urllib3 v1.22 and later. 12:10:40 raise SSLError(e, request=request) 12:10:40 12:10:40 > raise ConnectionError(e, request=request) 12:10:40 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_18_xpdr_device_not_connected 12:10:40 _______ TransportPCEPortMappingTesting.test_19_rdm_device_disconnection ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 > sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 12:10:40 raise err 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 address = ('localhost', 8182), timeout = 10, source_address = None 12:10:40 socket_options = [(6, 1, 1)] 12:10:40 12:10:40 def create_connection( 12:10:40 address: tuple[str, int], 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 source_address: tuple[str, int] | None = None, 12:10:40 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 12:10:40 ) -> socket.socket: 12:10:40 """Connect to *address* and return the socket object. 12:10:40 12:10:40 Convenience function. Connect to *address* (a 2-tuple ``(host, 12:10:40 port)``) and return the socket object. Passing the optional 12:10:40 *timeout* parameter will set the timeout on the socket instance 12:10:40 before attempting to connect. If no *timeout* is supplied, the 12:10:40 global default timeout setting returned by :func:`socket.getdefaulttimeout` 12:10:40 is used. If *source_address* is set it must be a tuple of (host, port) 12:10:40 for the socket to bind as a source address before making the connection. 12:10:40 An host of '' or port 0 tells the OS to use the default. 12:10:40 """ 12:10:40 12:10:40 host, port = address 12:10:40 if host.startswith("["): 12:10:40 host = host.strip("[]") 12:10:40 err = None 12:10:40 12:10:40 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 12:10:40 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 12:10:40 # The original create_connection function always returns all records. 12:10:40 family = allowed_gai_family() 12:10:40 12:10:40 try: 12:10:40 host.encode("idna") 12:10:40 except UnicodeError: 12:10:40 raise LocationParseError(f"'{host}', label empty or too long") from None 12:10:40 12:10:40 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 12:10:40 af, socktype, proto, canonname, sa = res 12:10:40 sock = None 12:10:40 try: 12:10:40 sock = socket.socket(af, socktype, proto) 12:10:40 12:10:40 # If provided, set socket level options before connecting. 12:10:40 _set_socket_options(sock, socket_options) 12:10:40 12:10:40 if timeout is not _DEFAULT_TIMEOUT: 12:10:40 sock.settimeout(timeout) 12:10:40 if source_address: 12:10:40 sock.bind(source_address) 12:10:40 > sock.connect(sa) 12:10:40 E ConnectionRefusedError: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 method = 'DELETE' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01' 12:10:40 body = None 12:10:40 headers = {'User-Agent': 'python-requests/2.32.3', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '0', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 12:10:40 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 redirect = False, assert_same_host = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 12:10:40 release_conn = False, chunked = False, body_pos = None, preload_content = False 12:10:40 decode_content = False, response_kw = {} 12:10:40 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01', query=None, fragment=None) 12:10:40 destination_scheme = None, conn = None, release_this_conn = True 12:10:40 http_tunnel_required = False, err = None, clean_exit = False 12:10:40 12:10:40 def urlopen( # type: ignore[override] 12:10:40 self, 12:10:40 method: str, 12:10:40 url: str, 12:10:40 body: _TYPE_BODY | None = None, 12:10:40 headers: typing.Mapping[str, str] | None = None, 12:10:40 retries: Retry | bool | int | None = None, 12:10:40 redirect: bool = True, 12:10:40 assert_same_host: bool = True, 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 pool_timeout: int | None = None, 12:10:40 release_conn: bool | None = None, 12:10:40 chunked: bool = False, 12:10:40 body_pos: _TYPE_BODY_POSITION | None = None, 12:10:40 preload_content: bool = True, 12:10:40 decode_content: bool = True, 12:10:40 **response_kw: typing.Any, 12:10:40 ) -> BaseHTTPResponse: 12:10:40 """ 12:10:40 Get a connection from the pool and perform an HTTP request. This is the 12:10:40 lowest level call for making a request, so you'll need to specify all 12:10:40 the raw details. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 More commonly, it's appropriate to use a convenience method 12:10:40 such as :meth:`request`. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 `release_conn` will only behave as expected if 12:10:40 `preload_content=False` because we want to make 12:10:40 `preload_content=False` the default behaviour someday soon without 12:10:40 breaking backwards compatibility. 12:10:40 12:10:40 :param method: 12:10:40 HTTP request method (such as GET, POST, PUT, etc.) 12:10:40 12:10:40 :param url: 12:10:40 The URL to perform the request on. 12:10:40 12:10:40 :param body: 12:10:40 Data to send in the request body, either :class:`str`, :class:`bytes`, 12:10:40 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 12:10:40 12:10:40 :param headers: 12:10:40 Dictionary of custom headers to send, such as User-Agent, 12:10:40 If-None-Match, etc. If None, pool headers are used. If provided, 12:10:40 these headers completely replace any pool-specific headers. 12:10:40 12:10:40 :param retries: 12:10:40 Configure the number of retries to allow before raising a 12:10:40 :class:`~urllib3.exceptions.MaxRetryError` exception. 12:10:40 12:10:40 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 12:10:40 :class:`~urllib3.util.retry.Retry` object for fine-grained control 12:10:40 over different types of retries. 12:10:40 Pass an integer number to retry connection errors that many times, 12:10:40 but no other types of errors. Pass zero to never retry. 12:10:40 12:10:40 If ``False``, then retries are disabled and any exception is raised 12:10:40 immediately. Also, instead of raising a MaxRetryError on redirects, 12:10:40 the redirect response will be returned. 12:10:40 12:10:40 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 12:10:40 12:10:40 :param redirect: 12:10:40 If True, automatically handle redirects (status codes 301, 302, 12:10:40 303, 307, 308). Each redirect counts as a retry. Disabling retries 12:10:40 will disable redirect, too. 12:10:40 12:10:40 :param assert_same_host: 12:10:40 If ``True``, will make sure that the host of the pool requests is 12:10:40 consistent else will raise HostChangedError. When ``False``, you can 12:10:40 use the pool on an HTTP proxy and request foreign hosts. 12:10:40 12:10:40 :param timeout: 12:10:40 If specified, overrides the default timeout for this one 12:10:40 request. It may be a float (in seconds) or an instance of 12:10:40 :class:`urllib3.util.Timeout`. 12:10:40 12:10:40 :param pool_timeout: 12:10:40 If set and the pool is set to block=True, then this method will 12:10:40 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 12:10:40 connection is available within the time period. 12:10:40 12:10:40 :param bool preload_content: 12:10:40 If True, the response's body will be preloaded into memory. 12:10:40 12:10:40 :param bool decode_content: 12:10:40 If True, will attempt to decode the body based on the 12:10:40 'content-encoding' header. 12:10:40 12:10:40 :param release_conn: 12:10:40 If False, then the urlopen call will not release the connection 12:10:40 back into the pool once a response is received (but will release if 12:10:40 you read the entire contents of the response such as when 12:10:40 `preload_content=True`). This is useful if you're not preloading 12:10:40 the response's content immediately. You will need to call 12:10:40 ``r.release_conn()`` on the response ``r`` to return the connection 12:10:40 back into the pool. If None, it takes the value of ``preload_content`` 12:10:40 which defaults to ``True``. 12:10:40 12:10:40 :param bool chunked: 12:10:40 If True, urllib3 will send the body using chunked transfer 12:10:40 encoding. Otherwise, urllib3 will send the body using the standard 12:10:40 content-length form. Defaults to False. 12:10:40 12:10:40 :param int body_pos: 12:10:40 Position to seek to in file-like body in the event of a retry or 12:10:40 redirect. Typically this won't need to be set because urllib3 will 12:10:40 auto-populate the value when needed. 12:10:40 """ 12:10:40 parsed_url = parse_url(url) 12:10:40 destination_scheme = parsed_url.scheme 12:10:40 12:10:40 if headers is None: 12:10:40 headers = self.headers 12:10:40 12:10:40 if not isinstance(retries, Retry): 12:10:40 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 12:10:40 12:10:40 if release_conn is None: 12:10:40 release_conn = preload_content 12:10:40 12:10:40 # Check host 12:10:40 if assert_same_host and not self.is_same_host(url): 12:10:40 raise HostChangedError(self, url, retries) 12:10:40 12:10:40 # Ensure that the URL we're connecting to is properly encoded 12:10:40 if url.startswith("/"): 12:10:40 url = to_str(_encode_target(url)) 12:10:40 else: 12:10:40 url = to_str(parsed_url.url) 12:10:40 12:10:40 conn = None 12:10:40 12:10:40 # Track whether `conn` needs to be released before 12:10:40 # returning/raising/recursing. Update this variable if necessary, and 12:10:40 # leave `release_conn` constant throughout the function. That way, if 12:10:40 # the function recurses, the original value of `release_conn` will be 12:10:40 # passed down into the recursive call, and its value will be respected. 12:10:40 # 12:10:40 # See issue #651 [1] for details. 12:10:40 # 12:10:40 # [1] 12:10:40 release_this_conn = release_conn 12:10:40 12:10:40 http_tunnel_required = connection_requires_http_tunnel( 12:10:40 self.proxy, self.proxy_config, destination_scheme 12:10:40 ) 12:10:40 12:10:40 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 12:10:40 # have to copy the headers dict so we can safely change it without those 12:10:40 # changes being reflected in anyone else's copy. 12:10:40 if not http_tunnel_required: 12:10:40 headers = headers.copy() # type: ignore[attr-defined] 12:10:40 headers.update(self.proxy_headers) # type: ignore[union-attr] 12:10:40 12:10:40 # Must keep the exception bound to a separate variable or else Python 3 12:10:40 # complains about UnboundLocalError. 12:10:40 err = None 12:10:40 12:10:40 # Keep track of whether we cleanly exited the except block. This 12:10:40 # ensures we do proper cleanup in finally. 12:10:40 clean_exit = False 12:10:40 12:10:40 # Rewind body position, if needed. Record current position 12:10:40 # for future rewinds in the event of a redirect/retry. 12:10:40 body_pos = set_file_position(body, body_pos) 12:10:40 12:10:40 try: 12:10:40 # Request a connection from the queue. 12:10:40 timeout_obj = self._get_timeout(timeout) 12:10:40 conn = self._get_conn(timeout=pool_timeout) 12:10:40 12:10:40 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 12:10:40 12:10:40 # Is this a closed/new connection that requires CONNECT tunnelling? 12:10:40 if self.proxy is not None and http_tunnel_required and conn.is_closed: 12:10:40 try: 12:10:40 self._prepare_proxy(conn) 12:10:40 except (BaseSSLError, OSError, SocketTimeout) as e: 12:10:40 self._raise_timeout( 12:10:40 err=e, url=self.proxy.url, timeout_value=conn.timeout 12:10:40 ) 12:10:40 raise 12:10:40 12:10:40 # If we're going to release the connection in ``finally:``, then 12:10:40 # the response doesn't need to know about the connection. Otherwise 12:10:40 # it will also try to release it and we'll have a double-release 12:10:40 # mess. 12:10:40 response_conn = conn if not release_conn else None 12:10:40 12:10:40 # Make the request on the HTTPConnection object 12:10:40 > response = self._make_request( 12:10:40 conn, 12:10:40 method, 12:10:40 url, 12:10:40 timeout=timeout_obj, 12:10:40 body=body, 12:10:40 headers=headers, 12:10:40 chunked=chunked, 12:10:40 retries=retries, 12:10:40 response_conn=response_conn, 12:10:40 preload_content=preload_content, 12:10:40 decode_content=decode_content, 12:10:40 **response_kw, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 12:10:40 conn.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 12:10:40 self.endheaders() 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 12:10:40 self._send_output(message_body, encode_chunked=encode_chunked) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 12:10:40 self.send(msg) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 12:10:40 self.connect() 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 12:10:40 self.sock = self._new_conn() 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 except socket.gaierror as e: 12:10:40 raise NameResolutionError(self.host, self, e) from e 12:10:40 except SocketTimeout as e: 12:10:40 raise ConnectTimeoutError( 12:10:40 self, 12:10:40 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 12:10:40 ) from e 12:10:40 12:10:40 except OSError as e: 12:10:40 > raise NewConnectionError( 12:10:40 self, f"Failed to establish a new connection: {e}" 12:10:40 ) from e 12:10:40 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 > resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 12:10:40 retries = retries.increment( 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 method = 'DELETE' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01' 12:10:40 response = None 12:10:40 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 12:10:40 _pool = 12:10:40 _stacktrace = 12:10:40 12:10:40 def increment( 12:10:40 self, 12:10:40 method: str | None = None, 12:10:40 url: str | None = None, 12:10:40 response: BaseHTTPResponse | None = None, 12:10:40 error: Exception | None = None, 12:10:40 _pool: ConnectionPool | None = None, 12:10:40 _stacktrace: TracebackType | None = None, 12:10:40 ) -> Self: 12:10:40 """Return a new Retry object with incremented retry counters. 12:10:40 12:10:40 :param response: A response object, or None, if the server did not 12:10:40 return a response. 12:10:40 :type response: :class:`~urllib3.response.BaseHTTPResponse` 12:10:40 :param Exception error: An error encountered during the request, or 12:10:40 None if the response was received successfully. 12:10:40 12:10:40 :return: A new ``Retry`` object. 12:10:40 """ 12:10:40 if self.total is False and error: 12:10:40 # Disabled, indicate to re-raise the error. 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 12:10:40 total = self.total 12:10:40 if total is not None: 12:10:40 total -= 1 12:10:40 12:10:40 connect = self.connect 12:10:40 read = self.read 12:10:40 redirect = self.redirect 12:10:40 status_count = self.status 12:10:40 other = self.other 12:10:40 cause = "unknown" 12:10:40 status = None 12:10:40 redirect_location = None 12:10:40 12:10:40 if error and self._is_connection_error(error): 12:10:40 # Connect retry? 12:10:40 if connect is False: 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif connect is not None: 12:10:40 connect -= 1 12:10:40 12:10:40 elif error and self._is_read_error(error): 12:10:40 # Read retry? 12:10:40 if read is False or method is None or not self._is_method_retryable(method): 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif read is not None: 12:10:40 read -= 1 12:10:40 12:10:40 elif error: 12:10:40 # Other retry? 12:10:40 if other is not None: 12:10:40 other -= 1 12:10:40 12:10:40 elif response and response.get_redirect_location(): 12:10:40 # Redirect retry? 12:10:40 if redirect is not None: 12:10:40 redirect -= 1 12:10:40 cause = "too many redirects" 12:10:40 response_redirect_location = response.get_redirect_location() 12:10:40 if response_redirect_location: 12:10:40 redirect_location = response_redirect_location 12:10:40 status = response.status 12:10:40 12:10:40 else: 12:10:40 # Incrementing because of a server error like a 500 in 12:10:40 # status_forcelist and the given method is in the allowed_methods 12:10:40 cause = ResponseError.GENERIC_ERROR 12:10:40 if response and response.status: 12:10:40 if status_count is not None: 12:10:40 status_count -= 1 12:10:40 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 12:10:40 status = response.status 12:10:40 12:10:40 history = self.history + ( 12:10:40 RequestHistory(method, url, error, status, redirect_location), 12:10:40 ) 12:10:40 12:10:40 new_retry = self.new( 12:10:40 total=total, 12:10:40 connect=connect, 12:10:40 read=read, 12:10:40 redirect=redirect, 12:10:40 status=status_count, 12:10:40 other=other, 12:10:40 history=history, 12:10:40 ) 12:10:40 12:10:40 if new_retry.is_exhausted(): 12:10:40 reason = error or ResponseError(cause) 12:10:40 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 12:10:40 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 12:10:40 12:10:40 During handling of the above exception, another exception occurred: 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_19_rdm_device_disconnection(self): 12:10:40 > response = test_utils.unmount_device("ROADMA01") 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:211: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 transportpce_tests/common/test_utils.py:358: in unmount_device 12:10:40 response = delete_request(url[RESTCONF_VERSION].format('{}', node)) 12:10:40 transportpce_tests/common/test_utils.py:133: in delete_request 12:10:40 return requests.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 12:10:40 return session.request(method=method, url=url, **kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 12:10:40 resp = self.send(prep, **send_kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 12:10:40 r = adapter.send(request, **kwargs) 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 except (ProtocolError, OSError) as err: 12:10:40 raise ConnectionError(err, request=request) 12:10:40 12:10:40 except MaxRetryError as e: 12:10:40 if isinstance(e.reason, ConnectTimeoutError): 12:10:40 # TODO: Remove this in 3.0.0: see #2811 12:10:40 if not isinstance(e.reason, NewConnectionError): 12:10:40 raise ConnectTimeout(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, ResponseError): 12:10:40 raise RetryError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _ProxyError): 12:10:40 raise ProxyError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _SSLError): 12:10:40 # This branch is for urllib3 v1.22 and later. 12:10:40 raise SSLError(e, request=request) 12:10:40 12:10:40 > raise ConnectionError(e, request=request) 12:10:40 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_19_rdm_device_disconnection 12:10:40 ________ TransportPCEPortMappingTesting.test_20_rdm_device_disconnected ________ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 > sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 12:10:40 raise err 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 address = ('localhost', 8182), timeout = 10, source_address = None 12:10:40 socket_options = [(6, 1, 1)] 12:10:40 12:10:40 def create_connection( 12:10:40 address: tuple[str, int], 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 source_address: tuple[str, int] | None = None, 12:10:40 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 12:10:40 ) -> socket.socket: 12:10:40 """Connect to *address* and return the socket object. 12:10:40 12:10:40 Convenience function. Connect to *address* (a 2-tuple ``(host, 12:10:40 port)``) and return the socket object. Passing the optional 12:10:40 *timeout* parameter will set the timeout on the socket instance 12:10:40 before attempting to connect. If no *timeout* is supplied, the 12:10:40 global default timeout setting returned by :func:`socket.getdefaulttimeout` 12:10:40 is used. If *source_address* is set it must be a tuple of (host, port) 12:10:40 for the socket to bind as a source address before making the connection. 12:10:40 An host of '' or port 0 tells the OS to use the default. 12:10:40 """ 12:10:40 12:10:40 host, port = address 12:10:40 if host.startswith("["): 12:10:40 host = host.strip("[]") 12:10:40 err = None 12:10:40 12:10:40 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 12:10:40 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 12:10:40 # The original create_connection function always returns all records. 12:10:40 family = allowed_gai_family() 12:10:40 12:10:40 try: 12:10:40 host.encode("idna") 12:10:40 except UnicodeError: 12:10:40 raise LocationParseError(f"'{host}', label empty or too long") from None 12:10:40 12:10:40 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 12:10:40 af, socktype, proto, canonname, sa = res 12:10:40 sock = None 12:10:40 try: 12:10:40 sock = socket.socket(af, socktype, proto) 12:10:40 12:10:40 # If provided, set socket level options before connecting. 12:10:40 _set_socket_options(sock, socket_options) 12:10:40 12:10:40 if timeout is not _DEFAULT_TIMEOUT: 12:10:40 sock.settimeout(timeout) 12:10:40 if source_address: 12:10:40 sock.bind(source_address) 12:10:40 > sock.connect(sa) 12:10:40 E ConnectionRefusedError: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 12:10:40 body = None 12:10:40 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='} 12:10:40 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 redirect = False, assert_same_host = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 12:10:40 release_conn = False, chunked = False, body_pos = None, preload_content = False 12:10:40 decode_content = False, response_kw = {} 12:10:40 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) 12:10:40 destination_scheme = None, conn = None, release_this_conn = True 12:10:40 http_tunnel_required = False, err = None, clean_exit = False 12:10:40 12:10:40 def urlopen( # type: ignore[override] 12:10:40 self, 12:10:40 method: str, 12:10:40 url: str, 12:10:40 body: _TYPE_BODY | None = None, 12:10:40 headers: typing.Mapping[str, str] | None = None, 12:10:40 retries: Retry | bool | int | None = None, 12:10:40 redirect: bool = True, 12:10:40 assert_same_host: bool = True, 12:10:40 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:10:40 pool_timeout: int | None = None, 12:10:40 release_conn: bool | None = None, 12:10:40 chunked: bool = False, 12:10:40 body_pos: _TYPE_BODY_POSITION | None = None, 12:10:40 preload_content: bool = True, 12:10:40 decode_content: bool = True, 12:10:40 **response_kw: typing.Any, 12:10:40 ) -> BaseHTTPResponse: 12:10:40 """ 12:10:40 Get a connection from the pool and perform an HTTP request. This is the 12:10:40 lowest level call for making a request, so you'll need to specify all 12:10:40 the raw details. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 More commonly, it's appropriate to use a convenience method 12:10:40 such as :meth:`request`. 12:10:40 12:10:40 .. note:: 12:10:40 12:10:40 `release_conn` will only behave as expected if 12:10:40 `preload_content=False` because we want to make 12:10:40 `preload_content=False` the default behaviour someday soon without 12:10:40 breaking backwards compatibility. 12:10:40 12:10:40 :param method: 12:10:40 HTTP request method (such as GET, POST, PUT, etc.) 12:10:40 12:10:40 :param url: 12:10:40 The URL to perform the request on. 12:10:40 12:10:40 :param body: 12:10:40 Data to send in the request body, either :class:`str`, :class:`bytes`, 12:10:40 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 12:10:40 12:10:40 :param headers: 12:10:40 Dictionary of custom headers to send, such as User-Agent, 12:10:40 If-None-Match, etc. If None, pool headers are used. If provided, 12:10:40 these headers completely replace any pool-specific headers. 12:10:40 12:10:40 :param retries: 12:10:40 Configure the number of retries to allow before raising a 12:10:40 :class:`~urllib3.exceptions.MaxRetryError` exception. 12:10:40 12:10:40 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 12:10:40 :class:`~urllib3.util.retry.Retry` object for fine-grained control 12:10:40 over different types of retries. 12:10:40 Pass an integer number to retry connection errors that many times, 12:10:40 but no other types of errors. Pass zero to never retry. 12:10:40 12:10:40 If ``False``, then retries are disabled and any exception is raised 12:10:40 immediately. Also, instead of raising a MaxRetryError on redirects, 12:10:40 the redirect response will be returned. 12:10:40 12:10:40 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 12:10:40 12:10:40 :param redirect: 12:10:40 If True, automatically handle redirects (status codes 301, 302, 12:10:40 303, 307, 308). Each redirect counts as a retry. Disabling retries 12:10:40 will disable redirect, too. 12:10:40 12:10:40 :param assert_same_host: 12:10:40 If ``True``, will make sure that the host of the pool requests is 12:10:40 consistent else will raise HostChangedError. When ``False``, you can 12:10:40 use the pool on an HTTP proxy and request foreign hosts. 12:10:40 12:10:40 :param timeout: 12:10:40 If specified, overrides the default timeout for this one 12:10:40 request. It may be a float (in seconds) or an instance of 12:10:40 :class:`urllib3.util.Timeout`. 12:10:40 12:10:40 :param pool_timeout: 12:10:40 If set and the pool is set to block=True, then this method will 12:10:40 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 12:10:40 connection is available within the time period. 12:10:40 12:10:40 :param bool preload_content: 12:10:40 If True, the response's body will be preloaded into memory. 12:10:40 12:10:40 :param bool decode_content: 12:10:40 If True, will attempt to decode the body based on the 12:10:40 'content-encoding' header. 12:10:40 12:10:40 :param release_conn: 12:10:40 If False, then the urlopen call will not release the connection 12:10:40 back into the pool once a response is received (but will release if 12:10:40 you read the entire contents of the response such as when 12:10:40 `preload_content=True`). This is useful if you're not preloading 12:10:40 the response's content immediately. You will need to call 12:10:40 ``r.release_conn()`` on the response ``r`` to return the connection 12:10:40 back into the pool. If None, it takes the value of ``preload_content`` 12:10:40 which defaults to ``True``. 12:10:40 12:10:40 :param bool chunked: 12:10:40 If True, urllib3 will send the body using chunked transfer 12:10:40 encoding. Otherwise, urllib3 will send the body using the standard 12:10:40 content-length form. Defaults to False. 12:10:40 12:10:40 :param int body_pos: 12:10:40 Position to seek to in file-like body in the event of a retry or 12:10:40 redirect. Typically this won't need to be set because urllib3 will 12:10:40 auto-populate the value when needed. 12:10:40 """ 12:10:40 parsed_url = parse_url(url) 12:10:40 destination_scheme = parsed_url.scheme 12:10:40 12:10:40 if headers is None: 12:10:40 headers = self.headers 12:10:40 12:10:40 if not isinstance(retries, Retry): 12:10:40 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 12:10:40 12:10:40 if release_conn is None: 12:10:40 release_conn = preload_content 12:10:40 12:10:40 # Check host 12:10:40 if assert_same_host and not self.is_same_host(url): 12:10:40 raise HostChangedError(self, url, retries) 12:10:40 12:10:40 # Ensure that the URL we're connecting to is properly encoded 12:10:40 if url.startswith("/"): 12:10:40 url = to_str(_encode_target(url)) 12:10:40 else: 12:10:40 url = to_str(parsed_url.url) 12:10:40 12:10:40 conn = None 12:10:40 12:10:40 # Track whether `conn` needs to be released before 12:10:40 # returning/raising/recursing. Update this variable if necessary, and 12:10:40 # leave `release_conn` constant throughout the function. That way, if 12:10:40 # the function recurses, the original value of `release_conn` will be 12:10:40 # passed down into the recursive call, and its value will be respected. 12:10:40 # 12:10:40 # See issue #651 [1] for details. 12:10:40 # 12:10:40 # [1] 12:10:40 release_this_conn = release_conn 12:10:40 12:10:40 http_tunnel_required = connection_requires_http_tunnel( 12:10:40 self.proxy, self.proxy_config, destination_scheme 12:10:40 ) 12:10:40 12:10:40 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 12:10:40 # have to copy the headers dict so we can safely change it without those 12:10:40 # changes being reflected in anyone else's copy. 12:10:40 if not http_tunnel_required: 12:10:40 headers = headers.copy() # type: ignore[attr-defined] 12:10:40 headers.update(self.proxy_headers) # type: ignore[union-attr] 12:10:40 12:10:40 # Must keep the exception bound to a separate variable or else Python 3 12:10:40 # complains about UnboundLocalError. 12:10:40 err = None 12:10:40 12:10:40 # Keep track of whether we cleanly exited the except block. This 12:10:40 # ensures we do proper cleanup in finally. 12:10:40 clean_exit = False 12:10:40 12:10:40 # Rewind body position, if needed. Record current position 12:10:40 # for future rewinds in the event of a redirect/retry. 12:10:40 body_pos = set_file_position(body, body_pos) 12:10:40 12:10:40 try: 12:10:40 # Request a connection from the queue. 12:10:40 timeout_obj = self._get_timeout(timeout) 12:10:40 conn = self._get_conn(timeout=pool_timeout) 12:10:40 12:10:40 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 12:10:40 12:10:40 # Is this a closed/new connection that requires CONNECT tunnelling? 12:10:40 if self.proxy is not None and http_tunnel_required and conn.is_closed: 12:10:40 try: 12:10:40 self._prepare_proxy(conn) 12:10:40 except (BaseSSLError, OSError, SocketTimeout) as e: 12:10:40 self._raise_timeout( 12:10:40 err=e, url=self.proxy.url, timeout_value=conn.timeout 12:10:40 ) 12:10:40 raise 12:10:40 12:10:40 # If we're going to release the connection in ``finally:``, then 12:10:40 # the response doesn't need to know about the connection. Otherwise 12:10:40 # it will also try to release it and we'll have a double-release 12:10:40 # mess. 12:10:40 response_conn = conn if not release_conn else None 12:10:40 12:10:40 # Make the request on the HTTPConnection object 12:10:40 > response = self._make_request( 12:10:40 conn, 12:10:40 method, 12:10:40 url, 12:10:40 timeout=timeout_obj, 12:10:40 body=body, 12:10:40 headers=headers, 12:10:40 chunked=chunked, 12:10:40 retries=retries, 12:10:40 response_conn=response_conn, 12:10:40 preload_content=preload_content, 12:10:40 decode_content=decode_content, 12:10:40 **response_kw, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 12:10:40 conn.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 12:10:40 self.endheaders() 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 12:10:40 self._send_output(message_body, encode_chunked=encode_chunked) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 12:10:40 self.send(msg) 12:10:40 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 12:10:40 self.connect() 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 12:10:40 self.sock = self._new_conn() 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 12:10:40 def _new_conn(self) -> socket.socket: 12:10:40 """Establish a socket connection and set nodelay settings on it. 12:10:40 12:10:40 :return: New socket connection. 12:10:40 """ 12:10:40 try: 12:10:40 sock = connection.create_connection( 12:10:40 (self._dns_host, self.port), 12:10:40 self.timeout, 12:10:40 source_address=self.source_address, 12:10:40 socket_options=self.socket_options, 12:10:40 ) 12:10:40 except socket.gaierror as e: 12:10:40 raise NameResolutionError(self.host, self, e) from e 12:10:40 except SocketTimeout as e: 12:10:40 raise ConnectTimeoutError( 12:10:40 self, 12:10:40 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 12:10:40 ) from e 12:10:40 12:10:40 except OSError as e: 12:10:40 > raise NewConnectionError( 12:10:40 self, f"Failed to establish a new connection: {e}" 12:10:40 ) from e 12:10:40 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 12:10:40 12:10:40 The above exception was the direct cause of the following exception: 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 > resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 12:10:40 retries = retries.increment( 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:10:40 method = 'GET' 12:10:40 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 12:10:40 response = None 12:10:40 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 12:10:40 _pool = 12:10:40 _stacktrace = 12:10:40 12:10:40 def increment( 12:10:40 self, 12:10:40 method: str | None = None, 12:10:40 url: str | None = None, 12:10:40 response: BaseHTTPResponse | None = None, 12:10:40 error: Exception | None = None, 12:10:40 _pool: ConnectionPool | None = None, 12:10:40 _stacktrace: TracebackType | None = None, 12:10:40 ) -> Self: 12:10:40 """Return a new Retry object with incremented retry counters. 12:10:40 12:10:40 :param response: A response object, or None, if the server did not 12:10:40 return a response. 12:10:40 :type response: :class:`~urllib3.response.BaseHTTPResponse` 12:10:40 :param Exception error: An error encountered during the request, or 12:10:40 None if the response was received successfully. 12:10:40 12:10:40 :return: A new ``Retry`` object. 12:10:40 """ 12:10:40 if self.total is False and error: 12:10:40 # Disabled, indicate to re-raise the error. 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 12:10:40 total = self.total 12:10:40 if total is not None: 12:10:40 total -= 1 12:10:40 12:10:40 connect = self.connect 12:10:40 read = self.read 12:10:40 redirect = self.redirect 12:10:40 status_count = self.status 12:10:40 other = self.other 12:10:40 cause = "unknown" 12:10:40 status = None 12:10:40 redirect_location = None 12:10:40 12:10:40 if error and self._is_connection_error(error): 12:10:40 # Connect retry? 12:10:40 if connect is False: 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif connect is not None: 12:10:40 connect -= 1 12:10:40 12:10:40 elif error and self._is_read_error(error): 12:10:40 # Read retry? 12:10:40 if read is False or method is None or not self._is_method_retryable(method): 12:10:40 raise reraise(type(error), error, _stacktrace) 12:10:40 elif read is not None: 12:10:40 read -= 1 12:10:40 12:10:40 elif error: 12:10:40 # Other retry? 12:10:40 if other is not None: 12:10:40 other -= 1 12:10:40 12:10:40 elif response and response.get_redirect_location(): 12:10:40 # Redirect retry? 12:10:40 if redirect is not None: 12:10:40 redirect -= 1 12:10:40 cause = "too many redirects" 12:10:40 response_redirect_location = response.get_redirect_location() 12:10:40 if response_redirect_location: 12:10:40 redirect_location = response_redirect_location 12:10:40 status = response.status 12:10:40 12:10:40 else: 12:10:40 # Incrementing because of a server error like a 500 in 12:10:40 # status_forcelist and the given method is in the allowed_methods 12:10:40 cause = ResponseError.GENERIC_ERROR 12:10:40 if response and response.status: 12:10:40 if status_count is not None: 12:10:40 status_count -= 1 12:10:40 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 12:10:40 status = response.status 12:10:40 12:10:40 history = self.history + ( 12:10:40 RequestHistory(method, url, error, status, redirect_location), 12:10:40 ) 12:10:40 12:10:40 new_retry = self.new( 12:10:40 total=total, 12:10:40 connect=connect, 12:10:40 read=read, 12:10:40 redirect=redirect, 12:10:40 status=status_count, 12:10:40 other=other, 12:10:40 history=history, 12:10:40 ) 12:10:40 12:10:40 if new_retry.is_exhausted(): 12:10:40 reason = error or ResponseError(cause) 12:10:40 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 12:10:40 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')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 12:10:40 12:10:40 During handling of the above exception, another exception occurred: 12:10:40 12:10:40 self = 12:10:40 12:10:40 def test_20_rdm_device_disconnected(self): 12:10:40 > response = test_utils.check_device_connection("ROADMA01") 12:10:40 12:10:40 transportpce_tests/1.2.1/test01_portmapping.py:215: 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 transportpce_tests/common/test_utils.py:369: in check_device_connection 12:10:40 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 12:10:40 transportpce_tests/common/test_utils.py:116: in get_request 12:10:40 return requests.request( 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 12:10:40 return session.request(method=method, url=url, **kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 12:10:40 resp = self.send(prep, **send_kwargs) 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 12:10:40 r = adapter.send(request, **kwargs) 12:10:40 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:10:40 12:10:40 self = 12:10:40 request = , stream = False 12:10:40 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 12:10:40 proxies = OrderedDict() 12:10:40 12:10:40 def send( 12:10:40 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:10:40 ): 12:10:40 """Sends PreparedRequest object. Returns Response object. 12:10:40 12:10:40 :param request: The :class:`PreparedRequest ` being sent. 12:10:40 :param stream: (optional) Whether to stream the request content. 12:10:40 :param timeout: (optional) How long to wait for the server to send 12:10:40 data before giving up, as a float, or a :ref:`(connect timeout, 12:10:40 read timeout) ` tuple. 12:10:40 :type timeout: float or tuple or urllib3 Timeout object 12:10:40 :param verify: (optional) Either a boolean, in which case it controls whether 12:10:40 we verify the server's TLS certificate, or a string, in which case it 12:10:40 must be a path to a CA bundle to use 12:10:40 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:10:40 :param proxies: (optional) The proxies dictionary to apply to the request. 12:10:40 :rtype: requests.Response 12:10:40 """ 12:10:40 12:10:40 try: 12:10:40 conn = self.get_connection_with_tls_context( 12:10:40 request, verify, proxies=proxies, cert=cert 12:10:40 ) 12:10:40 except LocationValueError as e: 12:10:40 raise InvalidURL(e, request=request) 12:10:40 12:10:40 self.cert_verify(conn, request.url, verify, cert) 12:10:40 url = self.request_url(request, proxies) 12:10:40 self.add_headers( 12:10:40 request, 12:10:40 stream=stream, 12:10:40 timeout=timeout, 12:10:40 verify=verify, 12:10:40 cert=cert, 12:10:40 proxies=proxies, 12:10:40 ) 12:10:40 12:10:40 chunked = not (request.body is None or "Content-Length" in request.headers) 12:10:40 12:10:40 if isinstance(timeout, tuple): 12:10:40 try: 12:10:40 connect, read = timeout 12:10:40 timeout = TimeoutSauce(connect=connect, read=read) 12:10:40 except ValueError: 12:10:40 raise ValueError( 12:10:40 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:10:40 f"or a single float to set both timeouts to the same value." 12:10:40 ) 12:10:40 elif isinstance(timeout, TimeoutSauce): 12:10:40 pass 12:10:40 else: 12:10:40 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:10:40 12:10:40 try: 12:10:40 resp = conn.urlopen( 12:10:40 method=request.method, 12:10:40 url=url, 12:10:40 body=request.body, 12:10:40 headers=request.headers, 12:10:40 redirect=False, 12:10:40 assert_same_host=False, 12:10:40 preload_content=False, 12:10:40 decode_content=False, 12:10:40 retries=self.max_retries, 12:10:40 timeout=timeout, 12:10:40 chunked=chunked, 12:10:40 ) 12:10:40 12:10:40 except (ProtocolError, OSError) as err: 12:10:40 raise ConnectionError(err, request=request) 12:10:40 12:10:40 except MaxRetryError as e: 12:10:40 if isinstance(e.reason, ConnectTimeoutError): 12:10:40 # TODO: Remove this in 3.0.0: see #2811 12:10:40 if not isinstance(e.reason, NewConnectionError): 12:10:40 raise ConnectTimeout(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, ResponseError): 12:10:40 raise RetryError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _ProxyError): 12:10:40 raise ProxyError(e, request=request) 12:10:40 12:10:40 if isinstance(e.reason, _SSLError): 12:10:40 # This branch is for urllib3 v1.22 and later. 12:10:40 raise SSLError(e, request=request) 12:10:40 12:10:40 > raise ConnectionError(e, request=request) 12:10:40 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')) 12:10:40 12:10:40 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 12:10:40 ----------------------------- Captured stdout call ----------------------------- 12:10:40 execution of test_20_rdm_device_disconnected 12:10:40 =========================== short test summary info ============================ 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_08_xpdr_device_connected 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_09_xpdr_portmapping_info 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_10_xpdr_portmapping_NETWORK1 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_11_xpdr_portmapping_NETWORK2 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_12_xpdr_portmapping_CLIENT1 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_13_xpdr_portmapping_CLIENT2 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_14_xpdr_portmapping_CLIENT3 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_15_xpdr_portmapping_CLIENT4 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_16_xpdr_device_disconnection 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_17_xpdr_device_disconnected 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_18_xpdr_device_not_connected 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_19_rdm_device_disconnection 12:10:40 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_20_rdm_device_disconnected 12:10:40 13 failed, 8 passed in 626.79s (0:10:26) 12:10:40 tests121: exit 1 (627.05 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=36060 12:10:47 ...................... [100%] 12:11:34 22 passed in 71.42s (0:01:11) 12:11:34 tests121: FAIL ✖ in 10 minutes 34.09 seconds 12:11:34 tests71: OK ✔ in 6 minutes 58.77 seconds 12:11:34 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 12:11:40 tests221: freeze> python -m pip freeze --all 12:11:41 tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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 12:11:41 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 12:11:41 using environment variables from ./karaf221.env 12:11:41 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 12:12:16 ................................... [100%] 12:12:56 35 passed in 74.92s (0:01:14) 12:12:56 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 12:13:26 ...... [100%] 12:13:40 6 passed in 43.75s 12:13:40 pytest -q transportpce_tests/2.2.1/test03_topology.py 12:14:21 ............................................ [100%] 12:15:55 44 passed in 135.35s (0:02:15) 12:15:55 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 12:16:30 ............ [100%] 12:16:54 12 passed in 58.61s 12:16:54 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 12:17:19 ................ [100%] 12:18:48 16 passed in 113.38s (0:01:53) 12:18:48 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 12:19:16 ............................... [100%] 12:19:22 31 passed in 34.40s 12:19:22 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 12:19:57 .......................... [100%] 12:20:52 26 passed in 89.87s (0:01:29) 12:20:52 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 12:21:28 ...................... [100%] 12:22:31 22 passed in 98.52s (0:01:38) 12:22:31 pytest -q transportpce_tests/2.2.1/test09_olm.py 12:23:11 ........................................ [100%] 12:25:33 40 passed in 181.59s (0:03:01) 12:25:33 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 12:26:15 ........................................................................ [ 74%] 12:31:51 ......................... [100%] 12:36:44 97 passed in 669.69s (0:11:09) 12:36:44 pytest -q transportpce_tests/2.2.1/test12_end2end.py 12:37:22 ...................................................... [100%] 12:44:10 54 passed in 446.48s (0:07:26) 12:44:10 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 12:45:02 ........................................................................ [ 71%] 12:50:10 ............................. [100%] 12:52:19 101 passed in 489.42s (0:08:09) 12:52:19 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 12:53:12 ........................................................................ [ 67%] 12:58:58 ................................... [100%] 13:02:18 107 passed in 598.82s (0:09:58) 13:02:18 tests221: OK ✔ in 50 minutes 44.11 seconds 13:02:18 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:02:25 tests_hybrid: freeze> python -m pip freeze --all 13:02:25 tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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:02:25 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 13:02:25 using environment variables from ./karaf121.env 13:02:25 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 13:03:10 ................................................... [100%] 13:10:55 51 passed in 510.10s (0:08:30) 13:10:55 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 13:11:38 ........................................................................ [ 66%] 13:15:58 ..................................... [100%] 13:18:04 109 passed in 428.69s (0:07:08) 13:18:04 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 13:18:51 ..................................................... [100%] 13:22:23 53 passed in 258.45s (0:04:18) 13:22:23 tests_hybrid: OK ✔ in 20 minutes 4.62 seconds 13:22:23 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 13:22:28 buildlighty: freeze> python -m pip freeze --all 13:22:29 buildlighty: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.1,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.2,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:22:29 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 13:22:29 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 13:22:44 [ERROR] COMPILATION ERROR : 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 13:22:44 symbol: class YangModuleInfo 13:22:44 location: package org.opendaylight.yangtools.binding 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 13:22:44 symbol: class YangModuleInfo 13:22:44 location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 13:22:44 symbol: class YangModuleInfo 13:22:44 location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 13:22:44 symbol: class YangModuleInfo 13:22:44 location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [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: 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 13:22:44 [ERROR] symbol: class YangModuleInfo 13:22:44 [ERROR] location: package org.opendaylight.yangtools.binding 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 13:22:44 [ERROR] symbol: class YangModuleInfo 13:22:44 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 13:22:44 [ERROR] symbol: class YangModuleInfo 13:22:44 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 13:22:44 [ERROR] symbol: class YangModuleInfo 13:22:44 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 13:22:44 [ERROR] -> [Help 1] 13:22:44 [ERROR] 13:22:44 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 13:22:44 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 13:22:44 [ERROR] 13:22:44 [ERROR] For more information about the errors and possible solutions, please read the following articles: 13:22:44 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException 13:22:44 unzip: cannot find or open target/tpce-bin.zip, target/tpce-bin.zip.zip or target/tpce-bin.zip.ZIP. 13:22:44 buildlighty: exit 9 (15.48 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh pid=59666 13:22:44 buildlighty: command failed but is marked ignore outcome so handling it as success 13:22:44 buildcontroller: OK (116.85=setup[9.13]+cmd[107.72] seconds) 13:22:44 testsPCE: OK (353.93=setup[94.08]+cmd[259.85] seconds) 13:22:44 sims: OK (11.72=setup[8.41]+cmd[3.30] seconds) 13:22:44 build_karaf_tests121: OK (64.77=setup[8.39]+cmd[56.39] seconds) 13:22:44 tests121: FAIL code 1 (634.09=setup[7.04]+cmd[627.05] seconds) 13:22:44 build_karaf_tests221: OK (63.07=setup[8.42]+cmd[54.66] seconds) 13:22:44 tests_tapi: FAIL code 1 (558.82=setup[9.14]+cmd[549.68] seconds) 13:22:44 tests221: OK (3044.11=setup[6.43]+cmd[3037.68] seconds) 13:22:44 build_karaf_tests71: OK (56.34=setup[11.89]+cmd[44.45] seconds) 13:22:44 tests71: OK (418.77=setup[7.06]+cmd[411.71] seconds) 13:22:44 build_karaf_tests_hybrid: OK (61.72=setup[10.79]+cmd[50.93] seconds) 13:22:44 tests_hybrid: OK (1204.62=setup[6.70]+cmd[1197.92] seconds) 13:22:44 buildlighty: OK (21.14=setup[5.66]+cmd[15.48] seconds) 13:22:44 docs: OK (42.58=setup[39.94]+cmd[2.64] seconds) 13:22:44 docs-linkcheck: OK (44.78=setup[41.39]+cmd[3.38] seconds) 13:22:44 checkbashisms: OK (3.14=setup[2.20]+cmd[0.01,0.05,0.87] seconds) 13:22:44 pre-commit: OK (59.17=setup[3.37]+cmd[0.00,0.00,47.32,8.47] seconds) 13:22:44 pylint: FAIL code 1 (29.55=setup[4.60]+cmd[24.95] seconds) 13:22:44 evaluation failed :( (5429.17 seconds) 13:22:44 + tox_status=255 13:22:44 + echo '---> Completed tox runs' 13:22:44 ---> Completed tox runs 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/build_karaf_tests121/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=build_karaf_tests121 13:22:44 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 13:22:44 + for i in .tox/*/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 ++ echo .tox/build_karaf_tests221/log 13:22:44 + tox_env=build_karaf_tests221 13:22:44 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/build_karaf_tests71/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=build_karaf_tests71 13:22:44 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/build_karaf_tests_hybrid/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=build_karaf_tests_hybrid 13:22:44 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/buildcontroller/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=buildcontroller 13:22:44 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/buildlighty/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=buildlighty 13:22:44 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/checkbashisms/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=checkbashisms 13:22:44 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 13:22:44 + for i in .tox/*/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 ++ echo .tox/docs-linkcheck/log 13:22:44 + tox_env=docs-linkcheck 13:22:44 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/docs/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=docs 13:22:44 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/pre-commit/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=pre-commit 13:22:44 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/pylint/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=pylint 13:22:44 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/sims/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=sims 13:22:44 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/tests121/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=tests121 13:22:44 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/tests221/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=tests221 13:22:44 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/tests71/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=tests71 13:22:44 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/testsPCE/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=testsPCE 13:22:44 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/tests_hybrid/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=tests_hybrid 13:22:44 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 13:22:44 + for i in .tox/*/log 13:22:44 ++ echo .tox/tests_tapi/log 13:22:44 ++ awk -F/ '{print $2}' 13:22:44 + tox_env=tests_tapi 13:22:44 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 13:22:44 + DOC_DIR=docs/_build/html 13:22:44 + [[ -d docs/_build/html ]] 13:22:44 + echo '---> Archiving generated docs' 13:22:44 ---> Archiving generated docs 13:22:44 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:22:44 + echo '---> tox-run.sh ends' 13:22:44 ---> tox-run.sh ends 13:22:44 + test 255 -eq 0 13:22:44 + exit 255 13:22:44 ++ '[' 1 = 1 ']' 13:22:44 ++ '[' -x /usr/bin/clear_console ']' 13:22:44 ++ /usr/bin/clear_console -q 13:22:44 Build step 'Execute shell' marked build as failure 13:22:44 $ ssh-agent -k 13:22:44 unset SSH_AUTH_SOCK; 13:22:44 unset SSH_AGENT_PID; 13:22:44 echo Agent pid 12376 killed; 13:22:44 [ssh-agent] Stopped. 13:22:44 [PostBuildScript] - [INFO] Executing post build scripts. 13:22:44 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3647010893842871824.sh 13:22:44 ---> sysstat.sh 13:22:45 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15266673404648251724.sh 13:22:45 ---> package-listing.sh 13:22:45 ++ facter osfamily 13:22:45 ++ tr '[:upper:]' '[:lower:]' 13:22:45 + OS_FAMILY=debian 13:22:45 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 13:22:45 + START_PACKAGES=/tmp/packages_start.txt 13:22:45 + END_PACKAGES=/tmp/packages_end.txt 13:22:45 + DIFF_PACKAGES=/tmp/packages_diff.txt 13:22:45 + PACKAGES=/tmp/packages_start.txt 13:22:45 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:22:45 + PACKAGES=/tmp/packages_end.txt 13:22:45 + case "${OS_FAMILY}" in 13:22:45 + dpkg -l 13:22:45 + grep '^ii' 13:22:45 + '[' -f /tmp/packages_start.txt ']' 13:22:45 + '[' -f /tmp/packages_end.txt ']' 13:22:45 + diff /tmp/packages_start.txt /tmp/packages_end.txt 13:22:45 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:22:45 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:22:45 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:22:45 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4100411121890924087.sh 13:22:45 ---> capture-instance-metadata.sh 13:22:45 Setup pyenv: 13:22:45 system 13:22:45 3.8.13 13:22:45 3.9.13 13:22:45 3.10.13 13:22:45 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:22:46 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-2LOv from file:/tmp/.os_lf_venv 13:22:46 lf-activate-venv(): INFO: Installing: lftools 13:22:56 lf-activate-venv(): INFO: Adding /tmp/venv-2LOv/bin to PATH 13:22:56 INFO: Running in OpenStack, capturing instance metadata 13:22:56 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1548270696067338939.sh 13:22:56 provisioning config files... 13:22:57 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #2090 13:22:57 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config6800780309157377605tmp 13:22:57 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 13:22:57 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 13:22:57 provisioning config files... 13:22:57 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 13:22:57 [EnvInject] - Injecting environment variables from a build step. 13:22:57 [EnvInject] - Injecting as environment variables the properties content 13:22:57 SERVER_ID=logs 13:22:57 13:22:57 [EnvInject] - Variables injected successfully. 13:22:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6095168897427845718.sh 13:22:57 ---> create-netrc.sh 13:22:57 WARN: Log server credential not found. 13:22:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17087856050382532915.sh 13:22:57 ---> python-tools-install.sh 13:22:57 Setup pyenv: 13:22:57 system 13:22:57 3.8.13 13:22:57 3.9.13 13:22:57 3.10.13 13:22:57 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:22:57 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-2LOv from file:/tmp/.os_lf_venv 13:22:58 lf-activate-venv(): INFO: Installing: lftools 13:23:07 lf-activate-venv(): INFO: Adding /tmp/venv-2LOv/bin to PATH 13:23:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10878304650573744296.sh 13:23:07 ---> sudo-logs.sh 13:23:07 Archiving 'sudo' log.. 13:23:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17237655843335078815.sh 13:23:07 ---> job-cost.sh 13:23:07 Setup pyenv: 13:23:07 system 13:23:07 3.8.13 13:23:07 3.9.13 13:23:07 3.10.13 13:23:07 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:23:07 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-2LOv from file:/tmp/.os_lf_venv 13:23:08 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 13:23:13 lf-activate-venv(): INFO: Adding /tmp/venv-2LOv/bin to PATH 13:23:13 INFO: No Stack... 13:23:14 INFO: Retrieving Pricing Info for: v3-standard-4 13:23:14 INFO: Archiving Costs 13:23:14 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins6691389994802701899.sh 13:23:14 ---> logs-deploy.sh 13:23:14 Setup pyenv: 13:23:14 system 13:23:14 3.8.13 13:23:14 3.9.13 13:23:14 3.10.13 13:23:14 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:23:14 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-2LOv from file:/tmp/.os_lf_venv 13:23:15 lf-activate-venv(): INFO: Installing: lftools 13:23:26 lf-activate-venv(): INFO: Adding /tmp/venv-2LOv/bin to PATH 13:23:26 WARNING: Nexus logging server not set 13:23:26 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/2090/ 13:23:26 INFO: archiving logs to S3 13:23:28 ---> uname -a: 13:23:28 Linux prd-ubuntu2004-docker-4c-16g-43727 5.4.0-190-generic #210-Ubuntu SMP Fri Jul 5 17:03:38 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 13:23:28 13:23:28 13:23:28 ---> lscpu: 13:23:28 Architecture: x86_64 13:23:28 CPU op-mode(s): 32-bit, 64-bit 13:23:28 Byte Order: Little Endian 13:23:28 Address sizes: 40 bits physical, 48 bits virtual 13:23:28 CPU(s): 4 13:23:28 On-line CPU(s) list: 0-3 13:23:28 Thread(s) per core: 1 13:23:28 Core(s) per socket: 1 13:23:28 Socket(s): 4 13:23:28 NUMA node(s): 1 13:23:28 Vendor ID: AuthenticAMD 13:23:28 CPU family: 23 13:23:28 Model: 49 13:23:28 Model name: AMD EPYC-Rome Processor 13:23:28 Stepping: 0 13:23:28 CPU MHz: 2799.998 13:23:28 BogoMIPS: 5599.99 13:23:28 Virtualization: AMD-V 13:23:28 Hypervisor vendor: KVM 13:23:28 Virtualization type: full 13:23:28 L1d cache: 128 KiB 13:23:28 L1i cache: 128 KiB 13:23:28 L2 cache: 2 MiB 13:23:28 L3 cache: 64 MiB 13:23:28 NUMA node0 CPU(s): 0-3 13:23:28 Vulnerability Gather data sampling: Not affected 13:23:28 Vulnerability Itlb multihit: Not affected 13:23:28 Vulnerability L1tf: Not affected 13:23:28 Vulnerability Mds: Not affected 13:23:28 Vulnerability Meltdown: Not affected 13:23:28 Vulnerability Mmio stale data: Not affected 13:23:28 Vulnerability Retbleed: Vulnerable 13:23:28 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 13:23:28 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 13:23:28 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 13:23:28 Vulnerability Srbds: Not affected 13:23:28 Vulnerability Tsx async abort: Not affected 13:23:28 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 13:23:28 13:23:28 13:23:28 ---> nproc: 13:23:28 4 13:23:28 13:23:28 13:23:28 ---> df -h: 13:23:28 Filesystem Size Used Avail Use% Mounted on 13:23:28 udev 7.8G 0 7.8G 0% /dev 13:23:28 tmpfs 1.6G 1.1M 1.6G 1% /run 13:23:28 /dev/vda1 78G 17G 62G 21% / 13:23:28 tmpfs 7.9G 0 7.9G 0% /dev/shm 13:23:28 tmpfs 5.0M 0 5.0M 0% /run/lock 13:23:28 tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup 13:23:28 /dev/loop0 62M 62M 0 100% /snap/core20/1405 13:23:28 /dev/loop2 44M 44M 0 100% /snap/snapd/15177 13:23:28 /dev/loop1 68M 68M 0 100% /snap/lxd/22753 13:23:28 /dev/vda15 105M 6.1M 99M 6% /boot/efi 13:23:28 tmpfs 1.6G 0 1.6G 0% /run/user/1001 13:23:28 /dev/loop3 92M 92M 0 100% /snap/lxd/29619 13:23:28 /dev/loop4 64M 64M 0 100% /snap/core20/2379 13:23:28 13:23:28 13:23:28 ---> free -m: 13:23:28 total used free shared buff/cache available 13:23:28 Mem: 15997 695 5468 1 9832 14962 13:23:28 Swap: 1023 0 1023 13:23:28 13:23:28 13:23:28 ---> ip addr: 13:23:28 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 13:23:28 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 13:23:28 inet 127.0.0.1/8 scope host lo 13:23:28 valid_lft forever preferred_lft forever 13:23:28 inet6 ::1/128 scope host 13:23:28 valid_lft forever preferred_lft forever 13:23:28 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 13:23:28 link/ether fa:16:3e:d8:d9:43 brd ff:ff:ff:ff:ff:ff 13:23:28 inet 10.30.171.74/23 brd 10.30.171.255 scope global dynamic ens3 13:23:28 valid_lft 80798sec preferred_lft 80798sec 13:23:28 inet6 fe80::f816:3eff:fed8:d943/64 scope link 13:23:28 valid_lft forever preferred_lft forever 13:23:28 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 13:23:28 link/ether 02:42:42:0d:a0:73 brd ff:ff:ff:ff:ff:ff 13:23:28 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 13:23:28 valid_lft forever preferred_lft forever 13:23:28 13:23:28 13:23:28 ---> sar -b -r -n DEV: 13:23:28 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-43727) 10/18/24 _x86_64_ (4 CPU) 13:23:28 13:23:28 11:50:10 LINUX RESTART (4 CPU) 13:23:28 13:23:28 11:51:01 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 13:23:28 11:52:01 129.85 63.42 66.42 0.00 1635.99 7182.02 0.00 13:23:28 11:53:01 202.70 34.99 167.71 0.00 2467.99 28165.44 0.00 13:23:28 11:54:01 116.64 7.98 108.66 0.00 339.11 42309.13 0.00 13:23:28 11:55:01 131.59 0.35 131.24 0.00 34.39 68045.18 0.00 13:23:28 11:56:01 144.01 14.03 129.98 0.00 2916.71 119680.32 0.00 13:23:28 11:57:01 156.47 1.97 154.51 0.00 88.12 45737.84 0.00 13:23:28 11:58:01 57.00 2.15 54.86 0.00 167.65 993.77 0.00 13:23:28 11:59:01 86.54 0.27 86.27 0.00 13.73 1640.66 0.00 13:23:28 12:00:01 77.69 0.13 77.56 0.00 27.32 1473.78 0.00 13:23:28 12:01:01 89.35 0.18 89.17 0.00 12.67 9706.93 0.00 13:23:28 12:02:01 23.61 0.00 23.61 0.00 0.00 492.85 0.00 13:23:28 12:03:01 3.02 0.00 3.02 0.00 0.00 55.31 0.00 13:23:28 12:04:01 2.32 0.00 2.32 0.00 0.00 38.53 0.00 13:23:28 12:05:01 26.58 0.05 26.53 0.00 0.40 1709.85 0.00 13:23:28 12:06:01 139.78 0.73 139.04 0.00 12.26 9405.50 0.00 13:23:28 12:07:01 2.75 0.00 2.75 0.00 0.00 45.85 0.00 13:23:28 12:08:01 1.80 0.00 1.80 0.00 0.00 33.86 0.00 13:23:28 12:09:01 73.82 0.00 73.82 0.00 0.00 1387.90 0.00 13:23:28 12:10:01 2.43 0.00 2.43 0.00 0.00 45.86 0.00 13:23:28 12:11:01 78.50 0.05 78.45 0.00 1.87 1155.81 0.00 13:23:28 12:12:01 30.69 0.00 30.69 0.00 0.00 742.94 0.00 13:23:28 12:13:01 68.01 0.00 68.01 0.00 0.00 2944.58 0.00 13:23:28 12:14:01 76.84 0.00 76.84 0.00 0.00 1147.14 0.00 13:23:28 12:15:01 47.73 0.00 47.73 0.00 0.00 683.35 0.00 13:23:28 12:16:01 15.50 0.00 15.50 0.00 0.00 254.76 0.00 13:23:28 12:17:01 73.75 0.00 73.75 0.00 0.00 1082.62 0.00 13:23:28 12:18:01 64.66 0.05 64.61 0.00 1.07 914.25 0.00 13:23:28 12:19:01 23.46 0.00 23.46 0.00 0.00 367.48 0.00 13:23:28 12:20:01 124.93 0.00 124.93 0.00 0.00 1804.50 0.00 13:23:28 12:21:01 26.92 1.72 25.21 0.00 1979.07 2778.54 0.00 13:23:28 12:22:01 51.71 0.00 51.71 0.00 0.00 744.41 0.00 13:23:28 12:23:01 17.78 0.00 17.78 0.00 0.00 300.75 0.00 13:23:28 12:24:01 52.97 0.00 52.97 0.00 0.00 762.27 0.00 13:23:28 12:25:01 3.38 0.00 3.38 0.00 0.00 59.99 0.00 13:23:28 12:26:01 17.15 0.00 17.15 0.00 0.00 298.88 0.00 13:23:28 12:27:01 50.41 0.00 50.41 0.00 0.00 739.34 0.00 13:23:28 12:28:01 2.00 0.00 2.00 0.00 0.00 34.53 0.00 13:23:28 12:29:01 2.35 0.00 2.35 0.00 0.00 33.99 0.00 13:23:28 12:30:01 2.15 0.00 2.15 0.00 0.00 44.26 0.00 13:23:28 12:31:01 2.17 0.00 2.17 0.00 0.00 39.59 0.00 13:23:28 12:32:01 1.85 0.00 1.85 0.00 0.00 39.46 0.00 13:23:28 12:33:01 2.77 0.00 2.77 0.00 0.00 44.93 0.00 13:23:28 12:34:01 2.27 0.00 2.27 0.00 0.00 41.46 0.00 13:23:28 12:35:01 1.67 0.00 1.67 0.00 0.00 23.46 0.00 13:23:28 12:36:01 1.35 0.00 1.35 0.00 0.00 18.53 0.00 13:23:28 12:37:01 16.46 0.00 16.46 0.00 0.00 268.49 0.00 13:23:28 12:38:01 46.19 0.00 46.19 0.00 0.00 682.02 0.00 13:23:28 12:39:01 2.53 0.00 2.53 0.00 0.00 53.99 0.00 13:23:28 12:40:01 2.07 0.00 2.07 0.00 0.00 56.26 0.00 13:23:28 12:41:01 2.93 0.00 2.93 0.00 0.00 49.73 0.00 13:23:28 12:42:01 1.92 0.00 1.92 0.00 0.00 55.99 0.00 13:23:28 12:43:01 2.37 0.00 2.37 0.00 0.00 49.33 0.00 13:23:28 12:44:01 1.82 0.00 1.82 0.00 0.00 53.46 0.00 13:23:28 12:45:01 63.98 0.00 63.98 0.00 0.00 957.68 0.00 13:23:28 12:46:01 2.43 0.00 2.43 0.00 0.00 56.26 0.00 13:23:28 12:47:01 3.92 0.00 3.92 0.00 0.00 74.25 0.00 13:23:28 12:48:01 2.68 0.00 2.68 0.00 0.00 57.06 0.00 13:23:28 12:49:01 2.65 0.00 2.65 0.00 0.00 45.46 0.00 13:23:28 12:50:01 2.07 0.00 2.07 0.00 0.00 41.19 0.00 13:23:28 12:51:01 2.18 0.00 2.18 0.00 0.00 47.99 0.00 13:23:28 12:52:01 2.47 0.00 2.47 0.00 0.00 45.19 0.00 13:23:28 12:53:01 27.36 0.00 27.36 0.00 0.00 444.79 0.00 13:23:28 12:54:01 55.86 0.00 55.86 0.00 0.00 786.14 0.00 13:23:28 12:55:01 3.55 0.00 3.55 0.00 0.00 84.92 0.00 13:23:28 12:56:01 2.75 0.00 2.75 0.00 0.00 49.73 0.00 13:23:28 12:57:01 2.07 0.00 2.07 0.00 0.00 41.19 0.00 13:23:28 12:58:01 1.88 0.00 1.88 0.00 0.00 34.66 0.00 13:23:28 12:59:02 2.22 0.00 2.22 0.00 0.00 38.26 0.00 13:23:28 13:00:01 1.63 0.00 1.63 0.00 0.00 32.13 0.00 13:23:28 13:01:01 2.05 0.00 2.05 0.00 0.00 40.12 0.00 13:23:28 13:02:01 1.95 0.00 1.95 0.00 0.00 47.19 0.00 13:23:28 13:03:01 57.66 0.00 57.66 0.00 0.00 4384.34 0.00 13:23:28 13:04:01 48.11 0.00 48.11 0.00 0.00 5573.87 0.00 13:23:28 13:05:01 3.50 0.00 3.50 0.00 0.00 62.66 0.00 13:23:28 13:06:01 1.33 0.00 1.33 0.00 0.00 16.53 0.00 13:23:28 13:07:01 2.22 0.00 2.22 0.00 0.00 28.80 0.00 13:23:28 13:08:01 1.53 0.00 1.53 0.00 0.00 20.66 0.00 13:23:28 13:09:01 2.55 0.00 2.55 0.00 0.00 29.60 0.00 13:23:28 13:10:01 1.50 0.00 1.50 0.00 0.00 18.26 0.00 13:23:28 13:11:01 15.51 0.00 15.51 0.00 0.00 250.89 0.00 13:23:28 13:12:01 56.66 0.00 56.66 0.00 0.00 933.58 0.00 13:23:28 13:13:01 2.47 0.00 2.47 0.00 0.00 44.53 0.00 13:23:28 13:14:01 2.28 0.00 2.28 0.00 0.00 37.46 0.00 13:23:28 13:15:01 1.75 0.00 1.75 0.00 0.00 35.19 0.00 13:23:28 13:16:01 1.80 0.00 1.80 0.00 0.00 30.13 0.00 13:23:28 13:17:01 2.22 0.00 2.22 0.00 0.00 43.59 0.00 13:23:28 13:18:01 1.77 0.00 1.77 0.00 0.00 37.59 0.00 13:23:28 13:19:01 79.62 0.00 79.62 0.00 0.00 1372.30 0.00 13:23:28 13:20:01 2.72 0.00 2.72 0.00 0.00 161.57 0.00 13:23:28 13:21:01 3.13 0.00 3.13 0.00 0.00 88.92 0.00 13:23:28 13:22:01 2.85 0.00 2.85 0.00 0.00 66.26 0.00 13:23:28 13:23:01 35.29 5.57 29.73 0.00 250.89 3137.34 0.00 13:23:28 Average: 31.50 1.45 30.05 0.00 108.17 4085.99 0.00 13:23:28 13:23:28 11:51:01 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 13:23:28 11:52:01 13323496 15462908 509820 3.11 73900 2256356 1223788 7.02 770112 1999084 241232 13:23:28 11:53:01 10520748 14199412 1756548 10.72 130176 3627780 2579344 14.80 2184600 3255868 1032600 13:23:28 11:54:01 9475024 13941788 2013284 12.29 151944 4350000 2588176 14.85 2567004 3874236 544284 13:23:28 11:55:01 5755676 12970852 2982644 18.21 188488 6950236 3808584 21.85 4259180 5782896 1265696 13:23:28 11:56:01 4726572 13711516 2232480 13.63 215008 8612076 3282828 18.83 4170736 6810488 612696 13:23:28 11:57:01 2967788 12247736 3694192 22.55 224072 8887728 5064020 29.05 5886956 6834820 956 13:23:28 11:58:01 640080 9222956 6717556 41.01 222140 8205728 7807276 44.79 8771588 6277144 924 13:23:28 11:59:01 166136 8691228 7248436 44.25 226800 8144416 8539320 48.99 9306056 6215972 148 13:23:28 12:00:01 3887964 12373844 3568516 21.78 229656 8102776 4402492 25.26 5648380 6166772 892 13:23:28 12:01:01 1542608 10271176 5669348 34.61 237684 8328556 7086712 40.66 7804336 6341248 844 13:23:28 12:02:01 548140 9278620 6661360 40.66 238552 8329536 7546556 43.30 8795300 6339204 4 13:23:28 12:03:01 527336 9258144 6681904 40.79 238576 8329840 7546556 43.30 8816608 6339400 104 13:23:28 12:04:01 515784 9246824 6693192 40.86 238604 8330048 7546556 43.30 8827024 6339564 168 13:23:28 12:05:01 3405116 12381220 3559960 21.73 244932 8555336 4977528 28.56 5764860 6508756 217108 13:23:28 12:06:01 2590384 11573428 4367360 26.66 249848 8556852 5194156 29.80 6607452 6478264 492 13:23:28 12:07:01 2561696 11545044 4395656 26.83 249876 8557104 5210188 29.89 6634772 6478216 188 13:23:28 12:08:01 2521052 11504564 4436124 27.08 249904 8557240 5260180 30.18 6674904 6477756 144 13:23:28 12:09:01 1862544 10848000 5092436 31.09 251568 8557412 5910076 33.91 7344272 6467068 184 13:23:28 12:10:01 1833968 10819692 5120740 31.26 251588 8557652 5910076 33.91 7372688 6467308 268 13:23:28 12:11:01 4751032 13739212 2202588 13.45 253708 8557896 3008864 17.26 4469448 6466000 344 13:23:28 12:12:01 4716888 13774176 2168092 13.24 256144 8618204 3468968 19.90 4438712 6524576 60100 13:23:28 12:13:01 5924908 14983680 959556 5.86 257572 8618236 1782352 10.23 3241800 6519492 400 13:23:28 12:14:01 4576020 13637336 2304972 14.07 259384 8618856 3521888 20.21 4592052 6511220 368 13:23:28 12:15:01 2796028 11858368 4083048 24.92 260192 8619032 5052432 28.99 6367032 6511396 108 13:23:28 12:16:01 5922364 14984768 958320 5.85 260208 8619024 1772612 10.17 3253160 6510548 344 13:23:28 12:17:01 5866460 14930440 1012596 6.18 261460 8619348 1831148 10.51 3308248 6510552 324 13:23:28 12:18:01 4681300 13747296 2194912 13.40 263024 8619760 2996172 17.19 4487704 6510948 60 13:23:28 12:19:01 5364480 14430900 1511852 9.23 263152 8620016 2801636 16.07 3807792 6511012 596 13:23:28 12:20:01 4756524 13825088 2117396 12.93 264740 8620544 2924064 16.78 4412324 6511352 84 13:23:28 12:21:01 5664136 14861608 1081340 6.60 265336 8745620 1888116 10.83 3448148 6568460 376 13:23:28 12:22:01 3759296 12957620 2984172 18.22 265836 8745944 3783844 21.71 5345380 6568784 320 13:23:28 12:23:01 3453712 12652444 3289120 20.08 265868 8746260 4938984 28.34 5648720 6569072 204 13:23:28 12:24:01 2273612 11473740 4467228 27.27 266804 8746696 5282408 30.31 6824068 6569496 104 13:23:28 12:25:01 2257052 11457544 4483460 27.37 266812 8747052 5282408 30.31 6841444 6569836 372 13:23:28 12:26:01 3896368 13097208 2844696 17.37 266860 8747248 4166164 23.90 5206072 6570028 908 13:23:28 12:27:01 2292564 11494548 4446328 27.14 267412 8747824 5250684 30.12 6805248 6570596 256 13:23:28 12:28:01 2280628 11482796 4458016 27.21 267420 8748012 5266728 30.22 6817612 6570772 212 13:23:28 12:29:01 2271336 11473632 4467136 27.27 267432 8748116 5282788 30.31 6826380 6570888 316 13:23:28 12:30:01 2248836 11451408 4489352 27.41 267448 8748372 5298836 30.40 6847960 6571144 232 13:23:28 12:31:01 2205980 11408932 4531816 27.66 267460 8748744 5298836 30.40 6890212 6571512 292 13:23:28 12:32:01 2219024 11422088 4518748 27.58 267460 8748852 5298836 30.40 6877612 6571620 120 13:23:28 12:33:01 2164016 11367232 4573596 27.92 267464 8749004 5348428 30.69 6932196 6571768 24 13:23:28 12:34:01 2153904 11357372 4583396 27.98 267464 8749252 5348428 30.69 6941840 6572020 304 13:23:28 12:35:01 2154080 11357548 4583272 27.98 267464 8749252 5348428 30.69 6941220 6572020 40 13:23:28 12:36:01 2153356 11356828 4583960 27.98 267468 8749256 5348428 30.69 6941336 6572024 60 13:23:28 12:37:01 4833988 14037684 1904768 11.63 267488 8749368 2854384 16.38 4270596 6572132 560 13:23:28 12:38:01 2347700 11552220 4388500 26.79 267936 8749728 5198600 29.83 6745928 6572484 464 13:23:28 12:39:01 2325652 11530716 4409924 26.92 267940 8750272 5230652 30.01 6767596 6573016 576 13:23:28 12:40:01 2311596 11517100 4423524 27.00 267948 8750700 5230652 30.01 6781640 6573448 308 13:23:28 12:41:01 2295136 11501116 4439508 27.10 267956 8751164 5230652 30.01 6796576 6573912 380 13:23:28 12:42:01 2287648 11494140 4446460 27.14 267960 8751692 5246644 30.10 6803928 6574420 76 13:23:28 12:43:01 2263944 11471048 4469556 27.28 267976 8752260 5246644 30.10 6826112 6575008 276 13:23:28 12:44:01 2248116 11456004 4484588 27.38 267976 8753040 5246644 30.10 6841188 6575784 132 13:23:28 12:45:01 1745912 10953572 4986896 30.44 268348 8752416 6314420 36.23 7346288 6575152 260 13:23:28 12:46:01 1087388 10295508 5644608 34.46 268348 8752872 6493708 37.26 8001780 6575596 364 13:23:28 12:47:01 886628 10095164 5844724 35.68 268348 8753288 6640788 38.10 8200068 6576012 84 13:23:28 12:48:01 805820 10014792 5924932 36.17 268360 8753716 6704992 38.47 8280640 6576432 204 13:23:28 12:49:01 791088 10000224 5939612 36.26 268360 8753876 6704992 38.47 8295492 6576596 316 13:23:28 12:50:01 771448 9980968 5958824 36.38 268368 8754248 6704992 38.47 8314696 6576972 428 13:23:28 12:51:01 757668 9967528 5972196 36.46 268376 8754564 6721884 38.57 8326588 6577288 412 13:23:28 12:52:01 748840 9958928 5980760 36.51 268380 8754788 6721884 38.57 8335652 6577504 100 13:23:28 12:53:01 2200436 11410424 4530128 27.65 268432 8754544 6257968 35.90 6891660 6577148 60 13:23:28 12:54:01 1045052 10255912 5684280 34.70 268840 8755000 6536528 37.50 8042036 6577596 188 13:23:28 12:55:01 807820 10019348 5920364 36.14 268844 8755668 6699352 38.44 8277316 6578260 196 13:23:28 12:56:01 805876 10017580 5922120 36.15 268852 8755836 6715548 38.53 8278908 6578432 304 13:23:28 12:57:01 797260 10009180 5930508 36.20 268856 8756044 6715548 38.53 8287536 6578640 316 13:23:28 12:58:01 784212 9996256 5943400 36.28 268868 8756156 6715548 38.53 8300456 6578752 368 13:23:28 12:59:02 778400 9990600 5949048 36.32 268872 8756308 6715548 38.53 8306356 6578904 120 13:23:28 13:00:01 758240 9970712 5968924 36.44 268880 8756576 6732108 38.62 8325064 6579164 300 13:23:28 13:01:01 723156 9935764 6003828 36.65 268912 8756680 6748184 38.72 8359432 6579276 148 13:23:28 13:02:01 687908 9901076 6038468 36.86 268924 8757204 6780732 38.90 8393584 6579800 444 13:23:28 13:03:01 3099056 12556824 3384132 20.66 275104 8982300 4882168 28.01 5805932 6754692 143388 13:23:28 13:04:01 2003136 11463368 4476980 27.33 275416 8984120 5247664 30.11 6903492 6748492 276 13:23:28 13:05:01 1942580 11403068 4537164 27.70 275424 8984360 5280984 30.30 6961416 6748644 76 13:23:28 13:06:01 1942560 11403052 4537180 27.70 275424 8984364 5280984 30.30 6961040 6748648 72 13:23:28 13:07:01 1942064 11402560 4537672 27.70 275424 8984364 5280984 30.30 6961364 6748648 236 13:23:28 13:08:01 1945796 11406308 4534008 27.68 275432 8984380 5280984 30.30 6957072 6748660 80 13:23:28 13:09:01 1945780 11406300 4534060 27.68 275436 8984380 5280984 30.30 6956860 6748660 256 13:23:28 13:10:01 1945552 11406080 4534272 27.68 275444 8984384 5280984 30.30 6956864 6748664 52 13:23:28 13:11:01 5528776 14989448 953028 5.82 275480 8984388 1765868 10.13 3401332 6737212 652 13:23:28 13:12:01 2039468 11500832 4439540 27.10 275780 8984712 5206728 29.87 6889896 6727112 328 13:23:28 13:13:01 2037280 11498852 4441512 27.11 275780 8984916 5222724 29.96 6892160 6727132 56 13:23:28 13:14:01 2025436 11487204 4453132 27.18 275780 8985104 5238720 30.06 6902556 6727308 228 13:23:28 13:15:01 2012292 11474244 4466180 27.26 275780 8985288 5238720 30.06 6914984 6727492 96 13:23:28 13:16:01 2005560 11467696 4472752 27.30 275780 8985464 5238720 30.06 6922028 6727668 392 13:23:28 13:17:01 1975240 11437884 4502476 27.49 275788 8985964 5238720 30.06 6950404 6728148 564 13:23:28 13:18:01 1968216 11431184 4509064 27.53 275788 8986284 5254808 30.15 6956608 6728432 484 13:23:28 13:19:01 1337656 10800616 5139504 31.37 276080 8985956 5931764 34.03 7597780 6716260 524 13:23:28 13:20:01 1200368 10663776 5276048 32.21 276084 8986428 6072072 34.84 7734804 6716576 252 13:23:28 13:21:01 1085380 10549968 5389828 32.90 276088 8987608 6120192 35.11 7846644 6717688 264 13:23:28 13:22:01 1025732 10490976 5448812 33.26 276092 8988248 6120192 35.11 7905864 6718332 432 13:23:28 13:23:01 5677156 15366344 575940 3.52 281260 9191700 1362076 7.81 3077036 6896280 138836 13:23:28 Average: 2682153 11663836 4277764 26.11 258238 8547672 5152321 29.56 6538846 6459236 46530 13:23:28 13:23:28 11:51:01 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 13:23:28 11:52:01 lo 0.80 0.80 0.08 0.08 0.00 0.00 0.00 0.00 13:23:28 11:52:01 ens3 73.44 61.31 897.67 7.63 0.00 0.00 0.00 0.00 13:23:28 11:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:53:01 lo 6.27 6.27 0.63 0.63 0.00 0.00 0.00 0.00 13:23:28 11:53:01 ens3 438.41 337.16 6507.74 37.17 0.00 0.00 0.00 0.00 13:23:28 11:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:54:01 lo 0.47 0.47 0.05 0.05 0.00 0.00 0.00 0.00 13:23:28 11:54:01 ens3 323.08 259.99 4670.12 26.25 0.00 0.00 0.00 0.00 13:23:28 11:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:55:01 lo 1.20 1.20 0.11 0.11 0.00 0.00 0.00 0.00 13:23:28 11:55:01 ens3 207.90 112.00 3961.38 12.24 0.00 0.00 0.00 0.00 13:23:28 11:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:56:01 lo 1.73 1.73 0.17 0.17 0.00 0.00 0.00 0.00 13:23:28 11:56:01 ens3 111.31 67.37 1396.97 5.86 0.00 0.00 0.00 0.00 13:23:28 11:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:57:01 lo 5.53 5.53 1.44 1.44 0.00 0.00 0.00 0.00 13:23:28 11:57:01 ens3 1.03 0.85 0.12 0.10 0.00 0.00 0.00 0.00 13:23:28 11:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:58:01 lo 35.27 35.27 41.46 41.46 0.00 0.00 0.00 0.00 13:23:28 11:58:01 ens3 2.03 2.07 0.34 0.32 0.00 0.00 0.00 0.00 13:23:28 11:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 11:59:01 lo 28.51 28.51 15.57 15.57 0.00 0.00 0.00 0.00 13:23:28 11:59:01 ens3 2.38 1.67 0.80 0.61 0.00 0.00 0.00 0.00 13:23:28 11:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:00:01 lo 31.97 31.97 13.71 13.71 0.00 0.00 0.00 0.00 13:23:28 12:00:01 ens3 1.53 0.92 0.23 0.17 0.00 0.00 0.00 0.00 13:23:28 12:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:01:01 lo 3.98 3.98 0.96 0.96 0.00 0.00 0.00 0.00 13:23:28 12:01:01 ens3 2.52 2.62 1.23 1.02 0.00 0.00 0.00 0.00 13:23:28 12:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:02:01 lo 34.48 34.48 30.96 30.96 0.00 0.00 0.00 0.00 13:23:28 12:02:01 ens3 0.62 0.73 0.11 0.12 0.00 0.00 0.00 0.00 13:23:28 12:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:03:01 lo 11.85 11.85 5.81 5.81 0.00 0.00 0.00 0.00 13:23:28 12:03:01 ens3 0.33 0.33 0.05 0.05 0.00 0.00 0.00 0.00 13:23:28 12:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:04:01 lo 16.66 16.66 6.10 6.10 0.00 0.00 0.00 0.00 13:23:28 12:04:01 ens3 0.40 0.32 0.05 0.06 0.00 0.00 0.00 0.00 13:23:28 12:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:05:01 lo 21.13 21.13 7.13 7.13 0.00 0.00 0.00 0.00 13:23:28 12:05:01 ens3 2.45 2.58 0.89 0.82 0.00 0.00 0.00 0.00 13:23:28 12:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:06:01 lo 15.35 15.35 20.46 20.46 0.00 0.00 0.00 0.00 13:23:28 12:06:01 ens3 1.12 1.28 0.29 0.24 0.00 0.00 0.00 0.00 13:23:28 12:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:07:01 lo 23.58 23.58 7.72 7.72 0.00 0.00 0.00 0.00 13:23:28 12:07:01 ens3 1.15 1.52 0.24 0.24 0.00 0.00 0.00 0.00 13:23:28 12:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:08:01 lo 26.36 26.36 8.26 8.26 0.00 0.00 0.00 0.00 13:23:28 12:08:01 ens3 2.07 1.90 0.37 0.34 0.00 0.00 0.00 0.00 13:23:28 12:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:09:01 lo 17.31 17.31 10.98 10.98 0.00 0.00 0.00 0.00 13:23:28 12:09:01 ens3 1.38 1.10 0.45 0.37 0.00 0.00 0.00 0.00 13:23:28 12:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:10:01 lo 42.44 42.44 14.07 14.07 0.00 0.00 0.00 0.00 13:23:28 12:10:01 ens3 1.08 0.98 0.22 0.20 0.00 0.00 0.00 0.00 13:23:28 12:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:11:01 lo 13.58 13.58 6.78 6.78 0.00 0.00 0.00 0.00 13:23:28 12:11:01 ens3 5.92 6.13 1.30 3.15 0.00 0.00 0.00 0.00 13:23:28 12:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:12:01 lo 17.86 17.86 5.41 5.41 0.00 0.00 0.00 0.00 13:23:28 12:12:01 ens3 2.20 2.15 0.87 0.76 0.00 0.00 0.00 0.00 13:23:28 12:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:13:01 lo 15.88 15.88 10.16 10.16 0.00 0.00 0.00 0.00 13:23:28 12:13:01 ens3 1.62 1.47 0.31 0.29 0.00 0.00 0.00 0.00 13:23:28 12:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:14:01 lo 13.11 13.11 4.64 4.64 0.00 0.00 0.00 0.00 13:23:28 12:14:01 ens3 0.72 0.62 0.10 0.10 0.00 0.00 0.00 0.00 13:23:28 12:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:15:01 lo 15.65 15.65 7.67 7.67 0.00 0.00 0.00 0.00 13:23:28 12:15:01 ens3 1.08 0.87 0.18 0.16 0.00 0.00 0.00 0.00 13:23:28 12:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:16:01 lo 16.30 16.30 6.59 6.59 0.00 0.00 0.00 0.00 13:23:28 12:16:01 ens3 1.35 1.30 0.36 0.29 0.00 0.00 0.00 0.00 13:23:28 12:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:17:01 lo 5.57 5.57 6.34 6.34 0.00 0.00 0.00 0.00 13:23:28 12:17:01 ens3 0.82 0.93 0.13 0.14 0.00 0.00 0.00 0.00 13:23:28 12:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:18:01 lo 7.77 7.77 3.03 3.03 0.00 0.00 0.00 0.00 13:23:28 12:18:01 ens3 0.45 0.40 0.06 0.06 0.00 0.00 0.00 0.00 13:23:28 12:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:19:01 lo 3.80 3.80 0.62 0.62 0.00 0.00 0.00 0.00 13:23:28 12:19:01 ens3 0.75 0.83 0.12 0.12 0.00 0.00 0.00 0.00 13:23:28 12:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:20:01 lo 30.83 30.83 14.95 14.95 0.00 0.00 0.00 0.00 13:23:28 12:20:01 ens3 0.62 0.77 0.11 0.11 0.00 0.00 0.00 0.00 13:23:28 12:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:21:01 lo 20.51 20.51 8.21 8.21 0.00 0.00 0.00 0.00 13:23:28 12:21:01 ens3 40.75 17.81 685.28 1.57 0.00 0.00 0.00 0.00 13:23:28 12:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:22:01 lo 13.91 13.91 16.44 16.44 0.00 0.00 0.00 0.00 13:23:28 12:22:01 ens3 0.60 0.67 0.09 0.09 0.00 0.00 0.00 0.00 13:23:28 12:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:23:01 lo 9.63 9.63 4.03 4.03 0.00 0.00 0.00 0.00 13:23:28 12:23:01 ens3 1.10 1.18 0.17 0.17 0.00 0.00 0.00 0.00 13:23:28 12:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:24:01 lo 44.98 44.98 17.75 17.75 0.00 0.00 0.00 0.00 13:23:28 12:24:01 ens3 1.37 1.28 0.43 0.36 0.00 0.00 0.00 0.00 13:23:28 12:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:25:01 lo 35.83 35.83 10.22 10.22 0.00 0.00 0.00 0.00 13:23:28 12:25:01 ens3 0.75 0.60 0.13 0.11 0.00 0.00 0.00 0.00 13:23:28 12:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:26:01 lo 14.16 14.16 4.05 4.05 0.00 0.00 0.00 0.00 13:23:28 12:26:01 ens3 0.92 0.75 0.24 0.17 0.00 0.00 0.00 0.00 13:23:28 12:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:27:01 lo 31.26 31.26 22.21 22.21 0.00 0.00 0.00 0.00 13:23:28 12:27:01 ens3 0.72 0.53 0.11 0.09 0.00 0.00 0.00 0.00 13:23:28 12:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:28:01 lo 10.98 10.98 6.96 6.96 0.00 0.00 0.00 0.00 13:23:28 12:28:01 ens3 0.72 0.60 0.14 0.12 0.00 0.00 0.00 0.00 13:23:28 12:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:29:01 lo 12.96 12.96 5.73 5.73 0.00 0.00 0.00 0.00 13:23:28 12:29:01 ens3 0.57 0.53 0.11 0.10 0.00 0.00 0.00 0.00 13:23:28 12:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:30:01 lo 24.01 24.01 10.08 10.08 0.00 0.00 0.00 0.00 13:23:28 12:30:01 ens3 0.62 0.53 0.11 0.09 0.00 0.00 0.00 0.00 13:23:28 12:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:31:01 lo 18.75 18.75 8.14 8.14 0.00 0.00 0.00 0.00 13:23:28 12:31:01 ens3 0.87 1.00 0.25 0.19 0.00 0.00 0.00 0.00 13:23:28 12:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:32:01 lo 7.37 7.37 3.09 3.09 0.00 0.00 0.00 0.00 13:23:28 12:32:01 ens3 1.43 0.97 0.41 0.30 0.00 0.00 0.00 0.00 13:23:28 12:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:33:01 lo 17.56 17.56 8.39 8.39 0.00 0.00 0.00 0.00 13:23:28 12:33:01 ens3 0.87 0.88 0.35 0.30 0.00 0.00 0.00 0.00 13:23:28 12:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:34:01 lo 21.05 21.05 6.90 6.90 0.00 0.00 0.00 0.00 13:23:28 12:34:01 ens3 0.90 0.23 0.11 0.05 0.00 0.00 0.00 0.00 13:23:28 12:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:35:01 lo 0.33 0.33 0.02 0.02 0.00 0.00 0.00 0.00 13:23:28 12:35:01 ens3 1.55 0.65 0.65 0.44 0.00 0.00 0.00 0.00 13:23:28 12:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:36:01 lo 0.20 0.20 0.02 0.02 0.00 0.00 0.00 0.00 13:23:28 12:36:01 ens3 0.67 0.32 0.38 0.29 0.00 0.00 0.00 0.00 13:23:28 12:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:37:01 lo 1.53 1.53 0.13 0.13 0.00 0.00 0.00 0.00 13:23:28 12:37:01 ens3 0.52 0.42 0.06 0.09 0.00 0.00 0.00 0.00 13:23:28 12:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:38:01 lo 34.26 34.26 13.10 13.10 0.00 0.00 0.00 0.00 13:23:28 12:38:01 ens3 0.88 0.70 0.18 0.12 0.00 0.00 0.00 0.00 13:23:28 12:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:39:01 lo 40.73 40.73 12.82 12.82 0.00 0.00 0.00 0.00 13:23:28 12:39:01 ens3 0.75 0.60 0.13 0.11 0.00 0.00 0.00 0.00 13:23:28 12:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:40:01 lo 31.58 31.58 9.87 9.87 0.00 0.00 0.00 0.00 13:23:28 12:40:01 ens3 0.40 0.22 0.05 0.04 0.00 0.00 0.00 0.00 13:23:28 12:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:41:01 lo 32.24 32.24 9.25 9.25 0.00 0.00 0.00 0.00 13:23:28 12:41:01 ens3 0.67 0.48 0.21 0.14 0.00 0.00 0.00 0.00 13:23:28 12:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:42:01 lo 29.73 29.73 9.14 9.14 0.00 0.00 0.00 0.00 13:23:28 12:42:01 ens3 0.23 0.15 0.04 0.03 0.00 0.00 0.00 0.00 13:23:28 12:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:43:01 lo 30.04 30.04 9.24 9.24 0.00 0.00 0.00 0.00 13:23:28 12:43:01 ens3 0.25 0.13 0.02 0.01 0.00 0.00 0.00 0.00 13:23:28 12:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:44:01 lo 63.19 63.19 19.36 19.36 0.00 0.00 0.00 0.00 13:23:28 12:44:01 ens3 0.13 0.00 0.01 0.00 0.00 0.00 0.00 0.00 13:23:28 12:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:45:01 lo 3.78 3.78 0.91 0.91 0.00 0.00 0.00 0.00 13:23:28 12:45:01 ens3 0.85 0.77 0.11 0.10 0.00 0.00 0.00 0.00 13:23:28 12:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:46:01 lo 24.35 24.35 22.51 22.51 0.00 0.00 0.00 0.00 13:23:28 12:46:01 ens3 0.88 0.75 0.27 0.20 0.00 0.00 0.00 0.00 13:23:28 12:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:47:01 lo 31.94 31.94 13.79 13.79 0.00 0.00 0.00 0.00 13:23:28 12:47:01 ens3 0.75 0.62 0.13 0.11 0.00 0.00 0.00 0.00 13:23:28 12:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:48:01 lo 22.66 22.66 10.89 10.89 0.00 0.00 0.00 0.00 13:23:28 12:48:01 ens3 0.55 0.45 0.10 0.09 0.00 0.00 0.00 0.00 13:23:28 12:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:49:01 lo 22.41 22.41 8.86 8.86 0.00 0.00 0.00 0.00 13:23:28 12:49:01 ens3 0.70 0.55 0.12 0.11 0.00 0.00 0.00 0.00 13:23:28 12:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:50:01 lo 32.64 32.64 10.71 10.71 0.00 0.00 0.00 0.00 13:23:28 12:50:01 ens3 0.82 0.33 0.12 0.07 0.00 0.00 0.00 0.00 13:23:28 12:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:51:01 lo 19.70 19.70 8.93 8.93 0.00 0.00 0.00 0.00 13:23:28 12:51:01 ens3 2.03 1.02 0.61 0.40 0.00 0.00 0.00 0.00 13:23:28 12:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:52:01 lo 20.68 20.68 7.83 7.83 0.00 0.00 0.00 0.00 13:23:28 12:52:01 ens3 0.93 0.60 0.38 0.30 0.00 0.00 0.00 0.00 13:23:28 12:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:53:01 lo 5.01 5.01 2.15 2.15 0.00 0.00 0.00 0.00 13:23:28 12:53:01 ens3 1.08 0.88 0.14 0.13 0.00 0.00 0.00 0.00 13:23:28 12:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:54:01 lo 23.20 23.20 22.64 22.64 0.00 0.00 0.00 0.00 13:23:28 12:54:01 ens3 0.73 0.50 0.12 0.10 0.00 0.00 0.00 0.00 13:23:28 12:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:55:01 lo 43.69 43.69 19.42 19.42 0.00 0.00 0.00 0.00 13:23:28 12:55:01 ens3 0.67 0.55 0.11 0.10 0.00 0.00 0.00 0.00 13:23:28 12:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:56:01 lo 9.63 9.63 5.44 5.44 0.00 0.00 0.00 0.00 13:23:28 12:56:01 ens3 1.17 0.50 0.28 0.15 0.00 0.00 0.00 0.00 13:23:28 12:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:57:01 lo 19.20 19.20 10.15 10.15 0.00 0.00 0.00 0.00 13:23:28 12:57:01 ens3 1.15 0.72 0.38 0.29 0.00 0.00 0.00 0.00 13:23:28 12:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:58:01 lo 13.80 13.80 8.34 8.34 0.00 0.00 0.00 0.00 13:23:28 12:58:01 ens3 0.70 0.57 0.12 0.11 0.00 0.00 0.00 0.00 13:23:28 12:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 12:59:02 lo 7.50 7.50 4.29 4.29 0.00 0.00 0.00 0.00 13:23:28 12:59:02 ens3 0.45 0.35 0.07 0.06 0.00 0.00 0.00 0.00 13:23:28 12:59:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:00:01 lo 25.18 25.18 12.09 12.09 0.00 0.00 0.00 0.00 13:23:28 13:00:01 ens3 1.30 0.32 0.18 0.07 0.00 0.00 0.00 0.00 13:23:28 13:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:01:01 lo 9.98 9.98 6.15 6.15 0.00 0.00 0.00 0.00 13:23:28 13:01:01 ens3 1.33 1.08 0.72 0.56 0.00 0.00 0.00 0.00 13:23:28 13:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:02:01 lo 38.01 38.01 14.29 14.29 0.00 0.00 0.00 0.00 13:23:28 13:02:01 ens3 0.40 0.32 0.07 0.06 0.00 0.00 0.00 0.00 13:23:28 13:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:03:01 lo 3.42 3.42 0.99 0.99 0.00 0.00 0.00 0.00 13:23:28 13:03:01 ens3 2.47 2.18 0.86 0.74 0.00 0.00 0.00 0.00 13:23:28 13:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:04:01 lo 44.24 44.24 37.52 37.52 0.00 0.00 0.00 0.00 13:23:28 13:04:01 ens3 0.92 0.73 0.17 0.15 0.00 0.00 0.00 0.00 13:23:28 13:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:05:01 lo 27.78 27.78 10.27 10.27 0.00 0.00 0.00 0.00 13:23:28 13:05:01 ens3 0.95 0.75 0.17 0.15 0.00 0.00 0.00 0.00 13:23:28 13:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:06:01 lo 0.23 0.23 0.02 0.02 0.00 0.00 0.00 0.00 13:23:28 13:06:01 ens3 0.38 0.15 0.14 0.07 0.00 0.00 0.00 0.00 13:23:28 13:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:07:01 lo 0.60 0.60 0.06 0.06 0.00 0.00 0.00 0.00 13:23:28 13:07:01 ens3 0.22 0.08 0.01 0.01 0.00 0.00 0.00 0.00 13:23:28 13:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:08:01 lo 0.70 0.70 0.06 0.06 0.00 0.00 0.00 0.00 13:23:28 13:08:01 ens3 0.18 0.10 0.02 0.02 0.00 0.00 0.00 0.00 13:23:28 13:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:09:01 lo 0.20 0.20 0.01 0.01 0.00 0.00 0.00 0.00 13:23:28 13:09:01 ens3 0.22 0.08 0.01 0.01 0.00 0.00 0.00 0.00 13:23:28 13:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:10:01 lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:10:01 ens3 0.13 0.00 0.01 0.00 0.00 0.00 0.00 0.00 13:23:28 13:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:11:01 lo 1.12 1.12 0.09 0.09 0.00 0.00 0.00 0.00 13:23:28 13:11:01 ens3 0.43 0.35 0.11 0.10 0.00 0.00 0.00 0.00 13:23:28 13:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:12:01 lo 31.44 31.44 16.96 16.96 0.00 0.00 0.00 0.00 13:23:28 13:12:01 ens3 0.75 0.67 0.17 0.11 0.00 0.00 0.00 0.00 13:23:28 13:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:13:01 lo 13.18 13.18 5.07 5.07 0.00 0.00 0.00 0.00 13:23:28 13:13:01 ens3 0.77 0.65 0.14 0.13 0.00 0.00 0.00 0.00 13:23:28 13:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:14:01 lo 17.55 17.55 7.23 7.23 0.00 0.00 0.00 0.00 13:23:28 13:14:01 ens3 0.72 0.62 0.14 0.12 0.00 0.00 0.00 0.00 13:23:28 13:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:15:01 lo 16.18 16.18 6.37 6.37 0.00 0.00 0.00 0.00 13:23:28 13:15:01 ens3 0.52 0.43 0.09 0.08 0.00 0.00 0.00 0.00 13:23:28 13:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:16:01 lo 18.05 18.05 6.78 6.78 0.00 0.00 0.00 0.00 13:23:28 13:16:01 ens3 2.50 1.22 0.89 0.60 0.00 0.00 0.00 0.00 13:23:28 13:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:17:01 lo 42.26 42.26 14.28 14.28 0.00 0.00 0.00 0.00 13:23:28 13:17:01 ens3 0.57 0.47 0.10 0.09 0.00 0.00 0.00 0.00 13:23:28 13:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:18:01 lo 36.51 36.51 12.08 12.08 0.00 0.00 0.00 0.00 13:23:28 13:18:01 ens3 1.00 0.78 0.19 0.16 0.00 0.00 0.00 0.00 13:23:28 13:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:19:01 lo 22.13 22.13 13.61 13.61 0.00 0.00 0.00 0.00 13:23:28 13:19:01 ens3 0.92 0.73 0.11 0.10 0.00 0.00 0.00 0.00 13:23:28 13:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:20:01 lo 29.41 29.41 9.54 9.54 0.00 0.00 0.00 0.00 13:23:28 13:20:01 ens3 1.40 0.97 0.46 0.36 0.00 0.00 0.00 0.00 13:23:28 13:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:21:01 lo 89.97 89.97 32.70 32.70 0.00 0.00 0.00 0.00 13:23:28 13:21:01 ens3 0.70 0.48 0.21 0.13 0.00 0.00 0.00 0.00 13:23:28 13:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:22:01 lo 72.74 72.74 23.79 23.79 0.00 0.00 0.00 0.00 13:23:28 13:22:01 ens3 1.10 0.42 0.15 0.08 0.00 0.00 0.00 0.00 13:23:28 13:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:23:01 lo 3.38 3.38 1.10 1.10 0.00 0.00 0.00 0.00 13:23:28 13:23:01 ens3 154.34 120.65 1958.57 27.52 0.00 0.00 0.00 0.00 13:23:28 13:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 Average: lo 20.18 20.18 9.29 9.29 0.00 0.00 0.00 0.00 13:23:28 Average: ens3 15.61 11.38 218.54 1.50 0.00 0.00 0.00 0.00 13:23:28 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:23:28 13:23:28 13:23:28 ---> sar -P ALL: 13:23:28 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-43727) 10/18/24 _x86_64_ (4 CPU) 13:23:28 13:23:28 11:50:10 LINUX RESTART (4 CPU) 13:23:28 13:23:28 11:51:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 11:52:01 all 18.91 10.04 9.19 2.69 0.09 59.08 13:23:28 11:52:01 0 12.60 9.73 8.73 2.37 0.10 66.48 13:23:28 11:52:01 1 15.74 12.23 10.64 2.21 0.08 59.11 13:23:28 11:52:01 2 26.01 7.60 7.94 4.14 0.08 54.23 13:23:28 11:52:01 3 21.35 10.60 9.46 2.05 0.10 56.43 13:23:28 11:53:01 all 60.57 0.00 4.98 5.01 0.11 29.33 13:23:28 11:53:01 0 57.21 0.00 4.92 5.27 0.10 32.50 13:23:28 11:53:01 1 64.76 0.00 5.63 3.76 0.10 25.75 13:23:28 11:53:01 2 58.19 0.00 4.88 6.35 0.12 30.45 13:23:28 11:53:01 3 62.06 0.00 4.48 4.69 0.10 28.66 13:23:28 11:54:01 all 68.17 0.00 2.60 2.16 0.11 26.96 13:23:28 11:54:01 0 70.25 0.00 1.94 3.02 0.12 24.67 13:23:28 11:54:01 1 71.08 0.00 4.07 1.32 0.10 23.43 13:23:28 11:54:01 2 77.47 0.00 1.78 1.37 0.12 19.26 13:23:28 11:54:01 3 53.80 0.00 2.59 2.94 0.10 40.57 13:23:28 11:55:01 all 72.77 0.00 4.22 3.32 0.11 19.59 13:23:28 11:55:01 0 73.03 0.00 4.45 2.88 0.12 19.53 13:23:28 11:55:01 1 68.05 0.00 3.96 3.22 0.10 24.68 13:23:28 11:55:01 2 78.88 0.00 4.63 3.30 0.10 13.09 13:23:28 11:55:01 3 71.05 0.00 3.83 3.88 0.10 21.14 13:23:28 11:56:01 all 66.85 0.00 4.40 16.83 0.14 11.78 13:23:28 11:56:01 0 66.50 0.00 4.63 12.54 0.14 16.19 13:23:28 11:56:01 1 66.38 0.00 4.80 19.11 0.15 9.56 13:23:28 11:56:01 2 69.57 0.00 3.70 12.23 0.12 14.38 13:23:28 11:56:01 3 64.91 0.00 4.48 23.54 0.15 6.92 13:23:28 11:57:01 all 79.54 0.00 3.13 3.84 0.11 13.38 13:23:28 11:57:01 0 79.48 0.00 3.02 1.39 0.10 16.00 13:23:28 11:57:01 1 78.04 0.00 3.69 7.82 0.12 10.33 13:23:28 11:57:01 2 80.61 0.00 2.65 2.28 0.13 14.33 13:23:28 11:57:01 3 80.05 0.00 3.16 3.82 0.10 12.87 13:23:28 11:58:01 all 52.40 0.00 2.14 0.31 0.11 45.04 13:23:28 11:58:01 0 54.15 0.00 2.46 0.17 0.10 43.12 13:23:28 11:58:01 1 51.57 0.00 2.07 0.71 0.10 45.56 13:23:28 11:58:01 2 52.27 0.00 2.43 0.30 0.12 44.89 13:23:28 11:58:01 3 51.59 0.00 1.61 0.08 0.12 46.60 13:23:28 11:59:01 all 43.72 0.00 1.59 0.62 0.11 53.97 13:23:28 11:59:01 0 45.39 0.00 1.48 0.54 0.10 52.49 13:23:28 11:59:01 1 45.13 0.00 1.64 1.64 0.12 51.48 13:23:28 11:59:01 2 43.37 0.00 1.70 0.22 0.10 54.61 13:23:28 11:59:01 3 41.03 0.00 1.54 0.08 0.10 57.25 13:23:28 12:00:01 all 53.67 0.00 2.06 0.10 0.10 44.07 13:23:28 12:00:01 0 54.28 0.00 2.30 0.12 0.12 43.19 13:23:28 12:00:01 1 54.06 0.00 1.78 0.08 0.10 43.97 13:23:28 12:00:01 2 54.44 0.00 2.44 0.02 0.10 43.01 13:23:28 12:00:01 3 51.92 0.00 1.71 0.17 0.10 46.11 13:23:28 12:01:01 all 82.14 0.00 3.38 0.47 0.12 13.89 13:23:28 12:01:01 0 81.55 0.00 3.34 1.11 0.15 13.85 13:23:28 12:01:01 1 81.10 0.00 3.68 0.56 0.10 14.55 13:23:28 12:01:01 2 83.51 0.00 3.38 0.03 0.13 12.94 13:23:28 12:01:01 3 82.38 0.00 3.11 0.17 0.10 14.24 13:23:28 12:02:01 all 22.45 0.00 0.78 0.08 0.09 76.59 13:23:28 12:02:01 0 22.74 0.00 0.89 0.00 0.08 76.29 13:23:28 12:02:01 1 22.34 0.00 0.80 0.27 0.10 76.49 13:23:28 12:02:01 2 21.97 0.00 0.64 0.00 0.08 77.31 13:23:28 12:02:01 3 22.74 0.00 0.80 0.07 0.10 76.29 13:23:28 13:23:28 12:02:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:03:01 all 3.98 0.00 0.35 0.02 0.09 95.56 13:23:28 12:03:01 0 4.00 0.00 0.32 0.00 0.08 95.59 13:23:28 12:03:01 1 3.58 0.00 0.30 0.07 0.10 95.96 13:23:28 12:03:01 2 4.55 0.00 0.37 0.02 0.10 94.97 13:23:28 12:03:01 3 3.79 0.00 0.42 0.00 0.08 95.71 13:23:28 12:04:01 all 3.40 0.00 0.35 0.02 0.09 96.14 13:23:28 12:04:01 0 2.75 0.00 0.39 0.00 0.10 96.77 13:23:28 12:04:01 1 4.04 0.00 0.35 0.03 0.08 95.49 13:23:28 12:04:01 2 2.99 0.00 0.42 0.03 0.10 96.46 13:23:28 12:04:01 3 3.81 0.00 0.27 0.00 0.08 95.84 13:23:28 12:05:01 all 30.58 0.00 1.32 0.24 0.10 67.76 13:23:28 12:05:01 0 38.25 0.00 1.59 0.05 0.08 60.03 13:23:28 12:05:01 1 28.69 0.00 1.51 0.40 0.13 69.27 13:23:28 12:05:01 2 26.59 0.00 0.99 0.49 0.10 71.83 13:23:28 12:05:01 3 28.77 0.00 1.21 0.02 0.10 69.90 13:23:28 12:06:01 all 46.86 0.00 1.86 1.27 0.10 49.90 13:23:28 12:06:01 0 47.94 0.00 1.71 2.13 0.10 48.12 13:23:28 12:06:01 1 46.09 0.00 2.18 2.08 0.10 49.56 13:23:28 12:06:01 2 44.86 0.00 1.81 0.79 0.12 52.43 13:23:28 12:06:01 3 48.55 0.00 1.74 0.10 0.10 49.51 13:23:28 12:07:01 all 5.00 0.00 0.52 0.01 0.10 94.38 13:23:28 12:07:01 0 4.92 0.00 0.47 0.00 0.08 94.53 13:23:28 12:07:01 1 6.49 0.00 0.40 0.05 0.10 92.97 13:23:28 12:07:01 2 4.31 0.00 0.62 0.00 0.12 94.96 13:23:28 12:07:01 3 4.25 0.00 0.58 0.00 0.10 95.07 13:23:28 12:08:01 all 3.21 0.00 0.47 0.02 0.10 96.21 13:23:28 12:08:01 0 3.32 0.00 0.55 0.03 0.12 95.98 13:23:28 12:08:01 1 3.27 0.00 0.40 0.03 0.08 96.21 13:23:28 12:08:01 2 3.04 0.00 0.43 0.00 0.12 96.41 13:23:28 12:08:01 3 3.20 0.00 0.49 0.00 0.08 96.24 13:23:28 12:09:01 all 42.17 0.00 1.65 0.33 0.10 55.75 13:23:28 12:09:01 0 43.71 0.00 1.71 0.57 0.08 53.93 13:23:28 12:09:01 1 42.34 0.00 1.68 0.72 0.10 55.16 13:23:28 12:09:01 2 41.16 0.00 1.69 0.03 0.10 57.01 13:23:28 12:09:01 3 41.47 0.00 1.52 0.02 0.10 56.89 13:23:28 12:10:01 all 5.65 0.00 0.51 0.01 0.10 93.73 13:23:28 12:10:01 0 5.70 0.00 0.48 0.00 0.10 93.71 13:23:28 12:10:01 1 5.83 0.00 0.58 0.03 0.10 93.45 13:23:28 12:10:01 2 5.00 0.00 0.40 0.02 0.08 94.50 13:23:28 12:10:01 3 6.05 0.00 0.57 0.00 0.12 93.27 13:23:28 12:11:01 all 30.99 0.00 1.35 0.07 0.09 67.50 13:23:28 12:11:01 0 31.07 0.00 1.23 0.02 0.08 67.60 13:23:28 12:11:01 1 30.93 0.00 1.56 0.13 0.10 67.27 13:23:28 12:11:01 2 31.66 0.00 1.39 0.03 0.08 66.83 13:23:28 12:11:01 3 30.32 0.00 1.20 0.08 0.10 68.30 13:23:28 12:12:01 all 29.71 0.00 1.07 0.12 0.09 69.01 13:23:28 12:12:01 0 27.80 0.00 0.95 0.00 0.08 71.17 13:23:28 12:12:01 1 29.58 0.00 1.13 0.37 0.08 68.84 13:23:28 12:12:01 2 25.95 0.00 1.12 0.02 0.10 72.81 13:23:28 12:12:01 3 35.50 0.00 1.08 0.08 0.08 63.24 13:23:28 12:13:01 all 23.95 0.00 0.96 0.42 0.09 74.58 13:23:28 12:13:01 0 24.06 0.00 1.17 0.79 0.10 73.88 13:23:28 12:13:01 1 24.27 0.00 0.94 0.50 0.08 74.20 13:23:28 12:13:01 2 24.50 0.00 0.79 0.00 0.08 74.63 13:23:28 12:13:01 3 22.97 0.00 0.92 0.40 0.08 75.62 13:23:28 13:23:28 12:13:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:14:01 all 52.39 0.00 1.38 0.26 0.09 45.87 13:23:28 12:14:01 0 56.39 0.00 1.67 0.64 0.08 41.22 13:23:28 12:14:01 1 51.78 0.00 1.06 0.00 0.08 47.08 13:23:28 12:14:01 2 53.65 0.00 1.47 0.40 0.10 44.38 13:23:28 12:14:01 3 47.76 0.00 1.33 0.02 0.10 50.79 13:23:28 12:15:01 all 21.54 0.00 0.73 0.32 0.08 77.32 13:23:28 12:15:01 0 22.51 0.00 0.80 1.22 0.07 75.41 13:23:28 12:15:01 1 21.36 0.00 0.72 0.03 0.08 77.81 13:23:28 12:15:01 2 18.97 0.00 0.74 0.02 0.08 80.19 13:23:28 12:15:01 3 23.31 0.00 0.68 0.00 0.10 75.90 13:23:28 12:16:01 all 10.23 0.00 0.74 0.02 0.08 88.93 13:23:28 12:16:01 0 9.50 0.00 0.77 0.03 0.08 89.61 13:23:28 12:16:01 1 9.84 0.00 0.72 0.03 0.07 89.34 13:23:28 12:16:01 2 10.61 0.00 0.63 0.00 0.08 88.67 13:23:28 12:16:01 3 10.99 0.00 0.83 0.00 0.10 88.08 13:23:28 12:17:01 all 29.49 0.00 1.06 0.29 0.10 69.06 13:23:28 12:17:01 0 26.42 0.00 1.35 0.70 0.08 71.45 13:23:28 12:17:01 1 30.89 0.00 1.10 0.03 0.12 67.86 13:23:28 12:17:01 2 31.41 0.00 0.80 0.00 0.10 67.68 13:23:28 12:17:01 3 29.24 0.00 0.99 0.43 0.08 69.26 13:23:28 12:18:01 all 19.74 0.00 0.59 0.35 0.08 79.24 13:23:28 12:18:01 0 20.01 0.00 0.69 1.34 0.10 77.87 13:23:28 12:18:01 1 20.37 0.00 0.45 0.03 0.08 79.07 13:23:28 12:18:01 2 19.42 0.00 0.75 0.03 0.08 79.71 13:23:28 12:18:01 3 19.15 0.00 0.47 0.00 0.07 80.31 13:23:28 12:19:01 all 19.10 0.00 0.80 0.04 0.08 79.98 13:23:28 12:19:01 0 19.92 0.00 0.65 0.00 0.08 79.35 13:23:28 12:19:01 1 16.55 0.00 0.76 0.03 0.08 82.58 13:23:28 12:19:01 2 20.23 0.00 1.14 0.10 0.10 78.44 13:23:28 12:19:01 3 19.68 0.00 0.65 0.02 0.07 79.59 13:23:28 12:20:01 all 47.08 0.00 1.34 0.64 0.09 50.85 13:23:28 12:20:01 0 45.69 0.00 1.16 0.10 0.10 52.95 13:23:28 12:20:01 1 47.48 0.00 1.54 1.98 0.08 48.92 13:23:28 12:20:01 2 47.91 0.00 1.05 0.03 0.07 50.94 13:23:28 12:20:01 3 47.23 0.00 1.61 0.45 0.10 50.61 13:23:28 12:21:01 all 16.96 0.00 0.87 0.59 0.09 81.49 13:23:28 12:21:01 0 17.15 0.00 0.85 0.57 0.08 81.35 13:23:28 12:21:01 1 17.51 0.00 0.70 0.60 0.08 81.10 13:23:28 12:21:01 2 17.57 0.00 0.80 0.60 0.10 80.92 13:23:28 12:21:01 3 15.61 0.00 1.14 0.57 0.08 82.60 13:23:28 12:22:01 all 27.72 0.00 0.71 0.23 0.08 71.25 13:23:28 12:22:01 0 28.13 0.00 0.92 0.15 0.08 70.71 13:23:28 12:22:01 1 28.65 0.00 0.80 0.23 0.08 70.23 13:23:28 12:22:01 2 28.31 0.00 0.46 0.51 0.08 70.63 13:23:28 12:22:01 3 25.81 0.00 0.67 0.02 0.08 73.43 13:23:28 12:23:01 all 34.62 0.00 1.08 0.02 0.08 64.20 13:23:28 12:23:01 0 35.50 0.00 0.82 0.00 0.08 63.60 13:23:28 12:23:01 1 34.89 0.00 1.24 0.00 0.08 63.79 13:23:28 12:23:01 2 37.69 0.00 1.32 0.05 0.08 60.86 13:23:28 12:23:01 3 30.41 0.00 0.94 0.02 0.08 68.55 13:23:28 12:24:01 all 21.68 0.00 0.57 0.23 0.08 77.43 13:23:28 12:24:01 0 21.77 0.00 0.49 0.00 0.08 77.66 13:23:28 12:24:01 1 21.98 0.00 0.75 0.43 0.07 76.76 13:23:28 12:24:01 2 22.32 0.00 0.50 0.49 0.10 76.59 13:23:28 12:24:01 3 20.65 0.00 0.55 0.02 0.08 78.69 13:23:28 13:23:28 12:24:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:25:01 all 3.96 0.00 0.20 0.02 0.08 95.74 13:23:28 12:25:01 0 3.59 0.00 0.23 0.00 0.10 96.08 13:23:28 12:25:01 1 3.63 0.00 0.27 0.00 0.08 96.02 13:23:28 12:25:01 2 3.70 0.00 0.17 0.07 0.07 96.00 13:23:28 12:25:01 3 4.91 0.00 0.12 0.00 0.08 94.89 13:23:28 12:26:01 all 31.84 0.00 1.04 0.03 0.10 66.99 13:23:28 12:26:01 0 33.09 0.00 1.10 0.00 0.08 65.73 13:23:28 12:26:01 1 32.06 0.00 0.82 0.02 0.08 67.02 13:23:28 12:26:01 2 33.86 0.00 1.24 0.08 0.12 64.69 13:23:28 12:26:01 3 28.40 0.00 1.01 0.00 0.12 70.47 13:23:28 12:27:01 all 24.38 0.00 0.69 0.26 0.09 74.57 13:23:28 12:27:01 0 24.83 0.00 0.60 0.03 0.08 74.45 13:23:28 12:27:01 1 25.79 0.00 0.75 0.58 0.10 72.77 13:23:28 12:27:01 2 24.54 0.00 0.83 0.38 0.10 74.15 13:23:28 12:27:01 3 22.38 0.00 0.58 0.03 0.08 76.92 13:23:28 12:28:01 all 2.85 0.00 0.29 0.01 0.09 96.75 13:23:28 12:28:01 0 2.98 0.00 0.23 0.00 0.08 96.70 13:23:28 12:28:01 1 2.86 0.00 0.28 0.03 0.10 96.72 13:23:28 12:28:01 2 2.68 0.00 0.42 0.00 0.10 96.81 13:23:28 12:28:01 3 2.89 0.00 0.22 0.02 0.08 96.79 13:23:28 12:29:01 all 2.02 0.00 0.29 0.03 0.09 97.57 13:23:28 12:29:01 0 2.00 0.00 0.38 0.00 0.08 97.53 13:23:28 12:29:01 1 2.12 0.00 0.38 0.07 0.10 97.33 13:23:28 12:29:01 2 2.05 0.00 0.13 0.07 0.07 97.68 13:23:28 12:29:01 3 1.90 0.00 0.25 0.00 0.10 97.75 13:23:28 12:30:01 all 2.61 0.00 0.30 0.02 0.09 96.98 13:23:28 12:30:01 0 2.57 0.00 0.37 0.00 0.12 96.95 13:23:28 12:30:01 1 2.50 0.00 0.27 0.03 0.08 97.12 13:23:28 12:30:01 2 2.59 0.00 0.33 0.02 0.08 96.97 13:23:28 12:30:01 3 2.77 0.00 0.25 0.02 0.08 96.88 13:23:28 12:31:01 all 2.29 0.00 0.26 0.01 0.08 97.35 13:23:28 12:31:01 0 2.24 0.00 0.23 0.00 0.08 97.44 13:23:28 12:31:01 1 2.70 0.00 0.30 0.03 0.08 96.88 13:23:28 12:31:01 2 2.05 0.00 0.25 0.00 0.07 97.63 13:23:28 12:31:01 3 2.17 0.00 0.27 0.02 0.08 97.46 13:23:28 12:32:01 all 1.30 0.00 0.25 0.03 0.09 98.33 13:23:28 12:32:01 0 1.45 0.00 0.35 0.00 0.12 98.08 13:23:28 12:32:01 1 1.34 0.00 0.17 0.03 0.07 98.40 13:23:28 12:32:01 2 0.80 0.00 0.15 0.00 0.07 98.98 13:23:28 12:32:01 3 1.62 0.00 0.32 0.10 0.12 97.85 13:23:28 12:33:01 all 1.95 0.00 0.28 0.01 0.08 97.68 13:23:28 12:33:01 0 2.28 0.00 0.32 0.00 0.08 97.32 13:23:28 12:33:01 1 1.82 0.00 0.22 0.03 0.07 97.86 13:23:28 12:33:01 2 1.84 0.00 0.40 0.00 0.10 97.66 13:23:28 12:33:01 3 1.86 0.00 0.20 0.02 0.07 97.86 13:23:28 12:34:01 all 1.73 0.00 0.25 0.05 0.09 97.87 13:23:28 12:34:01 0 1.78 0.00 0.27 0.00 0.10 97.85 13:23:28 12:34:01 1 1.84 0.00 0.25 0.07 0.10 97.74 13:23:28 12:34:01 2 1.71 0.00 0.23 0.13 0.10 97.83 13:23:28 12:34:01 3 1.60 0.00 0.27 0.00 0.07 98.07 13:23:28 12:35:01 all 0.47 0.00 0.21 0.06 0.08 99.18 13:23:28 12:35:01 0 0.35 0.00 0.13 0.00 0.07 99.45 13:23:28 12:35:01 1 0.62 0.00 0.30 0.03 0.10 98.94 13:23:28 12:35:01 2 0.43 0.00 0.17 0.20 0.08 99.11 13:23:28 12:35:01 3 0.47 0.00 0.23 0.00 0.08 99.22 13:23:28 13:23:28 12:35:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:36:01 all 0.41 0.00 0.19 0.02 0.07 99.31 13:23:28 12:36:01 0 0.37 0.00 0.17 0.00 0.05 99.42 13:23:28 12:36:01 1 0.34 0.00 0.18 0.03 0.08 99.36 13:23:28 12:36:01 2 0.50 0.00 0.25 0.05 0.08 99.11 13:23:28 12:36:01 3 0.43 0.00 0.15 0.00 0.07 99.35 13:23:28 12:37:01 all 22.67 0.00 0.84 0.05 0.08 76.36 13:23:28 12:37:01 0 23.49 0.00 1.04 0.00 0.08 75.39 13:23:28 12:37:01 1 19.41 0.00 0.69 0.03 0.08 79.79 13:23:28 12:37:01 2 24.44 0.00 1.10 0.18 0.08 74.19 13:23:28 12:37:01 3 23.30 0.00 0.55 0.00 0.07 76.08 13:23:28 12:38:01 all 31.26 0.00 0.90 0.23 0.10 67.50 13:23:28 12:38:01 0 31.61 0.00 1.04 0.02 0.10 67.23 13:23:28 12:38:01 1 28.27 0.00 0.67 0.60 0.10 70.36 13:23:28 12:38:01 2 32.93 0.00 0.94 0.25 0.10 65.79 13:23:28 12:38:01 3 32.24 0.00 0.97 0.07 0.08 66.64 13:23:28 12:39:01 all 4.87 0.00 0.24 0.01 0.08 94.79 13:23:28 12:39:01 0 5.09 0.00 0.28 0.00 0.08 94.54 13:23:28 12:39:01 1 4.81 0.00 0.24 0.03 0.08 94.84 13:23:28 12:39:01 2 4.51 0.00 0.20 0.02 0.08 95.19 13:23:28 12:39:01 3 5.09 0.00 0.25 0.00 0.08 94.58 13:23:28 12:40:01 all 2.71 0.00 0.17 0.02 0.08 97.02 13:23:28 12:40:01 0 2.57 0.00 0.15 0.00 0.08 97.20 13:23:28 12:40:01 1 3.26 0.00 0.23 0.07 0.08 96.35 13:23:28 12:40:01 2 2.58 0.00 0.18 0.00 0.08 97.15 13:23:28 12:40:01 3 2.43 0.00 0.10 0.00 0.08 97.38 13:23:28 12:41:01 all 2.66 0.00 0.22 0.02 0.08 97.02 13:23:28 12:41:01 0 2.91 0.00 0.23 0.00 0.08 96.77 13:23:28 12:41:01 1 2.71 0.00 0.23 0.07 0.08 96.91 13:23:28 12:41:01 2 2.63 0.00 0.20 0.00 0.08 97.09 13:23:28 12:41:01 3 2.39 0.00 0.22 0.00 0.08 97.31 13:23:28 12:42:01 all 2.53 0.00 0.15 0.01 0.09 97.22 13:23:28 12:42:01 0 2.37 0.00 0.15 0.00 0.08 97.39 13:23:28 12:42:01 1 3.67 0.00 0.12 0.05 0.08 96.08 13:23:28 12:42:01 2 1.99 0.00 0.18 0.00 0.10 97.72 13:23:28 12:42:01 3 2.07 0.00 0.13 0.00 0.08 97.71 13:23:28 12:43:01 all 2.07 0.00 0.16 0.04 0.09 97.64 13:23:28 12:43:01 0 2.09 0.00 0.17 0.00 0.08 97.66 13:23:28 12:43:01 1 2.14 0.00 0.17 0.15 0.10 97.44 13:23:28 12:43:01 2 1.91 0.00 0.22 0.00 0.08 97.79 13:23:28 12:43:01 3 2.14 0.00 0.10 0.00 0.08 97.67 13:23:28 12:44:01 all 4.17 0.00 0.24 0.01 0.09 95.49 13:23:28 12:44:01 0 4.55 0.00 0.25 0.00 0.10 95.10 13:23:28 12:44:01 1 4.07 0.00 0.17 0.02 0.08 95.66 13:23:28 12:44:01 2 4.24 0.00 0.30 0.02 0.08 95.36 13:23:28 12:44:01 3 3.83 0.00 0.25 0.00 0.08 95.83 13:23:28 12:45:01 all 50.18 0.00 1.71 0.34 0.09 47.68 13:23:28 12:45:01 0 50.56 0.00 1.65 0.02 0.08 47.69 13:23:28 12:45:01 1 51.35 0.00 1.30 1.32 0.08 45.95 13:23:28 12:45:01 2 46.53 0.00 1.68 0.02 0.10 51.67 13:23:28 12:45:01 3 52.27 0.00 2.21 0.02 0.08 45.42 13:23:28 12:46:01 all 13.56 0.00 0.43 0.01 0.09 85.91 13:23:28 12:46:01 0 13.25 0.00 0.58 0.00 0.10 86.06 13:23:28 12:46:01 1 14.87 0.00 0.40 0.02 0.08 84.64 13:23:28 12:46:01 2 13.38 0.00 0.40 0.00 0.08 86.14 13:23:28 12:46:01 3 12.71 0.00 0.35 0.02 0.10 86.82 13:23:28 13:23:28 12:46:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:47:01 all 8.47 0.00 0.31 0.02 0.08 91.13 13:23:28 12:47:01 0 8.24 0.00 0.32 0.00 0.08 91.35 13:23:28 12:47:01 1 9.56 0.00 0.35 0.05 0.08 89.96 13:23:28 12:47:01 2 8.29 0.00 0.17 0.00 0.07 91.47 13:23:28 12:47:01 3 7.78 0.00 0.40 0.02 0.08 91.72 13:23:28 12:48:01 all 5.39 0.00 0.31 0.03 0.08 94.18 13:23:28 12:48:01 0 5.67 0.00 0.30 0.08 0.08 93.86 13:23:28 12:48:01 1 5.78 0.00 0.18 0.03 0.07 93.94 13:23:28 12:48:01 2 4.84 0.00 0.39 0.02 0.10 94.66 13:23:28 12:48:01 3 5.26 0.00 0.38 0.00 0.08 94.28 13:23:28 12:49:01 all 2.82 0.00 0.27 0.01 0.08 96.81 13:23:28 12:49:01 0 2.79 0.00 0.20 0.00 0.08 96.92 13:23:28 12:49:01 1 2.56 0.00 0.30 0.03 0.08 97.02 13:23:28 12:49:01 2 2.76 0.00 0.39 0.02 0.08 96.75 13:23:28 12:49:01 3 3.16 0.00 0.20 0.00 0.08 96.56 13:23:28 12:50:01 all 3.03 0.00 0.25 0.02 0.08 96.61 13:23:28 12:50:01 0 3.13 0.00 0.25 0.00 0.08 96.54 13:23:28 12:50:01 1 3.12 0.00 0.25 0.05 0.08 96.50 13:23:28 12:50:01 2 3.23 0.00 0.17 0.02 0.08 96.50 13:23:28 12:50:01 3 2.66 0.00 0.35 0.00 0.08 96.91 13:23:28 12:51:01 all 2.54 0.00 0.27 0.01 0.08 97.11 13:23:28 12:51:01 0 1.77 0.00 0.25 0.00 0.08 97.90 13:23:28 12:51:01 1 2.30 0.00 0.10 0.03 0.08 97.48 13:23:28 12:51:01 2 2.12 0.00 0.25 0.02 0.07 97.55 13:23:28 12:51:01 3 3.94 0.00 0.46 0.00 0.08 95.52 13:23:28 12:52:01 all 2.50 0.00 0.24 0.02 0.08 97.16 13:23:28 12:52:01 0 1.82 0.00 0.32 0.00 0.07 97.79 13:23:28 12:52:01 1 2.47 0.00 0.20 0.05 0.08 97.19 13:23:28 12:52:01 2 2.10 0.00 0.23 0.03 0.08 97.55 13:23:28 12:52:01 3 3.58 0.00 0.21 0.00 0.10 96.10 13:23:28 12:53:01 all 43.58 0.00 1.46 0.02 0.08 54.86 13:23:28 12:53:01 0 45.11 0.00 1.86 0.03 0.08 52.91 13:23:28 12:53:01 1 43.67 0.00 1.31 0.03 0.08 54.91 13:23:28 12:53:01 2 39.77 0.00 1.24 0.02 0.08 58.88 13:23:28 12:53:01 3 45.73 0.00 1.43 0.00 0.08 52.75 13:23:28 12:54:01 all 19.50 0.00 0.50 0.25 0.09 79.66 13:23:28 12:54:01 0 19.36 0.00 0.43 0.32 0.08 79.81 13:23:28 12:54:01 1 19.72 0.00 0.53 0.51 0.08 79.15 13:23:28 12:54:01 2 19.39 0.00 0.47 0.00 0.10 80.04 13:23:28 12:54:01 3 19.55 0.00 0.57 0.17 0.08 79.63 13:23:28 12:55:01 all 10.93 0.00 0.33 0.02 0.09 88.64 13:23:28 12:55:01 0 10.04 0.00 0.32 0.03 0.08 89.52 13:23:28 12:55:01 1 11.32 0.00 0.35 0.05 0.08 88.20 13:23:28 12:55:01 2 11.19 0.00 0.35 0.00 0.08 88.38 13:23:28 12:55:01 3 11.16 0.00 0.28 0.00 0.10 88.45 13:23:28 12:56:01 all 2.46 0.00 0.19 0.02 0.09 97.25 13:23:28 12:56:01 0 2.61 0.00 0.15 0.00 0.08 97.16 13:23:28 12:56:01 1 3.28 0.00 0.22 0.07 0.10 96.34 13:23:28 12:56:01 2 1.70 0.00 0.20 0.00 0.08 98.01 13:23:28 12:56:01 3 2.24 0.00 0.18 0.00 0.10 97.48 13:23:28 12:57:01 all 3.43 0.00 0.24 0.01 0.10 96.23 13:23:28 12:57:01 0 4.23 0.00 0.23 0.00 0.08 95.46 13:23:28 12:57:01 1 3.19 0.00 0.25 0.03 0.10 96.42 13:23:28 12:57:01 2 3.32 0.00 0.22 0.02 0.10 96.34 13:23:28 12:57:01 3 2.96 0.00 0.25 0.00 0.10 96.69 13:23:28 13:23:28 12:57:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 12:58:01 all 1.87 0.00 0.18 0.12 0.08 97.75 13:23:28 12:58:01 0 2.09 0.00 0.20 0.00 0.08 97.62 13:23:28 12:58:01 1 1.76 0.00 0.20 0.44 0.08 97.52 13:23:28 12:58:01 2 1.99 0.00 0.22 0.03 0.07 97.70 13:23:28 12:58:01 3 1.65 0.00 0.12 0.00 0.07 98.17 13:23:28 12:59:02 all 0.91 0.00 0.11 0.33 0.07 98.58 13:23:28 12:59:02 0 0.92 0.00 0.10 0.00 0.05 98.93 13:23:28 12:59:02 1 0.84 0.00 0.17 1.14 0.10 97.75 13:23:28 12:59:02 2 1.06 0.00 0.12 0.20 0.07 98.56 13:23:28 12:59:02 3 0.84 0.00 0.05 0.00 0.05 99.06 13:23:28 13:00:01 all 2.56 0.00 0.18 0.03 0.08 97.15 13:23:28 13:00:01 0 2.64 0.00 0.26 0.00 0.09 97.02 13:23:28 13:00:01 1 2.25 0.00 0.17 0.10 0.09 97.39 13:23:28 13:00:01 2 2.54 0.00 0.10 0.02 0.09 97.26 13:23:28 13:00:01 3 2.80 0.00 0.20 0.00 0.07 96.93 13:23:28 13:01:01 all 1.03 0.00 0.16 0.01 0.07 98.72 13:23:28 13:01:01 0 1.05 0.00 0.22 0.00 0.08 98.65 13:23:28 13:01:01 1 0.97 0.00 0.18 0.03 0.05 98.76 13:23:28 13:01:01 2 1.05 0.00 0.15 0.00 0.07 98.73 13:23:28 13:01:01 3 1.06 0.00 0.10 0.02 0.07 98.76 13:23:28 13:02:01 all 3.00 0.00 0.28 0.04 0.08 96.61 13:23:28 13:02:01 0 3.07 0.00 0.25 0.02 0.07 96.59 13:23:28 13:02:01 1 3.30 0.00 0.32 0.10 0.08 96.20 13:23:28 13:02:01 2 2.63 0.00 0.32 0.02 0.07 96.97 13:23:28 13:02:01 3 3.02 0.00 0.22 0.02 0.08 96.67 13:23:28 13:03:01 all 41.20 0.00 1.52 0.27 0.10 56.91 13:23:28 13:03:01 0 38.51 0.00 2.02 0.17 0.08 59.23 13:23:28 13:03:01 1 38.99 0.00 1.17 0.32 0.10 59.41 13:23:28 13:03:01 2 42.33 0.00 1.56 0.35 0.10 55.66 13:23:28 13:03:01 3 44.97 0.00 1.32 0.25 0.10 53.35 13:23:28 13:04:01 all 20.80 0.00 0.61 0.89 0.10 77.61 13:23:28 13:04:01 0 20.97 0.00 0.53 1.83 0.10 76.57 13:23:28 13:04:01 1 20.29 0.00 0.55 0.00 0.10 79.06 13:23:28 13:04:01 2 20.41 0.00 0.63 0.47 0.08 78.41 13:23:28 13:04:01 3 21.53 0.00 0.70 1.27 0.10 76.40 13:23:28 13:05:01 all 3.86 0.00 0.28 0.03 0.09 95.74 13:23:28 13:05:01 0 3.71 0.00 0.35 0.05 0.08 95.80 13:23:28 13:05:01 1 4.08 0.00 0.23 0.00 0.07 95.61 13:23:28 13:05:01 2 3.73 0.00 0.30 0.03 0.10 95.84 13:23:28 13:05:01 3 3.93 0.00 0.25 0.02 0.10 95.71 13:23:28 13:06:01 all 0.48 0.00 0.18 0.01 0.07 99.25 13:23:28 13:06:01 0 0.48 0.00 0.20 0.02 0.07 99.23 13:23:28 13:06:01 1 0.33 0.00 0.08 0.00 0.03 99.55 13:23:28 13:06:01 2 0.62 0.00 0.29 0.00 0.10 98.99 13:23:28 13:06:01 3 0.50 0.00 0.17 0.03 0.08 99.21 13:23:28 13:07:01 all 0.65 0.00 0.22 0.01 0.07 99.05 13:23:28 13:07:01 0 0.37 0.00 0.08 0.03 0.07 99.45 13:23:28 13:07:01 1 0.37 0.00 0.15 0.00 0.02 99.47 13:23:28 13:07:01 2 1.43 0.00 0.48 0.00 0.10 97.99 13:23:28 13:07:01 3 0.44 0.00 0.15 0.02 0.08 99.31 13:23:28 13:08:01 all 1.09 0.00 0.27 0.01 0.07 98.56 13:23:28 13:08:01 0 0.78 0.00 0.28 0.02 0.07 98.85 13:23:28 13:08:01 1 0.38 0.00 0.20 0.00 0.05 99.37 13:23:28 13:08:01 2 2.30 0.00 0.18 0.00 0.10 97.42 13:23:28 13:08:01 3 0.87 0.00 0.40 0.03 0.08 98.61 13:23:28 13:23:28 13:08:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 13:09:01 all 0.61 0.00 0.22 0.01 0.07 99.09 13:23:28 13:09:01 0 0.23 0.00 0.17 0.03 0.03 99.53 13:23:28 13:09:01 1 0.65 0.00 0.33 0.00 0.08 98.93 13:23:28 13:09:01 2 1.21 0.00 0.15 0.02 0.07 98.56 13:23:28 13:09:01 3 0.33 0.00 0.23 0.00 0.10 99.33 13:23:28 13:10:01 all 0.38 0.00 0.18 0.01 0.07 99.37 13:23:28 13:10:01 0 0.25 0.00 0.07 0.02 0.05 99.62 13:23:28 13:10:01 1 0.22 0.00 0.12 0.00 0.08 99.58 13:23:28 13:10:01 2 0.25 0.00 0.08 0.00 0.05 99.61 13:23:28 13:10:01 3 0.78 0.00 0.43 0.02 0.08 98.68 13:23:28 13:11:01 all 7.23 0.00 0.53 0.02 0.08 92.13 13:23:28 13:11:01 0 7.51 0.00 0.55 0.03 0.07 91.84 13:23:28 13:11:01 1 6.87 0.00 0.67 0.03 0.08 92.35 13:23:28 13:11:01 2 7.75 0.00 0.33 0.00 0.08 91.83 13:23:28 13:11:01 3 6.79 0.00 0.57 0.02 0.10 92.53 13:23:28 13:12:01 all 50.15 0.00 1.49 0.28 0.10 47.98 13:23:28 13:12:01 0 50.61 0.00 1.40 0.90 0.12 46.97 13:23:28 13:12:01 1 50.38 0.00 1.44 0.00 0.08 48.10 13:23:28 13:12:01 2 47.88 0.00 1.63 0.20 0.10 50.18 13:23:28 13:12:01 3 51.74 0.00 1.49 0.02 0.08 46.68 13:23:28 13:13:01 all 3.41 0.00 0.30 0.02 0.09 96.19 13:23:28 13:13:01 0 3.25 0.00 0.28 0.00 0.07 96.40 13:23:28 13:13:01 1 3.20 0.00 0.28 0.00 0.10 96.42 13:23:28 13:13:01 2 4.05 0.00 0.38 0.03 0.10 95.43 13:23:28 13:13:01 3 3.13 0.00 0.25 0.03 0.08 96.51 13:23:28 13:14:01 all 2.67 0.00 0.27 0.02 0.08 96.97 13:23:28 13:14:01 0 2.85 0.00 0.30 0.02 0.08 96.75 13:23:28 13:14:01 1 2.48 0.00 0.20 0.00 0.05 97.27 13:23:28 13:14:01 2 2.55 0.00 0.33 0.03 0.08 97.00 13:23:28 13:14:01 3 2.81 0.00 0.25 0.02 0.08 96.84 13:23:28 13:15:01 all 2.00 0.00 0.25 0.01 0.09 97.64 13:23:28 13:15:01 0 1.82 0.00 0.22 0.00 0.08 97.87 13:23:28 13:15:01 1 1.82 0.00 0.20 0.00 0.08 97.90 13:23:28 13:15:01 2 2.57 0.00 0.35 0.02 0.08 96.98 13:23:28 13:15:01 3 1.80 0.00 0.25 0.03 0.10 97.81 13:23:28 13:16:01 all 1.99 0.00 0.29 0.01 0.08 97.63 13:23:28 13:16:01 0 1.90 0.00 0.30 0.00 0.07 97.73 13:23:28 13:16:01 1 1.85 0.00 0.27 0.02 0.08 97.78 13:23:28 13:16:01 2 2.20 0.00 0.33 0.02 0.10 97.35 13:23:28 13:16:01 3 2.00 0.00 0.25 0.02 0.08 97.65 13:23:28 13:17:01 all 4.07 0.00 0.30 0.02 0.08 95.53 13:23:28 13:17:01 0 4.24 0.00 0.25 0.00 0.07 95.44 13:23:28 13:17:01 1 3.64 0.00 0.33 0.00 0.08 95.95 13:23:28 13:17:01 2 4.53 0.00 0.30 0.00 0.08 95.09 13:23:28 13:17:01 3 3.87 0.00 0.33 0.07 0.08 95.65 13:23:28 13:18:01 all 3.27 0.00 0.29 0.01 0.09 96.35 13:23:28 13:18:01 0 2.49 0.00 0.32 0.02 0.10 97.08 13:23:28 13:18:01 1 3.04 0.00 0.47 0.00 0.10 96.39 13:23:28 13:18:01 2 4.52 0.00 0.08 0.00 0.07 95.33 13:23:28 13:18:01 3 3.01 0.00 0.28 0.02 0.08 96.61 13:23:28 13:19:01 all 56.36 0.00 1.59 0.32 0.08 41.64 13:23:28 13:19:01 0 57.07 0.00 2.16 0.97 0.08 39.72 13:23:28 13:19:01 1 59.62 0.00 1.44 0.02 0.07 38.86 13:23:28 13:19:01 2 53.69 0.00 1.20 0.00 0.08 45.03 13:23:28 13:19:01 3 55.08 0.00 1.58 0.30 0.10 42.94 13:23:28 13:23:28 13:19:01 CPU %user %nice %system %iowait %steal %idle 13:23:28 13:20:01 all 8.43 0.00 0.30 0.06 0.09 91.13 13:23:28 13:20:01 0 7.91 0.00 0.22 0.10 0.08 91.69 13:23:28 13:20:01 1 8.77 0.00 0.33 0.00 0.10 90.80 13:23:28 13:20:01 2 9.05 0.00 0.36 0.13 0.08 90.37 13:23:28 13:20:01 3 7.98 0.00 0.27 0.00 0.08 91.67 13:23:28 13:21:01 all 10.77 0.00 0.45 0.01 0.08 88.69 13:23:28 13:21:01 0 10.94 0.00 0.45 0.02 0.07 88.52 13:23:28 13:21:01 1 10.62 0.00 0.39 0.00 0.08 88.91 13:23:28 13:21:01 2 10.43 0.00 0.47 0.00 0.08 89.02 13:23:28 13:21:01 3 11.08 0.00 0.50 0.03 0.07 88.32 13:23:28 13:22:01 all 5.07 0.00 0.34 0.05 0.08 94.45 13:23:28 13:22:01 0 4.94 0.00 0.35 0.10 0.08 94.53 13:23:28 13:22:01 1 5.30 0.00 0.27 0.00 0.07 94.36 13:23:28 13:22:01 2 5.00 0.00 0.38 0.00 0.07 94.55 13:23:28 13:22:01 3 5.05 0.00 0.37 0.12 0.08 94.38 13:23:28 13:23:01 all 22.83 0.00 1.45 0.80 0.09 74.83 13:23:28 13:23:01 0 22.94 0.00 1.40 0.48 0.07 75.10 13:23:28 13:23:01 1 16.81 0.00 1.34 0.69 0.10 81.06 13:23:28 13:23:01 2 33.49 0.00 1.56 1.63 0.10 63.23 13:23:28 13:23:01 3 18.03 0.00 1.51 0.38 0.08 79.99 13:23:28 Average: all 18.65 0.11 0.92 0.50 0.09 79.73 13:23:28 Average: 0 18.73 0.11 0.94 0.46 0.09 79.68 13:23:28 Average: 1 18.57 0.13 0.95 0.60 0.09 79.66 13:23:28 Average: 2 18.97 0.08 0.89 0.42 0.09 79.55 13:23:28 Average: 3 18.35 0.11 0.89 0.50 0.09 80.05 13:23:28 13:23:28 13:23:28