17:14:35 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/113874 17:14:35 Running as SYSTEM 17:14:35 [EnvInject] - Loading node environment variables. 17:14:35 Building remotely on prd-ubuntu2004-docker-4c-16g-40238 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 17:14:35 [ssh-agent] Looking for ssh-agent implementation... 17:14:36 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 17:14:36 $ ssh-agent 17:14:36 SSH_AUTH_SOCK=/tmp/ssh-39fqgVkFH53r/agent.13145 17:14:36 SSH_AGENT_PID=13150 17:14:36 [ssh-agent] Started. 17:14:36 Running ssh-add (command line suppressed) 17:14:36 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_15854625186528091278.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_15854625186528091278.key) 17:14:36 [ssh-agent] Using credentials jenkins (jenkins-ssh) 17:14:36 The recommended git tool is: NONE 17:14:38 using credential jenkins-ssh 17:14:38 Wiping out workspace first. 17:14:38 Cloning the remote Git repository 17:14:38 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 17:14:38 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 17:14:38 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 17:14:38 > git --version # timeout=10 17:14:38 > git --version # 'git version 2.25.1' 17:14:38 using GIT_SSH to set credentials jenkins-ssh 17:14:38 Verifying host key using known hosts file 17:14:38 You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. 17:14:38 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 17:14:41 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 17:14:41 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 17:14:41 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 17:14:41 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 17:14:41 using GIT_SSH to set credentials jenkins-ssh 17:14:41 Verifying host key using known hosts file 17:14:41 You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. 17:14:41 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/74/113874/1 # timeout=10 17:14:42 > git rev-parse 701d4a9f2e70c32d5d809d11fa5441360fa8a8ee^{commit} # timeout=10 17:14:42 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 17:14:42 Checking out Revision 701d4a9f2e70c32d5d809d11fa5441360fa8a8ee (refs/changes/74/113874/1) 17:14:42 > git config core.sparsecheckout # timeout=10 17:14:42 > git checkout -f 701d4a9f2e70c32d5d809d11fa5441360fa8a8ee # timeout=10 17:14:45 Commit message: "Correct bugs handling spectrum constraint" 17:14:45 > git rev-parse FETCH_HEAD^{commit} # timeout=10 17:14:45 > git rev-list --no-walk ee77c94d73171d4eb7a8f85abdfd387dc14ffd3a # timeout=10 17:14:45 > git remote # timeout=10 17:14:45 > git submodule init # timeout=10 17:14:45 > git submodule sync # timeout=10 17:14:45 > git config --get remote.origin.url # timeout=10 17:14:45 > git submodule init # timeout=10 17:14:45 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 17:14:45 ERROR: No submodules found. 17:14:46 provisioning config files... 17:14:46 copy managed file [npmrc] to file:/home/jenkins/.npmrc 17:14:46 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 17:14:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10024053993126477377.sh 17:14:46 ---> python-tools-install.sh 17:14:46 Setup pyenv: 17:14:46 * system (set by /opt/pyenv/version) 17:14:46 * 3.8.13 (set by /opt/pyenv/version) 17:14:46 * 3.9.13 (set by /opt/pyenv/version) 17:14:46 * 3.10.13 (set by /opt/pyenv/version) 17:14:46 * 3.11.7 (set by /opt/pyenv/version) 17:14:50 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-4M4o 17:14:50 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 17:14:53 lf-activate-venv(): INFO: Installing: lftools 17:15:23 lf-activate-venv(): INFO: Adding /tmp/venv-4M4o/bin to PATH 17:15:23 Generating Requirements File 17:15:45 Python 3.11.7 17:15:45 pip 24.2 from /tmp/venv-4M4o/lib/python3.11/site-packages/pip (python 3.11) 17:15:45 appdirs==1.4.4 17:15:45 argcomplete==3.5.1 17:15:45 aspy.yaml==1.3.0 17:15:45 attrs==24.2.0 17:15:45 autopage==0.5.2 17:15:45 beautifulsoup4==4.12.3 17:15:45 boto3==1.35.34 17:15:45 botocore==1.35.34 17:15:45 bs4==0.0.2 17:15:45 cachetools==5.5.0 17:15:45 certifi==2024.8.30 17:15:45 cffi==1.17.1 17:15:45 cfgv==3.4.0 17:15:45 chardet==5.2.0 17:15:45 charset-normalizer==3.3.2 17:15:45 click==8.1.7 17:15:45 cliff==4.7.0 17:15:45 cmd2==2.4.3 17:15:45 cryptography==3.3.2 17:15:45 debtcollector==3.0.0 17:15:45 decorator==5.1.1 17:15:45 defusedxml==0.7.1 17:15:45 Deprecated==1.2.14 17:15:45 distlib==0.3.8 17:15:45 dnspython==2.7.0 17:15:45 docker==4.2.2 17:15:45 dogpile.cache==1.3.3 17:15:45 durationpy==0.9 17:15:45 email_validator==2.2.0 17:15:45 filelock==3.16.1 17:15:45 future==1.0.0 17:15:45 gitdb==4.0.11 17:15:45 GitPython==3.1.43 17:15:45 google-auth==2.35.0 17:15:45 httplib2==0.22.0 17:15:45 identify==2.6.1 17:15:45 idna==3.10 17:15:45 importlib-resources==1.5.0 17:15:45 iso8601==2.1.0 17:15:45 Jinja2==3.1.4 17:15:45 jmespath==1.0.1 17:15:45 jsonpatch==1.33 17:15:45 jsonpointer==3.0.0 17:15:45 jsonschema==4.23.0 17:15:45 jsonschema-specifications==2023.12.1 17:15:45 keystoneauth1==5.8.0 17:15:45 kubernetes==31.0.0 17:15:45 lftools==0.37.10 17:15:45 lxml==5.3.0 17:15:45 MarkupSafe==2.1.5 17:15:45 msgpack==1.1.0 17:15:45 multi_key_dict==2.0.3 17:15:45 munch==4.0.0 17:15:45 netaddr==1.3.0 17:15:45 netifaces==0.11.0 17:15:45 niet==1.4.2 17:15:45 nodeenv==1.9.1 17:15:45 oauth2client==4.1.3 17:15:45 oauthlib==3.2.2 17:15:45 openstacksdk==4.0.0 17:15:45 os-client-config==2.1.0 17:15:45 os-service-types==1.7.0 17:15:45 osc-lib==3.1.0 17:15:45 oslo.config==9.6.0 17:15:45 oslo.context==5.6.0 17:15:45 oslo.i18n==6.4.0 17:15:45 oslo.log==6.1.2 17:15:45 oslo.serialization==5.5.0 17:15:45 oslo.utils==7.3.0 17:15:45 packaging==24.1 17:15:45 pbr==6.1.0 17:15:45 platformdirs==4.3.6 17:15:45 prettytable==3.11.0 17:15:45 pyasn1==0.6.1 17:15:45 pyasn1_modules==0.4.1 17:15:45 pycparser==2.22 17:15:45 pygerrit2==2.0.15 17:15:45 PyGithub==2.4.0 17:15:45 PyJWT==2.9.0 17:15:45 PyNaCl==1.5.0 17:15:45 pyparsing==2.4.7 17:15:45 pyperclip==1.9.0 17:15:45 pyrsistent==0.20.0 17:15:45 python-cinderclient==9.6.0 17:15:45 python-dateutil==2.9.0.post0 17:15:45 python-heatclient==4.0.0 17:15:45 python-jenkins==1.8.2 17:15:45 python-keystoneclient==5.5.0 17:15:45 python-magnumclient==4.7.0 17:15:45 python-openstackclient==7.1.2 17:15:45 python-swiftclient==4.6.0 17:15:45 PyYAML==6.0.2 17:15:45 referencing==0.35.1 17:15:45 requests==2.32.3 17:15:45 requests-oauthlib==2.0.0 17:15:45 requestsexceptions==1.4.0 17:15:45 rfc3986==2.0.0 17:15:45 rpds-py==0.20.0 17:15:45 rsa==4.9 17:15:45 ruamel.yaml==0.18.6 17:15:45 ruamel.yaml.clib==0.2.8 17:15:45 s3transfer==0.10.2 17:15:45 simplejson==3.19.3 17:15:45 six==1.16.0 17:15:45 smmap==5.0.1 17:15:45 soupsieve==2.6 17:15:45 stevedore==5.3.0 17:15:45 tabulate==0.9.0 17:15:45 toml==0.10.2 17:15:45 tomlkit==0.13.2 17:15:45 tqdm==4.66.5 17:15:45 typing_extensions==4.12.2 17:15:45 tzdata==2024.2 17:15:45 urllib3==1.26.20 17:15:45 virtualenv==20.26.6 17:15:45 wcwidth==0.2.13 17:15:45 websocket-client==1.8.0 17:15:45 wrapt==1.16.0 17:15:45 xdg==6.0.0 17:15:45 xmltodict==0.13.0 17:15:45 yq==3.4.3 17:15:46 [EnvInject] - Injecting environment variables from a build step. 17:15:46 [EnvInject] - Injecting as environment variables the properties content 17:15:46 PYTHON=python3 17:15:46 17:15:46 [EnvInject] - Variables injected successfully. 17:15:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins10986271301798842567.sh 17:15:46 ---> tox-install.sh 17:15:46 + source /home/jenkins/lf-env.sh 17:15:46 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 17:15:46 ++ mktemp -d /tmp/venv-XXXX 17:15:46 + lf_venv=/tmp/venv-wzan 17:15:46 + local venv_file=/tmp/.os_lf_venv 17:15:46 + local python=python3 17:15:46 + local options 17:15:46 + local set_path=true 17:15:46 + local install_args= 17:15:46 ++ 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 17:15:46 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 17:15:46 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 17:15:46 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 17:15:46 + true 17:15:46 + case $1 in 17:15:46 + venv_file=/tmp/.toxenv 17:15:46 + shift 2 17:15:46 + true 17:15:46 + case $1 in 17:15:46 + shift 17:15:46 + break 17:15:46 + case $python in 17:15:46 + local pkg_list= 17:15:46 + [[ -d /opt/pyenv ]] 17:15:46 + echo 'Setup pyenv:' 17:15:46 Setup pyenv: 17:15:46 + export PYENV_ROOT=/opt/pyenv 17:15:46 + PYENV_ROOT=/opt/pyenv 17:15:46 + 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 17:15:46 + 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 17:15:46 + pyenv versions 17:15:46 system 17:15:46 3.8.13 17:15:46 3.9.13 17:15:46 3.10.13 17:15:46 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 17:15:46 + command -v pyenv 17:15:46 ++ pyenv init - --no-rehash 17:15:46 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 17:15:46 for i in ${!paths[@]}; do 17:15:46 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 17:15:46 fi; done; 17:15:46 echo "${paths[*]}"'\'')" 17:15:46 export PATH="/opt/pyenv/shims:${PATH}" 17:15:46 export PYENV_SHELL=bash 17:15:46 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 17:15:46 pyenv() { 17:15:46 local command 17:15:46 command="${1:-}" 17:15:46 if [ "$#" -gt 0 ]; then 17:15:46 shift 17:15:46 fi 17:15:46 17:15:46 case "$command" in 17:15:46 rehash|shell) 17:15:46 eval "$(pyenv "sh-$command" "$@")" 17:15:46 ;; 17:15:46 *) 17:15:46 command pyenv "$command" "$@" 17:15:46 ;; 17:15:46 esac 17:15:46 }' 17:15:46 +++ bash --norc -ec 'IFS=:; paths=($PATH); 17:15:46 for i in ${!paths[@]}; do 17:15:46 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 17:15:46 fi; done; 17:15:46 echo "${paths[*]}"' 17:15:46 ++ 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 17:15:46 ++ 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 17:15:46 ++ 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 17:15:46 ++ export PYENV_SHELL=bash 17:15:46 ++ PYENV_SHELL=bash 17:15:46 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 17:15:46 +++ complete -F _pyenv pyenv 17:15:46 ++ lf-pyver python3 17:15:46 ++ local py_version_xy=python3 17:15:46 ++ local py_version_xyz= 17:15:46 ++ pyenv versions 17:15:46 ++ local command 17:15:46 ++ command=versions 17:15:46 ++ '[' 1 -gt 0 ']' 17:15:46 ++ shift 17:15:46 ++ sed 's/^[ *]* //' 17:15:46 ++ case "$command" in 17:15:46 ++ command pyenv versions 17:15:46 ++ pyenv versions 17:15:46 ++ awk '{ print $1 }' 17:15:46 ++ grep -E '^[0-9.]*[0-9]$' 17:15:46 ++ [[ ! -s /tmp/.pyenv_versions ]] 17:15:46 +++ grep '^3' /tmp/.pyenv_versions 17:15:46 +++ sort -V 17:15:46 +++ tail -n 1 17:15:46 ++ py_version_xyz=3.11.7 17:15:46 ++ [[ -z 3.11.7 ]] 17:15:46 ++ echo 3.11.7 17:15:46 ++ return 0 17:15:46 + pyenv local 3.11.7 17:15:46 + local command 17:15:46 + command=local 17:15:46 + '[' 2 -gt 0 ']' 17:15:46 + shift 17:15:46 + case "$command" in 17:15:46 + command pyenv local 3.11.7 17:15:46 + pyenv local 3.11.7 17:15:46 + for arg in "$@" 17:15:46 + case $arg in 17:15:46 + pkg_list+='tox ' 17:15:46 + for arg in "$@" 17:15:46 + case $arg in 17:15:46 + pkg_list+='virtualenv ' 17:15:46 + for arg in "$@" 17:15:46 + case $arg in 17:15:46 + pkg_list+='urllib3~=1.26.15 ' 17:15:46 + [[ -f /tmp/.toxenv ]] 17:15:46 + [[ ! -f /tmp/.toxenv ]] 17:15:46 + [[ -n '' ]] 17:15:46 + python3 -m venv /tmp/venv-wzan 17:15:50 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-wzan' 17:15:50 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-wzan 17:15:50 + echo /tmp/venv-wzan 17:15:50 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 17:15:50 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 17:15:50 + /tmp/venv-wzan/bin/python3 -m pip install --upgrade --quiet pip virtualenv 17:15:56 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 17:15:56 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 17:15:56 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 17:15:56 + /tmp/venv-wzan/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 17:15:57 + type python3 17:15:57 + true 17:15:57 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-wzan/bin to PATH' 17:15:57 lf-activate-venv(): INFO: Adding /tmp/venv-wzan/bin to PATH 17:15:57 + PATH=/tmp/venv-wzan/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 17:15:57 + return 0 17:15:57 + python3 --version 17:15:57 Python 3.11.7 17:15:57 + python3 -m pip --version 17:15:58 pip 24.2 from /tmp/venv-wzan/lib/python3.11/site-packages/pip (python 3.11) 17:15:58 + python3 -m pip freeze 17:15:58 cachetools==5.5.0 17:15:58 chardet==5.2.0 17:15:58 colorama==0.4.6 17:15:58 distlib==0.3.8 17:15:58 filelock==3.16.1 17:15:58 packaging==24.1 17:15:58 platformdirs==4.3.6 17:15:58 pluggy==1.5.0 17:15:58 pyproject-api==1.8.0 17:15:58 tox==4.21.2 17:15:58 urllib3==1.26.20 17:15:58 virtualenv==20.26.6 17:15:58 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins2686375486584740019.sh 17:15:58 [EnvInject] - Injecting environment variables from a build step. 17:15:58 [EnvInject] - Injecting as environment variables the properties content 17:15:58 PARALLEL=True 17:15:58 17:15:58 [EnvInject] - Variables injected successfully. 17:15:58 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins11902770484962359412.sh 17:15:58 ---> tox-run.sh 17:15:58 + 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 17:15:58 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 17:15:58 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 17:15:58 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 17:15:58 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 17:15:58 + source /home/jenkins/lf-env.sh 17:15:58 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 17:15:58 ++ mktemp -d /tmp/venv-XXXX 17:15:58 + lf_venv=/tmp/venv-dU7l 17:15:58 + local venv_file=/tmp/.os_lf_venv 17:15:58 + local python=python3 17:15:58 + local options 17:15:58 + local set_path=true 17:15:58 + local install_args= 17:15:58 ++ 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 17:15:58 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 17:15:58 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 17:15:58 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 17:15:58 + true 17:15:58 + case $1 in 17:15:58 + venv_file=/tmp/.toxenv 17:15:58 + shift 2 17:15:58 + true 17:15:58 + case $1 in 17:15:58 + shift 17:15:58 + break 17:15:58 + case $python in 17:15:58 + local pkg_list= 17:15:58 + [[ -d /opt/pyenv ]] 17:15:58 + echo 'Setup pyenv:' 17:15:58 Setup pyenv: 17:15:58 + export PYENV_ROOT=/opt/pyenv 17:15:58 + PYENV_ROOT=/opt/pyenv 17:15:58 + 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 17:15:58 + 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 17:15:58 + pyenv versions 17:15:58 system 17:15:58 3.8.13 17:15:58 3.9.13 17:15:58 3.10.13 17:15:58 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 17:15:58 + command -v pyenv 17:15:58 ++ pyenv init - --no-rehash 17:15:58 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 17:15:58 for i in ${!paths[@]}; do 17:15:58 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 17:15:58 fi; done; 17:15:58 echo "${paths[*]}"'\'')" 17:15:58 export PATH="/opt/pyenv/shims:${PATH}" 17:15:58 export PYENV_SHELL=bash 17:15:58 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 17:15:58 pyenv() { 17:15:58 local command 17:15:58 command="${1:-}" 17:15:58 if [ "$#" -gt 0 ]; then 17:15:58 shift 17:15:58 fi 17:15:58 17:15:58 case "$command" in 17:15:58 rehash|shell) 17:15:58 eval "$(pyenv "sh-$command" "$@")" 17:15:58 ;; 17:15:58 *) 17:15:58 command pyenv "$command" "$@" 17:15:58 ;; 17:15:58 esac 17:15:58 }' 17:15:58 +++ bash --norc -ec 'IFS=:; paths=($PATH); 17:15:58 for i in ${!paths[@]}; do 17:15:58 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 17:15:58 fi; done; 17:15:58 echo "${paths[*]}"' 17:15:58 ++ 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 17:15:58 ++ 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 17:15:58 ++ 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 17:15:58 ++ export PYENV_SHELL=bash 17:15:58 ++ PYENV_SHELL=bash 17:15:58 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 17:15:58 +++ complete -F _pyenv pyenv 17:15:58 ++ lf-pyver python3 17:15:58 ++ local py_version_xy=python3 17:15:58 ++ local py_version_xyz= 17:15:58 ++ pyenv versions 17:15:58 ++ local command 17:15:58 ++ command=versions 17:15:58 ++ '[' 1 -gt 0 ']' 17:15:58 ++ shift 17:15:58 ++ case "$command" in 17:15:58 ++ command pyenv versions 17:15:58 ++ pyenv versions 17:15:58 ++ awk '{ print $1 }' 17:15:58 ++ sed 's/^[ *]* //' 17:15:58 ++ grep -E '^[0-9.]*[0-9]$' 17:15:58 ++ [[ ! -s /tmp/.pyenv_versions ]] 17:15:58 +++ grep '^3' /tmp/.pyenv_versions 17:15:58 +++ sort -V 17:15:58 +++ tail -n 1 17:15:58 ++ py_version_xyz=3.11.7 17:15:58 ++ [[ -z 3.11.7 ]] 17:15:58 ++ echo 3.11.7 17:15:58 ++ return 0 17:15:58 + pyenv local 3.11.7 17:15:58 + local command 17:15:58 + command=local 17:15:58 + '[' 2 -gt 0 ']' 17:15:58 + shift 17:15:58 + case "$command" in 17:15:58 + command pyenv local 3.11.7 17:15:58 + pyenv local 3.11.7 17:15:58 + for arg in "$@" 17:15:58 + case $arg in 17:15:58 + pkg_list+='tox ' 17:15:58 + for arg in "$@" 17:15:58 + case $arg in 17:15:58 + pkg_list+='virtualenv ' 17:15:58 + for arg in "$@" 17:15:58 + case $arg in 17:15:58 + pkg_list+='urllib3~=1.26.15 ' 17:15:58 + [[ -f /tmp/.toxenv ]] 17:15:58 ++ cat /tmp/.toxenv 17:15:58 + lf_venv=/tmp/venv-wzan 17:15:58 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wzan from' file:/tmp/.toxenv 17:15:58 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wzan from file:/tmp/.toxenv 17:15:58 + /tmp/venv-wzan/bin/python3 -m pip install --upgrade --quiet pip virtualenv 17:15:59 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 17:15:59 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 17:15:59 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 17:15:59 + /tmp/venv-wzan/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 17:16:00 + type python3 17:16:00 + true 17:16:00 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-wzan/bin to PATH' 17:16:00 lf-activate-venv(): INFO: Adding /tmp/venv-wzan/bin to PATH 17:16:00 + PATH=/tmp/venv-wzan/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 17:16:00 + return 0 17:16:00 + [[ -d /opt/pyenv ]] 17:16:00 + echo '---> Setting up pyenv' 17:16:00 ---> Setting up pyenv 17:16:00 + export PYENV_ROOT=/opt/pyenv 17:16:00 + PYENV_ROOT=/opt/pyenv 17:16:00 + export PATH=/opt/pyenv/bin:/tmp/venv-wzan/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 17:16:00 + PATH=/opt/pyenv/bin:/tmp/venv-wzan/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 17:16:00 ++ pwd 17:16:00 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 17:16:00 + export PYTHONPATH 17:16:00 + export TOX_TESTENV_PASSENV=PYTHONPATH 17:16:00 + TOX_TESTENV_PASSENV=PYTHONPATH 17:16:00 + tox --version 17:16:00 4.21.2 from /tmp/venv-wzan/lib/python3.11/site-packages/tox/__init__.py 17:16:00 + PARALLEL=True 17:16:00 + TOX_OPTIONS_LIST= 17:16:00 + [[ -n '' ]] 17:16:00 + case ${PARALLEL,,} in 17:16:00 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 17:16:00 + tox --parallel auto --parallel-live 17:16:00 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 17:16:02 checkbashisms: freeze> python -m pip freeze --all 17:16:02 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 17:16:02 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 17:16:02 docs: install_deps> python -I -m pip install -r docs/requirements.txt 17:16:03 checkbashisms: pip==24.2,setuptools==75.1.0,wheel==0.44.0 17:16:03 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 17:16:03 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)' 17:16:03 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 17:16:04 script ./reflectwarn.sh does not appear to have a #! interpreter line; 17:16:04 you may get strange results 17:16:04 checkbashisms: OK ✔ in 3.07 seconds 17:16:04 pre-commit: install_deps> python -I -m pip install pre-commit 17:16:07 pre-commit: freeze> python -m pip freeze --all 17:16:07 pre-commit: cfgv==3.4.0,distlib==0.3.8,filelock==3.16.1,identify==2.6.1,nodeenv==1.9.1,pip==24.2,platformdirs==4.3.6,pre_commit==4.0.0,PyYAML==6.0.2,setuptools==75.1.0,virtualenv==20.26.6,wheel==0.44.0 17:16:07 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 17:16:07 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)' 17:16:07 /usr/bin/cpan 17:16:07 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 17:16:07 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 17:16:07 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 17:16:07 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 17:16:08 [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. 17:16:08 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 17:16:08 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 17:16:09 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 17:16:09 buildcontroller: freeze> python -m pip freeze --all 17:16:09 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 17:16:09 buildcontroller: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:16:09 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 17:16:09 + update-java-alternatives -l 17:16:09 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 17:16:09 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 17:16:09 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 17:16:09 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 17:16:09 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 17:16:09 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 17:16:09 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 17:16:09 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 17:16:09 + java -version 17:16:10 + JAVA_VER=21 17:16:10 + echo 21 17:16:10 21 17:16:10 + javac -version 17:16:10 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 17:16:10 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 17:16:10 [INFO] Once installed this environment will be reused. 17:16:10 [INFO] This may take a few minutes... 17:16:10 + JAVAC_VER=21 17:16:10 + echo 21 17:16:10 21 17:16:10 ok, java is 21 or newer 17:16:10 + [ 21 -ge 21 ] 17:16:10 + [ 21 -ge 21 ] 17:16:10 + echo ok, java is 21 or newer 17:16:10 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp 17:16:11 2024-10-07 17:16:11 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] 17:16:11 + sudo mkdir -p /opt 17:16:11 + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt 17:16:11 + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven 17:16:11 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 17:16:11 + mvn --version 17:16:12 Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) 17:16:12 Maven home: /opt/maven 17:16:12 Java version: 21.0.4, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 17:16:12 Default locale: en, platform encoding: UTF-8 17:16:12 OS name: "linux", version: "5.4.0-190-generic", arch: "amd64", family: "unix" 17:16:12 NOTE: Picked up JDK_JAVA_OPTIONS: 17:16:12 --add-opens=java.base/java.io=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.lang=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.net=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.nio=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.nio.file=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.util=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.util.jar=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.util.stream=ALL-UNNAMED 17:16:12 --add-opens=java.base/java.util.zip=ALL-UNNAMED 17:16:12 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 17:16:12 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 17:16:12 -Xlog:disable 17:16:14 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 17:16:14 [INFO] Once installed this environment will be reused. 17:16:14 [INFO] This may take a few minutes... 17:16:19 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 17:16:19 [INFO] Once installed this environment will be reused. 17:16:19 [INFO] This may take a few minutes... 17:16:22 [INFO] Installing environment for https://github.com/perltidy/perltidy. 17:16:22 [INFO] Once installed this environment will be reused. 17:16:22 [INFO] This may take a few minutes... 17:16:30 docs: freeze> python -m pip freeze --all 17:16:30 docs: alabaster==1.0.0,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.3.2,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==2.1.5,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==10.4.0,pip==24.2,Pygments==2.18.0,pyparsing==3.1.4,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.1.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.0.2,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.0,sphinx-tabs==3.4.5,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 17:16:30 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 17:16:32 docs-linkcheck: freeze> python -m pip freeze --all 17:16:32 /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs/lib/python3.11/site-packages/sphinx_tabs/tabs.py:335: RemovedInSphinx90Warning: The str interface for _JavaScript objects is deprecated. Use js.filename instead. 17:16:32 if path.suffix == ".js" and path.as_posix() in context["script_files"]: 17:16:32 /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs/lib/python3.11/site-packages/sphinx_tabs/tabs.py:336: RemovedInSphinx90Warning: The str interface for _JavaScript objects is deprecated. Use js.filename instead. 17:16:32 context["script_files"].remove(path.as_posix()) 17:16:33 docs: OK ✔ in 31.91 seconds 17:16:33 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.3.2,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==2.1.5,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==10.4.0,pip==24.2,Pygments==2.18.0,pyparsing==3.1.4,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.1.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.0.2,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.0,sphinx-tabs==3.4.5,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 17:16:33 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 17:16:33 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 17:16:35 trim trailing whitespace.................................................Passed 17:16:35 Tabs remover.............................................................Passed 17:16:35 autopep8.................................................................docs-linkcheck: OK ✔ in 35.58 seconds 17:16:37 pylint: freeze> python -m pip freeze --all 17:16:37 pylint: astroid==3.3.5,dill==0.3.9,isort==5.13.2,mccabe==0.7.0,pip==24.2,platformdirs==4.3.6,pylint==3.3.1,setuptools==75.1.0,tomlkit==0.13.2,wheel==0.44.0 17:16:37 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}$' '{}' + 17:16:40 Passed 17:16:40 perltidy.................................................................Passed 17:16:41 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 17:16:41 [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. 17:16:41 [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. 17:16:41 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 17:16:41 [INFO] Once installed this environment will be reused. 17:16:41 [INFO] This may take a few minutes... 17:16:48 gitlint..................................................................Passed 17:16:57 17:16:57 ------------------------------------ 17:16:57 Your code has been rated at 10.00/10 17:16:57 17:17:46 pre-commit: OK ✔ in 43.98 seconds 17:17:46 pylint: OK ✔ in 25.82 seconds 17:17:46 buildcontroller: OK ✔ in 1 minute 44.56 seconds 17:17:46 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 17:17:46 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 17:17:46 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 17:17:46 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 17:17:52 build_karaf_tests221: freeze> python -m pip freeze --all 17:17:52 sims: freeze> python -m pip freeze --all 17:17:52 build_karaf_tests121: freeze> python -m pip freeze --all 17:17:53 build_karaf_tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:17:53 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 17:17:53 sims: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:17:53 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 17:17:53 NOTE: Picked up JDK_JAVA_OPTIONS: 17:17:53 --add-opens=java.base/java.io=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.net=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio.file=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.jar=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.stream=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.zip=ALL-UNNAMED 17:17:53 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 17:17:53 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 17:17:53 -Xlog:disable 17:17:53 Using lighynode version 20.1.0.2 17:17:53 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 17:17:53 build_karaf_tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:17:53 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 17:17:53 NOTE: Picked up JDK_JAVA_OPTIONS: 17:17:53 --add-opens=java.base/java.io=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.net=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.nio.file=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.jar=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.stream=ALL-UNNAMED 17:17:53 --add-opens=java.base/java.util.zip=ALL-UNNAMED 17:17:53 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 17:17:53 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 17:17:53 -Xlog:disable 17:17:57 sims: OK ✔ in 11.33 seconds 17:17:57 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 17:18:10 build_karaf_tests71: freeze> python -m pip freeze --all 17:18:10 build_karaf_tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:18:10 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 17:18:11 NOTE: Picked up JDK_JAVA_OPTIONS: 17:18:11 --add-opens=java.base/java.io=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.lang=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.net=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.nio=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.nio.file=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.util=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.util.jar=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.util.stream=ALL-UNNAMED 17:18:11 --add-opens=java.base/java.util.zip=ALL-UNNAMED 17:18:11 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 17:18:11 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 17:18:11 -Xlog:disable 17:18:41 build_karaf_tests121: OK ✔ in 55.04 seconds 17:18:41 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 17:18:42 build_karaf_tests221: OK ✔ in 56.28 seconds 17:18:42 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 17:18:51 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 17:18:51 tests_tapi: freeze> python -m pip freeze --all 17:18:52 build_karaf_tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:18:52 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 17:18:52 testsPCE: freeze> python -m pip freeze --all 17:18:52 tests_tapi: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:18:52 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 17:18:52 using environment variables from ./karaf221.env 17:18:52 NOTE: Picked up JDK_JAVA_OPTIONS: 17:18:52 --add-opens=java.base/java.io=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.lang=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.net=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.nio=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.nio.file=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.util=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.util.jar=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.util.stream=ALL-UNNAMED 17:18:52 --add-opens=java.base/java.util.zip=ALL-UNNAMED 17:18:52 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 17:18:52 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 17:18:52 -Xlog:disable 17:18:52 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 17:18:52 testsPCE: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,click==8.1.7,contourpy==1.3.0,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.6,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.54.1,gnpy4tpce==2.4.7,idna==3.10,iniconfig==2.0.0,injector==0.22.0,itsdangerous==2.2.0,Jinja2==3.1.4,kiwisolver==1.4.7,lxml==5.3.0,MarkupSafe==2.1.5,matplotlib==3.9.2,netconf-client==3.1.1,networkx==2.8.8,numpy==1.26.4,packaging==24.1,pandas==1.5.3,paramiko==3.5.0,pbr==5.11.1,pillow==10.4.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pyparsing==3.1.4,pytest==8.3.3,python-dateutil==2.9.0.post0,pytz==2024.2,requests==2.32.3,scipy==1.14.1,setuptools==50.3.2,six==1.16.0,urllib3==2.2.3,Werkzeug==2.0.3,wheel==0.44.0,xlrd==1.2.0 17:18:52 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 17:18:52 pytest -q transportpce_tests/pce/test01_pce.py 17:19:57 .............................. [100%] 17:21:01 20 passed in 128.69s (0:02:08) 17:21:01 pytest -q transportpce_tests/pce/test02_pce_400G.py 17:21:03 ............................... [100%] 17:21:44 9 passed in 42.59s 17:21:44 pytest -q transportpce_tests/pce/test03_gnpy.py 17:22:02 ............. [100%] 17:22:23 8 passed in 38.76s 17:22:23 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 17:22:27 ............ [100%] 17:23:00 3 passed in 36.63s 17:23:00 build_karaf_tests71: OK ✔ in 57.12 seconds 17:23:00 build_karaf_tests_hybrid: OK ✔ in 1 minute 0.04 seconds 17:23:00 testsPCE: OK ✔ in 5 minutes 15 seconds 17:23:00 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 17:23:06 tests121: freeze> python -m pip freeze --all 17:23:06 tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:23:06 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 17:23:06 using environment variables from ./karaf121.env 17:23:06 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 17:25:47 .... [100%] 17:25:52 50 passed in 419.62s (0:06:59) 17:25:52 pytest -q transportpce_tests/tapi/test02_full_topology.py 17:26:37 .FFFFF...........F.FFFFFFFFFFF...... [100%] 17:29:20 =================================== FAILURES =================================== 17:29:20 _____________ TransportPCEtesting.test_12_check_openroadm_topology _____________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_12_check_openroadm_topology(self): 17:29:20 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 17:29:20 self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 > self.assertEqual(len(response['network'][0]['node']), 13, 'There should be 13 openroadm nodes') 17:29:20 E AssertionError: 14 != 13 : There should be 13 openroadm nodes 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:272: AssertionError 17:29:20 ________________ TransportPCEtesting.test_14_check_sip_details _________________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_14_check_sip_details(self): 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-common', 'get-service-interface-point-list', None) 17:29:20 > self.assertEqual(len(response['output']['sip']), 72, 'There should be 72 service interface point') 17:29:20 E AssertionError: 22 != 72 : There should be 72 service interface point 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:291: AssertionError 17:29:20 ____ TransportPCEtesting.test_15_create_connectivity_service_PhotonicMedia _____ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_15_create_connectivity_service_PhotonicMedia(self): 17:29:20 self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sAOTS 17:29:20 self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZOTS 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) 17:29:20 time.sleep(self.WAITING) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 500 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:300: AssertionError 17:29:20 ____________ TransportPCEtesting.test_16_get_service_PhotonicMedia _____________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_16_get_service_PhotonicMedia(self): 17:29:20 response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.pm)) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 409 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:330: AssertionError 17:29:20 _________ TransportPCEtesting.test_17_create_connectivity_service_ODU __________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_17_create_connectivity_service_ODU(self): 17:29:20 # pylint: disable=line-too-long 17:29:20 self.cr_serv_input_data["layer-protocol-name"] = "ODU" 17:29:20 self.cr_serv_input_data["end-point"][0]["layer-protocol-name"] = "ODU" 17:29:20 self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sAeODU 17:29:20 self.cr_serv_input_data["end-point"][1]["layer-protocol-name"] = "ODU" 17:29:20 self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZeODU 17:29:20 # self.cr_serv_input_data["connectivity-constraint"]["service-layer"] = "ODU" 17:29:20 self.cr_serv_input_data["connectivity-constraint"]["service-level"] = self.uuid_services.pm 17:29:20 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) 17:29:20 time.sleep(self.WAITING) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 500 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:351: AssertionError 17:29:20 _________________ TransportPCEtesting.test_18_get_service_ODU __________________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_18_get_service_ODU(self): 17:29:20 response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.odu)) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 409 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:379: AssertionError 17:29:20 _________ TransportPCEtesting.test_19_create_connectivity_service_DSR __________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_19_create_connectivity_service_DSR(self): 17:29:20 # pylint: disable=line-too-long 17:29:20 self.cr_serv_input_data["layer-protocol-name"] = "DSR" 17:29:20 self.cr_serv_input_data["end-point"][0]["layer-protocol-name"] = "DSR" 17:29:20 self.cr_serv_input_data["end-point"][0]["service-interface-point"]["service-interface-point-uuid"] = self.sADSR 17:29:20 self.cr_serv_input_data["end-point"][1]["layer-protocol-name"] = "DSR" 17:29:20 self.cr_serv_input_data["end-point"][1]["service-interface-point"]["service-interface-point-uuid"] = self.sZDSR 17:29:20 # self.cr_serv_input_data["connectivity-constraint"]["service-layer"] = "DSR" 17:29:20 self.cr_serv_input_data["connectivity-constraint"]["requested-capacity"]["total-size"]["value"] = "10" 17:29:20 self.cr_serv_input_data["connectivity-constraint"]["service-level"] = self.uuid_services.odu 17:29:20 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'create-connectivity-service', self.cr_serv_input_data) 17:29:20 time.sleep(self.WAITING) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 500 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:401: AssertionError 17:29:20 _________________ TransportPCEtesting.test_20_get_service_DSR __________________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_20_get_service_DSR(self): 17:29:20 response = test_utils.get_ordm_serv_list_attr_request("services", str(self.uuid_services.dsr)) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 409 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:432: AssertionError 17:29:20 __________ TransportPCEtesting.test_21_get_connectivity_service_list ___________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_21_get_connectivity_service_list(self): 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'get-connectivity-service-list', None) 17:29:20 > self.assertEqual(response['status_code'], requests.codes.ok) 17:29:20 E AssertionError: 500 != 200 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:442: AssertionError 17:29:20 _________ TransportPCEtesting.test_22_delete_connectivity_service_DSR __________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_22_delete_connectivity_service_DSR(self): 17:29:20 self.del_serv_input_data["uuid"] = str(self.uuid_services.dsr) 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) 17:29:20 > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) 17:29:20 E AssertionError: 500 not found in (200, 204) 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:471: AssertionError 17:29:20 _________ TransportPCEtesting.test_23_delete_connectivity_service_ODU __________ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_23_delete_connectivity_service_ODU(self): 17:29:20 self.del_serv_input_data["uuid"] = str(self.uuid_services.odu) 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) 17:29:20 > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) 17:29:20 E AssertionError: 500 not found in (200, 204) 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:478: AssertionError 17:29:20 ____ TransportPCEtesting.test_24_delete_connectivity_service_PhotonicMedia _____ 17:29:20 17:29:20 self = 17:29:20 17:29:20 def test_24_delete_connectivity_service_PhotonicMedia(self): 17:29:20 self.del_serv_input_data["uuid"] = str(self.uuid_services.pm) 17:29:20 response = test_utils.transportpce_api_rpc_request( 17:29:20 'tapi-connectivity', 'delete-connectivity-service', self.del_serv_input_data) 17:29:20 > self.assertIn(response["status_code"], (requests.codes.ok, requests.codes.no_content)) 17:29:20 E AssertionError: 500 not found in (200, 204) 17:29:20 17:29:20 transportpce_tests/tapi/test02_full_topology.py:485: AssertionError 17:29:20 =========================== short test summary info ============================ 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_12_check_openroadm_topology 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_14_check_sip_details 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_15_create_connectivity_service_PhotonicMedia 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_16_get_service_PhotonicMedia 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_17_create_connectivity_service_ODU 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_18_get_service_ODU 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_19_create_connectivity_service_DSR 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_20_get_service_DSR 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_21_get_connectivity_service_list 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_22_delete_connectivity_service_DSR 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_23_delete_connectivity_service_ODU 17:29:20 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_24_delete_connectivity_service_PhotonicMedia 17:29:20 12 failed, 18 passed in 207.85s (0:03:27) 17:29:20 tests_tapi: exit 1 (627.99 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=30642 17:29:20 tests_tapi: FAIL ✖ in 10 minutes 38.43 seconds 17:29:20 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 17:29:26 tests71: freeze> python -m pip freeze --all 17:29:26 tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:29:26 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 17:29:26 using environment variables from ./karaf71.env 17:29:26 pytest -q transportpce_tests/7.1/test01_portmapping.py 17:29:44 .FFFFFFFF............ [100%] 17:30:10 12 passed in 44.06s 17:30:10 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 17:30:36 .............................................................. [100%] 17:32:46 62 passed in 155.17s (0:02:35) 17:32:46 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 17:32:56 FFF................................................ [100%] 17:35:01 48 passed in 134.75s (0:02:14) 17:35:01 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 17:35:26 ................F.... [100%] 17:36:05 =================================== FAILURES =================================== 17:36:05 _________ TransportPCEPortMappingTesting.test_02_rdm_device_connected __________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_02_rdm_device_connected(self): 17:36:05 response = test_utils.check_device_connection("ROADMA01") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:54: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_02_rdm_device_connected 17:36:05 _________ TransportPCEPortMappingTesting.test_03_rdm_portmapping_info __________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_03_rdm_portmapping_info(self): 17:36:05 response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:60: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_03_rdm_portmapping_info 17:36:05 _____ TransportPCEPortMappingTesting.test_04_rdm_portmapping_DEG1_TTP_TXRX _____ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_04_rdm_portmapping_DEG1_TTP_TXRX(self): 17:36:05 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "DEG1-TTP-TXRX") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:73: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_04_rdm_portmapping_DEG1_TTP_TXRX 17:36:05 _____ TransportPCEPortMappingTesting.test_05_rdm_portmapping_SRG1_PP7_TXRX _____ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_05_rdm_portmapping_SRG1_PP7_TXRX(self): 17:36:05 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG1-PP7-TXRX") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:82: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_05_rdm_portmapping_SRG1_PP7_TXRX 17:36:05 _____ TransportPCEPortMappingTesting.test_06_rdm_portmapping_SRG3_PP1_TXRX _____ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_06_rdm_portmapping_SRG3_PP1_TXRX(self): 17:36:05 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG3-PP1-TXRX") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:91: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_06_rdm_portmapping_SRG3_PP1_TXRX 17:36:05 _________ TransportPCEPortMappingTesting.test_08_xpdr_device_connected _________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 > sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 17:36:05 raise err 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 address = ('localhost', 8182), timeout = 10, source_address = None 17:36:05 socket_options = [(6, 1, 1)] 17:36:05 17:36:05 def create_connection( 17:36:05 address: tuple[str, int], 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 source_address: tuple[str, int] | None = None, 17:36:05 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 17:36:05 ) -> socket.socket: 17:36:05 """Connect to *address* and return the socket object. 17:36:05 17:36:05 Convenience function. Connect to *address* (a 2-tuple ``(host, 17:36:05 port)``) and return the socket object. Passing the optional 17:36:05 *timeout* parameter will set the timeout on the socket instance 17:36:05 before attempting to connect. If no *timeout* is supplied, the 17:36:05 global default timeout setting returned by :func:`socket.getdefaulttimeout` 17:36:05 is used. If *source_address* is set it must be a tuple of (host, port) 17:36:05 for the socket to bind as a source address before making the connection. 17:36:05 An host of '' or port 0 tells the OS to use the default. 17:36:05 """ 17:36:05 17:36:05 host, port = address 17:36:05 if host.startswith("["): 17:36:05 host = host.strip("[]") 17:36:05 err = None 17:36:05 17:36:05 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 17:36:05 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 17:36:05 # The original create_connection function always returns all records. 17:36:05 family = allowed_gai_family() 17:36:05 17:36:05 try: 17:36:05 host.encode("idna") 17:36:05 except UnicodeError: 17:36:05 raise LocationParseError(f"'{host}', label empty or too long") from None 17:36:05 17:36:05 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 17:36:05 af, socktype, proto, canonname, sa = res 17:36:05 sock = None 17:36:05 try: 17:36:05 sock = socket.socket(af, socktype, proto) 17:36:05 17:36:05 # If provided, set socket level options before connecting. 17:36:05 _set_socket_options(sock, socket_options) 17:36:05 17:36:05 if timeout is not _DEFAULT_TIMEOUT: 17:36:05 sock.settimeout(timeout) 17:36:05 if source_address: 17:36:05 sock.bind(source_address) 17:36:05 > sock.connect(sa) 17:36:05 E ConnectionRefusedError: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 17:36:05 body = None 17:36:05 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='} 17:36:05 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 redirect = False, assert_same_host = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 17:36:05 release_conn = False, chunked = False, body_pos = None, preload_content = False 17:36:05 decode_content = False, response_kw = {} 17:36:05 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01', query='content=nonconfig', fragment=None) 17:36:05 destination_scheme = None, conn = None, release_this_conn = True 17:36:05 http_tunnel_required = False, err = None, clean_exit = False 17:36:05 17:36:05 def urlopen( # type: ignore[override] 17:36:05 self, 17:36:05 method: str, 17:36:05 url: str, 17:36:05 body: _TYPE_BODY | None = None, 17:36:05 headers: typing.Mapping[str, str] | None = None, 17:36:05 retries: Retry | bool | int | None = None, 17:36:05 redirect: bool = True, 17:36:05 assert_same_host: bool = True, 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 pool_timeout: int | None = None, 17:36:05 release_conn: bool | None = None, 17:36:05 chunked: bool = False, 17:36:05 body_pos: _TYPE_BODY_POSITION | None = None, 17:36:05 preload_content: bool = True, 17:36:05 decode_content: bool = True, 17:36:05 **response_kw: typing.Any, 17:36:05 ) -> BaseHTTPResponse: 17:36:05 """ 17:36:05 Get a connection from the pool and perform an HTTP request. This is the 17:36:05 lowest level call for making a request, so you'll need to specify all 17:36:05 the raw details. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 More commonly, it's appropriate to use a convenience method 17:36:05 such as :meth:`request`. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 `release_conn` will only behave as expected if 17:36:05 `preload_content=False` because we want to make 17:36:05 `preload_content=False` the default behaviour someday soon without 17:36:05 breaking backwards compatibility. 17:36:05 17:36:05 :param method: 17:36:05 HTTP request method (such as GET, POST, PUT, etc.) 17:36:05 17:36:05 :param url: 17:36:05 The URL to perform the request on. 17:36:05 17:36:05 :param body: 17:36:05 Data to send in the request body, either :class:`str`, :class:`bytes`, 17:36:05 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 17:36:05 17:36:05 :param headers: 17:36:05 Dictionary of custom headers to send, such as User-Agent, 17:36:05 If-None-Match, etc. If None, pool headers are used. If provided, 17:36:05 these headers completely replace any pool-specific headers. 17:36:05 17:36:05 :param retries: 17:36:05 Configure the number of retries to allow before raising a 17:36:05 :class:`~urllib3.exceptions.MaxRetryError` exception. 17:36:05 17:36:05 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 17:36:05 :class:`~urllib3.util.retry.Retry` object for fine-grained control 17:36:05 over different types of retries. 17:36:05 Pass an integer number to retry connection errors that many times, 17:36:05 but no other types of errors. Pass zero to never retry. 17:36:05 17:36:05 If ``False``, then retries are disabled and any exception is raised 17:36:05 immediately. Also, instead of raising a MaxRetryError on redirects, 17:36:05 the redirect response will be returned. 17:36:05 17:36:05 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 17:36:05 17:36:05 :param redirect: 17:36:05 If True, automatically handle redirects (status codes 301, 302, 17:36:05 303, 307, 308). Each redirect counts as a retry. Disabling retries 17:36:05 will disable redirect, too. 17:36:05 17:36:05 :param assert_same_host: 17:36:05 If ``True``, will make sure that the host of the pool requests is 17:36:05 consistent else will raise HostChangedError. When ``False``, you can 17:36:05 use the pool on an HTTP proxy and request foreign hosts. 17:36:05 17:36:05 :param timeout: 17:36:05 If specified, overrides the default timeout for this one 17:36:05 request. It may be a float (in seconds) or an instance of 17:36:05 :class:`urllib3.util.Timeout`. 17:36:05 17:36:05 :param pool_timeout: 17:36:05 If set and the pool is set to block=True, then this method will 17:36:05 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 17:36:05 connection is available within the time period. 17:36:05 17:36:05 :param bool preload_content: 17:36:05 If True, the response's body will be preloaded into memory. 17:36:05 17:36:05 :param bool decode_content: 17:36:05 If True, will attempt to decode the body based on the 17:36:05 'content-encoding' header. 17:36:05 17:36:05 :param release_conn: 17:36:05 If False, then the urlopen call will not release the connection 17:36:05 back into the pool once a response is received (but will release if 17:36:05 you read the entire contents of the response such as when 17:36:05 `preload_content=True`). This is useful if you're not preloading 17:36:05 the response's content immediately. You will need to call 17:36:05 ``r.release_conn()`` on the response ``r`` to return the connection 17:36:05 back into the pool. If None, it takes the value of ``preload_content`` 17:36:05 which defaults to ``True``. 17:36:05 17:36:05 :param bool chunked: 17:36:05 If True, urllib3 will send the body using chunked transfer 17:36:05 encoding. Otherwise, urllib3 will send the body using the standard 17:36:05 content-length form. Defaults to False. 17:36:05 17:36:05 :param int body_pos: 17:36:05 Position to seek to in file-like body in the event of a retry or 17:36:05 redirect. Typically this won't need to be set because urllib3 will 17:36:05 auto-populate the value when needed. 17:36:05 """ 17:36:05 parsed_url = parse_url(url) 17:36:05 destination_scheme = parsed_url.scheme 17:36:05 17:36:05 if headers is None: 17:36:05 headers = self.headers 17:36:05 17:36:05 if not isinstance(retries, Retry): 17:36:05 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 17:36:05 17:36:05 if release_conn is None: 17:36:05 release_conn = preload_content 17:36:05 17:36:05 # Check host 17:36:05 if assert_same_host and not self.is_same_host(url): 17:36:05 raise HostChangedError(self, url, retries) 17:36:05 17:36:05 # Ensure that the URL we're connecting to is properly encoded 17:36:05 if url.startswith("/"): 17:36:05 url = to_str(_encode_target(url)) 17:36:05 else: 17:36:05 url = to_str(parsed_url.url) 17:36:05 17:36:05 conn = None 17:36:05 17:36:05 # Track whether `conn` needs to be released before 17:36:05 # returning/raising/recursing. Update this variable if necessary, and 17:36:05 # leave `release_conn` constant throughout the function. That way, if 17:36:05 # the function recurses, the original value of `release_conn` will be 17:36:05 # passed down into the recursive call, and its value will be respected. 17:36:05 # 17:36:05 # See issue #651 [1] for details. 17:36:05 # 17:36:05 # [1] 17:36:05 release_this_conn = release_conn 17:36:05 17:36:05 http_tunnel_required = connection_requires_http_tunnel( 17:36:05 self.proxy, self.proxy_config, destination_scheme 17:36:05 ) 17:36:05 17:36:05 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 17:36:05 # have to copy the headers dict so we can safely change it without those 17:36:05 # changes being reflected in anyone else's copy. 17:36:05 if not http_tunnel_required: 17:36:05 headers = headers.copy() # type: ignore[attr-defined] 17:36:05 headers.update(self.proxy_headers) # type: ignore[union-attr] 17:36:05 17:36:05 # Must keep the exception bound to a separate variable or else Python 3 17:36:05 # complains about UnboundLocalError. 17:36:05 err = None 17:36:05 17:36:05 # Keep track of whether we cleanly exited the except block. This 17:36:05 # ensures we do proper cleanup in finally. 17:36:05 clean_exit = False 17:36:05 17:36:05 # Rewind body position, if needed. Record current position 17:36:05 # for future rewinds in the event of a redirect/retry. 17:36:05 body_pos = set_file_position(body, body_pos) 17:36:05 17:36:05 try: 17:36:05 # Request a connection from the queue. 17:36:05 timeout_obj = self._get_timeout(timeout) 17:36:05 conn = self._get_conn(timeout=pool_timeout) 17:36:05 17:36:05 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 17:36:05 17:36:05 # Is this a closed/new connection that requires CONNECT tunnelling? 17:36:05 if self.proxy is not None and http_tunnel_required and conn.is_closed: 17:36:05 try: 17:36:05 self._prepare_proxy(conn) 17:36:05 except (BaseSSLError, OSError, SocketTimeout) as e: 17:36:05 self._raise_timeout( 17:36:05 err=e, url=self.proxy.url, timeout_value=conn.timeout 17:36:05 ) 17:36:05 raise 17:36:05 17:36:05 # If we're going to release the connection in ``finally:``, then 17:36:05 # the response doesn't need to know about the connection. Otherwise 17:36:05 # it will also try to release it and we'll have a double-release 17:36:05 # mess. 17:36:05 response_conn = conn if not release_conn else None 17:36:05 17:36:05 # Make the request on the HTTPConnection object 17:36:05 > response = self._make_request( 17:36:05 conn, 17:36:05 method, 17:36:05 url, 17:36:05 timeout=timeout_obj, 17:36:05 body=body, 17:36:05 headers=headers, 17:36:05 chunked=chunked, 17:36:05 retries=retries, 17:36:05 response_conn=response_conn, 17:36:05 preload_content=preload_content, 17:36:05 decode_content=decode_content, 17:36:05 **response_kw, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 17:36:05 conn.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 17:36:05 self.endheaders() 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 17:36:05 self._send_output(message_body, encode_chunked=encode_chunked) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 17:36:05 self.send(msg) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 17:36:05 self.connect() 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 17:36:05 self.sock = self._new_conn() 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 except socket.gaierror as e: 17:36:05 raise NameResolutionError(self.host, self, e) from e 17:36:05 except SocketTimeout as e: 17:36:05 raise ConnectTimeoutError( 17:36:05 self, 17:36:05 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 17:36:05 ) from e 17:36:05 17:36:05 except OSError as e: 17:36:05 > raise NewConnectionError( 17:36:05 self, f"Failed to establish a new connection: {e}" 17:36:05 ) from e 17:36:05 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 > resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 17:36:05 retries = retries.increment( 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 17:36:05 response = None 17:36:05 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 17:36:05 _pool = 17:36:05 _stacktrace = 17:36:05 17:36:05 def increment( 17:36:05 self, 17:36:05 method: str | None = None, 17:36:05 url: str | None = None, 17:36:05 response: BaseHTTPResponse | None = None, 17:36:05 error: Exception | None = None, 17:36:05 _pool: ConnectionPool | None = None, 17:36:05 _stacktrace: TracebackType | None = None, 17:36:05 ) -> Self: 17:36:05 """Return a new Retry object with incremented retry counters. 17:36:05 17:36:05 :param response: A response object, or None, if the server did not 17:36:05 return a response. 17:36:05 :type response: :class:`~urllib3.response.BaseHTTPResponse` 17:36:05 :param Exception error: An error encountered during the request, or 17:36:05 None if the response was received successfully. 17:36:05 17:36:05 :return: A new ``Retry`` object. 17:36:05 """ 17:36:05 if self.total is False and error: 17:36:05 # Disabled, indicate to re-raise the error. 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 17:36:05 total = self.total 17:36:05 if total is not None: 17:36:05 total -= 1 17:36:05 17:36:05 connect = self.connect 17:36:05 read = self.read 17:36:05 redirect = self.redirect 17:36:05 status_count = self.status 17:36:05 other = self.other 17:36:05 cause = "unknown" 17:36:05 status = None 17:36:05 redirect_location = None 17:36:05 17:36:05 if error and self._is_connection_error(error): 17:36:05 # Connect retry? 17:36:05 if connect is False: 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif connect is not None: 17:36:05 connect -= 1 17:36:05 17:36:05 elif error and self._is_read_error(error): 17:36:05 # Read retry? 17:36:05 if read is False or method is None or not self._is_method_retryable(method): 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif read is not None: 17:36:05 read -= 1 17:36:05 17:36:05 elif error: 17:36:05 # Other retry? 17:36:05 if other is not None: 17:36:05 other -= 1 17:36:05 17:36:05 elif response and response.get_redirect_location(): 17:36:05 # Redirect retry? 17:36:05 if redirect is not None: 17:36:05 redirect -= 1 17:36:05 cause = "too many redirects" 17:36:05 response_redirect_location = response.get_redirect_location() 17:36:05 if response_redirect_location: 17:36:05 redirect_location = response_redirect_location 17:36:05 status = response.status 17:36:05 17:36:05 else: 17:36:05 # Incrementing because of a server error like a 500 in 17:36:05 # status_forcelist and the given method is in the allowed_methods 17:36:05 cause = ResponseError.GENERIC_ERROR 17:36:05 if response and response.status: 17:36:05 if status_count is not None: 17:36:05 status_count -= 1 17:36:05 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 17:36:05 status = response.status 17:36:05 17:36:05 history = self.history + ( 17:36:05 RequestHistory(method, url, error, status, redirect_location), 17:36:05 ) 17:36:05 17:36:05 new_retry = self.new( 17:36:05 total=total, 17:36:05 connect=connect, 17:36:05 read=read, 17:36:05 redirect=redirect, 17:36:05 status=status_count, 17:36:05 other=other, 17:36:05 history=history, 17:36:05 ) 17:36:05 17:36:05 if new_retry.is_exhausted(): 17:36:05 reason = error or ResponseError(cause) 17:36:05 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 17:36:05 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 17:36:05 17:36:05 During handling of the above exception, another exception occurred: 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_08_xpdr_device_connected(self): 17:36:05 > response = test_utils.check_device_connection("XPDRA01") 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:103: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 transportpce_tests/common/test_utils.py:369: in check_device_connection 17:36:05 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 17:36:05 transportpce_tests/common/test_utils.py:116: in get_request 17:36:05 return requests.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 17:36:05 return session.request(method=method, url=url, **kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 17:36:05 resp = self.send(prep, **send_kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 17:36:05 r = adapter.send(request, **kwargs) 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 except (ProtocolError, OSError) as err: 17:36:05 raise ConnectionError(err, request=request) 17:36:05 17:36:05 except MaxRetryError as e: 17:36:05 if isinstance(e.reason, ConnectTimeoutError): 17:36:05 # TODO: Remove this in 3.0.0: see #2811 17:36:05 if not isinstance(e.reason, NewConnectionError): 17:36:05 raise ConnectTimeout(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, ResponseError): 17:36:05 raise RetryError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _ProxyError): 17:36:05 raise ProxyError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _SSLError): 17:36:05 # This branch is for urllib3 v1.22 and later. 17:36:05 raise SSLError(e, request=request) 17:36:05 17:36:05 > raise ConnectionError(e, request=request) 17:36:05 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_08_xpdr_device_connected 17:36:05 _________ TransportPCEPortMappingTesting.test_09_xpdr_portmapping_info _________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 > sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 17:36:05 raise err 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 address = ('localhost', 8182), timeout = 10, source_address = None 17:36:05 socket_options = [(6, 1, 1)] 17:36:05 17:36:05 def create_connection( 17:36:05 address: tuple[str, int], 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 source_address: tuple[str, int] | None = None, 17:36:05 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 17:36:05 ) -> socket.socket: 17:36:05 """Connect to *address* and return the socket object. 17:36:05 17:36:05 Convenience function. Connect to *address* (a 2-tuple ``(host, 17:36:05 port)``) and return the socket object. Passing the optional 17:36:05 *timeout* parameter will set the timeout on the socket instance 17:36:05 before attempting to connect. If no *timeout* is supplied, the 17:36:05 global default timeout setting returned by :func:`socket.getdefaulttimeout` 17:36:05 is used. If *source_address* is set it must be a tuple of (host, port) 17:36:05 for the socket to bind as a source address before making the connection. 17:36:05 An host of '' or port 0 tells the OS to use the default. 17:36:05 """ 17:36:05 17:36:05 host, port = address 17:36:05 if host.startswith("["): 17:36:05 host = host.strip("[]") 17:36:05 err = None 17:36:05 17:36:05 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 17:36:05 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 17:36:05 # The original create_connection function always returns all records. 17:36:05 family = allowed_gai_family() 17:36:05 17:36:05 try: 17:36:05 host.encode("idna") 17:36:05 except UnicodeError: 17:36:05 raise LocationParseError(f"'{host}', label empty or too long") from None 17:36:05 17:36:05 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 17:36:05 af, socktype, proto, canonname, sa = res 17:36:05 sock = None 17:36:05 try: 17:36:05 sock = socket.socket(af, socktype, proto) 17:36:05 17:36:05 # If provided, set socket level options before connecting. 17:36:05 _set_socket_options(sock, socket_options) 17:36:05 17:36:05 if timeout is not _DEFAULT_TIMEOUT: 17:36:05 sock.settimeout(timeout) 17:36:05 if source_address: 17:36:05 sock.bind(source_address) 17:36:05 > sock.connect(sa) 17:36:05 E ConnectionRefusedError: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 17:36:05 body = None 17:36:05 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='} 17:36:05 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 redirect = False, assert_same_host = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 17:36:05 release_conn = False, chunked = False, body_pos = None, preload_content = False 17:36:05 decode_content = False, response_kw = {} 17:36:05 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info', query=None, fragment=None) 17:36:05 destination_scheme = None, conn = None, release_this_conn = True 17:36:05 http_tunnel_required = False, err = None, clean_exit = False 17:36:05 17:36:05 def urlopen( # type: ignore[override] 17:36:05 self, 17:36:05 method: str, 17:36:05 url: str, 17:36:05 body: _TYPE_BODY | None = None, 17:36:05 headers: typing.Mapping[str, str] | None = None, 17:36:05 retries: Retry | bool | int | None = None, 17:36:05 redirect: bool = True, 17:36:05 assert_same_host: bool = True, 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 pool_timeout: int | None = None, 17:36:05 release_conn: bool | None = None, 17:36:05 chunked: bool = False, 17:36:05 body_pos: _TYPE_BODY_POSITION | None = None, 17:36:05 preload_content: bool = True, 17:36:05 decode_content: bool = True, 17:36:05 **response_kw: typing.Any, 17:36:05 ) -> BaseHTTPResponse: 17:36:05 """ 17:36:05 Get a connection from the pool and perform an HTTP request. This is the 17:36:05 lowest level call for making a request, so you'll need to specify all 17:36:05 the raw details. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 More commonly, it's appropriate to use a convenience method 17:36:05 such as :meth:`request`. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 `release_conn` will only behave as expected if 17:36:05 `preload_content=False` because we want to make 17:36:05 `preload_content=False` the default behaviour someday soon without 17:36:05 breaking backwards compatibility. 17:36:05 17:36:05 :param method: 17:36:05 HTTP request method (such as GET, POST, PUT, etc.) 17:36:05 17:36:05 :param url: 17:36:05 The URL to perform the request on. 17:36:05 17:36:05 :param body: 17:36:05 Data to send in the request body, either :class:`str`, :class:`bytes`, 17:36:05 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 17:36:05 17:36:05 :param headers: 17:36:05 Dictionary of custom headers to send, such as User-Agent, 17:36:05 If-None-Match, etc. If None, pool headers are used. If provided, 17:36:05 these headers completely replace any pool-specific headers. 17:36:05 17:36:05 :param retries: 17:36:05 Configure the number of retries to allow before raising a 17:36:05 :class:`~urllib3.exceptions.MaxRetryError` exception. 17:36:05 17:36:05 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 17:36:05 :class:`~urllib3.util.retry.Retry` object for fine-grained control 17:36:05 over different types of retries. 17:36:05 Pass an integer number to retry connection errors that many times, 17:36:05 but no other types of errors. Pass zero to never retry. 17:36:05 17:36:05 If ``False``, then retries are disabled and any exception is raised 17:36:05 immediately. Also, instead of raising a MaxRetryError on redirects, 17:36:05 the redirect response will be returned. 17:36:05 17:36:05 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 17:36:05 17:36:05 :param redirect: 17:36:05 If True, automatically handle redirects (status codes 301, 302, 17:36:05 303, 307, 308). Each redirect counts as a retry. Disabling retries 17:36:05 will disable redirect, too. 17:36:05 17:36:05 :param assert_same_host: 17:36:05 If ``True``, will make sure that the host of the pool requests is 17:36:05 consistent else will raise HostChangedError. When ``False``, you can 17:36:05 use the pool on an HTTP proxy and request foreign hosts. 17:36:05 17:36:05 :param timeout: 17:36:05 If specified, overrides the default timeout for this one 17:36:05 request. It may be a float (in seconds) or an instance of 17:36:05 :class:`urllib3.util.Timeout`. 17:36:05 17:36:05 :param pool_timeout: 17:36:05 If set and the pool is set to block=True, then this method will 17:36:05 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 17:36:05 connection is available within the time period. 17:36:05 17:36:05 :param bool preload_content: 17:36:05 If True, the response's body will be preloaded into memory. 17:36:05 17:36:05 :param bool decode_content: 17:36:05 If True, will attempt to decode the body based on the 17:36:05 'content-encoding' header. 17:36:05 17:36:05 :param release_conn: 17:36:05 If False, then the urlopen call will not release the connection 17:36:05 back into the pool once a response is received (but will release if 17:36:05 you read the entire contents of the response such as when 17:36:05 `preload_content=True`). This is useful if you're not preloading 17:36:05 the response's content immediately. You will need to call 17:36:05 ``r.release_conn()`` on the response ``r`` to return the connection 17:36:05 back into the pool. If None, it takes the value of ``preload_content`` 17:36:05 which defaults to ``True``. 17:36:05 17:36:05 :param bool chunked: 17:36:05 If True, urllib3 will send the body using chunked transfer 17:36:05 encoding. Otherwise, urllib3 will send the body using the standard 17:36:05 content-length form. Defaults to False. 17:36:05 17:36:05 :param int body_pos: 17:36:05 Position to seek to in file-like body in the event of a retry or 17:36:05 redirect. Typically this won't need to be set because urllib3 will 17:36:05 auto-populate the value when needed. 17:36:05 """ 17:36:05 parsed_url = parse_url(url) 17:36:05 destination_scheme = parsed_url.scheme 17:36:05 17:36:05 if headers is None: 17:36:05 headers = self.headers 17:36:05 17:36:05 if not isinstance(retries, Retry): 17:36:05 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 17:36:05 17:36:05 if release_conn is None: 17:36:05 release_conn = preload_content 17:36:05 17:36:05 # Check host 17:36:05 if assert_same_host and not self.is_same_host(url): 17:36:05 raise HostChangedError(self, url, retries) 17:36:05 17:36:05 # Ensure that the URL we're connecting to is properly encoded 17:36:05 if url.startswith("/"): 17:36:05 url = to_str(_encode_target(url)) 17:36:05 else: 17:36:05 url = to_str(parsed_url.url) 17:36:05 17:36:05 conn = None 17:36:05 17:36:05 # Track whether `conn` needs to be released before 17:36:05 # returning/raising/recursing. Update this variable if necessary, and 17:36:05 # leave `release_conn` constant throughout the function. That way, if 17:36:05 # the function recurses, the original value of `release_conn` will be 17:36:05 # passed down into the recursive call, and its value will be respected. 17:36:05 # 17:36:05 # See issue #651 [1] for details. 17:36:05 # 17:36:05 # [1] 17:36:05 release_this_conn = release_conn 17:36:05 17:36:05 http_tunnel_required = connection_requires_http_tunnel( 17:36:05 self.proxy, self.proxy_config, destination_scheme 17:36:05 ) 17:36:05 17:36:05 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 17:36:05 # have to copy the headers dict so we can safely change it without those 17:36:05 # changes being reflected in anyone else's copy. 17:36:05 if not http_tunnel_required: 17:36:05 headers = headers.copy() # type: ignore[attr-defined] 17:36:05 headers.update(self.proxy_headers) # type: ignore[union-attr] 17:36:05 17:36:05 # Must keep the exception bound to a separate variable or else Python 3 17:36:05 # complains about UnboundLocalError. 17:36:05 err = None 17:36:05 17:36:05 # Keep track of whether we cleanly exited the except block. This 17:36:05 # ensures we do proper cleanup in finally. 17:36:05 clean_exit = False 17:36:05 17:36:05 # Rewind body position, if needed. Record current position 17:36:05 # for future rewinds in the event of a redirect/retry. 17:36:05 body_pos = set_file_position(body, body_pos) 17:36:05 17:36:05 try: 17:36:05 # Request a connection from the queue. 17:36:05 timeout_obj = self._get_timeout(timeout) 17:36:05 conn = self._get_conn(timeout=pool_timeout) 17:36:05 17:36:05 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 17:36:05 17:36:05 # Is this a closed/new connection that requires CONNECT tunnelling? 17:36:05 if self.proxy is not None and http_tunnel_required and conn.is_closed: 17:36:05 try: 17:36:05 self._prepare_proxy(conn) 17:36:05 except (BaseSSLError, OSError, SocketTimeout) as e: 17:36:05 self._raise_timeout( 17:36:05 err=e, url=self.proxy.url, timeout_value=conn.timeout 17:36:05 ) 17:36:05 raise 17:36:05 17:36:05 # If we're going to release the connection in ``finally:``, then 17:36:05 # the response doesn't need to know about the connection. Otherwise 17:36:05 # it will also try to release it and we'll have a double-release 17:36:05 # mess. 17:36:05 response_conn = conn if not release_conn else None 17:36:05 17:36:05 # Make the request on the HTTPConnection object 17:36:05 > response = self._make_request( 17:36:05 conn, 17:36:05 method, 17:36:05 url, 17:36:05 timeout=timeout_obj, 17:36:05 body=body, 17:36:05 headers=headers, 17:36:05 chunked=chunked, 17:36:05 retries=retries, 17:36:05 response_conn=response_conn, 17:36:05 preload_content=preload_content, 17:36:05 decode_content=decode_content, 17:36:05 **response_kw, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 17:36:05 conn.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 17:36:05 self.endheaders() 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 17:36:05 self._send_output(message_body, encode_chunked=encode_chunked) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 17:36:05 self.send(msg) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 17:36:05 self.connect() 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 17:36:05 self.sock = self._new_conn() 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 except socket.gaierror as e: 17:36:05 raise NameResolutionError(self.host, self, e) from e 17:36:05 except SocketTimeout as e: 17:36:05 raise ConnectTimeoutError( 17:36:05 self, 17:36:05 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 17:36:05 ) from e 17:36:05 17:36:05 except OSError as e: 17:36:05 > raise NewConnectionError( 17:36:05 self, f"Failed to establish a new connection: {e}" 17:36:05 ) from e 17:36:05 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 > resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 17:36:05 retries = retries.increment( 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 17:36:05 response = None 17:36:05 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 17:36:05 _pool = 17:36:05 _stacktrace = 17:36:05 17:36:05 def increment( 17:36:05 self, 17:36:05 method: str | None = None, 17:36:05 url: str | None = None, 17:36:05 response: BaseHTTPResponse | None = None, 17:36:05 error: Exception | None = None, 17:36:05 _pool: ConnectionPool | None = None, 17:36:05 _stacktrace: TracebackType | None = None, 17:36:05 ) -> Self: 17:36:05 """Return a new Retry object with incremented retry counters. 17:36:05 17:36:05 :param response: A response object, or None, if the server did not 17:36:05 return a response. 17:36:05 :type response: :class:`~urllib3.response.BaseHTTPResponse` 17:36:05 :param Exception error: An error encountered during the request, or 17:36:05 None if the response was received successfully. 17:36:05 17:36:05 :return: A new ``Retry`` object. 17:36:05 """ 17:36:05 if self.total is False and error: 17:36:05 # Disabled, indicate to re-raise the error. 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 17:36:05 total = self.total 17:36:05 if total is not None: 17:36:05 total -= 1 17:36:05 17:36:05 connect = self.connect 17:36:05 read = self.read 17:36:05 redirect = self.redirect 17:36:05 status_count = self.status 17:36:05 other = self.other 17:36:05 cause = "unknown" 17:36:05 status = None 17:36:05 redirect_location = None 17:36:05 17:36:05 if error and self._is_connection_error(error): 17:36:05 # Connect retry? 17:36:05 if connect is False: 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif connect is not None: 17:36:05 connect -= 1 17:36:05 17:36:05 elif error and self._is_read_error(error): 17:36:05 # Read retry? 17:36:05 if read is False or method is None or not self._is_method_retryable(method): 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif read is not None: 17:36:05 read -= 1 17:36:05 17:36:05 elif error: 17:36:05 # Other retry? 17:36:05 if other is not None: 17:36:05 other -= 1 17:36:05 17:36:05 elif response and response.get_redirect_location(): 17:36:05 # Redirect retry? 17:36:05 if redirect is not None: 17:36:05 redirect -= 1 17:36:05 cause = "too many redirects" 17:36:05 response_redirect_location = response.get_redirect_location() 17:36:05 if response_redirect_location: 17:36:05 redirect_location = response_redirect_location 17:36:05 status = response.status 17:36:05 17:36:05 else: 17:36:05 # Incrementing because of a server error like a 500 in 17:36:05 # status_forcelist and the given method is in the allowed_methods 17:36:05 cause = ResponseError.GENERIC_ERROR 17:36:05 if response and response.status: 17:36:05 if status_count is not None: 17:36:05 status_count -= 1 17:36:05 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 17:36:05 status = response.status 17:36:05 17:36:05 history = self.history + ( 17:36:05 RequestHistory(method, url, error, status, redirect_location), 17:36:05 ) 17:36:05 17:36:05 new_retry = self.new( 17:36:05 total=total, 17:36:05 connect=connect, 17:36:05 read=read, 17:36:05 redirect=redirect, 17:36:05 status=status_count, 17:36:05 other=other, 17:36:05 history=history, 17:36:05 ) 17:36:05 17:36:05 if new_retry.is_exhausted(): 17:36:05 reason = error or ResponseError(cause) 17:36:05 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 17:36:05 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 17:36:05 17:36:05 During handling of the above exception, another exception occurred: 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_09_xpdr_portmapping_info(self): 17:36:05 > response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:109: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 transportpce_tests/common/test_utils.py:470: in get_portmapping_node_attr 17:36:05 response = get_request(target_url) 17:36:05 transportpce_tests/common/test_utils.py:116: in get_request 17:36:05 return requests.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 17:36:05 return session.request(method=method, url=url, **kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 17:36:05 resp = self.send(prep, **send_kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 17:36:05 r = adapter.send(request, **kwargs) 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 except (ProtocolError, OSError) as err: 17:36:05 raise ConnectionError(err, request=request) 17:36:05 17:36:05 except MaxRetryError as e: 17:36:05 if isinstance(e.reason, ConnectTimeoutError): 17:36:05 # TODO: Remove this in 3.0.0: see #2811 17:36:05 if not isinstance(e.reason, NewConnectionError): 17:36:05 raise ConnectTimeout(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, ResponseError): 17:36:05 raise RetryError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _ProxyError): 17:36:05 raise ProxyError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _SSLError): 17:36:05 # This branch is for urllib3 v1.22 and later. 17:36:05 raise SSLError(e, request=request) 17:36:05 17:36:05 > raise ConnectionError(e, request=request) 17:36:05 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_09_xpdr_portmapping_info 17:36:05 _______ TransportPCEPortMappingTesting.test_10_xpdr_portmapping_NETWORK1 _______ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_10_xpdr_portmapping_NETWORK1(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK1") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:123: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_10_xpdr_portmapping_NETWORK1 17:36:05 _______ TransportPCEPortMappingTesting.test_11_xpdr_portmapping_NETWORK2 _______ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_11_xpdr_portmapping_NETWORK2(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK2") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:134: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_11_xpdr_portmapping_NETWORK2 17:36:05 _______ TransportPCEPortMappingTesting.test_12_xpdr_portmapping_CLIENT1 ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_12_xpdr_portmapping_CLIENT1(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT1") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:145: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_12_xpdr_portmapping_CLIENT1 17:36:05 _______ TransportPCEPortMappingTesting.test_13_xpdr_portmapping_CLIENT2 ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_13_xpdr_portmapping_CLIENT2(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT2") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:157: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_13_xpdr_portmapping_CLIENT2 17:36:05 _______ TransportPCEPortMappingTesting.test_14_xpdr_portmapping_CLIENT3 ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_14_xpdr_portmapping_CLIENT3(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT3") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:169: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_14_xpdr_portmapping_CLIENT3 17:36:05 _______ TransportPCEPortMappingTesting.test_15_xpdr_portmapping_CLIENT4 ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_15_xpdr_portmapping_CLIENT4(self): 17:36:05 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT4") 17:36:05 > self.assertEqual(response['status_code'], requests.codes.ok) 17:36:05 E AssertionError: 409 != 200 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:181: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_15_xpdr_portmapping_CLIENT4 17:36:05 _______ TransportPCEPortMappingTesting.test_16_xpdr_device_disconnection _______ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_16_xpdr_device_disconnection(self): 17:36:05 response = test_utils.unmount_device("XPDRA01") 17:36:05 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 17:36:05 E AssertionError: 409 not found in (200, 204) 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:192: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_16_xpdr_device_disconnection 17:36:05 Searching for pattern 'onDeviceDisConnected:\ XPDRA01' in karaf.log... Pattern not found after 180 seconds! Node XPDRA01 still not deleted from tpce topology... 17:36:05 _______ TransportPCEPortMappingTesting.test_17_xpdr_device_disconnected ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 > sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 17:36:05 raise err 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 address = ('localhost', 8182), timeout = 10, source_address = None 17:36:05 socket_options = [(6, 1, 1)] 17:36:05 17:36:05 def create_connection( 17:36:05 address: tuple[str, int], 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 source_address: tuple[str, int] | None = None, 17:36:05 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 17:36:05 ) -> socket.socket: 17:36:05 """Connect to *address* and return the socket object. 17:36:05 17:36:05 Convenience function. Connect to *address* (a 2-tuple ``(host, 17:36:05 port)``) and return the socket object. Passing the optional 17:36:05 *timeout* parameter will set the timeout on the socket instance 17:36:05 before attempting to connect. If no *timeout* is supplied, the 17:36:05 global default timeout setting returned by :func:`socket.getdefaulttimeout` 17:36:05 is used. If *source_address* is set it must be a tuple of (host, port) 17:36:05 for the socket to bind as a source address before making the connection. 17:36:05 An host of '' or port 0 tells the OS to use the default. 17:36:05 """ 17:36:05 17:36:05 host, port = address 17:36:05 if host.startswith("["): 17:36:05 host = host.strip("[]") 17:36:05 err = None 17:36:05 17:36:05 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 17:36:05 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 17:36:05 # The original create_connection function always returns all records. 17:36:05 family = allowed_gai_family() 17:36:05 17:36:05 try: 17:36:05 host.encode("idna") 17:36:05 except UnicodeError: 17:36:05 raise LocationParseError(f"'{host}', label empty or too long") from None 17:36:05 17:36:05 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 17:36:05 af, socktype, proto, canonname, sa = res 17:36:05 sock = None 17:36:05 try: 17:36:05 sock = socket.socket(af, socktype, proto) 17:36:05 17:36:05 # If provided, set socket level options before connecting. 17:36:05 _set_socket_options(sock, socket_options) 17:36:05 17:36:05 if timeout is not _DEFAULT_TIMEOUT: 17:36:05 sock.settimeout(timeout) 17:36:05 if source_address: 17:36:05 sock.bind(source_address) 17:36:05 > sock.connect(sa) 17:36:05 E ConnectionRefusedError: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 17:36:05 body = None 17:36:05 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='} 17:36:05 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 redirect = False, assert_same_host = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 17:36:05 release_conn = False, chunked = False, body_pos = None, preload_content = False 17:36:05 decode_content = False, response_kw = {} 17:36:05 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01', query='content=nonconfig', fragment=None) 17:36:05 destination_scheme = None, conn = None, release_this_conn = True 17:36:05 http_tunnel_required = False, err = None, clean_exit = False 17:36:05 17:36:05 def urlopen( # type: ignore[override] 17:36:05 self, 17:36:05 method: str, 17:36:05 url: str, 17:36:05 body: _TYPE_BODY | None = None, 17:36:05 headers: typing.Mapping[str, str] | None = None, 17:36:05 retries: Retry | bool | int | None = None, 17:36:05 redirect: bool = True, 17:36:05 assert_same_host: bool = True, 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 pool_timeout: int | None = None, 17:36:05 release_conn: bool | None = None, 17:36:05 chunked: bool = False, 17:36:05 body_pos: _TYPE_BODY_POSITION | None = None, 17:36:05 preload_content: bool = True, 17:36:05 decode_content: bool = True, 17:36:05 **response_kw: typing.Any, 17:36:05 ) -> BaseHTTPResponse: 17:36:05 """ 17:36:05 Get a connection from the pool and perform an HTTP request. This is the 17:36:05 lowest level call for making a request, so you'll need to specify all 17:36:05 the raw details. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 More commonly, it's appropriate to use a convenience method 17:36:05 such as :meth:`request`. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 `release_conn` will only behave as expected if 17:36:05 `preload_content=False` because we want to make 17:36:05 `preload_content=False` the default behaviour someday soon without 17:36:05 breaking backwards compatibility. 17:36:05 17:36:05 :param method: 17:36:05 HTTP request method (such as GET, POST, PUT, etc.) 17:36:05 17:36:05 :param url: 17:36:05 The URL to perform the request on. 17:36:05 17:36:05 :param body: 17:36:05 Data to send in the request body, either :class:`str`, :class:`bytes`, 17:36:05 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 17:36:05 17:36:05 :param headers: 17:36:05 Dictionary of custom headers to send, such as User-Agent, 17:36:05 If-None-Match, etc. If None, pool headers are used. If provided, 17:36:05 these headers completely replace any pool-specific headers. 17:36:05 17:36:05 :param retries: 17:36:05 Configure the number of retries to allow before raising a 17:36:05 :class:`~urllib3.exceptions.MaxRetryError` exception. 17:36:05 17:36:05 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 17:36:05 :class:`~urllib3.util.retry.Retry` object for fine-grained control 17:36:05 over different types of retries. 17:36:05 Pass an integer number to retry connection errors that many times, 17:36:05 but no other types of errors. Pass zero to never retry. 17:36:05 17:36:05 If ``False``, then retries are disabled and any exception is raised 17:36:05 immediately. Also, instead of raising a MaxRetryError on redirects, 17:36:05 the redirect response will be returned. 17:36:05 17:36:05 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 17:36:05 17:36:05 :param redirect: 17:36:05 If True, automatically handle redirects (status codes 301, 302, 17:36:05 303, 307, 308). Each redirect counts as a retry. Disabling retries 17:36:05 will disable redirect, too. 17:36:05 17:36:05 :param assert_same_host: 17:36:05 If ``True``, will make sure that the host of the pool requests is 17:36:05 consistent else will raise HostChangedError. When ``False``, you can 17:36:05 use the pool on an HTTP proxy and request foreign hosts. 17:36:05 17:36:05 :param timeout: 17:36:05 If specified, overrides the default timeout for this one 17:36:05 request. It may be a float (in seconds) or an instance of 17:36:05 :class:`urllib3.util.Timeout`. 17:36:05 17:36:05 :param pool_timeout: 17:36:05 If set and the pool is set to block=True, then this method will 17:36:05 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 17:36:05 connection is available within the time period. 17:36:05 17:36:05 :param bool preload_content: 17:36:05 If True, the response's body will be preloaded into memory. 17:36:05 17:36:05 :param bool decode_content: 17:36:05 If True, will attempt to decode the body based on the 17:36:05 'content-encoding' header. 17:36:05 17:36:05 :param release_conn: 17:36:05 If False, then the urlopen call will not release the connection 17:36:05 back into the pool once a response is received (but will release if 17:36:05 you read the entire contents of the response such as when 17:36:05 `preload_content=True`). This is useful if you're not preloading 17:36:05 the response's content immediately. You will need to call 17:36:05 ``r.release_conn()`` on the response ``r`` to return the connection 17:36:05 back into the pool. If None, it takes the value of ``preload_content`` 17:36:05 which defaults to ``True``. 17:36:05 17:36:05 :param bool chunked: 17:36:05 If True, urllib3 will send the body using chunked transfer 17:36:05 encoding. Otherwise, urllib3 will send the body using the standard 17:36:05 content-length form. Defaults to False. 17:36:05 17:36:05 :param int body_pos: 17:36:05 Position to seek to in file-like body in the event of a retry or 17:36:05 redirect. Typically this won't need to be set because urllib3 will 17:36:05 auto-populate the value when needed. 17:36:05 """ 17:36:05 parsed_url = parse_url(url) 17:36:05 destination_scheme = parsed_url.scheme 17:36:05 17:36:05 if headers is None: 17:36:05 headers = self.headers 17:36:05 17:36:05 if not isinstance(retries, Retry): 17:36:05 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 17:36:05 17:36:05 if release_conn is None: 17:36:05 release_conn = preload_content 17:36:05 17:36:05 # Check host 17:36:05 if assert_same_host and not self.is_same_host(url): 17:36:05 raise HostChangedError(self, url, retries) 17:36:05 17:36:05 # Ensure that the URL we're connecting to is properly encoded 17:36:05 if url.startswith("/"): 17:36:05 url = to_str(_encode_target(url)) 17:36:05 else: 17:36:05 url = to_str(parsed_url.url) 17:36:05 17:36:05 conn = None 17:36:05 17:36:05 # Track whether `conn` needs to be released before 17:36:05 # returning/raising/recursing. Update this variable if necessary, and 17:36:05 # leave `release_conn` constant throughout the function. That way, if 17:36:05 # the function recurses, the original value of `release_conn` will be 17:36:05 # passed down into the recursive call, and its value will be respected. 17:36:05 # 17:36:05 # See issue #651 [1] for details. 17:36:05 # 17:36:05 # [1] 17:36:05 release_this_conn = release_conn 17:36:05 17:36:05 http_tunnel_required = connection_requires_http_tunnel( 17:36:05 self.proxy, self.proxy_config, destination_scheme 17:36:05 ) 17:36:05 17:36:05 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 17:36:05 # have to copy the headers dict so we can safely change it without those 17:36:05 # changes being reflected in anyone else's copy. 17:36:05 if not http_tunnel_required: 17:36:05 headers = headers.copy() # type: ignore[attr-defined] 17:36:05 headers.update(self.proxy_headers) # type: ignore[union-attr] 17:36:05 17:36:05 # Must keep the exception bound to a separate variable or else Python 3 17:36:05 # complains about UnboundLocalError. 17:36:05 err = None 17:36:05 17:36:05 # Keep track of whether we cleanly exited the except block. This 17:36:05 # ensures we do proper cleanup in finally. 17:36:05 clean_exit = False 17:36:05 17:36:05 # Rewind body position, if needed. Record current position 17:36:05 # for future rewinds in the event of a redirect/retry. 17:36:05 body_pos = set_file_position(body, body_pos) 17:36:05 17:36:05 try: 17:36:05 # Request a connection from the queue. 17:36:05 timeout_obj = self._get_timeout(timeout) 17:36:05 conn = self._get_conn(timeout=pool_timeout) 17:36:05 17:36:05 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 17:36:05 17:36:05 # Is this a closed/new connection that requires CONNECT tunnelling? 17:36:05 if self.proxy is not None and http_tunnel_required and conn.is_closed: 17:36:05 try: 17:36:05 self._prepare_proxy(conn) 17:36:05 except (BaseSSLError, OSError, SocketTimeout) as e: 17:36:05 self._raise_timeout( 17:36:05 err=e, url=self.proxy.url, timeout_value=conn.timeout 17:36:05 ) 17:36:05 raise 17:36:05 17:36:05 # If we're going to release the connection in ``finally:``, then 17:36:05 # the response doesn't need to know about the connection. Otherwise 17:36:05 # it will also try to release it and we'll have a double-release 17:36:05 # mess. 17:36:05 response_conn = conn if not release_conn else None 17:36:05 17:36:05 # Make the request on the HTTPConnection object 17:36:05 > response = self._make_request( 17:36:05 conn, 17:36:05 method, 17:36:05 url, 17:36:05 timeout=timeout_obj, 17:36:05 body=body, 17:36:05 headers=headers, 17:36:05 chunked=chunked, 17:36:05 retries=retries, 17:36:05 response_conn=response_conn, 17:36:05 preload_content=preload_content, 17:36:05 decode_content=decode_content, 17:36:05 **response_kw, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 17:36:05 conn.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 17:36:05 self.endheaders() 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 17:36:05 self._send_output(message_body, encode_chunked=encode_chunked) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 17:36:05 self.send(msg) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 17:36:05 self.connect() 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 17:36:05 self.sock = self._new_conn() 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 except socket.gaierror as e: 17:36:05 raise NameResolutionError(self.host, self, e) from e 17:36:05 except SocketTimeout as e: 17:36:05 raise ConnectTimeoutError( 17:36:05 self, 17:36:05 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 17:36:05 ) from e 17:36:05 17:36:05 except OSError as e: 17:36:05 > raise NewConnectionError( 17:36:05 self, f"Failed to establish a new connection: {e}" 17:36:05 ) from e 17:36:05 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 > resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 17:36:05 retries = retries.increment( 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig' 17:36:05 response = None 17:36:05 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 17:36:05 _pool = 17:36:05 _stacktrace = 17:36:05 17:36:05 def increment( 17:36:05 self, 17:36:05 method: str | None = None, 17:36:05 url: str | None = None, 17:36:05 response: BaseHTTPResponse | None = None, 17:36:05 error: Exception | None = None, 17:36:05 _pool: ConnectionPool | None = None, 17:36:05 _stacktrace: TracebackType | None = None, 17:36:05 ) -> Self: 17:36:05 """Return a new Retry object with incremented retry counters. 17:36:05 17:36:05 :param response: A response object, or None, if the server did not 17:36:05 return a response. 17:36:05 :type response: :class:`~urllib3.response.BaseHTTPResponse` 17:36:05 :param Exception error: An error encountered during the request, or 17:36:05 None if the response was received successfully. 17:36:05 17:36:05 :return: A new ``Retry`` object. 17:36:05 """ 17:36:05 if self.total is False and error: 17:36:05 # Disabled, indicate to re-raise the error. 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 17:36:05 total = self.total 17:36:05 if total is not None: 17:36:05 total -= 1 17:36:05 17:36:05 connect = self.connect 17:36:05 read = self.read 17:36:05 redirect = self.redirect 17:36:05 status_count = self.status 17:36:05 other = self.other 17:36:05 cause = "unknown" 17:36:05 status = None 17:36:05 redirect_location = None 17:36:05 17:36:05 if error and self._is_connection_error(error): 17:36:05 # Connect retry? 17:36:05 if connect is False: 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif connect is not None: 17:36:05 connect -= 1 17:36:05 17:36:05 elif error and self._is_read_error(error): 17:36:05 # Read retry? 17:36:05 if read is False or method is None or not self._is_method_retryable(method): 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif read is not None: 17:36:05 read -= 1 17:36:05 17:36:05 elif error: 17:36:05 # Other retry? 17:36:05 if other is not None: 17:36:05 other -= 1 17:36:05 17:36:05 elif response and response.get_redirect_location(): 17:36:05 # Redirect retry? 17:36:05 if redirect is not None: 17:36:05 redirect -= 1 17:36:05 cause = "too many redirects" 17:36:05 response_redirect_location = response.get_redirect_location() 17:36:05 if response_redirect_location: 17:36:05 redirect_location = response_redirect_location 17:36:05 status = response.status 17:36:05 17:36:05 else: 17:36:05 # Incrementing because of a server error like a 500 in 17:36:05 # status_forcelist and the given method is in the allowed_methods 17:36:05 cause = ResponseError.GENERIC_ERROR 17:36:05 if response and response.status: 17:36:05 if status_count is not None: 17:36:05 status_count -= 1 17:36:05 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 17:36:05 status = response.status 17:36:05 17:36:05 history = self.history + ( 17:36:05 RequestHistory(method, url, error, status, redirect_location), 17:36:05 ) 17:36:05 17:36:05 new_retry = self.new( 17:36:05 total=total, 17:36:05 connect=connect, 17:36:05 read=read, 17:36:05 redirect=redirect, 17:36:05 status=status_count, 17:36:05 other=other, 17:36:05 history=history, 17:36:05 ) 17:36:05 17:36:05 if new_retry.is_exhausted(): 17:36:05 reason = error or ResponseError(cause) 17:36:05 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 17:36:05 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 17:36:05 17:36:05 During handling of the above exception, another exception occurred: 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_17_xpdr_device_disconnected(self): 17:36:05 > response = test_utils.check_device_connection("XPDRA01") 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:195: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 transportpce_tests/common/test_utils.py:369: in check_device_connection 17:36:05 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 17:36:05 transportpce_tests/common/test_utils.py:116: in get_request 17:36:05 return requests.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 17:36:05 return session.request(method=method, url=url, **kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 17:36:05 resp = self.send(prep, **send_kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 17:36:05 r = adapter.send(request, **kwargs) 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 except (ProtocolError, OSError) as err: 17:36:05 raise ConnectionError(err, request=request) 17:36:05 17:36:05 except MaxRetryError as e: 17:36:05 if isinstance(e.reason, ConnectTimeoutError): 17:36:05 # TODO: Remove this in 3.0.0: see #2811 17:36:05 if not isinstance(e.reason, NewConnectionError): 17:36:05 raise ConnectTimeout(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, ResponseError): 17:36:05 raise RetryError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _ProxyError): 17:36:05 raise ProxyError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _SSLError): 17:36:05 # This branch is for urllib3 v1.22 and later. 17:36:05 raise SSLError(e, request=request) 17:36:05 17:36:05 > raise ConnectionError(e, request=request) 17:36:05 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_17_xpdr_device_disconnected 17:36:05 _______ TransportPCEPortMappingTesting.test_18_xpdr_device_not_connected _______ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 > sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 17:36:05 raise err 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 address = ('localhost', 8182), timeout = 10, source_address = None 17:36:05 socket_options = [(6, 1, 1)] 17:36:05 17:36:05 def create_connection( 17:36:05 address: tuple[str, int], 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 source_address: tuple[str, int] | None = None, 17:36:05 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 17:36:05 ) -> socket.socket: 17:36:05 """Connect to *address* and return the socket object. 17:36:05 17:36:05 Convenience function. Connect to *address* (a 2-tuple ``(host, 17:36:05 port)``) and return the socket object. Passing the optional 17:36:05 *timeout* parameter will set the timeout on the socket instance 17:36:05 before attempting to connect. If no *timeout* is supplied, the 17:36:05 global default timeout setting returned by :func:`socket.getdefaulttimeout` 17:36:05 is used. If *source_address* is set it must be a tuple of (host, port) 17:36:05 for the socket to bind as a source address before making the connection. 17:36:05 An host of '' or port 0 tells the OS to use the default. 17:36:05 """ 17:36:05 17:36:05 host, port = address 17:36:05 if host.startswith("["): 17:36:05 host = host.strip("[]") 17:36:05 err = None 17:36:05 17:36:05 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 17:36:05 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 17:36:05 # The original create_connection function always returns all records. 17:36:05 family = allowed_gai_family() 17:36:05 17:36:05 try: 17:36:05 host.encode("idna") 17:36:05 except UnicodeError: 17:36:05 raise LocationParseError(f"'{host}', label empty or too long") from None 17:36:05 17:36:05 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 17:36:05 af, socktype, proto, canonname, sa = res 17:36:05 sock = None 17:36:05 try: 17:36:05 sock = socket.socket(af, socktype, proto) 17:36:05 17:36:05 # If provided, set socket level options before connecting. 17:36:05 _set_socket_options(sock, socket_options) 17:36:05 17:36:05 if timeout is not _DEFAULT_TIMEOUT: 17:36:05 sock.settimeout(timeout) 17:36:05 if source_address: 17:36:05 sock.bind(source_address) 17:36:05 > sock.connect(sa) 17:36:05 E ConnectionRefusedError: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 17:36:05 body = None 17:36:05 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='} 17:36:05 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 redirect = False, assert_same_host = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 17:36:05 release_conn = False, chunked = False, body_pos = None, preload_content = False 17:36:05 decode_content = False, response_kw = {} 17:36:05 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info', query=None, fragment=None) 17:36:05 destination_scheme = None, conn = None, release_this_conn = True 17:36:05 http_tunnel_required = False, err = None, clean_exit = False 17:36:05 17:36:05 def urlopen( # type: ignore[override] 17:36:05 self, 17:36:05 method: str, 17:36:05 url: str, 17:36:05 body: _TYPE_BODY | None = None, 17:36:05 headers: typing.Mapping[str, str] | None = None, 17:36:05 retries: Retry | bool | int | None = None, 17:36:05 redirect: bool = True, 17:36:05 assert_same_host: bool = True, 17:36:05 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 17:36:05 pool_timeout: int | None = None, 17:36:05 release_conn: bool | None = None, 17:36:05 chunked: bool = False, 17:36:05 body_pos: _TYPE_BODY_POSITION | None = None, 17:36:05 preload_content: bool = True, 17:36:05 decode_content: bool = True, 17:36:05 **response_kw: typing.Any, 17:36:05 ) -> BaseHTTPResponse: 17:36:05 """ 17:36:05 Get a connection from the pool and perform an HTTP request. This is the 17:36:05 lowest level call for making a request, so you'll need to specify all 17:36:05 the raw details. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 More commonly, it's appropriate to use a convenience method 17:36:05 such as :meth:`request`. 17:36:05 17:36:05 .. note:: 17:36:05 17:36:05 `release_conn` will only behave as expected if 17:36:05 `preload_content=False` because we want to make 17:36:05 `preload_content=False` the default behaviour someday soon without 17:36:05 breaking backwards compatibility. 17:36:05 17:36:05 :param method: 17:36:05 HTTP request method (such as GET, POST, PUT, etc.) 17:36:05 17:36:05 :param url: 17:36:05 The URL to perform the request on. 17:36:05 17:36:05 :param body: 17:36:05 Data to send in the request body, either :class:`str`, :class:`bytes`, 17:36:05 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 17:36:05 17:36:05 :param headers: 17:36:05 Dictionary of custom headers to send, such as User-Agent, 17:36:05 If-None-Match, etc. If None, pool headers are used. If provided, 17:36:05 these headers completely replace any pool-specific headers. 17:36:05 17:36:05 :param retries: 17:36:05 Configure the number of retries to allow before raising a 17:36:05 :class:`~urllib3.exceptions.MaxRetryError` exception. 17:36:05 17:36:05 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 17:36:05 :class:`~urllib3.util.retry.Retry` object for fine-grained control 17:36:05 over different types of retries. 17:36:05 Pass an integer number to retry connection errors that many times, 17:36:05 but no other types of errors. Pass zero to never retry. 17:36:05 17:36:05 If ``False``, then retries are disabled and any exception is raised 17:36:05 immediately. Also, instead of raising a MaxRetryError on redirects, 17:36:05 the redirect response will be returned. 17:36:05 17:36:05 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 17:36:05 17:36:05 :param redirect: 17:36:05 If True, automatically handle redirects (status codes 301, 302, 17:36:05 303, 307, 308). Each redirect counts as a retry. Disabling retries 17:36:05 will disable redirect, too. 17:36:05 17:36:05 :param assert_same_host: 17:36:05 If ``True``, will make sure that the host of the pool requests is 17:36:05 consistent else will raise HostChangedError. When ``False``, you can 17:36:05 use the pool on an HTTP proxy and request foreign hosts. 17:36:05 17:36:05 :param timeout: 17:36:05 If specified, overrides the default timeout for this one 17:36:05 request. It may be a float (in seconds) or an instance of 17:36:05 :class:`urllib3.util.Timeout`. 17:36:05 17:36:05 :param pool_timeout: 17:36:05 If set and the pool is set to block=True, then this method will 17:36:05 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 17:36:05 connection is available within the time period. 17:36:05 17:36:05 :param bool preload_content: 17:36:05 If True, the response's body will be preloaded into memory. 17:36:05 17:36:05 :param bool decode_content: 17:36:05 If True, will attempt to decode the body based on the 17:36:05 'content-encoding' header. 17:36:05 17:36:05 :param release_conn: 17:36:05 If False, then the urlopen call will not release the connection 17:36:05 back into the pool once a response is received (but will release if 17:36:05 you read the entire contents of the response such as when 17:36:05 `preload_content=True`). This is useful if you're not preloading 17:36:05 the response's content immediately. You will need to call 17:36:05 ``r.release_conn()`` on the response ``r`` to return the connection 17:36:05 back into the pool. If None, it takes the value of ``preload_content`` 17:36:05 which defaults to ``True``. 17:36:05 17:36:05 :param bool chunked: 17:36:05 If True, urllib3 will send the body using chunked transfer 17:36:05 encoding. Otherwise, urllib3 will send the body using the standard 17:36:05 content-length form. Defaults to False. 17:36:05 17:36:05 :param int body_pos: 17:36:05 Position to seek to in file-like body in the event of a retry or 17:36:05 redirect. Typically this won't need to be set because urllib3 will 17:36:05 auto-populate the value when needed. 17:36:05 """ 17:36:05 parsed_url = parse_url(url) 17:36:05 destination_scheme = parsed_url.scheme 17:36:05 17:36:05 if headers is None: 17:36:05 headers = self.headers 17:36:05 17:36:05 if not isinstance(retries, Retry): 17:36:05 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 17:36:05 17:36:05 if release_conn is None: 17:36:05 release_conn = preload_content 17:36:05 17:36:05 # Check host 17:36:05 if assert_same_host and not self.is_same_host(url): 17:36:05 raise HostChangedError(self, url, retries) 17:36:05 17:36:05 # Ensure that the URL we're connecting to is properly encoded 17:36:05 if url.startswith("/"): 17:36:05 url = to_str(_encode_target(url)) 17:36:05 else: 17:36:05 url = to_str(parsed_url.url) 17:36:05 17:36:05 conn = None 17:36:05 17:36:05 # Track whether `conn` needs to be released before 17:36:05 # returning/raising/recursing. Update this variable if necessary, and 17:36:05 # leave `release_conn` constant throughout the function. That way, if 17:36:05 # the function recurses, the original value of `release_conn` will be 17:36:05 # passed down into the recursive call, and its value will be respected. 17:36:05 # 17:36:05 # See issue #651 [1] for details. 17:36:05 # 17:36:05 # [1] 17:36:05 release_this_conn = release_conn 17:36:05 17:36:05 http_tunnel_required = connection_requires_http_tunnel( 17:36:05 self.proxy, self.proxy_config, destination_scheme 17:36:05 ) 17:36:05 17:36:05 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 17:36:05 # have to copy the headers dict so we can safely change it without those 17:36:05 # changes being reflected in anyone else's copy. 17:36:05 if not http_tunnel_required: 17:36:05 headers = headers.copy() # type: ignore[attr-defined] 17:36:05 headers.update(self.proxy_headers) # type: ignore[union-attr] 17:36:05 17:36:05 # Must keep the exception bound to a separate variable or else Python 3 17:36:05 # complains about UnboundLocalError. 17:36:05 err = None 17:36:05 17:36:05 # Keep track of whether we cleanly exited the except block. This 17:36:05 # ensures we do proper cleanup in finally. 17:36:05 clean_exit = False 17:36:05 17:36:05 # Rewind body position, if needed. Record current position 17:36:05 # for future rewinds in the event of a redirect/retry. 17:36:05 body_pos = set_file_position(body, body_pos) 17:36:05 17:36:05 try: 17:36:05 # Request a connection from the queue. 17:36:05 timeout_obj = self._get_timeout(timeout) 17:36:05 conn = self._get_conn(timeout=pool_timeout) 17:36:05 17:36:05 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 17:36:05 17:36:05 # Is this a closed/new connection that requires CONNECT tunnelling? 17:36:05 if self.proxy is not None and http_tunnel_required and conn.is_closed: 17:36:05 try: 17:36:05 self._prepare_proxy(conn) 17:36:05 except (BaseSSLError, OSError, SocketTimeout) as e: 17:36:05 self._raise_timeout( 17:36:05 err=e, url=self.proxy.url, timeout_value=conn.timeout 17:36:05 ) 17:36:05 raise 17:36:05 17:36:05 # If we're going to release the connection in ``finally:``, then 17:36:05 # the response doesn't need to know about the connection. Otherwise 17:36:05 # it will also try to release it and we'll have a double-release 17:36:05 # mess. 17:36:05 response_conn = conn if not release_conn else None 17:36:05 17:36:05 # Make the request on the HTTPConnection object 17:36:05 > response = self._make_request( 17:36:05 conn, 17:36:05 method, 17:36:05 url, 17:36:05 timeout=timeout_obj, 17:36:05 body=body, 17:36:05 headers=headers, 17:36:05 chunked=chunked, 17:36:05 retries=retries, 17:36:05 response_conn=response_conn, 17:36:05 preload_content=preload_content, 17:36:05 decode_content=decode_content, 17:36:05 **response_kw, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 17:36:05 conn.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 17:36:05 self.endheaders() 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 17:36:05 self._send_output(message_body, encode_chunked=encode_chunked) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 17:36:05 self.send(msg) 17:36:05 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 17:36:05 self.connect() 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 17:36:05 self.sock = self._new_conn() 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def _new_conn(self) -> socket.socket: 17:36:05 """Establish a socket connection and set nodelay settings on it. 17:36:05 17:36:05 :return: New socket connection. 17:36:05 """ 17:36:05 try: 17:36:05 sock = connection.create_connection( 17:36:05 (self._dns_host, self.port), 17:36:05 self.timeout, 17:36:05 source_address=self.source_address, 17:36:05 socket_options=self.socket_options, 17:36:05 ) 17:36:05 except socket.gaierror as e: 17:36:05 raise NameResolutionError(self.host, self, e) from e 17:36:05 except SocketTimeout as e: 17:36:05 raise ConnectTimeoutError( 17:36:05 self, 17:36:05 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 17:36:05 ) from e 17:36:05 17:36:05 except OSError as e: 17:36:05 > raise NewConnectionError( 17:36:05 self, f"Failed to establish a new connection: {e}" 17:36:05 ) from e 17:36:05 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 17:36:05 17:36:05 The above exception was the direct cause of the following exception: 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 > resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 17:36:05 retries = retries.increment( 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 17:36:05 method = 'GET' 17:36:05 url = '/rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info' 17:36:05 response = None 17:36:05 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 17:36:05 _pool = 17:36:05 _stacktrace = 17:36:05 17:36:05 def increment( 17:36:05 self, 17:36:05 method: str | None = None, 17:36:05 url: str | None = None, 17:36:05 response: BaseHTTPResponse | None = None, 17:36:05 error: Exception | None = None, 17:36:05 _pool: ConnectionPool | None = None, 17:36:05 _stacktrace: TracebackType | None = None, 17:36:05 ) -> Self: 17:36:05 """Return a new Retry object with incremented retry counters. 17:36:05 17:36:05 :param response: A response object, or None, if the server did not 17:36:05 return a response. 17:36:05 :type response: :class:`~urllib3.response.BaseHTTPResponse` 17:36:05 :param Exception error: An error encountered during the request, or 17:36:05 None if the response was received successfully. 17:36:05 17:36:05 :return: A new ``Retry`` object. 17:36:05 """ 17:36:05 if self.total is False and error: 17:36:05 # Disabled, indicate to re-raise the error. 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 17:36:05 total = self.total 17:36:05 if total is not None: 17:36:05 total -= 1 17:36:05 17:36:05 connect = self.connect 17:36:05 read = self.read 17:36:05 redirect = self.redirect 17:36:05 status_count = self.status 17:36:05 other = self.other 17:36:05 cause = "unknown" 17:36:05 status = None 17:36:05 redirect_location = None 17:36:05 17:36:05 if error and self._is_connection_error(error): 17:36:05 # Connect retry? 17:36:05 if connect is False: 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif connect is not None: 17:36:05 connect -= 1 17:36:05 17:36:05 elif error and self._is_read_error(error): 17:36:05 # Read retry? 17:36:05 if read is False or method is None or not self._is_method_retryable(method): 17:36:05 raise reraise(type(error), error, _stacktrace) 17:36:05 elif read is not None: 17:36:05 read -= 1 17:36:05 17:36:05 elif error: 17:36:05 # Other retry? 17:36:05 if other is not None: 17:36:05 other -= 1 17:36:05 17:36:05 elif response and response.get_redirect_location(): 17:36:05 # Redirect retry? 17:36:05 if redirect is not None: 17:36:05 redirect -= 1 17:36:05 cause = "too many redirects" 17:36:05 response_redirect_location = response.get_redirect_location() 17:36:05 if response_redirect_location: 17:36:05 redirect_location = response_redirect_location 17:36:05 status = response.status 17:36:05 17:36:05 else: 17:36:05 # Incrementing because of a server error like a 500 in 17:36:05 # status_forcelist and the given method is in the allowed_methods 17:36:05 cause = ResponseError.GENERIC_ERROR 17:36:05 if response and response.status: 17:36:05 if status_count is not None: 17:36:05 status_count -= 1 17:36:05 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 17:36:05 status = response.status 17:36:05 17:36:05 history = self.history + ( 17:36:05 RequestHistory(method, url, error, status, redirect_location), 17:36:05 ) 17:36:05 17:36:05 new_retry = self.new( 17:36:05 total=total, 17:36:05 connect=connect, 17:36:05 read=read, 17:36:05 redirect=redirect, 17:36:05 status=status_count, 17:36:05 other=other, 17:36:05 history=history, 17:36:05 ) 17:36:05 17:36:05 if new_retry.is_exhausted(): 17:36:05 reason = error or ResponseError(cause) 17:36:05 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 17:36:05 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 17:36:05 17:36:05 During handling of the above exception, another exception occurred: 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_18_xpdr_device_not_connected(self): 17:36:05 > response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:203: 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 transportpce_tests/common/test_utils.py:470: in get_portmapping_node_attr 17:36:05 response = get_request(target_url) 17:36:05 transportpce_tests/common/test_utils.py:116: in get_request 17:36:05 return requests.request( 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 17:36:05 return session.request(method=method, url=url, **kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 17:36:05 resp = self.send(prep, **send_kwargs) 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 17:36:05 r = adapter.send(request, **kwargs) 17:36:05 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 17:36:05 17:36:05 self = 17:36:05 request = , stream = False 17:36:05 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 17:36:05 proxies = OrderedDict() 17:36:05 17:36:05 def send( 17:36:05 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 17:36:05 ): 17:36:05 """Sends PreparedRequest object. Returns Response object. 17:36:05 17:36:05 :param request: The :class:`PreparedRequest ` being sent. 17:36:05 :param stream: (optional) Whether to stream the request content. 17:36:05 :param timeout: (optional) How long to wait for the server to send 17:36:05 data before giving up, as a float, or a :ref:`(connect timeout, 17:36:05 read timeout) ` tuple. 17:36:05 :type timeout: float or tuple or urllib3 Timeout object 17:36:05 :param verify: (optional) Either a boolean, in which case it controls whether 17:36:05 we verify the server's TLS certificate, or a string, in which case it 17:36:05 must be a path to a CA bundle to use 17:36:05 :param cert: (optional) Any user-provided SSL certificate to be trusted. 17:36:05 :param proxies: (optional) The proxies dictionary to apply to the request. 17:36:05 :rtype: requests.Response 17:36:05 """ 17:36:05 17:36:05 try: 17:36:05 conn = self.get_connection_with_tls_context( 17:36:05 request, verify, proxies=proxies, cert=cert 17:36:05 ) 17:36:05 except LocationValueError as e: 17:36:05 raise InvalidURL(e, request=request) 17:36:05 17:36:05 self.cert_verify(conn, request.url, verify, cert) 17:36:05 url = self.request_url(request, proxies) 17:36:05 self.add_headers( 17:36:05 request, 17:36:05 stream=stream, 17:36:05 timeout=timeout, 17:36:05 verify=verify, 17:36:05 cert=cert, 17:36:05 proxies=proxies, 17:36:05 ) 17:36:05 17:36:05 chunked = not (request.body is None or "Content-Length" in request.headers) 17:36:05 17:36:05 if isinstance(timeout, tuple): 17:36:05 try: 17:36:05 connect, read = timeout 17:36:05 timeout = TimeoutSauce(connect=connect, read=read) 17:36:05 except ValueError: 17:36:05 raise ValueError( 17:36:05 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 17:36:05 f"or a single float to set both timeouts to the same value." 17:36:05 ) 17:36:05 elif isinstance(timeout, TimeoutSauce): 17:36:05 pass 17:36:05 else: 17:36:05 timeout = TimeoutSauce(connect=timeout, read=timeout) 17:36:05 17:36:05 try: 17:36:05 resp = conn.urlopen( 17:36:05 method=request.method, 17:36:05 url=url, 17:36:05 body=request.body, 17:36:05 headers=request.headers, 17:36:05 redirect=False, 17:36:05 assert_same_host=False, 17:36:05 preload_content=False, 17:36:05 decode_content=False, 17:36:05 retries=self.max_retries, 17:36:05 timeout=timeout, 17:36:05 chunked=chunked, 17:36:05 ) 17:36:05 17:36:05 except (ProtocolError, OSError) as err: 17:36:05 raise ConnectionError(err, request=request) 17:36:05 17:36:05 except MaxRetryError as e: 17:36:05 if isinstance(e.reason, ConnectTimeoutError): 17:36:05 # TODO: Remove this in 3.0.0: see #2811 17:36:05 if not isinstance(e.reason, NewConnectionError): 17:36:05 raise ConnectTimeout(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, ResponseError): 17:36:05 raise RetryError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _ProxyError): 17:36:05 raise ProxyError(e, request=request) 17:36:05 17:36:05 if isinstance(e.reason, _SSLError): 17:36:05 # This branch is for urllib3 v1.22 and later. 17:36:05 raise SSLError(e, request=request) 17:36:05 17:36:05 > raise ConnectionError(e, request=request) 17:36:05 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=XPDRA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 17:36:05 17:36:05 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_18_xpdr_device_not_connected 17:36:05 _______ TransportPCEPortMappingTesting.test_19_rdm_device_disconnection ________ 17:36:05 17:36:05 self = 17:36:05 17:36:05 def test_19_rdm_device_disconnection(self): 17:36:05 response = test_utils.unmount_device("ROADMA01") 17:36:05 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 17:36:05 E AssertionError: 409 not found in (200, 204) 17:36:05 17:36:05 transportpce_tests/1.2.1/test01_portmapping.py:212: AssertionError 17:36:05 ----------------------------- Captured stdout call ----------------------------- 17:36:05 execution of test_19_rdm_device_disconnection 17:36:05 Searching for pattern 'onDeviceDisConnected:\ ROADMA01' in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not deleted from tpce topology... 17:36:05 =========================== short test summary info ============================ 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_02_rdm_device_connected 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_03_rdm_portmapping_info 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_04_rdm_portmapping_DEG1_TTP_TXRX 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_05_rdm_portmapping_SRG1_PP7_TXRX 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_06_rdm_portmapping_SRG3_PP1_TXRX 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_08_xpdr_device_connected 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_09_xpdr_portmapping_info 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_10_xpdr_portmapping_NETWORK1 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_11_xpdr_portmapping_NETWORK2 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_12_xpdr_portmapping_CLIENT1 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_13_xpdr_portmapping_CLIENT2 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_14_xpdr_portmapping_CLIENT3 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_15_xpdr_portmapping_CLIENT4 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_16_xpdr_device_disconnection 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_17_xpdr_device_disconnected 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_18_xpdr_device_not_connected 17:36:05 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_19_rdm_device_disconnection 17:36:05 17 failed, 4 passed in 778.59s (0:12:58) 17:36:05 tests121: exit 1 (778.82 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=35278 17:36:06 .... [100%] 17:36:13 22 passed in 72.47s (0:01:12) 17:36:14 tests121: FAIL ✖ in 13 minutes 4.64 seconds 17:36:14 tests71: OK ✔ in 6 minutes 53.6 seconds 17:36:14 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 17:36:20 tests221: freeze> python -m pip freeze --all 17:36:20 tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 17:36:20 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 17:36:20 using environment variables from ./karaf221.env 17:36:20 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 17:37:00 ................................... [100%] 17:37:40 35 passed in 80.07s (0:01:20) 17:37:40 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 17:38:21 ...... [100%] 17:38:34 6 passed in 53.71s 17:38:34 pytest -q transportpce_tests/2.2.1/test03_topology.py 17:39:19 ............................................ [100%] 17:40:54 44 passed in 139.65s (0:02:19) 17:40:54 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 17:41:30 ............ [100%] 17:41:54 12 passed in 59.64s 17:41:54 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 17:42:20 ................ [100%] 17:43:49 16 passed in 114.91s (0:01:54) 17:43:49 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 17:44:20 ............................... [100%] 17:44:26 31 passed in 36.65s 17:44:26 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 17:45:02 .......................... [100%] 17:45:57 26 passed in 91.08s (0:01:31) 17:45:57 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 17:46:34 ...................... [100%] 17:47:37 22 passed in 99.82s (0:01:39) 17:47:37 pytest -q transportpce_tests/2.2.1/test09_olm.py 17:48:19 ........................................ [100%] 17:50:40 40 passed in 182.43s (0:03:02) 17:50:40 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 17:51:22 ........................................................................ [ 74%] 17:56:58 ......................... [100%] 17:58:50 97 passed in 489.82s (0:08:09) 17:58:50 pytest -q transportpce_tests/2.2.1/test12_end2end.py 17:59:30 ...................................................... [100%] 18:06:17 54 passed in 447.03s (0:07:27) 18:06:17 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 18:07:13 ........................................................................ [ 71%] 18:12:22 ............................. [100%] 18:17:31 101 passed in 673.18s (0:11:13) 18:17:31 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 18:18:24 ........................................................................ [ 67%] 18:24:10 ................................... [100%] 18:27:31 107 passed in 599.50s (0:09:59) 18:27:31 tests221: OK ✔ in 51 minutes 17.02 seconds 18:27:31 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 18:27:52 tests_hybrid: freeze> python -m pip freeze --all 18:27:53 tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 18:27:53 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 18:27:53 using environment variables from ./karaf121.env 18:27:53 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 18:28:38 ................................................... [100%] 18:33:24 51 passed in 330.74s (0:05:30) 18:33:24 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 18:34:05 ........................................................................ [ 66%] 18:38:25 ..................................... [100%] 18:43:31 109 passed in 607.23s (0:10:07) 18:43:31 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 18:44:19 ..................................................... [100%] 18:47:50 53 passed in 258.80s (0:04:18) 18:47:50 tests_hybrid: OK ✔ in 20 minutes 19.7 seconds 18:47:50 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 18:47:56 buildlighty: freeze> python -m pip freeze --all 18:47:56 buildlighty: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.3.2,cryptography==43.0.1,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.0.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.1.0,urllib3==2.2.3,wheel==0.44.0 18:47:56 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 18:47:56 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 18:48:11 [ERROR] COMPILATION ERROR : 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 18:48:11 symbol: class YangModuleInfo 18:48:11 location: package org.opendaylight.yangtools.binding 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 18:48:11 symbol: class YangModuleInfo 18:48:11 location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 18:48:11 symbol: class YangModuleInfo 18:48:11 location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 18:48:11 symbol: class YangModuleInfo 18:48:11 location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0:compile (default-compile) on project tpce: Compilation failure: Compilation failure: 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 18:48:11 [ERROR] symbol: class YangModuleInfo 18:48:11 [ERROR] location: package org.opendaylight.yangtools.binding 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 18:48:11 [ERROR] symbol: class YangModuleInfo 18:48:11 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 18:48:11 [ERROR] symbol: class YangModuleInfo 18:48:11 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 18:48:11 [ERROR] symbol: class YangModuleInfo 18:48:11 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 18:48:11 [ERROR] -> [Help 1] 18:48:11 [ERROR] 18:48:11 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 18:48:11 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 18:48:11 [ERROR] 18:48:11 [ERROR] For more information about the errors and possible solutions, please read the following articles: 18:48:11 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException 18:48:11 unzip: cannot find or open target/tpce-bin.zip, target/tpce-bin.zip.zip or target/tpce-bin.zip.ZIP. 18:48:11 buildlighty: exit 9 (14.83 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh pid=59487 18:48:11 buildlighty: command failed but is marked ignore outcome so handling it as success 18:48:11 buildcontroller: OK (104.56=setup[8.42]+cmd[96.14] seconds) 18:48:11 testsPCE: OK (315.00=setup[67.28]+cmd[247.72] seconds) 18:48:11 sims: OK (11.33=setup[7.41]+cmd[3.92] seconds) 18:48:11 build_karaf_tests121: OK (55.04=setup[7.44]+cmd[47.60] seconds) 18:48:11 tests121: FAIL code 1 (784.64=setup[5.82]+cmd[778.82] seconds) 18:48:11 build_karaf_tests221: OK (56.28=setup[7.38]+cmd[48.90] seconds) 18:48:11 tests_tapi: FAIL code 1 (638.43=setup[10.45]+cmd[627.99] seconds) 18:48:11 tests221: OK (3077.02=setup[6.46]+cmd[3070.56] seconds) 18:48:11 build_karaf_tests71: OK (57.12=setup[13.92]+cmd[43.20] seconds) 18:48:11 tests71: OK (413.60=setup[6.24]+cmd[407.36] seconds) 18:48:11 build_karaf_tests_hybrid: OK (60.04=setup[11.52]+cmd[48.53] seconds) 18:48:11 tests_hybrid: OK (1219.70=setup[22.24]+cmd[1197.46] seconds) 18:48:11 buildlighty: OK (20.55=setup[5.72]+cmd[14.83] seconds) 18:48:11 docs: OK (31.90=setup[29.37]+cmd[2.54] seconds) 18:48:11 docs-linkcheck: OK (35.58=setup[31.96]+cmd[3.63] seconds) 18:48:11 checkbashisms: OK (3.07=setup[2.03]+cmd[0.02,0.09,0.93] seconds) 18:48:11 pre-commit: OK (43.98=setup[3.56]+cmd[0.00,0.00,33.45,6.97] seconds) 18:48:11 pylint: OK (25.82=setup[4.66]+cmd[21.17] seconds) 18:48:11 evaluation failed :( (5530.22 seconds) 18:48:11 + tox_status=255 18:48:11 + echo '---> Completed tox runs' 18:48:11 ---> Completed tox runs 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/build_karaf_tests121/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=build_karaf_tests121 18:48:11 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/build_karaf_tests221/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=build_karaf_tests221 18:48:11 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/build_karaf_tests71/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=build_karaf_tests71 18:48:11 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/build_karaf_tests_hybrid/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=build_karaf_tests_hybrid 18:48:11 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/buildcontroller/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=buildcontroller 18:48:11 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/buildlighty/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=buildlighty 18:48:11 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/checkbashisms/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=checkbashisms 18:48:11 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/docs-linkcheck/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=docs-linkcheck 18:48:11 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/docs/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=docs 18:48:11 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/pre-commit/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=pre-commit 18:48:11 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/pylint/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=pylint 18:48:11 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/sims/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=sims 18:48:11 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/tests121/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=tests121 18:48:11 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/tests221/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=tests221 18:48:11 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/tests71/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=tests71 18:48:11 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 18:48:11 + for i in .tox/*/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 ++ echo .tox/testsPCE/log 18:48:11 + tox_env=testsPCE 18:48:11 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/tests_hybrid/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=tests_hybrid 18:48:11 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 18:48:11 + for i in .tox/*/log 18:48:11 ++ echo .tox/tests_tapi/log 18:48:11 ++ awk -F/ '{print $2}' 18:48:11 + tox_env=tests_tapi 18:48:11 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 18:48:11 + DOC_DIR=docs/_build/html 18:48:11 + [[ -d docs/_build/html ]] 18:48:11 + echo '---> Archiving generated docs' 18:48:11 ---> Archiving generated docs 18:48:11 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 18:48:11 + echo '---> tox-run.sh ends' 18:48:11 ---> tox-run.sh ends 18:48:11 + test 255 -eq 0 18:48:11 + exit 255 18:48:11 ++ '[' 1 = 1 ']' 18:48:11 ++ '[' -x /usr/bin/clear_console ']' 18:48:11 ++ /usr/bin/clear_console -q 18:48:11 Build step 'Execute shell' marked build as failure 18:48:11 $ ssh-agent -k 18:48:11 unset SSH_AUTH_SOCK; 18:48:11 unset SSH_AGENT_PID; 18:48:11 echo Agent pid 13150 killed; 18:48:11 [ssh-agent] Stopped. 18:48:11 [PostBuildScript] - [INFO] Executing post build scripts. 18:48:11 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10463951966685254959.sh 18:48:11 ---> sysstat.sh 18:48:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13998216912746109540.sh 18:48:12 ---> package-listing.sh 18:48:12 ++ facter osfamily 18:48:12 ++ tr '[:upper:]' '[:lower:]' 18:48:13 + OS_FAMILY=debian 18:48:13 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 18:48:13 + START_PACKAGES=/tmp/packages_start.txt 18:48:13 + END_PACKAGES=/tmp/packages_end.txt 18:48:13 + DIFF_PACKAGES=/tmp/packages_diff.txt 18:48:13 + PACKAGES=/tmp/packages_start.txt 18:48:13 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 18:48:13 + PACKAGES=/tmp/packages_end.txt 18:48:13 + case "${OS_FAMILY}" in 18:48:13 + dpkg -l 18:48:13 + grep '^ii' 18:48:13 + '[' -f /tmp/packages_start.txt ']' 18:48:13 + '[' -f /tmp/packages_end.txt ']' 18:48:13 + diff /tmp/packages_start.txt /tmp/packages_end.txt 18:48:13 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 18:48:13 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 18:48:13 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 18:48:13 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6740359029949824475.sh 18:48:13 ---> capture-instance-metadata.sh 18:48:13 Setup pyenv: 18:48:13 system 18:48:13 3.8.13 18:48:13 3.9.13 18:48:13 3.10.13 18:48:13 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:48:13 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-4M4o from file:/tmp/.os_lf_venv 18:48:14 lf-activate-venv(): INFO: Installing: lftools 18:48:23 lf-activate-venv(): INFO: Adding /tmp/venv-4M4o/bin to PATH 18:48:23 INFO: Running in OpenStack, capturing instance metadata 18:48:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16783453681373978984.sh 18:48:23 provisioning config files... 18:48:23 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #2040 18:48:23 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config17111576236324417093tmp 18:48:23 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 18:48:23 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 18:48:23 provisioning config files... 18:48:24 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 18:48:24 [EnvInject] - Injecting environment variables from a build step. 18:48:24 [EnvInject] - Injecting as environment variables the properties content 18:48:24 SERVER_ID=logs 18:48:24 18:48:24 [EnvInject] - Variables injected successfully. 18:48:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15647107045485143877.sh 18:48:24 ---> create-netrc.sh 18:48:24 WARN: Log server credential not found. 18:48:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15934946872740663152.sh 18:48:24 ---> python-tools-install.sh 18:48:24 Setup pyenv: 18:48:24 system 18:48:24 3.8.13 18:48:24 3.9.13 18:48:24 3.10.13 18:48:24 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:48:24 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-4M4o from file:/tmp/.os_lf_venv 18:48:25 lf-activate-venv(): INFO: Installing: lftools 18:48:34 lf-activate-venv(): INFO: Adding /tmp/venv-4M4o/bin to PATH 18:48:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8673786716619742551.sh 18:48:34 ---> sudo-logs.sh 18:48:34 Archiving 'sudo' log.. 18:48:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1397623186579839948.sh 18:48:34 ---> job-cost.sh 18:48:34 Setup pyenv: 18:48:34 system 18:48:34 3.8.13 18:48:34 3.9.13 18:48:34 3.10.13 18:48:34 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:48:34 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-4M4o from file:/tmp/.os_lf_venv 18:48:35 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 18:48:40 lf-activate-venv(): INFO: Adding /tmp/venv-4M4o/bin to PATH 18:48:40 INFO: No Stack... 18:48:40 INFO: Retrieving Pricing Info for: v3-standard-4 18:48:41 INFO: Archiving Costs 18:48:41 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins2180191036489452821.sh 18:48:41 ---> logs-deploy.sh 18:48:41 Setup pyenv: 18:48:41 system 18:48:41 3.8.13 18:48:41 3.9.13 18:48:41 3.10.13 18:48:41 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:48:41 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-4M4o from file:/tmp/.os_lf_venv 18:48:42 lf-activate-venv(): INFO: Installing: lftools 18:48:51 lf-activate-venv(): INFO: Adding /tmp/venv-4M4o/bin to PATH 18:48:51 WARNING: Nexus logging server not set 18:48:51 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/2040/ 18:48:51 INFO: archiving logs to S3 18:48:53 ---> uname -a: 18:48:53 Linux prd-ubuntu2004-docker-4c-16g-40238 5.4.0-190-generic #210-Ubuntu SMP Fri Jul 5 17:03:38 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 18:48:53 18:48:53 18:48:53 ---> lscpu: 18:48:53 Architecture: x86_64 18:48:53 CPU op-mode(s): 32-bit, 64-bit 18:48:53 Byte Order: Little Endian 18:48:53 Address sizes: 40 bits physical, 48 bits virtual 18:48:53 CPU(s): 4 18:48:53 On-line CPU(s) list: 0-3 18:48:53 Thread(s) per core: 1 18:48:53 Core(s) per socket: 1 18:48:53 Socket(s): 4 18:48:53 NUMA node(s): 1 18:48:53 Vendor ID: AuthenticAMD 18:48:53 CPU family: 23 18:48:53 Model: 49 18:48:53 Model name: AMD EPYC-Rome Processor 18:48:53 Stepping: 0 18:48:53 CPU MHz: 2799.998 18:48:53 BogoMIPS: 5599.99 18:48:53 Virtualization: AMD-V 18:48:53 Hypervisor vendor: KVM 18:48:53 Virtualization type: full 18:48:53 L1d cache: 128 KiB 18:48:53 L1i cache: 128 KiB 18:48:53 L2 cache: 2 MiB 18:48:53 L3 cache: 64 MiB 18:48:53 NUMA node0 CPU(s): 0-3 18:48:53 Vulnerability Gather data sampling: Not affected 18:48:53 Vulnerability Itlb multihit: Not affected 18:48:53 Vulnerability L1tf: Not affected 18:48:53 Vulnerability Mds: Not affected 18:48:53 Vulnerability Meltdown: Not affected 18:48:53 Vulnerability Mmio stale data: Not affected 18:48:53 Vulnerability Retbleed: Vulnerable 18:48:53 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 18:48:53 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 18:48:53 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 18:48:53 Vulnerability Srbds: Not affected 18:48:53 Vulnerability Tsx async abort: Not affected 18:48:53 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 18:48:53 18:48:53 18:48:53 ---> nproc: 18:48:53 4 18:48:53 18:48:53 18:48:53 ---> df -h: 18:48:53 Filesystem Size Used Avail Use% Mounted on 18:48:53 udev 7.8G 0 7.8G 0% /dev 18:48:53 tmpfs 1.6G 1.1M 1.6G 1% /run 18:48:53 /dev/vda1 78G 17G 62G 21% / 18:48:53 tmpfs 7.9G 0 7.9G 0% /dev/shm 18:48:53 tmpfs 5.0M 0 5.0M 0% /run/lock 18:48:53 tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup 18:48:53 /dev/loop0 62M 62M 0 100% /snap/core20/1405 18:48:53 /dev/loop1 68M 68M 0 100% /snap/lxd/22753 18:48:53 /dev/vda15 105M 6.1M 99M 6% /boot/efi 18:48:53 tmpfs 1.6G 0 1.6G 0% /run/user/1001 18:48:53 /dev/loop3 39M 39M 0 100% /snap/snapd/21759 18:48:53 /dev/loop4 92M 92M 0 100% /snap/lxd/29619 18:48:53 18:48:53 18:48:53 ---> free -m: 18:48:53 total used free shared buff/cache available 18:48:53 Mem: 15997 679 7023 1 8293 14978 18:48:53 Swap: 1023 0 1023 18:48:53 18:48:53 18:48:53 ---> ip addr: 18:48:53 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 18:48:53 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 18:48:53 inet 127.0.0.1/8 scope host lo 18:48:53 valid_lft forever preferred_lft forever 18:48:53 inet6 ::1/128 scope host 18:48:53 valid_lft forever preferred_lft forever 18:48:53 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 18:48:53 link/ether fa:16:3e:5e:d1:72 brd ff:ff:ff:ff:ff:ff 18:48:53 inet 10.30.171.202/23 brd 10.30.171.255 scope global dynamic ens3 18:48:53 valid_lft 80705sec preferred_lft 80705sec 18:48:53 inet6 fe80::f816:3eff:fe5e:d172/64 scope link 18:48:53 valid_lft forever preferred_lft forever 18:48:53 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 18:48:53 link/ether 02:42:13:6c:9c:3b brd ff:ff:ff:ff:ff:ff 18:48:53 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 18:48:53 valid_lft forever preferred_lft forever 18:48:53 18:48:53 18:48:53 ---> sar -b -r -n DEV: 18:48:53 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-40238) 10/07/24 _x86_64_ (4 CPU) 18:48:53 18:48:53 17:14:00 LINUX RESTART (4 CPU) 18:48:53 18:48:53 17:15:02 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 18:48:53 17:16:01 118.10 35.59 82.51 0.00 1276.12 11211.95 0.00 18:48:53 17:17:01 253.49 41.09 212.40 0.00 2729.95 52425.53 0.00 18:48:53 17:18:01 61.16 1.63 59.53 0.00 88.90 24654.58 0.00 18:48:53 17:19:01 181.06 7.63 173.43 0.00 259.20 152666.20 0.00 18:48:53 17:20:01 227.31 7.71 219.59 0.00 2707.36 69143.75 0.00 18:48:53 17:21:01 61.76 2.12 59.65 0.00 72.38 1098.30 0.00 18:48:53 17:22:01 138.44 1.92 136.53 0.00 209.43 2385.34 0.00 18:48:53 17:23:01 70.65 0.08 70.57 0.00 3.47 1077.55 0.00 18:48:53 17:24:01 68.56 3.08 65.47 0.00 505.38 9359.24 0.00 18:48:53 17:25:01 2.37 0.00 2.37 0.00 0.00 42.53 0.00 18:48:53 17:26:01 15.88 0.20 15.68 0.00 15.86 359.75 0.00 18:48:53 17:27:01 96.17 0.20 95.97 0.00 4.40 2113.91 0.00 18:48:53 17:28:01 2.13 0.00 2.13 0.00 0.00 49.99 0.00 18:48:53 17:29:01 2.38 0.00 2.38 0.00 0.00 37.46 0.00 18:48:53 17:30:01 91.72 1.25 90.47 0.00 49.33 4960.37 0.00 18:48:53 17:31:01 78.02 0.00 78.02 0.00 0.00 6103.92 0.00 18:48:53 17:32:01 1.95 0.00 1.95 0.00 0.00 39.19 0.00 18:48:53 17:33:01 65.38 0.00 65.38 0.00 0.00 952.08 0.00 18:48:53 17:34:01 2.58 0.00 2.58 0.00 0.00 52.52 0.00 18:48:53 17:35:01 2.25 0.00 2.25 0.00 0.00 43.73 0.00 18:48:53 17:36:01 79.25 0.00 79.25 0.00 0.00 1145.41 0.00 18:48:53 17:37:01 32.66 0.00 32.66 0.00 0.00 2671.02 0.00 18:48:53 17:38:01 16.54 0.00 16.54 0.00 0.00 302.83 0.00 18:48:53 17:39:01 36.51 0.00 36.51 0.00 0.00 511.65 0.00 18:48:53 17:40:01 7.17 0.00 7.17 0.00 0.00 128.65 0.00 18:48:53 17:41:01 15.51 0.00 15.51 0.00 0.00 257.69 0.00 18:48:53 17:42:01 50.96 0.00 50.96 0.00 0.00 740.96 0.00 18:48:53 17:43:01 11.50 0.00 11.50 0.00 0.00 186.24 0.00 18:48:53 17:44:01 15.66 0.00 15.66 0.00 0.00 257.16 0.00 18:48:53 17:45:01 100.98 0.00 100.98 0.00 0.00 1418.99 0.00 18:48:53 17:46:01 15.23 0.00 15.23 0.00 0.00 251.96 0.00 18:48:53 17:47:01 51.92 0.00 51.92 0.00 0.00 722.95 0.00 18:48:53 17:48:01 16.53 0.00 16.53 0.00 0.00 278.57 0.00 18:48:53 17:49:01 53.62 0.00 53.62 0.00 0.00 742.28 0.00 18:48:53 17:50:01 2.33 0.00 2.33 0.00 0.00 48.66 0.00 18:48:53 17:51:01 17.15 0.00 17.15 0.00 0.00 287.42 0.00 18:48:53 17:52:01 61.81 0.00 61.81 0.00 0.00 847.86 0.00 18:48:53 17:53:01 2.47 0.00 2.47 0.00 0.00 43.99 0.00 18:48:53 17:54:01 1.95 0.00 1.95 0.00 0.00 34.39 0.00 18:48:53 17:55:01 3.02 0.00 3.02 0.00 0.00 58.39 0.00 18:48:53 17:56:01 2.13 0.00 2.13 0.00 0.00 45.86 0.00 18:48:53 17:57:01 2.73 0.00 2.73 0.00 0.00 45.73 0.00 18:48:53 17:58:01 2.00 0.00 2.00 0.00 0.00 34.93 0.00 18:48:53 17:59:01 16.64 0.00 16.64 0.00 0.00 285.77 0.00 18:48:53 18:00:01 51.75 0.00 51.75 0.00 0.00 728.42 0.00 18:48:53 18:01:01 2.80 0.00 2.80 0.00 0.00 60.11 0.00 18:48:53 18:02:01 2.23 0.00 2.23 0.00 0.00 51.07 0.00 18:48:53 18:03:01 1.68 0.00 1.68 0.00 0.00 42.13 0.00 18:48:53 18:04:01 1.82 0.00 1.82 0.00 0.00 42.53 0.00 18:48:53 18:05:01 2.98 0.00 2.98 0.00 0.00 68.92 0.00 18:48:53 18:06:01 2.52 0.00 2.52 0.00 0.00 63.99 0.00 18:48:53 18:07:01 27.81 0.00 27.81 0.00 0.00 448.38 0.00 18:48:53 18:08:01 59.24 0.00 59.24 0.00 0.00 798.93 0.00 18:48:53 18:09:01 3.60 0.00 3.60 0.00 0.00 73.32 0.00 18:48:53 18:10:01 2.42 0.00 2.42 0.00 0.00 50.26 0.00 18:48:53 18:11:01 3.85 0.00 3.85 0.00 0.00 68.52 0.00 18:48:53 18:12:01 2.77 0.00 2.77 0.00 0.00 53.99 0.00 18:48:53 18:13:01 2.55 0.00 2.55 0.00 0.00 38.39 0.00 18:48:53 18:14:01 1.77 0.00 1.77 0.00 0.00 23.86 0.00 18:48:53 18:15:01 2.33 0.00 2.33 0.00 0.00 31.99 0.00 18:48:53 18:16:01 2.55 0.00 2.55 0.00 0.00 49.99 0.00 18:48:53 18:17:01 3.03 0.03 3.00 0.00 0.93 52.65 0.00 18:48:53 18:18:01 28.72 0.00 28.72 0.00 0.00 553.73 0.00 18:48:53 18:19:01 56.26 0.00 56.26 0.00 0.00 768.81 0.00 18:48:53 18:20:01 2.07 0.00 2.07 0.00 0.00 49.58 0.00 18:48:53 18:21:01 2.17 0.00 2.17 0.00 0.00 47.86 0.00 18:48:53 18:22:01 1.82 0.00 1.82 0.00 0.00 34.13 0.00 18:48:53 18:23:01 2.37 0.00 2.37 0.00 0.00 40.39 0.00 18:48:53 18:24:01 1.97 0.00 1.97 0.00 0.00 38.66 0.00 18:48:53 18:25:01 2.25 0.00 2.25 0.00 0.00 42.66 0.00 18:48:53 18:26:01 1.83 0.00 1.83 0.00 0.00 32.93 0.00 18:48:53 18:27:01 2.27 0.00 2.27 0.00 0.00 52.26 0.00 18:48:53 18:28:01 13.41 0.02 13.40 0.00 0.13 1366.04 0.00 18:48:53 18:29:01 102.45 0.00 102.45 0.00 0.00 8826.53 0.00 18:48:53 18:30:01 3.53 0.00 3.53 0.00 0.00 121.31 0.00 18:48:53 18:31:01 2.58 0.00 2.58 0.00 0.00 35.46 0.00 18:48:53 18:32:01 1.50 0.00 1.50 0.00 0.00 19.60 0.00 18:48:53 18:33:01 2.12 0.00 2.12 0.00 0.00 28.53 0.00 18:48:53 18:34:01 26.90 0.00 26.90 0.00 0.00 638.96 0.00 18:48:53 18:35:01 54.72 0.00 54.72 0.00 0.00 772.54 0.00 18:48:53 18:36:01 2.08 0.00 2.08 0.00 0.00 41.06 0.00 18:48:53 18:37:01 1.70 0.00 1.70 0.00 0.00 33.33 0.00 18:48:53 18:38:01 1.58 0.00 1.58 0.00 0.00 28.26 0.00 18:48:53 18:39:01 2.12 0.00 2.12 0.00 0.00 52.12 0.00 18:48:53 18:40:01 1.85 0.00 1.85 0.00 0.00 33.59 0.00 18:48:53 18:41:01 1.70 0.00 1.70 0.00 0.00 35.86 0.00 18:48:53 18:42:01 1.68 0.00 1.68 0.00 0.00 21.73 0.00 18:48:53 18:43:01 1.75 0.00 1.75 0.00 0.00 23.86 0.00 18:48:53 18:44:01 24.45 0.00 24.45 0.00 0.00 685.75 0.00 18:48:53 18:45:01 51.72 0.00 51.72 0.00 0.00 846.26 0.00 18:48:53 18:46:01 1.88 0.00 1.88 0.00 0.00 37.33 0.00 18:48:53 18:47:01 2.02 0.00 2.02 0.00 0.00 70.39 0.00 18:48:53 18:48:01 9.57 3.23 6.33 0.00 65.32 362.74 0.00 18:48:53 Average: 29.53 1.13 28.40 0.00 85.70 3963.52 0.00 18:48:53 18:48:53 17:15:02 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 18:48:53 17:16:01 13247788 15446176 527468 3.22 77328 2309172 1394492 8.00 805500 2038532 154476 18:48:53 17:17:01 10408956 14261792 1697800 10.36 137760 3780612 2439824 14.00 2179588 3361796 267012 18:48:53 17:18:01 8794244 14303704 1655472 10.11 163344 5334864 2524784 14.49 2469340 4610132 1185320 18:48:53 17:19:01 6264680 14484200 1473068 8.99 203396 7885840 2416596 13.86 3171064 6315820 529912 18:48:53 17:20:01 4625404 13973376 1972820 12.04 226712 8951148 2784912 15.98 4139548 6929356 2224 18:48:53 17:21:01 162856 8917832 7025952 42.89 221328 8375660 8188700 46.98 9075356 6448624 164 18:48:53 17:22:01 255596 8733608 7209568 44.01 227084 8095664 8532300 48.95 9267676 6166128 1400 18:48:53 17:23:01 993252 9472868 6470128 39.50 230320 8092664 7467444 42.84 8529260 6168060 16816 18:48:53 17:24:01 174536 7469492 8472836 51.72 235836 6920064 9649916 55.36 10457976 5067332 640 18:48:53 17:25:01 174332 7469340 8472924 51.72 235864 6920072 9649916 55.36 10457824 5066980 120 18:48:53 17:26:01 5550152 12845668 3098976 18.92 235924 6920476 4116876 23.62 5111468 5058816 568 18:48:53 17:27:01 2486112 9785588 6157992 37.59 239072 6921244 7304812 41.91 8168388 5055936 644 18:48:53 17:28:01 2153352 9452996 6490412 39.62 239100 6921384 7402812 42.47 8500156 5055924 128 18:48:53 17:29:01 2150212 9449948 6493452 39.64 239124 6921460 7402812 42.47 8504068 5055832 168 18:48:53 17:30:01 4049140 11591188 4353332 26.57 246964 7149048 5231420 30.01 6446564 5212652 146876 18:48:53 17:31:01 4158144 11702460 4242148 25.90 248760 7149404 5156608 29.58 6360148 5191064 116 18:48:53 17:32:01 4139896 11684400 4260176 26.01 248800 7149556 5156608 29.58 6378556 5191176 96 18:48:53 17:33:01 4623364 12169508 3775232 23.05 250260 7149644 5056420 29.01 5909564 5179656 452 18:48:53 17:34:01 3357860 10904340 5040024 30.77 250284 7149936 5938396 34.07 7169604 5179764 96 18:48:53 17:35:01 5712456 13258908 2685576 16.39 250304 7149888 3957640 22.71 4824576 5179160 132 18:48:53 17:36:01 4145060 11693464 4251076 25.95 251828 7150252 5170424 29.66 6386244 5179512 112 18:48:53 17:37:01 4935108 12550396 3395324 20.73 254212 7210660 4385312 25.16 5539004 5237908 988 18:48:53 17:38:01 6976056 14591576 1355164 8.27 254268 7210832 2099680 12.05 3511256 5232972 172 18:48:53 17:39:01 5735576 13351920 2593636 15.83 254428 7211428 4141568 23.76 4753224 5224612 680 18:48:53 17:40:01 4262200 11878860 4065976 24.82 254552 7211624 5028956 28.85 6221872 5224804 56 18:48:53 17:41:01 7274536 14891336 1055304 6.44 254588 7211724 1867764 10.72 3222520 5224584 364 18:48:53 17:42:01 7300760 14918588 1028204 6.28 255280 7212040 1824448 10.47 3196552 5224648 340 18:48:53 17:43:01 6202028 13820400 2125712 12.98 255536 7212324 2902508 16.65 4289180 5224932 140 18:48:53 17:44:01 7013848 14632368 1314280 8.02 255572 7212436 2102644 12.06 3481676 5224760 652 18:48:53 17:45:01 6199036 13819712 2126380 12.98 257056 7213104 2926656 16.79 4290180 5225084 128 18:48:53 17:46:01 7442512 15063248 883592 5.39 257072 7213140 1713176 9.83 3053988 5224892 296 18:48:53 17:47:01 5362624 12984584 2960820 18.07 257760 7213660 3725276 21.37 5124404 5225372 152 18:48:53 17:48:01 5922664 13544936 2400796 14.66 257784 7213916 3500540 20.08 4567664 5225388 636 18:48:53 17:49:01 3886524 11510488 4434108 27.07 259020 7214332 5250912 30.13 6593040 5225788 280 18:48:53 17:50:01 3851764 11476032 4468564 27.28 259036 7214600 5282936 30.31 6628448 5226044 212 18:48:53 17:51:01 6022572 13647160 2298572 14.03 259072 7214876 3490376 20.03 4466980 5226216 696 18:48:53 17:52:01 3906272 11531952 4412500 26.94 259620 7215412 5180308 29.72 6574364 5226512 224 18:48:53 17:53:01 3893264 11519052 4425372 27.01 259636 7215496 5180308 29.72 6586096 5226588 124 18:48:53 17:54:01 3872868 11498876 4445536 27.14 259652 7215696 5180308 29.72 6606364 5226780 428 18:48:53 17:55:01 3853384 11479676 4464656 27.25 259676 7215956 5196320 29.81 6624664 5227040 28 18:48:53 17:56:01 3843824 11470460 4473864 27.31 259728 7216252 5196320 29.81 6634424 5227336 112 18:48:53 17:57:01 3838744 11465604 4478728 27.34 259756 7216436 5196320 29.81 6638732 5227516 116 18:48:53 17:58:01 3795936 11423084 4521176 27.60 259780 7216716 5261668 30.19 6680168 5227780 108 18:48:53 17:59:01 7101912 14729420 1216892 7.43 259816 7217020 2019376 11.59 3390552 5228040 692 18:48:53 18:00:01 3936520 11564996 4379292 26.73 260376 7217408 5177636 29.71 6541204 5228420 276 18:48:53 18:01:01 3925212 11554016 4390192 26.80 260384 7217732 5193628 29.80 6551600 5228740 108 18:48:53 18:02:01 3895028 11524484 4419812 26.98 260392 7218388 5209668 29.89 6581440 5229380 360 18:48:53 18:03:01 3883924 11513764 4430520 27.05 260396 7218748 5209668 29.89 6591144 5229760 244 18:48:53 18:04:01 3862528 11492788 4451452 27.17 260396 7219180 5225692 29.98 6612772 5230180 244 18:48:53 18:05:01 3841808 11472716 4471600 27.30 260396 7219816 5241768 30.07 6633940 5230828 428 18:48:53 18:06:01 3795912 11427576 4516652 27.57 260408 7220580 5241768 30.07 6678528 5231572 392 18:48:53 18:07:01 4044472 11676060 4268540 26.06 260540 7220300 5557536 31.89 6432340 5231292 216 18:48:53 18:08:01 2673280 10305372 5638544 34.42 260948 7220388 6474340 37.14 7799756 5231372 372 18:48:53 18:09:01 2502144 10134676 5809032 35.46 260952 7220824 6588752 37.80 7969808 5231804 360 18:48:53 18:10:01 2432324 10065148 5878444 35.88 260952 7221116 6638276 38.09 8039752 5232096 380 18:48:53 18:11:01 2406460 10039584 5903932 36.04 260960 7221416 6654312 38.18 8063988 5232384 68 18:48:53 18:12:01 2372432 10005936 5937540 36.25 260964 7221780 6702376 38.45 8097628 5232760 56 18:48:53 18:13:01 2370140 10003676 5939740 36.26 260972 7221804 6702376 38.45 8099760 5232784 108 18:48:53 18:14:01 2369732 10003276 5940108 36.26 260992 7221800 6702376 38.45 8099348 5232784 112 18:48:53 18:15:01 2369440 10003012 5940460 36.26 261004 7221808 6702376 38.45 8099540 5232792 300 18:48:53 18:16:01 2343356 9977204 5966176 36.42 261016 7222104 6702376 38.45 8125776 5233048 272 18:48:53 18:17:01 2333756 9967868 5975476 36.48 261028 7222332 6702376 38.45 8133776 5233296 304 18:48:53 18:18:01 5201652 12836024 3109128 18.98 261180 7222344 4200020 24.10 5277848 5233296 260 18:48:53 18:19:01 2645888 10281384 5662308 34.57 262052 7222576 6510756 37.35 7825640 5233520 188 18:48:53 18:20:01 2467672 10103620 5839800 35.65 262076 7223004 6625440 38.01 8001268 5233952 488 18:48:53 18:21:01 2381660 10018020 5925320 36.17 262084 7223412 6657956 38.20 8087428 5234356 136 18:48:53 18:22:01 2371116 10007592 5935752 36.23 262092 7223516 6657956 38.20 8097928 5234460 324 18:48:53 18:23:01 2350128 9986820 5956416 36.36 262096 7223728 6673944 38.29 8117324 5234672 212 18:48:53 18:24:01 2339732 9976584 5966644 36.42 262100 7223884 6673944 38.29 8127720 5234828 324 18:48:53 18:25:01 2324980 9962104 5981160 36.51 262104 7224152 6689944 38.38 8141164 5235100 456 18:48:53 18:26:01 2320908 9958140 5985116 36.54 262104 7224264 6689944 38.38 8145120 5235200 408 18:48:53 18:27:01 2275800 9913420 6029788 36.81 262108 7224652 6739944 38.67 8189940 5235588 152 18:48:53 18:28:01 6710160 14583216 1362892 8.32 268008 7445892 2188944 12.56 3569360 5432092 205688 18:48:53 18:29:01 3636080 11515808 4428104 27.03 268760 7451472 5243932 30.09 6655460 5404568 1780 18:48:53 18:30:01 3514520 11394544 4549344 27.77 268760 7451760 5345784 30.67 6776636 5404492 288 18:48:53 18:31:01 3513740 11393772 4550112 27.78 268760 7451768 5345784 30.67 6777716 5404472 52 18:48:53 18:32:01 3513332 11393364 4550512 27.78 268760 7451768 5345784 30.67 6777284 5404472 80 18:48:53 18:33:01 3513144 11393184 4550676 27.78 268764 7451772 5345784 30.67 6777736 5404476 56 18:48:53 18:34:01 4087292 11967580 3976884 24.28 268848 7451772 4958060 28.45 6227768 5385212 340 18:48:53 18:35:01 3648028 11529068 4414816 26.95 269168 7452204 5187016 29.76 6666412 5382912 316 18:48:53 18:36:01 3640688 11521912 4421956 26.99 269168 7452400 5219076 29.94 6673108 5383032 88 18:48:53 18:37:01 3622504 11503920 4439956 27.10 269168 7452576 5219076 29.94 6690760 5383216 128 18:48:53 18:38:01 3616488 11498100 4445768 27.14 269176 7452760 5219076 29.94 6695984 5383400 184 18:48:53 18:39:01 3576796 11458956 4484772 27.38 269184 7453296 5236236 30.04 6735548 5383912 340 18:48:53 18:40:01 3570132 11452640 4491076 27.42 269192 7453632 5236236 30.04 6741000 5384244 620 18:48:53 18:41:01 3569308 11451916 4491808 27.42 269196 7453716 5236236 30.04 6741624 5384332 156 18:48:53 18:42:01 3569624 11452240 4491464 27.42 269204 7453716 5236236 30.04 6740956 5384332 80 18:48:53 18:43:01 3590320 11472944 4470728 27.29 269204 7453724 5216064 29.93 6721624 5384340 100 18:48:53 18:44:01 4943364 12825816 3118948 19.04 269344 7453444 4230912 24.27 5387560 5372648 416 18:48:53 18:45:01 2899504 10782824 5160596 31.50 269800 7453784 5964308 34.22 7423224 5372836 456 18:48:53 18:46:01 2850960 10734800 5208564 31.80 269812 7454288 5964308 34.22 7469864 5373268 536 18:48:53 18:47:01 2787408 10672048 5271244 32.18 269820 7455068 5980328 34.31 7531368 5374044 236 18:48:53 18:48:01 7189288 15151024 794796 4.85 272756 7521844 1619000 9.29 3078392 5436620 68576 18:48:53 Average: 4018517 11610711 4334361 26.46 253228 7194553 5192287 29.79 6440975 5254420 27991 18:48:53 18:48:53 17:15:02 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 18:48:53 17:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:16:01 lo 0.81 0.81 0.08 0.08 0.00 0.00 0.00 0.00 18:48:53 17:16:01 ens3 65.73 55.80 637.23 9.10 0.00 0.00 0.00 0.00 18:48:53 17:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:17:01 lo 6.07 6.07 0.61 0.61 0.00 0.00 0.00 0.00 18:48:53 17:17:01 ens3 479.09 405.22 7748.14 42.02 0.00 0.00 0.00 0.00 18:48:53 17:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:18:01 lo 0.87 0.87 0.09 0.09 0.00 0.00 0.00 0.00 18:48:53 17:18:01 ens3 334.14 264.38 5645.45 26.64 0.00 0.00 0.00 0.00 18:48:53 17:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:19:01 lo 1.00 1.00 0.10 0.10 0.00 0.00 0.00 0.00 18:48:53 17:19:01 ens3 74.88 37.08 1770.01 5.55 0.00 0.00 0.00 0.00 18:48:53 17:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:20:01 lo 5.05 5.05 1.23 1.23 0.00 0.00 0.00 0.00 18:48:53 17:20:01 ens3 144.30 42.17 2062.50 3.22 0.00 0.00 0.00 0.00 18:48:53 17:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:21:01 lo 26.81 26.81 29.01 29.01 0.00 0.00 0.00 0.00 18:48:53 17:21:01 ens3 1.62 1.47 0.25 0.26 0.00 0.00 0.00 0.00 18:48:53 17:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:22:01 lo 32.08 32.08 24.67 24.67 0.00 0.00 0.00 0.00 18:48:53 17:22:01 ens3 1.33 1.15 0.24 0.22 0.00 0.00 0.00 0.00 18:48:53 17:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:23:01 lo 35.63 35.63 17.86 17.86 0.00 0.00 0.00 0.00 18:48:53 17:23:01 ens3 1.20 0.95 0.20 0.18 0.00 0.00 0.00 0.00 18:48:53 17:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:24:01 lo 8.18 8.18 6.46 6.46 0.00 0.00 0.00 0.00 18:48:53 17:24:01 ens3 1.45 1.63 0.73 0.64 0.00 0.00 0.00 0.00 18:48:53 17:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:25:01 lo 0.77 0.77 0.07 0.07 0.00 0.00 0.00 0.00 18:48:53 17:25:01 ens3 0.42 0.22 0.15 0.07 0.00 0.00 0.00 0.00 18:48:53 17:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:26:01 lo 2.20 2.20 0.21 0.21 0.00 0.00 0.00 0.00 18:48:53 17:26:01 ens3 0.43 0.30 0.06 0.05 0.00 0.00 0.00 0.00 18:48:53 17:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:27:01 lo 9.57 9.57 12.38 12.38 0.00 0.00 0.00 0.00 18:48:53 17:27:01 ens3 0.73 0.70 0.10 0.10 0.00 0.00 0.00 0.00 18:48:53 17:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:28:01 lo 13.56 13.56 7.89 7.89 0.00 0.00 0.00 0.00 18:48:53 17:28:01 ens3 0.63 0.47 0.11 0.09 0.00 0.00 0.00 0.00 18:48:53 17:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:29:01 lo 2.27 2.27 0.30 0.30 0.00 0.00 0.00 0.00 18:48:53 17:29:01 ens3 0.57 0.38 0.08 0.07 0.00 0.00 0.00 0.00 18:48:53 17:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:30:01 lo 11.01 11.01 15.73 15.73 0.00 0.00 0.00 0.00 18:48:53 17:30:01 ens3 2.78 3.30 1.12 1.15 0.00 0.00 0.00 0.00 18:48:53 17:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:31:01 lo 14.06 14.06 6.93 6.93 0.00 0.00 0.00 0.00 18:48:53 17:31:01 ens3 1.20 1.25 0.22 0.21 0.00 0.00 0.00 0.00 18:48:53 17:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:32:01 lo 28.10 28.10 9.18 9.18 0.00 0.00 0.00 0.00 18:48:53 17:32:01 ens3 2.10 1.40 0.55 0.42 0.00 0.00 0.00 0.00 18:48:53 17:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:33:01 lo 16.81 16.81 4.90 4.90 0.00 0.00 0.00 0.00 18:48:53 17:33:01 ens3 1.73 1.42 0.53 0.45 0.00 0.00 0.00 0.00 18:48:53 17:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:34:01 lo 39.59 39.59 18.77 18.77 0.00 0.00 0.00 0.00 18:48:53 17:34:01 ens3 0.95 0.77 0.17 0.15 0.00 0.00 0.00 0.00 18:48:53 17:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:35:01 lo 22.73 22.73 6.79 6.79 0.00 0.00 0.00 0.00 18:48:53 17:35:01 ens3 1.55 1.20 0.38 0.29 0.00 0.00 0.00 0.00 18:48:53 17:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:36:01 lo 26.36 26.36 11.58 11.58 0.00 0.00 0.00 0.00 18:48:53 17:36:01 ens3 0.90 0.95 0.16 0.15 0.00 0.00 0.00 0.00 18:48:53 17:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:37:01 lo 8.68 8.68 2.77 2.77 0.00 0.00 0.00 0.00 18:48:53 17:37:01 ens3 6.00 6.35 1.76 3.64 0.00 0.00 0.00 0.00 18:48:53 17:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:38:01 lo 11.06 11.06 7.82 7.82 0.00 0.00 0.00 0.00 18:48:53 17:38:01 ens3 1.63 1.37 0.30 0.28 0.00 0.00 0.00 0.00 18:48:53 17:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:39:01 lo 13.56 13.56 4.67 4.67 0.00 0.00 0.00 0.00 18:48:53 17:39:01 ens3 0.83 0.77 0.12 0.11 0.00 0.00 0.00 0.00 18:48:53 17:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:40:01 lo 15.75 15.75 7.94 7.94 0.00 0.00 0.00 0.00 18:48:53 17:40:01 ens3 1.10 0.88 0.30 0.22 0.00 0.00 0.00 0.00 18:48:53 17:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:41:01 lo 16.35 16.35 6.12 6.12 0.00 0.00 0.00 0.00 18:48:53 17:41:01 ens3 1.12 1.02 0.22 0.20 0.00 0.00 0.00 0.00 18:48:53 17:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:42:01 lo 5.55 5.55 6.26 6.26 0.00 0.00 0.00 0.00 18:48:53 17:42:01 ens3 0.82 0.90 0.14 0.15 0.00 0.00 0.00 0.00 18:48:53 17:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:43:01 lo 8.40 8.40 3.12 3.12 0.00 0.00 0.00 0.00 18:48:53 17:43:01 ens3 0.52 0.47 0.07 0.06 0.00 0.00 0.00 0.00 18:48:53 17:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:44:01 lo 3.58 3.58 0.60 0.60 0.00 0.00 0.00 0.00 18:48:53 17:44:01 ens3 0.58 0.68 0.10 0.11 0.00 0.00 0.00 0.00 18:48:53 17:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:45:01 lo 31.31 31.31 14.85 14.85 0.00 0.00 0.00 0.00 18:48:53 17:45:01 ens3 0.87 0.95 0.23 0.18 0.00 0.00 0.00 0.00 18:48:53 17:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:46:01 lo 21.40 21.40 8.90 8.90 0.00 0.00 0.00 0.00 18:48:53 17:46:01 ens3 1.17 1.50 0.23 0.24 0.00 0.00 0.00 0.00 18:48:53 17:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:47:01 lo 13.65 13.65 16.40 16.40 0.00 0.00 0.00 0.00 18:48:53 17:47:01 ens3 0.53 0.58 0.08 0.08 0.00 0.00 0.00 0.00 18:48:53 17:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:48:01 lo 9.85 9.85 4.33 4.33 0.00 0.00 0.00 0.00 18:48:53 17:48:01 ens3 1.00 1.12 0.16 0.17 0.00 0.00 0.00 0.00 18:48:53 17:49:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:49:01 lo 35.26 35.26 14.29 14.29 0.00 0.00 0.00 0.00 18:48:53 17:49:01 ens3 0.92 1.05 0.15 0.15 0.00 0.00 0.00 0.00 18:48:53 17:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:50:01 lo 38.86 38.86 11.87 11.87 0.00 0.00 0.00 0.00 18:48:53 17:50:01 ens3 1.42 1.23 0.54 0.40 0.00 0.00 0.00 0.00 18:48:53 17:51:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:51:01 lo 18.91 18.91 5.74 5.74 0.00 0.00 0.00 0.00 18:48:53 17:51:01 ens3 0.75 0.85 0.12 0.12 0.00 0.00 0.00 0.00 18:48:53 17:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:52:01 lo 31.34 31.34 22.22 22.22 0.00 0.00 0.00 0.00 18:48:53 17:52:01 ens3 0.68 0.73 0.11 0.11 0.00 0.00 0.00 0.00 18:48:53 17:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:53:01 lo 6.23 6.23 3.79 3.79 0.00 0.00 0.00 0.00 18:48:53 17:53:01 ens3 0.77 0.95 0.14 0.15 0.00 0.00 0.00 0.00 18:48:53 17:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:54:01 lo 18.41 18.41 8.75 8.75 0.00 0.00 0.00 0.00 18:48:53 17:54:01 ens3 0.58 0.62 0.10 0.10 0.00 0.00 0.00 0.00 18:48:53 17:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:55:01 lo 23.50 23.50 10.00 10.00 0.00 0.00 0.00 0.00 18:48:53 17:55:01 ens3 0.77 0.95 0.24 0.19 0.00 0.00 0.00 0.00 18:48:53 17:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:56:01 lo 15.90 15.90 6.54 6.54 0.00 0.00 0.00 0.00 18:48:53 17:56:01 ens3 0.53 0.62 0.10 0.10 0.00 0.00 0.00 0.00 18:48:53 17:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:57:01 lo 9.43 9.43 4.44 4.44 0.00 0.00 0.00 0.00 18:48:53 17:57:01 ens3 0.55 0.58 0.09 0.09 0.00 0.00 0.00 0.00 18:48:53 17:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:58:01 lo 17.56 17.56 8.57 8.57 0.00 0.00 0.00 0.00 18:48:53 17:58:01 ens3 0.68 0.77 0.12 0.12 0.00 0.00 0.00 0.00 18:48:53 17:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 17:59:01 lo 20.63 20.63 6.88 6.88 0.00 0.00 0.00 0.00 18:48:53 17:59:01 ens3 0.55 0.67 0.09 0.10 0.00 0.00 0.00 0.00 18:48:53 18:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:00:01 lo 35.43 35.43 13.43 13.43 0.00 0.00 0.00 0.00 18:48:53 18:00:01 ens3 1.07 1.08 0.27 0.20 0.00 0.00 0.00 0.00 18:48:53 18:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:01:01 lo 18.99 18.99 6.38 6.38 0.00 0.00 0.00 0.00 18:48:53 18:01:01 ens3 0.62 0.77 0.11 0.12 0.00 0.00 0.00 0.00 18:48:53 18:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:02:01 lo 52.85 52.85 16.26 16.26 0.00 0.00 0.00 0.00 18:48:53 18:02:01 ens3 0.33 0.42 0.06 0.07 0.00 0.00 0.00 0.00 18:48:53 18:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:03:01 lo 22.75 22.75 6.60 6.60 0.00 0.00 0.00 0.00 18:48:53 18:03:01 ens3 0.55 0.55 0.09 0.08 0.00 0.00 0.00 0.00 18:48:53 18:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:04:01 lo 32.24 32.24 9.27 9.27 0.00 0.00 0.00 0.00 18:48:53 18:04:01 ens3 0.30 0.23 0.04 0.03 0.00 0.00 0.00 0.00 18:48:53 18:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:05:01 lo 39.11 39.11 11.90 11.90 0.00 0.00 0.00 0.00 18:48:53 18:05:01 ens3 0.42 0.35 0.15 0.09 0.00 0.00 0.00 0.00 18:48:53 18:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:06:01 lo 62.52 62.52 19.32 19.32 0.00 0.00 0.00 0.00 18:48:53 18:06:01 ens3 0.10 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:07:01 lo 2.82 2.82 0.26 0.26 0.00 0.00 0.00 0.00 18:48:53 18:07:01 ens3 0.87 0.88 0.11 0.11 0.00 0.00 0.00 0.00 18:48:53 18:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:08:01 lo 23.90 23.90 22.69 22.69 0.00 0.00 0.00 0.00 18:48:53 18:08:01 ens3 0.67 0.75 0.11 0.12 0.00 0.00 0.00 0.00 18:48:53 18:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:09:01 lo 33.11 33.11 13.76 13.76 0.00 0.00 0.00 0.00 18:48:53 18:09:01 ens3 0.63 0.83 0.13 0.13 0.00 0.00 0.00 0.00 18:48:53 18:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:10:01 lo 17.60 17.60 7.65 7.65 0.00 0.00 0.00 0.00 18:48:53 18:10:01 ens3 0.85 1.05 0.26 0.21 0.00 0.00 0.00 0.00 18:48:53 18:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:11:01 lo 28.25 28.25 12.43 12.43 0.00 0.00 0.00 0.00 18:48:53 18:11:01 ens3 0.72 0.88 0.13 0.14 0.00 0.00 0.00 0.00 18:48:53 18:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:12:01 lo 32.76 32.76 10.73 10.73 0.00 0.00 0.00 0.00 18:48:53 18:12:01 ens3 0.35 0.42 0.06 0.07 0.00 0.00 0.00 0.00 18:48:53 18:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:13:01 lo 3.58 3.58 1.90 1.90 0.00 0.00 0.00 0.00 18:48:53 18:13:01 ens3 0.50 0.58 0.09 0.09 0.00 0.00 0.00 0.00 18:48:53 18:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:14:01 lo 0.85 0.85 0.10 0.10 0.00 0.00 0.00 0.00 18:48:53 18:14:01 ens3 0.08 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:15:01 lo 0.85 0.85 0.07 0.07 0.00 0.00 0.00 0.00 18:48:53 18:15:01 ens3 0.92 0.28 0.20 0.08 0.00 0.00 0.00 0.00 18:48:53 18:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:16:01 lo 15.21 15.21 6.49 6.49 0.00 0.00 0.00 0.00 18:48:53 18:16:01 ens3 0.65 0.47 0.34 0.27 0.00 0.00 0.00 0.00 18:48:53 18:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:17:01 lo 21.64 21.64 8.50 8.50 0.00 0.00 0.00 0.00 18:48:53 18:17:01 ens3 0.50 0.38 0.08 0.07 0.00 0.00 0.00 0.00 18:48:53 18:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:18:01 lo 4.63 4.63 2.13 2.13 0.00 0.00 0.00 0.00 18:48:53 18:18:01 ens3 0.80 0.65 0.12 0.11 0.00 0.00 0.00 0.00 18:48:53 18:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:19:01 lo 23.20 23.20 22.61 22.61 0.00 0.00 0.00 0.00 18:48:53 18:19:01 ens3 0.73 0.65 0.11 0.10 0.00 0.00 0.00 0.00 18:48:53 18:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:20:01 lo 33.14 33.14 13.90 13.90 0.00 0.00 0.00 0.00 18:48:53 18:20:01 ens3 0.75 0.58 0.25 0.17 0.00 0.00 0.00 0.00 18:48:53 18:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:21:01 lo 18.50 18.50 9.74 9.74 0.00 0.00 0.00 0.00 18:48:53 18:21:01 ens3 0.57 0.47 0.09 0.07 0.00 0.00 0.00 0.00 18:48:53 18:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:22:01 lo 10.70 10.70 7.28 7.28 0.00 0.00 0.00 0.00 18:48:53 18:22:01 ens3 1.08 0.98 0.19 0.16 0.00 0.00 0.00 0.00 18:48:53 18:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:23:01 lo 23.08 23.08 10.77 10.77 0.00 0.00 0.00 0.00 18:48:53 18:23:01 ens3 0.87 0.90 0.38 0.32 0.00 0.00 0.00 0.00 18:48:53 18:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:24:01 lo 8.22 8.22 5.72 5.72 0.00 0.00 0.00 0.00 18:48:53 18:24:01 ens3 1.10 0.57 0.15 0.09 0.00 0.00 0.00 0.00 18:48:53 18:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:25:01 lo 24.45 24.45 12.03 12.03 0.00 0.00 0.00 0.00 18:48:53 18:25:01 ens3 1.63 0.90 0.55 0.36 0.00 0.00 0.00 0.00 18:48:53 18:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:26:01 lo 10.46 10.46 6.16 6.16 0.00 0.00 0.00 0.00 18:48:53 18:26:01 ens3 1.17 0.53 0.41 0.29 0.00 0.00 0.00 0.00 18:48:53 18:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:27:01 lo 36.21 36.21 12.62 12.62 0.00 0.00 0.00 0.00 18:48:53 18:27:01 ens3 0.60 0.42 0.33 0.26 0.00 0.00 0.00 0.00 18:48:53 18:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:28:01 lo 4.92 4.92 2.58 2.58 0.00 0.00 0.00 0.00 18:48:53 18:28:01 ens3 2.75 2.03 0.94 0.74 0.00 0.00 0.00 0.00 18:48:53 18:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:29:01 lo 35.46 35.46 32.66 32.66 0.00 0.00 0.00 0.00 18:48:53 18:29:01 ens3 3.27 0.97 0.75 0.47 0.00 0.00 0.00 0.00 18:48:53 18:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:30:01 lo 35.46 35.46 14.32 14.32 0.00 0.00 0.00 0.00 18:48:53 18:30:01 ens3 3.25 2.10 1.05 0.77 0.00 0.00 0.00 0.00 18:48:53 18:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:31:01 lo 1.68 1.68 0.61 0.61 0.00 0.00 0.00 0.00 18:48:53 18:31:01 ens3 0.80 0.38 0.34 0.24 0.00 0.00 0.00 0.00 18:48:53 18:32:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:32:01 lo 0.62 0.62 0.07 0.07 0.00 0.00 0.00 0.00 18:48:53 18:32:01 ens3 0.87 0.23 0.31 0.20 0.00 0.00 0.00 0.00 18:48:53 18:33:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:33:01 lo 0.60 0.60 0.05 0.05 0.00 0.00 0.00 0.00 18:48:53 18:33:01 ens3 0.83 0.43 0.33 0.25 0.00 0.00 0.00 0.00 18:48:53 18:34:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:34:01 lo 2.52 2.52 0.24 0.24 0.00 0.00 0.00 0.00 18:48:53 18:34:01 ens3 1.57 0.58 0.20 0.08 0.00 0.00 0.00 0.00 18:48:53 18:35:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:35:01 lo 37.54 37.54 19.24 19.24 0.00 0.00 0.00 0.00 18:48:53 18:35:01 ens3 1.97 1.40 0.67 0.48 0.00 0.00 0.00 0.00 18:48:53 18:36:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:36:01 lo 12.53 12.53 5.33 5.33 0.00 0.00 0.00 0.00 18:48:53 18:36:01 ens3 1.08 1.22 0.44 0.38 0.00 0.00 0.00 0.00 18:48:53 18:37:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:37:01 lo 21.58 21.58 8.31 8.31 0.00 0.00 0.00 0.00 18:48:53 18:37:01 ens3 0.58 0.58 0.09 0.09 0.00 0.00 0.00 0.00 18:48:53 18:38:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:38:01 lo 17.63 17.63 6.93 6.93 0.00 0.00 0.00 0.00 18:48:53 18:38:01 ens3 1.62 0.93 0.24 0.15 0.00 0.00 0.00 0.00 18:48:53 18:39:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:39:01 lo 44.19 44.19 15.58 15.58 0.00 0.00 0.00 0.00 18:48:53 18:39:01 ens3 2.42 1.17 0.80 0.56 0.00 0.00 0.00 0.00 18:48:53 18:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:40:01 lo 38.19 38.19 12.06 12.06 0.00 0.00 0.00 0.00 18:48:53 18:40:01 ens3 1.40 0.87 0.78 0.57 0.00 0.00 0.00 0.00 18:48:53 18:41:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:41:01 lo 3.68 3.68 1.00 1.00 0.00 0.00 0.00 0.00 18:48:53 18:41:01 ens3 1.07 0.60 0.37 0.27 0.00 0.00 0.00 0.00 18:48:53 18:42:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:42:01 lo 0.58 0.58 0.07 0.07 0.00 0.00 0.00 0.00 18:48:53 18:42:01 ens3 0.23 0.00 0.01 0.00 0.00 0.00 0.00 0.00 18:48:53 18:43:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:43:01 lo 0.55 0.55 0.04 0.04 0.00 0.00 0.00 0.00 18:48:53 18:43:01 ens3 0.25 0.10 0.01 0.01 0.00 0.00 0.00 0.00 18:48:53 18:44:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:44:01 lo 2.22 2.22 0.20 0.20 0.00 0.00 0.00 0.00 18:48:53 18:44:01 ens3 1.60 0.50 0.20 0.08 0.00 0.00 0.00 0.00 18:48:53 18:45:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:45:01 lo 44.16 44.16 21.73 21.73 0.00 0.00 0.00 0.00 18:48:53 18:45:01 ens3 1.50 1.33 0.76 0.59 0.00 0.00 0.00 0.00 18:48:53 18:46:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:46:01 lo 41.51 41.51 15.36 15.36 0.00 0.00 0.00 0.00 18:48:53 18:46:01 ens3 0.95 1.07 0.17 0.17 0.00 0.00 0.00 0.00 18:48:53 18:47:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:47:01 lo 59.57 59.57 20.55 20.55 0.00 0.00 0.00 0.00 18:48:53 18:47:01 ens3 0.88 0.60 0.13 0.09 0.00 0.00 0.00 0.00 18:48:53 18:48:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 18:48:01 lo 69.16 69.16 23.02 23.02 0.00 0.00 0.00 0.00 18:48:53 18:48:01 ens3 8.48 10.76 48.80 2.58 0.00 0.00 0.00 0.00 18:48:53 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 18:48:53 Average: lo 19.46 19.46 8.95 8.95 0.00 0.00 0.00 0.00 18:48:53 Average: ens3 12.88 9.59 192.83 1.19 0.00 0.00 0.00 0.00 18:48:53 18:48:53 18:48:53 ---> sar -P ALL: 18:48:53 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-40238) 10/07/24 _x86_64_ (4 CPU) 18:48:53 18:48:53 17:14:00 LINUX RESTART (4 CPU) 18:48:53 18:48:53 17:15:02 CPU %user %nice %system %iowait %steal %idle 18:48:53 17:16:01 all 18.36 4.30 4.33 3.23 0.08 69.69 18:48:53 17:16:01 0 16.71 4.58 4.00 1.80 0.07 72.84 18:48:53 17:16:01 1 6.49 5.16 4.34 0.76 0.08 83.17 18:48:53 17:16:01 2 29.75 4.70 5.13 3.74 0.12 56.57 18:48:53 17:16:01 3 20.69 2.77 3.86 6.66 0.07 65.95 18:48:53 17:17:01 all 82.62 0.00 4.62 4.82 0.12 7.82 18:48:53 17:17:01 0 84.63 0.00 4.06 3.42 0.12 7.77 18:48:53 17:17:01 1 79.46 0.00 4.84 4.89 0.12 10.69 18:48:53 17:17:01 2 83.03 0.00 4.67 4.07 0.12 8.11 18:48:53 17:17:01 3 83.37 0.00 4.91 6.87 0.12 4.73 18:48:53 17:18:01 all 53.94 0.00 2.66 1.52 0.10 41.78 18:48:53 17:18:01 0 55.65 0.00 2.54 0.57 0.12 41.12 18:48:53 17:18:01 1 32.37 0.00 2.05 3.82 0.10 61.66 18:48:53 17:18:01 2 49.28 0.00 1.96 0.58 0.08 48.10 18:48:53 17:18:01 3 78.62 0.00 4.11 1.11 0.10 16.06 18:48:53 17:19:01 all 82.59 0.00 4.58 7.34 0.14 5.35 18:48:53 17:19:01 0 85.80 0.00 4.18 6.56 0.12 3.35 18:48:53 17:19:01 1 80.80 0.00 5.60 9.07 0.12 4.42 18:48:53 17:19:01 2 81.68 0.00 4.05 4.74 0.14 9.40 18:48:53 17:19:01 3 82.10 0.00 4.48 9.00 0.17 4.25 18:48:53 17:20:01 all 86.15 0.00 4.25 3.61 0.13 5.87 18:48:53 17:20:01 0 85.49 0.00 4.40 4.92 0.12 5.07 18:48:53 17:20:01 1 88.03 0.00 4.26 2.65 0.12 4.94 18:48:53 17:20:01 2 85.27 0.00 4.42 4.32 0.15 5.84 18:48:53 17:20:01 3 85.78 0.00 3.92 2.55 0.12 7.63 18:48:53 17:21:01 all 60.23 0.00 2.21 0.34 0.10 37.12 18:48:53 17:21:01 0 59.67 0.00 2.29 0.05 0.12 37.87 18:48:53 17:21:01 1 62.21 0.00 2.72 0.90 0.08 34.08 18:48:53 17:21:01 2 58.62 0.00 1.76 0.40 0.08 39.13 18:48:53 17:21:01 3 60.43 0.00 2.05 0.02 0.12 37.39 18:48:53 17:22:01 all 52.64 0.00 2.06 0.62 0.10 44.58 18:48:53 17:22:01 0 55.24 0.00 1.71 0.47 0.10 42.49 18:48:53 17:22:01 1 52.43 0.00 2.04 0.54 0.10 44.89 18:48:53 17:22:01 2 51.25 0.00 2.22 0.12 0.10 46.31 18:48:53 17:22:01 3 51.64 0.00 2.28 1.34 0.10 44.64 18:48:53 17:23:01 all 27.49 0.00 1.23 0.32 0.10 70.86 18:48:53 17:23:01 0 29.38 0.00 1.20 0.35 0.10 68.97 18:48:53 17:23:01 1 27.05 0.00 1.28 0.76 0.10 70.82 18:48:53 17:23:01 2 24.87 0.00 1.40 0.08 0.10 73.55 18:48:53 17:23:01 3 28.67 0.00 1.05 0.08 0.10 70.09 18:48:53 17:24:01 all 35.51 0.00 1.47 0.71 0.10 62.21 18:48:53 17:24:01 0 41.12 0.00 1.39 0.12 0.10 57.27 18:48:53 17:24:01 1 37.82 0.00 1.78 0.54 0.10 59.77 18:48:53 17:24:01 2 28.01 0.00 1.34 0.50 0.10 70.05 18:48:53 17:24:01 3 35.14 0.00 1.36 1.69 0.10 61.70 18:48:53 17:25:01 all 0.66 0.00 0.23 0.01 0.09 99.01 18:48:53 17:25:01 0 0.79 0.00 0.23 0.00 0.10 98.88 18:48:53 17:25:01 1 0.76 0.00 0.20 0.00 0.08 98.96 18:48:53 17:25:01 2 0.50 0.00 0.25 0.03 0.08 99.13 18:48:53 17:25:01 3 0.57 0.00 0.22 0.02 0.10 99.09 18:48:53 17:26:01 all 13.20 0.00 0.73 0.02 0.10 85.95 18:48:53 17:26:01 0 11.68 0.00 0.81 0.00 0.08 87.43 18:48:53 17:26:01 1 13.41 0.00 0.64 0.02 0.08 85.85 18:48:53 17:26:01 2 14.19 0.00 0.77 0.07 0.12 84.86 18:48:53 17:26:01 3 13.53 0.00 0.72 0.00 0.10 85.65 18:48:53 18:48:53 17:26:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 17:27:01 all 60.27 0.00 1.85 0.11 0.10 37.67 18:48:53 17:27:01 0 59.60 0.00 1.66 0.03 0.10 38.60 18:48:53 17:27:01 1 63.49 0.00 1.71 0.00 0.12 34.69 18:48:53 17:27:01 2 57.05 0.00 2.05 0.34 0.08 40.48 18:48:53 17:27:01 3 60.93 0.00 1.98 0.07 0.10 36.92 18:48:53 17:28:01 all 7.69 0.00 0.30 0.10 0.09 91.83 18:48:53 17:28:01 0 7.79 0.00 0.24 0.02 0.08 91.87 18:48:53 17:28:01 1 8.45 0.00 0.32 0.00 0.08 91.14 18:48:53 17:28:01 2 7.19 0.00 0.38 0.33 0.12 91.98 18:48:53 17:28:01 3 7.32 0.00 0.25 0.03 0.08 92.31 18:48:53 17:29:01 all 1.26 0.00 0.17 0.05 0.10 98.41 18:48:53 17:29:01 0 1.24 0.00 0.13 0.00 0.08 98.54 18:48:53 17:29:01 1 0.82 0.00 0.17 0.00 0.12 98.89 18:48:53 17:29:01 2 1.18 0.00 0.17 0.17 0.10 98.39 18:48:53 17:29:01 3 1.81 0.00 0.22 0.03 0.12 97.82 18:48:53 17:30:01 all 40.57 0.00 1.93 0.92 0.11 56.46 18:48:53 17:30:01 0 39.90 0.00 1.93 1.81 0.10 56.27 18:48:53 17:30:01 1 45.89 0.00 2.38 0.64 0.12 50.97 18:48:53 17:30:01 2 37.10 0.00 1.49 0.89 0.12 60.40 18:48:53 17:30:01 3 39.37 0.00 1.90 0.35 0.12 58.25 18:48:53 17:31:01 all 31.37 0.00 1.14 0.62 0.11 66.77 18:48:53 17:31:01 0 31.31 0.00 1.04 1.22 0.10 66.33 18:48:53 17:31:01 1 29.35 0.00 0.96 0.12 0.12 69.46 18:48:53 17:31:01 2 32.46 0.00 0.87 0.82 0.10 65.74 18:48:53 17:31:01 3 32.34 0.00 1.66 0.32 0.12 65.56 18:48:53 17:32:01 all 3.36 0.00 0.29 0.09 0.11 96.15 18:48:53 17:32:01 0 3.21 0.00 0.35 0.18 0.12 96.13 18:48:53 17:32:01 1 3.76 0.00 0.30 0.00 0.12 95.82 18:48:53 17:32:01 2 2.80 0.00 0.22 0.18 0.10 96.70 18:48:53 17:32:01 3 3.66 0.00 0.29 0.00 0.12 95.94 18:48:53 17:33:01 all 22.94 0.00 0.84 0.16 0.10 75.96 18:48:53 17:33:01 0 23.69 0.00 0.75 0.10 0.10 75.36 18:48:53 17:33:01 1 23.46 0.00 0.77 0.02 0.10 75.65 18:48:53 17:33:01 2 23.05 0.00 0.79 0.47 0.10 75.59 18:48:53 17:33:01 3 21.59 0.00 1.05 0.05 0.10 77.21 18:48:53 17:34:01 all 22.12 0.00 0.73 0.01 0.11 77.03 18:48:53 17:34:01 0 21.79 0.00 0.87 0.00 0.12 77.22 18:48:53 17:34:01 1 22.59 0.00 0.70 0.00 0.12 76.59 18:48:53 17:34:01 2 22.19 0.00 0.57 0.02 0.10 77.12 18:48:53 17:34:01 3 21.90 0.00 0.78 0.02 0.12 77.19 18:48:53 17:35:01 all 3.06 0.00 0.38 0.02 0.10 96.44 18:48:53 17:35:01 0 2.33 0.00 0.34 0.00 0.10 97.23 18:48:53 17:35:01 1 2.56 0.00 0.35 0.00 0.10 96.98 18:48:53 17:35:01 2 2.50 0.00 0.39 0.03 0.10 96.98 18:48:53 17:35:01 3 4.83 0.00 0.46 0.03 0.10 94.57 18:48:53 17:36:01 all 32.46 0.00 1.28 0.28 0.09 65.88 18:48:53 17:36:01 0 32.18 0.00 1.10 0.00 0.08 66.63 18:48:53 17:36:01 1 30.43 0.00 1.33 0.00 0.08 68.15 18:48:53 17:36:01 2 34.06 0.00 1.29 0.87 0.10 63.68 18:48:53 17:36:01 3 33.18 0.00 1.39 0.27 0.10 65.06 18:48:53 17:37:01 all 40.53 0.00 1.92 3.14 0.13 54.28 18:48:53 17:37:01 0 37.08 0.00 2.11 0.37 0.14 60.31 18:48:53 17:37:01 1 45.09 0.00 2.10 10.31 0.12 42.37 18:48:53 17:37:01 2 41.64 0.00 1.67 0.59 0.12 55.98 18:48:53 17:37:01 3 38.35 0.00 1.80 1.34 0.15 58.36 18:48:53 18:48:53 17:37:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 17:38:01 all 22.51 0.00 1.07 3.42 0.11 72.90 18:48:53 17:38:01 0 21.46 0.00 0.86 0.30 0.08 77.29 18:48:53 17:38:01 1 24.27 0.00 1.04 8.38 0.15 66.15 18:48:53 17:38:01 2 21.98 0.00 1.15 3.07 0.10 73.70 18:48:53 17:38:01 3 22.29 0.00 1.21 1.89 0.12 74.49 18:48:53 17:39:01 all 47.62 0.00 1.95 0.48 0.14 49.80 18:48:53 17:39:01 0 44.74 0.00 1.66 0.02 0.14 53.45 18:48:53 17:39:01 1 47.93 0.00 2.49 0.19 0.15 49.24 18:48:53 17:39:01 2 48.19 0.00 1.85 0.07 0.12 49.77 18:48:53 17:39:01 3 49.65 0.00 1.81 1.65 0.15 46.74 18:48:53 17:40:01 all 18.44 0.00 0.62 0.60 0.09 80.24 18:48:53 17:40:01 0 18.80 0.00 0.62 0.03 0.10 80.45 18:48:53 17:40:01 1 16.88 0.00 0.73 0.08 0.10 82.21 18:48:53 17:40:01 2 19.76 0.00 0.80 0.74 0.08 78.62 18:48:53 17:40:01 3 18.33 0.00 0.35 1.55 0.08 79.69 18:48:53 17:41:01 all 12.22 0.00 0.69 0.09 0.09 86.90 18:48:53 17:41:01 0 11.65 0.00 0.57 0.00 0.08 87.70 18:48:53 17:41:01 1 12.33 0.00 0.54 0.02 0.07 87.05 18:48:53 17:41:01 2 13.22 0.00 1.04 0.08 0.12 85.54 18:48:53 17:41:01 3 11.71 0.00 0.62 0.25 0.10 87.32 18:48:53 17:42:01 all 28.83 0.00 1.04 0.47 0.08 69.58 18:48:53 17:42:01 0 28.02 0.00 1.13 0.44 0.08 70.33 18:48:53 17:42:01 1 30.62 0.00 0.91 0.00 0.10 68.37 18:48:53 17:42:01 2 30.07 0.00 0.94 0.00 0.08 68.90 18:48:53 17:42:01 3 26.62 0.00 1.19 1.43 0.07 70.69 18:48:53 17:43:01 all 19.92 0.00 0.55 0.50 0.08 78.95 18:48:53 17:43:01 0 20.40 0.00 0.57 0.39 0.10 78.54 18:48:53 17:43:01 1 20.86 0.00 0.49 0.00 0.07 78.59 18:48:53 17:43:01 2 19.01 0.00 0.52 0.15 0.07 80.25 18:48:53 17:43:01 3 19.40 0.00 0.61 1.46 0.10 78.43 18:48:53 17:44:01 all 15.99 0.00 0.70 0.21 0.08 83.01 18:48:53 17:44:01 0 15.14 0.00 0.83 0.10 0.08 83.85 18:48:53 17:44:01 1 13.82 0.00 0.60 0.30 0.10 85.18 18:48:53 17:44:01 2 17.76 0.00 0.66 0.00 0.07 81.51 18:48:53 17:44:01 3 17.26 0.00 0.72 0.44 0.08 81.50 18:48:53 17:45:01 all 51.83 0.00 1.68 0.55 0.10 45.84 18:48:53 17:45:01 0 51.24 0.00 1.81 0.37 0.10 46.48 18:48:53 17:45:01 1 47.70 0.00 1.63 0.35 0.10 50.22 18:48:53 17:45:01 2 53.65 0.00 1.73 0.03 0.12 44.46 18:48:53 17:45:01 3 54.76 0.00 1.57 1.45 0.08 42.14 18:48:53 17:46:01 all 10.39 0.00 0.49 0.02 0.08 89.02 18:48:53 17:46:01 0 10.28 0.00 0.49 0.00 0.07 89.16 18:48:53 17:46:01 1 10.91 0.00 0.36 0.00 0.07 88.66 18:48:53 17:46:01 2 11.44 0.00 0.38 0.03 0.08 88.06 18:48:53 17:46:01 3 8.92 0.00 0.72 0.05 0.12 90.19 18:48:53 17:47:01 all 35.26 0.00 1.00 0.23 0.08 63.43 18:48:53 17:47:01 0 37.13 0.00 0.60 0.00 0.08 62.18 18:48:53 17:47:01 1 35.59 0.00 1.27 0.43 0.07 62.64 18:48:53 17:47:01 2 31.01 0.00 1.03 0.02 0.08 67.86 18:48:53 17:47:01 3 37.36 0.00 1.09 0.47 0.10 60.98 18:48:53 17:48:01 all 29.73 0.00 1.00 0.10 0.08 69.09 18:48:53 17:48:01 0 30.97 0.00 0.99 0.10 0.08 67.86 18:48:53 17:48:01 1 31.74 0.00 0.61 0.02 0.08 67.55 18:48:53 17:48:01 2 26.84 0.00 1.36 0.27 0.07 71.47 18:48:53 17:48:01 3 29.37 0.00 1.05 0.02 0.07 69.50 18:48:53 18:48:53 17:48:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 17:49:01 all 26.70 0.00 0.80 0.26 0.09 72.15 18:48:53 17:49:01 0 26.98 0.00 0.85 0.00 0.10 72.07 18:48:53 17:49:01 1 26.72 0.00 0.72 0.17 0.08 72.30 18:48:53 17:49:01 2 27.37 0.00 1.01 0.29 0.10 71.24 18:48:53 17:49:01 3 25.74 0.00 0.60 0.60 0.08 72.97 18:48:53 17:50:01 all 4.84 0.00 0.30 0.01 0.07 94.78 18:48:53 17:50:01 0 4.36 0.00 0.18 0.05 0.07 95.33 18:48:53 17:50:01 1 4.80 0.00 0.25 0.00 0.07 94.89 18:48:53 17:50:01 2 5.80 0.00 0.43 0.00 0.08 93.68 18:48:53 17:50:01 3 4.39 0.00 0.32 0.00 0.05 95.24 18:48:53 17:51:01 all 27.41 0.00 1.00 0.15 0.10 71.35 18:48:53 17:51:01 0 26.67 0.00 0.84 0.52 0.08 71.89 18:48:53 17:51:01 1 28.32 0.00 0.91 0.00 0.10 70.67 18:48:53 17:51:01 2 27.61 0.00 1.20 0.05 0.10 71.04 18:48:53 17:51:01 3 27.03 0.00 1.05 0.02 0.10 71.80 18:48:53 17:52:01 all 29.64 0.00 0.94 0.23 0.09 69.10 18:48:53 17:52:01 0 30.16 0.00 1.04 0.52 0.08 68.20 18:48:53 17:52:01 1 27.77 0.00 0.95 0.00 0.10 71.18 18:48:53 17:52:01 2 29.08 0.00 0.78 0.38 0.08 69.67 18:48:53 17:52:01 3 31.57 0.00 0.97 0.02 0.08 67.36 18:48:53 17:53:01 all 2.03 0.00 0.23 0.03 0.10 97.61 18:48:53 17:53:01 0 1.85 0.00 0.28 0.07 0.10 97.70 18:48:53 17:53:01 1 1.81 0.00 0.23 0.00 0.10 97.86 18:48:53 17:53:01 2 2.66 0.00 0.28 0.00 0.10 96.96 18:48:53 17:53:01 3 1.79 0.00 0.13 0.07 0.08 97.93 18:48:53 17:54:01 all 3.40 0.00 0.27 0.05 0.09 96.19 18:48:53 17:54:01 0 2.92 0.00 0.27 0.20 0.08 96.53 18:48:53 17:54:01 1 3.82 0.00 0.28 0.00 0.10 95.79 18:48:53 17:54:01 2 3.04 0.00 0.17 0.00 0.08 96.71 18:48:53 17:54:01 3 3.82 0.00 0.37 0.00 0.10 95.72 18:48:53 17:55:01 all 3.02 0.00 0.28 0.01 0.08 96.60 18:48:53 17:55:01 0 2.24 0.00 0.23 0.05 0.08 97.39 18:48:53 17:55:01 1 3.32 0.00 0.28 0.00 0.08 96.32 18:48:53 17:55:01 2 2.75 0.00 0.42 0.00 0.10 96.73 18:48:53 17:55:01 3 3.75 0.00 0.20 0.00 0.07 95.99 18:48:53 17:56:01 all 2.18 0.00 0.25 0.01 0.07 97.49 18:48:53 17:56:01 0 2.26 0.00 0.42 0.03 0.08 97.21 18:48:53 17:56:01 1 1.72 0.00 0.17 0.00 0.07 98.05 18:48:53 17:56:01 2 1.94 0.00 0.18 0.00 0.08 97.80 18:48:53 17:56:01 3 2.78 0.00 0.23 0.00 0.07 96.92 18:48:53 17:57:01 all 1.78 0.00 0.21 0.01 0.07 97.92 18:48:53 17:57:01 0 1.25 0.00 0.27 0.03 0.08 98.36 18:48:53 17:57:01 1 1.07 0.00 0.15 0.02 0.07 98.70 18:48:53 17:57:01 2 2.50 0.00 0.13 0.00 0.07 97.30 18:48:53 17:57:01 3 2.30 0.00 0.28 0.00 0.08 97.33 18:48:53 17:58:01 all 2.10 0.00 0.28 0.01 0.08 97.54 18:48:53 17:58:01 0 2.21 0.00 0.33 0.03 0.10 97.33 18:48:53 17:58:01 1 1.97 0.00 0.30 0.00 0.08 97.65 18:48:53 17:58:01 2 2.69 0.00 0.25 0.00 0.07 97.00 18:48:53 17:58:01 3 1.54 0.00 0.22 0.00 0.07 98.18 18:48:53 17:59:01 all 17.76 0.00 0.73 0.02 0.08 81.40 18:48:53 17:59:01 0 18.44 0.00 0.60 0.05 0.08 80.82 18:48:53 17:59:01 1 15.14 0.00 0.80 0.03 0.10 83.93 18:48:53 17:59:01 2 17.93 0.00 0.84 0.00 0.05 81.17 18:48:53 17:59:01 3 19.52 0.00 0.68 0.00 0.10 79.70 18:48:53 18:48:53 17:59:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 18:00:01 all 40.11 0.00 1.30 0.36 0.09 58.13 18:48:53 18:00:01 0 38.97 0.00 0.96 1.33 0.09 58.65 18:48:53 18:00:01 1 41.92 0.00 1.26 0.09 0.09 56.65 18:48:53 18:00:01 2 37.81 0.00 1.16 0.02 0.10 60.91 18:48:53 18:00:01 3 41.73 0.00 1.84 0.02 0.09 56.33 18:48:53 18:01:01 all 3.09 0.00 0.25 0.04 0.08 96.53 18:48:53 18:01:01 0 3.19 0.00 0.37 0.15 0.08 96.21 18:48:53 18:01:01 1 2.72 0.00 0.22 0.02 0.08 96.97 18:48:53 18:01:01 2 2.94 0.00 0.22 0.00 0.07 96.78 18:48:53 18:01:01 3 3.53 0.00 0.22 0.00 0.08 96.17 18:48:53 18:02:01 all 5.25 0.00 0.37 0.02 0.08 94.29 18:48:53 18:02:01 0 5.32 0.00 0.42 0.02 0.08 94.16 18:48:53 18:02:01 1 5.65 0.00 0.35 0.00 0.07 93.94 18:48:53 18:02:01 2 4.99 0.00 0.38 0.00 0.08 94.54 18:48:53 18:02:01 3 5.05 0.00 0.32 0.05 0.07 94.51 18:48:53 18:03:01 all 2.53 0.00 0.27 0.01 0.09 97.11 18:48:53 18:03:01 0 2.81 0.00 0.27 0.03 0.08 96.81 18:48:53 18:03:01 1 1.97 0.00 0.30 0.00 0.10 97.63 18:48:53 18:03:01 2 3.26 0.00 0.25 0.00 0.08 96.40 18:48:53 18:03:01 3 2.07 0.00 0.25 0.00 0.08 97.59 18:48:53 18:04:01 all 2.80 0.00 0.28 0.01 0.08 96.83 18:48:53 18:04:01 0 2.31 0.00 0.23 0.03 0.07 97.36 18:48:53 18:04:01 1 3.60 0.00 0.27 0.00 0.08 96.05 18:48:53 18:04:01 2 2.62 0.00 0.32 0.00 0.10 96.96 18:48:53 18:04:01 3 2.69 0.00 0.28 0.00 0.08 96.95 18:48:53 18:05:01 all 3.15 0.00 0.26 0.03 0.08 96.48 18:48:53 18:05:01 0 3.46 0.00 0.32 0.12 0.08 96.02 18:48:53 18:05:01 1 2.88 0.00 0.32 0.00 0.08 96.72 18:48:53 18:05:01 2 2.94 0.00 0.22 0.00 0.08 96.76 18:48:53 18:05:01 3 3.30 0.00 0.18 0.02 0.07 96.43 18:48:53 18:06:01 all 4.67 0.00 0.40 0.01 0.09 94.83 18:48:53 18:06:01 0 4.24 0.00 0.47 0.05 0.10 95.14 18:48:53 18:06:01 1 4.64 0.00 0.43 0.00 0.08 94.84 18:48:53 18:06:01 2 4.95 0.00 0.30 0.00 0.08 94.67 18:48:53 18:06:01 3 4.83 0.00 0.42 0.00 0.08 94.67 18:48:53 18:07:01 all 45.46 0.00 1.54 0.03 0.10 52.87 18:48:53 18:07:01 0 44.24 0.00 1.72 0.05 0.10 53.88 18:48:53 18:07:01 1 46.02 0.00 1.63 0.02 0.10 52.23 18:48:53 18:07:01 2 44.48 0.00 1.17 0.03 0.10 54.21 18:48:53 18:07:01 3 47.10 0.00 1.62 0.00 0.10 51.18 18:48:53 18:08:01 all 21.74 0.00 0.83 0.30 0.09 77.03 18:48:53 18:08:01 0 21.05 0.00 1.16 1.19 0.10 76.51 18:48:53 18:08:01 1 22.01 0.00 0.68 0.02 0.10 77.19 18:48:53 18:08:01 2 21.19 0.00 0.67 0.02 0.08 78.05 18:48:53 18:08:01 3 22.73 0.00 0.82 0.00 0.08 76.36 18:48:53 18:09:01 all 9.09 0.00 0.40 0.02 0.10 90.40 18:48:53 18:09:01 0 9.55 0.00 0.47 0.07 0.13 89.78 18:48:53 18:09:01 1 8.01 0.00 0.50 0.00 0.08 91.40 18:48:53 18:09:01 2 9.09 0.00 0.18 0.00 0.10 90.63 18:48:53 18:09:01 3 9.68 0.00 0.43 0.00 0.08 89.80 18:48:53 18:10:01 all 4.14 0.00 0.35 0.01 0.08 95.43 18:48:53 18:10:01 0 4.27 0.00 0.52 0.05 0.10 95.06 18:48:53 18:10:01 1 3.67 0.00 0.28 0.00 0.07 95.98 18:48:53 18:10:01 2 3.99 0.00 0.20 0.00 0.05 95.76 18:48:53 18:10:01 3 4.61 0.00 0.38 0.00 0.08 94.92 18:48:53 18:48:53 18:10:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 18:11:01 all 4.79 0.00 0.35 0.05 0.08 94.72 18:48:53 18:11:01 0 4.50 0.00 0.43 0.20 0.07 94.80 18:48:53 18:11:01 1 4.31 0.00 0.30 0.00 0.10 95.29 18:48:53 18:11:01 2 5.72 0.00 0.30 0.02 0.08 93.89 18:48:53 18:11:01 3 4.62 0.00 0.38 0.00 0.07 94.93 18:48:53 18:12:01 all 3.51 0.00 0.26 0.02 0.09 96.12 18:48:53 18:12:01 0 4.17 0.00 0.35 0.07 0.10 95.31 18:48:53 18:12:01 1 3.81 0.00 0.20 0.00 0.08 95.91 18:48:53 18:12:01 2 2.86 0.00 0.27 0.00 0.08 96.79 18:48:53 18:12:01 3 3.19 0.00 0.22 0.00 0.10 96.49 18:48:53 18:13:01 all 0.90 0.00 0.23 0.03 0.08 98.77 18:48:53 18:13:01 0 0.62 0.00 0.17 0.03 0.07 99.11 18:48:53 18:13:01 1 0.57 0.00 0.10 0.00 0.07 99.26 18:48:53 18:13:01 2 0.85 0.00 0.35 0.00 0.10 98.70 18:48:53 18:13:01 3 1.57 0.00 0.28 0.07 0.07 98.01 18:48:53 18:14:01 all 0.48 0.00 0.23 0.03 0.06 99.20 18:48:53 18:14:01 0 0.47 0.00 0.33 0.08 0.08 99.03 18:48:53 18:14:01 1 0.35 0.00 0.17 0.00 0.07 99.42 18:48:53 18:14:01 2 0.68 0.00 0.28 0.00 0.05 98.98 18:48:53 18:14:01 3 0.40 0.00 0.13 0.05 0.05 99.36 18:48:53 18:15:01 all 0.44 0.00 0.20 0.01 0.08 99.27 18:48:53 18:15:01 0 0.52 0.00 0.17 0.03 0.08 99.20 18:48:53 18:15:01 1 0.42 0.00 0.18 0.02 0.07 99.32 18:48:53 18:15:01 2 0.58 0.00 0.30 0.00 0.12 99.00 18:48:53 18:15:01 3 0.25 0.00 0.13 0.00 0.05 99.56 18:48:53 18:16:01 all 1.88 0.00 0.25 0.00 0.09 97.77 18:48:53 18:16:01 0 2.10 0.00 0.32 0.00 0.08 97.49 18:48:53 18:16:01 1 1.69 0.00 0.25 0.00 0.10 97.96 18:48:53 18:16:01 2 1.59 0.00 0.15 0.02 0.08 98.16 18:48:53 18:16:01 3 2.16 0.00 0.27 0.00 0.10 97.47 18:48:53 18:17:01 all 2.48 0.00 0.26 0.01 0.09 97.17 18:48:53 18:17:01 0 2.49 0.00 0.32 0.03 0.10 97.06 18:48:53 18:17:01 1 2.51 0.00 0.17 0.00 0.07 97.26 18:48:53 18:17:01 2 2.44 0.00 0.27 0.02 0.10 97.18 18:48:53 18:17:01 3 2.46 0.00 0.29 0.00 0.08 97.17 18:48:53 18:18:01 all 33.11 0.00 1.39 0.05 0.10 65.35 18:48:53 18:18:01 0 35.79 0.00 1.07 0.08 0.08 62.97 18:48:53 18:18:01 1 30.02 0.00 1.41 0.07 0.08 68.43 18:48:53 18:18:01 2 33.98 0.00 1.29 0.03 0.12 64.58 18:48:53 18:18:01 3 32.63 0.00 1.81 0.02 0.10 65.44 18:48:53 18:19:01 all 30.55 0.00 0.97 0.26 0.10 68.13 18:48:53 18:19:01 0 30.46 0.00 0.91 0.23 0.10 68.29 18:48:53 18:19:01 1 28.80 0.00 1.07 0.50 0.10 69.53 18:48:53 18:19:01 2 32.69 0.00 1.13 0.30 0.08 65.79 18:48:53 18:19:01 3 30.24 0.00 0.77 0.00 0.10 68.90 18:48:53 18:20:01 all 8.50 0.00 0.46 0.01 0.08 90.94 18:48:53 18:20:01 0 9.53 0.00 0.48 0.00 0.08 89.90 18:48:53 18:20:01 1 8.60 0.00 0.35 0.05 0.08 90.91 18:48:53 18:20:01 2 8.38 0.00 0.60 0.00 0.08 90.93 18:48:53 18:20:01 3 7.48 0.00 0.42 0.00 0.07 92.04 18:48:53 18:21:01 all 4.54 0.00 0.36 0.01 0.09 95.00 18:48:53 18:21:01 0 4.55 0.00 0.30 0.03 0.10 95.02 18:48:53 18:21:01 1 4.16 0.00 0.34 0.02 0.08 95.41 18:48:53 18:21:01 2 4.22 0.00 0.37 0.00 0.08 95.33 18:48:53 18:21:01 3 5.23 0.00 0.43 0.00 0.10 94.24 18:48:53 18:48:53 18:21:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 18:22:01 all 2.50 0.00 0.25 0.01 0.09 97.16 18:48:53 18:22:01 0 2.67 0.00 0.28 0.00 0.10 96.94 18:48:53 18:22:01 1 2.36 0.00 0.22 0.03 0.07 97.32 18:48:53 18:22:01 2 2.62 0.00 0.27 0.00 0.08 97.03 18:48:53 18:22:01 3 2.34 0.00 0.22 0.00 0.10 97.34 18:48:53 18:23:01 all 2.91 0.00 0.29 0.01 0.10 96.70 18:48:53 18:23:01 0 3.04 0.00 0.28 0.02 0.10 96.56 18:48:53 18:23:01 1 3.00 0.00 0.23 0.03 0.08 96.65 18:48:53 18:23:01 2 2.82 0.00 0.33 0.00 0.10 96.75 18:48:53 18:23:01 3 2.76 0.00 0.30 0.00 0.10 96.83 18:48:53 18:24:01 all 1.31 0.00 0.27 0.02 0.07 98.34 18:48:53 18:24:01 0 1.67 0.00 0.43 0.02 0.07 97.81 18:48:53 18:24:01 1 1.10 0.00 0.18 0.05 0.07 98.60 18:48:53 18:24:01 2 1.15 0.00 0.23 0.00 0.07 98.55 18:48:53 18:24:01 3 1.31 0.00 0.22 0.00 0.07 98.41 18:48:53 18:25:01 all 2.79 0.00 0.30 0.02 0.08 96.81 18:48:53 18:25:01 0 2.76 0.00 0.37 0.02 0.10 96.76 18:48:53 18:25:01 1 2.83 0.00 0.22 0.05 0.05 96.85 18:48:53 18:25:01 2 2.64 0.00 0.32 0.00 0.08 96.96 18:48:53 18:25:01 3 2.95 0.00 0.32 0.00 0.08 96.65 18:48:53 18:26:01 all 1.15 0.00 0.23 0.03 0.08 98.52 18:48:53 18:26:01 0 1.24 0.00 0.28 0.02 0.08 98.38 18:48:53 18:26:01 1 1.09 0.00 0.13 0.08 0.08 98.61 18:48:53 18:26:01 2 1.00 0.00 0.23 0.00 0.07 98.69 18:48:53 18:26:01 3 1.25 0.00 0.27 0.00 0.08 98.40 18:48:53 18:27:01 all 3.05 0.00 0.34 0.03 0.08 96.50 18:48:53 18:27:01 0 2.93 0.00 0.38 0.02 0.08 96.59 18:48:53 18:27:01 1 3.27 0.00 0.33 0.10 0.08 96.22 18:48:53 18:27:01 2 2.97 0.00 0.20 0.00 0.08 96.74 18:48:53 18:27:01 3 3.03 0.00 0.45 0.00 0.08 96.44 18:48:53 18:28:01 all 12.57 0.00 0.82 0.20 0.08 86.33 18:48:53 18:28:01 0 10.08 0.00 0.87 0.40 0.10 88.55 18:48:53 18:28:01 1 12.08 0.00 0.69 0.22 0.05 86.97 18:48:53 18:28:01 2 16.85 0.00 0.84 0.05 0.08 82.18 18:48:53 18:28:01 3 11.28 0.00 0.90 0.13 0.07 87.62 18:48:53 18:29:01 all 48.92 0.00 1.30 1.26 0.10 48.43 18:48:53 18:29:01 0 50.60 0.00 1.19 0.23 0.08 47.89 18:48:53 18:29:01 1 50.03 0.00 1.47 1.57 0.10 46.82 18:48:53 18:29:01 2 47.47 0.00 1.25 3.00 0.12 48.17 18:48:53 18:29:01 3 47.57 0.00 1.29 0.23 0.08 50.83 18:48:53 18:30:01 all 5.53 0.00 0.38 0.01 0.08 94.00 18:48:53 18:30:01 0 4.71 0.00 0.33 0.00 0.08 94.88 18:48:53 18:30:01 1 5.53 0.00 0.37 0.02 0.08 94.00 18:48:53 18:30:01 2 5.40 0.00 0.40 0.03 0.08 94.09 18:48:53 18:30:01 3 6.46 0.00 0.41 0.00 0.07 93.06 18:48:53 18:31:01 all 0.93 0.00 0.21 0.01 0.08 98.76 18:48:53 18:31:01 0 0.80 0.00 0.22 0.02 0.08 98.88 18:48:53 18:31:01 1 0.72 0.00 0.20 0.03 0.08 98.97 18:48:53 18:31:01 2 0.85 0.00 0.22 0.00 0.08 98.85 18:48:53 18:31:01 3 1.35 0.00 0.22 0.00 0.08 98.36 18:48:53 18:32:01 all 0.85 0.00 0.21 0.02 0.07 98.85 18:48:53 18:32:01 0 0.42 0.00 0.20 0.07 0.07 99.25 18:48:53 18:32:01 1 1.75 0.00 0.23 0.00 0.07 97.95 18:48:53 18:32:01 2 0.84 0.00 0.30 0.00 0.10 98.76 18:48:53 18:32:01 3 0.38 0.00 0.12 0.00 0.05 99.45 18:48:53 18:48:53 18:32:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 18:33:01 all 0.93 0.00 0.19 0.01 0.07 98.81 18:48:53 18:33:01 0 0.33 0.00 0.18 0.03 0.08 99.36 18:48:53 18:33:01 1 2.40 0.00 0.13 0.00 0.07 97.41 18:48:53 18:33:01 2 0.65 0.00 0.27 0.00 0.08 99.00 18:48:53 18:33:01 3 0.30 0.00 0.17 0.00 0.05 99.48 18:48:53 18:34:01 all 38.21 0.00 1.34 0.05 0.08 60.32 18:48:53 18:34:01 0 37.46 0.00 1.51 0.10 0.10 60.83 18:48:53 18:34:01 1 36.79 0.00 1.07 0.02 0.07 62.06 18:48:53 18:34:01 2 38.89 0.00 1.50 0.02 0.08 59.50 18:48:53 18:34:01 3 39.68 0.00 1.29 0.05 0.08 58.90 18:48:53 18:35:01 all 19.03 0.00 0.61 0.25 0.09 80.02 18:48:53 18:35:01 0 18.49 0.00 0.63 0.32 0.08 80.47 18:48:53 18:35:01 1 18.74 0.00 0.50 0.00 0.07 80.69 18:48:53 18:35:01 2 20.42 0.00 0.55 0.00 0.08 78.95 18:48:53 18:35:01 3 18.48 0.00 0.75 0.70 0.12 79.94 18:48:53 18:36:01 all 3.05 0.00 0.30 0.01 0.08 96.57 18:48:53 18:36:01 0 4.13 0.00 0.17 0.03 0.08 95.59 18:48:53 18:36:01 1 2.98 0.00 0.33 0.00 0.07 96.62 18:48:53 18:36:01 2 2.49 0.00 0.28 0.00 0.08 97.15 18:48:53 18:36:01 3 2.57 0.00 0.40 0.02 0.08 96.93 18:48:53 18:37:01 all 3.04 0.00 0.34 0.01 0.08 96.53 18:48:53 18:37:01 0 3.27 0.00 0.23 0.02 0.05 96.43 18:48:53 18:37:01 1 2.90 0.00 0.42 0.00 0.08 96.60 18:48:53 18:37:01 2 3.23 0.00 0.37 0.00 0.08 96.32 18:48:53 18:37:01 3 2.77 0.00 0.33 0.03 0.08 96.77 18:48:53 18:38:01 all 2.55 0.00 0.32 0.00 0.08 97.05 18:48:53 18:38:01 0 2.50 0.00 0.30 0.02 0.08 97.10 18:48:53 18:38:01 1 2.50 0.00 0.27 0.00 0.08 97.15 18:48:53 18:38:01 2 2.72 0.00 0.37 0.00 0.07 96.85 18:48:53 18:38:01 3 2.49 0.00 0.33 0.00 0.07 97.11 18:48:53 18:39:01 all 4.10 0.00 0.36 0.01 0.08 95.45 18:48:53 18:39:01 0 4.16 0.00 0.32 0.02 0.08 95.42 18:48:53 18:39:01 1 4.07 0.00 0.45 0.00 0.08 95.40 18:48:53 18:39:01 2 4.04 0.00 0.27 0.00 0.07 95.63 18:48:53 18:39:01 3 4.12 0.00 0.40 0.02 0.10 95.36 18:48:53 18:40:01 all 3.35 0.00 0.37 0.01 0.09 96.18 18:48:53 18:40:01 0 3.18 0.00 0.48 0.02 0.12 96.20 18:48:53 18:40:01 1 4.61 0.00 0.33 0.00 0.08 94.98 18:48:53 18:40:01 2 2.95 0.00 0.37 0.00 0.10 96.59 18:48:53 18:40:01 3 2.64 0.00 0.32 0.02 0.07 96.96 18:48:53 18:41:01 all 1.01 0.00 0.24 0.01 0.08 98.66 18:48:53 18:41:01 0 0.73 0.00 0.25 0.00 0.08 98.93 18:48:53 18:41:01 1 1.99 0.00 0.30 0.00 0.08 97.63 18:48:53 18:41:01 2 0.65 0.00 0.22 0.00 0.08 99.05 18:48:53 18:41:01 3 0.63 0.00 0.20 0.03 0.08 99.05 18:48:53 18:42:01 all 0.46 0.00 0.18 0.02 0.08 99.27 18:48:53 18:42:01 0 0.53 0.00 0.18 0.05 0.07 99.17 18:48:53 18:42:01 1 0.37 0.00 0.23 0.00 0.08 99.31 18:48:53 18:42:01 2 0.50 0.00 0.17 0.00 0.08 99.25 18:48:53 18:42:01 3 0.42 0.00 0.13 0.02 0.08 99.35 18:48:53 18:43:01 all 0.69 0.00 0.21 0.01 0.08 99.01 18:48:53 18:43:01 0 0.33 0.00 0.17 0.02 0.10 99.38 18:48:53 18:43:01 1 0.48 0.00 0.23 0.00 0.10 99.18 18:48:53 18:43:01 2 0.63 0.00 0.30 0.00 0.08 98.98 18:48:53 18:43:01 3 1.31 0.00 0.13 0.02 0.05 98.49 18:48:53 18:48:53 18:43:01 CPU %user %nice %system %iowait %steal %idle 18:48:53 18:44:01 all 32.30 0.00 1.31 0.06 0.09 66.24 18:48:53 18:44:01 0 32.52 0.00 1.51 0.00 0.07 65.91 18:48:53 18:44:01 1 31.86 0.00 1.14 0.08 0.10 66.82 18:48:53 18:44:01 2 33.96 0.00 1.34 0.00 0.08 64.62 18:48:53 18:44:01 3 30.87 0.00 1.26 0.17 0.10 67.61 18:48:53 18:45:01 all 31.88 0.00 1.00 0.30 0.10 66.71 18:48:53 18:45:01 0 31.09 0.00 1.23 0.22 0.12 67.35 18:48:53 18:45:01 1 33.42 0.00 0.79 0.40 0.10 65.30 18:48:53 18:45:01 2 31.14 0.00 1.10 0.43 0.10 67.23 18:48:53 18:45:01 3 31.90 0.00 0.88 0.17 0.10 66.94 18:48:53 18:46:01 all 5.97 0.00 0.41 0.00 0.07 93.55 18:48:53 18:46:01 0 6.07 0.00 0.50 0.00 0.07 93.37 18:48:53 18:46:01 1 6.15 0.00 0.53 0.00 0.07 93.25 18:48:53 18:46:01 2 5.56 0.00 0.32 0.02 0.07 94.04 18:48:53 18:46:01 3 6.10 0.00 0.30 0.00 0.07 93.54 18:48:53 18:47:01 all 6.22 0.00 0.41 0.01 0.08 93.27 18:48:53 18:47:01 0 5.98 0.00 0.34 0.02 0.08 93.58 18:48:53 18:47:01 1 6.45 0.00 0.47 0.00 0.07 93.02 18:48:53 18:47:01 2 6.52 0.00 0.40 0.03 0.08 92.97 18:48:53 18:47:01 3 5.94 0.00 0.45 0.00 0.08 93.52 18:48:53 18:48:01 all 11.60 0.00 0.78 0.09 0.09 87.44 18:48:53 18:48:01 0 8.95 0.00 0.64 0.02 0.10 90.30 18:48:53 18:48:01 1 9.93 0.00 0.70 0.00 0.08 89.28 18:48:53 18:48:01 2 11.07 0.00 0.69 0.22 0.08 87.94 18:48:53 18:48:01 3 16.42 0.00 1.10 0.13 0.10 82.25 18:48:53 Average: all 17.93 0.05 0.85 0.42 0.09 80.66 18:48:53 Average: 0 17.91 0.05 0.84 0.33 0.09 80.78 18:48:53 Average: 1 17.63 0.06 0.85 0.52 0.09 80.86 18:48:53 Average: 2 17.86 0.05 0.84 0.35 0.09 80.81 18:48:53 Average: 3 18.33 0.03 0.88 0.48 0.09 80.19 18:48:53 18:48:53 18:48:53