07:50:10 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/114581 07:50:10 Running as SYSTEM 07:50:10 [EnvInject] - Loading node environment variables. 07:50:10 Building remotely on prd-ubuntu2004-docker-4c-16g-123 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 07:50:11 [ssh-agent] Looking for ssh-agent implementation... 07:50:11 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 07:50:11 $ ssh-agent 07:50:11 SSH_AUTH_SOCK=/tmp/ssh-APMvnjaqU0WQ/agent.11679 07:50:11 SSH_AGENT_PID=11682 07:50:11 [ssh-agent] Started. 07:50:11 Running ssh-add (command line suppressed) 07:50:11 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4620802924338157357.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4620802924338157357.key) 07:50:11 [ssh-agent] Using credentials jenkins (jenkins-ssh) 07:50:11 The recommended git tool is: NONE 07:50:13 using credential jenkins-ssh 07:50:13 Wiping out workspace first. 07:50:13 Cloning the remote Git repository 07:50:13 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 07:50:13 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 07:50:13 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 07:50:13 > git --version # timeout=10 07:50:13 > git --version # 'git version 2.25.1' 07:50:13 using GIT_SSH to set credentials jenkins-ssh 07:50:13 Verifying host key using known hosts file 07:50:14 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. 07:50:14 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 07:50:19 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 07:50:19 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 07:50:19 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 07:50:19 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 07:50:19 using GIT_SSH to set credentials jenkins-ssh 07:50:19 Verifying host key using known hosts file 07:50:19 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. 07:50:19 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/81/114581/6 # timeout=10 07:50:19 > git rev-parse 7c7362e65d82b2931c1293e212655e57116e2b41^{commit} # timeout=10 07:50:19 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 07:50:19 Checking out Revision 7c7362e65d82b2931c1293e212655e57116e2b41 (refs/changes/81/114581/6) 07:50:19 > git config core.sparsecheckout # timeout=10 07:50:19 > git checkout -f 7c7362e65d82b2931c1293e212655e57116e2b41 # timeout=10 07:50:20 Commit message: "Enhancements for discovering OpenConfig XPDRs" 07:50:20 > git rev-parse FETCH_HEAD^{commit} # timeout=10 07:50:20 > git rev-list --no-walk 14a38aa83db06d38e73ac00c316ac3db70ebc64f # timeout=10 07:50:20 > git remote # timeout=10 07:50:20 > git submodule init # timeout=10 07:50:20 > git submodule sync # timeout=10 07:50:20 > git config --get remote.origin.url # timeout=10 07:50:20 > git submodule init # timeout=10 07:50:20 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 07:50:20 ERROR: No submodules found. 07:50:23 provisioning config files... 07:50:23 copy managed file [npmrc] to file:/home/jenkins/.npmrc 07:50:23 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 07:50:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6371995663621781844.sh 07:50:23 ---> python-tools-install.sh 07:50:23 Setup pyenv: 07:50:23 * system (set by /opt/pyenv/version) 07:50:23 * 3.8.20 (set by /opt/pyenv/version) 07:50:23 * 3.9.20 (set by /opt/pyenv/version) 07:50:23 * 3.10.15 (set by /opt/pyenv/version) 07:50:23 * 3.11.10 (set by /opt/pyenv/version) 07:50:28 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-mp7M 07:50:28 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 07:50:31 lf-activate-venv(): INFO: Installing: lftools 07:50:59 lf-activate-venv(): INFO: Adding /tmp/venv-mp7M/bin to PATH 07:50:59 Generating Requirements File 07:51:20 Python 3.11.10 07:51:21 pip 24.3.1 from /tmp/venv-mp7M/lib/python3.11/site-packages/pip (python 3.11) 07:51:21 appdirs==1.4.4 07:51:21 argcomplete==3.5.1 07:51:21 aspy.yaml==1.3.0 07:51:21 attrs==24.2.0 07:51:21 autopage==0.5.2 07:51:21 beautifulsoup4==4.12.3 07:51:21 boto3==1.35.76 07:51:21 botocore==1.35.76 07:51:21 bs4==0.0.2 07:51:21 cachetools==5.5.0 07:51:21 certifi==2024.8.30 07:51:21 cffi==1.17.1 07:51:21 cfgv==3.4.0 07:51:21 chardet==5.2.0 07:51:21 charset-normalizer==3.4.0 07:51:21 click==8.1.7 07:51:21 cliff==4.8.0 07:51:21 cmd2==2.5.7 07:51:21 cryptography==3.3.2 07:51:21 debtcollector==3.0.0 07:51:21 decorator==5.1.1 07:51:21 defusedxml==0.7.1 07:51:21 Deprecated==1.2.15 07:51:21 distlib==0.3.9 07:51:21 dnspython==2.7.0 07:51:21 docker==4.2.2 07:51:21 dogpile.cache==1.3.3 07:51:21 durationpy==0.9 07:51:21 email_validator==2.2.0 07:51:21 filelock==3.16.1 07:51:21 future==1.0.0 07:51:21 gitdb==4.0.11 07:51:21 GitPython==3.1.43 07:51:21 google-auth==2.36.0 07:51:21 httplib2==0.22.0 07:51:21 identify==2.6.3 07:51:21 idna==3.10 07:51:21 importlib-resources==1.5.0 07:51:21 iso8601==2.1.0 07:51:21 Jinja2==3.1.4 07:51:21 jmespath==1.0.1 07:51:21 jsonpatch==1.33 07:51:21 jsonpointer==3.0.0 07:51:21 jsonschema==4.23.0 07:51:21 jsonschema-specifications==2024.10.1 07:51:21 keystoneauth1==5.9.1 07:51:21 kubernetes==31.0.0 07:51:21 lftools==0.37.10 07:51:21 lxml==5.3.0 07:51:21 MarkupSafe==3.0.2 07:51:21 msgpack==1.1.0 07:51:21 multi_key_dict==2.0.3 07:51:21 munch==4.0.0 07:51:21 netaddr==1.3.0 07:51:21 netifaces==0.11.0 07:51:21 niet==1.4.2 07:51:21 nodeenv==1.9.1 07:51:21 oauth2client==4.1.3 07:51:21 oauthlib==3.2.2 07:51:21 openstacksdk==4.1.0 07:51:21 os-client-config==2.1.0 07:51:21 os-service-types==1.7.0 07:51:21 osc-lib==3.2.0 07:51:21 oslo.config==9.7.0 07:51:21 oslo.context==5.7.0 07:51:21 oslo.i18n==6.5.0 07:51:21 oslo.log==6.2.0 07:51:21 oslo.serialization==5.6.0 07:51:21 oslo.utils==8.0.0 07:51:21 packaging==24.2 07:51:21 pbr==6.1.0 07:51:21 platformdirs==4.3.6 07:51:21 prettytable==3.12.0 07:51:21 psutil==6.1.0 07:51:21 pyasn1==0.6.1 07:51:21 pyasn1_modules==0.4.1 07:51:21 pycparser==2.22 07:51:21 pygerrit2==2.0.15 07:51:21 PyGithub==2.5.0 07:51:21 PyJWT==2.10.1 07:51:21 PyNaCl==1.5.0 07:51:21 pyparsing==2.4.7 07:51:21 pyperclip==1.9.0 07:51:21 pyrsistent==0.20.0 07:51:21 python-cinderclient==9.6.0 07:51:21 python-dateutil==2.9.0.post0 07:51:21 python-heatclient==4.0.0 07:51:21 python-jenkins==1.8.2 07:51:21 python-keystoneclient==5.5.0 07:51:21 python-magnumclient==4.7.0 07:51:21 python-openstackclient==7.2.1 07:51:21 python-swiftclient==4.6.0 07:51:21 PyYAML==6.0.2 07:51:21 referencing==0.35.1 07:51:21 requests==2.32.3 07:51:21 requests-oauthlib==2.0.0 07:51:21 requestsexceptions==1.4.0 07:51:21 rfc3986==2.0.0 07:51:21 rpds-py==0.22.3 07:51:21 rsa==4.9 07:51:21 ruamel.yaml==0.18.6 07:51:21 ruamel.yaml.clib==0.2.12 07:51:21 s3transfer==0.10.4 07:51:21 simplejson==3.19.3 07:51:21 six==1.17.0 07:51:21 smmap==5.0.1 07:51:21 soupsieve==2.6 07:51:21 stevedore==5.4.0 07:51:21 tabulate==0.9.0 07:51:21 toml==0.10.2 07:51:21 tomlkit==0.13.2 07:51:21 tqdm==4.67.1 07:51:21 typing_extensions==4.12.2 07:51:21 tzdata==2024.2 07:51:21 urllib3==1.26.20 07:51:21 virtualenv==20.28.0 07:51:21 wcwidth==0.2.13 07:51:21 websocket-client==1.8.0 07:51:21 wrapt==1.17.0 07:51:21 xdg==6.0.0 07:51:21 xmltodict==0.14.2 07:51:21 yq==3.4.3 07:51:21 [EnvInject] - Injecting environment variables from a build step. 07:51:21 [EnvInject] - Injecting as environment variables the properties content 07:51:21 PYTHON=python3 07:51:21 07:51:21 [EnvInject] - Variables injected successfully. 07:51:21 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins1788850812044538337.sh 07:51:21 ---> tox-install.sh 07:51:21 + source /home/jenkins/lf-env.sh 07:51:21 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 07:51:21 ++ mktemp -d /tmp/venv-XXXX 07:51:21 + lf_venv=/tmp/venv-3vEj 07:51:21 + local venv_file=/tmp/.os_lf_venv 07:51:21 + local python=python3 07:51:21 + local options 07:51:21 + local set_path=true 07:51:21 + local install_args= 07:51:21 ++ 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 07:51:21 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:51:21 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:51:21 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 07:51:21 + true 07:51:21 + case $1 in 07:51:21 + venv_file=/tmp/.toxenv 07:51:21 + shift 2 07:51:21 + true 07:51:21 + case $1 in 07:51:21 + shift 07:51:21 + break 07:51:21 + case $python in 07:51:21 + local pkg_list= 07:51:21 + [[ -d /opt/pyenv ]] 07:51:21 + echo 'Setup pyenv:' 07:51:21 Setup pyenv: 07:51:21 + export PYENV_ROOT=/opt/pyenv 07:51:21 + PYENV_ROOT=/opt/pyenv 07:51:21 + 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 07:51:21 + 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 07:51:21 + pyenv versions 07:51:21 system 07:51:21 3.8.20 07:51:21 3.9.20 07:51:21 3.10.15 07:51:21 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:51:21 + command -v pyenv 07:51:21 ++ pyenv init - --no-rehash 07:51:21 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 07:51:21 for i in ${!paths[@]}; do 07:51:21 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 07:51:21 fi; done; 07:51:21 echo "${paths[*]}"'\'')" 07:51:21 export PATH="/opt/pyenv/shims:${PATH}" 07:51:21 export PYENV_SHELL=bash 07:51:21 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 07:51:21 pyenv() { 07:51:21 local command 07:51:21 command="${1:-}" 07:51:21 if [ "$#" -gt 0 ]; then 07:51:21 shift 07:51:21 fi 07:51:21 07:51:21 case "$command" in 07:51:21 rehash|shell) 07:51:21 eval "$(pyenv "sh-$command" "$@")" 07:51:21 ;; 07:51:21 *) 07:51:21 command pyenv "$command" "$@" 07:51:21 ;; 07:51:21 esac 07:51:21 }' 07:51:21 +++ bash --norc -ec 'IFS=:; paths=($PATH); 07:51:21 for i in ${!paths[@]}; do 07:51:21 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 07:51:21 fi; done; 07:51:21 echo "${paths[*]}"' 07:51:21 ++ 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 07:51:21 ++ 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 07:51:21 ++ 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 07:51:21 ++ export PYENV_SHELL=bash 07:51:21 ++ PYENV_SHELL=bash 07:51:21 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 07:51:21 +++ complete -F _pyenv pyenv 07:51:21 ++ lf-pyver python3 07:51:21 ++ local py_version_xy=python3 07:51:21 ++ local py_version_xyz= 07:51:21 ++ pyenv versions 07:51:21 ++ local command 07:51:21 ++ command=versions 07:51:21 ++ '[' 1 -gt 0 ']' 07:51:21 ++ shift 07:51:21 ++ case "$command" in 07:51:21 ++ command pyenv versions 07:51:21 ++ pyenv versions 07:51:21 ++ sed 's/^[ *]* //' 07:51:21 ++ grep -E '^[0-9.]*[0-9]$' 07:51:21 ++ awk '{ print $1 }' 07:51:21 ++ [[ ! -s /tmp/.pyenv_versions ]] 07:51:21 +++ grep '^3' /tmp/.pyenv_versions 07:51:21 +++ sort -V 07:51:21 +++ tail -n 1 07:51:21 ++ py_version_xyz=3.11.10 07:51:21 ++ [[ -z 3.11.10 ]] 07:51:21 ++ echo 3.11.10 07:51:21 ++ return 0 07:51:21 + pyenv local 3.11.10 07:51:21 + local command 07:51:21 + command=local 07:51:21 + '[' 2 -gt 0 ']' 07:51:21 + shift 07:51:21 + case "$command" in 07:51:21 + command pyenv local 3.11.10 07:51:21 + pyenv local 3.11.10 07:51:21 + for arg in "$@" 07:51:21 + case $arg in 07:51:21 + pkg_list+='tox ' 07:51:21 + for arg in "$@" 07:51:21 + case $arg in 07:51:21 + pkg_list+='virtualenv ' 07:51:21 + for arg in "$@" 07:51:21 + case $arg in 07:51:21 + pkg_list+='urllib3~=1.26.15 ' 07:51:21 + [[ -f /tmp/.toxenv ]] 07:51:21 + [[ ! -f /tmp/.toxenv ]] 07:51:21 + [[ -n '' ]] 07:51:21 + python3 -m venv /tmp/venv-3vEj 07:51:25 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-3vEj' 07:51:25 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-3vEj 07:51:25 + echo /tmp/venv-3vEj 07:51:25 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 07:51:25 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 07:51:25 + /tmp/venv-3vEj/bin/python3 -m pip install --upgrade --quiet pip virtualenv 07:51:29 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 07:51:29 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 07:51:29 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 07:51:29 + /tmp/venv-3vEj/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 07:51:31 + type python3 07:51:31 + true 07:51:31 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-3vEj/bin to PATH' 07:51:31 lf-activate-venv(): INFO: Adding /tmp/venv-3vEj/bin to PATH 07:51:31 + PATH=/tmp/venv-3vEj/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 07:51:31 + return 0 07:51:31 + python3 --version 07:51:31 Python 3.11.10 07:51:31 + python3 -m pip --version 07:51:31 pip 24.3.1 from /tmp/venv-3vEj/lib/python3.11/site-packages/pip (python 3.11) 07:51:31 + python3 -m pip freeze 07:51:31 cachetools==5.5.0 07:51:31 chardet==5.2.0 07:51:31 colorama==0.4.6 07:51:31 distlib==0.3.9 07:51:31 filelock==3.16.1 07:51:31 packaging==24.2 07:51:31 platformdirs==4.3.6 07:51:31 pluggy==1.5.0 07:51:31 pyproject-api==1.8.0 07:51:31 tox==4.23.2 07:51:31 urllib3==1.26.20 07:51:31 virtualenv==20.28.0 07:51:31 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins134355494683237030.sh 07:51:31 [EnvInject] - Injecting environment variables from a build step. 07:51:31 [EnvInject] - Injecting as environment variables the properties content 07:51:31 PARALLEL=True 07:51:31 07:51:31 [EnvInject] - Variables injected successfully. 07:51:31 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins16420149743063527940.sh 07:51:31 ---> tox-run.sh 07:51:31 + 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 07:51:31 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 07:51:31 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 07:51:31 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 07:51:31 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 07:51:31 + source /home/jenkins/lf-env.sh 07:51:31 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 07:51:31 ++ mktemp -d /tmp/venv-XXXX 07:51:31 + lf_venv=/tmp/venv-w2Q1 07:51:31 + local venv_file=/tmp/.os_lf_venv 07:51:31 + local python=python3 07:51:31 + local options 07:51:31 + local set_path=true 07:51:31 + local install_args= 07:51:31 ++ 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 07:51:31 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:51:31 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:51:31 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 07:51:31 + true 07:51:31 + case $1 in 07:51:31 + venv_file=/tmp/.toxenv 07:51:31 + shift 2 07:51:31 + true 07:51:31 + case $1 in 07:51:31 + shift 07:51:31 + break 07:51:31 + case $python in 07:51:31 + local pkg_list= 07:51:31 + [[ -d /opt/pyenv ]] 07:51:31 + echo 'Setup pyenv:' 07:51:31 Setup pyenv: 07:51:31 + export PYENV_ROOT=/opt/pyenv 07:51:31 + PYENV_ROOT=/opt/pyenv 07:51:31 + 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 07:51:31 + 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 07:51:31 + pyenv versions 07:51:31 system 07:51:31 3.8.20 07:51:31 3.9.20 07:51:31 3.10.15 07:51:31 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:51:31 + command -v pyenv 07:51:31 ++ pyenv init - --no-rehash 07:51:31 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 07:51:31 for i in ${!paths[@]}; do 07:51:31 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 07:51:31 fi; done; 07:51:31 echo "${paths[*]}"'\'')" 07:51:31 export PATH="/opt/pyenv/shims:${PATH}" 07:51:31 export PYENV_SHELL=bash 07:51:31 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 07:51:31 pyenv() { 07:51:31 local command 07:51:31 command="${1:-}" 07:51:31 if [ "$#" -gt 0 ]; then 07:51:31 shift 07:51:31 fi 07:51:31 07:51:31 case "$command" in 07:51:31 rehash|shell) 07:51:31 eval "$(pyenv "sh-$command" "$@")" 07:51:31 ;; 07:51:31 *) 07:51:31 command pyenv "$command" "$@" 07:51:31 ;; 07:51:31 esac 07:51:31 }' 07:51:31 +++ bash --norc -ec 'IFS=:; paths=($PATH); 07:51:31 for i in ${!paths[@]}; do 07:51:31 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 07:51:31 fi; done; 07:51:31 echo "${paths[*]}"' 07:51:31 ++ 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 07:51:31 ++ 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 07:51:31 ++ 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 07:51:31 ++ export PYENV_SHELL=bash 07:51:31 ++ PYENV_SHELL=bash 07:51:31 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 07:51:31 +++ complete -F _pyenv pyenv 07:51:31 ++ lf-pyver python3 07:51:31 ++ local py_version_xy=python3 07:51:31 ++ local py_version_xyz= 07:51:31 ++ pyenv versions 07:51:31 ++ local command 07:51:31 ++ command=versions 07:51:31 ++ '[' 1 -gt 0 ']' 07:51:31 ++ shift 07:51:31 ++ case "$command" in 07:51:31 ++ command pyenv versions 07:51:31 ++ pyenv versions 07:51:31 ++ awk '{ print $1 }' 07:51:31 ++ grep -E '^[0-9.]*[0-9]$' 07:51:31 ++ sed 's/^[ *]* //' 07:51:31 ++ [[ ! -s /tmp/.pyenv_versions ]] 07:51:31 +++ grep '^3' /tmp/.pyenv_versions 07:51:31 +++ sort -V 07:51:31 +++ tail -n 1 07:51:31 ++ py_version_xyz=3.11.10 07:51:31 ++ [[ -z 3.11.10 ]] 07:51:31 ++ echo 3.11.10 07:51:31 ++ return 0 07:51:31 + pyenv local 3.11.10 07:51:31 + local command 07:51:31 + command=local 07:51:31 + '[' 2 -gt 0 ']' 07:51:31 + shift 07:51:31 + case "$command" in 07:51:31 + command pyenv local 3.11.10 07:51:31 + pyenv local 3.11.10 07:51:31 + for arg in "$@" 07:51:31 + case $arg in 07:51:31 + pkg_list+='tox ' 07:51:31 + for arg in "$@" 07:51:31 + case $arg in 07:51:31 + pkg_list+='virtualenv ' 07:51:31 + for arg in "$@" 07:51:31 + case $arg in 07:51:31 + pkg_list+='urllib3~=1.26.15 ' 07:51:31 + [[ -f /tmp/.toxenv ]] 07:51:31 ++ cat /tmp/.toxenv 07:51:31 + lf_venv=/tmp/venv-3vEj 07:51:31 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3vEj from' file:/tmp/.toxenv 07:51:31 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3vEj from file:/tmp/.toxenv 07:51:31 + /tmp/venv-3vEj/bin/python3 -m pip install --upgrade --quiet pip virtualenv 07:51:32 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 07:51:32 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 07:51:32 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 07:51:32 + /tmp/venv-3vEj/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 07:51:33 + type python3 07:51:33 + true 07:51:33 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-3vEj/bin to PATH' 07:51:33 lf-activate-venv(): INFO: Adding /tmp/venv-3vEj/bin to PATH 07:51:33 + PATH=/tmp/venv-3vEj/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 07:51:33 + return 0 07:51:33 + [[ -d /opt/pyenv ]] 07:51:33 + echo '---> Setting up pyenv' 07:51:33 ---> Setting up pyenv 07:51:33 + export PYENV_ROOT=/opt/pyenv 07:51:33 + PYENV_ROOT=/opt/pyenv 07:51:33 + export PATH=/opt/pyenv/bin:/tmp/venv-3vEj/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 07:51:33 + PATH=/opt/pyenv/bin:/tmp/venv-3vEj/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 07:51:33 ++ pwd 07:51:33 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 07:51:33 + export PYTHONPATH 07:51:33 + export TOX_TESTENV_PASSENV=PYTHONPATH 07:51:33 + TOX_TESTENV_PASSENV=PYTHONPATH 07:51:33 + tox --version 07:51:33 4.23.2 from /tmp/venv-3vEj/lib/python3.11/site-packages/tox/__init__.py 07:51:33 + PARALLEL=True 07:51:33 + TOX_OPTIONS_LIST= 07:51:33 + [[ -n '' ]] 07:51:33 + case ${PARALLEL,,} in 07:51:33 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 07:51:33 + tox --parallel auto --parallel-live 07:51:33 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 07:51:35 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 07:51:35 checkbashisms: freeze> python -m pip freeze --all 07:51:35 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 07:51:35 docs: install_deps> python -I -m pip install -r docs/requirements.txt 07:51:35 checkbashisms: pip==24.3.1,setuptools==75.6.0,wheel==0.45.1 07:51:35 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 07:51:35 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)' 07:51:36 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 07:51:36 script ./reflectwarn.sh does not appear to have a #! interpreter line; 07:51:36 you may get strange results 07:51:37 checkbashisms: OK ✔ in 2.74 seconds 07:51:37 pre-commit: install_deps> python -I -m pip install pre-commit 07:51:39 pre-commit: freeze> python -m pip freeze --all 07:51:39 pre-commit: cfgv==3.4.0,distlib==0.3.9,filelock==3.16.1,identify==2.6.3,nodeenv==1.9.1,pip==24.3.1,platformdirs==4.3.6,pre_commit==4.0.1,PyYAML==6.0.2,setuptools==75.6.0,virtualenv==20.28.0,wheel==0.45.1 07:51:39 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 07:51:39 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)' 07:51:39 /usr/bin/cpan 07:51:39 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 07:51:40 [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. 07:51:40 [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. 07:51:40 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 07:51:40 [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. 07:51:40 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 07:51:40 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 07:51:41 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 07:51:41 buildcontroller: freeze> python -m pip freeze --all 07:51:41 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 07:51:41 buildcontroller: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:51:41 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 07:51:41 + update-java-alternatives -l 07:51:41 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 07:51:41 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 07:51:41 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 07:51:41 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 07:51:41 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 07:51:41 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 07:51:41 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 07:51:41 + + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 07:51:41 java -version 07:51:42 21 07:51:42 + JAVA_VER=21 07:51:42 + echo 21 07:51:42 + javac -version 07:51:42 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 07:51:42 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 07:51:42 [INFO] Once installed this environment will be reused. 07:51:42 [INFO] This may take a few minutes... 07:51:42 + JAVAC_VER=21 07:51:42 + echo 21 07:51:42 + [ 21 -ge 21 ] 07:51:42 + [ 21 -ge 21 ] 07:51:42 + echo ok, java is 21 or newer 07:51:42 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp 07:51:42 21 07:51:42 ok, java is 21 or newer 07:51:43 2024-12-05 07:51:43 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] 07:51:43 + sudo mkdir -p /opt 07:51:43 + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt 07:51:43 + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven 07:51:44 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 07:51:44 + mvn --version 07:51:44 Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) 07:51:44 Maven home: /opt/maven 07:51:44 Java version: 21.0.5, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 07:51:44 Default locale: en, platform encoding: UTF-8 07:51:44 OS name: "linux", version: "5.4.0-200-generic", arch: "amd64", family: "unix" 07:51:44 NOTE: Picked up JDK_JAVA_OPTIONS: 07:51:44 --add-opens=java.base/java.io=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.lang=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.net=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.nio=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.util=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:51:44 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:51:44 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:51:44 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:51:44 -Xlog:disable 07:51:46 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 07:51:46 [INFO] Once installed this environment will be reused. 07:51:46 [INFO] This may take a few minutes... 07:51:53 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 07:51:53 [INFO] Once installed this environment will be reused. 07:51:53 [INFO] This may take a few minutes... 07:51:56 [INFO] Installing environment for https://github.com/perltidy/perltidy. 07:51:56 [INFO] Once installed this environment will be reused. 07:51:56 [INFO] This may take a few minutes... 07:52:05 docs-linkcheck: freeze> python -m pip freeze --all 07:52:05 docs: freeze> python -m pip freeze --all 07:52:05 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.1,cycler==0.12.1,docutils==0.21.2,fonttools==4.55.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.3,numpy==2.1.3,nwdiag==3.0.0,packaging==24.2,pillow==11.0.0,pip==24.3.1,Pygments==2.18.0,pyparsing==3.2.0,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.6.0,six==1.17.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.2,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.11.1,wheel==0.45.1 07:52:05 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 07:52:05 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.1,cycler==0.12.1,docutils==0.21.2,fonttools==4.55.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.3,numpy==2.1.3,nwdiag==3.0.0,packaging==24.2,pillow==11.0.0,pip==24.3.1,Pygments==2.18.0,pyparsing==3.2.0,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.6.0,six==1.17.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.2,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.11.1,wheel==0.45.1 07:52:05 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 07:52:08 docs: OK ✔ in 33.89 seconds 07:52:08 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 07:52:09 trim trailing whitespace.................................................Passed 07:52:09 Tabs remover.............................................................Passed 07:52:09 autopep8................................................................./w/workspace/transportpce-tox-verify-transportpce-master/docs/tox-guide.rst:196: WARNING: broken link: https://lighty.io/ (HTTPSConnectionPool(host='lighty.io', port=443): Max retries exceeded with url: / (Caused by SSLError(SSLCertVerificationError(1, "[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: Hostname mismatch, certificate is not valid for 'lighty.io'. (_ssl.c:1006)")))) 07:52:10 docs-linkcheck: exit 1 (4.96 seconds) /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 pid=29848 07:52:13 docs-linkcheck: FAIL ✖ in 36.39 seconds 07:52:13 pylint: freeze> python -m pip freeze --all 07:52:14 pylint: astroid==3.3.5,dill==0.3.9,isort==5.13.2,mccabe==0.7.0,pip==24.3.1,platformdirs==4.3.6,pylint==3.3.2,setuptools==75.6.0,tomlkit==0.13.2,wheel==0.45.1 07:52:14 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}$' '{}' + 07:52:14 Failed 07:52:14 - hook id: autopep8 07:52:14 - files were modified by this hook 07:52:14 perltidy.................................................................Passed 07:52:15 pre-commit hook(s) made changes. 07:52:15 If you are seeing this message in CI, reproduce locally with: `pre-commit run --all-files`. 07:52:15 To run `pre-commit` as part of git workflow, use `pre-commit install`. 07:52:15 All changes made by hooks: 07:52:15 diff --git a/tests/transportpce_tests/common/test_utils.py b/tests/transportpce_tests/common/test_utils.py 07:52:15 index 77b28d03..34a26e28 100644 07:52:15 --- a/tests/transportpce_tests/common/test_utils.py 07:52:15 +++ b/tests/transportpce_tests/common/test_utils.py 07:52:15 @@ -179,7 +179,7 @@ def start_lightynode(log_file: str, sim): 07:52:15 version = 'OC' if sim[1] == 'oc' else sim[1] 07:52:15 return subprocess.Popen( 07:52:15 [executable, "-v" + version, "-p" + SIMS[sim]['port'], "-f" + os.path.join(sample_directory, 07:52:15 - SIMS[sim]['configfile'])], 07:52:15 + SIMS[sim]['configfile'])], 07:52:15 stdout=outfile, stderr=outfile) 07:52:15 return None 07:52:15 07:52:15 pre-commit: exit 1 (35.39 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure pid=29135 07:52:34 07:52:34 ------------------------------------ 07:52:34 Your code has been rated at 10.00/10 07:52:34 07:53:29 pre-commit: FAIL ✖ in 38.25 seconds 07:53:29 pylint: OK ✔ in 29.45 seconds 07:53:29 buildcontroller: OK ✔ in 1 minute 54.56 seconds 07:53:29 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 07:53:29 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 07:53:29 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 07:53:29 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 07:53:35 sims: freeze> python -m pip freeze --all 07:53:35 build_karaf_tests221: freeze> python -m pip freeze --all 07:53:35 build_karaf_tests121: freeze> python -m pip freeze --all 07:53:35 sims: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:53:35 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 07:53:35 Using lighynode version 20.1.0.2 07:53:35 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 07:53:35 build_karaf_tests221: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:53:35 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:53:35 NOTE: Picked up JDK_JAVA_OPTIONS: 07:53:35 --add-opens=java.base/java.io=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.net=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:53:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:53:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:53:35 -Xlog:disable 07:53:35 build_karaf_tests121: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:53:35 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:53:35 NOTE: Picked up JDK_JAVA_OPTIONS: 07:53:35 --add-opens=java.base/java.io=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.net=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:53:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:53:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:53:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:53:35 -Xlog:disable 07:53:40 sims: OK ✔ in 11.48 seconds 07:53:40 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 07:54:01 build_karaf_tests71: freeze> python -m pip freeze --all 07:54:02 build_karaf_tests71: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:54:02 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:54:02 NOTE: Picked up JDK_JAVA_OPTIONS: 07:54:02 --add-opens=java.base/java.io=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.lang=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.net=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.nio=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.util=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:54:02 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:54:02 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:54:02 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:54:02 -Xlog:disable 07:54:36 build_karaf_tests121: OK ✔ in 1 minute 7.21 seconds 07:54:36 build_karaf_tests190: 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 07:54:36 build_karaf_tests221: OK ✔ in 1 minute 7.63 seconds 07:54:36 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 07:54:54 build_karaf_tests71: OK ✔ in 1 minute 5.65 seconds 07:54:54 build_karaf_tests190: freeze> python -m pip freeze --all 07:54:54 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 07:54:54 build_karaf_tests_hybrid: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:54:54 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:54:54 NOTE: Picked up JDK_JAVA_OPTIONS: 07:54:54 --add-opens=java.base/java.io=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.net=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:54:54 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:54:54 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:54:54 -Xlog:disable 07:54:54 build_karaf_tests190: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:54:54 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:54:54 NOTE: Picked up JDK_JAVA_OPTIONS: 07:54:54 --add-opens=java.base/java.io=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.net=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:54:54 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:54:54 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:54:54 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:54:54 -Xlog:disable 07:55:11 testsPCE: freeze> python -m pip freeze --all 07:55:12 testsPCE: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,click==8.1.7,contourpy==1.3.1,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.6,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.55.1,gnpy4tpce==2.4.7,idna==3.10,iniconfig==2.0.0,injector==0.22.0,itsdangerous==2.2.0,Jinja2==3.1.4,kiwisolver==1.4.7,lxml==5.3.0,MarkupSafe==3.0.2,matplotlib==3.9.3,netconf-client==3.1.2,networkx==2.8.8,numpy==1.26.4,packaging==24.2,pandas==1.5.3,paramiko==3.5.0,pbr==5.11.1,pillow==11.0.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pyparsing==3.2.0,pytest==8.3.4,python-dateutil==2.9.0.post0,pytz==2024.2,requests==2.32.3,scipy==1.14.1,setuptools==50.3.2,six==1.17.0,urllib3==2.2.3,Werkzeug==2.0.3,wheel==0.45.1,xlrd==1.2.0 07:55:12 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 07:55:12 pytest -q transportpce_tests/pce/test01_pce.py 07:55:49 build_karaf_tests_hybrid: OK ✔ in 1 minute 10.26 seconds 07:55:49 build_karaf_tests190: OK ✔ in 1 minute 12.5 seconds 07:55:49 tests190: 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 07:55:56 tests190: freeze> python -m pip freeze --all 07:55:56 tests190: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:55:56 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 07:55:56 using environment variables from ./karafoc.env 07:55:56 pytest -q transportpce_tests/oc/test01_portmapping.py 07:56:02 ..........FF.......... [100%] 07:57:06 20 passed in 114.42s (0:01:54) 07:57:06 pytest -q transportpce_tests/pce/test02_pce_400G.py 07:57:25 ......... [100%] 07:57:47 9 passed in 40.69s 07:57:47 pytest -q transportpce_tests/pce/test03_gnpy.py 07:58:05 ........ [100%] 07:58:26 8 passed in 38.96s 07:58:27 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 07:59:00 ... [100%] 07:59:05 3 passed in 38.11s 07:59:05 testsPCE: OK ✔ in 5 minutes 36.65 seconds 07:59:05 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 07:59:11 tests_tapi: freeze> python -m pip freeze --all 07:59:11 tests_tapi: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 07:59:11 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 07:59:11 using environment variables from ./karaf221.env 07:59:11 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 07:59:27 FFFFFFFFE [100%] 07:59:37 ==================================== ERRORS ==================================== 07:59:37 _ ERROR at teardown of TransportpceOCPortMappingTesting.test_10_xpdr_device_disconnection _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 > sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:199: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 07:59:37 raise err 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 address = ('localhost', 8182), timeout = 10, source_address = None 07:59:37 socket_options = [(6, 1, 1)] 07:59:37 07:59:37 def create_connection( 07:59:37 address: tuple[str, int], 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 source_address: tuple[str, int] | None = None, 07:59:37 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 07:59:37 ) -> socket.socket: 07:59:37 """Connect to *address* and return the socket object. 07:59:37 07:59:37 Convenience function. Connect to *address* (a 2-tuple ``(host, 07:59:37 port)``) and return the socket object. Passing the optional 07:59:37 *timeout* parameter will set the timeout on the socket instance 07:59:37 before attempting to connect. If no *timeout* is supplied, the 07:59:37 global default timeout setting returned by :func:`socket.getdefaulttimeout` 07:59:37 is used. If *source_address* is set it must be a tuple of (host, port) 07:59:37 for the socket to bind as a source address before making the connection. 07:59:37 An host of '' or port 0 tells the OS to use the default. 07:59:37 """ 07:59:37 07:59:37 host, port = address 07:59:37 if host.startswith("["): 07:59:37 host = host.strip("[]") 07:59:37 err = None 07:59:37 07:59:37 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 07:59:37 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 07:59:37 # The original create_connection function always returns all records. 07:59:37 family = allowed_gai_family() 07:59:37 07:59:37 try: 07:59:37 host.encode("idna") 07:59:37 except UnicodeError: 07:59:37 raise LocationParseError(f"'{host}', label empty or too long") from None 07:59:37 07:59:37 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 07:59:37 af, socktype, proto, canonname, sa = res 07:59:37 sock = None 07:59:37 try: 07:59:37 sock = socket.socket(af, socktype, proto) 07:59:37 07:59:37 # If provided, set socket level options before connecting. 07:59:37 _set_socket_options(sock, socket_options) 07:59:37 07:59:37 if timeout is not _DEFAULT_TIMEOUT: 07:59:37 sock.settimeout(timeout) 07:59:37 if source_address: 07:59:37 sock.bind(source_address) 07:59:37 > sock.connect(sa) 07:59:37 E ConnectionRefusedError: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 method = 'DELETE' 07:59:37 url = '/rests/data/open-terminal-meta-data:open-terminal-meta-data', body = None 07:59:37 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='} 07:59:37 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 redirect = False, assert_same_host = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 07:59:37 release_conn = False, chunked = False, body_pos = None, preload_content = False 07:59:37 decode_content = False, response_kw = {} 07:59:37 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/open-terminal-meta-data:open-terminal-meta-data', query=None, fragment=None) 07:59:37 destination_scheme = None, conn = None, release_this_conn = True 07:59:37 http_tunnel_required = False, err = None, clean_exit = False 07:59:37 07:59:37 def urlopen( # type: ignore[override] 07:59:37 self, 07:59:37 method: str, 07:59:37 url: str, 07:59:37 body: _TYPE_BODY | None = None, 07:59:37 headers: typing.Mapping[str, str] | None = None, 07:59:37 retries: Retry | bool | int | None = None, 07:59:37 redirect: bool = True, 07:59:37 assert_same_host: bool = True, 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 pool_timeout: int | None = None, 07:59:37 release_conn: bool | None = None, 07:59:37 chunked: bool = False, 07:59:37 body_pos: _TYPE_BODY_POSITION | None = None, 07:59:37 preload_content: bool = True, 07:59:37 decode_content: bool = True, 07:59:37 **response_kw: typing.Any, 07:59:37 ) -> BaseHTTPResponse: 07:59:37 """ 07:59:37 Get a connection from the pool and perform an HTTP request. This is the 07:59:37 lowest level call for making a request, so you'll need to specify all 07:59:37 the raw details. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 More commonly, it's appropriate to use a convenience method 07:59:37 such as :meth:`request`. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 `release_conn` will only behave as expected if 07:59:37 `preload_content=False` because we want to make 07:59:37 `preload_content=False` the default behaviour someday soon without 07:59:37 breaking backwards compatibility. 07:59:37 07:59:37 :param method: 07:59:37 HTTP request method (such as GET, POST, PUT, etc.) 07:59:37 07:59:37 :param url: 07:59:37 The URL to perform the request on. 07:59:37 07:59:37 :param body: 07:59:37 Data to send in the request body, either :class:`str`, :class:`bytes`, 07:59:37 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 07:59:37 07:59:37 :param headers: 07:59:37 Dictionary of custom headers to send, such as User-Agent, 07:59:37 If-None-Match, etc. If None, pool headers are used. If provided, 07:59:37 these headers completely replace any pool-specific headers. 07:59:37 07:59:37 :param retries: 07:59:37 Configure the number of retries to allow before raising a 07:59:37 :class:`~urllib3.exceptions.MaxRetryError` exception. 07:59:37 07:59:37 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 07:59:37 :class:`~urllib3.util.retry.Retry` object for fine-grained control 07:59:37 over different types of retries. 07:59:37 Pass an integer number to retry connection errors that many times, 07:59:37 but no other types of errors. Pass zero to never retry. 07:59:37 07:59:37 If ``False``, then retries are disabled and any exception is raised 07:59:37 immediately. Also, instead of raising a MaxRetryError on redirects, 07:59:37 the redirect response will be returned. 07:59:37 07:59:37 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 07:59:37 07:59:37 :param redirect: 07:59:37 If True, automatically handle redirects (status codes 301, 302, 07:59:37 303, 307, 308). Each redirect counts as a retry. Disabling retries 07:59:37 will disable redirect, too. 07:59:37 07:59:37 :param assert_same_host: 07:59:37 If ``True``, will make sure that the host of the pool requests is 07:59:37 consistent else will raise HostChangedError. When ``False``, you can 07:59:37 use the pool on an HTTP proxy and request foreign hosts. 07:59:37 07:59:37 :param timeout: 07:59:37 If specified, overrides the default timeout for this one 07:59:37 request. It may be a float (in seconds) or an instance of 07:59:37 :class:`urllib3.util.Timeout`. 07:59:37 07:59:37 :param pool_timeout: 07:59:37 If set and the pool is set to block=True, then this method will 07:59:37 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 07:59:37 connection is available within the time period. 07:59:37 07:59:37 :param bool preload_content: 07:59:37 If True, the response's body will be preloaded into memory. 07:59:37 07:59:37 :param bool decode_content: 07:59:37 If True, will attempt to decode the body based on the 07:59:37 'content-encoding' header. 07:59:37 07:59:37 :param release_conn: 07:59:37 If False, then the urlopen call will not release the connection 07:59:37 back into the pool once a response is received (but will release if 07:59:37 you read the entire contents of the response such as when 07:59:37 `preload_content=True`). This is useful if you're not preloading 07:59:37 the response's content immediately. You will need to call 07:59:37 ``r.release_conn()`` on the response ``r`` to return the connection 07:59:37 back into the pool. If None, it takes the value of ``preload_content`` 07:59:37 which defaults to ``True``. 07:59:37 07:59:37 :param bool chunked: 07:59:37 If True, urllib3 will send the body using chunked transfer 07:59:37 encoding. Otherwise, urllib3 will send the body using the standard 07:59:37 content-length form. Defaults to False. 07:59:37 07:59:37 :param int body_pos: 07:59:37 Position to seek to in file-like body in the event of a retry or 07:59:37 redirect. Typically this won't need to be set because urllib3 will 07:59:37 auto-populate the value when needed. 07:59:37 """ 07:59:37 parsed_url = parse_url(url) 07:59:37 destination_scheme = parsed_url.scheme 07:59:37 07:59:37 if headers is None: 07:59:37 headers = self.headers 07:59:37 07:59:37 if not isinstance(retries, Retry): 07:59:37 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 07:59:37 07:59:37 if release_conn is None: 07:59:37 release_conn = preload_content 07:59:37 07:59:37 # Check host 07:59:37 if assert_same_host and not self.is_same_host(url): 07:59:37 raise HostChangedError(self, url, retries) 07:59:37 07:59:37 # Ensure that the URL we're connecting to is properly encoded 07:59:37 if url.startswith("/"): 07:59:37 url = to_str(_encode_target(url)) 07:59:37 else: 07:59:37 url = to_str(parsed_url.url) 07:59:37 07:59:37 conn = None 07:59:37 07:59:37 # Track whether `conn` needs to be released before 07:59:37 # returning/raising/recursing. Update this variable if necessary, and 07:59:37 # leave `release_conn` constant throughout the function. That way, if 07:59:37 # the function recurses, the original value of `release_conn` will be 07:59:37 # passed down into the recursive call, and its value will be respected. 07:59:37 # 07:59:37 # See issue #651 [1] for details. 07:59:37 # 07:59:37 # [1] 07:59:37 release_this_conn = release_conn 07:59:37 07:59:37 http_tunnel_required = connection_requires_http_tunnel( 07:59:37 self.proxy, self.proxy_config, destination_scheme 07:59:37 ) 07:59:37 07:59:37 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 07:59:37 # have to copy the headers dict so we can safely change it without those 07:59:37 # changes being reflected in anyone else's copy. 07:59:37 if not http_tunnel_required: 07:59:37 headers = headers.copy() # type: ignore[attr-defined] 07:59:37 headers.update(self.proxy_headers) # type: ignore[union-attr] 07:59:37 07:59:37 # Must keep the exception bound to a separate variable or else Python 3 07:59:37 # complains about UnboundLocalError. 07:59:37 err = None 07:59:37 07:59:37 # Keep track of whether we cleanly exited the except block. This 07:59:37 # ensures we do proper cleanup in finally. 07:59:37 clean_exit = False 07:59:37 07:59:37 # Rewind body position, if needed. Record current position 07:59:37 # for future rewinds in the event of a redirect/retry. 07:59:37 body_pos = set_file_position(body, body_pos) 07:59:37 07:59:37 try: 07:59:37 # Request a connection from the queue. 07:59:37 timeout_obj = self._get_timeout(timeout) 07:59:37 conn = self._get_conn(timeout=pool_timeout) 07:59:37 07:59:37 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 07:59:37 07:59:37 # Is this a closed/new connection that requires CONNECT tunnelling? 07:59:37 if self.proxy is not None and http_tunnel_required and conn.is_closed: 07:59:37 try: 07:59:37 self._prepare_proxy(conn) 07:59:37 except (BaseSSLError, OSError, SocketTimeout) as e: 07:59:37 self._raise_timeout( 07:59:37 err=e, url=self.proxy.url, timeout_value=conn.timeout 07:59:37 ) 07:59:37 raise 07:59:37 07:59:37 # If we're going to release the connection in ``finally:``, then 07:59:37 # the response doesn't need to know about the connection. Otherwise 07:59:37 # it will also try to release it and we'll have a double-release 07:59:37 # mess. 07:59:37 response_conn = conn if not release_conn else None 07:59:37 07:59:37 # Make the request on the HTTPConnection object 07:59:37 > response = self._make_request( 07:59:37 conn, 07:59:37 method, 07:59:37 url, 07:59:37 timeout=timeout_obj, 07:59:37 body=body, 07:59:37 headers=headers, 07:59:37 chunked=chunked, 07:59:37 retries=retries, 07:59:37 response_conn=response_conn, 07:59:37 preload_content=preload_content, 07:59:37 decode_content=decode_content, 07:59:37 **response_kw, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 07:59:37 conn.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:441: in request 07:59:37 self.endheaders() 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 07:59:37 self._send_output(message_body, encode_chunked=encode_chunked) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 07:59:37 self.send(msg) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 07:59:37 self.connect() 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 07:59:37 self.sock = self._new_conn() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 except socket.gaierror as e: 07:59:37 raise NameResolutionError(self.host, self, e) from e 07:59:37 except SocketTimeout as e: 07:59:37 raise ConnectTimeoutError( 07:59:37 self, 07:59:37 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 07:59:37 ) from e 07:59:37 07:59:37 except OSError as e: 07:59:37 > raise NewConnectionError( 07:59:37 self, f"Failed to establish a new connection: {e}" 07:59:37 ) from e 07:59:37 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 > resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:667: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 07:59:37 retries = retries.increment( 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 method = 'DELETE' 07:59:37 url = '/rests/data/open-terminal-meta-data:open-terminal-meta-data' 07:59:37 response = None 07:59:37 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 07:59:37 _pool = 07:59:37 _stacktrace = 07:59:37 07:59:37 def increment( 07:59:37 self, 07:59:37 method: str | None = None, 07:59:37 url: str | None = None, 07:59:37 response: BaseHTTPResponse | None = None, 07:59:37 error: Exception | None = None, 07:59:37 _pool: ConnectionPool | None = None, 07:59:37 _stacktrace: TracebackType | None = None, 07:59:37 ) -> Self: 07:59:37 """Return a new Retry object with incremented retry counters. 07:59:37 07:59:37 :param response: A response object, or None, if the server did not 07:59:37 return a response. 07:59:37 :type response: :class:`~urllib3.response.BaseHTTPResponse` 07:59:37 :param Exception error: An error encountered during the request, or 07:59:37 None if the response was received successfully. 07:59:37 07:59:37 :return: A new ``Retry`` object. 07:59:37 """ 07:59:37 if self.total is False and error: 07:59:37 # Disabled, indicate to re-raise the error. 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 07:59:37 total = self.total 07:59:37 if total is not None: 07:59:37 total -= 1 07:59:37 07:59:37 connect = self.connect 07:59:37 read = self.read 07:59:37 redirect = self.redirect 07:59:37 status_count = self.status 07:59:37 other = self.other 07:59:37 cause = "unknown" 07:59:37 status = None 07:59:37 redirect_location = None 07:59:37 07:59:37 if error and self._is_connection_error(error): 07:59:37 # Connect retry? 07:59:37 if connect is False: 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif connect is not None: 07:59:37 connect -= 1 07:59:37 07:59:37 elif error and self._is_read_error(error): 07:59:37 # Read retry? 07:59:37 if read is False or method is None or not self._is_method_retryable(method): 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif read is not None: 07:59:37 read -= 1 07:59:37 07:59:37 elif error: 07:59:37 # Other retry? 07:59:37 if other is not None: 07:59:37 other -= 1 07:59:37 07:59:37 elif response and response.get_redirect_location(): 07:59:37 # Redirect retry? 07:59:37 if redirect is not None: 07:59:37 redirect -= 1 07:59:37 cause = "too many redirects" 07:59:37 response_redirect_location = response.get_redirect_location() 07:59:37 if response_redirect_location: 07:59:37 redirect_location = response_redirect_location 07:59:37 status = response.status 07:59:37 07:59:37 else: 07:59:37 # Incrementing because of a server error like a 500 in 07:59:37 # status_forcelist and the given method is in the allowed_methods 07:59:37 cause = ResponseError.GENERIC_ERROR 07:59:37 if response and response.status: 07:59:37 if status_count is not None: 07:59:37 status_count -= 1 07:59:37 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 07:59:37 status = response.status 07:59:37 07:59:37 history = self.history + ( 07:59:37 RequestHistory(method, url, error, status, redirect_location), 07:59:37 ) 07:59:37 07:59:37 new_retry = self.new( 07:59:37 total=total, 07:59:37 connect=connect, 07:59:37 read=read, 07:59:37 redirect=redirect, 07:59:37 status=status_count, 07:59:37 other=other, 07:59:37 history=history, 07:59:37 ) 07:59:37 07:59:37 if new_retry.is_exhausted(): 07:59:37 reason = error or ResponseError(cause) 07:59:37 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 07:59:37 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/open-terminal-meta-data:open-terminal-meta-data (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 cls = 07:59:37 07:59:37 @classmethod 07:59:37 def tearDownClass(cls): 07:59:37 # pylint: disable=not-an-iterable 07:59:37 > test_utils_oc.del_metadata() 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:38: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/oc/test_utils_oc.py:240: in del_metadata 07:59:37 response = test_utils.delete_request(url[test_utils.RESTCONF_VERSION].format('{}')) 07:59:37 transportpce_tests/common/test_utils.py:133: in delete_request 07:59:37 return requests.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/api.py:59: in request 07:59:37 return session.request(method=method, url=url, **kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:589: in request 07:59:37 resp = self.send(prep, **send_kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:703: in send 07:59:37 r = adapter.send(request, **kwargs) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 except (ProtocolError, OSError) as err: 07:59:37 raise ConnectionError(err, request=request) 07:59:37 07:59:37 except MaxRetryError as e: 07:59:37 if isinstance(e.reason, ConnectTimeoutError): 07:59:37 # TODO: Remove this in 3.0.0: see #2811 07:59:37 if not isinstance(e.reason, NewConnectionError): 07:59:37 raise ConnectTimeout(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, ResponseError): 07:59:37 raise RetryError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _ProxyError): 07:59:37 raise ProxyError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _SSLError): 07:59:37 # This branch is for urllib3 v1.22 and later. 07:59:37 raise SSLError(e, request=request) 07:59:37 07:59:37 > raise ConnectionError(e, request=request) 07:59:37 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/open-terminal-meta-data:open-terminal-meta-data (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_10_xpdr_device_disconnection 07:59:37 =================================== FAILURES =================================== 07:59:37 _________ TransportpceOCPortMappingTesting.test_01_meta_data_insertion _________ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_01_meta_data_insertion(self): 07:59:37 response = test_utils_oc.metadata_input() 07:59:37 > self.assertEqual(response.status_code, requests.codes.created, 07:59:37 test_utils.CODE_SHOULD_BE_201) 07:59:37 E AssertionError: 404 != 201 : Http status code should be 201 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:50: AssertionError 07:59:37 ---------------------------- Captured stdout setup ----------------------------- 07:59:37 starting OpenDaylight... 07:59:37 starting KARAF TransportPCE build... 07:59:37 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 07:59:37 starting simulator sample-openconfig-mpdr in OpenROADM device version oc... 07:59:37 Searching for patterns in sample-openconfig-mpdr.log... Pattern found! simulator for sample-openconfig-mpdr started 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_01_meta_data_insertion 07:59:37 _______ TransportpceOCPortMappingTesting.test_02_catlog_input_insertion ________ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_02_catlog_input_insertion(self): 07:59:37 response = test_utils_oc.catlog_input() 07:59:37 > self.assertEqual(response.status_code, requests.codes.ok, 07:59:37 test_utils.CODE_SHOULD_BE_200) 07:59:37 E AssertionError: 404 != 200 : Http status code should be 200 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:55: AssertionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_02_catlog_input_insertion 07:59:37 _______ TransportpceOCPortMappingTesting.test_03_xpdr_device_connection ________ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_03_xpdr_device_connection(self): 07:59:37 response = test_utils.mount_device("XPDR-OC", 07:59:37 ('sample-openconfig-mpdr', self.NODE_VERSION)) 07:59:37 > self.assertEqual(response.status_code, requests.codes.created, 07:59:37 test_utils.CODE_SHOULD_BE_201) 07:59:37 E AssertionError: 404 != 201 : Http status code should be 201 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:61: AssertionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_03_xpdr_device_connection 07:59:37 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not added to tpce topology... 07:59:37 ________ TransportpceOCPortMappingTesting.test_04_xpdr_device_connected ________ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 > sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:199: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 07:59:37 raise err 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 address = ('localhost', 8182), timeout = 10, source_address = None 07:59:37 socket_options = [(6, 1, 1)] 07:59:37 07:59:37 def create_connection( 07:59:37 address: tuple[str, int], 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 source_address: tuple[str, int] | None = None, 07:59:37 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 07:59:37 ) -> socket.socket: 07:59:37 """Connect to *address* and return the socket object. 07:59:37 07:59:37 Convenience function. Connect to *address* (a 2-tuple ``(host, 07:59:37 port)``) and return the socket object. Passing the optional 07:59:37 *timeout* parameter will set the timeout on the socket instance 07:59:37 before attempting to connect. If no *timeout* is supplied, the 07:59:37 global default timeout setting returned by :func:`socket.getdefaulttimeout` 07:59:37 is used. If *source_address* is set it must be a tuple of (host, port) 07:59:37 for the socket to bind as a source address before making the connection. 07:59:37 An host of '' or port 0 tells the OS to use the default. 07:59:37 """ 07:59:37 07:59:37 host, port = address 07:59:37 if host.startswith("["): 07:59:37 host = host.strip("[]") 07:59:37 err = None 07:59:37 07:59:37 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 07:59:37 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 07:59:37 # The original create_connection function always returns all records. 07:59:37 family = allowed_gai_family() 07:59:37 07:59:37 try: 07:59:37 host.encode("idna") 07:59:37 except UnicodeError: 07:59:37 raise LocationParseError(f"'{host}', label empty or too long") from None 07:59:37 07:59:37 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 07:59:37 af, socktype, proto, canonname, sa = res 07:59:37 sock = None 07:59:37 try: 07:59:37 sock = socket.socket(af, socktype, proto) 07:59:37 07:59:37 # If provided, set socket level options before connecting. 07:59:37 _set_socket_options(sock, socket_options) 07:59:37 07:59:37 if timeout is not _DEFAULT_TIMEOUT: 07:59:37 sock.settimeout(timeout) 07:59:37 if source_address: 07:59:37 sock.bind(source_address) 07:59:37 > sock.connect(sa) 07:59:37 E ConnectionRefusedError: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC?content=nonconfig' 07:59:37 body = None 07:59:37 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='} 07:59:37 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 redirect = False, assert_same_host = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 07:59:37 release_conn = False, chunked = False, body_pos = None, preload_content = False 07:59:37 decode_content = False, response_kw = {} 07:59:37 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC', query='content=nonconfig', fragment=None) 07:59:37 destination_scheme = None, conn = None, release_this_conn = True 07:59:37 http_tunnel_required = False, err = None, clean_exit = False 07:59:37 07:59:37 def urlopen( # type: ignore[override] 07:59:37 self, 07:59:37 method: str, 07:59:37 url: str, 07:59:37 body: _TYPE_BODY | None = None, 07:59:37 headers: typing.Mapping[str, str] | None = None, 07:59:37 retries: Retry | bool | int | None = None, 07:59:37 redirect: bool = True, 07:59:37 assert_same_host: bool = True, 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 pool_timeout: int | None = None, 07:59:37 release_conn: bool | None = None, 07:59:37 chunked: bool = False, 07:59:37 body_pos: _TYPE_BODY_POSITION | None = None, 07:59:37 preload_content: bool = True, 07:59:37 decode_content: bool = True, 07:59:37 **response_kw: typing.Any, 07:59:37 ) -> BaseHTTPResponse: 07:59:37 """ 07:59:37 Get a connection from the pool and perform an HTTP request. This is the 07:59:37 lowest level call for making a request, so you'll need to specify all 07:59:37 the raw details. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 More commonly, it's appropriate to use a convenience method 07:59:37 such as :meth:`request`. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 `release_conn` will only behave as expected if 07:59:37 `preload_content=False` because we want to make 07:59:37 `preload_content=False` the default behaviour someday soon without 07:59:37 breaking backwards compatibility. 07:59:37 07:59:37 :param method: 07:59:37 HTTP request method (such as GET, POST, PUT, etc.) 07:59:37 07:59:37 :param url: 07:59:37 The URL to perform the request on. 07:59:37 07:59:37 :param body: 07:59:37 Data to send in the request body, either :class:`str`, :class:`bytes`, 07:59:37 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 07:59:37 07:59:37 :param headers: 07:59:37 Dictionary of custom headers to send, such as User-Agent, 07:59:37 If-None-Match, etc. If None, pool headers are used. If provided, 07:59:37 these headers completely replace any pool-specific headers. 07:59:37 07:59:37 :param retries: 07:59:37 Configure the number of retries to allow before raising a 07:59:37 :class:`~urllib3.exceptions.MaxRetryError` exception. 07:59:37 07:59:37 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 07:59:37 :class:`~urllib3.util.retry.Retry` object for fine-grained control 07:59:37 over different types of retries. 07:59:37 Pass an integer number to retry connection errors that many times, 07:59:37 but no other types of errors. Pass zero to never retry. 07:59:37 07:59:37 If ``False``, then retries are disabled and any exception is raised 07:59:37 immediately. Also, instead of raising a MaxRetryError on redirects, 07:59:37 the redirect response will be returned. 07:59:37 07:59:37 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 07:59:37 07:59:37 :param redirect: 07:59:37 If True, automatically handle redirects (status codes 301, 302, 07:59:37 303, 307, 308). Each redirect counts as a retry. Disabling retries 07:59:37 will disable redirect, too. 07:59:37 07:59:37 :param assert_same_host: 07:59:37 If ``True``, will make sure that the host of the pool requests is 07:59:37 consistent else will raise HostChangedError. When ``False``, you can 07:59:37 use the pool on an HTTP proxy and request foreign hosts. 07:59:37 07:59:37 :param timeout: 07:59:37 If specified, overrides the default timeout for this one 07:59:37 request. It may be a float (in seconds) or an instance of 07:59:37 :class:`urllib3.util.Timeout`. 07:59:37 07:59:37 :param pool_timeout: 07:59:37 If set and the pool is set to block=True, then this method will 07:59:37 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 07:59:37 connection is available within the time period. 07:59:37 07:59:37 :param bool preload_content: 07:59:37 If True, the response's body will be preloaded into memory. 07:59:37 07:59:37 :param bool decode_content: 07:59:37 If True, will attempt to decode the body based on the 07:59:37 'content-encoding' header. 07:59:37 07:59:37 :param release_conn: 07:59:37 If False, then the urlopen call will not release the connection 07:59:37 back into the pool once a response is received (but will release if 07:59:37 you read the entire contents of the response such as when 07:59:37 `preload_content=True`). This is useful if you're not preloading 07:59:37 the response's content immediately. You will need to call 07:59:37 ``r.release_conn()`` on the response ``r`` to return the connection 07:59:37 back into the pool. If None, it takes the value of ``preload_content`` 07:59:37 which defaults to ``True``. 07:59:37 07:59:37 :param bool chunked: 07:59:37 If True, urllib3 will send the body using chunked transfer 07:59:37 encoding. Otherwise, urllib3 will send the body using the standard 07:59:37 content-length form. Defaults to False. 07:59:37 07:59:37 :param int body_pos: 07:59:37 Position to seek to in file-like body in the event of a retry or 07:59:37 redirect. Typically this won't need to be set because urllib3 will 07:59:37 auto-populate the value when needed. 07:59:37 """ 07:59:37 parsed_url = parse_url(url) 07:59:37 destination_scheme = parsed_url.scheme 07:59:37 07:59:37 if headers is None: 07:59:37 headers = self.headers 07:59:37 07:59:37 if not isinstance(retries, Retry): 07:59:37 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 07:59:37 07:59:37 if release_conn is None: 07:59:37 release_conn = preload_content 07:59:37 07:59:37 # Check host 07:59:37 if assert_same_host and not self.is_same_host(url): 07:59:37 raise HostChangedError(self, url, retries) 07:59:37 07:59:37 # Ensure that the URL we're connecting to is properly encoded 07:59:37 if url.startswith("/"): 07:59:37 url = to_str(_encode_target(url)) 07:59:37 else: 07:59:37 url = to_str(parsed_url.url) 07:59:37 07:59:37 conn = None 07:59:37 07:59:37 # Track whether `conn` needs to be released before 07:59:37 # returning/raising/recursing. Update this variable if necessary, and 07:59:37 # leave `release_conn` constant throughout the function. That way, if 07:59:37 # the function recurses, the original value of `release_conn` will be 07:59:37 # passed down into the recursive call, and its value will be respected. 07:59:37 # 07:59:37 # See issue #651 [1] for details. 07:59:37 # 07:59:37 # [1] 07:59:37 release_this_conn = release_conn 07:59:37 07:59:37 http_tunnel_required = connection_requires_http_tunnel( 07:59:37 self.proxy, self.proxy_config, destination_scheme 07:59:37 ) 07:59:37 07:59:37 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 07:59:37 # have to copy the headers dict so we can safely change it without those 07:59:37 # changes being reflected in anyone else's copy. 07:59:37 if not http_tunnel_required: 07:59:37 headers = headers.copy() # type: ignore[attr-defined] 07:59:37 headers.update(self.proxy_headers) # type: ignore[union-attr] 07:59:37 07:59:37 # Must keep the exception bound to a separate variable or else Python 3 07:59:37 # complains about UnboundLocalError. 07:59:37 err = None 07:59:37 07:59:37 # Keep track of whether we cleanly exited the except block. This 07:59:37 # ensures we do proper cleanup in finally. 07:59:37 clean_exit = False 07:59:37 07:59:37 # Rewind body position, if needed. Record current position 07:59:37 # for future rewinds in the event of a redirect/retry. 07:59:37 body_pos = set_file_position(body, body_pos) 07:59:37 07:59:37 try: 07:59:37 # Request a connection from the queue. 07:59:37 timeout_obj = self._get_timeout(timeout) 07:59:37 conn = self._get_conn(timeout=pool_timeout) 07:59:37 07:59:37 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 07:59:37 07:59:37 # Is this a closed/new connection that requires CONNECT tunnelling? 07:59:37 if self.proxy is not None and http_tunnel_required and conn.is_closed: 07:59:37 try: 07:59:37 self._prepare_proxy(conn) 07:59:37 except (BaseSSLError, OSError, SocketTimeout) as e: 07:59:37 self._raise_timeout( 07:59:37 err=e, url=self.proxy.url, timeout_value=conn.timeout 07:59:37 ) 07:59:37 raise 07:59:37 07:59:37 # If we're going to release the connection in ``finally:``, then 07:59:37 # the response doesn't need to know about the connection. Otherwise 07:59:37 # it will also try to release it and we'll have a double-release 07:59:37 # mess. 07:59:37 response_conn = conn if not release_conn else None 07:59:37 07:59:37 # Make the request on the HTTPConnection object 07:59:37 > response = self._make_request( 07:59:37 conn, 07:59:37 method, 07:59:37 url, 07:59:37 timeout=timeout_obj, 07:59:37 body=body, 07:59:37 headers=headers, 07:59:37 chunked=chunked, 07:59:37 retries=retries, 07:59:37 response_conn=response_conn, 07:59:37 preload_content=preload_content, 07:59:37 decode_content=decode_content, 07:59:37 **response_kw, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 07:59:37 conn.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:441: in request 07:59:37 self.endheaders() 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 07:59:37 self._send_output(message_body, encode_chunked=encode_chunked) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 07:59:37 self.send(msg) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 07:59:37 self.connect() 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 07:59:37 self.sock = self._new_conn() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 except socket.gaierror as e: 07:59:37 raise NameResolutionError(self.host, self, e) from e 07:59:37 except SocketTimeout as e: 07:59:37 raise ConnectTimeoutError( 07:59:37 self, 07:59:37 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 07:59:37 ) from e 07:59:37 07:59:37 except OSError as e: 07:59:37 > raise NewConnectionError( 07:59:37 self, f"Failed to establish a new connection: {e}" 07:59:37 ) from e 07:59:37 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 > resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:667: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 07:59:37 retries = retries.increment( 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC?content=nonconfig' 07:59:37 response = None 07:59:37 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 07:59:37 _pool = 07:59:37 _stacktrace = 07:59:37 07:59:37 def increment( 07:59:37 self, 07:59:37 method: str | None = None, 07:59:37 url: str | None = None, 07:59:37 response: BaseHTTPResponse | None = None, 07:59:37 error: Exception | None = None, 07:59:37 _pool: ConnectionPool | None = None, 07:59:37 _stacktrace: TracebackType | None = None, 07:59:37 ) -> Self: 07:59:37 """Return a new Retry object with incremented retry counters. 07:59:37 07:59:37 :param response: A response object, or None, if the server did not 07:59:37 return a response. 07:59:37 :type response: :class:`~urllib3.response.BaseHTTPResponse` 07:59:37 :param Exception error: An error encountered during the request, or 07:59:37 None if the response was received successfully. 07:59:37 07:59:37 :return: A new ``Retry`` object. 07:59:37 """ 07:59:37 if self.total is False and error: 07:59:37 # Disabled, indicate to re-raise the error. 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 07:59:37 total = self.total 07:59:37 if total is not None: 07:59:37 total -= 1 07:59:37 07:59:37 connect = self.connect 07:59:37 read = self.read 07:59:37 redirect = self.redirect 07:59:37 status_count = self.status 07:59:37 other = self.other 07:59:37 cause = "unknown" 07:59:37 status = None 07:59:37 redirect_location = None 07:59:37 07:59:37 if error and self._is_connection_error(error): 07:59:37 # Connect retry? 07:59:37 if connect is False: 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif connect is not None: 07:59:37 connect -= 1 07:59:37 07:59:37 elif error and self._is_read_error(error): 07:59:37 # Read retry? 07:59:37 if read is False or method is None or not self._is_method_retryable(method): 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif read is not None: 07:59:37 read -= 1 07:59:37 07:59:37 elif error: 07:59:37 # Other retry? 07:59:37 if other is not None: 07:59:37 other -= 1 07:59:37 07:59:37 elif response and response.get_redirect_location(): 07:59:37 # Redirect retry? 07:59:37 if redirect is not None: 07:59:37 redirect -= 1 07:59:37 cause = "too many redirects" 07:59:37 response_redirect_location = response.get_redirect_location() 07:59:37 if response_redirect_location: 07:59:37 redirect_location = response_redirect_location 07:59:37 status = response.status 07:59:37 07:59:37 else: 07:59:37 # Incrementing because of a server error like a 500 in 07:59:37 # status_forcelist and the given method is in the allowed_methods 07:59:37 cause = ResponseError.GENERIC_ERROR 07:59:37 if response and response.status: 07:59:37 if status_count is not None: 07:59:37 status_count -= 1 07:59:37 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 07:59:37 status = response.status 07:59:37 07:59:37 history = self.history + ( 07:59:37 RequestHistory(method, url, error, status, redirect_location), 07:59:37 ) 07:59:37 07:59:37 new_retry = self.new( 07:59:37 total=total, 07:59:37 connect=connect, 07:59:37 read=read, 07:59:37 redirect=redirect, 07:59:37 status=status_count, 07:59:37 other=other, 07:59:37 history=history, 07:59:37 ) 07:59:37 07:59:37 if new_retry.is_exhausted(): 07:59:37 reason = error or ResponseError(cause) 07:59:37 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 07:59:37 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_04_xpdr_device_connected(self): 07:59:37 > response = test_utils.check_device_connection("XPDR-OC") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:65: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:385: in check_device_connection 07:59:37 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 07:59:37 transportpce_tests/common/test_utils.py:116: in get_request 07:59:37 return requests.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/api.py:59: in request 07:59:37 return session.request(method=method, url=url, **kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:589: in request 07:59:37 resp = self.send(prep, **send_kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:703: in send 07:59:37 r = adapter.send(request, **kwargs) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 except (ProtocolError, OSError) as err: 07:59:37 raise ConnectionError(err, request=request) 07:59:37 07:59:37 except MaxRetryError as e: 07:59:37 if isinstance(e.reason, ConnectTimeoutError): 07:59:37 # TODO: Remove this in 3.0.0: see #2811 07:59:37 if not isinstance(e.reason, NewConnectionError): 07:59:37 raise ConnectTimeout(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, ResponseError): 07:59:37 raise RetryError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _ProxyError): 07:59:37 raise ProxyError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _SSLError): 07:59:37 # This branch is for urllib3 v1.22 and later. 07:59:37 raise SSLError(e, request=request) 07:59:37 07:59:37 > raise ConnectionError(e, request=request) 07:59:37 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_04_xpdr_device_connected 07:59:37 ________ TransportpceOCPortMappingTesting.test_05_xpdr_portmapping_info ________ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 > sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:199: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 07:59:37 raise err 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 address = ('localhost', 8182), timeout = 10, source_address = None 07:59:37 socket_options = [(6, 1, 1)] 07:59:37 07:59:37 def create_connection( 07:59:37 address: tuple[str, int], 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 source_address: tuple[str, int] | None = None, 07:59:37 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 07:59:37 ) -> socket.socket: 07:59:37 """Connect to *address* and return the socket object. 07:59:37 07:59:37 Convenience function. Connect to *address* (a 2-tuple ``(host, 07:59:37 port)``) and return the socket object. Passing the optional 07:59:37 *timeout* parameter will set the timeout on the socket instance 07:59:37 before attempting to connect. If no *timeout* is supplied, the 07:59:37 global default timeout setting returned by :func:`socket.getdefaulttimeout` 07:59:37 is used. If *source_address* is set it must be a tuple of (host, port) 07:59:37 for the socket to bind as a source address before making the connection. 07:59:37 An host of '' or port 0 tells the OS to use the default. 07:59:37 """ 07:59:37 07:59:37 host, port = address 07:59:37 if host.startswith("["): 07:59:37 host = host.strip("[]") 07:59:37 err = None 07:59:37 07:59:37 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 07:59:37 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 07:59:37 # The original create_connection function always returns all records. 07:59:37 family = allowed_gai_family() 07:59:37 07:59:37 try: 07:59:37 host.encode("idna") 07:59:37 except UnicodeError: 07:59:37 raise LocationParseError(f"'{host}', label empty or too long") from None 07:59:37 07:59:37 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 07:59:37 af, socktype, proto, canonname, sa = res 07:59:37 sock = None 07:59:37 try: 07:59:37 sock = socket.socket(af, socktype, proto) 07:59:37 07:59:37 # If provided, set socket level options before connecting. 07:59:37 _set_socket_options(sock, socket_options) 07:59:37 07:59:37 if timeout is not _DEFAULT_TIMEOUT: 07:59:37 sock.settimeout(timeout) 07:59:37 if source_address: 07:59:37 sock.bind(source_address) 07:59:37 > sock.connect(sa) 07:59:37 E ConnectionRefusedError: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/node-info' 07:59:37 body = None 07:59:37 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='} 07:59:37 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 redirect = False, assert_same_host = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 07:59:37 release_conn = False, chunked = False, body_pos = None, preload_content = False 07:59:37 decode_content = False, response_kw = {} 07:59:37 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/node-info', query=None, fragment=None) 07:59:37 destination_scheme = None, conn = None, release_this_conn = True 07:59:37 http_tunnel_required = False, err = None, clean_exit = False 07:59:37 07:59:37 def urlopen( # type: ignore[override] 07:59:37 self, 07:59:37 method: str, 07:59:37 url: str, 07:59:37 body: _TYPE_BODY | None = None, 07:59:37 headers: typing.Mapping[str, str] | None = None, 07:59:37 retries: Retry | bool | int | None = None, 07:59:37 redirect: bool = True, 07:59:37 assert_same_host: bool = True, 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 pool_timeout: int | None = None, 07:59:37 release_conn: bool | None = None, 07:59:37 chunked: bool = False, 07:59:37 body_pos: _TYPE_BODY_POSITION | None = None, 07:59:37 preload_content: bool = True, 07:59:37 decode_content: bool = True, 07:59:37 **response_kw: typing.Any, 07:59:37 ) -> BaseHTTPResponse: 07:59:37 """ 07:59:37 Get a connection from the pool and perform an HTTP request. This is the 07:59:37 lowest level call for making a request, so you'll need to specify all 07:59:37 the raw details. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 More commonly, it's appropriate to use a convenience method 07:59:37 such as :meth:`request`. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 `release_conn` will only behave as expected if 07:59:37 `preload_content=False` because we want to make 07:59:37 `preload_content=False` the default behaviour someday soon without 07:59:37 breaking backwards compatibility. 07:59:37 07:59:37 :param method: 07:59:37 HTTP request method (such as GET, POST, PUT, etc.) 07:59:37 07:59:37 :param url: 07:59:37 The URL to perform the request on. 07:59:37 07:59:37 :param body: 07:59:37 Data to send in the request body, either :class:`str`, :class:`bytes`, 07:59:37 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 07:59:37 07:59:37 :param headers: 07:59:37 Dictionary of custom headers to send, such as User-Agent, 07:59:37 If-None-Match, etc. If None, pool headers are used. If provided, 07:59:37 these headers completely replace any pool-specific headers. 07:59:37 07:59:37 :param retries: 07:59:37 Configure the number of retries to allow before raising a 07:59:37 :class:`~urllib3.exceptions.MaxRetryError` exception. 07:59:37 07:59:37 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 07:59:37 :class:`~urllib3.util.retry.Retry` object for fine-grained control 07:59:37 over different types of retries. 07:59:37 Pass an integer number to retry connection errors that many times, 07:59:37 but no other types of errors. Pass zero to never retry. 07:59:37 07:59:37 If ``False``, then retries are disabled and any exception is raised 07:59:37 immediately. Also, instead of raising a MaxRetryError on redirects, 07:59:37 the redirect response will be returned. 07:59:37 07:59:37 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 07:59:37 07:59:37 :param redirect: 07:59:37 If True, automatically handle redirects (status codes 301, 302, 07:59:37 303, 307, 308). Each redirect counts as a retry. Disabling retries 07:59:37 will disable redirect, too. 07:59:37 07:59:37 :param assert_same_host: 07:59:37 If ``True``, will make sure that the host of the pool requests is 07:59:37 consistent else will raise HostChangedError. When ``False``, you can 07:59:37 use the pool on an HTTP proxy and request foreign hosts. 07:59:37 07:59:37 :param timeout: 07:59:37 If specified, overrides the default timeout for this one 07:59:37 request. It may be a float (in seconds) or an instance of 07:59:37 :class:`urllib3.util.Timeout`. 07:59:37 07:59:37 :param pool_timeout: 07:59:37 If set and the pool is set to block=True, then this method will 07:59:37 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 07:59:37 connection is available within the time period. 07:59:37 07:59:37 :param bool preload_content: 07:59:37 If True, the response's body will be preloaded into memory. 07:59:37 07:59:37 :param bool decode_content: 07:59:37 If True, will attempt to decode the body based on the 07:59:37 'content-encoding' header. 07:59:37 07:59:37 :param release_conn: 07:59:37 If False, then the urlopen call will not release the connection 07:59:37 back into the pool once a response is received (but will release if 07:59:37 you read the entire contents of the response such as when 07:59:37 `preload_content=True`). This is useful if you're not preloading 07:59:37 the response's content immediately. You will need to call 07:59:37 ``r.release_conn()`` on the response ``r`` to return the connection 07:59:37 back into the pool. If None, it takes the value of ``preload_content`` 07:59:37 which defaults to ``True``. 07:59:37 07:59:37 :param bool chunked: 07:59:37 If True, urllib3 will send the body using chunked transfer 07:59:37 encoding. Otherwise, urllib3 will send the body using the standard 07:59:37 content-length form. Defaults to False. 07:59:37 07:59:37 :param int body_pos: 07:59:37 Position to seek to in file-like body in the event of a retry or 07:59:37 redirect. Typically this won't need to be set because urllib3 will 07:59:37 auto-populate the value when needed. 07:59:37 """ 07:59:37 parsed_url = parse_url(url) 07:59:37 destination_scheme = parsed_url.scheme 07:59:37 07:59:37 if headers is None: 07:59:37 headers = self.headers 07:59:37 07:59:37 if not isinstance(retries, Retry): 07:59:37 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 07:59:37 07:59:37 if release_conn is None: 07:59:37 release_conn = preload_content 07:59:37 07:59:37 # Check host 07:59:37 if assert_same_host and not self.is_same_host(url): 07:59:37 raise HostChangedError(self, url, retries) 07:59:37 07:59:37 # Ensure that the URL we're connecting to is properly encoded 07:59:37 if url.startswith("/"): 07:59:37 url = to_str(_encode_target(url)) 07:59:37 else: 07:59:37 url = to_str(parsed_url.url) 07:59:37 07:59:37 conn = None 07:59:37 07:59:37 # Track whether `conn` needs to be released before 07:59:37 # returning/raising/recursing. Update this variable if necessary, and 07:59:37 # leave `release_conn` constant throughout the function. That way, if 07:59:37 # the function recurses, the original value of `release_conn` will be 07:59:37 # passed down into the recursive call, and its value will be respected. 07:59:37 # 07:59:37 # See issue #651 [1] for details. 07:59:37 # 07:59:37 # [1] 07:59:37 release_this_conn = release_conn 07:59:37 07:59:37 http_tunnel_required = connection_requires_http_tunnel( 07:59:37 self.proxy, self.proxy_config, destination_scheme 07:59:37 ) 07:59:37 07:59:37 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 07:59:37 # have to copy the headers dict so we can safely change it without those 07:59:37 # changes being reflected in anyone else's copy. 07:59:37 if not http_tunnel_required: 07:59:37 headers = headers.copy() # type: ignore[attr-defined] 07:59:37 headers.update(self.proxy_headers) # type: ignore[union-attr] 07:59:37 07:59:37 # Must keep the exception bound to a separate variable or else Python 3 07:59:37 # complains about UnboundLocalError. 07:59:37 err = None 07:59:37 07:59:37 # Keep track of whether we cleanly exited the except block. This 07:59:37 # ensures we do proper cleanup in finally. 07:59:37 clean_exit = False 07:59:37 07:59:37 # Rewind body position, if needed. Record current position 07:59:37 # for future rewinds in the event of a redirect/retry. 07:59:37 body_pos = set_file_position(body, body_pos) 07:59:37 07:59:37 try: 07:59:37 # Request a connection from the queue. 07:59:37 timeout_obj = self._get_timeout(timeout) 07:59:37 conn = self._get_conn(timeout=pool_timeout) 07:59:37 07:59:37 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 07:59:37 07:59:37 # Is this a closed/new connection that requires CONNECT tunnelling? 07:59:37 if self.proxy is not None and http_tunnel_required and conn.is_closed: 07:59:37 try: 07:59:37 self._prepare_proxy(conn) 07:59:37 except (BaseSSLError, OSError, SocketTimeout) as e: 07:59:37 self._raise_timeout( 07:59:37 err=e, url=self.proxy.url, timeout_value=conn.timeout 07:59:37 ) 07:59:37 raise 07:59:37 07:59:37 # If we're going to release the connection in ``finally:``, then 07:59:37 # the response doesn't need to know about the connection. Otherwise 07:59:37 # it will also try to release it and we'll have a double-release 07:59:37 # mess. 07:59:37 response_conn = conn if not release_conn else None 07:59:37 07:59:37 # Make the request on the HTTPConnection object 07:59:37 > response = self._make_request( 07:59:37 conn, 07:59:37 method, 07:59:37 url, 07:59:37 timeout=timeout_obj, 07:59:37 body=body, 07:59:37 headers=headers, 07:59:37 chunked=chunked, 07:59:37 retries=retries, 07:59:37 response_conn=response_conn, 07:59:37 preload_content=preload_content, 07:59:37 decode_content=decode_content, 07:59:37 **response_kw, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 07:59:37 conn.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:441: in request 07:59:37 self.endheaders() 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 07:59:37 self._send_output(message_body, encode_chunked=encode_chunked) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 07:59:37 self.send(msg) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 07:59:37 self.connect() 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 07:59:37 self.sock = self._new_conn() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 except socket.gaierror as e: 07:59:37 raise NameResolutionError(self.host, self, e) from e 07:59:37 except SocketTimeout as e: 07:59:37 raise ConnectTimeoutError( 07:59:37 self, 07:59:37 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 07:59:37 ) from e 07:59:37 07:59:37 except OSError as e: 07:59:37 > raise NewConnectionError( 07:59:37 self, f"Failed to establish a new connection: {e}" 07:59:37 ) from e 07:59:37 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 > resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:667: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 07:59:37 retries = retries.increment( 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/node-info' 07:59:37 response = None 07:59:37 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 07:59:37 _pool = 07:59:37 _stacktrace = 07:59:37 07:59:37 def increment( 07:59:37 self, 07:59:37 method: str | None = None, 07:59:37 url: str | None = None, 07:59:37 response: BaseHTTPResponse | None = None, 07:59:37 error: Exception | None = None, 07:59:37 _pool: ConnectionPool | None = None, 07:59:37 _stacktrace: TracebackType | None = None, 07:59:37 ) -> Self: 07:59:37 """Return a new Retry object with incremented retry counters. 07:59:37 07:59:37 :param response: A response object, or None, if the server did not 07:59:37 return a response. 07:59:37 :type response: :class:`~urllib3.response.BaseHTTPResponse` 07:59:37 :param Exception error: An error encountered during the request, or 07:59:37 None if the response was received successfully. 07:59:37 07:59:37 :return: A new ``Retry`` object. 07:59:37 """ 07:59:37 if self.total is False and error: 07:59:37 # Disabled, indicate to re-raise the error. 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 07:59:37 total = self.total 07:59:37 if total is not None: 07:59:37 total -= 1 07:59:37 07:59:37 connect = self.connect 07:59:37 read = self.read 07:59:37 redirect = self.redirect 07:59:37 status_count = self.status 07:59:37 other = self.other 07:59:37 cause = "unknown" 07:59:37 status = None 07:59:37 redirect_location = None 07:59:37 07:59:37 if error and self._is_connection_error(error): 07:59:37 # Connect retry? 07:59:37 if connect is False: 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif connect is not None: 07:59:37 connect -= 1 07:59:37 07:59:37 elif error and self._is_read_error(error): 07:59:37 # Read retry? 07:59:37 if read is False or method is None or not self._is_method_retryable(method): 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif read is not None: 07:59:37 read -= 1 07:59:37 07:59:37 elif error: 07:59:37 # Other retry? 07:59:37 if other is not None: 07:59:37 other -= 1 07:59:37 07:59:37 elif response and response.get_redirect_location(): 07:59:37 # Redirect retry? 07:59:37 if redirect is not None: 07:59:37 redirect -= 1 07:59:37 cause = "too many redirects" 07:59:37 response_redirect_location = response.get_redirect_location() 07:59:37 if response_redirect_location: 07:59:37 redirect_location = response_redirect_location 07:59:37 status = response.status 07:59:37 07:59:37 else: 07:59:37 # Incrementing because of a server error like a 500 in 07:59:37 # status_forcelist and the given method is in the allowed_methods 07:59:37 cause = ResponseError.GENERIC_ERROR 07:59:37 if response and response.status: 07:59:37 if status_count is not None: 07:59:37 status_count -= 1 07:59:37 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 07:59:37 status = response.status 07:59:37 07:59:37 history = self.history + ( 07:59:37 RequestHistory(method, url, error, status, redirect_location), 07:59:37 ) 07:59:37 07:59:37 new_retry = self.new( 07:59:37 total=total, 07:59:37 connect=connect, 07:59:37 read=read, 07:59:37 redirect=redirect, 07:59:37 status=status_count, 07:59:37 other=other, 07:59:37 history=history, 07:59:37 ) 07:59:37 07:59:37 if new_retry.is_exhausted(): 07:59:37 reason = error or ResponseError(cause) 07:59:37 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 07:59:37 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDR-OC/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_05_xpdr_portmapping_info(self): 07:59:37 > response = test_utils.get_portmapping_node_attr("XPDR-OC", "node-info", None) 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:70: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:487: in get_portmapping_node_attr 07:59:37 response = get_request(target_url) 07:59:37 transportpce_tests/common/test_utils.py:116: in get_request 07:59:37 return requests.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/api.py:59: in request 07:59:37 return session.request(method=method, url=url, **kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:589: in request 07:59:37 resp = self.send(prep, **send_kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:703: in send 07:59:37 r = adapter.send(request, **kwargs) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 except (ProtocolError, OSError) as err: 07:59:37 raise ConnectionError(err, request=request) 07:59:37 07:59:37 except MaxRetryError as e: 07:59:37 if isinstance(e.reason, ConnectTimeoutError): 07:59:37 # TODO: Remove this in 3.0.0: see #2811 07:59:37 if not isinstance(e.reason, NewConnectionError): 07:59:37 raise ConnectTimeout(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, ResponseError): 07:59:37 raise RetryError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _ProxyError): 07:59:37 raise ProxyError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _SSLError): 07:59:37 # This branch is for urllib3 v1.22 and later. 07:59:37 raise SSLError(e, request=request) 07:59:37 07:59:37 > raise ConnectionError(e, request=request) 07:59:37 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDR-OC/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_05_xpdr_portmapping_info 07:59:37 ______ TransportpceOCPortMappingTesting.test_06_mpdr_portmapping_NETWORK1 ______ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 > sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:199: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 07:59:37 raise err 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 address = ('localhost', 8182), timeout = 10, source_address = None 07:59:37 socket_options = [(6, 1, 1)] 07:59:37 07:59:37 def create_connection( 07:59:37 address: tuple[str, int], 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 source_address: tuple[str, int] | None = None, 07:59:37 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 07:59:37 ) -> socket.socket: 07:59:37 """Connect to *address* and return the socket object. 07:59:37 07:59:37 Convenience function. Connect to *address* (a 2-tuple ``(host, 07:59:37 port)``) and return the socket object. Passing the optional 07:59:37 *timeout* parameter will set the timeout on the socket instance 07:59:37 before attempting to connect. If no *timeout* is supplied, the 07:59:37 global default timeout setting returned by :func:`socket.getdefaulttimeout` 07:59:37 is used. If *source_address* is set it must be a tuple of (host, port) 07:59:37 for the socket to bind as a source address before making the connection. 07:59:37 An host of '' or port 0 tells the OS to use the default. 07:59:37 """ 07:59:37 07:59:37 host, port = address 07:59:37 if host.startswith("["): 07:59:37 host = host.strip("[]") 07:59:37 err = None 07:59:37 07:59:37 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 07:59:37 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 07:59:37 # The original create_connection function always returns all records. 07:59:37 family = allowed_gai_family() 07:59:37 07:59:37 try: 07:59:37 host.encode("idna") 07:59:37 except UnicodeError: 07:59:37 raise LocationParseError(f"'{host}', label empty or too long") from None 07:59:37 07:59:37 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 07:59:37 af, socktype, proto, canonname, sa = res 07:59:37 sock = None 07:59:37 try: 07:59:37 sock = socket.socket(af, socktype, proto) 07:59:37 07:59:37 # If provided, set socket level options before connecting. 07:59:37 _set_socket_options(sock, socket_options) 07:59:37 07:59:37 if timeout is not _DEFAULT_TIMEOUT: 07:59:37 sock.settimeout(timeout) 07:59:37 if source_address: 07:59:37 sock.bind(source_address) 07:59:37 > sock.connect(sa) 07:59:37 E ConnectionRefusedError: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/mapping=XPDR1-NETWORK5' 07:59:37 body = None 07:59:37 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='} 07:59:37 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 redirect = False, assert_same_host = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 07:59:37 release_conn = False, chunked = False, body_pos = None, preload_content = False 07:59:37 decode_content = False, response_kw = {} 07:59:37 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/mapping=XPDR1-NETWORK5', query=None, fragment=None) 07:59:37 destination_scheme = None, conn = None, release_this_conn = True 07:59:37 http_tunnel_required = False, err = None, clean_exit = False 07:59:37 07:59:37 def urlopen( # type: ignore[override] 07:59:37 self, 07:59:37 method: str, 07:59:37 url: str, 07:59:37 body: _TYPE_BODY | None = None, 07:59:37 headers: typing.Mapping[str, str] | None = None, 07:59:37 retries: Retry | bool | int | None = None, 07:59:37 redirect: bool = True, 07:59:37 assert_same_host: bool = True, 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 pool_timeout: int | None = None, 07:59:37 release_conn: bool | None = None, 07:59:37 chunked: bool = False, 07:59:37 body_pos: _TYPE_BODY_POSITION | None = None, 07:59:37 preload_content: bool = True, 07:59:37 decode_content: bool = True, 07:59:37 **response_kw: typing.Any, 07:59:37 ) -> BaseHTTPResponse: 07:59:37 """ 07:59:37 Get a connection from the pool and perform an HTTP request. This is the 07:59:37 lowest level call for making a request, so you'll need to specify all 07:59:37 the raw details. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 More commonly, it's appropriate to use a convenience method 07:59:37 such as :meth:`request`. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 `release_conn` will only behave as expected if 07:59:37 `preload_content=False` because we want to make 07:59:37 `preload_content=False` the default behaviour someday soon without 07:59:37 breaking backwards compatibility. 07:59:37 07:59:37 :param method: 07:59:37 HTTP request method (such as GET, POST, PUT, etc.) 07:59:37 07:59:37 :param url: 07:59:37 The URL to perform the request on. 07:59:37 07:59:37 :param body: 07:59:37 Data to send in the request body, either :class:`str`, :class:`bytes`, 07:59:37 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 07:59:37 07:59:37 :param headers: 07:59:37 Dictionary of custom headers to send, such as User-Agent, 07:59:37 If-None-Match, etc. If None, pool headers are used. If provided, 07:59:37 these headers completely replace any pool-specific headers. 07:59:37 07:59:37 :param retries: 07:59:37 Configure the number of retries to allow before raising a 07:59:37 :class:`~urllib3.exceptions.MaxRetryError` exception. 07:59:37 07:59:37 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 07:59:37 :class:`~urllib3.util.retry.Retry` object for fine-grained control 07:59:37 over different types of retries. 07:59:37 Pass an integer number to retry connection errors that many times, 07:59:37 but no other types of errors. Pass zero to never retry. 07:59:37 07:59:37 If ``False``, then retries are disabled and any exception is raised 07:59:37 immediately. Also, instead of raising a MaxRetryError on redirects, 07:59:37 the redirect response will be returned. 07:59:37 07:59:37 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 07:59:37 07:59:37 :param redirect: 07:59:37 If True, automatically handle redirects (status codes 301, 302, 07:59:37 303, 307, 308). Each redirect counts as a retry. Disabling retries 07:59:37 will disable redirect, too. 07:59:37 07:59:37 :param assert_same_host: 07:59:37 If ``True``, will make sure that the host of the pool requests is 07:59:37 consistent else will raise HostChangedError. When ``False``, you can 07:59:37 use the pool on an HTTP proxy and request foreign hosts. 07:59:37 07:59:37 :param timeout: 07:59:37 If specified, overrides the default timeout for this one 07:59:37 request. It may be a float (in seconds) or an instance of 07:59:37 :class:`urllib3.util.Timeout`. 07:59:37 07:59:37 :param pool_timeout: 07:59:37 If set and the pool is set to block=True, then this method will 07:59:37 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 07:59:37 connection is available within the time period. 07:59:37 07:59:37 :param bool preload_content: 07:59:37 If True, the response's body will be preloaded into memory. 07:59:37 07:59:37 :param bool decode_content: 07:59:37 If True, will attempt to decode the body based on the 07:59:37 'content-encoding' header. 07:59:37 07:59:37 :param release_conn: 07:59:37 If False, then the urlopen call will not release the connection 07:59:37 back into the pool once a response is received (but will release if 07:59:37 you read the entire contents of the response such as when 07:59:37 `preload_content=True`). This is useful if you're not preloading 07:59:37 the response's content immediately. You will need to call 07:59:37 ``r.release_conn()`` on the response ``r`` to return the connection 07:59:37 back into the pool. If None, it takes the value of ``preload_content`` 07:59:37 which defaults to ``True``. 07:59:37 07:59:37 :param bool chunked: 07:59:37 If True, urllib3 will send the body using chunked transfer 07:59:37 encoding. Otherwise, urllib3 will send the body using the standard 07:59:37 content-length form. Defaults to False. 07:59:37 07:59:37 :param int body_pos: 07:59:37 Position to seek to in file-like body in the event of a retry or 07:59:37 redirect. Typically this won't need to be set because urllib3 will 07:59:37 auto-populate the value when needed. 07:59:37 """ 07:59:37 parsed_url = parse_url(url) 07:59:37 destination_scheme = parsed_url.scheme 07:59:37 07:59:37 if headers is None: 07:59:37 headers = self.headers 07:59:37 07:59:37 if not isinstance(retries, Retry): 07:59:37 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 07:59:37 07:59:37 if release_conn is None: 07:59:37 release_conn = preload_content 07:59:37 07:59:37 # Check host 07:59:37 if assert_same_host and not self.is_same_host(url): 07:59:37 raise HostChangedError(self, url, retries) 07:59:37 07:59:37 # Ensure that the URL we're connecting to is properly encoded 07:59:37 if url.startswith("/"): 07:59:37 url = to_str(_encode_target(url)) 07:59:37 else: 07:59:37 url = to_str(parsed_url.url) 07:59:37 07:59:37 conn = None 07:59:37 07:59:37 # Track whether `conn` needs to be released before 07:59:37 # returning/raising/recursing. Update this variable if necessary, and 07:59:37 # leave `release_conn` constant throughout the function. That way, if 07:59:37 # the function recurses, the original value of `release_conn` will be 07:59:37 # passed down into the recursive call, and its value will be respected. 07:59:37 # 07:59:37 # See issue #651 [1] for details. 07:59:37 # 07:59:37 # [1] 07:59:37 release_this_conn = release_conn 07:59:37 07:59:37 http_tunnel_required = connection_requires_http_tunnel( 07:59:37 self.proxy, self.proxy_config, destination_scheme 07:59:37 ) 07:59:37 07:59:37 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 07:59:37 # have to copy the headers dict so we can safely change it without those 07:59:37 # changes being reflected in anyone else's copy. 07:59:37 if not http_tunnel_required: 07:59:37 headers = headers.copy() # type: ignore[attr-defined] 07:59:37 headers.update(self.proxy_headers) # type: ignore[union-attr] 07:59:37 07:59:37 # Must keep the exception bound to a separate variable or else Python 3 07:59:37 # complains about UnboundLocalError. 07:59:37 err = None 07:59:37 07:59:37 # Keep track of whether we cleanly exited the except block. This 07:59:37 # ensures we do proper cleanup in finally. 07:59:37 clean_exit = False 07:59:37 07:59:37 # Rewind body position, if needed. Record current position 07:59:37 # for future rewinds in the event of a redirect/retry. 07:59:37 body_pos = set_file_position(body, body_pos) 07:59:37 07:59:37 try: 07:59:37 # Request a connection from the queue. 07:59:37 timeout_obj = self._get_timeout(timeout) 07:59:37 conn = self._get_conn(timeout=pool_timeout) 07:59:37 07:59:37 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 07:59:37 07:59:37 # Is this a closed/new connection that requires CONNECT tunnelling? 07:59:37 if self.proxy is not None and http_tunnel_required and conn.is_closed: 07:59:37 try: 07:59:37 self._prepare_proxy(conn) 07:59:37 except (BaseSSLError, OSError, SocketTimeout) as e: 07:59:37 self._raise_timeout( 07:59:37 err=e, url=self.proxy.url, timeout_value=conn.timeout 07:59:37 ) 07:59:37 raise 07:59:37 07:59:37 # If we're going to release the connection in ``finally:``, then 07:59:37 # the response doesn't need to know about the connection. Otherwise 07:59:37 # it will also try to release it and we'll have a double-release 07:59:37 # mess. 07:59:37 response_conn = conn if not release_conn else None 07:59:37 07:59:37 # Make the request on the HTTPConnection object 07:59:37 > response = self._make_request( 07:59:37 conn, 07:59:37 method, 07:59:37 url, 07:59:37 timeout=timeout_obj, 07:59:37 body=body, 07:59:37 headers=headers, 07:59:37 chunked=chunked, 07:59:37 retries=retries, 07:59:37 response_conn=response_conn, 07:59:37 preload_content=preload_content, 07:59:37 decode_content=decode_content, 07:59:37 **response_kw, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 07:59:37 conn.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:441: in request 07:59:37 self.endheaders() 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 07:59:37 self._send_output(message_body, encode_chunked=encode_chunked) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 07:59:37 self.send(msg) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 07:59:37 self.connect() 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 07:59:37 self.sock = self._new_conn() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 except socket.gaierror as e: 07:59:37 raise NameResolutionError(self.host, self, e) from e 07:59:37 except SocketTimeout as e: 07:59:37 raise ConnectTimeoutError( 07:59:37 self, 07:59:37 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 07:59:37 ) from e 07:59:37 07:59:37 except OSError as e: 07:59:37 > raise NewConnectionError( 07:59:37 self, f"Failed to establish a new connection: {e}" 07:59:37 ) from e 07:59:37 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 > resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:667: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 07:59:37 retries = retries.increment( 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 method = 'GET' 07:59:37 url = '/rests/data/transportpce-portmapping:network/nodes=XPDR-OC/mapping=XPDR1-NETWORK5' 07:59:37 response = None 07:59:37 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 07:59:37 _pool = 07:59:37 _stacktrace = 07:59:37 07:59:37 def increment( 07:59:37 self, 07:59:37 method: str | None = None, 07:59:37 url: str | None = None, 07:59:37 response: BaseHTTPResponse | None = None, 07:59:37 error: Exception | None = None, 07:59:37 _pool: ConnectionPool | None = None, 07:59:37 _stacktrace: TracebackType | None = None, 07:59:37 ) -> Self: 07:59:37 """Return a new Retry object with incremented retry counters. 07:59:37 07:59:37 :param response: A response object, or None, if the server did not 07:59:37 return a response. 07:59:37 :type response: :class:`~urllib3.response.BaseHTTPResponse` 07:59:37 :param Exception error: An error encountered during the request, or 07:59:37 None if the response was received successfully. 07:59:37 07:59:37 :return: A new ``Retry`` object. 07:59:37 """ 07:59:37 if self.total is False and error: 07:59:37 # Disabled, indicate to re-raise the error. 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 07:59:37 total = self.total 07:59:37 if total is not None: 07:59:37 total -= 1 07:59:37 07:59:37 connect = self.connect 07:59:37 read = self.read 07:59:37 redirect = self.redirect 07:59:37 status_count = self.status 07:59:37 other = self.other 07:59:37 cause = "unknown" 07:59:37 status = None 07:59:37 redirect_location = None 07:59:37 07:59:37 if error and self._is_connection_error(error): 07:59:37 # Connect retry? 07:59:37 if connect is False: 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif connect is not None: 07:59:37 connect -= 1 07:59:37 07:59:37 elif error and self._is_read_error(error): 07:59:37 # Read retry? 07:59:37 if read is False or method is None or not self._is_method_retryable(method): 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif read is not None: 07:59:37 read -= 1 07:59:37 07:59:37 elif error: 07:59:37 # Other retry? 07:59:37 if other is not None: 07:59:37 other -= 1 07:59:37 07:59:37 elif response and response.get_redirect_location(): 07:59:37 # Redirect retry? 07:59:37 if redirect is not None: 07:59:37 redirect -= 1 07:59:37 cause = "too many redirects" 07:59:37 response_redirect_location = response.get_redirect_location() 07:59:37 if response_redirect_location: 07:59:37 redirect_location = response_redirect_location 07:59:37 status = response.status 07:59:37 07:59:37 else: 07:59:37 # Incrementing because of a server error like a 500 in 07:59:37 # status_forcelist and the given method is in the allowed_methods 07:59:37 cause = ResponseError.GENERIC_ERROR 07:59:37 if response and response.status: 07:59:37 if status_count is not None: 07:59:37 status_count -= 1 07:59:37 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 07:59:37 status = response.status 07:59:37 07:59:37 history = self.history + ( 07:59:37 RequestHistory(method, url, error, status, redirect_location), 07:59:37 ) 07:59:37 07:59:37 new_retry = self.new( 07:59:37 total=total, 07:59:37 connect=connect, 07:59:37 read=read, 07:59:37 redirect=redirect, 07:59:37 status=status_count, 07:59:37 other=other, 07:59:37 history=history, 07:59:37 ) 07:59:37 07:59:37 if new_retry.is_exhausted(): 07:59:37 reason = error or ResponseError(cause) 07:59:37 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 07:59:37 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDR-OC/mapping=XPDR1-NETWORK5 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_06_mpdr_portmapping_NETWORK1(self): 07:59:37 > response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-NETWORK5") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:83: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:487: in get_portmapping_node_attr 07:59:37 response = get_request(target_url) 07:59:37 transportpce_tests/common/test_utils.py:116: in get_request 07:59:37 return requests.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/api.py:59: in request 07:59:37 return session.request(method=method, url=url, **kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:589: in request 07:59:37 resp = self.send(prep, **send_kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:703: in send 07:59:37 r = adapter.send(request, **kwargs) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 except (ProtocolError, OSError) as err: 07:59:37 raise ConnectionError(err, request=request) 07:59:37 07:59:37 except MaxRetryError as e: 07:59:37 if isinstance(e.reason, ConnectTimeoutError): 07:59:37 # TODO: Remove this in 3.0.0: see #2811 07:59:37 if not isinstance(e.reason, NewConnectionError): 07:59:37 raise ConnectTimeout(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, ResponseError): 07:59:37 raise RetryError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _ProxyError): 07:59:37 raise ProxyError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _SSLError): 07:59:37 # This branch is for urllib3 v1.22 and later. 07:59:37 raise SSLError(e, request=request) 07:59:37 07:59:37 > raise ConnectionError(e, request=request) 07:59:37 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDR-OC/mapping=XPDR1-NETWORK5 (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_06_mpdr_portmapping_NETWORK1 07:59:37 ______ TransportpceOCPortMappingTesting.test_07_mpdr_portmapping_CLIENT1 _______ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 > return complexjson.loads(self.text, **kwargs) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:974: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/__init__.py:346: in loads 07:59:37 return _default_decoder.decode(s) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:337: in decode 07:59:37 obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , s = '', idx = 0 07:59:37 07:59:37 def raw_decode(self, s, idx=0): 07:59:37 """Decode a JSON document from ``s`` (a ``str`` beginning with 07:59:37 a JSON document) and return a 2-tuple of the Python 07:59:37 representation and the index in ``s`` where the document ended. 07:59:37 07:59:37 This can be used to decode a JSON document from a string that may 07:59:37 have extraneous data at the end. 07:59:37 07:59:37 """ 07:59:37 try: 07:59:37 obj, end = self.scan_once(s, idx) 07:59:37 except StopIteration as err: 07:59:37 > raise JSONDecodeError("Expecting value", s, err.value) from None 07:59:37 E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:355: JSONDecodeError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_07_mpdr_portmapping_CLIENT1(self): 07:59:37 > response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-CLIENT1") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:101: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:488: in get_portmapping_node_attr 07:59:37 res = response.json() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 return complexjson.loads(self.text, **kwargs) 07:59:37 except JSONDecodeError as e: 07:59:37 # Catch JSON-related errors and raise as requests.JSONDecodeError 07:59:37 # This aliases json.JSONDecodeError and simplejson.JSONDecodeError 07:59:37 > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:978: JSONDecodeError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_07_mpdr_portmapping_CLIENT1 07:59:37 _________ TransportpceOCPortMappingTesting.test_08_mpdr_switching_pool _________ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 > return complexjson.loads(self.text, **kwargs) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:974: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/__init__.py:346: in loads 07:59:37 return _default_decoder.decode(s) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:337: in decode 07:59:37 obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , s = '', idx = 0 07:59:37 07:59:37 def raw_decode(self, s, idx=0): 07:59:37 """Decode a JSON document from ``s`` (a ``str`` beginning with 07:59:37 a JSON document) and return a 2-tuple of the Python 07:59:37 representation and the index in ``s`` where the document ended. 07:59:37 07:59:37 This can be used to decode a JSON document from a string that may 07:59:37 have extraneous data at the end. 07:59:37 07:59:37 """ 07:59:37 try: 07:59:37 obj, end = self.scan_once(s, idx) 07:59:37 except StopIteration as err: 07:59:37 > raise JSONDecodeError("Expecting value", s, err.value) from None 07:59:37 E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:355: JSONDecodeError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_08_mpdr_switching_pool(self): 07:59:37 > response = test_utils.get_portmapping_node_attr("XPDR-OC", "switching-pool-lcp", "1") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:118: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:488: in get_portmapping_node_attr 07:59:37 res = response.json() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 return complexjson.loads(self.text, **kwargs) 07:59:37 except JSONDecodeError as e: 07:59:37 # Catch JSON-related errors and raise as requests.JSONDecodeError 07:59:37 # This aliases json.JSONDecodeError and simplejson.JSONDecodeError 07:59:37 > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:978: JSONDecodeError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_08_mpdr_switching_pool 07:59:37 _________ TransportpceOCPortMappingTesting.test_09_check_mccapprofile __________ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 > return complexjson.loads(self.text, **kwargs) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:974: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/__init__.py:346: in loads 07:59:37 return _default_decoder.decode(s) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:337: in decode 07:59:37 obj, end = self.raw_decode(s, idx=_w(s, 0).end()) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , s = '', idx = 0 07:59:37 07:59:37 def raw_decode(self, s, idx=0): 07:59:37 """Decode a JSON document from ``s`` (a ``str`` beginning with 07:59:37 a JSON document) and return a 2-tuple of the Python 07:59:37 representation and the index in ``s`` where the document ended. 07:59:37 07:59:37 This can be used to decode a JSON document from a string that may 07:59:37 have extraneous data at the end. 07:59:37 07:59:37 """ 07:59:37 try: 07:59:37 obj, end = self.scan_once(s, idx) 07:59:37 except StopIteration as err: 07:59:37 > raise JSONDecodeError("Expecting value", s, err.value) from None 07:59:37 E json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/json/decoder.py:355: JSONDecodeError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_09_check_mccapprofile(self): 07:59:37 > res = test_utils.get_portmapping_node_attr("XPDR-OC", "mc-capabilities", "XPDR-mcprofile") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:131: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:488: in get_portmapping_node_attr 07:59:37 res = response.json() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = , kwargs = {} 07:59:37 07:59:37 def json(self, **kwargs): 07:59:37 r"""Returns the json-encoded content of a response, if any. 07:59:37 07:59:37 :param \*\*kwargs: Optional arguments that ``json.loads`` takes. 07:59:37 :raises requests.exceptions.JSONDecodeError: If the response body does not 07:59:37 contain valid json. 07:59:37 """ 07:59:37 07:59:37 if not self.encoding and self.content and len(self.content) > 3: 07:59:37 # No encoding set. JSON RFC 4627 section 3 states we should expect 07:59:37 # UTF-8, -16 or -32. Detect which one to use; If the detection or 07:59:37 # decoding fails, fall back to `self.text` (using charset_normalizer to make 07:59:37 # a best guess). 07:59:37 encoding = guess_json_utf(self.content) 07:59:37 if encoding is not None: 07:59:37 try: 07:59:37 return complexjson.loads(self.content.decode(encoding), **kwargs) 07:59:37 except UnicodeDecodeError: 07:59:37 # Wrong UTF codec detected; usually because it's not UTF-8 07:59:37 # but some other 8-bit codec. This is an RFC violation, 07:59:37 # and the server didn't bother to tell us what codec *was* 07:59:37 # used. 07:59:37 pass 07:59:37 except JSONDecodeError as e: 07:59:37 raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 07:59:37 try: 07:59:37 return complexjson.loads(self.text, **kwargs) 07:59:37 except JSONDecodeError as e: 07:59:37 # Catch JSON-related errors and raise as requests.JSONDecodeError 07:59:37 # This aliases json.JSONDecodeError and simplejson.JSONDecodeError 07:59:37 > raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) 07:59:37 E requests.exceptions.JSONDecodeError: Expecting value: line 1 column 1 (char 0) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/models.py:978: JSONDecodeError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_09_check_mccapprofile 07:59:37 ______ TransportpceOCPortMappingTesting.test_10_xpdr_device_disconnection ______ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 > sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:199: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 07:59:37 raise err 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 address = ('localhost', 8182), timeout = 10, source_address = None 07:59:37 socket_options = [(6, 1, 1)] 07:59:37 07:59:37 def create_connection( 07:59:37 address: tuple[str, int], 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 source_address: tuple[str, int] | None = None, 07:59:37 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 07:59:37 ) -> socket.socket: 07:59:37 """Connect to *address* and return the socket object. 07:59:37 07:59:37 Convenience function. Connect to *address* (a 2-tuple ``(host, 07:59:37 port)``) and return the socket object. Passing the optional 07:59:37 *timeout* parameter will set the timeout on the socket instance 07:59:37 before attempting to connect. If no *timeout* is supplied, the 07:59:37 global default timeout setting returned by :func:`socket.getdefaulttimeout` 07:59:37 is used. If *source_address* is set it must be a tuple of (host, port) 07:59:37 for the socket to bind as a source address before making the connection. 07:59:37 An host of '' or port 0 tells the OS to use the default. 07:59:37 """ 07:59:37 07:59:37 host, port = address 07:59:37 if host.startswith("["): 07:59:37 host = host.strip("[]") 07:59:37 err = None 07:59:37 07:59:37 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 07:59:37 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 07:59:37 # The original create_connection function always returns all records. 07:59:37 family = allowed_gai_family() 07:59:37 07:59:37 try: 07:59:37 host.encode("idna") 07:59:37 except UnicodeError: 07:59:37 raise LocationParseError(f"'{host}', label empty or too long") from None 07:59:37 07:59:37 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 07:59:37 af, socktype, proto, canonname, sa = res 07:59:37 sock = None 07:59:37 try: 07:59:37 sock = socket.socket(af, socktype, proto) 07:59:37 07:59:37 # If provided, set socket level options before connecting. 07:59:37 _set_socket_options(sock, socket_options) 07:59:37 07:59:37 if timeout is not _DEFAULT_TIMEOUT: 07:59:37 sock.settimeout(timeout) 07:59:37 if source_address: 07:59:37 sock.bind(source_address) 07:59:37 > sock.connect(sa) 07:59:37 E ConnectionRefusedError: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 method = 'DELETE' 07:59:37 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC' 07:59:37 body = None 07:59:37 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='} 07:59:37 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 redirect = False, assert_same_host = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 07:59:37 release_conn = False, chunked = False, body_pos = None, preload_content = False 07:59:37 decode_content = False, response_kw = {} 07:59:37 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC', query=None, fragment=None) 07:59:37 destination_scheme = None, conn = None, release_this_conn = True 07:59:37 http_tunnel_required = False, err = None, clean_exit = False 07:59:37 07:59:37 def urlopen( # type: ignore[override] 07:59:37 self, 07:59:37 method: str, 07:59:37 url: str, 07:59:37 body: _TYPE_BODY | None = None, 07:59:37 headers: typing.Mapping[str, str] | None = None, 07:59:37 retries: Retry | bool | int | None = None, 07:59:37 redirect: bool = True, 07:59:37 assert_same_host: bool = True, 07:59:37 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 07:59:37 pool_timeout: int | None = None, 07:59:37 release_conn: bool | None = None, 07:59:37 chunked: bool = False, 07:59:37 body_pos: _TYPE_BODY_POSITION | None = None, 07:59:37 preload_content: bool = True, 07:59:37 decode_content: bool = True, 07:59:37 **response_kw: typing.Any, 07:59:37 ) -> BaseHTTPResponse: 07:59:37 """ 07:59:37 Get a connection from the pool and perform an HTTP request. This is the 07:59:37 lowest level call for making a request, so you'll need to specify all 07:59:37 the raw details. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 More commonly, it's appropriate to use a convenience method 07:59:37 such as :meth:`request`. 07:59:37 07:59:37 .. note:: 07:59:37 07:59:37 `release_conn` will only behave as expected if 07:59:37 `preload_content=False` because we want to make 07:59:37 `preload_content=False` the default behaviour someday soon without 07:59:37 breaking backwards compatibility. 07:59:37 07:59:37 :param method: 07:59:37 HTTP request method (such as GET, POST, PUT, etc.) 07:59:37 07:59:37 :param url: 07:59:37 The URL to perform the request on. 07:59:37 07:59:37 :param body: 07:59:37 Data to send in the request body, either :class:`str`, :class:`bytes`, 07:59:37 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 07:59:37 07:59:37 :param headers: 07:59:37 Dictionary of custom headers to send, such as User-Agent, 07:59:37 If-None-Match, etc. If None, pool headers are used. If provided, 07:59:37 these headers completely replace any pool-specific headers. 07:59:37 07:59:37 :param retries: 07:59:37 Configure the number of retries to allow before raising a 07:59:37 :class:`~urllib3.exceptions.MaxRetryError` exception. 07:59:37 07:59:37 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 07:59:37 :class:`~urllib3.util.retry.Retry` object for fine-grained control 07:59:37 over different types of retries. 07:59:37 Pass an integer number to retry connection errors that many times, 07:59:37 but no other types of errors. Pass zero to never retry. 07:59:37 07:59:37 If ``False``, then retries are disabled and any exception is raised 07:59:37 immediately. Also, instead of raising a MaxRetryError on redirects, 07:59:37 the redirect response will be returned. 07:59:37 07:59:37 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 07:59:37 07:59:37 :param redirect: 07:59:37 If True, automatically handle redirects (status codes 301, 302, 07:59:37 303, 307, 308). Each redirect counts as a retry. Disabling retries 07:59:37 will disable redirect, too. 07:59:37 07:59:37 :param assert_same_host: 07:59:37 If ``True``, will make sure that the host of the pool requests is 07:59:37 consistent else will raise HostChangedError. When ``False``, you can 07:59:37 use the pool on an HTTP proxy and request foreign hosts. 07:59:37 07:59:37 :param timeout: 07:59:37 If specified, overrides the default timeout for this one 07:59:37 request. It may be a float (in seconds) or an instance of 07:59:37 :class:`urllib3.util.Timeout`. 07:59:37 07:59:37 :param pool_timeout: 07:59:37 If set and the pool is set to block=True, then this method will 07:59:37 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 07:59:37 connection is available within the time period. 07:59:37 07:59:37 :param bool preload_content: 07:59:37 If True, the response's body will be preloaded into memory. 07:59:37 07:59:37 :param bool decode_content: 07:59:37 If True, will attempt to decode the body based on the 07:59:37 'content-encoding' header. 07:59:37 07:59:37 :param release_conn: 07:59:37 If False, then the urlopen call will not release the connection 07:59:37 back into the pool once a response is received (but will release if 07:59:37 you read the entire contents of the response such as when 07:59:37 `preload_content=True`). This is useful if you're not preloading 07:59:37 the response's content immediately. You will need to call 07:59:37 ``r.release_conn()`` on the response ``r`` to return the connection 07:59:37 back into the pool. If None, it takes the value of ``preload_content`` 07:59:37 which defaults to ``True``. 07:59:37 07:59:37 :param bool chunked: 07:59:37 If True, urllib3 will send the body using chunked transfer 07:59:37 encoding. Otherwise, urllib3 will send the body using the standard 07:59:37 content-length form. Defaults to False. 07:59:37 07:59:37 :param int body_pos: 07:59:37 Position to seek to in file-like body in the event of a retry or 07:59:37 redirect. Typically this won't need to be set because urllib3 will 07:59:37 auto-populate the value when needed. 07:59:37 """ 07:59:37 parsed_url = parse_url(url) 07:59:37 destination_scheme = parsed_url.scheme 07:59:37 07:59:37 if headers is None: 07:59:37 headers = self.headers 07:59:37 07:59:37 if not isinstance(retries, Retry): 07:59:37 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 07:59:37 07:59:37 if release_conn is None: 07:59:37 release_conn = preload_content 07:59:37 07:59:37 # Check host 07:59:37 if assert_same_host and not self.is_same_host(url): 07:59:37 raise HostChangedError(self, url, retries) 07:59:37 07:59:37 # Ensure that the URL we're connecting to is properly encoded 07:59:37 if url.startswith("/"): 07:59:37 url = to_str(_encode_target(url)) 07:59:37 else: 07:59:37 url = to_str(parsed_url.url) 07:59:37 07:59:37 conn = None 07:59:37 07:59:37 # Track whether `conn` needs to be released before 07:59:37 # returning/raising/recursing. Update this variable if necessary, and 07:59:37 # leave `release_conn` constant throughout the function. That way, if 07:59:37 # the function recurses, the original value of `release_conn` will be 07:59:37 # passed down into the recursive call, and its value will be respected. 07:59:37 # 07:59:37 # See issue #651 [1] for details. 07:59:37 # 07:59:37 # [1] 07:59:37 release_this_conn = release_conn 07:59:37 07:59:37 http_tunnel_required = connection_requires_http_tunnel( 07:59:37 self.proxy, self.proxy_config, destination_scheme 07:59:37 ) 07:59:37 07:59:37 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 07:59:37 # have to copy the headers dict so we can safely change it without those 07:59:37 # changes being reflected in anyone else's copy. 07:59:37 if not http_tunnel_required: 07:59:37 headers = headers.copy() # type: ignore[attr-defined] 07:59:37 headers.update(self.proxy_headers) # type: ignore[union-attr] 07:59:37 07:59:37 # Must keep the exception bound to a separate variable or else Python 3 07:59:37 # complains about UnboundLocalError. 07:59:37 err = None 07:59:37 07:59:37 # Keep track of whether we cleanly exited the except block. This 07:59:37 # ensures we do proper cleanup in finally. 07:59:37 clean_exit = False 07:59:37 07:59:37 # Rewind body position, if needed. Record current position 07:59:37 # for future rewinds in the event of a redirect/retry. 07:59:37 body_pos = set_file_position(body, body_pos) 07:59:37 07:59:37 try: 07:59:37 # Request a connection from the queue. 07:59:37 timeout_obj = self._get_timeout(timeout) 07:59:37 conn = self._get_conn(timeout=pool_timeout) 07:59:37 07:59:37 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 07:59:37 07:59:37 # Is this a closed/new connection that requires CONNECT tunnelling? 07:59:37 if self.proxy is not None and http_tunnel_required and conn.is_closed: 07:59:37 try: 07:59:37 self._prepare_proxy(conn) 07:59:37 except (BaseSSLError, OSError, SocketTimeout) as e: 07:59:37 self._raise_timeout( 07:59:37 err=e, url=self.proxy.url, timeout_value=conn.timeout 07:59:37 ) 07:59:37 raise 07:59:37 07:59:37 # If we're going to release the connection in ``finally:``, then 07:59:37 # the response doesn't need to know about the connection. Otherwise 07:59:37 # it will also try to release it and we'll have a double-release 07:59:37 # mess. 07:59:37 response_conn = conn if not release_conn else None 07:59:37 07:59:37 # Make the request on the HTTPConnection object 07:59:37 > response = self._make_request( 07:59:37 conn, 07:59:37 method, 07:59:37 url, 07:59:37 timeout=timeout_obj, 07:59:37 body=body, 07:59:37 headers=headers, 07:59:37 chunked=chunked, 07:59:37 retries=retries, 07:59:37 response_conn=response_conn, 07:59:37 preload_content=preload_content, 07:59:37 decode_content=decode_content, 07:59:37 **response_kw, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 07:59:37 conn.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:441: in request 07:59:37 self.endheaders() 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 07:59:37 self._send_output(message_body, encode_chunked=encode_chunked) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 07:59:37 self.send(msg) 07:59:37 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 07:59:37 self.connect() 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 07:59:37 self.sock = self._new_conn() 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 07:59:37 def _new_conn(self) -> socket.socket: 07:59:37 """Establish a socket connection and set nodelay settings on it. 07:59:37 07:59:37 :return: New socket connection. 07:59:37 """ 07:59:37 try: 07:59:37 sock = connection.create_connection( 07:59:37 (self._dns_host, self.port), 07:59:37 self.timeout, 07:59:37 source_address=self.source_address, 07:59:37 socket_options=self.socket_options, 07:59:37 ) 07:59:37 except socket.gaierror as e: 07:59:37 raise NameResolutionError(self.host, self, e) from e 07:59:37 except SocketTimeout as e: 07:59:37 raise ConnectTimeoutError( 07:59:37 self, 07:59:37 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 07:59:37 ) from e 07:59:37 07:59:37 except OSError as e: 07:59:37 > raise NewConnectionError( 07:59:37 self, f"Failed to establish a new connection: {e}" 07:59:37 ) from e 07:59:37 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 07:59:37 07:59:37 The above exception was the direct cause of the following exception: 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 > resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:667: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 07:59:37 retries = retries.increment( 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 07:59:37 method = 'DELETE' 07:59:37 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC' 07:59:37 response = None 07:59:37 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 07:59:37 _pool = 07:59:37 _stacktrace = 07:59:37 07:59:37 def increment( 07:59:37 self, 07:59:37 method: str | None = None, 07:59:37 url: str | None = None, 07:59:37 response: BaseHTTPResponse | None = None, 07:59:37 error: Exception | None = None, 07:59:37 _pool: ConnectionPool | None = None, 07:59:37 _stacktrace: TracebackType | None = None, 07:59:37 ) -> Self: 07:59:37 """Return a new Retry object with incremented retry counters. 07:59:37 07:59:37 :param response: A response object, or None, if the server did not 07:59:37 return a response. 07:59:37 :type response: :class:`~urllib3.response.BaseHTTPResponse` 07:59:37 :param Exception error: An error encountered during the request, or 07:59:37 None if the response was received successfully. 07:59:37 07:59:37 :return: A new ``Retry`` object. 07:59:37 """ 07:59:37 if self.total is False and error: 07:59:37 # Disabled, indicate to re-raise the error. 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 07:59:37 total = self.total 07:59:37 if total is not None: 07:59:37 total -= 1 07:59:37 07:59:37 connect = self.connect 07:59:37 read = self.read 07:59:37 redirect = self.redirect 07:59:37 status_count = self.status 07:59:37 other = self.other 07:59:37 cause = "unknown" 07:59:37 status = None 07:59:37 redirect_location = None 07:59:37 07:59:37 if error and self._is_connection_error(error): 07:59:37 # Connect retry? 07:59:37 if connect is False: 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif connect is not None: 07:59:37 connect -= 1 07:59:37 07:59:37 elif error and self._is_read_error(error): 07:59:37 # Read retry? 07:59:37 if read is False or method is None or not self._is_method_retryable(method): 07:59:37 raise reraise(type(error), error, _stacktrace) 07:59:37 elif read is not None: 07:59:37 read -= 1 07:59:37 07:59:37 elif error: 07:59:37 # Other retry? 07:59:37 if other is not None: 07:59:37 other -= 1 07:59:37 07:59:37 elif response and response.get_redirect_location(): 07:59:37 # Redirect retry? 07:59:37 if redirect is not None: 07:59:37 redirect -= 1 07:59:37 cause = "too many redirects" 07:59:37 response_redirect_location = response.get_redirect_location() 07:59:37 if response_redirect_location: 07:59:37 redirect_location = response_redirect_location 07:59:37 status = response.status 07:59:37 07:59:37 else: 07:59:37 # Incrementing because of a server error like a 500 in 07:59:37 # status_forcelist and the given method is in the allowed_methods 07:59:37 cause = ResponseError.GENERIC_ERROR 07:59:37 if response and response.status: 07:59:37 if status_count is not None: 07:59:37 status_count -= 1 07:59:37 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 07:59:37 status = response.status 07:59:37 07:59:37 history = self.history + ( 07:59:37 RequestHistory(method, url, error, status, redirect_location), 07:59:37 ) 07:59:37 07:59:37 new_retry = self.new( 07:59:37 total=total, 07:59:37 connect=connect, 07:59:37 read=read, 07:59:37 redirect=redirect, 07:59:37 status=status_count, 07:59:37 other=other, 07:59:37 history=history, 07:59:37 ) 07:59:37 07:59:37 if new_retry.is_exhausted(): 07:59:37 reason = error or ResponseError(cause) 07:59:37 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 07:59:37 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 07:59:37 07:59:37 During handling of the above exception, another exception occurred: 07:59:37 07:59:37 self = 07:59:37 07:59:37 def test_10_xpdr_device_disconnection(self): 07:59:37 > response = test_utils.unmount_device("XPDR-OC") 07:59:37 07:59:37 transportpce_tests/oc/test01_portmapping.py:138: 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 transportpce_tests/common/test_utils.py:374: in unmount_device 07:59:37 response = delete_request(url[RESTCONF_VERSION].format('{}', node)) 07:59:37 transportpce_tests/common/test_utils.py:133: in delete_request 07:59:37 return requests.request( 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/api.py:59: in request 07:59:37 return session.request(method=method, url=url, **kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:589: in request 07:59:37 resp = self.send(prep, **send_kwargs) 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/sessions.py:703: in send 07:59:37 r = adapter.send(request, **kwargs) 07:59:37 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:59:37 07:59:37 self = 07:59:37 request = , stream = False 07:59:37 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 07:59:37 proxies = OrderedDict() 07:59:37 07:59:37 def send( 07:59:37 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 07:59:37 ): 07:59:37 """Sends PreparedRequest object. Returns Response object. 07:59:37 07:59:37 :param request: The :class:`PreparedRequest ` being sent. 07:59:37 :param stream: (optional) Whether to stream the request content. 07:59:37 :param timeout: (optional) How long to wait for the server to send 07:59:37 data before giving up, as a float, or a :ref:`(connect timeout, 07:59:37 read timeout) ` tuple. 07:59:37 :type timeout: float or tuple or urllib3 Timeout object 07:59:37 :param verify: (optional) Either a boolean, in which case it controls whether 07:59:37 we verify the server's TLS certificate, or a string, in which case it 07:59:37 must be a path to a CA bundle to use 07:59:37 :param cert: (optional) Any user-provided SSL certificate to be trusted. 07:59:37 :param proxies: (optional) The proxies dictionary to apply to the request. 07:59:37 :rtype: requests.Response 07:59:37 """ 07:59:37 07:59:37 try: 07:59:37 conn = self.get_connection_with_tls_context( 07:59:37 request, verify, proxies=proxies, cert=cert 07:59:37 ) 07:59:37 except LocationValueError as e: 07:59:37 raise InvalidURL(e, request=request) 07:59:37 07:59:37 self.cert_verify(conn, request.url, verify, cert) 07:59:37 url = self.request_url(request, proxies) 07:59:37 self.add_headers( 07:59:37 request, 07:59:37 stream=stream, 07:59:37 timeout=timeout, 07:59:37 verify=verify, 07:59:37 cert=cert, 07:59:37 proxies=proxies, 07:59:37 ) 07:59:37 07:59:37 chunked = not (request.body is None or "Content-Length" in request.headers) 07:59:37 07:59:37 if isinstance(timeout, tuple): 07:59:37 try: 07:59:37 connect, read = timeout 07:59:37 timeout = TimeoutSauce(connect=connect, read=read) 07:59:37 except ValueError: 07:59:37 raise ValueError( 07:59:37 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 07:59:37 f"or a single float to set both timeouts to the same value." 07:59:37 ) 07:59:37 elif isinstance(timeout, TimeoutSauce): 07:59:37 pass 07:59:37 else: 07:59:37 timeout = TimeoutSauce(connect=timeout, read=timeout) 07:59:37 07:59:37 try: 07:59:37 resp = conn.urlopen( 07:59:37 method=request.method, 07:59:37 url=url, 07:59:37 body=request.body, 07:59:37 headers=request.headers, 07:59:37 redirect=False, 07:59:37 assert_same_host=False, 07:59:37 preload_content=False, 07:59:37 decode_content=False, 07:59:37 retries=self.max_retries, 07:59:37 timeout=timeout, 07:59:37 chunked=chunked, 07:59:37 ) 07:59:37 07:59:37 except (ProtocolError, OSError) as err: 07:59:37 raise ConnectionError(err, request=request) 07:59:37 07:59:37 except MaxRetryError as e: 07:59:37 if isinstance(e.reason, ConnectTimeoutError): 07:59:37 # TODO: Remove this in 3.0.0: see #2811 07:59:37 if not isinstance(e.reason, NewConnectionError): 07:59:37 raise ConnectTimeout(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, ResponseError): 07:59:37 raise RetryError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _ProxyError): 07:59:37 raise ProxyError(e, request=request) 07:59:37 07:59:37 if isinstance(e.reason, _SSLError): 07:59:37 # This branch is for urllib3 v1.22 and later. 07:59:37 raise SSLError(e, request=request) 07:59:37 07:59:37 > raise ConnectionError(e, request=request) 07:59:37 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDR-OC (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 07:59:37 07:59:37 ../.tox/tests190/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 07:59:37 ----------------------------- Captured stdout call ----------------------------- 07:59:37 execution of test_10_xpdr_device_disconnection 07:59:37 =========================== short test summary info ============================ 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_01_meta_data_insertion 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_02_catlog_input_insertion 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_03_xpdr_device_connection 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_04_xpdr_device_connected 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_05_xpdr_portmapping_info 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_06_mpdr_portmapping_NETWORK1 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_07_mpdr_portmapping_CLIENT1 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_08_mpdr_switching_pool 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_09_check_mccapprofile 07:59:37 FAILED transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_10_xpdr_device_disconnection 07:59:37 ERROR transportpce_tests/oc/test01_portmapping.py::TransportpceOCPortMappingTesting::test_10_xpdr_device_disconnection 07:59:37 10 failed, 1 error in 220.53s (0:03:40) 07:59:37 tests190: exit 1 (220.78 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc pid=32206 08:00:36 ................................................... [100%] 08:05:46 51 passed in 394.74s (0:06:34) 08:05:46 pytest -q transportpce_tests/tapi/test02_full_topology.py 08:06:56 ............................... [100%] 08:10:39 31 passed in 292.08s (0:04:52) 08:10:39 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 08:11:42 ....................................................................... [100%] 08:15:28 71 passed in 289.14s (0:04:49) 08:15:28 pytest -q transportpce_tests/tapi/test04_topo_extension.py 08:16:35 ................... [100%] 08:20:53 19 passed in 324.37s (0:05:24) 08:20:53 tests190: FAIL ✖ in 3 minutes 48.86 seconds 08:20:53 tests_tapi: OK ✔ in 21 minutes 48.06 seconds 08:20:53 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 08:20:58 tests71: freeze> python -m pip freeze --all 08:20:59 tests71: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 08:20:59 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 08:20:59 using environment variables from ./karaf71.env 08:20:59 pytest -q transportpce_tests/7.1/test01_portmapping.py 08:21:33 ............ [100%] 08:21:46 12 passed in 47.41s 08:21:46 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 08:22:15 .............................................................. [100%] 08:24:26 62 passed in 158.98s (0:02:38) 08:24:26 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 08:24:58 ................................................ [100%] 08:26:43 48 passed in 136.99s (0:02:16) 08:26:43 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 08:27:10 ...................... [100%] 08:27:58 22 passed in 74.92s (0:01:14) 08:27:58 tests71: OK ✔ in 7 minutes 5.07 seconds 08:27:58 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 08:28:08 tests221: freeze> python -m pip freeze --all 08:28:08 tests221: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 08:28:08 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 08:28:08 using environment variables from ./karaf221.env 08:28:08 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 08:28:46 ................................... [100%] 08:29:26 35 passed in 78.00s (0:01:17) 08:29:26 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 08:29:57 ...... [100%] 08:30:11 6 passed in 44.40s 08:30:11 pytest -q transportpce_tests/2.2.1/test03_topology.py 08:30:53 ............................................ [100%] 08:32:28 44 passed in 136.71s (0:02:16) 08:32:28 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 08:33:02 ............ [100%] 08:33:27 12 passed in 58.69s 08:33:27 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 08:33:52 ................ [100%] 08:35:21 16 passed in 113.96s (0:01:53) 08:35:21 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 08:35:51 ............................... [100%] 08:35:57 31 passed in 35.87s 08:35:57 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 08:36:32 .......................... [100%] 08:37:28 26 passed in 90.84s (0:01:30) 08:37:28 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 08:38:04 ...................... [100%] 08:39:07 22 passed in 98.86s (0:01:38) 08:39:07 pytest -q transportpce_tests/2.2.1/test09_olm.py 08:39:47 ........................................ [100%] 08:42:09 40 passed in 181.37s (0:03:01) 08:42:09 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 08:42:51 ........................................................................ [ 74%] 08:48:27 ......................... [100%] 08:50:19 97 passed in 490.18s (0:08:10) 08:50:19 pytest -q transportpce_tests/2.2.1/test12_end2end.py 08:50:57 ...................................................... [100%] 09:00:44 54 passed in 624.55s (0:10:24) 09:00:44 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 09:01:39 ........................................................................ [ 71%] 09:06:48 ............................. [100%] 09:08:57 101 passed in 493.02s (0:08:13) 09:08:57 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 09:09:51 ........................................................................ [ 67%] 09:15:37 ................................... [100%] 09:18:57 107 passed in 600.02s (0:10:00) 09:18:57 tests221: OK ✔ in 50 minutes 59.29 seconds 09:18:57 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 09:19:04 tests121: freeze> python -m pip freeze --all 09:19:05 tests121: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 09:19:05 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 09:19:05 using environment variables from ./karaf121.env 09:19:05 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 09:19:42 ..................... [100%] 09:20:31 21 passed in 86.47s (0:01:26) 09:20:32 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 09:21:03 ...... [100%] 09:21:16 6 passed in 44.64s 09:21:16 pytest -q transportpce_tests/1.2.1/test03_topology.py 09:21:59 ............................................ [100%] 09:23:34 44 passed in 137.22s (0:02:17) 09:23:34 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 09:24:05 ........................ [100%] 09:24:56 24 passed in 82.44s (0:01:22) 09:24:56 pytest -q transportpce_tests/1.2.1/test05_olm.py 09:25:37 ........................................ [100%] 09:27:58 40 passed in 181.48s (0:03:01) 09:27:58 pytest -q transportpce_tests/1.2.1/test06_end2end.py 09:28:37 ...................................................... [100%] 09:36:52 54 passed in 533.76s (0:08:53) 09:36:52 tests121: OK ✔ in 17 minutes 54.92 seconds 09:36:52 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 09:36:58 tests_hybrid: freeze> python -m pip freeze --all 09:36:58 tests_hybrid: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 09:36:58 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 09:36:58 using environment variables from ./karaf121.env 09:36:58 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 09:37:43 ................................................... [100%] 09:39:30 51 passed in 151.65s (0:02:31) 09:39:30 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 09:40:12 ........................................................................ [ 66%] 09:44:32 ..................................... [100%] 09:49:38 109 passed in 608.27s (0:10:08) 09:49:38 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 09:50:25 ..................................................... [100%] 09:56:57 53 passed in 439.13s (0:07:19) 09:56:58 tests_hybrid: OK ✔ in 20 minutes 5.33 seconds 09:56:58 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 09:57:04 buildlighty: freeze> python -m pip freeze --all 09:57:04 buildlighty: bcrypt==4.2.1,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==44.0.0,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.2,packaging==24.2,paramiko==3.5.0,pip==24.3.1,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.4,requests==2.32.3,setuptools==75.6.0,urllib3==2.2.3,wheel==0.45.1 09:57:04 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 09:57:04 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 09:57:24 buildcontroller: OK (114.56=setup[7.44]+cmd[107.12] seconds) 09:57:24 testsPCE: OK (336.65=setup[103.40]+cmd[233.25] seconds) 09:57:24 sims: OK (11.48=setup[6.94]+cmd[4.54] seconds) 09:57:24 build_karaf_tests121: OK (67.21=setup[7.18]+cmd[60.04] seconds) 09:57:24 tests121: OK (1074.92=setup[7.50]+cmd[1067.42] seconds) 09:57:24 build_karaf_tests221: OK (67.62=setup[7.09]+cmd[60.54] seconds) 09:57:24 tests_tapi: OK (1308.06=setup[6.53]+cmd[1301.52] seconds) 09:57:24 tests221: OK (3059.29=setup[9.83]+cmd[3049.45] seconds) 09:57:24 build_karaf_tests71: OK (65.65=setup[22.31]+cmd[43.34] seconds) 09:57:24 tests71: OK (425.07=setup[5.78]+cmd[419.29] seconds) 09:57:24 build_karaf_tests190: OK (72.50=setup[18.58]+cmd[53.92] seconds) 09:57:24 tests190: FAIL code 1 (228.86=setup[8.08]+cmd[220.78] seconds) 09:57:24 build_karaf_tests_hybrid: OK (70.26=setup[18.09]+cmd[52.18] seconds) 09:57:24 tests_hybrid: OK (1205.33=setup[5.61]+cmd[1199.72] seconds) 09:57:24 buildlighty: OK (25.98=setup[6.39]+cmd[19.59] seconds) 09:57:24 docs: OK (33.89=setup[31.34]+cmd[2.55] seconds) 09:57:24 docs-linkcheck: FAIL code 1 (36.38=setup[31.43]+cmd[4.96] seconds) 09:57:24 checkbashisms: OK (2.74=setup[1.77]+cmd[0.02,0.05,0.90] seconds) 09:57:24 pre-commit: FAIL code 1 (38.25=setup[2.86]+cmd[0.00,0.00,35.39] seconds) 09:57:24 pylint: OK (29.45=setup[6.13]+cmd[23.32] seconds) 09:57:24 evaluation failed :( (7549.94 seconds) 09:57:24 + tox_status=255 09:57:24 + echo '---> Completed tox runs' 09:57:24 ---> Completed tox runs 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/build_karaf_tests121/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=build_karaf_tests121 09:57:24 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/build_karaf_tests190/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=build_karaf_tests190 09:57:24 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/build_karaf_tests221/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=build_karaf_tests221 09:57:24 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/build_karaf_tests71/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=build_karaf_tests71 09:57:24 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/build_karaf_tests_hybrid/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=build_karaf_tests_hybrid 09:57:24 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/buildcontroller/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=buildcontroller 09:57:24 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/buildlighty/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=buildlighty 09:57:24 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/checkbashisms/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=checkbashisms 09:57:24 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/docs-linkcheck/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=docs-linkcheck 09:57:24 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/docs/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=docs 09:57:24 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/pre-commit/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=pre-commit 09:57:24 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/pylint/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=pylint 09:57:24 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/sims/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=sims 09:57:24 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests121/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests121 09:57:24 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests190/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests190 09:57:24 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests221/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests221 09:57:24 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests71/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests71 09:57:24 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/testsPCE/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=testsPCE 09:57:24 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests_hybrid/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests_hybrid 09:57:24 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 09:57:24 + for i in .tox/*/log 09:57:24 ++ echo .tox/tests_tapi/log 09:57:24 ++ awk -F/ '{print $2}' 09:57:24 + tox_env=tests_tapi 09:57:24 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 09:57:24 + DOC_DIR=docs/_build/html 09:57:24 + [[ -d docs/_build/html ]] 09:57:24 + echo '---> Archiving generated docs' 09:57:24 ---> Archiving generated docs 09:57:24 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 09:57:24 + echo '---> tox-run.sh ends' 09:57:24 ---> tox-run.sh ends 09:57:24 + test 255 -eq 0 09:57:24 + exit 255 09:57:24 ++ '[' 1 = 1 ']' 09:57:24 ++ '[' -x /usr/bin/clear_console ']' 09:57:24 ++ /usr/bin/clear_console -q 09:57:24 Build step 'Execute shell' marked build as failure 09:57:24 $ ssh-agent -k 09:57:24 unset SSH_AUTH_SOCK; 09:57:24 unset SSH_AGENT_PID; 09:57:24 echo Agent pid 11682 killed; 09:57:24 [ssh-agent] Stopped. 09:57:24 [PostBuildScript] - [INFO] Executing post build scripts. 09:57:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12138219080829705063.sh 09:57:24 ---> sysstat.sh 09:57:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9585793934728713281.sh 09:57:24 ---> package-listing.sh 09:57:24 ++ facter osfamily 09:57:24 ++ tr '[:upper:]' '[:lower:]' 09:57:25 + OS_FAMILY=debian 09:57:25 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 09:57:25 + START_PACKAGES=/tmp/packages_start.txt 09:57:25 + END_PACKAGES=/tmp/packages_end.txt 09:57:25 + DIFF_PACKAGES=/tmp/packages_diff.txt 09:57:25 + PACKAGES=/tmp/packages_start.txt 09:57:25 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:57:25 + PACKAGES=/tmp/packages_end.txt 09:57:25 + case "${OS_FAMILY}" in 09:57:25 + dpkg -l 09:57:25 + grep '^ii' 09:57:25 + '[' -f /tmp/packages_start.txt ']' 09:57:25 + '[' -f /tmp/packages_end.txt ']' 09:57:25 + diff /tmp/packages_start.txt /tmp/packages_end.txt 09:57:25 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:57:25 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:57:25 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:57:25 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11878376908735710452.sh 09:57:25 ---> capture-instance-metadata.sh 09:57:25 Setup pyenv: 09:57:25 system 09:57:25 3.8.20 09:57:25 3.9.20 09:57:25 3.10.15 09:57:25 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:57:25 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mp7M from file:/tmp/.os_lf_venv 09:57:26 lf-activate-venv(): INFO: Installing: lftools 09:57:37 lf-activate-venv(): INFO: Adding /tmp/venv-mp7M/bin to PATH 09:57:37 INFO: Running in OpenStack, capturing instance metadata 09:57:38 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4046513799323020499.sh 09:57:38 provisioning config files... 09:57:38 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #2284 09:57:38 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config3234415063199563119tmp 09:57:38 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 09:57:38 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 09:57:38 provisioning config files... 09:57:39 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 09:57:39 [EnvInject] - Injecting environment variables from a build step. 09:57:39 [EnvInject] - Injecting as environment variables the properties content 09:57:39 SERVER_ID=logs 09:57:39 09:57:39 [EnvInject] - Variables injected successfully. 09:57:39 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10598691210242746021.sh 09:57:39 ---> create-netrc.sh 09:57:39 WARN: Log server credential not found. 09:57:39 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins208369262405106593.sh 09:57:39 ---> python-tools-install.sh 09:57:39 Setup pyenv: 09:57:39 system 09:57:39 3.8.20 09:57:39 3.9.20 09:57:39 3.10.15 09:57:39 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:57:39 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mp7M from file:/tmp/.os_lf_venv 09:57:40 lf-activate-venv(): INFO: Installing: lftools 09:57:48 lf-activate-venv(): INFO: Adding /tmp/venv-mp7M/bin to PATH 09:57:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12573058361647488302.sh 09:57:49 ---> sudo-logs.sh 09:57:49 Archiving 'sudo' log.. 09:57:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10044546575197133840.sh 09:57:49 ---> job-cost.sh 09:57:49 Setup pyenv: 09:57:49 system 09:57:49 3.8.20 09:57:49 3.9.20 09:57:49 3.10.15 09:57:49 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:57:49 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mp7M from file:/tmp/.os_lf_venv 09:57:50 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 09:57:57 lf-activate-venv(): INFO: Adding /tmp/venv-mp7M/bin to PATH 09:57:57 INFO: No Stack... 09:57:58 INFO: Retrieving Pricing Info for: v3-standard-4 09:57:58 INFO: Archiving Costs 09:57:58 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins16780566965763369576.sh 09:57:58 ---> logs-deploy.sh 09:57:58 Setup pyenv: 09:57:58 system 09:57:58 3.8.20 09:57:58 3.9.20 09:57:58 3.10.15 09:57:58 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:57:58 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mp7M from file:/tmp/.os_lf_venv 09:57:59 lf-activate-venv(): INFO: Installing: lftools 09:58:08 lf-activate-venv(): INFO: Adding /tmp/venv-mp7M/bin to PATH 09:58:08 WARNING: Nexus logging server not set 09:58:08 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/2284/ 09:58:08 INFO: archiving logs to S3 09:58:10 ---> uname -a: 09:58:10 Linux prd-ubuntu2004-docker-4c-16g-123 5.4.0-200-generic #220-Ubuntu SMP Fri Sep 27 13:19:16 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 09:58:10 09:58:10 09:58:10 ---> lscpu: 09:58:10 Architecture: x86_64 09:58:10 CPU op-mode(s): 32-bit, 64-bit 09:58:10 Byte Order: Little Endian 09:58:10 Address sizes: 40 bits physical, 48 bits virtual 09:58:10 CPU(s): 4 09:58:10 On-line CPU(s) list: 0-3 09:58:10 Thread(s) per core: 1 09:58:10 Core(s) per socket: 1 09:58:10 Socket(s): 4 09:58:10 NUMA node(s): 1 09:58:10 Vendor ID: AuthenticAMD 09:58:10 CPU family: 23 09:58:10 Model: 49 09:58:10 Model name: AMD EPYC-Rome Processor 09:58:10 Stepping: 0 09:58:10 CPU MHz: 2800.000 09:58:10 BogoMIPS: 5600.00 09:58:10 Virtualization: AMD-V 09:58:10 Hypervisor vendor: KVM 09:58:10 Virtualization type: full 09:58:10 L1d cache: 128 KiB 09:58:10 L1i cache: 128 KiB 09:58:10 L2 cache: 2 MiB 09:58:10 L3 cache: 64 MiB 09:58:10 NUMA node0 CPU(s): 0-3 09:58:10 Vulnerability Gather data sampling: Not affected 09:58:10 Vulnerability Itlb multihit: Not affected 09:58:10 Vulnerability L1tf: Not affected 09:58:10 Vulnerability Mds: Not affected 09:58:10 Vulnerability Meltdown: Not affected 09:58:10 Vulnerability Mmio stale data: Not affected 09:58:10 Vulnerability Retbleed: Vulnerable 09:58:10 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 09:58:10 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 09:58:10 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 09:58:10 Vulnerability Srbds: Not affected 09:58:10 Vulnerability Tsx async abort: Not affected 09:58:10 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 09:58:10 09:58:10 09:58:10 ---> nproc: 09:58:10 4 09:58:10 09:58:10 09:58:10 ---> df -h: 09:58:10 Filesystem Size Used Avail Use% Mounted on 09:58:10 udev 7.8G 0 7.8G 0% /dev 09:58:10 tmpfs 1.6G 1.1M 1.6G 1% /run 09:58:10 /dev/vda1 78G 18G 60G 23% / 09:58:10 tmpfs 7.9G 0 7.9G 0% /dev/shm 09:58:10 tmpfs 5.0M 0 5.0M 0% /run/lock 09:58:10 tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup 09:58:10 /dev/loop1 68M 68M 0 100% /snap/lxd/22753 09:58:10 /dev/loop0 62M 62M 0 100% /snap/core20/1405 09:58:10 /dev/vda15 105M 6.1M 99M 6% /boot/efi 09:58:10 tmpfs 1.6G 0 1.6G 0% /run/user/1001 09:58:10 /dev/loop3 45M 45M 0 100% /snap/snapd/23258 09:58:10 /dev/loop4 64M 64M 0 100% /snap/core20/2434 09:58:10 /dev/loop5 92M 92M 0 100% /snap/lxd/29619 09:58:10 09:58:10 09:58:10 ---> free -m: 09:58:10 total used free shared buff/cache available 09:58:10 Mem: 15997 2216 4277 1 9503 13441 09:58:10 Swap: 1023 0 1023 09:58:10 09:58:10 09:58:10 ---> ip addr: 09:58:10 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 09:58:10 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 09:58:10 inet 127.0.0.1/8 scope host lo 09:58:10 valid_lft forever preferred_lft forever 09:58:10 inet6 ::1/128 scope host 09:58:10 valid_lft forever preferred_lft forever 09:58:10 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 09:58:10 link/ether fa:16:3e:af:f1:e6 brd ff:ff:ff:ff:ff:ff 09:58:10 inet 10.30.170.86/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 09:58:10 valid_lft 78681sec preferred_lft 78681sec 09:58:10 inet6 fe80::f816:3eff:feaf:f1e6/64 scope link 09:58:10 valid_lft forever preferred_lft forever 09:58:10 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 09:58:10 link/ether 02:42:2f:8e:20:b0 brd ff:ff:ff:ff:ff:ff 09:58:10 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 09:58:10 valid_lft forever preferred_lft forever 09:58:10 09:58:10 09:58:10 ---> sar -b -r -n DEV: 09:58:10 Linux 5.4.0-200-generic (prd-ubuntu2004-docker-4c-16g-123) 12/05/24 _x86_64_ (4 CPU) 09:58:10 09:58:10 07:49:34 LINUX RESTART (4 CPU) 09:58:10 09:58:10 07:50:02 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 09:58:10 07:51:02 350.13 159.21 190.92 0.00 12013.56 18476.60 0.00 09:58:10 07:52:01 186.57 28.24 158.33 0.00 1986.86 22215.87 0.00 09:58:10 07:53:01 125.69 15.53 110.16 0.00 826.92 43754.75 0.00 09:58:10 07:54:01 96.20 1.08 95.12 0.00 53.19 55638.06 0.00 09:58:10 07:55:01 150.49 2.33 148.16 0.00 2013.53 130366.54 0.00 09:58:10 07:56:01 186.97 13.83 173.14 0.00 2879.97 88053.72 0.00 09:58:10 07:57:01 70.90 0.55 70.35 0.00 35.99 9943.94 0.00 09:58:10 07:58:01 80.46 0.10 80.36 0.00 4.00 1572.14 0.00 09:58:10 07:59:01 124.63 0.03 124.60 0.00 0.53 2094.72 0.00 09:58:10 08:00:01 135.63 0.37 135.26 0.00 26.13 11582.47 0.00 09:58:10 08:01:01 59.48 4.02 55.46 0.00 503.97 1159.21 0.00 09:58:10 08:02:01 5.15 0.35 4.80 0.00 5.33 145.18 0.00 09:58:10 08:03:01 2.73 0.00 2.73 0.00 0.00 50.66 0.00 09:58:10 08:04:01 2.30 0.00 2.30 0.00 0.00 28.40 0.00 09:58:10 08:05:01 3.90 1.15 2.75 0.00 32.93 38.39 0.00 09:58:10 08:06:01 28.16 1.37 26.79 0.00 149.68 1240.79 0.00 09:58:10 08:07:01 83.45 0.02 83.44 0.00 1.07 2272.69 0.00 09:58:10 08:08:01 3.25 0.00 3.25 0.00 0.00 77.05 0.00 09:58:10 08:09:01 2.38 0.00 2.38 0.00 0.00 44.65 0.00 09:58:10 08:10:01 3.68 0.00 3.68 0.00 0.00 63.32 0.00 09:58:10 08:11:01 91.73 0.02 91.72 0.00 0.13 2418.53 0.00 09:58:10 08:12:01 73.34 0.00 73.34 0.00 0.00 1856.22 0.00 09:58:10 08:13:01 2.37 0.00 2.37 0.00 0.00 60.51 0.00 09:58:10 08:14:01 3.35 0.00 3.35 0.00 0.00 58.66 0.00 09:58:10 08:15:01 2.15 0.00 2.15 0.00 0.00 46.79 0.00 09:58:10 08:16:01 142.14 0.00 142.14 0.00 0.00 3491.90 0.00 09:58:10 08:17:01 58.78 0.05 58.73 0.00 1.07 1197.60 0.00 09:58:10 08:18:01 2.53 0.00 2.53 0.00 0.00 35.99 0.00 09:58:10 08:19:01 1.72 0.00 1.72 0.00 0.00 22.13 0.00 09:58:10 08:20:01 2.13 0.00 2.13 0.00 0.00 25.86 0.00 09:58:10 08:21:01 71.74 0.15 71.59 0.00 8.13 1879.82 0.00 09:58:10 08:22:01 109.62 0.07 109.55 0.00 1.07 10937.51 0.00 09:58:10 08:23:01 55.29 0.00 55.29 0.00 0.00 829.73 0.00 09:58:10 08:24:01 2.87 0.00 2.87 0.00 0.00 48.92 0.00 09:58:10 08:25:01 73.74 0.00 73.74 0.00 0.00 1099.82 0.00 09:58:10 08:26:01 3.25 0.00 3.25 0.00 0.00 58.92 0.00 09:58:10 08:27:01 37.25 0.00 37.25 0.00 0.00 510.10 0.00 09:58:10 08:28:01 45.89 0.02 45.88 0.00 0.13 740.41 0.00 09:58:10 08:29:01 85.30 0.00 85.30 0.00 0.00 3681.39 0.00 09:58:10 08:30:01 68.96 0.00 68.96 0.00 0.00 1047.16 0.00 09:58:10 08:31:01 65.57 0.02 65.56 0.00 0.13 1014.90 0.00 09:58:10 08:32:01 2.48 0.00 2.48 0.00 0.00 43.33 0.00 09:58:10 08:33:01 62.46 0.00 62.46 0.00 0.00 950.24 0.00 09:58:10 08:34:01 74.14 0.00 74.14 0.00 0.00 1105.10 0.00 09:58:10 08:35:01 2.07 0.00 2.07 0.00 0.00 33.59 0.00 09:58:10 08:36:01 24.31 0.00 24.31 0.00 0.00 529.25 0.00 09:58:10 08:37:01 33.55 0.00 33.55 0.00 0.00 446.67 0.00 09:58:10 08:38:01 45.06 0.00 45.06 0.00 0.00 710.81 0.00 09:58:10 08:39:01 2.50 0.00 2.50 0.00 0.00 47.73 0.00 09:58:10 08:40:01 43.55 0.00 43.55 0.00 0.00 691.77 0.00 09:58:10 08:41:01 3.28 0.00 3.28 0.00 0.00 64.79 0.00 09:58:10 08:42:01 4.30 0.00 4.30 0.00 0.00 71.19 0.00 09:58:10 08:43:01 67.37 0.00 67.37 0.00 0.00 1026.10 0.00 09:58:10 08:44:01 3.82 0.00 3.82 0.00 0.00 68.92 0.00 09:58:10 08:45:01 2.38 0.00 2.38 0.00 0.00 38.13 0.00 09:58:10 08:46:01 2.45 0.00 2.45 0.00 0.00 39.73 0.00 09:58:10 08:47:01 2.80 0.00 2.80 0.00 0.00 51.06 0.00 09:58:10 08:48:01 3.60 0.00 3.60 0.00 0.00 66.12 0.00 09:58:10 08:49:01 2.35 0.00 2.35 0.00 0.00 38.79 0.00 09:58:10 08:50:01 3.12 0.00 3.12 0.00 0.00 52.39 0.00 09:58:10 08:51:01 46.09 0.00 46.09 0.00 0.00 753.21 0.00 09:58:10 08:52:01 2.47 0.00 2.47 0.00 0.00 61.06 0.00 09:58:10 08:53:01 2.02 0.00 2.02 0.00 0.00 34.26 0.00 09:58:10 08:54:01 2.20 0.00 2.20 0.00 0.00 55.59 0.00 09:58:10 08:55:01 2.30 0.00 2.30 0.00 0.00 42.39 0.00 09:58:10 08:56:01 1.98 0.00 1.98 0.00 0.00 46.26 0.00 09:58:10 08:57:01 2.12 0.00 2.12 0.00 0.00 48.53 0.00 09:58:10 08:58:01 2.12 0.00 2.12 0.00 0.00 53.72 0.00 09:58:10 08:59:01 1.90 0.00 1.90 0.00 0.00 22.66 0.00 09:58:10 09:00:01 1.98 0.00 1.98 0.00 0.00 25.60 0.00 09:58:10 09:01:01 25.78 0.00 25.78 0.00 0.00 433.93 0.00 09:58:10 09:02:01 44.83 0.00 44.83 0.00 0.00 682.82 0.00 09:58:10 09:03:01 2.05 0.00 2.05 0.00 0.00 38.53 0.00 09:58:10 09:04:01 2.80 0.00 2.80 0.00 0.00 54.52 0.00 09:58:10 09:05:01 2.08 0.00 2.08 0.00 0.00 41.59 0.00 09:58:10 09:06:01 2.00 0.00 2.00 0.00 0.00 43.99 0.00 09:58:10 09:07:01 2.55 0.00 2.55 0.00 0.00 49.19 0.00 09:58:10 09:08:01 2.10 0.00 2.10 0.00 0.00 43.99 0.00 09:58:10 09:09:01 16.08 0.00 16.08 0.00 0.00 290.17 0.00 09:58:10 09:10:01 65.11 0.00 65.11 0.00 0.00 983.44 0.00 09:58:10 09:11:01 2.13 0.00 2.13 0.00 0.00 40.79 0.00 09:58:10 09:12:01 2.10 0.00 2.10 0.00 0.00 50.26 0.00 09:58:10 09:13:01 2.20 0.00 2.20 0.00 0.00 45.33 0.00 09:58:10 09:14:02 1.88 0.00 1.88 0.00 0.00 33.73 0.00 09:58:10 09:15:01 2.52 0.00 2.52 0.00 0.00 44.33 0.00 09:58:10 09:16:01 1.90 0.00 1.90 0.00 0.00 36.12 0.00 09:58:10 09:17:01 2.28 0.00 2.28 0.00 0.00 41.73 0.00 09:58:10 09:18:01 3.08 0.00 3.08 0.00 0.00 47.86 0.00 09:58:10 09:19:01 3.47 0.00 3.47 0.00 0.00 151.57 0.00 09:58:10 09:20:01 99.23 0.00 99.23 0.00 0.00 10745.14 0.00 09:58:10 09:21:01 65.02 0.00 65.02 0.00 0.00 1423.50 0.00 09:58:10 09:22:01 65.26 0.00 65.26 0.00 0.00 1131.41 0.00 09:58:10 09:23:01 2.08 0.00 2.08 0.00 0.00 38.79 0.00 09:58:10 09:24:01 45.56 0.00 45.56 0.00 0.00 709.35 0.00 09:58:10 09:25:01 46.29 0.00 46.29 0.00 0.00 707.08 0.00 09:58:10 09:26:01 64.61 0.00 64.61 0.00 0.00 923.31 0.00 09:58:10 09:27:01 3.07 0.00 3.07 0.00 0.00 62.26 0.00 09:58:10 09:28:01 3.13 0.00 3.13 0.00 0.00 56.79 0.00 09:58:10 09:29:01 66.61 0.00 66.61 0.00 0.00 1018.90 0.00 09:58:10 09:30:01 2.93 0.00 2.93 0.00 0.00 64.12 0.00 09:58:10 09:31:01 2.57 0.00 2.57 0.00 0.00 51.46 0.00 09:58:10 09:32:01 2.55 0.00 2.55 0.00 0.00 45.73 0.00 09:58:10 09:33:01 1.83 0.00 1.83 0.00 0.00 38.26 0.00 09:58:10 09:34:01 1.85 0.00 1.85 0.00 0.00 38.93 0.00 09:58:10 09:35:01 2.07 0.00 2.07 0.00 0.00 36.66 0.00 09:58:10 09:36:01 2.23 0.00 2.23 0.00 0.00 48.39 0.00 09:58:10 09:37:01 7.40 0.00 7.40 0.00 0.00 330.16 0.00 09:58:10 09:38:01 102.10 0.00 102.10 0.00 0.00 10495.72 0.00 09:58:10 09:39:01 3.32 0.00 3.32 0.00 0.00 101.98 0.00 09:58:10 09:40:01 25.33 0.00 25.33 0.00 0.00 838.39 0.00 09:58:10 09:41:01 45.74 0.00 45.74 0.00 0.00 673.22 0.00 09:58:10 09:42:01 3.37 0.00 3.37 0.00 0.00 54.79 0.00 09:58:10 09:43:01 2.28 0.00 2.28 0.00 0.00 35.46 0.00 09:58:10 09:44:01 3.08 0.00 3.08 0.00 0.00 49.33 0.00 09:58:10 09:45:01 2.07 0.00 2.07 0.00 0.00 39.73 0.00 09:58:10 09:46:01 3.40 0.00 3.40 0.00 0.00 57.32 0.00 09:58:10 09:47:01 2.08 0.00 2.08 0.00 0.00 41.06 0.00 09:58:10 09:48:01 2.32 0.00 2.32 0.00 0.00 28.26 0.00 09:58:10 09:49:01 1.65 0.00 1.65 0.00 0.00 19.73 0.00 09:58:10 09:50:01 23.48 0.00 23.48 0.00 0.00 659.62 0.00 09:58:10 09:51:01 49.09 0.00 49.09 0.00 0.00 724.81 0.00 09:58:10 09:52:01 2.40 0.00 2.40 0.00 0.00 175.70 0.00 09:58:10 09:53:01 2.50 0.00 2.50 0.00 0.00 76.52 0.00 09:58:10 09:54:01 2.22 0.00 2.22 0.00 0.00 53.99 0.00 09:58:10 09:55:01 2.03 0.00 2.03 0.00 0.00 31.19 0.00 09:58:10 09:56:01 2.10 0.00 2.10 0.00 0.00 26.00 0.00 09:58:10 09:57:01 3.53 0.00 3.53 0.00 0.00 149.58 0.00 09:58:10 09:58:01 71.67 17.40 54.27 0.00 1263.52 32513.78 0.00 09:58:10 Average: 32.60 1.90 30.70 0.00 168.63 3860.22 0.00 09:58:10 09:58:10 07:50:02 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 09:58:10 07:51:02 13389072 15438872 540604 3.30 68616 2178744 1294264 7.43 793800 1920940 154488 09:58:10 07:52:01 11110740 14627608 1329304 8.11 119944 3493204 2183536 12.53 1825108 3043316 1036176 09:58:10 07:53:01 10124948 14055440 1900836 11.60 137528 3853796 2576796 14.78 2401284 3417488 148720 09:58:10 07:54:01 7711088 13674472 2279980 13.92 171548 5763948 3083132 17.69 3277300 4862228 516860 09:58:10 07:55:01 6074268 14511376 1435912 8.77 198036 8110112 2433140 13.96 3252248 6414812 184720 09:58:10 07:56:01 3966912 14038528 1902868 11.62 227608 9653356 2643260 15.17 4342760 7359036 78852 09:58:10 07:57:01 2482160 12735336 3206424 19.57 233568 9821272 3948392 22.65 5711876 7465668 136 09:58:10 07:58:01 2782220 13039488 2902152 17.72 236696 9821956 4043180 23.20 5441740 7435284 1548 09:58:10 07:59:01 2660572 12923732 3018060 18.42 242020 9822428 3839760 22.03 5564988 7434256 404 09:58:10 08:00:01 1689680 12223292 3717848 22.70 252504 10067820 4995160 28.66 6358216 7595868 2720 09:58:10 08:01:01 165468 8192628 7745812 47.28 246812 7608872 8838380 50.71 10065828 5435840 1328 09:58:10 08:02:01 172908 8146104 7792612 47.57 246856 7555996 8887136 50.99 10093432 5402816 108 09:58:10 08:03:01 156780 8130420 7808224 47.67 246884 7556384 8887136 50.99 10107864 5403000 116 09:58:10 08:04:01 156452 8130104 7808540 47.67 246900 7556388 8903224 51.08 10107668 5402996 124 09:58:10 08:05:01 173516 8127864 7810504 47.68 247004 7537492 8955456 51.38 10109840 5383372 156 09:58:10 08:06:01 5588048 13094556 2846896 17.38 247276 7098760 3699384 21.22 5125328 4984780 1616 09:58:10 08:07:01 2817308 10327584 5612424 34.26 249272 7100448 6662816 38.23 7886276 4983808 548 09:58:10 08:08:01 2420772 9931624 6007980 36.68 249308 7100984 6843352 39.26 8281884 4983840 220 09:58:10 08:09:01 2386120 9897236 6042340 36.89 249332 7101224 6859384 39.35 8315788 4984012 164 09:58:10 08:10:01 2355280 9866928 6072572 37.07 249364 7101720 6859384 39.35 8345736 4984472 40 09:58:10 08:11:01 4390452 11904932 4035892 24.64 251616 7102272 6005128 34.45 6328776 4974544 1620 09:58:10 08:12:01 2710288 10226712 5713120 34.88 253140 7102844 6644836 38.12 8001008 4974548 540 09:58:10 08:13:01 2484172 10001172 5938376 36.25 253156 7103392 6777272 38.88 8229940 4974852 364 09:58:10 08:14:01 2449048 9966276 5973260 36.46 253172 7103600 6794468 38.98 8263812 4975000 240 09:58:10 08:15:01 2403064 9920692 6018852 36.74 253192 7103980 6810508 39.07 8307676 4975384 112 09:58:10 08:16:01 5637948 13157928 2783416 16.99 255004 7104568 3921448 22.50 5085472 4975348 2232 09:58:10 08:17:01 2457284 9979244 5960392 36.39 256528 7104996 6782960 38.92 8256968 4975592 148 09:58:10 08:18:01 2448504 9970576 5968968 36.44 256544 7105072 6782960 38.92 8264604 4975652 120 09:58:10 08:19:01 2448404 9970504 5969068 36.44 256564 7105076 6782960 38.92 8264460 4975656 72 09:58:10 08:20:01 2447924 9970044 5969496 36.44 256592 7105072 6782960 38.92 8264828 4975656 108 09:58:10 08:21:01 6170740 13771892 2168724 13.24 260252 7177020 3094632 17.75 4483656 5042280 72888 09:58:10 08:22:01 5331620 13112208 2828824 17.27 265044 7348580 3647580 20.93 5220060 5140340 1940 09:58:10 08:23:01 4466392 12248108 3692352 22.54 266076 7348764 4479372 25.70 6086400 5135644 64 09:58:10 08:24:01 4447688 12229556 3710972 22.65 266088 7348908 4495368 25.79 6105272 5135748 128 09:58:10 08:25:01 3677480 11460536 4479704 27.35 267128 7349024 5296640 30.39 6883700 5124372 512 09:58:10 08:26:01 3609156 11392456 4547552 27.76 267144 7349256 5329240 30.58 6951796 5124452 108 09:58:10 08:27:01 4900612 12684248 3256544 19.88 267312 7349400 4316400 24.76 5666148 5123920 400 09:58:10 08:28:01 6070408 13881044 2059860 12.57 269044 7372588 3162560 18.14 4475476 5146028 24836 09:58:10 08:29:01 3156036 11008016 4931692 30.11 270532 7410460 6096676 34.98 7339624 5183976 184 09:58:10 08:30:01 3772580 11625396 4314628 26.34 271060 7410720 5520292 31.67 6729684 5178400 236 09:58:10 08:31:01 2603556 10457256 5482228 33.47 271640 7411024 6863024 39.37 7903680 5169080 284 09:58:10 08:32:01 2252784 10106552 5832744 35.61 271644 7411084 6962100 39.94 8255992 5169124 324 09:58:10 08:33:01 4512996 12367268 3573132 21.81 272040 7411184 4661540 26.74 6003272 5168604 172 09:58:10 08:34:01 4410240 12265352 3675056 22.43 272628 7411388 4785508 27.46 6105580 5168480 252 09:58:10 08:35:01 4399860 12255012 3685284 22.50 272636 7411416 4785508 27.46 6116244 5168492 108 09:58:10 08:36:01 5702548 13558180 2382676 14.55 272676 7411820 3509448 20.13 4817284 5168596 428 09:58:10 08:37:01 4421972 12278080 3662172 22.36 272864 7412108 4761604 27.32 6093612 5168880 132 09:58:10 08:38:01 3820380 11676812 4263192 26.02 272968 7412324 5455300 31.30 6692796 5169048 284 09:58:10 08:39:01 3595712 11452312 4487436 27.39 272968 7412472 5553572 31.86 6916844 5169196 96 09:58:10 08:40:01 2369852 10226796 5712292 34.87 273112 7412668 6926140 39.74 8137960 5169172 376 09:58:10 08:41:01 2149216 10006412 5932500 36.21 273116 7412920 7024516 40.30 8358884 5169412 180 09:58:10 08:42:01 2125544 9983040 5955844 36.36 273120 7413216 7024516 40.30 8382092 5169704 196 09:58:10 08:43:01 2247608 10105600 5833452 35.61 273464 7413348 6898900 39.58 8261228 5169796 336 09:58:10 08:44:01 2143812 10002160 5936540 36.24 273476 7413692 6979796 40.04 8363432 5170140 200 09:58:10 08:45:01 2136480 9994928 5943872 36.28 273480 7413784 6995788 40.14 8369796 5170236 36 09:58:10 08:46:01 2112824 9971424 5967372 36.43 273492 7413924 7011804 40.23 8393712 5170376 228 09:58:10 08:47:01 2102272 9961068 5977716 36.49 273504 7414108 7011804 40.23 8403748 5170560 112 09:58:10 08:48:01 2064816 9924032 6014644 36.72 273512 7414516 7043932 40.41 8440052 5170964 196 09:58:10 08:49:01 2041080 9900412 6038284 36.86 273516 7414628 7059976 40.50 8463056 5171076 112 09:58:10 08:50:01 2034756 9894320 6044320 36.90 273520 7414872 7059976 40.50 8470568 5171300 128 09:58:10 08:51:01 2384752 10244516 5694476 34.76 273692 7414856 6926184 39.74 8123472 5171236 356 09:58:10 08:52:01 2184848 10045192 5893448 35.98 273692 7415432 7040676 40.39 8320320 5171812 304 09:58:10 08:53:01 2163852 10024644 5913988 36.10 273696 7415876 7040676 40.39 8339692 5172256 468 09:58:10 08:54:01 2136432 9997572 5941056 36.27 273696 7416228 7056724 40.49 8367124 5172604 264 09:58:10 08:55:01 2103956 9965528 5973192 36.46 273696 7416656 7056724 40.49 8399828 5173036 296 09:58:10 08:56:01 2093112 9955104 5983616 36.53 273696 7417076 7056724 40.49 8409812 5173456 356 09:58:10 08:57:01 2055036 9917760 6020892 36.75 273700 7417804 7089328 40.67 8446500 5174184 536 09:58:10 08:58:01 2052500 9915516 6023100 36.77 273708 7418088 7105332 40.77 8448400 5174468 236 09:58:10 08:59:01 2051980 9915004 6023576 36.77 273716 7418088 7105332 40.77 8449352 5174468 56 09:58:10 09:00:01 2050996 9914028 6024524 36.78 273716 7418092 7105332 40.77 8450624 5174472 136 09:58:10 09:01:01 4730000 12593124 3347140 20.43 273792 7418104 4743188 27.21 5780560 5174436 544 09:58:10 09:02:01 719196 8581940 7356216 44.91 274056 7417448 8456976 48.52 9778764 5173764 336 09:58:10 09:03:01 535872 8398984 7538988 46.02 274068 7417804 8556476 49.09 9960476 5174116 548 09:58:10 09:04:01 499668 8363244 7574592 46.24 274080 7418256 8589480 49.28 9995060 5174568 484 09:58:10 09:05:01 479272 8342972 7594860 46.36 274088 7418368 8621508 49.46 10016016 5174684 456 09:58:10 09:06:01 441740 8305764 7632044 46.59 274088 7418696 8621508 49.46 10053584 5175004 612 09:58:10 09:07:01 431912 8296120 7641688 46.65 274092 7418872 8621508 49.46 10062608 5175184 136 09:58:10 09:08:01 415720 8280296 7657480 46.75 274096 7419236 8637512 49.56 10078256 5175544 340 09:58:10 09:09:01 5649708 13514304 2426272 14.81 274108 7419224 3511988 20.15 4864308 5175500 448 09:58:10 09:10:01 1015188 8879812 7058488 43.09 274284 7419060 8288292 47.55 9483240 5175324 448 09:58:10 09:11:01 723124 8587928 7350156 44.87 274292 7419232 8419272 48.30 9773920 5175488 312 09:58:10 09:12:01 583608 8448960 7488960 45.72 274292 7419780 8501012 48.77 9912352 5176036 532 09:58:10 09:13:01 566156 8431708 7506104 45.82 274300 7419972 8501012 48.77 9928808 5176228 256 09:58:10 09:14:02 552108 8417756 7520048 45.91 274312 7420060 8501012 48.77 9942588 5176316 396 09:58:10 09:15:01 539792 8405616 7532252 45.98 274316 7420224 8501012 48.77 9954860 5176472 152 09:58:10 09:16:01 527412 8393432 7544528 46.06 274324 7420412 8501012 48.77 9965908 5176660 448 09:58:10 09:17:01 492872 8359052 7578904 46.27 274324 7420576 8550148 49.05 10001172 5176820 416 09:58:10 09:18:01 484120 8350540 7587216 46.32 274332 7420808 8550148 49.05 10008244 5177016 368 09:58:10 09:19:01 5943160 13836076 2104120 12.84 275444 7444184 3168840 18.18 4544416 5199904 24972 09:58:10 09:20:01 3438504 11561492 4378076 26.73 280724 7664188 5509224 31.61 6873936 5361868 1120 09:58:10 09:21:01 3750160 11873568 4066144 24.82 280920 7664460 5343168 30.66 6583948 5341960 208 09:58:10 09:22:01 2512080 10636032 5302828 32.37 281072 7664840 6747884 38.71 7827732 5329952 324 09:58:10 09:23:01 2063692 10187716 5751032 35.11 281072 7664904 6864812 39.39 8277516 5329936 132 09:58:10 09:24:01 3667340 11791576 4147944 25.32 281156 7665044 5484836 31.47 6681624 5329092 716 09:58:10 09:25:01 5408204 13532620 2407588 14.70 281260 7665072 3502016 20.09 4947608 5328588 312 09:58:10 09:26:01 2070768 10195888 5742656 35.06 281508 7665488 6963340 39.95 8270384 5328504 500 09:58:10 09:27:01 1830864 9956272 5982084 36.52 281524 7665760 7044780 40.42 8509252 5328728 68 09:58:10 09:28:01 5555564 13681060 2258868 13.79 281524 7665832 3428056 19.67 4799552 5328448 384 09:58:10 09:29:01 2016372 10142396 5795824 35.38 281636 7666184 6932632 39.77 8326892 5328052 372 09:58:10 09:30:01 1941844 10068140 5870168 35.83 281640 7666452 6932632 39.77 8400364 5328320 100 09:58:10 09:31:01 1823300 9950100 5988092 36.55 281644 7666952 7015804 40.25 8517496 5328788 288 09:58:10 09:32:01 1806904 9933956 6004220 36.65 281644 7667200 7015804 40.25 8534052 5329040 228 09:58:10 09:33:01 1790012 9917404 6020756 36.75 281648 7667540 7015804 40.25 8549968 5329376 240 09:58:10 09:34:01 1783460 9911360 6026780 36.79 281652 7668060 7015804 40.25 8555964 5329880 472 09:58:10 09:35:01 1778680 9906852 6031252 36.82 281656 7668308 7015804 40.25 8560104 5330148 248 09:58:10 09:36:01 1769624 9898132 6039968 36.87 281660 7668640 7031804 40.34 8568644 5330480 396 09:58:10 09:37:01 5413476 13621372 2318908 14.16 284116 7741196 3378884 19.39 4867384 5398136 75232 09:58:10 09:38:01 1570288 9956720 5981296 36.51 287964 7913304 7041036 40.40 8576788 5514904 2000 09:58:10 09:39:01 1447680 9834248 6103780 37.26 287964 7913440 7113752 40.81 8698292 5514864 184 09:58:10 09:40:01 2688184 11075184 4863576 29.69 288020 7913608 6641816 38.11 7479404 5496412 968 09:58:10 09:41:01 1582320 9969860 5968116 36.43 288128 7914044 6986136 40.08 8587012 5493300 392 09:58:10 09:42:01 1566060 9953796 5984168 36.53 288128 7914236 6986136 40.08 8603508 5493436 228 09:58:10 09:43:01 1540300 9928216 6009736 36.69 288132 7914412 7002156 40.17 8628232 5493608 224 09:58:10 09:44:01 1529692 9917816 6020220 36.75 288132 7914604 7034164 40.36 8637932 5493800 224 09:58:10 09:45:01 1510500 9898888 6039088 36.87 288136 7914864 7034164 40.36 8657636 5494060 340 09:58:10 09:46:01 1496364 9885080 6052880 36.95 288136 7915192 7034164 40.36 8670976 5494364 68 09:58:10 09:47:01 1471676 9860696 6077236 37.10 288140 7915496 7034164 40.36 8695344 5494664 112 09:58:10 09:48:01 1470552 9859584 6078352 37.11 288140 7915504 7034164 40.36 8696156 5494672 240 09:58:10 09:49:01 1469528 9858560 6079372 37.11 288140 7915504 7034164 40.36 8697572 5494672 224 09:58:10 09:50:01 3529316 11918244 4021040 24.55 288180 7915312 5389240 30.92 6655904 5482236 732 09:58:10 09:51:01 747740 9136840 6800804 41.52 288284 7915380 7801200 44.76 9429016 5482232 136 09:58:10 09:52:01 662128 9051856 6885768 42.03 288284 7915944 7850408 45.04 9512728 5482648 764 09:58:10 09:53:01 585024 8975508 6962064 42.50 288288 7916692 7850408 45.04 9588580 5483392 140 09:58:10 09:54:01 539884 8931028 7006472 42.77 288288 7917344 7898400 45.32 9633476 5484044 400 09:58:10 09:55:01 537988 8929136 7008396 42.78 288288 7917348 7898400 45.32 9634504 5484048 248 09:58:10 09:56:01 536852 8928024 7009536 42.79 288288 7917352 7898400 45.32 9636112 5484052 120 09:58:10 09:57:01 5358020 13776548 2163072 13.20 289392 7940916 3169908 18.19 4807132 5506260 25448 09:58:10 09:58:01 4462296 13814476 2125504 12.98 292728 8839584 3046208 17.48 4987288 6190716 19436 09:58:10 Average: 2706592 10631957 5307890 32.40 266520 7492670 6342046 36.39 7699956 5277814 18822 09:58:10 09:58:10 07:50:02 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 09:58:10 07:51:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:51:02 lo 0.81 0.81 0.08 0.08 0.00 0.00 0.00 0.00 09:58:10 07:51:02 ens3 411.63 285.02 1677.29 75.16 0.00 0.00 0.00 0.00 09:58:10 07:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:52:01 lo 3.93 3.93 0.38 0.38 0.00 0.00 0.00 0.00 09:58:10 07:52:01 ens3 357.49 276.85 5513.94 32.36 0.00 0.00 0.00 0.00 09:58:10 07:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:53:01 lo 2.87 2.87 0.31 0.31 0.00 0.00 0.00 0.00 09:58:10 07:53:01 ens3 275.84 236.20 4166.78 25.19 0.00 0.00 0.00 0.00 09:58:10 07:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:54:01 lo 1.13 1.13 0.10 0.10 0.00 0.00 0.00 0.00 09:58:10 07:54:01 ens3 317.80 217.63 3981.91 20.43 0.00 0.00 0.00 0.00 09:58:10 07:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:55:01 lo 0.60 0.60 0.07 0.07 0.00 0.00 0.00 0.00 09:58:10 07:55:01 ens3 162.96 96.82 3229.01 9.01 0.00 0.00 0.00 0.00 09:58:10 07:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:56:01 lo 2.17 2.17 0.42 0.42 0.00 0.00 0.00 0.00 09:58:10 07:56:01 ens3 58.73 28.02 1392.59 2.67 0.00 0.00 0.00 0.00 09:58:10 07:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:57:01 lo 6.52 6.52 14.38 14.38 0.00 0.00 0.00 0.00 09:58:10 07:57:01 ens3 0.92 0.80 0.17 0.16 0.00 0.00 0.00 0.00 09:58:10 07:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:58:01 lo 5.03 5.03 1.85 1.85 0.00 0.00 0.00 0.00 09:58:10 07:58:01 ens3 0.93 0.82 0.15 0.14 0.00 0.00 0.00 0.00 09:58:10 07:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 07:59:01 lo 8.17 8.17 5.84 5.84 0.00 0.00 0.00 0.00 09:58:10 07:59:01 ens3 0.72 0.47 0.11 0.09 0.00 0.00 0.00 0.00 09:58:10 08:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:00:01 lo 5.13 5.13 1.09 1.09 0.00 0.00 0.00 0.00 09:58:10 08:00:01 ens3 8.12 6.82 2.07 4.44 0.00 0.00 0.00 0.00 09:58:10 08:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:01:01 lo 30.22 30.22 28.07 28.07 0.00 0.00 0.00 0.00 09:58:10 08:01:01 ens3 1.28 1.00 0.30 0.23 0.00 0.00 0.00 0.00 09:58:10 08:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:02:01 lo 23.85 23.85 14.48 14.48 0.00 0.00 0.00 0.00 09:58:10 08:02:01 ens3 0.55 0.30 0.07 0.05 0.00 0.00 0.00 0.00 09:58:10 08:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:03:01 lo 20.71 20.71 7.83 7.83 0.00 0.00 0.00 0.00 09:58:10 08:03:01 ens3 0.27 0.12 0.03 0.02 0.00 0.00 0.00 0.00 09:58:10 08:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:04:01 lo 0.67 0.67 0.05 0.05 0.00 0.00 0.00 0.00 09:58:10 08:04:01 ens3 0.35 0.10 0.02 0.01 0.00 0.00 0.00 0.00 09:58:10 08:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:05:01 lo 0.73 0.73 0.09 0.09 0.00 0.00 0.00 0.00 09:58:10 08:05:01 ens3 0.12 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:06:01 lo 3.92 3.92 0.43 0.43 0.00 0.00 0.00 0.00 09:58:10 08:06:01 ens3 0.72 0.55 0.21 0.14 0.00 0.00 0.00 0.00 09:58:10 08:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:07:01 lo 6.63 6.63 10.73 10.73 0.00 0.00 0.00 0.00 09:58:10 08:07:01 ens3 0.52 0.42 0.05 0.05 0.00 0.00 0.00 0.00 09:58:10 08:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:08:01 lo 27.98 27.98 15.84 15.84 0.00 0.00 0.00 0.00 09:58:10 08:08:01 ens3 0.62 0.53 0.11 0.10 0.00 0.00 0.00 0.00 09:58:10 08:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:09:01 lo 8.73 8.73 4.85 4.85 0.00 0.00 0.00 0.00 09:58:10 08:09:01 ens3 0.37 0.23 0.05 0.04 0.00 0.00 0.00 0.00 09:58:10 08:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:10:01 lo 31.48 31.48 11.05 11.05 0.00 0.00 0.00 0.00 09:58:10 08:10:01 ens3 0.28 0.23 0.03 0.03 0.00 0.00 0.00 0.00 09:58:10 08:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:11:01 lo 4.30 4.30 0.51 0.51 0.00 0.00 0.00 0.00 09:58:10 08:11:01 ens3 0.77 0.57 0.22 0.15 0.00 0.00 0.00 0.00 09:58:10 08:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:12:01 lo 16.70 16.70 7.06 7.06 0.00 0.00 0.00 0.00 09:58:10 08:12:01 ens3 0.93 0.75 0.12 0.10 0.00 0.00 0.00 0.00 09:58:10 08:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:13:01 lo 23.81 23.81 8.94 8.94 0.00 0.00 0.00 0.00 09:58:10 08:13:01 ens3 0.53 0.50 0.10 0.10 0.00 0.00 0.00 0.00 09:58:10 08:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:14:01 lo 9.97 9.97 8.26 8.26 0.00 0.00 0.00 0.00 09:58:10 08:14:01 ens3 1.02 0.97 0.21 0.19 0.00 0.00 0.00 0.00 09:58:10 08:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:15:01 lo 29.75 29.75 11.26 11.26 0.00 0.00 0.00 0.00 09:58:10 08:15:01 ens3 0.67 0.55 0.13 0.11 0.00 0.00 0.00 0.00 09:58:10 08:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:16:01 lo 7.66 7.66 1.52 1.52 0.00 0.00 0.00 0.00 09:58:10 08:16:01 ens3 1.07 0.85 0.26 0.18 0.00 0.00 0.00 0.00 09:58:10 08:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:17:01 lo 15.31 15.31 15.18 15.18 0.00 0.00 0.00 0.00 09:58:10 08:17:01 ens3 1.93 0.43 0.23 0.07 0.00 0.00 0.00 0.00 09:58:10 08:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:18:01 lo 3.05 3.05 3.17 3.17 0.00 0.00 0.00 0.00 09:58:10 08:18:01 ens3 1.13 0.77 0.59 0.46 0.00 0.00 0.00 0.00 09:58:10 08:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:19:01 lo 0.40 0.40 0.05 0.05 0.00 0.00 0.00 0.00 09:58:10 08:19:01 ens3 0.13 0.00 0.01 0.00 0.00 0.00 0.00 0.00 09:58:10 08:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:20:01 lo 0.47 0.47 0.03 0.03 0.00 0.00 0.00 0.00 09:58:10 08:20:01 ens3 0.77 0.10 0.09 0.01 0.00 0.00 0.00 0.00 09:58:10 08:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:21:01 lo 2.10 2.10 0.25 0.25 0.00 0.00 0.00 0.00 09:58:10 08:21:01 ens3 1.73 1.80 0.90 0.75 0.00 0.00 0.00 0.00 09:58:10 08:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:22:01 lo 10.45 10.45 15.73 15.73 0.00 0.00 0.00 0.00 09:58:10 08:22:01 ens3 0.83 0.75 0.14 0.13 0.00 0.00 0.00 0.00 09:58:10 08:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:23:01 lo 19.91 19.91 9.30 9.30 0.00 0.00 0.00 0.00 09:58:10 08:23:01 ens3 1.02 0.88 0.19 0.18 0.00 0.00 0.00 0.00 09:58:10 08:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:24:01 lo 25.41 25.41 8.56 8.56 0.00 0.00 0.00 0.00 09:58:10 08:24:01 ens3 1.27 1.17 0.24 0.24 0.00 0.00 0.00 0.00 09:58:10 08:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:25:01 lo 14.26 14.26 6.88 6.88 0.00 0.00 0.00 0.00 09:58:10 08:25:01 ens3 0.85 0.68 0.14 0.12 0.00 0.00 0.00 0.00 09:58:10 08:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:26:01 lo 36.91 36.91 15.02 15.02 0.00 0.00 0.00 0.00 09:58:10 08:26:01 ens3 1.33 1.13 0.36 0.27 0.00 0.00 0.00 0.00 09:58:10 08:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:27:01 lo 21.26 21.26 6.53 6.53 0.00 0.00 0.00 0.00 09:58:10 08:27:01 ens3 0.95 0.85 0.18 0.17 0.00 0.00 0.00 0.00 09:58:10 08:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:28:01 lo 26.48 26.48 11.59 11.59 0.00 0.00 0.00 0.00 09:58:10 08:28:01 ens3 2.13 1.65 0.62 0.50 0.00 0.00 0.00 0.00 09:58:10 08:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:29:01 lo 10.06 10.06 4.09 4.09 0.00 0.00 0.00 0.00 09:58:10 08:29:01 ens3 1.85 1.65 0.74 0.63 0.00 0.00 0.00 0.00 09:58:10 08:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:30:01 lo 15.46 15.46 9.25 9.25 0.00 0.00 0.00 0.00 09:58:10 08:30:01 ens3 1.22 1.13 0.22 0.21 0.00 0.00 0.00 0.00 09:58:10 08:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:31:01 lo 10.18 10.18 4.18 4.18 0.00 0.00 0.00 0.00 09:58:10 08:31:01 ens3 1.40 1.18 0.52 0.39 0.00 0.00 0.00 0.00 09:58:10 08:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:32:01 lo 21.86 21.86 10.12 10.12 0.00 0.00 0.00 0.00 09:58:10 08:32:01 ens3 1.25 1.60 0.25 0.25 0.00 0.00 0.00 0.00 09:58:10 08:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:33:01 lo 5.60 5.60 6.21 6.21 0.00 0.00 0.00 0.00 09:58:10 08:33:01 ens3 0.75 0.85 0.13 0.13 0.00 0.00 0.00 0.00 09:58:10 08:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:34:01 lo 8.73 8.73 3.41 3.41 0.00 0.00 0.00 0.00 09:58:10 08:34:01 ens3 1.37 1.00 0.20 0.15 0.00 0.00 0.00 0.00 09:58:10 08:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:35:01 lo 3.77 3.77 0.94 0.94 0.00 0.00 0.00 0.00 09:58:10 08:35:01 ens3 0.87 0.93 0.34 0.30 0.00 0.00 0.00 0.00 09:58:10 08:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:36:01 lo 29.98 29.98 9.65 9.65 0.00 0.00 0.00 0.00 09:58:10 08:36:01 ens3 1.17 1.30 0.29 0.23 0.00 0.00 0.00 0.00 09:58:10 08:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:37:01 lo 10.65 10.65 9.53 9.53 0.00 0.00 0.00 0.00 09:58:10 08:37:01 ens3 1.83 0.80 0.21 0.12 0.00 0.00 0.00 0.00 09:58:10 08:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:38:01 lo 15.25 15.25 9.65 9.65 0.00 0.00 0.00 0.00 09:58:10 08:38:01 ens3 1.88 1.00 0.18 0.15 0.00 0.00 0.00 0.00 09:58:10 08:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:39:01 lo 18.80 18.80 14.84 14.84 0.00 0.00 0.00 0.00 09:58:10 08:39:01 ens3 1.12 1.03 0.20 0.16 0.00 0.00 0.00 0.00 09:58:10 08:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:40:01 lo 20.14 20.14 8.19 8.19 0.00 0.00 0.00 0.00 09:58:10 08:40:01 ens3 1.40 1.15 0.20 0.16 0.00 0.00 0.00 0.00 09:58:10 08:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:41:01 lo 34.43 34.43 11.68 11.68 0.00 0.00 0.00 0.00 09:58:10 08:41:01 ens3 0.82 0.83 0.26 0.19 0.00 0.00 0.00 0.00 09:58:10 08:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:42:01 lo 40.88 40.88 12.22 12.22 0.00 0.00 0.00 0.00 09:58:10 08:42:01 ens3 0.68 0.68 0.12 0.10 0.00 0.00 0.00 0.00 09:58:10 08:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:43:01 lo 16.30 16.30 15.11 15.11 0.00 0.00 0.00 0.00 09:58:10 08:43:01 ens3 0.75 0.75 0.10 0.10 0.00 0.00 0.00 0.00 09:58:10 08:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:44:01 lo 21.21 21.21 9.83 9.83 0.00 0.00 0.00 0.00 09:58:10 08:44:01 ens3 0.82 1.05 0.16 0.16 0.00 0.00 0.00 0.00 09:58:10 08:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:45:01 lo 7.47 7.47 4.55 4.55 0.00 0.00 0.00 0.00 09:58:10 08:45:01 ens3 0.55 0.57 0.09 0.09 0.00 0.00 0.00 0.00 09:58:10 08:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:46:01 lo 18.18 18.18 8.88 8.88 0.00 0.00 0.00 0.00 09:58:10 08:46:01 ens3 0.88 1.05 0.26 0.20 0.00 0.00 0.00 0.00 09:58:10 08:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:47:01 lo 20.36 20.36 7.40 7.40 0.00 0.00 0.00 0.00 09:58:10 08:47:01 ens3 0.73 0.62 0.11 0.10 0.00 0.00 0.00 0.00 09:58:10 08:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:48:01 lo 20.83 20.83 9.05 9.05 0.00 0.00 0.00 0.00 09:58:10 08:48:01 ens3 1.23 0.77 0.43 0.31 0.00 0.00 0.00 0.00 09:58:10 08:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:49:01 lo 15.38 15.38 6.39 6.39 0.00 0.00 0.00 0.00 09:58:10 08:49:01 ens3 0.67 0.43 0.10 0.09 0.00 0.00 0.00 0.00 09:58:10 08:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:50:01 lo 22.66 22.66 8.96 8.96 0.00 0.00 0.00 0.00 09:58:10 08:50:01 ens3 0.97 0.38 0.14 0.07 0.00 0.00 0.00 0.00 09:58:10 08:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:51:01 lo 17.31 17.31 8.00 8.00 0.00 0.00 0.00 0.00 09:58:10 08:51:01 ens3 1.12 0.87 0.27 0.20 0.00 0.00 0.00 0.00 09:58:10 08:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:52:01 lo 36.81 36.81 12.28 12.28 0.00 0.00 0.00 0.00 09:58:10 08:52:01 ens3 0.98 0.58 0.17 0.11 0.00 0.00 0.00 0.00 09:58:10 08:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:53:01 lo 44.98 44.98 13.31 13.31 0.00 0.00 0.00 0.00 09:58:10 08:53:01 ens3 0.83 0.33 0.12 0.07 0.00 0.00 0.00 0.00 09:58:10 08:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:54:01 lo 18.18 18.18 6.16 6.16 0.00 0.00 0.00 0.00 09:58:10 08:54:01 ens3 0.58 0.45 0.10 0.08 0.00 0.00 0.00 0.00 09:58:10 08:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:55:01 lo 33.46 33.46 9.73 9.73 0.00 0.00 0.00 0.00 09:58:10 08:55:01 ens3 0.37 0.25 0.06 0.05 0.00 0.00 0.00 0.00 09:58:10 08:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:56:01 lo 32.69 32.69 9.11 9.11 0.00 0.00 0.00 0.00 09:58:10 08:56:01 ens3 0.38 0.18 0.14 0.07 0.00 0.00 0.00 0.00 09:58:10 08:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:57:01 lo 53.91 53.91 17.65 17.65 0.00 0.00 0.00 0.00 09:58:10 08:57:01 ens3 1.80 0.28 0.35 0.21 0.00 0.00 0.00 0.00 09:58:10 08:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:58:01 lo 27.01 27.01 7.70 7.70 0.00 0.00 0.00 0.00 09:58:10 08:58:01 ens3 1.80 0.20 0.14 0.02 0.00 0.00 0.00 0.00 09:58:10 08:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 08:59:01 lo 0.23 0.23 0.02 0.02 0.00 0.00 0.00 0.00 09:58:10 08:59:01 ens3 0.93 0.30 0.35 0.24 0.00 0.00 0.00 0.00 09:58:10 09:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:00:01 lo 0.57 0.57 0.06 0.06 0.00 0.00 0.00 0.00 09:58:10 09:00:01 ens3 0.47 0.10 0.03 0.01 0.00 0.00 0.00 0.00 09:58:10 09:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:01:01 lo 1.62 1.62 0.15 0.15 0.00 0.00 0.00 0.00 09:58:10 09:01:01 ens3 1.67 0.42 0.32 0.12 0.00 0.00 0.00 0.00 09:58:10 09:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:02:01 lo 22.13 22.13 22.30 22.30 0.00 0.00 0.00 0.00 09:58:10 09:02:01 ens3 0.85 0.68 0.11 0.09 0.00 0.00 0.00 0.00 09:58:10 09:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:03:01 lo 30.31 30.31 12.55 12.55 0.00 0.00 0.00 0.00 09:58:10 09:03:01 ens3 1.72 0.58 0.27 0.12 0.00 0.00 0.00 0.00 09:58:10 09:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:04:01 lo 19.61 19.61 8.20 8.20 0.00 0.00 0.00 0.00 09:58:10 09:04:01 ens3 0.97 0.68 0.40 0.29 0.00 0.00 0.00 0.00 09:58:10 09:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:05:01 lo 10.10 10.10 4.52 4.52 0.00 0.00 0.00 0.00 09:58:10 09:05:01 ens3 0.70 0.57 0.13 0.11 0.00 0.00 0.00 0.00 09:58:10 09:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:06:01 lo 38.34 38.34 14.69 14.69 0.00 0.00 0.00 0.00 09:58:10 09:06:01 ens3 0.90 0.72 0.26 0.19 0.00 0.00 0.00 0.00 09:58:10 09:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:07:01 lo 17.15 17.15 5.53 5.53 0.00 0.00 0.00 0.00 09:58:10 09:07:01 ens3 0.48 0.35 0.08 0.07 0.00 0.00 0.00 0.00 09:58:10 09:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:08:01 lo 22.00 22.00 9.65 9.65 0.00 0.00 0.00 0.00 09:58:10 09:08:01 ens3 0.53 0.38 0.08 0.07 0.00 0.00 0.00 0.00 09:58:10 09:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:09:01 lo 20.14 20.14 8.09 8.09 0.00 0.00 0.00 0.00 09:58:10 09:09:01 ens3 0.75 0.67 0.14 0.13 0.00 0.00 0.00 0.00 09:58:10 09:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:10:01 lo 12.23 12.23 18.09 18.09 0.00 0.00 0.00 0.00 09:58:10 09:10:01 ens3 1.52 0.65 0.12 0.08 0.00 0.00 0.00 0.00 09:58:10 09:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:11:01 lo 29.51 29.51 11.07 11.07 0.00 0.00 0.00 0.00 09:58:10 09:11:01 ens3 2.37 0.92 0.60 0.39 0.00 0.00 0.00 0.00 09:58:10 09:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:12:01 lo 29.48 29.48 14.87 14.87 0.00 0.00 0.00 0.00 09:58:10 09:12:01 ens3 1.28 0.37 0.17 0.06 0.00 0.00 0.00 0.00 09:58:10 09:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:13:01 lo 11.41 11.41 7.49 7.49 0.00 0.00 0.00 0.00 09:58:10 09:13:01 ens3 1.72 0.68 0.65 0.45 0.00 0.00 0.00 0.00 09:58:10 09:14:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:14:02 lo 15.46 15.46 7.38 7.38 0.00 0.00 0.00 0.00 09:58:10 09:14:02 ens3 0.85 0.70 0.15 0.13 0.00 0.00 0.00 0.00 09:58:10 09:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:15:01 lo 15.59 15.59 9.69 9.69 0.00 0.00 0.00 0.00 09:58:10 09:15:01 ens3 1.08 0.36 0.17 0.07 0.00 0.00 0.00 0.00 09:58:10 09:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:16:01 lo 11.48 11.48 5.95 5.95 0.00 0.00 0.00 0.00 09:58:10 09:16:01 ens3 0.73 0.50 0.21 0.13 0.00 0.00 0.00 0.00 09:58:10 09:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:17:01 lo 23.36 23.36 12.74 12.74 0.00 0.00 0.00 0.00 09:58:10 09:17:01 ens3 1.30 0.73 0.19 0.12 0.00 0.00 0.00 0.00 09:58:10 09:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:18:01 lo 22.25 22.25 8.83 8.83 0.00 0.00 0.00 0.00 09:58:10 09:18:01 ens3 1.27 0.60 0.31 0.25 0.00 0.00 0.00 0.00 09:58:10 09:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:19:01 lo 20.71 20.71 7.60 7.60 0.00 0.00 0.00 0.00 09:58:10 09:19:01 ens3 3.13 2.07 0.95 0.76 0.00 0.00 0.00 0.00 09:58:10 09:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:20:01 lo 9.73 9.73 8.62 8.62 0.00 0.00 0.00 0.00 09:58:10 09:20:01 ens3 2.22 1.23 0.41 0.34 0.00 0.00 0.00 0.00 09:58:10 09:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:21:01 lo 6.08 6.08 2.35 2.35 0.00 0.00 0.00 0.00 09:58:10 09:21:01 ens3 3.27 1.12 0.46 0.23 0.00 0.00 0.00 0.00 09:58:10 09:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:22:01 lo 21.21 21.21 7.98 7.98 0.00 0.00 0.00 0.00 09:58:10 09:22:01 ens3 1.13 1.22 0.37 0.33 0.00 0.00 0.00 0.00 09:58:10 09:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:23:01 lo 22.58 22.58 12.82 12.82 0.00 0.00 0.00 0.00 09:58:10 09:23:01 ens3 1.07 1.43 0.22 0.23 0.00 0.00 0.00 0.00 09:58:10 09:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:24:01 lo 5.07 5.07 1.66 1.66 0.00 0.00 0.00 0.00 09:58:10 09:24:01 ens3 1.60 1.15 0.25 0.17 0.00 0.00 0.00 0.00 09:58:10 09:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:25:01 lo 22.96 22.96 8.55 8.55 0.00 0.00 0.00 0.00 09:58:10 09:25:01 ens3 1.50 1.40 0.26 0.22 0.00 0.00 0.00 0.00 09:58:10 09:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:26:01 lo 21.98 21.98 11.20 11.20 0.00 0.00 0.00 0.00 09:58:10 09:26:01 ens3 1.52 1.25 0.53 0.40 0.00 0.00 0.00 0.00 09:58:10 09:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:27:01 lo 36.44 36.44 10.83 10.83 0.00 0.00 0.00 0.00 09:58:10 09:27:01 ens3 0.68 0.53 0.12 0.11 0.00 0.00 0.00 0.00 09:58:10 09:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:28:01 lo 18.90 18.90 5.73 5.73 0.00 0.00 0.00 0.00 09:58:10 09:28:01 ens3 0.75 0.67 0.13 0.12 0.00 0.00 0.00 0.00 09:58:10 09:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:29:01 lo 32.18 32.18 13.36 13.36 0.00 0.00 0.00 0.00 09:58:10 09:29:01 ens3 1.30 0.58 0.16 0.09 0.00 0.00 0.00 0.00 09:58:10 09:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:30:01 lo 17.50 17.50 5.27 5.27 0.00 0.00 0.00 0.00 09:58:10 09:30:01 ens3 0.78 0.68 0.14 0.13 0.00 0.00 0.00 0.00 09:58:10 09:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:31:01 lo 40.86 40.86 12.51 12.51 0.00 0.00 0.00 0.00 09:58:10 09:31:01 ens3 3.65 5.72 0.63 10.18 0.00 0.00 0.00 0.00 09:58:10 09:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:32:01 lo 17.00 17.00 4.65 4.65 0.00 0.00 0.00 0.00 09:58:10 09:32:01 ens3 2.22 0.40 0.24 0.07 0.00 0.00 0.00 0.00 09:58:10 09:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:33:01 lo 25.23 25.23 7.69 7.69 0.00 0.00 0.00 0.00 09:58:10 09:33:01 ens3 1.53 0.43 0.33 0.24 0.00 0.00 0.00 0.00 09:58:10 09:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:34:01 lo 23.10 23.10 6.43 6.43 0.00 0.00 0.00 0.00 09:58:10 09:34:01 ens3 0.50 0.10 0.03 0.01 0.00 0.00 0.00 0.00 09:58:10 09:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:35:01 lo 16.10 16.10 4.44 4.44 0.00 0.00 0.00 0.00 09:58:10 09:35:01 ens3 0.17 0.07 0.01 0.01 0.00 0.00 0.00 0.00 09:58:10 09:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:36:01 lo 25.01 25.01 6.73 6.73 0.00 0.00 0.00 0.00 09:58:10 09:36:01 ens3 0.48 0.22 0.15 0.07 0.00 0.00 0.00 0.00 09:58:10 09:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:37:01 lo 17.13 17.13 4.52 4.52 0.00 0.00 0.00 0.00 09:58:10 09:37:01 ens3 1.57 1.75 0.78 0.69 0.00 0.00 0.00 0.00 09:58:10 09:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:38:01 lo 36.78 36.78 32.89 32.89 0.00 0.00 0.00 0.00 09:58:10 09:38:01 ens3 0.68 0.58 0.09 0.08 0.00 0.00 0.00 0.00 09:58:10 09:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:39:01 lo 27.20 27.20 12.17 12.17 0.00 0.00 0.00 0.00 09:58:10 09:39:01 ens3 1.40 1.20 0.28 0.25 0.00 0.00 0.00 0.00 09:58:10 09:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:40:01 lo 11.98 11.98 3.01 3.01 0.00 0.00 0.00 0.00 09:58:10 09:40:01 ens3 1.33 0.80 0.43 0.32 0.00 0.00 0.00 0.00 09:58:10 09:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:41:01 lo 38.78 38.78 19.59 19.59 0.00 0.00 0.00 0.00 09:58:10 09:41:01 ens3 1.98 0.92 0.35 0.23 0.00 0.00 0.00 0.00 09:58:10 09:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:42:01 lo 12.68 12.68 5.42 5.42 0.00 0.00 0.00 0.00 09:58:10 09:42:01 ens3 2.52 1.02 0.54 0.37 0.00 0.00 0.00 0.00 09:58:10 09:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:43:01 lo 20.81 20.81 7.69 7.69 0.00 0.00 0.00 0.00 09:58:10 09:43:01 ens3 0.98 0.32 0.14 0.05 0.00 0.00 0.00 0.00 09:58:10 09:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:44:01 lo 18.68 18.68 7.58 7.58 0.00 0.00 0.00 0.00 09:58:10 09:44:01 ens3 1.92 1.15 0.28 0.18 0.00 0.00 0.00 0.00 09:58:10 09:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:45:01 lo 29.25 29.25 9.59 9.59 0.00 0.00 0.00 0.00 09:58:10 09:45:01 ens3 1.60 1.58 0.64 0.55 0.00 0.00 0.00 0.00 09:58:10 09:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:46:01 lo 21.58 21.58 7.55 7.55 0.00 0.00 0.00 0.00 09:58:10 09:46:01 ens3 1.37 0.78 0.28 0.18 0.00 0.00 0.00 0.00 09:58:10 09:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:47:01 lo 35.19 35.19 11.55 11.55 0.00 0.00 0.00 0.00 09:58:10 09:47:01 ens3 0.63 0.35 0.09 0.07 0.00 0.00 0.00 0.00 09:58:10 09:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:48:01 lo 0.47 0.47 0.03 0.03 0.00 0.00 0.00 0.00 09:58:10 09:48:01 ens3 0.40 0.10 0.02 0.01 0.00 0.00 0.00 0.00 09:58:10 09:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:49:01 lo 0.33 0.33 0.04 0.04 0.00 0.00 0.00 0.00 09:58:10 09:49:01 ens3 1.07 0.00 0.04 0.00 0.00 0.00 0.00 0.00 09:58:10 09:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:50:01 lo 1.98 1.98 0.17 0.17 0.00 0.00 0.00 0.00 09:58:10 09:50:01 ens3 1.12 0.45 0.10 0.07 0.00 0.00 0.00 0.00 09:58:10 09:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:51:01 lo 41.21 41.21 20.85 20.85 0.00 0.00 0.00 0.00 09:58:10 09:51:01 ens3 0.90 0.70 0.24 0.17 0.00 0.00 0.00 0.00 09:58:10 09:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:52:01 lo 41.58 41.58 15.18 15.18 0.00 0.00 0.00 0.00 09:58:10 09:52:01 ens3 0.95 0.78 0.17 0.16 0.00 0.00 0.00 0.00 09:58:10 09:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:53:01 lo 60.79 60.79 20.80 20.80 0.00 0.00 0.00 0.00 09:58:10 09:53:01 ens3 0.40 0.33 0.07 0.07 0.00 0.00 0.00 0.00 09:58:10 09:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:54:01 lo 73.42 73.42 23.86 23.86 0.00 0.00 0.00 0.00 09:58:10 09:54:01 ens3 0.48 0.38 0.08 0.07 0.00 0.00 0.00 0.00 09:58:10 09:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:55:01 lo 0.25 0.25 0.02 0.02 0.00 0.00 0.00 0.00 09:58:10 09:55:01 ens3 0.07 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:56:01 lo 0.60 0.60 0.06 0.06 0.00 0.00 0.00 0.00 09:58:10 09:56:01 ens3 0.37 0.18 0.14 0.07 0.00 0.00 0.00 0.00 09:58:10 09:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:57:01 lo 0.80 0.80 0.07 0.07 0.00 0.00 0.00 0.00 09:58:10 09:57:01 ens3 1.05 1.22 0.59 0.52 0.00 0.00 0.00 0.00 09:58:10 09:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 09:58:01 lo 1.20 1.20 0.11 0.11 0.00 0.00 0.00 0.00 09:58:10 09:58:01 ens3 127.86 108.38 1611.89 18.00 0.00 0.00 0.00 0.00 09:58:10 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:58:10 Average: lo 18.29 18.29 8.12 8.12 0.00 0.00 0.00 0.00 09:58:10 Average: ens3 14.37 10.44 167.93 1.69 0.00 0.00 0.00 0.00 09:58:10 09:58:10 09:58:10 ---> sar -P ALL: 09:58:10 Linux 5.4.0-200-generic (prd-ubuntu2004-docker-4c-16g-123) 12/05/24 _x86_64_ (4 CPU) 09:58:10 09:58:10 07:49:34 LINUX RESTART (4 CPU) 09:58:10 09:58:10 07:50:02 CPU %user %nice %system %iowait %steal %idle 09:58:10 07:51:02 all 20.58 16.49 13.13 4.81 0.14 44.85 09:58:10 07:51:02 0 25.32 14.67 11.53 4.63 0.12 43.73 09:58:10 07:51:02 1 22.66 15.81 13.10 6.09 0.17 42.17 09:58:10 07:51:02 2 16.44 19.00 14.86 3.03 0.14 46.54 09:58:10 07:51:02 3 17.94 16.47 13.03 5.49 0.14 46.94 09:58:10 07:52:01 all 43.76 0.00 3.89 5.51 0.10 46.75 09:58:10 07:52:01 0 39.37 0.00 3.56 9.18 0.10 47.79 09:58:10 07:52:01 1 41.52 0.00 3.93 4.85 0.09 49.62 09:58:10 07:52:01 2 57.90 0.00 4.60 4.74 0.10 32.65 09:58:10 07:52:01 3 36.27 0.00 3.46 3.27 0.12 56.88 09:58:10 07:53:01 all 79.14 0.00 2.90 2.08 0.12 15.76 09:58:10 07:53:01 0 73.10 0.00 2.53 1.79 0.10 22.48 09:58:10 07:53:01 1 79.52 0.00 3.27 5.04 0.12 12.05 09:58:10 07:53:01 2 80.22 0.00 2.75 0.67 0.12 16.25 09:58:10 07:53:01 3 83.79 0.00 3.04 0.80 0.14 12.23 09:58:10 07:54:01 all 52.80 0.00 3.64 8.10 0.14 35.33 09:58:10 07:54:01 0 47.56 0.00 2.58 8.82 0.12 40.93 09:58:10 07:54:01 1 66.64 0.00 4.62 7.05 0.14 21.55 09:58:10 07:54:01 2 48.77 0.00 3.74 5.06 0.15 42.27 09:58:10 07:54:01 3 48.18 0.00 3.60 11.51 0.14 36.57 09:58:10 07:55:01 all 65.69 0.00 4.03 18.76 0.13 11.38 09:58:10 07:55:01 0 68.49 0.00 3.84 21.24 0.12 6.32 09:58:10 07:55:01 1 65.62 0.00 4.40 18.14 0.14 11.70 09:58:10 07:55:01 2 61.86 0.00 3.50 18.06 0.14 16.44 09:58:10 07:55:01 3 66.79 0.00 4.40 17.57 0.14 11.11 09:58:10 07:56:01 all 79.97 0.00 4.31 6.26 0.13 9.33 09:58:10 07:56:01 0 79.90 0.00 4.65 6.51 0.10 8.84 09:58:10 07:56:01 1 80.88 0.00 4.27 4.02 0.14 10.69 09:58:10 07:56:01 2 78.04 0.00 4.56 9.66 0.14 7.60 09:58:10 07:56:01 3 81.04 0.00 3.74 4.85 0.15 10.21 09:58:10 07:57:01 all 32.51 0.00 1.40 0.78 0.10 65.21 09:58:10 07:57:01 0 33.60 0.00 1.33 0.07 0.10 64.90 09:58:10 07:57:01 1 31.99 0.00 1.28 0.28 0.10 66.34 09:58:10 07:57:01 2 31.16 0.00 1.66 2.69 0.10 64.39 09:58:10 07:57:01 3 33.27 0.00 1.33 0.08 0.10 65.21 09:58:10 07:58:01 all 43.24 0.00 1.59 0.25 0.08 54.84 09:58:10 07:58:01 0 44.91 0.00 1.49 0.02 0.08 53.50 09:58:10 07:58:01 1 45.03 0.00 1.29 0.54 0.08 53.07 09:58:10 07:58:01 2 44.40 0.00 1.98 0.39 0.07 53.17 09:58:10 07:58:01 3 38.63 0.00 1.61 0.05 0.08 59.62 09:58:10 07:59:01 all 27.45 0.00 1.10 0.67 0.09 70.69 09:58:10 07:59:01 0 25.62 0.00 1.24 1.09 0.08 71.97 09:58:10 07:59:01 1 27.90 0.00 1.04 0.40 0.08 70.58 09:58:10 07:59:01 2 28.16 0.00 1.07 0.89 0.10 69.79 09:58:10 07:59:01 3 28.14 0.00 1.06 0.30 0.08 70.42 09:58:10 08:00:01 all 68.20 0.00 2.61 0.87 0.12 28.20 09:58:10 08:00:01 0 71.98 0.00 2.26 1.57 0.12 24.08 09:58:10 08:00:01 1 64.66 0.00 2.28 0.50 0.12 32.44 09:58:10 08:00:01 2 71.08 0.00 2.88 0.44 0.12 25.48 09:58:10 08:00:01 3 65.08 0.00 3.00 0.97 0.12 30.83 09:58:10 08:01:01 all 43.43 0.00 1.88 0.31 0.10 54.30 09:58:10 08:01:01 0 44.63 0.00 2.19 0.07 0.08 53.02 09:58:10 08:01:01 1 48.14 0.00 1.31 0.50 0.10 49.95 09:58:10 08:01:01 2 48.77 0.00 1.74 0.64 0.10 48.75 09:58:10 08:01:01 3 32.16 0.00 2.26 0.02 0.10 65.46 09:58:10 09:58:10 08:01:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:02:01 all 8.07 0.00 0.41 0.04 0.09 91.39 09:58:10 08:02:01 0 7.59 0.00 0.40 0.12 0.08 91.80 09:58:10 08:02:01 1 8.25 0.00 0.44 0.00 0.10 91.20 09:58:10 08:02:01 2 8.37 0.00 0.40 0.03 0.08 91.11 09:58:10 08:02:01 3 8.06 0.00 0.38 0.02 0.08 91.46 09:58:10 08:03:01 all 3.05 0.00 0.35 0.02 0.08 96.50 09:58:10 08:03:01 0 2.84 0.00 0.35 0.02 0.10 96.69 09:58:10 08:03:01 1 3.28 0.00 0.40 0.00 0.07 96.25 09:58:10 08:03:01 2 3.15 0.00 0.29 0.05 0.07 96.44 09:58:10 08:03:01 3 2.94 0.00 0.37 0.00 0.08 96.61 09:58:10 08:04:01 all 0.59 0.00 0.25 0.05 0.10 99.01 09:58:10 08:04:01 0 0.45 0.00 0.15 0.12 0.10 99.18 09:58:10 08:04:01 1 0.80 0.00 0.42 0.00 0.10 98.68 09:58:10 08:04:01 2 0.50 0.00 0.22 0.08 0.10 99.10 09:58:10 08:04:01 3 0.60 0.00 0.22 0.00 0.08 99.10 09:58:10 08:05:01 all 0.63 0.00 0.28 0.03 0.08 98.98 09:58:10 08:05:01 0 0.45 0.00 0.18 0.02 0.07 99.28 09:58:10 08:05:01 1 0.78 0.00 0.42 0.08 0.08 98.63 09:58:10 08:05:01 2 0.67 0.00 0.30 0.03 0.08 98.91 09:58:10 08:05:01 3 0.60 0.00 0.20 0.00 0.08 99.11 09:58:10 08:06:01 all 30.60 0.00 1.50 0.94 0.10 66.86 09:58:10 08:06:01 0 24.90 0.00 1.32 1.05 0.10 72.62 09:58:10 08:06:01 1 32.27 0.00 1.64 0.05 0.10 65.94 09:58:10 08:06:01 2 32.31 0.00 1.41 2.29 0.08 63.91 09:58:10 08:06:01 3 32.95 0.00 1.62 0.35 0.12 64.96 09:58:10 08:07:01 all 65.25 0.00 2.33 0.37 0.10 31.95 09:58:10 08:07:01 0 62.15 0.00 1.67 0.08 0.10 36.00 09:58:10 08:07:01 1 68.75 0.00 2.60 0.32 0.10 28.23 09:58:10 08:07:01 2 65.47 0.00 1.94 0.94 0.08 31.56 09:58:10 08:07:01 3 64.65 0.00 3.09 0.13 0.12 32.01 09:58:10 08:08:01 all 12.70 0.00 0.55 0.01 0.09 86.65 09:58:10 08:08:01 0 12.32 0.00 0.53 0.02 0.08 87.04 09:58:10 08:08:01 1 12.62 0.00 0.43 0.00 0.08 86.86 09:58:10 08:08:01 2 12.91 0.00 0.55 0.03 0.10 86.41 09:58:10 08:08:01 3 12.94 0.00 0.68 0.00 0.10 86.29 09:58:10 08:09:01 all 3.33 0.00 0.35 0.02 0.10 96.20 09:58:10 08:09:01 0 2.87 0.00 0.37 0.03 0.10 96.63 09:58:10 08:09:01 1 2.82 0.00 0.35 0.02 0.10 96.71 09:58:10 08:09:01 2 2.89 0.00 0.40 0.03 0.10 96.58 09:58:10 08:09:01 3 4.71 0.00 0.28 0.00 0.08 94.93 09:58:10 08:10:01 all 4.20 0.00 0.34 0.04 0.09 95.33 09:58:10 08:10:01 0 4.27 0.00 0.43 0.15 0.08 95.06 09:58:10 08:10:01 1 4.33 0.00 0.30 0.00 0.08 95.29 09:58:10 08:10:01 2 4.01 0.00 0.33 0.00 0.08 95.57 09:58:10 08:10:01 3 4.21 0.00 0.28 0.00 0.10 95.40 09:58:10 08:11:01 all 39.39 0.00 1.46 0.42 0.10 58.63 09:58:10 08:11:01 0 44.57 0.00 1.45 0.12 0.10 53.76 09:58:10 08:11:01 1 34.57 0.00 1.67 0.32 0.10 63.34 09:58:10 08:11:01 2 38.95 0.00 1.27 0.35 0.10 59.32 09:58:10 08:11:01 3 39.48 0.00 1.44 0.90 0.08 58.09 09:58:10 08:12:01 all 57.88 0.00 1.96 0.30 0.09 39.77 09:58:10 08:12:01 0 60.58 0.00 1.57 0.59 0.08 37.18 09:58:10 08:12:01 1 56.35 0.00 2.06 0.42 0.08 41.08 09:58:10 08:12:01 2 55.55 0.00 2.17 0.05 0.08 42.14 09:58:10 08:12:01 3 59.03 0.00 2.05 0.15 0.10 38.68 09:58:10 09:58:10 08:12:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:13:01 all 7.75 0.00 0.50 0.04 0.09 91.62 09:58:10 08:13:01 0 7.55 0.00 0.50 0.07 0.08 91.80 09:58:10 08:13:01 1 7.82 0.00 0.70 0.00 0.12 91.37 09:58:10 08:13:01 2 8.02 0.00 0.35 0.00 0.08 91.55 09:58:10 08:13:01 3 7.63 0.00 0.47 0.08 0.07 91.76 09:58:10 08:14:01 all 2.07 0.00 0.41 0.02 0.08 97.42 09:58:10 08:14:01 0 2.01 0.00 0.47 0.03 0.08 97.40 09:58:10 08:14:01 1 1.74 0.00 0.43 0.00 0.08 97.75 09:58:10 08:14:01 2 2.41 0.00 0.37 0.00 0.08 97.14 09:58:10 08:14:01 3 2.12 0.00 0.38 0.03 0.08 97.38 09:58:10 08:15:01 all 4.38 0.00 0.45 0.01 0.07 95.08 09:58:10 08:15:01 0 4.45 0.00 0.65 0.02 0.08 94.80 09:58:10 08:15:01 1 3.98 0.00 0.38 0.00 0.07 95.57 09:58:10 08:15:01 2 4.97 0.00 0.45 0.00 0.07 94.52 09:58:10 08:15:01 3 4.12 0.00 0.32 0.03 0.08 95.45 09:58:10 08:16:01 all 55.28 0.00 2.01 0.48 0.10 42.13 09:58:10 08:16:01 0 53.99 0.00 2.17 1.34 0.10 42.40 09:58:10 08:16:01 1 60.48 0.00 1.82 0.00 0.10 37.59 09:58:10 08:16:01 2 49.81 0.00 2.03 0.35 0.10 47.72 09:58:10 08:16:01 3 56.89 0.00 2.01 0.22 0.10 40.79 09:58:10 08:17:01 all 47.00 0.00 1.49 0.30 0.11 51.11 09:58:10 08:17:01 0 48.79 0.00 1.25 0.95 0.10 48.91 09:58:10 08:17:01 1 48.06 0.00 1.51 0.00 0.12 50.32 09:58:10 08:17:01 2 45.75 0.00 1.51 0.25 0.10 52.39 09:58:10 08:17:01 3 45.41 0.00 1.68 0.00 0.12 52.80 09:58:10 08:18:01 all 1.36 0.00 0.30 0.01 0.08 98.25 09:58:10 08:18:01 0 1.17 0.00 0.42 0.05 0.10 98.26 09:58:10 08:18:01 1 1.28 0.00 0.27 0.00 0.07 98.38 09:58:10 08:18:01 2 0.97 0.00 0.25 0.00 0.08 98.69 09:58:10 08:18:01 3 1.99 0.00 0.25 0.00 0.08 97.67 09:58:10 08:19:01 all 0.68 0.00 0.35 0.01 0.09 98.87 09:58:10 08:19:01 0 0.74 0.00 0.30 0.05 0.08 98.83 09:58:10 08:19:01 1 0.50 0.00 0.23 0.00 0.08 99.18 09:58:10 08:19:01 2 0.79 0.00 0.59 0.00 0.10 98.52 09:58:10 08:19:01 3 0.70 0.00 0.27 0.00 0.10 98.93 09:58:10 08:20:01 all 0.66 0.00 0.29 0.01 0.09 98.95 09:58:10 08:20:01 0 0.57 0.00 0.27 0.05 0.08 99.03 09:58:10 08:20:01 1 0.87 0.00 0.37 0.00 0.08 98.68 09:58:10 08:20:01 2 0.79 0.00 0.30 0.00 0.08 98.83 09:58:10 08:20:01 3 0.43 0.00 0.22 0.00 0.10 99.25 09:58:10 08:21:01 all 17.10 0.00 1.06 0.41 0.09 81.34 09:58:10 08:21:01 0 15.08 0.00 1.11 1.47 0.08 82.26 09:58:10 08:21:01 1 17.67 0.00 1.17 0.03 0.08 81.04 09:58:10 08:21:01 2 15.79 0.00 1.08 0.05 0.08 83.00 09:58:10 08:21:01 3 19.86 0.00 0.89 0.10 0.10 79.06 09:58:10 08:22:01 all 59.09 0.00 2.17 0.89 0.11 37.74 09:58:10 08:22:01 0 59.73 0.00 2.31 0.47 0.10 37.40 09:58:10 08:22:01 1 59.21 0.00 1.94 1.68 0.12 37.06 09:58:10 08:22:01 2 60.66 0.00 2.01 0.23 0.10 37.00 09:58:10 08:22:01 3 56.76 0.00 2.42 1.19 0.12 39.51 09:58:10 08:23:01 all 18.46 0.00 0.81 0.29 0.08 80.36 09:58:10 08:23:01 0 18.79 0.00 1.07 0.02 0.08 80.05 09:58:10 08:23:01 1 16.23 0.00 0.73 0.32 0.07 82.65 09:58:10 08:23:01 2 19.65 0.00 0.63 0.00 0.08 79.64 09:58:10 08:23:01 3 19.18 0.00 0.80 0.82 0.08 79.12 09:58:10 09:58:10 08:23:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:24:01 all 3.53 0.00 0.49 0.03 0.09 95.87 09:58:10 08:24:01 0 3.42 0.00 0.45 0.00 0.08 96.05 09:58:10 08:24:01 1 3.57 0.00 0.47 0.03 0.08 95.85 09:58:10 08:24:01 2 3.55 0.00 0.45 0.00 0.10 95.90 09:58:10 08:24:01 3 3.58 0.00 0.58 0.07 0.10 95.67 09:58:10 08:25:01 all 38.26 0.00 1.45 0.31 0.08 59.89 09:58:10 08:25:01 0 37.33 0.00 1.86 0.27 0.08 60.46 09:58:10 08:25:01 1 40.75 0.00 1.27 0.15 0.08 57.75 09:58:10 08:25:01 2 36.55 0.00 1.18 0.02 0.08 62.18 09:58:10 08:25:01 3 38.42 0.00 1.52 0.80 0.08 59.17 09:58:10 08:26:01 all 8.62 0.00 0.49 0.03 0.10 90.78 09:58:10 08:26:01 0 8.36 0.00 0.45 0.00 0.08 91.11 09:58:10 08:26:01 1 8.34 0.00 0.40 0.03 0.08 91.14 09:58:10 08:26:01 2 9.25 0.00 0.45 0.02 0.10 90.18 09:58:10 08:26:01 3 8.53 0.00 0.63 0.05 0.12 90.67 09:58:10 08:27:01 all 26.45 0.00 1.26 0.03 0.09 72.17 09:58:10 08:27:01 0 26.62 0.00 1.02 0.00 0.08 72.28 09:58:10 08:27:01 1 26.01 0.00 1.09 0.00 0.10 72.80 09:58:10 08:27:01 2 27.59 0.00 1.21 0.02 0.08 71.10 09:58:10 08:27:01 3 25.57 0.00 1.72 0.12 0.08 72.51 09:58:10 08:28:01 all 14.43 0.00 0.81 0.33 0.09 84.33 09:58:10 08:28:01 0 14.29 0.00 0.77 0.35 0.08 84.51 09:58:10 08:28:01 1 13.64 0.00 0.59 0.03 0.08 85.65 09:58:10 08:28:01 2 16.98 0.00 1.12 0.02 0.10 81.78 09:58:10 08:28:01 3 12.82 0.00 0.77 0.93 0.10 85.38 09:58:10 08:29:01 all 45.54 0.00 1.71 0.46 0.10 52.19 09:58:10 08:29:01 0 51.12 0.00 1.72 0.05 0.10 47.00 09:58:10 08:29:01 1 44.37 0.00 1.66 0.62 0.10 53.25 09:58:10 08:29:01 2 44.52 0.00 1.65 0.18 0.08 53.56 09:58:10 08:29:01 3 42.14 0.00 1.82 1.00 0.10 54.93 09:58:10 08:30:01 all 36.23 0.00 1.38 0.30 0.09 62.00 09:58:10 08:30:01 0 37.59 0.00 1.22 0.00 0.08 61.11 09:58:10 08:30:01 1 37.13 0.00 1.74 0.20 0.08 60.85 09:58:10 08:30:01 2 38.21 0.00 1.02 0.62 0.10 60.05 09:58:10 08:30:01 3 31.99 0.00 1.55 0.38 0.08 65.99 09:58:10 08:31:01 all 45.75 0.00 1.44 0.26 0.09 52.46 09:58:10 08:31:01 0 48.11 0.00 1.46 0.08 0.07 50.28 09:58:10 08:31:01 1 47.00 0.00 1.21 0.08 0.10 51.62 09:58:10 08:31:01 2 42.75 0.00 1.36 0.22 0.08 55.59 09:58:10 08:31:01 3 45.13 0.00 1.76 0.67 0.10 52.34 09:58:10 08:32:01 all 7.42 0.00 0.55 0.79 0.13 91.11 09:58:10 08:32:01 0 6.61 0.00 0.87 0.00 0.10 92.42 09:58:10 08:32:01 1 8.02 0.00 0.48 0.00 0.15 91.35 09:58:10 08:32:01 2 7.43 0.00 0.39 0.15 0.15 91.89 09:58:10 08:32:01 3 7.62 0.00 0.45 3.01 0.13 88.78 09:58:10 08:33:01 all 28.97 0.00 1.11 0.34 0.09 69.48 09:58:10 08:33:01 0 25.31 0.00 1.18 0.56 0.08 72.86 09:58:10 08:33:01 1 30.61 0.00 1.09 0.03 0.10 68.17 09:58:10 08:33:01 2 29.87 0.00 0.89 0.59 0.08 68.57 09:58:10 08:33:01 3 30.13 0.00 1.30 0.17 0.10 68.31 09:58:10 08:34:01 all 28.55 0.00 1.14 0.56 0.09 69.67 09:58:10 08:34:01 0 26.61 0.00 1.07 0.45 0.08 71.79 09:58:10 08:34:01 1 27.99 0.00 1.34 0.72 0.08 69.87 09:58:10 08:34:01 2 28.82 0.00 1.13 1.03 0.10 68.91 09:58:10 08:34:01 3 30.78 0.00 1.00 0.02 0.08 68.11 09:58:10 09:58:10 08:34:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:35:01 all 2.03 0.00 0.32 0.40 0.08 97.17 09:58:10 08:35:01 0 2.23 0.00 0.35 0.17 0.08 97.18 09:58:10 08:35:01 1 1.73 0.00 0.28 0.18 0.08 97.72 09:58:10 08:35:01 2 1.89 0.00 0.28 1.24 0.07 96.52 09:58:10 08:35:01 3 2.27 0.00 0.38 0.00 0.08 97.26 09:58:10 08:36:01 all 45.20 0.00 1.62 1.28 0.09 51.80 09:58:10 08:36:01 0 46.12 0.00 1.76 0.15 0.08 51.89 09:58:10 08:36:01 1 40.12 0.00 1.73 1.24 0.08 56.82 09:58:10 08:36:01 2 48.34 0.00 1.50 3.51 0.10 46.55 09:58:10 08:36:01 3 46.21 0.00 1.51 0.23 0.08 51.97 09:58:10 08:37:01 all 26.17 0.00 0.79 0.87 0.08 72.09 09:58:10 08:37:01 0 27.53 0.00 0.77 0.37 0.07 71.26 09:58:10 08:37:01 1 28.04 0.00 0.84 0.42 0.08 70.62 09:58:10 08:37:01 2 25.87 0.00 0.80 2.65 0.08 70.60 09:58:10 08:37:01 3 23.22 0.00 0.76 0.05 0.10 75.87 09:58:10 08:38:01 all 35.73 0.00 1.24 0.44 0.08 62.51 09:58:10 08:38:01 0 34.99 0.00 1.34 0.69 0.08 62.90 09:58:10 08:38:01 1 36.06 0.00 0.85 0.10 0.07 62.92 09:58:10 08:38:01 2 35.79 0.00 1.47 0.95 0.10 61.69 09:58:10 08:38:01 3 36.10 0.00 1.29 0.02 0.08 62.51 09:58:10 08:39:01 all 8.24 0.00 0.53 0.02 0.08 91.13 09:58:10 08:39:01 0 8.00 0.00 0.52 0.00 0.08 91.40 09:58:10 08:39:01 1 8.61 0.00 0.52 0.02 0.08 90.78 09:58:10 08:39:01 2 8.93 0.00 0.60 0.05 0.08 90.34 09:58:10 08:39:01 3 7.42 0.00 0.48 0.00 0.07 92.03 09:58:10 08:40:01 all 49.44 0.00 1.55 0.25 0.11 48.65 09:58:10 08:40:01 0 50.48 0.00 1.47 0.23 0.10 47.71 09:58:10 08:40:01 1 47.04 0.00 1.32 0.08 0.10 51.47 09:58:10 08:40:01 2 50.76 0.00 1.63 0.67 0.12 46.83 09:58:10 08:40:01 3 49.51 0.00 1.78 0.03 0.12 48.57 09:58:10 08:41:01 all 6.82 0.00 0.42 0.06 0.07 92.63 09:58:10 08:41:01 0 7.02 0.00 0.45 0.00 0.08 92.44 09:58:10 08:41:01 1 6.77 0.00 0.45 0.10 0.08 92.59 09:58:10 08:41:01 2 6.84 0.00 0.47 0.15 0.07 92.48 09:58:10 08:41:01 3 6.64 0.00 0.30 0.00 0.05 93.01 09:58:10 08:42:01 all 4.14 0.00 0.37 0.05 0.08 95.36 09:58:10 08:42:01 0 4.71 0.00 0.30 0.00 0.07 94.92 09:58:10 08:42:01 1 3.99 0.00 0.45 0.18 0.08 95.29 09:58:10 08:42:01 2 3.89 0.00 0.34 0.03 0.08 95.66 09:58:10 08:42:01 3 3.96 0.00 0.39 0.00 0.08 95.57 09:58:10 08:43:01 all 50.74 0.00 1.83 0.27 0.10 47.05 09:58:10 08:43:01 0 50.32 0.00 1.98 0.23 0.08 47.38 09:58:10 08:43:01 1 50.18 0.00 1.69 0.13 0.12 47.88 09:58:10 08:43:01 2 51.41 0.00 1.37 0.38 0.10 46.73 09:58:10 08:43:01 3 51.06 0.00 2.29 0.33 0.12 46.20 09:58:10 08:44:01 all 7.83 0.00 0.55 0.02 0.09 91.50 09:58:10 08:44:01 0 7.86 0.00 0.53 0.05 0.10 91.46 09:58:10 08:44:01 1 8.65 0.00 0.55 0.00 0.08 90.71 09:58:10 08:44:01 2 7.16 0.00 0.67 0.00 0.10 92.07 09:58:10 08:44:01 3 7.66 0.00 0.47 0.03 0.08 91.76 09:58:10 08:45:01 all 2.62 0.00 0.39 0.02 0.07 96.90 09:58:10 08:45:01 0 2.39 0.00 0.35 0.05 0.07 97.14 09:58:10 08:45:01 1 2.81 0.00 0.33 0.00 0.07 96.79 09:58:10 08:45:01 2 2.55 0.00 0.42 0.00 0.07 96.96 09:58:10 08:45:01 3 2.72 0.00 0.47 0.03 0.07 96.72 09:58:10 09:58:10 08:45:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:46:01 all 3.01 0.00 0.48 0.05 0.08 96.38 09:58:10 08:46:01 0 2.96 0.00 0.38 0.03 0.07 96.55 09:58:10 08:46:01 1 3.03 0.00 0.53 0.00 0.08 96.35 09:58:10 08:46:01 2 3.00 0.00 0.53 0.00 0.08 96.38 09:58:10 08:46:01 3 3.03 0.00 0.47 0.17 0.10 96.24 09:58:10 08:47:01 all 2.48 0.00 0.45 0.03 0.08 96.97 09:58:10 08:47:01 0 2.32 0.00 0.32 0.05 0.07 97.25 09:58:10 08:47:01 1 2.52 0.00 0.35 0.00 0.07 97.06 09:58:10 08:47:01 2 2.76 0.00 0.72 0.00 0.10 96.42 09:58:10 08:47:01 3 2.32 0.00 0.40 0.07 0.07 97.15 09:58:10 08:48:01 all 2.77 0.00 0.40 0.15 0.09 96.59 09:58:10 08:48:01 0 3.01 0.00 0.43 0.32 0.08 96.15 09:58:10 08:48:01 1 2.62 0.00 0.32 0.00 0.08 96.98 09:58:10 08:48:01 2 2.66 0.00 0.44 0.00 0.08 96.82 09:58:10 08:48:01 3 2.78 0.00 0.43 0.28 0.10 96.40 09:58:10 08:49:01 all 2.30 0.00 0.39 0.02 0.07 97.22 09:58:10 08:49:01 0 2.64 0.00 0.37 0.03 0.08 96.88 09:58:10 08:49:01 1 1.91 0.00 0.40 0.00 0.07 97.62 09:58:10 08:49:01 2 2.33 0.00 0.35 0.00 0.08 97.24 09:58:10 08:49:01 3 2.33 0.00 0.43 0.03 0.07 97.13 09:58:10 08:50:01 all 2.75 0.00 0.42 0.02 0.07 96.74 09:58:10 08:50:01 0 2.86 0.00 0.45 0.05 0.05 96.59 09:58:10 08:50:01 1 2.38 0.00 0.50 0.00 0.10 97.02 09:58:10 08:50:01 2 2.85 0.00 0.22 0.00 0.07 96.86 09:58:10 08:50:01 3 2.90 0.00 0.50 0.03 0.08 96.49 09:58:10 08:51:01 all 46.49 0.00 1.65 0.27 0.10 51.49 09:58:10 08:51:01 0 45.57 0.00 1.87 0.28 0.10 52.18 09:58:10 08:51:01 1 44.29 0.00 2.03 0.52 0.10 53.06 09:58:10 08:51:01 2 47.71 0.00 1.16 0.13 0.08 50.92 09:58:10 08:51:01 3 48.40 0.00 1.56 0.13 0.10 49.81 09:58:10 08:52:01 all 8.36 0.00 0.45 0.02 0.09 91.09 09:58:10 08:52:01 0 8.36 0.00 0.48 0.02 0.10 91.04 09:58:10 08:52:01 1 8.12 0.00 0.52 0.00 0.07 91.29 09:58:10 08:52:01 2 8.18 0.00 0.44 0.00 0.10 91.29 09:58:10 08:52:01 3 8.77 0.00 0.35 0.07 0.08 90.72 09:58:10 08:53:01 all 4.78 0.00 0.42 0.01 0.08 94.71 09:58:10 08:53:01 0 4.97 0.00 0.45 0.02 0.08 94.48 09:58:10 08:53:01 1 4.43 0.00 0.35 0.00 0.07 95.16 09:58:10 08:53:01 2 4.83 0.00 0.50 0.00 0.08 94.58 09:58:10 08:53:01 3 4.90 0.00 0.37 0.03 0.08 94.61 09:58:10 08:54:01 all 2.22 0.00 0.33 0.02 0.07 97.36 09:58:10 08:54:01 0 2.00 0.00 0.22 0.03 0.05 97.70 09:58:10 08:54:01 1 2.08 0.00 0.32 0.00 0.07 97.54 09:58:10 08:54:01 2 2.52 0.00 0.49 0.00 0.08 96.91 09:58:10 08:54:01 3 2.31 0.00 0.30 0.05 0.07 97.27 09:58:10 08:55:01 all 2.91 0.00 0.42 0.03 0.07 96.58 09:58:10 08:55:01 0 2.47 0.00 0.32 0.00 0.05 97.16 09:58:10 08:55:01 1 2.72 0.00 0.37 0.00 0.07 96.84 09:58:10 08:55:01 2 3.08 0.00 0.55 0.05 0.07 96.25 09:58:10 08:55:01 3 3.35 0.00 0.44 0.05 0.08 96.08 09:58:10 08:56:01 all 2.24 0.00 0.36 0.02 0.08 97.30 09:58:10 08:56:01 0 1.91 0.00 0.35 0.02 0.07 97.66 09:58:10 08:56:01 1 2.55 0.00 0.42 0.02 0.08 96.93 09:58:10 08:56:01 2 2.31 0.00 0.44 0.00 0.08 97.17 09:58:10 08:56:01 3 2.21 0.00 0.24 0.03 0.10 97.42 09:58:10 09:58:10 08:56:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 08:57:01 all 3.64 0.00 0.44 0.01 0.08 95.83 09:58:10 08:57:01 0 3.46 0.00 0.40 0.00 0.07 96.07 09:58:10 08:57:01 1 3.53 0.00 0.38 0.00 0.05 96.04 09:58:10 08:57:01 2 3.83 0.00 0.57 0.00 0.12 95.49 09:58:10 08:57:01 3 3.73 0.00 0.40 0.03 0.08 95.74 09:58:10 08:58:01 all 2.62 0.00 0.31 0.01 0.07 96.99 09:58:10 08:58:01 0 2.53 0.00 0.28 0.02 0.08 97.09 09:58:10 08:58:01 1 2.40 0.00 0.40 0.00 0.07 97.13 09:58:10 08:58:01 2 3.20 0.00 0.32 0.00 0.07 96.42 09:58:10 08:58:01 3 2.33 0.00 0.23 0.03 0.07 97.33 09:58:10 08:59:01 all 0.92 0.00 0.25 0.01 0.09 98.73 09:58:10 08:59:01 0 0.44 0.00 0.24 0.00 0.10 99.23 09:58:10 08:59:01 1 0.43 0.00 0.22 0.02 0.07 99.27 09:58:10 08:59:01 2 2.38 0.00 0.25 0.00 0.12 97.26 09:58:10 08:59:01 3 0.43 0.00 0.28 0.02 0.08 99.18 09:58:10 09:00:01 all 0.49 0.00 0.25 0.00 0.06 99.20 09:58:10 09:00:01 0 0.55 0.00 0.25 0.00 0.05 99.15 09:58:10 09:00:01 1 0.60 0.00 0.33 0.00 0.07 99.00 09:58:10 09:00:01 2 0.38 0.00 0.20 0.00 0.07 99.35 09:58:10 09:00:01 3 0.40 0.00 0.22 0.02 0.05 99.31 09:58:10 09:01:01 all 22.87 0.00 0.95 0.08 0.07 76.03 09:58:10 09:01:01 0 23.24 0.00 0.97 0.03 0.07 75.69 09:58:10 09:01:01 1 20.82 0.00 0.94 0.03 0.07 78.14 09:58:10 09:01:01 2 23.70 0.00 0.67 0.00 0.07 75.57 09:58:10 09:01:01 3 23.73 0.00 1.20 0.25 0.08 74.73 09:58:10 09:02:01 all 43.63 0.00 1.46 0.47 0.10 54.34 09:58:10 09:02:01 0 45.14 0.00 1.67 0.18 0.08 52.92 09:58:10 09:02:01 1 43.12 0.00 1.25 0.02 0.10 55.51 09:58:10 09:02:01 2 42.91 0.00 1.60 1.35 0.10 54.04 09:58:10 09:02:01 3 43.37 0.00 1.30 0.33 0.10 54.89 09:58:10 09:03:01 all 8.65 0.00 0.55 0.01 0.08 90.71 09:58:10 09:03:01 0 9.03 0.00 0.55 0.00 0.10 90.32 09:58:10 09:03:01 1 8.28 0.00 0.53 0.02 0.07 91.10 09:58:10 09:03:01 2 8.63 0.00 0.52 0.03 0.07 90.75 09:58:10 09:03:01 3 8.65 0.00 0.58 0.00 0.08 90.68 09:58:10 09:04:01 all 5.03 0.00 0.50 0.01 0.07 94.38 09:58:10 09:04:01 0 5.63 0.00 0.45 0.02 0.07 93.84 09:58:10 09:04:01 1 5.86 0.00 0.45 0.02 0.08 93.59 09:58:10 09:04:01 2 4.18 0.00 0.55 0.02 0.07 95.19 09:58:10 09:04:01 3 4.44 0.00 0.57 0.00 0.07 94.93 09:58:10 09:05:01 all 3.04 0.00 0.47 0.01 0.07 96.41 09:58:10 09:05:01 0 3.14 0.00 0.52 0.00 0.07 96.27 09:58:10 09:05:01 1 3.02 0.00 0.48 0.02 0.07 96.42 09:58:10 09:05:01 2 3.01 0.00 0.40 0.02 0.08 96.49 09:58:10 09:05:01 3 2.98 0.00 0.48 0.00 0.07 96.47 09:58:10 09:06:01 all 4.72 0.00 0.52 0.03 0.07 94.66 09:58:10 09:06:01 0 5.12 0.00 0.60 0.00 0.07 94.22 09:58:10 09:06:01 1 4.43 0.00 0.53 0.02 0.07 94.95 09:58:10 09:06:01 2 4.54 0.00 0.49 0.12 0.07 94.79 09:58:10 09:06:01 3 4.79 0.00 0.45 0.00 0.07 94.69 09:58:10 09:07:01 all 2.22 0.00 0.44 0.02 0.07 97.24 09:58:10 09:07:01 0 1.98 0.00 0.50 0.00 0.07 97.45 09:58:10 09:07:01 1 2.47 0.00 0.43 0.02 0.10 96.99 09:58:10 09:07:01 2 2.43 0.00 0.42 0.07 0.05 97.04 09:58:10 09:07:01 3 2.02 0.00 0.42 0.00 0.07 97.50 09:58:10 09:58:10 09:07:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 09:08:01 all 2.66 0.00 0.44 0.02 0.08 96.80 09:58:10 09:08:01 0 2.43 0.00 0.45 0.02 0.08 97.02 09:58:10 09:08:01 1 2.63 0.00 0.47 0.02 0.08 96.80 09:58:10 09:08:01 2 2.73 0.00 0.48 0.03 0.08 96.67 09:58:10 09:08:01 3 2.84 0.00 0.37 0.00 0.08 96.70 09:58:10 09:09:01 all 8.43 0.00 0.78 0.01 0.07 90.71 09:58:10 09:09:01 0 8.18 0.00 0.73 0.02 0.07 91.00 09:58:10 09:09:01 1 9.05 0.00 0.58 0.02 0.08 90.27 09:58:10 09:09:01 2 8.49 0.00 0.95 0.02 0.07 90.48 09:58:10 09:09:01 3 7.98 0.00 0.87 0.00 0.07 91.09 09:58:10 09:10:01 all 54.73 0.00 1.68 0.25 0.12 43.22 09:58:10 09:10:01 0 53.80 0.00 1.45 0.33 0.10 44.32 09:58:10 09:10:01 1 51.68 0.00 1.41 0.10 0.10 46.71 09:58:10 09:10:01 2 56.86 0.00 1.78 0.58 0.10 40.68 09:58:10 09:10:01 3 56.60 0.00 2.07 0.00 0.17 41.16 09:58:10 09:11:01 all 8.95 0.00 0.57 0.02 0.07 90.39 09:58:10 09:11:01 0 7.99 0.00 0.72 0.02 0.07 91.21 09:58:10 09:11:01 1 9.34 0.00 0.58 0.00 0.07 90.01 09:58:10 09:11:01 2 9.85 0.00 0.41 0.07 0.08 89.59 09:58:10 09:11:01 3 8.62 0.00 0.57 0.00 0.08 90.73 09:58:10 09:12:01 all 7.50 0.00 0.53 0.01 0.08 91.87 09:58:10 09:12:01 0 6.96 0.00 0.42 0.00 0.08 92.54 09:58:10 09:12:01 1 7.89 0.00 0.47 0.00 0.08 91.56 09:58:10 09:12:01 2 7.90 0.00 0.52 0.02 0.08 91.48 09:58:10 09:12:01 3 7.27 0.00 0.71 0.03 0.08 91.90 09:58:10 09:13:01 all 3.35 0.00 0.42 0.01 0.08 96.13 09:58:10 09:13:01 0 3.79 0.00 0.57 0.00 0.10 95.54 09:58:10 09:13:01 1 3.28 0.00 0.44 0.00 0.07 96.22 09:58:10 09:13:01 2 2.90 0.00 0.27 0.03 0.07 96.73 09:58:10 09:13:01 3 3.44 0.00 0.42 0.02 0.08 96.05 09:58:10 09:14:02 all 2.77 0.00 0.43 0.01 0.08 96.72 09:58:10 09:14:02 0 2.93 0.00 0.48 0.02 0.07 96.50 09:58:10 09:14:02 1 3.01 0.00 0.47 0.00 0.08 96.44 09:58:10 09:14:02 2 2.73 0.00 0.48 0.02 0.08 96.69 09:58:10 09:14:02 3 2.40 0.00 0.30 0.00 0.07 97.23 09:58:10 09:15:01 all 2.77 0.00 0.40 0.04 0.07 96.72 09:58:10 09:15:01 0 2.32 0.00 0.53 0.03 0.07 97.05 09:58:10 09:15:01 1 2.59 0.00 0.30 0.00 0.07 97.04 09:58:10 09:15:01 2 2.93 0.00 0.42 0.12 0.08 96.45 09:58:10 09:15:01 3 3.23 0.00 0.34 0.00 0.07 96.37 09:58:10 09:16:01 all 2.55 0.00 0.44 0.01 0.08 96.93 09:58:10 09:16:01 0 2.25 0.00 0.57 0.02 0.08 97.09 09:58:10 09:16:01 1 2.69 0.00 0.40 0.00 0.08 96.83 09:58:10 09:16:01 2 2.75 0.00 0.43 0.03 0.07 96.72 09:58:10 09:16:01 3 2.50 0.00 0.35 0.00 0.08 97.07 09:58:10 09:17:01 all 2.51 0.00 0.43 0.01 0.08 96.96 09:58:10 09:17:01 0 2.83 0.00 0.52 0.05 0.08 96.51 09:58:10 09:17:01 1 2.20 0.00 0.35 0.00 0.08 97.36 09:58:10 09:17:01 2 2.54 0.00 0.45 0.00 0.10 96.91 09:58:10 09:17:01 3 2.48 0.00 0.40 0.00 0.07 97.05 09:58:10 09:18:01 all 2.55 0.00 0.42 0.02 0.07 96.95 09:58:10 09:18:01 0 2.33 0.00 0.35 0.07 0.07 97.18 09:58:10 09:18:01 1 2.83 0.00 0.40 0.00 0.05 96.72 09:58:10 09:18:01 2 2.29 0.00 0.37 0.00 0.07 97.28 09:58:10 09:18:01 3 2.75 0.00 0.55 0.00 0.08 96.62 09:58:10 09:58:10 09:18:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 09:19:01 all 3.14 0.00 0.68 0.25 0.09 95.84 09:58:10 09:19:01 0 2.29 0.00 0.64 0.87 0.08 96.12 09:58:10 09:19:01 1 2.25 0.00 0.58 0.00 0.10 97.06 09:58:10 09:19:01 2 3.47 0.00 0.65 0.00 0.08 95.80 09:58:10 09:19:01 3 4.54 0.00 0.83 0.15 0.08 94.40 09:58:10 09:20:01 all 43.82 0.00 1.55 1.48 0.09 53.06 09:58:10 09:20:01 0 46.37 0.00 1.54 1.30 0.08 50.71 09:58:10 09:20:01 1 43.18 0.00 1.51 1.05 0.10 54.16 09:58:10 09:20:01 2 38.62 0.00 1.64 3.04 0.08 56.62 09:58:10 09:20:01 3 47.12 0.00 1.50 0.54 0.10 50.74 09:58:10 09:21:01 all 32.45 0.00 1.25 0.45 0.09 65.76 09:58:10 09:21:01 0 34.04 0.00 1.47 0.18 0.10 64.21 09:58:10 09:21:01 1 30.72 0.00 1.35 1.34 0.08 66.51 09:58:10 09:21:01 2 31.26 0.00 1.21 0.17 0.10 67.26 09:58:10 09:21:01 3 33.77 0.00 0.97 0.12 0.08 65.05 09:58:10 09:22:01 all 49.81 0.00 1.63 0.28 0.09 48.20 09:58:10 09:22:01 0 52.04 0.00 1.74 0.08 0.08 46.05 09:58:10 09:22:01 1 43.97 0.00 1.55 0.77 0.08 53.64 09:58:10 09:22:01 2 52.06 0.00 1.69 0.00 0.10 46.15 09:58:10 09:22:01 3 51.21 0.00 1.52 0.25 0.10 46.92 09:58:10 09:23:01 all 8.20 0.00 0.50 0.01 0.09 91.21 09:58:10 09:23:01 0 8.47 0.00 0.62 0.00 0.10 90.81 09:58:10 09:23:01 1 8.17 0.00 0.51 0.02 0.10 91.21 09:58:10 09:23:01 2 7.90 0.00 0.45 0.00 0.08 91.57 09:58:10 09:23:01 3 8.24 0.00 0.42 0.02 0.07 91.26 09:58:10 09:24:01 all 28.53 0.00 1.22 0.16 0.09 70.00 09:58:10 09:24:01 0 28.92 0.00 1.00 0.05 0.07 69.96 09:58:10 09:24:01 1 28.75 0.00 1.35 0.42 0.10 69.37 09:58:10 09:24:01 2 26.84 0.00 1.18 0.08 0.10 71.80 09:58:10 09:24:01 3 29.63 0.00 1.34 0.10 0.08 68.85 09:58:10 09:25:01 all 15.90 0.00 0.85 0.19 0.08 82.98 09:58:10 09:25:01 0 15.24 0.00 1.04 0.17 0.08 83.47 09:58:10 09:25:01 1 17.28 0.00 0.77 0.00 0.08 81.87 09:58:10 09:25:01 2 15.08 0.00 0.68 0.25 0.08 83.91 09:58:10 09:25:01 3 15.98 0.00 0.92 0.33 0.08 82.69 09:58:10 09:26:01 all 45.41 0.00 1.29 0.36 0.09 52.85 09:58:10 09:26:01 0 47.49 0.00 1.22 0.02 0.08 51.19 09:58:10 09:26:01 1 47.66 0.00 1.12 0.00 0.08 51.13 09:58:10 09:26:01 2 44.40 0.00 1.52 0.02 0.08 53.98 09:58:10 09:26:01 3 42.08 0.00 1.30 1.40 0.10 55.11 09:58:10 09:27:01 all 6.91 0.00 0.41 0.02 0.07 92.60 09:58:10 09:27:01 0 6.66 0.00 0.49 0.00 0.07 92.79 09:58:10 09:27:01 1 7.27 0.00 0.37 0.02 0.07 92.28 09:58:10 09:27:01 2 6.95 0.00 0.40 0.02 0.07 92.57 09:58:10 09:27:01 3 6.75 0.00 0.40 0.03 0.07 92.75 09:58:10 09:28:01 all 5.12 0.00 0.56 0.02 0.07 94.24 09:58:10 09:28:01 0 5.46 0.00 0.81 0.00 0.08 93.65 09:58:10 09:28:01 1 5.16 0.00 0.54 0.02 0.07 94.22 09:58:10 09:28:01 2 4.90 0.00 0.47 0.03 0.07 94.53 09:58:10 09:28:01 3 4.96 0.00 0.42 0.02 0.07 94.54 09:58:10 09:29:01 all 50.84 0.00 1.57 0.29 0.09 47.20 09:58:10 09:29:01 0 49.73 0.00 1.59 0.07 0.10 48.51 09:58:10 09:29:01 1 52.53 0.00 1.33 0.47 0.10 45.57 09:58:10 09:29:01 2 51.38 0.00 1.97 0.15 0.08 46.41 09:58:10 09:29:01 3 49.72 0.00 1.41 0.49 0.08 48.31 09:58:10 09:58:10 09:29:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 09:30:01 all 3.23 0.00 0.46 0.01 0.07 96.22 09:58:10 09:30:01 0 3.38 0.00 0.50 0.00 0.07 96.05 09:58:10 09:30:01 1 3.01 0.00 0.53 0.05 0.08 96.33 09:58:10 09:30:01 2 3.35 0.00 0.40 0.00 0.07 96.19 09:58:10 09:30:01 3 3.20 0.00 0.42 0.00 0.07 96.32 09:58:10 09:31:01 all 4.79 0.00 0.53 0.03 0.09 94.57 09:58:10 09:31:01 0 4.92 0.00 0.50 0.00 0.08 94.50 09:58:10 09:31:01 1 5.01 0.00 0.68 0.12 0.08 94.10 09:58:10 09:31:01 2 4.73 0.00 0.43 0.00 0.08 94.75 09:58:10 09:31:01 3 4.48 0.00 0.50 0.00 0.10 94.92 09:58:10 09:32:01 all 2.44 0.00 0.43 0.03 0.08 97.02 09:58:10 09:32:01 0 2.14 0.00 0.43 0.08 0.07 97.28 09:58:10 09:32:01 1 2.52 0.00 0.37 0.02 0.10 96.99 09:58:10 09:32:01 2 2.18 0.00 0.28 0.00 0.07 97.47 09:58:10 09:32:01 3 2.91 0.00 0.65 0.00 0.10 96.34 09:58:10 09:33:01 all 2.65 0.00 0.44 0.03 0.06 96.82 09:58:10 09:33:01 0 2.76 0.00 0.62 0.00 0.07 96.55 09:58:10 09:33:01 1 2.83 0.00 0.35 0.10 0.07 96.65 09:58:10 09:33:01 2 2.42 0.00 0.38 0.00 0.07 97.13 09:58:10 09:33:01 3 2.59 0.00 0.42 0.00 0.05 96.95 09:58:10 09:34:01 all 2.52 0.00 0.42 0.01 0.07 96.98 09:58:10 09:34:01 0 2.42 0.00 0.43 0.00 0.08 97.06 09:58:10 09:34:01 1 3.31 0.00 0.25 0.03 0.05 96.36 09:58:10 09:34:01 2 2.15 0.00 0.50 0.00 0.08 97.26 09:58:10 09:34:01 3 2.19 0.00 0.48 0.00 0.08 97.25 09:58:10 09:35:01 all 2.06 0.00 0.46 0.02 0.07 97.39 09:58:10 09:35:01 0 1.82 0.00 0.60 0.03 0.07 97.48 09:58:10 09:35:01 1 3.10 0.00 0.51 0.03 0.08 96.28 09:58:10 09:35:01 2 1.68 0.00 0.43 0.00 0.07 97.82 09:58:10 09:35:01 3 1.64 0.00 0.30 0.00 0.07 98.00 09:58:10 09:36:01 all 2.83 0.00 0.38 0.01 0.06 96.71 09:58:10 09:36:01 0 2.35 0.00 0.42 0.00 0.07 97.17 09:58:10 09:36:01 1 4.16 0.00 0.48 0.03 0.07 95.26 09:58:10 09:36:01 2 3.07 0.00 0.35 0.00 0.07 96.52 09:58:10 09:36:01 3 1.73 0.00 0.28 0.00 0.05 97.93 09:58:10 09:37:01 all 7.28 0.00 0.85 0.06 0.07 91.74 09:58:10 09:37:01 0 6.49 0.00 0.90 0.02 0.07 92.53 09:58:10 09:37:01 1 12.06 0.00 0.94 0.22 0.07 86.72 09:58:10 09:37:01 2 4.83 0.00 0.72 0.00 0.07 94.38 09:58:10 09:37:01 3 5.71 0.00 0.83 0.02 0.08 93.36 09:58:10 09:38:01 all 59.52 0.00 1.85 0.43 0.10 38.09 09:58:10 09:38:01 0 62.62 0.00 1.25 0.10 0.10 35.92 09:58:10 09:38:01 1 56.88 0.00 1.79 1.00 0.10 40.22 09:58:10 09:38:01 2 56.80 0.00 1.92 0.25 0.10 40.94 09:58:10 09:38:01 3 61.80 0.00 2.45 0.39 0.10 35.27 09:58:10 09:39:01 all 4.72 0.00 0.30 0.01 0.08 94.89 09:58:10 09:39:01 0 4.88 0.00 0.30 0.02 0.08 94.72 09:58:10 09:39:01 1 5.31 0.00 0.33 0.03 0.08 94.24 09:58:10 09:39:01 2 5.03 0.00 0.37 0.00 0.08 94.52 09:58:10 09:39:01 3 3.64 0.00 0.20 0.00 0.07 96.10 09:58:10 09:40:01 all 36.03 0.00 1.31 0.04 0.10 62.52 09:58:10 09:40:01 0 38.72 0.00 1.27 0.07 0.10 59.84 09:58:10 09:40:01 1 36.03 0.00 0.99 0.03 0.08 62.87 09:58:10 09:40:01 2 36.82 0.00 1.56 0.07 0.10 61.45 09:58:10 09:40:01 3 32.56 0.00 1.44 0.00 0.10 65.90 09:58:10 09:58:10 09:40:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 09:41:01 all 24.11 0.00 0.71 0.25 0.09 74.84 09:58:10 09:41:01 0 25.17 0.00 0.70 0.65 0.08 73.40 09:58:10 09:41:01 1 24.99 0.00 0.60 0.18 0.08 74.14 09:58:10 09:41:01 2 22.45 0.00 0.89 0.03 0.10 76.53 09:58:10 09:41:01 3 23.84 0.00 0.65 0.13 0.10 75.28 09:58:10 09:42:01 all 2.59 0.00 0.33 0.02 0.07 96.99 09:58:10 09:42:01 0 2.55 0.00 0.30 0.02 0.07 97.06 09:58:10 09:42:01 1 2.77 0.00 0.42 0.00 0.07 96.74 09:58:10 09:42:01 2 2.76 0.00 0.42 0.05 0.07 96.70 09:58:10 09:42:01 3 2.28 0.00 0.18 0.00 0.07 97.47 09:58:10 09:43:01 all 2.81 0.00 0.33 0.01 0.05 96.80 09:58:10 09:43:01 0 2.79 0.00 0.27 0.03 0.05 96.86 09:58:10 09:43:01 1 3.01 0.00 0.37 0.00 0.07 96.55 09:58:10 09:43:01 2 2.82 0.00 0.43 0.00 0.05 96.69 09:58:10 09:43:01 3 2.60 0.00 0.25 0.00 0.05 97.10 09:58:10 09:44:01 all 2.53 0.00 0.33 0.02 0.08 97.03 09:58:10 09:44:01 0 2.18 0.00 0.28 0.03 0.10 97.40 09:58:10 09:44:01 1 2.77 0.00 0.40 0.02 0.08 96.73 09:58:10 09:44:01 2 3.04 0.00 0.38 0.03 0.08 96.46 09:58:10 09:44:01 3 2.13 0.00 0.27 0.00 0.07 97.53 09:58:10 09:45:01 all 2.99 0.00 0.34 0.01 0.08 96.58 09:58:10 09:45:01 0 2.52 0.00 0.27 0.02 0.05 97.15 09:58:10 09:45:01 1 2.63 0.00 0.35 0.00 0.08 96.94 09:58:10 09:45:01 2 3.22 0.00 0.38 0.02 0.08 96.29 09:58:10 09:45:01 3 3.60 0.00 0.37 0.00 0.08 95.95 09:58:10 09:46:01 all 1.97 0.00 0.33 0.02 0.08 97.60 09:58:10 09:46:01 0 1.77 0.00 0.33 0.05 0.08 97.76 09:58:10 09:46:01 1 1.85 0.00 0.32 0.00 0.07 97.76 09:58:10 09:46:01 2 2.21 0.00 0.42 0.02 0.10 97.25 09:58:10 09:46:01 3 2.04 0.00 0.27 0.00 0.05 97.64 09:58:10 09:47:01 all 2.77 0.00 0.34 0.01 0.07 96.82 09:58:10 09:47:01 0 2.44 0.00 0.35 0.02 0.05 97.14 09:58:10 09:47:01 1 2.89 0.00 0.38 0.00 0.07 96.65 09:58:10 09:47:01 2 2.99 0.00 0.37 0.02 0.08 96.54 09:58:10 09:47:01 3 2.75 0.00 0.25 0.00 0.07 96.93 09:58:10 09:48:01 all 0.52 0.00 0.20 0.02 0.08 99.19 09:58:10 09:48:01 0 0.69 0.00 0.29 0.03 0.08 98.91 09:58:10 09:48:01 1 0.32 0.00 0.15 0.00 0.08 99.45 09:58:10 09:48:01 2 0.54 0.00 0.27 0.03 0.08 99.08 09:58:10 09:48:01 3 0.53 0.00 0.10 0.00 0.05 99.32 09:58:10 09:49:01 all 0.51 0.00 0.28 0.01 0.08 99.13 09:58:10 09:49:01 0 0.67 0.00 0.39 0.02 0.08 98.84 09:58:10 09:49:01 1 0.42 0.00 0.30 0.00 0.08 99.20 09:58:10 09:49:01 2 0.37 0.00 0.22 0.02 0.07 99.33 09:58:10 09:49:01 3 0.57 0.00 0.20 0.00 0.08 99.15 09:58:10 09:50:01 all 27.42 0.00 1.17 0.03 0.09 71.29 09:58:10 09:50:01 0 26.77 0.00 1.22 0.05 0.08 71.88 09:58:10 09:50:01 1 27.95 0.00 1.44 0.02 0.08 70.52 09:58:10 09:50:01 2 28.03 0.00 1.05 0.05 0.10 70.76 09:58:10 09:50:01 3 26.93 0.00 0.97 0.02 0.08 72.00 09:58:10 09:51:01 all 37.83 0.00 1.17 0.27 0.09 60.63 09:58:10 09:51:01 0 38.56 0.00 1.28 0.20 0.08 59.87 09:58:10 09:51:01 1 39.95 0.00 1.60 0.02 0.10 58.33 09:58:10 09:51:01 2 38.76 0.00 0.77 0.68 0.10 59.69 09:58:10 09:51:01 3 34.07 0.00 1.03 0.18 0.08 64.63 09:58:10 09:58:10 09:51:01 CPU %user %nice %system %iowait %steal %idle 09:58:10 09:52:01 all 7.29 0.00 0.53 0.01 0.08 92.10 09:58:10 09:52:01 0 7.49 0.00 0.53 0.00 0.07 91.92 09:58:10 09:52:01 1 7.41 0.00 0.50 0.00 0.08 92.00 09:58:10 09:52:01 2 7.09 0.00 0.62 0.02 0.08 92.19 09:58:10 09:52:01 3 7.15 0.00 0.45 0.02 0.08 92.29 09:58:10 09:53:01 all 6.86 0.00 0.55 0.01 0.08 92.49 09:58:10 09:53:01 0 6.61 0.00 0.43 0.00 0.07 92.89 09:58:10 09:53:01 1 6.71 0.00 0.50 0.03 0.08 92.67 09:58:10 09:53:01 2 7.67 0.00 0.68 0.02 0.10 91.54 09:58:10 09:53:01 3 6.45 0.00 0.60 0.00 0.08 92.86 09:58:10 09:54:01 all 5.55 0.00 0.53 0.01 0.08 93.83 09:58:10 09:54:01 0 5.41 0.00 0.50 0.03 0.08 93.97 09:58:10 09:54:01 1 5.26 0.00 0.43 0.00 0.08 94.22 09:58:10 09:54:01 2 6.45 0.00 0.65 0.02 0.08 92.80 09:58:10 09:54:01 3 5.06 0.00 0.53 0.00 0.08 94.33 09:58:10 09:55:01 all 1.14 0.00 0.37 0.00 0.07 98.42 09:58:10 09:55:01 0 0.98 0.00 0.57 0.00 0.07 98.39 09:58:10 09:55:01 1 0.83 0.00 0.35 0.00 0.08 98.74 09:58:10 09:55:01 2 1.54 0.00 0.23 0.02 0.07 98.15 09:58:10 09:55:01 3 1.21 0.00 0.32 0.00 0.07 98.40 09:58:10 09:56:01 all 0.71 0.00 0.36 0.01 0.08 98.84 09:58:10 09:56:01 0 0.67 0.00 0.45 0.02 0.08 98.78 09:58:10 09:56:01 1 0.86 0.00 0.33 0.02 0.07 98.72 09:58:10 09:56:01 2 0.70 0.00 0.35 0.02 0.07 98.86 09:58:10 09:56:01 3 0.60 0.00 0.32 0.00 0.08 99.00 09:58:10 09:57:01 all 1.99 0.00 0.50 0.05 0.08 97.38 09:58:10 09:57:01 0 1.84 0.00 0.42 0.02 0.07 97.66 09:58:10 09:57:01 1 1.58 0.00 0.35 0.13 0.07 97.88 09:58:10 09:57:01 2 1.00 0.00 0.70 0.00 0.10 98.20 09:58:10 09:57:01 3 3.56 0.00 0.52 0.05 0.07 95.80 09:58:10 09:58:01 all 31.58 0.00 1.89 1.93 0.07 64.53 09:58:10 09:58:01 0 24.29 0.00 2.21 2.80 0.07 70.63 09:58:10 09:58:01 1 28.42 0.00 1.57 4.05 0.07 65.89 09:58:10 09:58:01 2 50.95 0.00 2.00 0.62 0.07 46.36 09:58:10 09:58:01 3 22.76 0.00 1.75 0.28 0.10 75.11 09:58:10 Average: all 18.51 0.13 1.00 0.53 0.09 79.74 09:58:10 Average: 0 18.53 0.11 0.99 0.57 0.08 79.71 09:58:10 Average: 1 18.61 0.12 0.99 0.51 0.09 79.68 09:58:10 Average: 2 18.72 0.14 1.02 0.56 0.09 79.47 09:58:10 Average: 3 18.19 0.13 1.02 0.49 0.09 80.09 09:58:10 09:58:10 09:58:10