10:50:30 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/113906 10:50:30 Running as SYSTEM 10:50:30 [EnvInject] - Loading node environment variables. 10:50:30 Building remotely on prd-ubuntu2004-docker-4c-16g-2195 (ubuntu2004-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 10:50:31 [ssh-agent] Looking for ssh-agent implementation... 10:50:31 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 10:50:31 $ ssh-agent 10:50:31 SSH_AUTH_SOCK=/tmp/ssh-ybwQ1TliOkO1/agent.12425 10:50:31 SSH_AGENT_PID=12427 10:50:31 [ssh-agent] Started. 10:50:31 Running ssh-add (command line suppressed) 10:50:31 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_16505407982650639104.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_16505407982650639104.key) 10:50:31 [ssh-agent] Using credentials jenkins (jenkins-ssh) 10:50:31 The recommended git tool is: NONE 10:50:33 using credential jenkins-ssh 10:50:33 Wiping out workspace first. 10:50:33 Cloning the remote Git repository 10:50:33 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 10:50:33 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 10:50:34 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 10:50:34 > git --version # timeout=10 10:50:34 > git --version # 'git version 2.25.1' 10:50:34 using GIT_SSH to set credentials jenkins-ssh 10:50:34 Verifying host key using known hosts file 10:50:34 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. 10:50:34 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 10:50:36 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 10:50:36 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 10:50:37 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 10:50:37 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 10:50:37 using GIT_SSH to set credentials jenkins-ssh 10:50:37 Verifying host key using known hosts file 10:50:37 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. 10:50:37 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/06/113906/16 # timeout=10 10:50:37 > git rev-parse 2d4b1fd2f8ee9c658bbbbc0863daed27302c445f^{commit} # timeout=10 10:50:37 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 10:50:37 Checking out Revision 2d4b1fd2f8ee9c658bbbbc0863daed27302c445f (refs/changes/06/113906/16) 10:50:37 > git config core.sparsecheckout # timeout=10 10:50:37 > git checkout -f 2d4b1fd2f8ee9c658bbbbc0863daed27302c445f # timeout=10 10:50:37 Commit message: "Add Tapi Abstracted Node to OR Topo" 10:50:37 > git rev-parse FETCH_HEAD^{commit} # timeout=10 10:50:38 > git rev-list --no-walk 9889c236444fdb4bb40abe9dc03a01d4dc69b802 # timeout=10 10:50:38 > git remote # timeout=10 10:50:38 > git submodule init # timeout=10 10:50:38 > git submodule sync # timeout=10 10:50:38 > git config --get remote.origin.url # timeout=10 10:50:38 > git submodule init # timeout=10 10:50:38 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 10:50:38 ERROR: No submodules found. 10:50:41 provisioning config files... 10:50:41 copy managed file [npmrc] to file:/home/jenkins/.npmrc 10:50:41 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 10:50:41 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7798002501798412744.sh 10:50:41 ---> python-tools-install.sh 10:50:41 Setup pyenv: 10:50:41 * system (set by /opt/pyenv/version) 10:50:41 * 3.8.13 (set by /opt/pyenv/version) 10:50:41 * 3.9.13 (set by /opt/pyenv/version) 10:50:41 * 3.10.13 (set by /opt/pyenv/version) 10:50:41 * 3.11.7 (set by /opt/pyenv/version) 10:50:46 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-pNr3 10:50:46 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 10:50:48 lf-activate-venv(): INFO: Installing: lftools 10:51:16 lf-activate-venv(): INFO: Adding /tmp/venv-pNr3/bin to PATH 10:51:16 Generating Requirements File 10:51:40 Python 3.11.7 10:51:41 pip 24.3.1 from /tmp/venv-pNr3/lib/python3.11/site-packages/pip (python 3.11) 10:51:41 appdirs==1.4.4 10:51:41 argcomplete==3.5.1 10:51:41 aspy.yaml==1.3.0 10:51:41 attrs==24.2.0 10:51:41 autopage==0.5.2 10:51:41 beautifulsoup4==4.12.3 10:51:41 boto3==1.35.49 10:51:41 botocore==1.35.49 10:51:41 bs4==0.0.2 10:51:41 cachetools==5.5.0 10:51:41 certifi==2024.8.30 10:51:41 cffi==1.17.1 10:51:41 cfgv==3.4.0 10:51:41 chardet==5.2.0 10:51:41 charset-normalizer==3.4.0 10:51:41 click==8.1.7 10:51:41 cliff==4.7.0 10:51:41 cmd2==2.5.0 10:51:41 cryptography==3.3.2 10:51:41 debtcollector==3.0.0 10:51:41 decorator==5.1.1 10:51:41 defusedxml==0.7.1 10:51:41 Deprecated==1.2.14 10:51:41 distlib==0.3.9 10:51:41 dnspython==2.7.0 10:51:41 docker==4.2.2 10:51:41 dogpile.cache==1.3.3 10:51:41 durationpy==0.9 10:51:41 email_validator==2.2.0 10:51:41 filelock==3.16.1 10:51:41 future==1.0.0 10:51:41 gitdb==4.0.11 10:51:41 GitPython==3.1.43 10:51:41 google-auth==2.35.0 10:51:41 httplib2==0.22.0 10:51:41 identify==2.6.1 10:51:41 idna==3.10 10:51:41 importlib-resources==1.5.0 10:51:41 iso8601==2.1.0 10:51:41 Jinja2==3.1.4 10:51:41 jmespath==1.0.1 10:51:41 jsonpatch==1.33 10:51:41 jsonpointer==3.0.0 10:51:41 jsonschema==4.23.0 10:51:41 jsonschema-specifications==2024.10.1 10:51:41 keystoneauth1==5.8.0 10:51:41 kubernetes==31.0.0 10:51:41 lftools==0.37.10 10:51:41 lxml==5.3.0 10:51:41 MarkupSafe==3.0.2 10:51:41 msgpack==1.1.0 10:51:41 multi_key_dict==2.0.3 10:51:41 munch==4.0.0 10:51:41 netaddr==1.3.0 10:51:41 netifaces==0.11.0 10:51:41 niet==1.4.2 10:51:41 nodeenv==1.9.1 10:51:41 oauth2client==4.1.3 10:51:41 oauthlib==3.2.2 10:51:41 openstacksdk==4.1.0 10:51:41 os-client-config==2.1.0 10:51:41 os-service-types==1.7.0 10:51:41 osc-lib==3.1.0 10:51:41 oslo.config==9.6.0 10:51:41 oslo.context==5.6.0 10:51:41 oslo.i18n==6.4.0 10:51:41 oslo.log==6.1.2 10:51:41 oslo.serialization==5.5.0 10:51:41 oslo.utils==7.3.0 10:51:41 packaging==24.1 10:51:41 pbr==6.1.0 10:51:41 platformdirs==4.3.6 10:51:41 prettytable==3.11.0 10:51:41 pyasn1==0.6.1 10:51:41 pyasn1_modules==0.4.1 10:51:41 pycparser==2.22 10:51:41 pygerrit2==2.0.15 10:51:41 PyGithub==2.4.0 10:51:41 PyJWT==2.9.0 10:51:41 PyNaCl==1.5.0 10:51:41 pyparsing==2.4.7 10:51:41 pyperclip==1.9.0 10:51:41 pyrsistent==0.20.0 10:51:41 python-cinderclient==9.6.0 10:51:41 python-dateutil==2.9.0.post0 10:51:41 python-heatclient==4.0.0 10:51:41 python-jenkins==1.8.2 10:51:41 python-keystoneclient==5.5.0 10:51:41 python-magnumclient==4.7.0 10:51:41 python-openstackclient==7.2.0 10:51:41 python-swiftclient==4.6.0 10:51:41 PyYAML==6.0.2 10:51:41 referencing==0.35.1 10:51:41 requests==2.32.3 10:51:41 requests-oauthlib==2.0.0 10:51:41 requestsexceptions==1.4.0 10:51:41 rfc3986==2.0.0 10:51:41 rpds-py==0.20.0 10:51:41 rsa==4.9 10:51:41 ruamel.yaml==0.18.6 10:51:41 ruamel.yaml.clib==0.2.12 10:51:41 s3transfer==0.10.3 10:51:41 simplejson==3.19.3 10:51:41 six==1.16.0 10:51:41 smmap==5.0.1 10:51:41 soupsieve==2.6 10:51:41 stevedore==5.3.0 10:51:41 tabulate==0.9.0 10:51:41 toml==0.10.2 10:51:41 tomlkit==0.13.2 10:51:41 tqdm==4.66.5 10:51:41 typing_extensions==4.12.2 10:51:41 tzdata==2024.2 10:51:41 urllib3==1.26.20 10:51:41 virtualenv==20.27.0 10:51:41 wcwidth==0.2.13 10:51:41 websocket-client==1.8.0 10:51:41 wrapt==1.16.0 10:51:41 xdg==6.0.0 10:51:41 xmltodict==0.14.2 10:51:41 yq==3.4.3 10:51:41 [EnvInject] - Injecting environment variables from a build step. 10:51:41 [EnvInject] - Injecting as environment variables the properties content 10:51:41 PYTHON=python3 10:51:41 10:51:41 [EnvInject] - Variables injected successfully. 10:51:41 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins15454564345098481907.sh 10:51:41 ---> tox-install.sh 10:51:41 + source /home/jenkins/lf-env.sh 10:51:41 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 10:51:41 ++ mktemp -d /tmp/venv-XXXX 10:51:41 + lf_venv=/tmp/venv-SYnU 10:51:41 + local venv_file=/tmp/.os_lf_venv 10:51:41 + local python=python3 10:51:41 + local options 10:51:41 + local set_path=true 10:51:41 + local install_args= 10:51:41 ++ 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 10:51:41 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:41 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:41 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 10:51:41 + true 10:51:41 + case $1 in 10:51:41 + venv_file=/tmp/.toxenv 10:51:41 + shift 2 10:51:41 + true 10:51:41 + case $1 in 10:51:41 + shift 10:51:41 + break 10:51:41 + case $python in 10:51:41 + local pkg_list= 10:51:41 + [[ -d /opt/pyenv ]] 10:51:41 + echo 'Setup pyenv:' 10:51:41 Setup pyenv: 10:51:41 + export PYENV_ROOT=/opt/pyenv 10:51:41 + PYENV_ROOT=/opt/pyenv 10:51:41 + 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 10:51:41 + 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 10:51:41 + pyenv versions 10:51:41 system 10:51:41 3.8.13 10:51:41 3.9.13 10:51:41 3.10.13 10:51:41 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:51:41 + command -v pyenv 10:51:41 ++ pyenv init - --no-rehash 10:51:41 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 10:51:41 for i in ${!paths[@]}; do 10:51:41 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 10:51:41 fi; done; 10:51:41 echo "${paths[*]}"'\'')" 10:51:41 export PATH="/opt/pyenv/shims:${PATH}" 10:51:41 export PYENV_SHELL=bash 10:51:41 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 10:51:41 pyenv() { 10:51:41 local command 10:51:41 command="${1:-}" 10:51:41 if [ "$#" -gt 0 ]; then 10:51:41 shift 10:51:41 fi 10:51:41 10:51:41 case "$command" in 10:51:41 rehash|shell) 10:51:41 eval "$(pyenv "sh-$command" "$@")" 10:51:41 ;; 10:51:41 *) 10:51:41 command pyenv "$command" "$@" 10:51:41 ;; 10:51:41 esac 10:51:41 }' 10:51:41 +++ bash --norc -ec 'IFS=:; paths=($PATH); 10:51:41 for i in ${!paths[@]}; do 10:51:41 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 10:51:41 fi; done; 10:51:41 echo "${paths[*]}"' 10:51:41 ++ 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 10:51:41 ++ 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 10:51:41 ++ 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 10:51:41 ++ export PYENV_SHELL=bash 10:51:41 ++ PYENV_SHELL=bash 10:51:41 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 10:51:41 +++ complete -F _pyenv pyenv 10:51:41 ++ lf-pyver python3 10:51:41 ++ local py_version_xy=python3 10:51:41 ++ local py_version_xyz= 10:51:41 ++ pyenv versions 10:51:41 ++ local command 10:51:41 ++ command=versions 10:51:41 ++ '[' 1 -gt 0 ']' 10:51:41 ++ shift 10:51:41 ++ case "$command" in 10:51:41 ++ command pyenv versions 10:51:41 ++ pyenv versions 10:51:41 ++ sed 's/^[ *]* //' 10:51:41 ++ grep -E '^[0-9.]*[0-9]$' 10:51:41 ++ awk '{ print $1 }' 10:51:41 ++ [[ ! -s /tmp/.pyenv_versions ]] 10:51:41 +++ grep '^3' /tmp/.pyenv_versions 10:51:41 +++ sort -V 10:51:41 +++ tail -n 1 10:51:41 ++ py_version_xyz=3.11.7 10:51:41 ++ [[ -z 3.11.7 ]] 10:51:41 ++ echo 3.11.7 10:51:41 ++ return 0 10:51:41 + pyenv local 3.11.7 10:51:41 + local command 10:51:41 + command=local 10:51:41 + '[' 2 -gt 0 ']' 10:51:41 + shift 10:51:41 + case "$command" in 10:51:41 + command pyenv local 3.11.7 10:51:41 + pyenv local 3.11.7 10:51:41 + for arg in "$@" 10:51:41 + case $arg in 10:51:41 + pkg_list+='tox ' 10:51:41 + for arg in "$@" 10:51:41 + case $arg in 10:51:41 + pkg_list+='virtualenv ' 10:51:41 + for arg in "$@" 10:51:41 + case $arg in 10:51:41 + pkg_list+='urllib3~=1.26.15 ' 10:51:41 + [[ -f /tmp/.toxenv ]] 10:51:41 + [[ ! -f /tmp/.toxenv ]] 10:51:41 + [[ -n '' ]] 10:51:41 + python3 -m venv /tmp/venv-SYnU 10:51:45 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-SYnU' 10:51:45 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-SYnU 10:51:45 + echo /tmp/venv-SYnU 10:51:45 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 10:51:45 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 10:51:45 + /tmp/venv-SYnU/bin/python3 -m pip install --upgrade --quiet pip virtualenv 10:51:48 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 10:51:48 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 10:51:48 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 10:51:48 + /tmp/venv-SYnU/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 10:51:50 + type python3 10:51:50 + true 10:51:50 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-SYnU/bin to PATH' 10:51:50 lf-activate-venv(): INFO: Adding /tmp/venv-SYnU/bin to PATH 10:51:50 + PATH=/tmp/venv-SYnU/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 10:51:50 + return 0 10:51:50 + python3 --version 10:51:50 Python 3.11.7 10:51:50 + python3 -m pip --version 10:51:50 pip 24.3.1 from /tmp/venv-SYnU/lib/python3.11/site-packages/pip (python 3.11) 10:51:51 + python3 -m pip freeze 10:51:51 cachetools==5.5.0 10:51:51 chardet==5.2.0 10:51:51 colorama==0.4.6 10:51:51 distlib==0.3.9 10:51:51 filelock==3.16.1 10:51:51 packaging==24.1 10:51:51 platformdirs==4.3.6 10:51:51 pluggy==1.5.0 10:51:51 pyproject-api==1.8.0 10:51:51 tox==4.23.2 10:51:51 urllib3==1.26.20 10:51:51 virtualenv==20.27.0 10:51:51 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins1251719237894710961.sh 10:51:51 [EnvInject] - Injecting environment variables from a build step. 10:51:51 [EnvInject] - Injecting as environment variables the properties content 10:51:51 PARALLEL=True 10:51:51 10:51:51 [EnvInject] - Variables injected successfully. 10:51:51 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins7700344307096958715.sh 10:51:51 ---> tox-run.sh 10:51:51 + 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 10:51:51 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 10:51:51 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 10:51:51 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 10:51:51 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 10:51:51 + source /home/jenkins/lf-env.sh 10:51:51 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 10:51:51 ++ mktemp -d /tmp/venv-XXXX 10:51:51 + lf_venv=/tmp/venv-IkB2 10:51:51 + local venv_file=/tmp/.os_lf_venv 10:51:51 + local python=python3 10:51:51 + local options 10:51:51 + local set_path=true 10:51:51 + local install_args= 10:51:51 ++ 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 10:51:51 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:51 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:51 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 10:51:51 + true 10:51:51 + case $1 in 10:51:51 + venv_file=/tmp/.toxenv 10:51:51 + shift 2 10:51:51 + true 10:51:51 + case $1 in 10:51:51 + shift 10:51:51 + break 10:51:51 + case $python in 10:51:51 + local pkg_list= 10:51:51 + [[ -d /opt/pyenv ]] 10:51:51 + echo 'Setup pyenv:' 10:51:51 Setup pyenv: 10:51:51 + export PYENV_ROOT=/opt/pyenv 10:51:51 + PYENV_ROOT=/opt/pyenv 10:51:51 + 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 10:51:51 + 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 10:51:51 + pyenv versions 10:51:51 system 10:51:51 3.8.13 10:51:51 3.9.13 10:51:51 3.10.13 10:51:51 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:51:51 + command -v pyenv 10:51:51 ++ pyenv init - --no-rehash 10:51:51 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 10:51:51 for i in ${!paths[@]}; do 10:51:51 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 10:51:51 fi; done; 10:51:51 echo "${paths[*]}"'\'')" 10:51:51 export PATH="/opt/pyenv/shims:${PATH}" 10:51:51 export PYENV_SHELL=bash 10:51:51 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 10:51:51 pyenv() { 10:51:51 local command 10:51:51 command="${1:-}" 10:51:51 if [ "$#" -gt 0 ]; then 10:51:51 shift 10:51:51 fi 10:51:51 10:51:51 case "$command" in 10:51:51 rehash|shell) 10:51:51 eval "$(pyenv "sh-$command" "$@")" 10:51:51 ;; 10:51:51 *) 10:51:51 command pyenv "$command" "$@" 10:51:51 ;; 10:51:51 esac 10:51:51 }' 10:51:51 +++ bash --norc -ec 'IFS=:; paths=($PATH); 10:51:51 for i in ${!paths[@]}; do 10:51:51 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 10:51:51 fi; done; 10:51:51 echo "${paths[*]}"' 10:51:51 ++ 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 10:51:51 ++ 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 10:51:51 ++ 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 10:51:51 ++ export PYENV_SHELL=bash 10:51:51 ++ PYENV_SHELL=bash 10:51:51 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 10:51:51 +++ complete -F _pyenv pyenv 10:51:51 ++ lf-pyver python3 10:51:51 ++ local py_version_xy=python3 10:51:51 ++ local py_version_xyz= 10:51:51 ++ pyenv versions 10:51:51 ++ local command 10:51:51 ++ command=versions 10:51:51 ++ '[' 1 -gt 0 ']' 10:51:51 ++ shift 10:51:51 ++ case "$command" in 10:51:51 ++ command pyenv versions 10:51:51 ++ sed 's/^[ *]* //' 10:51:51 ++ pyenv versions 10:51:51 ++ awk '{ print $1 }' 10:51:51 ++ grep -E '^[0-9.]*[0-9]$' 10:51:51 ++ [[ ! -s /tmp/.pyenv_versions ]] 10:51:51 +++ grep '^3' /tmp/.pyenv_versions 10:51:51 +++ sort -V 10:51:51 +++ tail -n 1 10:51:51 ++ py_version_xyz=3.11.7 10:51:51 ++ [[ -z 3.11.7 ]] 10:51:51 ++ echo 3.11.7 10:51:51 ++ return 0 10:51:51 + pyenv local 3.11.7 10:51:51 + local command 10:51:51 + command=local 10:51:51 + '[' 2 -gt 0 ']' 10:51:51 + shift 10:51:51 + case "$command" in 10:51:51 + command pyenv local 3.11.7 10:51:51 + pyenv local 3.11.7 10:51:51 + for arg in "$@" 10:51:51 + case $arg in 10:51:51 + pkg_list+='tox ' 10:51:51 + for arg in "$@" 10:51:51 + case $arg in 10:51:51 + pkg_list+='virtualenv ' 10:51:51 + for arg in "$@" 10:51:51 + case $arg in 10:51:51 + pkg_list+='urllib3~=1.26.15 ' 10:51:51 + [[ -f /tmp/.toxenv ]] 10:51:51 ++ cat /tmp/.toxenv 10:51:51 + lf_venv=/tmp/venv-SYnU 10:51:51 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SYnU from' file:/tmp/.toxenv 10:51:51 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SYnU from file:/tmp/.toxenv 10:51:51 + /tmp/venv-SYnU/bin/python3 -m pip install --upgrade --quiet pip virtualenv 10:51:52 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 10:51:52 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 10:51:52 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 10:51:52 + /tmp/venv-SYnU/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 10:51:53 + type python3 10:51:53 + true 10:51:53 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-SYnU/bin to PATH' 10:51:53 lf-activate-venv(): INFO: Adding /tmp/venv-SYnU/bin to PATH 10:51:53 + PATH=/tmp/venv-SYnU/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 10:51:53 + return 0 10:51:53 + [[ -d /opt/pyenv ]] 10:51:53 + echo '---> Setting up pyenv' 10:51:53 ---> Setting up pyenv 10:51:53 + export PYENV_ROOT=/opt/pyenv 10:51:53 + PYENV_ROOT=/opt/pyenv 10:51:53 + export PATH=/opt/pyenv/bin:/tmp/venv-SYnU/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 10:51:53 + PATH=/opt/pyenv/bin:/tmp/venv-SYnU/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 10:51:53 ++ pwd 10:51:53 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 10:51:53 + export PYTHONPATH 10:51:53 + export TOX_TESTENV_PASSENV=PYTHONPATH 10:51:53 + TOX_TESTENV_PASSENV=PYTHONPATH 10:51:53 + tox --version 10:51:53 4.23.2 from /tmp/venv-SYnU/lib/python3.11/site-packages/tox/__init__.py 10:51:53 + PARALLEL=True 10:51:53 + TOX_OPTIONS_LIST= 10:51:53 + [[ -n '' ]] 10:51:53 + case ${PARALLEL,,} in 10:51:53 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 10:51:53 + tox --parallel auto --parallel-live 10:51:53 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 10:51:55 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 10:51:55 docs: install_deps> python -I -m pip install -r docs/requirements.txt 10:51:55 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 10:51:55 checkbashisms: freeze> python -m pip freeze --all 10:51:55 checkbashisms: pip==24.2,setuptools==75.2.0,wheel==0.44.0 10:51:55 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 10:51:55 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)' 10:51:56 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 10:51:56 script ./reflectwarn.sh does not appear to have a #! interpreter line; 10:51:56 you may get strange results 10:51:57 checkbashisms: OK ✔ in 2.87 seconds 10:51:57 pre-commit: install_deps> python -I -m pip install pre-commit 10:52:02 pre-commit: freeze> python -m pip freeze --all 10:52:02 pre-commit: cfgv==3.4.0,distlib==0.3.9,filelock==3.16.1,identify==2.6.1,nodeenv==1.9.1,pip==24.2,platformdirs==4.3.6,pre_commit==4.0.1,PyYAML==6.0.2,setuptools==75.2.0,virtualenv==20.27.0,wheel==0.44.0 10:52:02 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 10:52:02 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)' 10:52:02 /usr/bin/cpan 10:52:02 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 10:52:02 [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. 10:52:02 [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. 10:52:02 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 10:52:03 [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. 10:52:03 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 10:52:03 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 10:52:03 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 10:52:04 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 10:52:04 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 10:52:04 buildcontroller: freeze> python -m pip freeze --all 10:52:04 buildcontroller: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:52:04 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 10:52:04 + update-java-alternatives -l 10:52:04 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 10:52:04 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 10:52:04 java-1.12.0-openjdk-amd64 1211 /usr/lib/jvm/java-1.12.0-openjdk-amd64 10:52:04 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 10:52:04 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 10:52:04 java-1.8.0-openjdk-amd64 1081 /usr/lib/jvm/java-1.8.0-openjdk-amd64 10:52:05 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 10:52:05 [INFO] Once installed this environment will be reused. 10:52:05 [INFO] This may take a few minutes... 10:52:05 + java -version 10:52:05 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 10:52:05 + JAVA_VER=21 10:52:05 21 10:52:05 + echo 21 10:52:05 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 10:52:05 + javac -version 10:52:06 + JAVAC_VER=21 10:52:06 + echo 21 10:52:06 21 10:52:06 ok, java is 21 or newer 10:52:06 + [ 21 -ge 21 ] 10:52:06 + [ 21 -ge 21 ] 10:52:06 + echo ok, java is 21 or newer 10:52:06 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.8/binaries/apache-maven-3.9.8-bin.tar.gz -P /tmp 10:52:06 2024-10-28 10:52:06 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] 10:52:06 + sudo mkdir -p /opt 10:52:06 + sudo tar xf /tmp/apache-maven-3.9.8-bin.tar.gz -C /opt 10:52:06 + sudo ln -s /opt/apache-maven-3.9.8 /opt/maven 10:52:06 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 10:52:06 + mvn --version 10:52:07 Apache Maven 3.9.8 (36645f6c9b5079805ea5009217e36f2cffd34256) 10:52:07 Maven home: /opt/maven 10:52:07 Java version: 21.0.4, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 10:52:07 Default locale: en, platform encoding: UTF-8 10:52:07 OS name: "linux", version: "5.4.0-190-generic", arch: "amd64", family: "unix" 10:52:07 NOTE: Picked up JDK_JAVA_OPTIONS: 10:52:07 --add-opens=java.base/java.io=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.lang=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.net=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.nio=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.util=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:52:07 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:52:07 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:52:07 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:52:07 -Xlog:disable 10:52:09 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 10:52:09 [INFO] Once installed this environment will be reused. 10:52:09 [INFO] This may take a few minutes... 10:52:19 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 10:52:19 [INFO] Once installed this environment will be reused. 10:52:19 [INFO] This may take a few minutes... 10:52:23 [INFO] Installing environment for https://github.com/perltidy/perltidy. 10:52:23 [INFO] Once installed this environment will be reused. 10:52:23 [INFO] This may take a few minutes... 10:52:32 docs-linkcheck: freeze> python -m pip freeze --all 10:52:32 docs: freeze> python -m pip freeze --all 10:52:32 docs-linkcheck: alabaster==1.0.0,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.4.0,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.2,Pygments==2.18.0,pyparsing==3.2.0,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.2.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.1.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.1,sphinx-tabs==3.4.7,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 10:52:32 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 10:52:32 docs: alabaster==1.0.0,attrs==24.2.0,babel==2.16.0,blockdiag==3.0.0,certifi==2024.8.30,charset-normalizer==3.4.0,contourpy==1.3.0,cycler==0.12.1,docutils==0.21.2,fonttools==4.54.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.4,jsonschema==3.2.0,kiwisolver==1.4.7,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.9.2,numpy==2.1.2,nwdiag==3.0.0,packaging==24.1,pillow==11.0.0,pip==24.2,Pygments==2.18.0,pyparsing==3.2.0,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.3,requests-file==1.5.1,seqdiag==3.0.0,setuptools==75.2.0,six==1.16.0,snowballstemmer==2.2.0,Sphinx==8.1.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.1,sphinx-tabs==3.4.7,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.30,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.2.3,webcolors==24.8.0,wheel==0.44.0 10:52:32 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 10:52:35 docs: OK ✔ in 40.98 seconds 10:52:35 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 10:52:36 trim trailing whitespace.................................................Passed 10:52:36 Tabs remover.............................................................Passed 10:52:36 autopep8.................................................................docs-linkcheck: OK ✔ in 42.58 seconds 10:52:40 pylint: freeze> python -m pip freeze --all 10:52:40 pylint: astroid==3.3.5,dill==0.3.9,isort==5.13.2,mccabe==0.7.0,pip==24.2,platformdirs==4.3.6,pylint==3.3.1,setuptools==75.2.0,tomlkit==0.13.2,wheel==0.44.0 10:52:40 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}$' '{}' + 10:52:40 Passed 10:52:40 perltidy.................................................................Passed 10:52:41 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 10:52: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. 10:52: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. 10:52:41 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 10:52:41 [INFO] Once installed this environment will be reused. 10:52:41 [INFO] This may take a few minutes... 10:52:55 gitlint..................................................................Passed 10:53:01 10:53:01 ------------------------------------ 10:53:01 Your code has been rated at 10.00/10 10:53:01 10:53:50 pre-commit: OK ✔ in 58.75 seconds 10:53:50 pylint: OK ✔ in 27.58 seconds 10:53:50 buildcontroller: OK ✔ in 1 minute 55.6 seconds 10:53:50 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 10:53:50 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 10:53:50 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 10:53:50 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 10:53:57 build_karaf_tests121: freeze> python -m pip freeze --all 10:53:57 sims: freeze> python -m pip freeze --all 10:53:57 build_karaf_tests221: freeze> python -m pip freeze --all 10:53:57 build_karaf_tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:53:57 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:53:57 NOTE: Picked up JDK_JAVA_OPTIONS: 10:53:57 --add-opens=java.base/java.io=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.net=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:53:57 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:53:57 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:53:57 -Xlog:disable 10:53:57 sims: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:53:57 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 10:53:57 Using lighynode version 20.1.0.2 10:53:57 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 10:53:57 build_karaf_tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:53:57 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:53:57 NOTE: Picked up JDK_JAVA_OPTIONS: 10:53:57 --add-opens=java.base/java.io=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.net=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:53:57 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:53:57 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:53:57 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:53:57 -Xlog:disable 10:54:02 sims: OK ✔ in 12.84 seconds 10:54:02 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 10:54:15 build_karaf_tests71: freeze> python -m pip freeze --all 10:54:16 build_karaf_tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:54:16 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:16 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:16 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:16 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:16 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:16 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:16 -Xlog:disable 10:54:47 build_karaf_tests121: OK ✔ in 57.33 seconds 10:54:47 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 10:54:48 build_karaf_tests221: OK ✔ in 59.13 seconds 10:54:48 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 10:54:57 build_karaf_tests71: OK ✔ in 53.6 seconds 10:54:57 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 10:54:57 build_karaf_tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:54:57 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:57 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:57 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:57 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:57 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:57 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:57 -Xlog:disable 10:54:59 tests_tapi: freeze> python -m pip freeze --all 10:55:00 tests_tapi: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:55:00 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 10:55:00 using environment variables from ./karaf221.env 10:55:00 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 10:55:33 testsPCE: freeze> python -m pip freeze --all 10:55:33 testsPCE: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,click==8.1.7,contourpy==1.3.0,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.6,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.54.1,gnpy4tpce==2.4.7,idna==3.10,iniconfig==2.0.0,injector==0.22.0,itsdangerous==2.2.0,Jinja2==3.1.4,kiwisolver==1.4.7,lxml==5.3.0,MarkupSafe==3.0.2,matplotlib==3.9.2,netconf-client==3.1.1,networkx==2.8.8,numpy==1.26.4,packaging==24.1,pandas==1.5.3,paramiko==3.5.0,pbr==5.11.1,pillow==11.0.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pyparsing==3.2.0,pytest==8.3.3,python-dateutil==2.9.0.post0,pytz==2024.2,requests==2.32.3,scipy==1.14.1,setuptools==50.3.2,six==1.16.0,urllib3==2.2.3,Werkzeug==2.0.3,wheel==0.44.0,xlrd==1.2.0 10:55:33 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 10:55:33 pytest -q transportpce_tests/pce/test01_pce.py 10:56:23 .................................................. [100%] 10:57:27 20 passed in 113.74s (0:01:53) 10:57:27 pytest -q transportpce_tests/pce/test02_pce_400G.py 10:57:44 .............. [100%] 10:58:06 9 passed in 39.21s 10:58:07 pytest -q transportpce_tests/pce/test03_gnpy.py 10:58:08 ........... [100%] 10:58:46 8 passed in 39.13s 10:58:46 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 10:58:48 ............ [100%] 10:58:53 50 passed in 233.12s (0:03:53) 10:58:53 pytest -q transportpce_tests/tapi/test02_full_topology.py 10:59:28 ... [100%] 10:59:33 3 passed in 46.52s 10:59:33 build_karaf_tests_hybrid: OK ✔ in 1 minute 2.64 seconds 10:59:33 testsPCE: OK ✔ in 5 minutes 43.67 seconds 10:59:33 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 10:59:40 tests121: freeze> python -m pip freeze --all 10:59:40 tests121: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 10:59:40 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 10:59:40 using environment variables from ./karaf121.env 10:59:40 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 11:00:21 ...........FF....................... [100%] 11:03:48 =================================== FAILURES =================================== 11:03:48 _____________ TransportPCEtesting.test_12_check_openroadm_topology _____________ 11:03:48 11:03:48 self = 11:03:48 11:03:48 def test_12_check_openroadm_topology(self): 11:03:48 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 11:03:48 self.assertEqual(response['status_code'], requests.codes.ok) 11:03:48 > self.assertEqual(len(response['network'][0]['node']), 14, 'There should be 14 openroadm nodes') 11:03:48 E AssertionError: 18 != 14 : There should be 14 openroadm nodes 11:03:48 11:03:48 transportpce_tests/tapi/test02_full_topology.py:272: AssertionError 11:03:48 ____________ TransportPCEtesting.test_13_get_tapi_topology_details _____________ 11:03:48 11:03:48 self = 11:03:48 11:03:48 def test_13_get_tapi_topology_details(self): 11:03:48 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 11:03:48 response = test_utils.transportpce_api_rpc_request( 11:03:48 'tapi-topology', 'get-topology-details', self.tapi_topo) 11:03:48 time.sleep(2) 11:03:48 self.assertEqual(response['status_code'], requests.codes.ok) 11:03:48 > self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 11:03:48 E AssertionError: 9 != 8 : There should be 8 TAPI nodes 11:03:48 11:03:48 transportpce_tests/tapi/test02_full_topology.py:282: AssertionError 11:03:48 =========================== short test summary info ============================ 11:03:48 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_12_check_openroadm_topology 11:03:48 FAILED transportpce_tests/tapi/test02_full_topology.py::TransportPCEtesting::test_13_get_tapi_topology_details 11:03:48 2 failed, 28 passed in 294.55s (0:04:54) 11:03:48 tests_tapi: exit 1 (528.17 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=30684 11:03:48 tests_tapi: FAIL ✖ in 8 minutes 59.64 seconds 11:03:48 tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 11:03:54 tests71: freeze> python -m pip freeze --all 11:03:54 tests71: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 11:03:54 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 11:03:54 using environment variables from ./karaf71.env 11:03:54 pytest -q transportpce_tests/7.1/test01_portmapping.py 11:04:25 ............ [100%] 11:04:38 12 passed in 43.29s 11:04:38 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 11:05:03 ...............................................FF.FF.FF.FF............. [100%] 11:07:13 62 passed in 155.27s (0:02:35) 11:07:13 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 11:07:44 ................................................ [100%] 11:09:27 48 passed in 133.92s (0:02:13) 11:09:27 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 11:09:47 F........................ [100%] 11:10:40 22 passed in 72.03s (0:01:12) 11:10:40 tests71: OK ✔ in 6 minutes 51.88 seconds 11:10:40 tests221: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 11:10:46 tests221: freeze> python -m pip freeze --all 11:10:46 tests221: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 11:10:46 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 11:10:46 using environment variables from ./karaf221.env 11:10:46 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 11:11:22 ................................... [100%] 11:12:01 35 passed in 75.05s (0:01:15) 11:12:01 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 11:12:33 .F..F. [100%] 11:12:46 =================================== FAILURES =================================== 11:12:46 _____ TransportPCEtesting.test_02_compareOpenroadmTopologyPortMapping_rdm ______ 11:12:46 11:12:46 self = 11:12:46 11:12:46 def test_02_compareOpenroadmTopologyPortMapping_rdm(self): 11:12:46 resTopo = test_utils.get_ietf_network_request('openroadm-topology', 'config') 11:12:46 self.assertEqual(resTopo['status_code'], requests.codes.ok) 11:12:46 nbMapCumul = 0 11:12:46 nbMappings = 0 11:12:46 for node in resTopo['network'][0]['node']: 11:12:46 nodeId = node['node-id'] 11:12:46 # pylint: disable=consider-using-f-string 11:12:46 print("nodeId={}".format(nodeId)) 11:12:46 nodeMapId = nodeId.split("-")[0] + "-" + nodeId.split("-")[1] 11:12:46 print("nodeMapId={}".format(nodeMapId)) 11:12:46 response = test_utils.get_portmapping_node_attr(nodeMapId, "node-info", None) 11:12:46 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:46 E AssertionError: 409 != 200 11:12:46 11:12:46 transportpce_tests/2.2.1/test02_topo_portmapping.py:64: AssertionError 11:12:46 ----------------------------- Captured stdout call ----------------------------- 11:12:46 nodeId=ROADM-A1-SRG3 11:12:46 nodeMapId=ROADM-A1 11:12:46 nodeId=ROADM-A1-DEG1 11:12:46 nodeMapId=ROADM-A1 11:12:46 nodeId=TAPI-SBI-ABS-NODE 11:12:46 nodeMapId=TAPI-SBI 11:12:46 _____ TransportPCEtesting.test_05_compareOpenroadmTopologyPortMapping_xpdr _____ 11:12:46 11:12:46 self = 11:12:46 11:12:46 def test_05_compareOpenroadmTopologyPortMapping_xpdr(self): 11:12:46 > self.test_02_compareOpenroadmTopologyPortMapping_rdm() 11:12:46 11:12:46 transportpce_tests/2.2.1/test02_topo_portmapping.py:91: 11:12:46 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:46 transportpce_tests/2.2.1/test02_topo_portmapping.py:64: in test_02_compareOpenroadmTopologyPortMapping_rdm 11:12:46 self.assertEqual(response['status_code'], requests.codes.ok) 11:12:46 E AssertionError: 409 != 200 11:12:46 ----------------------------- Captured stdout call ----------------------------- 11:12:46 nodeId=TAPI-SBI-ABS-NODE 11:12:46 nodeMapId=TAPI-SBI 11:12:46 =========================== short test summary info ============================ 11:12:46 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TransportPCEtesting::test_02_compareOpenroadmTopologyPortMapping_rdm 11:12:46 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TransportPCEtesting::test_05_compareOpenroadmTopologyPortMapping_xpdr 11:12:46 2 failed, 4 passed in 44.63s 11:12:46 tests221: exit 1 (120.13 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 pid=40984 11:12:52 FFF [100%] 11:12:56 =================================== FAILURES =================================== 11:12:56 _________ TransportPCEPortMappingTesting.test_08_xpdr_device_connected _________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_08_xpdr_device_connected(self): 11:12:56 response = test_utils.check_device_connection("XPDRA01") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:104: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_08_xpdr_device_connected 11:12:56 _________ TransportPCEPortMappingTesting.test_09_xpdr_portmapping_info _________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_09_xpdr_portmapping_info(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "node-info", None) 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:110: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_09_xpdr_portmapping_info 11:12:56 _______ TransportPCEPortMappingTesting.test_10_xpdr_portmapping_NETWORK1 _______ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_10_xpdr_portmapping_NETWORK1(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK1") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:123: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_10_xpdr_portmapping_NETWORK1 11:12:56 _______ TransportPCEPortMappingTesting.test_11_xpdr_portmapping_NETWORK2 _______ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_11_xpdr_portmapping_NETWORK2(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-NETWORK2") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:134: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_11_xpdr_portmapping_NETWORK2 11:12:56 _______ TransportPCEPortMappingTesting.test_12_xpdr_portmapping_CLIENT1 ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_12_xpdr_portmapping_CLIENT1(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT1") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:145: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_12_xpdr_portmapping_CLIENT1 11:12:56 _______ TransportPCEPortMappingTesting.test_13_xpdr_portmapping_CLIENT2 ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_13_xpdr_portmapping_CLIENT2(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT2") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:157: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_13_xpdr_portmapping_CLIENT2 11:12:56 _______ TransportPCEPortMappingTesting.test_14_xpdr_portmapping_CLIENT3 ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_14_xpdr_portmapping_CLIENT3(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT3") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:169: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_14_xpdr_portmapping_CLIENT3 11:12:56 _______ TransportPCEPortMappingTesting.test_15_xpdr_portmapping_CLIENT4 ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_15_xpdr_portmapping_CLIENT4(self): 11:12:56 response = test_utils.get_portmapping_node_attr("XPDRA01", "mapping", "XPDR1-CLIENT4") 11:12:56 > self.assertEqual(response['status_code'], requests.codes.ok) 11:12:56 E AssertionError: 409 != 200 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:181: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_15_xpdr_portmapping_CLIENT4 11:12:56 _______ TransportPCEPortMappingTesting.test_16_xpdr_device_disconnection _______ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_16_xpdr_device_disconnection(self): 11:12:56 response = test_utils.unmount_device("XPDRA01") 11:12:56 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 11:12:56 E AssertionError: 409 not found in (200, 204) 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:192: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_16_xpdr_device_disconnection 11:12:56 Searching for pattern 'onDeviceDisConnected:\ XPDRA01' in karaf.log... Pattern not found after 180 seconds! Node XPDRA01 still not deleted from tpce topology... 11:12:56 _______ TransportPCEPortMappingTesting.test_19_rdm_device_disconnection ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_19_rdm_device_disconnection(self): 11:12:56 response = test_utils.unmount_device("ROADMA01") 11:12:56 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 11:12:56 E AssertionError: 409 not found in (200, 204) 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:212: AssertionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_19_rdm_device_disconnection 11:12:56 Searching for pattern 'onDeviceDisConnected:\ ROADMA01' in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not deleted from tpce topology... 11:12:56 ________ TransportPCEPortMappingTesting.test_20_rdm_device_disconnected ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def _new_conn(self) -> socket.socket: 11:12:56 """Establish a socket connection and set nodelay settings on it. 11:12:56 11:12:56 :return: New socket connection. 11:12:56 """ 11:12:56 try: 11:12:56 > sock = connection.create_connection( 11:12:56 (self._dns_host, self.port), 11:12:56 self.timeout, 11:12:56 source_address=self.source_address, 11:12:56 socket_options=self.socket_options, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 11:12:56 raise err 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 address = ('localhost', 8182), timeout = 10, source_address = None 11:12:56 socket_options = [(6, 1, 1)] 11:12:56 11:12:56 def create_connection( 11:12:56 address: tuple[str, int], 11:12:56 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 11:12:56 source_address: tuple[str, int] | None = None, 11:12:56 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 11:12:56 ) -> socket.socket: 11:12:56 """Connect to *address* and return the socket object. 11:12:56 11:12:56 Convenience function. Connect to *address* (a 2-tuple ``(host, 11:12:56 port)``) and return the socket object. Passing the optional 11:12:56 *timeout* parameter will set the timeout on the socket instance 11:12:56 before attempting to connect. If no *timeout* is supplied, the 11:12:56 global default timeout setting returned by :func:`socket.getdefaulttimeout` 11:12:56 is used. If *source_address* is set it must be a tuple of (host, port) 11:12:56 for the socket to bind as a source address before making the connection. 11:12:56 An host of '' or port 0 tells the OS to use the default. 11:12:56 """ 11:12:56 11:12:56 host, port = address 11:12:56 if host.startswith("["): 11:12:56 host = host.strip("[]") 11:12:56 err = None 11:12:56 11:12:56 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 11:12:56 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 11:12:56 # The original create_connection function always returns all records. 11:12:56 family = allowed_gai_family() 11:12:56 11:12:56 try: 11:12:56 host.encode("idna") 11:12:56 except UnicodeError: 11:12:56 raise LocationParseError(f"'{host}', label empty or too long") from None 11:12:56 11:12:56 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 11:12:56 af, socktype, proto, canonname, sa = res 11:12:56 sock = None 11:12:56 try: 11:12:56 sock = socket.socket(af, socktype, proto) 11:12:56 11:12:56 # If provided, set socket level options before connecting. 11:12:56 _set_socket_options(sock, socket_options) 11:12:56 11:12:56 if timeout is not _DEFAULT_TIMEOUT: 11:12:56 sock.settimeout(timeout) 11:12:56 if source_address: 11:12:56 sock.bind(source_address) 11:12:56 > sock.connect(sa) 11:12:56 E ConnectionRefusedError: [Errno 111] Connection refused 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 11:12:56 11:12:56 The above exception was the direct cause of the following exception: 11:12:56 11:12:56 self = 11:12:56 method = 'GET' 11:12:56 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 11:12:56 body = None 11:12:56 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='} 11:12:56 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 11:12:56 redirect = False, assert_same_host = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 11:12:56 release_conn = False, chunked = False, body_pos = None, preload_content = False 11:12:56 decode_content = False, response_kw = {} 11:12:56 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01', query='content=nonconfig', fragment=None) 11:12:56 destination_scheme = None, conn = None, release_this_conn = True 11:12:56 http_tunnel_required = False, err = None, clean_exit = False 11:12:56 11:12:56 def urlopen( # type: ignore[override] 11:12:56 self, 11:12:56 method: str, 11:12:56 url: str, 11:12:56 body: _TYPE_BODY | None = None, 11:12:56 headers: typing.Mapping[str, str] | None = None, 11:12:56 retries: Retry | bool | int | None = None, 11:12:56 redirect: bool = True, 11:12:56 assert_same_host: bool = True, 11:12:56 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 11:12:56 pool_timeout: int | None = None, 11:12:56 release_conn: bool | None = None, 11:12:56 chunked: bool = False, 11:12:56 body_pos: _TYPE_BODY_POSITION | None = None, 11:12:56 preload_content: bool = True, 11:12:56 decode_content: bool = True, 11:12:56 **response_kw: typing.Any, 11:12:56 ) -> BaseHTTPResponse: 11:12:56 """ 11:12:56 Get a connection from the pool and perform an HTTP request. This is the 11:12:56 lowest level call for making a request, so you'll need to specify all 11:12:56 the raw details. 11:12:56 11:12:56 .. note:: 11:12:56 11:12:56 More commonly, it's appropriate to use a convenience method 11:12:56 such as :meth:`request`. 11:12:56 11:12:56 .. note:: 11:12:56 11:12:56 `release_conn` will only behave as expected if 11:12:56 `preload_content=False` because we want to make 11:12:56 `preload_content=False` the default behaviour someday soon without 11:12:56 breaking backwards compatibility. 11:12:56 11:12:56 :param method: 11:12:56 HTTP request method (such as GET, POST, PUT, etc.) 11:12:56 11:12:56 :param url: 11:12:56 The URL to perform the request on. 11:12:56 11:12:56 :param body: 11:12:56 Data to send in the request body, either :class:`str`, :class:`bytes`, 11:12:56 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 11:12:56 11:12:56 :param headers: 11:12:56 Dictionary of custom headers to send, such as User-Agent, 11:12:56 If-None-Match, etc. If None, pool headers are used. If provided, 11:12:56 these headers completely replace any pool-specific headers. 11:12:56 11:12:56 :param retries: 11:12:56 Configure the number of retries to allow before raising a 11:12:56 :class:`~urllib3.exceptions.MaxRetryError` exception. 11:12:56 11:12:56 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 11:12:56 :class:`~urllib3.util.retry.Retry` object for fine-grained control 11:12:56 over different types of retries. 11:12:56 Pass an integer number to retry connection errors that many times, 11:12:56 but no other types of errors. Pass zero to never retry. 11:12:56 11:12:56 If ``False``, then retries are disabled and any exception is raised 11:12:56 immediately. Also, instead of raising a MaxRetryError on redirects, 11:12:56 the redirect response will be returned. 11:12:56 11:12:56 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 11:12:56 11:12:56 :param redirect: 11:12:56 If True, automatically handle redirects (status codes 301, 302, 11:12:56 303, 307, 308). Each redirect counts as a retry. Disabling retries 11:12:56 will disable redirect, too. 11:12:56 11:12:56 :param assert_same_host: 11:12:56 If ``True``, will make sure that the host of the pool requests is 11:12:56 consistent else will raise HostChangedError. When ``False``, you can 11:12:56 use the pool on an HTTP proxy and request foreign hosts. 11:12:56 11:12:56 :param timeout: 11:12:56 If specified, overrides the default timeout for this one 11:12:56 request. It may be a float (in seconds) or an instance of 11:12:56 :class:`urllib3.util.Timeout`. 11:12:56 11:12:56 :param pool_timeout: 11:12:56 If set and the pool is set to block=True, then this method will 11:12:56 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 11:12:56 connection is available within the time period. 11:12:56 11:12:56 :param bool preload_content: 11:12:56 If True, the response's body will be preloaded into memory. 11:12:56 11:12:56 :param bool decode_content: 11:12:56 If True, will attempt to decode the body based on the 11:12:56 'content-encoding' header. 11:12:56 11:12:56 :param release_conn: 11:12:56 If False, then the urlopen call will not release the connection 11:12:56 back into the pool once a response is received (but will release if 11:12:56 you read the entire contents of the response such as when 11:12:56 `preload_content=True`). This is useful if you're not preloading 11:12:56 the response's content immediately. You will need to call 11:12:56 ``r.release_conn()`` on the response ``r`` to return the connection 11:12:56 back into the pool. If None, it takes the value of ``preload_content`` 11:12:56 which defaults to ``True``. 11:12:56 11:12:56 :param bool chunked: 11:12:56 If True, urllib3 will send the body using chunked transfer 11:12:56 encoding. Otherwise, urllib3 will send the body using the standard 11:12:56 content-length form. Defaults to False. 11:12:56 11:12:56 :param int body_pos: 11:12:56 Position to seek to in file-like body in the event of a retry or 11:12:56 redirect. Typically this won't need to be set because urllib3 will 11:12:56 auto-populate the value when needed. 11:12:56 """ 11:12:56 parsed_url = parse_url(url) 11:12:56 destination_scheme = parsed_url.scheme 11:12:56 11:12:56 if headers is None: 11:12:56 headers = self.headers 11:12:56 11:12:56 if not isinstance(retries, Retry): 11:12:56 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 11:12:56 11:12:56 if release_conn is None: 11:12:56 release_conn = preload_content 11:12:56 11:12:56 # Check host 11:12:56 if assert_same_host and not self.is_same_host(url): 11:12:56 raise HostChangedError(self, url, retries) 11:12:56 11:12:56 # Ensure that the URL we're connecting to is properly encoded 11:12:56 if url.startswith("/"): 11:12:56 url = to_str(_encode_target(url)) 11:12:56 else: 11:12:56 url = to_str(parsed_url.url) 11:12:56 11:12:56 conn = None 11:12:56 11:12:56 # Track whether `conn` needs to be released before 11:12:56 # returning/raising/recursing. Update this variable if necessary, and 11:12:56 # leave `release_conn` constant throughout the function. That way, if 11:12:56 # the function recurses, the original value of `release_conn` will be 11:12:56 # passed down into the recursive call, and its value will be respected. 11:12:56 # 11:12:56 # See issue #651 [1] for details. 11:12:56 # 11:12:56 # [1] 11:12:56 release_this_conn = release_conn 11:12:56 11:12:56 http_tunnel_required = connection_requires_http_tunnel( 11:12:56 self.proxy, self.proxy_config, destination_scheme 11:12:56 ) 11:12:56 11:12:56 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 11:12:56 # have to copy the headers dict so we can safely change it without those 11:12:56 # changes being reflected in anyone else's copy. 11:12:56 if not http_tunnel_required: 11:12:56 headers = headers.copy() # type: ignore[attr-defined] 11:12:56 headers.update(self.proxy_headers) # type: ignore[union-attr] 11:12:56 11:12:56 # Must keep the exception bound to a separate variable or else Python 3 11:12:56 # complains about UnboundLocalError. 11:12:56 err = None 11:12:56 11:12:56 # Keep track of whether we cleanly exited the except block. This 11:12:56 # ensures we do proper cleanup in finally. 11:12:56 clean_exit = False 11:12:56 11:12:56 # Rewind body position, if needed. Record current position 11:12:56 # for future rewinds in the event of a redirect/retry. 11:12:56 body_pos = set_file_position(body, body_pos) 11:12:56 11:12:56 try: 11:12:56 # Request a connection from the queue. 11:12:56 timeout_obj = self._get_timeout(timeout) 11:12:56 conn = self._get_conn(timeout=pool_timeout) 11:12:56 11:12:56 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 11:12:56 11:12:56 # Is this a closed/new connection that requires CONNECT tunnelling? 11:12:56 if self.proxy is not None and http_tunnel_required and conn.is_closed: 11:12:56 try: 11:12:56 self._prepare_proxy(conn) 11:12:56 except (BaseSSLError, OSError, SocketTimeout) as e: 11:12:56 self._raise_timeout( 11:12:56 err=e, url=self.proxy.url, timeout_value=conn.timeout 11:12:56 ) 11:12:56 raise 11:12:56 11:12:56 # If we're going to release the connection in ``finally:``, then 11:12:56 # the response doesn't need to know about the connection. Otherwise 11:12:56 # it will also try to release it and we'll have a double-release 11:12:56 # mess. 11:12:56 response_conn = conn if not release_conn else None 11:12:56 11:12:56 # Make the request on the HTTPConnection object 11:12:56 > response = self._make_request( 11:12:56 conn, 11:12:56 method, 11:12:56 url, 11:12:56 timeout=timeout_obj, 11:12:56 body=body, 11:12:56 headers=headers, 11:12:56 chunked=chunked, 11:12:56 retries=retries, 11:12:56 response_conn=response_conn, 11:12:56 preload_content=preload_content, 11:12:56 decode_content=decode_content, 11:12:56 **response_kw, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 11:12:56 conn.request( 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 11:12:56 self.endheaders() 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 11:12:56 self._send_output(message_body, encode_chunked=encode_chunked) 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 11:12:56 self.send(msg) 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 11:12:56 self.connect() 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 11:12:56 self.sock = self._new_conn() 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def _new_conn(self) -> socket.socket: 11:12:56 """Establish a socket connection and set nodelay settings on it. 11:12:56 11:12:56 :return: New socket connection. 11:12:56 """ 11:12:56 try: 11:12:56 sock = connection.create_connection( 11:12:56 (self._dns_host, self.port), 11:12:56 self.timeout, 11:12:56 source_address=self.source_address, 11:12:56 socket_options=self.socket_options, 11:12:56 ) 11:12:56 except socket.gaierror as e: 11:12:56 raise NameResolutionError(self.host, self, e) from e 11:12:56 except SocketTimeout as e: 11:12:56 raise ConnectTimeoutError( 11:12:56 self, 11:12:56 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 11:12:56 ) from e 11:12:56 11:12:56 except OSError as e: 11:12:56 > raise NewConnectionError( 11:12:56 self, f"Failed to establish a new connection: {e}" 11:12:56 ) from e 11:12:56 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 11:12:56 11:12:56 The above exception was the direct cause of the following exception: 11:12:56 11:12:56 self = 11:12:56 request = , stream = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 11:12:56 proxies = OrderedDict() 11:12:56 11:12:56 def send( 11:12:56 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:12:56 ): 11:12:56 """Sends PreparedRequest object. Returns Response object. 11:12:56 11:12:56 :param request: The :class:`PreparedRequest ` being sent. 11:12:56 :param stream: (optional) Whether to stream the request content. 11:12:56 :param timeout: (optional) How long to wait for the server to send 11:12:56 data before giving up, as a float, or a :ref:`(connect timeout, 11:12:56 read timeout) ` tuple. 11:12:56 :type timeout: float or tuple or urllib3 Timeout object 11:12:56 :param verify: (optional) Either a boolean, in which case it controls whether 11:12:56 we verify the server's TLS certificate, or a string, in which case it 11:12:56 must be a path to a CA bundle to use 11:12:56 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:12:56 :param proxies: (optional) The proxies dictionary to apply to the request. 11:12:56 :rtype: requests.Response 11:12:56 """ 11:12:56 11:12:56 try: 11:12:56 conn = self.get_connection_with_tls_context( 11:12:56 request, verify, proxies=proxies, cert=cert 11:12:56 ) 11:12:56 except LocationValueError as e: 11:12:56 raise InvalidURL(e, request=request) 11:12:56 11:12:56 self.cert_verify(conn, request.url, verify, cert) 11:12:56 url = self.request_url(request, proxies) 11:12:56 self.add_headers( 11:12:56 request, 11:12:56 stream=stream, 11:12:56 timeout=timeout, 11:12:56 verify=verify, 11:12:56 cert=cert, 11:12:56 proxies=proxies, 11:12:56 ) 11:12:56 11:12:56 chunked = not (request.body is None or "Content-Length" in request.headers) 11:12:56 11:12:56 if isinstance(timeout, tuple): 11:12:56 try: 11:12:56 connect, read = timeout 11:12:56 timeout = TimeoutSauce(connect=connect, read=read) 11:12:56 except ValueError: 11:12:56 raise ValueError( 11:12:56 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:12:56 f"or a single float to set both timeouts to the same value." 11:12:56 ) 11:12:56 elif isinstance(timeout, TimeoutSauce): 11:12:56 pass 11:12:56 else: 11:12:56 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:12:56 11:12:56 try: 11:12:56 > resp = conn.urlopen( 11:12:56 method=request.method, 11:12:56 url=url, 11:12:56 body=request.body, 11:12:56 headers=request.headers, 11:12:56 redirect=False, 11:12:56 assert_same_host=False, 11:12:56 preload_content=False, 11:12:56 decode_content=False, 11:12:56 retries=self.max_retries, 11:12:56 timeout=timeout, 11:12:56 chunked=chunked, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 11:12:56 retries = retries.increment( 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 11:12:56 method = 'GET' 11:12:56 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig' 11:12:56 response = None 11:12:56 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 11:12:56 _pool = 11:12:56 _stacktrace = 11:12:56 11:12:56 def increment( 11:12:56 self, 11:12:56 method: str | None = None, 11:12:56 url: str | None = None, 11:12:56 response: BaseHTTPResponse | None = None, 11:12:56 error: Exception | None = None, 11:12:56 _pool: ConnectionPool | None = None, 11:12:56 _stacktrace: TracebackType | None = None, 11:12:56 ) -> Self: 11:12:56 """Return a new Retry object with incremented retry counters. 11:12:56 11:12:56 :param response: A response object, or None, if the server did not 11:12:56 return a response. 11:12:56 :type response: :class:`~urllib3.response.BaseHTTPResponse` 11:12:56 :param Exception error: An error encountered during the request, or 11:12:56 None if the response was received successfully. 11:12:56 11:12:56 :return: A new ``Retry`` object. 11:12:56 """ 11:12:56 if self.total is False and error: 11:12:56 # Disabled, indicate to re-raise the error. 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 11:12:56 total = self.total 11:12:56 if total is not None: 11:12:56 total -= 1 11:12:56 11:12:56 connect = self.connect 11:12:56 read = self.read 11:12:56 redirect = self.redirect 11:12:56 status_count = self.status 11:12:56 other = self.other 11:12:56 cause = "unknown" 11:12:56 status = None 11:12:56 redirect_location = None 11:12:56 11:12:56 if error and self._is_connection_error(error): 11:12:56 # Connect retry? 11:12:56 if connect is False: 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 elif connect is not None: 11:12:56 connect -= 1 11:12:56 11:12:56 elif error and self._is_read_error(error): 11:12:56 # Read retry? 11:12:56 if read is False or method is None or not self._is_method_retryable(method): 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 elif read is not None: 11:12:56 read -= 1 11:12:56 11:12:56 elif error: 11:12:56 # Other retry? 11:12:56 if other is not None: 11:12:56 other -= 1 11:12:56 11:12:56 elif response and response.get_redirect_location(): 11:12:56 # Redirect retry? 11:12:56 if redirect is not None: 11:12:56 redirect -= 1 11:12:56 cause = "too many redirects" 11:12:56 response_redirect_location = response.get_redirect_location() 11:12:56 if response_redirect_location: 11:12:56 redirect_location = response_redirect_location 11:12:56 status = response.status 11:12:56 11:12:56 else: 11:12:56 # Incrementing because of a server error like a 500 in 11:12:56 # status_forcelist and the given method is in the allowed_methods 11:12:56 cause = ResponseError.GENERIC_ERROR 11:12:56 if response and response.status: 11:12:56 if status_count is not None: 11:12:56 status_count -= 1 11:12:56 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 11:12:56 status = response.status 11:12:56 11:12:56 history = self.history + ( 11:12:56 RequestHistory(method, url, error, status, redirect_location), 11:12:56 ) 11:12:56 11:12:56 new_retry = self.new( 11:12:56 total=total, 11:12:56 connect=connect, 11:12:56 read=read, 11:12:56 redirect=redirect, 11:12:56 status=status_count, 11:12:56 other=other, 11:12:56 history=history, 11:12:56 ) 11:12:56 11:12:56 if new_retry.is_exhausted(): 11:12:56 reason = error or ResponseError(cause) 11:12:56 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 11:12:56 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 11:12:56 11:12:56 During handling of the above exception, another exception occurred: 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_20_rdm_device_disconnected(self): 11:12:56 > response = test_utils.check_device_connection("ROADMA01") 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:215: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 transportpce_tests/common/test_utils.py:369: in check_device_connection 11:12:56 response = get_request(url[RESTCONF_VERSION].format('{}', node)) 11:12:56 transportpce_tests/common/test_utils.py:116: in get_request 11:12:56 return requests.request( 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 11:12:56 return session.request(method=method, url=url, **kwargs) 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 11:12:56 resp = self.send(prep, **send_kwargs) 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 11:12:56 r = adapter.send(request, **kwargs) 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = 11:12:56 request = , stream = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 11:12:56 proxies = OrderedDict() 11:12:56 11:12:56 def send( 11:12:56 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:12:56 ): 11:12:56 """Sends PreparedRequest object. Returns Response object. 11:12:56 11:12:56 :param request: The :class:`PreparedRequest ` being sent. 11:12:56 :param stream: (optional) Whether to stream the request content. 11:12:56 :param timeout: (optional) How long to wait for the server to send 11:12:56 data before giving up, as a float, or a :ref:`(connect timeout, 11:12:56 read timeout) ` tuple. 11:12:56 :type timeout: float or tuple or urllib3 Timeout object 11:12:56 :param verify: (optional) Either a boolean, in which case it controls whether 11:12:56 we verify the server's TLS certificate, or a string, in which case it 11:12:56 must be a path to a CA bundle to use 11:12:56 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:12:56 :param proxies: (optional) The proxies dictionary to apply to the request. 11:12:56 :rtype: requests.Response 11:12:56 """ 11:12:56 11:12:56 try: 11:12:56 conn = self.get_connection_with_tls_context( 11:12:56 request, verify, proxies=proxies, cert=cert 11:12:56 ) 11:12:56 except LocationValueError as e: 11:12:56 raise InvalidURL(e, request=request) 11:12:56 11:12:56 self.cert_verify(conn, request.url, verify, cert) 11:12:56 url = self.request_url(request, proxies) 11:12:56 self.add_headers( 11:12:56 request, 11:12:56 stream=stream, 11:12:56 timeout=timeout, 11:12:56 verify=verify, 11:12:56 cert=cert, 11:12:56 proxies=proxies, 11:12:56 ) 11:12:56 11:12:56 chunked = not (request.body is None or "Content-Length" in request.headers) 11:12:56 11:12:56 if isinstance(timeout, tuple): 11:12:56 try: 11:12:56 connect, read = timeout 11:12:56 timeout = TimeoutSauce(connect=connect, read=read) 11:12:56 except ValueError: 11:12:56 raise ValueError( 11:12:56 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:12:56 f"or a single float to set both timeouts to the same value." 11:12:56 ) 11:12:56 elif isinstance(timeout, TimeoutSauce): 11:12:56 pass 11:12:56 else: 11:12:56 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:12:56 11:12:56 try: 11:12:56 resp = conn.urlopen( 11:12:56 method=request.method, 11:12:56 url=url, 11:12:56 body=request.body, 11:12:56 headers=request.headers, 11:12:56 redirect=False, 11:12:56 assert_same_host=False, 11:12:56 preload_content=False, 11:12:56 decode_content=False, 11:12:56 retries=self.max_retries, 11:12:56 timeout=timeout, 11:12:56 chunked=chunked, 11:12:56 ) 11:12:56 11:12:56 except (ProtocolError, OSError) as err: 11:12:56 raise ConnectionError(err, request=request) 11:12:56 11:12:56 except MaxRetryError as e: 11:12:56 if isinstance(e.reason, ConnectTimeoutError): 11:12:56 # TODO: Remove this in 3.0.0: see #2811 11:12:56 if not isinstance(e.reason, NewConnectionError): 11:12:56 raise ConnectTimeout(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, ResponseError): 11:12:56 raise RetryError(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, _ProxyError): 11:12:56 raise ProxyError(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, _SSLError): 11:12:56 # This branch is for urllib3 v1.22 and later. 11:12:56 raise SSLError(e, request=request) 11:12:56 11:12:56 > raise ConnectionError(e, request=request) 11:12:56 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADMA01?content=nonconfig (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_20_rdm_device_disconnected 11:12:56 _______ TransportPCEPortMappingTesting.test_21_rdm_device_not_connected ________ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def _new_conn(self) -> socket.socket: 11:12:56 """Establish a socket connection and set nodelay settings on it. 11:12:56 11:12:56 :return: New socket connection. 11:12:56 """ 11:12:56 try: 11:12:56 > sock = connection.create_connection( 11:12:56 (self._dns_host, self.port), 11:12:56 self.timeout, 11:12:56 source_address=self.source_address, 11:12:56 socket_options=self.socket_options, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:199: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 11:12:56 raise err 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 address = ('localhost', 8182), timeout = 10, source_address = None 11:12:56 socket_options = [(6, 1, 1)] 11:12:56 11:12:56 def create_connection( 11:12:56 address: tuple[str, int], 11:12:56 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 11:12:56 source_address: tuple[str, int] | None = None, 11:12:56 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 11:12:56 ) -> socket.socket: 11:12:56 """Connect to *address* and return the socket object. 11:12:56 11:12:56 Convenience function. Connect to *address* (a 2-tuple ``(host, 11:12:56 port)``) and return the socket object. Passing the optional 11:12:56 *timeout* parameter will set the timeout on the socket instance 11:12:56 before attempting to connect. If no *timeout* is supplied, the 11:12:56 global default timeout setting returned by :func:`socket.getdefaulttimeout` 11:12:56 is used. If *source_address* is set it must be a tuple of (host, port) 11:12:56 for the socket to bind as a source address before making the connection. 11:12:56 An host of '' or port 0 tells the OS to use the default. 11:12:56 """ 11:12:56 11:12:56 host, port = address 11:12:56 if host.startswith("["): 11:12:56 host = host.strip("[]") 11:12:56 err = None 11:12:56 11:12:56 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 11:12:56 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 11:12:56 # The original create_connection function always returns all records. 11:12:56 family = allowed_gai_family() 11:12:56 11:12:56 try: 11:12:56 host.encode("idna") 11:12:56 except UnicodeError: 11:12:56 raise LocationParseError(f"'{host}', label empty or too long") from None 11:12:56 11:12:56 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 11:12:56 af, socktype, proto, canonname, sa = res 11:12:56 sock = None 11:12:56 try: 11:12:56 sock = socket.socket(af, socktype, proto) 11:12:56 11:12:56 # If provided, set socket level options before connecting. 11:12:56 _set_socket_options(sock, socket_options) 11:12:56 11:12:56 if timeout is not _DEFAULT_TIMEOUT: 11:12:56 sock.settimeout(timeout) 11:12:56 if source_address: 11:12:56 sock.bind(source_address) 11:12:56 > sock.connect(sa) 11:12:56 E ConnectionRefusedError: [Errno 111] Connection refused 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 11:12:56 11:12:56 The above exception was the direct cause of the following exception: 11:12:56 11:12:56 self = 11:12:56 method = 'GET' 11:12:56 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info' 11:12:56 body = None 11:12:56 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='} 11:12:56 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 11:12:56 redirect = False, assert_same_host = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), pool_timeout = None 11:12:56 release_conn = False, chunked = False, body_pos = None, preload_content = False 11:12:56 decode_content = False, response_kw = {} 11:12:56 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info', query=None, fragment=None) 11:12:56 destination_scheme = None, conn = None, release_this_conn = True 11:12:56 http_tunnel_required = False, err = None, clean_exit = False 11:12:56 11:12:56 def urlopen( # type: ignore[override] 11:12:56 self, 11:12:56 method: str, 11:12:56 url: str, 11:12:56 body: _TYPE_BODY | None = None, 11:12:56 headers: typing.Mapping[str, str] | None = None, 11:12:56 retries: Retry | bool | int | None = None, 11:12:56 redirect: bool = True, 11:12:56 assert_same_host: bool = True, 11:12:56 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 11:12:56 pool_timeout: int | None = None, 11:12:56 release_conn: bool | None = None, 11:12:56 chunked: bool = False, 11:12:56 body_pos: _TYPE_BODY_POSITION | None = None, 11:12:56 preload_content: bool = True, 11:12:56 decode_content: bool = True, 11:12:56 **response_kw: typing.Any, 11:12:56 ) -> BaseHTTPResponse: 11:12:56 """ 11:12:56 Get a connection from the pool and perform an HTTP request. This is the 11:12:56 lowest level call for making a request, so you'll need to specify all 11:12:56 the raw details. 11:12:56 11:12:56 .. note:: 11:12:56 11:12:56 More commonly, it's appropriate to use a convenience method 11:12:56 such as :meth:`request`. 11:12:56 11:12:56 .. note:: 11:12:56 11:12:56 `release_conn` will only behave as expected if 11:12:56 `preload_content=False` because we want to make 11:12:56 `preload_content=False` the default behaviour someday soon without 11:12:56 breaking backwards compatibility. 11:12:56 11:12:56 :param method: 11:12:56 HTTP request method (such as GET, POST, PUT, etc.) 11:12:56 11:12:56 :param url: 11:12:56 The URL to perform the request on. 11:12:56 11:12:56 :param body: 11:12:56 Data to send in the request body, either :class:`str`, :class:`bytes`, 11:12:56 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 11:12:56 11:12:56 :param headers: 11:12:56 Dictionary of custom headers to send, such as User-Agent, 11:12:56 If-None-Match, etc. If None, pool headers are used. If provided, 11:12:56 these headers completely replace any pool-specific headers. 11:12:56 11:12:56 :param retries: 11:12:56 Configure the number of retries to allow before raising a 11:12:56 :class:`~urllib3.exceptions.MaxRetryError` exception. 11:12:56 11:12:56 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 11:12:56 :class:`~urllib3.util.retry.Retry` object for fine-grained control 11:12:56 over different types of retries. 11:12:56 Pass an integer number to retry connection errors that many times, 11:12:56 but no other types of errors. Pass zero to never retry. 11:12:56 11:12:56 If ``False``, then retries are disabled and any exception is raised 11:12:56 immediately. Also, instead of raising a MaxRetryError on redirects, 11:12:56 the redirect response will be returned. 11:12:56 11:12:56 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 11:12:56 11:12:56 :param redirect: 11:12:56 If True, automatically handle redirects (status codes 301, 302, 11:12:56 303, 307, 308). Each redirect counts as a retry. Disabling retries 11:12:56 will disable redirect, too. 11:12:56 11:12:56 :param assert_same_host: 11:12:56 If ``True``, will make sure that the host of the pool requests is 11:12:56 consistent else will raise HostChangedError. When ``False``, you can 11:12:56 use the pool on an HTTP proxy and request foreign hosts. 11:12:56 11:12:56 :param timeout: 11:12:56 If specified, overrides the default timeout for this one 11:12:56 request. It may be a float (in seconds) or an instance of 11:12:56 :class:`urllib3.util.Timeout`. 11:12:56 11:12:56 :param pool_timeout: 11:12:56 If set and the pool is set to block=True, then this method will 11:12:56 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 11:12:56 connection is available within the time period. 11:12:56 11:12:56 :param bool preload_content: 11:12:56 If True, the response's body will be preloaded into memory. 11:12:56 11:12:56 :param bool decode_content: 11:12:56 If True, will attempt to decode the body based on the 11:12:56 'content-encoding' header. 11:12:56 11:12:56 :param release_conn: 11:12:56 If False, then the urlopen call will not release the connection 11:12:56 back into the pool once a response is received (but will release if 11:12:56 you read the entire contents of the response such as when 11:12:56 `preload_content=True`). This is useful if you're not preloading 11:12:56 the response's content immediately. You will need to call 11:12:56 ``r.release_conn()`` on the response ``r`` to return the connection 11:12:56 back into the pool. If None, it takes the value of ``preload_content`` 11:12:56 which defaults to ``True``. 11:12:56 11:12:56 :param bool chunked: 11:12:56 If True, urllib3 will send the body using chunked transfer 11:12:56 encoding. Otherwise, urllib3 will send the body using the standard 11:12:56 content-length form. Defaults to False. 11:12:56 11:12:56 :param int body_pos: 11:12:56 Position to seek to in file-like body in the event of a retry or 11:12:56 redirect. Typically this won't need to be set because urllib3 will 11:12:56 auto-populate the value when needed. 11:12:56 """ 11:12:56 parsed_url = parse_url(url) 11:12:56 destination_scheme = parsed_url.scheme 11:12:56 11:12:56 if headers is None: 11:12:56 headers = self.headers 11:12:56 11:12:56 if not isinstance(retries, Retry): 11:12:56 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 11:12:56 11:12:56 if release_conn is None: 11:12:56 release_conn = preload_content 11:12:56 11:12:56 # Check host 11:12:56 if assert_same_host and not self.is_same_host(url): 11:12:56 raise HostChangedError(self, url, retries) 11:12:56 11:12:56 # Ensure that the URL we're connecting to is properly encoded 11:12:56 if url.startswith("/"): 11:12:56 url = to_str(_encode_target(url)) 11:12:56 else: 11:12:56 url = to_str(parsed_url.url) 11:12:56 11:12:56 conn = None 11:12:56 11:12:56 # Track whether `conn` needs to be released before 11:12:56 # returning/raising/recursing. Update this variable if necessary, and 11:12:56 # leave `release_conn` constant throughout the function. That way, if 11:12:56 # the function recurses, the original value of `release_conn` will be 11:12:56 # passed down into the recursive call, and its value will be respected. 11:12:56 # 11:12:56 # See issue #651 [1] for details. 11:12:56 # 11:12:56 # [1] 11:12:56 release_this_conn = release_conn 11:12:56 11:12:56 http_tunnel_required = connection_requires_http_tunnel( 11:12:56 self.proxy, self.proxy_config, destination_scheme 11:12:56 ) 11:12:56 11:12:56 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 11:12:56 # have to copy the headers dict so we can safely change it without those 11:12:56 # changes being reflected in anyone else's copy. 11:12:56 if not http_tunnel_required: 11:12:56 headers = headers.copy() # type: ignore[attr-defined] 11:12:56 headers.update(self.proxy_headers) # type: ignore[union-attr] 11:12:56 11:12:56 # Must keep the exception bound to a separate variable or else Python 3 11:12:56 # complains about UnboundLocalError. 11:12:56 err = None 11:12:56 11:12:56 # Keep track of whether we cleanly exited the except block. This 11:12:56 # ensures we do proper cleanup in finally. 11:12:56 clean_exit = False 11:12:56 11:12:56 # Rewind body position, if needed. Record current position 11:12:56 # for future rewinds in the event of a redirect/retry. 11:12:56 body_pos = set_file_position(body, body_pos) 11:12:56 11:12:56 try: 11:12:56 # Request a connection from the queue. 11:12:56 timeout_obj = self._get_timeout(timeout) 11:12:56 conn = self._get_conn(timeout=pool_timeout) 11:12:56 11:12:56 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 11:12:56 11:12:56 # Is this a closed/new connection that requires CONNECT tunnelling? 11:12:56 if self.proxy is not None and http_tunnel_required and conn.is_closed: 11:12:56 try: 11:12:56 self._prepare_proxy(conn) 11:12:56 except (BaseSSLError, OSError, SocketTimeout) as e: 11:12:56 self._raise_timeout( 11:12:56 err=e, url=self.proxy.url, timeout_value=conn.timeout 11:12:56 ) 11:12:56 raise 11:12:56 11:12:56 # If we're going to release the connection in ``finally:``, then 11:12:56 # the response doesn't need to know about the connection. Otherwise 11:12:56 # it will also try to release it and we'll have a double-release 11:12:56 # mess. 11:12:56 response_conn = conn if not release_conn else None 11:12:56 11:12:56 # Make the request on the HTTPConnection object 11:12:56 > response = self._make_request( 11:12:56 conn, 11:12:56 method, 11:12:56 url, 11:12:56 timeout=timeout_obj, 11:12:56 body=body, 11:12:56 headers=headers, 11:12:56 chunked=chunked, 11:12:56 retries=retries, 11:12:56 response_conn=response_conn, 11:12:56 preload_content=preload_content, 11:12:56 decode_content=decode_content, 11:12:56 **response_kw, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:789: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:495: in _make_request 11:12:56 conn.request( 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:441: in request 11:12:56 self.endheaders() 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1289: in endheaders 11:12:56 self._send_output(message_body, encode_chunked=encode_chunked) 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:1048: in _send_output 11:12:56 self.send(msg) 11:12:56 /opt/pyenv/versions/3.11.7/lib/python3.11/http/client.py:986: in send 11:12:56 self.connect() 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:279: in connect 11:12:56 self.sock = self._new_conn() 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = 11:12:56 11:12:56 def _new_conn(self) -> socket.socket: 11:12:56 """Establish a socket connection and set nodelay settings on it. 11:12:56 11:12:56 :return: New socket connection. 11:12:56 """ 11:12:56 try: 11:12:56 sock = connection.create_connection( 11:12:56 (self._dns_host, self.port), 11:12:56 self.timeout, 11:12:56 source_address=self.source_address, 11:12:56 socket_options=self.socket_options, 11:12:56 ) 11:12:56 except socket.gaierror as e: 11:12:56 raise NameResolutionError(self.host, self, e) from e 11:12:56 except SocketTimeout as e: 11:12:56 raise ConnectTimeoutError( 11:12:56 self, 11:12:56 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 11:12:56 ) from e 11:12:56 11:12:56 except OSError as e: 11:12:56 > raise NewConnectionError( 11:12:56 self, f"Failed to establish a new connection: {e}" 11:12:56 ) from e 11:12:56 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:214: NewConnectionError 11:12:56 11:12:56 The above exception was the direct cause of the following exception: 11:12:56 11:12:56 self = 11:12:56 request = , stream = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 11:12:56 proxies = OrderedDict() 11:12:56 11:12:56 def send( 11:12:56 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:12:56 ): 11:12:56 """Sends PreparedRequest object. Returns Response object. 11:12:56 11:12:56 :param request: The :class:`PreparedRequest ` being sent. 11:12:56 :param stream: (optional) Whether to stream the request content. 11:12:56 :param timeout: (optional) How long to wait for the server to send 11:12:56 data before giving up, as a float, or a :ref:`(connect timeout, 11:12:56 read timeout) ` tuple. 11:12:56 :type timeout: float or tuple or urllib3 Timeout object 11:12:56 :param verify: (optional) Either a boolean, in which case it controls whether 11:12:56 we verify the server's TLS certificate, or a string, in which case it 11:12:56 must be a path to a CA bundle to use 11:12:56 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:12:56 :param proxies: (optional) The proxies dictionary to apply to the request. 11:12:56 :rtype: requests.Response 11:12:56 """ 11:12:56 11:12:56 try: 11:12:56 conn = self.get_connection_with_tls_context( 11:12:56 request, verify, proxies=proxies, cert=cert 11:12:56 ) 11:12:56 except LocationValueError as e: 11:12:56 raise InvalidURL(e, request=request) 11:12:56 11:12:56 self.cert_verify(conn, request.url, verify, cert) 11:12:56 url = self.request_url(request, proxies) 11:12:56 self.add_headers( 11:12:56 request, 11:12:56 stream=stream, 11:12:56 timeout=timeout, 11:12:56 verify=verify, 11:12:56 cert=cert, 11:12:56 proxies=proxies, 11:12:56 ) 11:12:56 11:12:56 chunked = not (request.body is None or "Content-Length" in request.headers) 11:12:56 11:12:56 if isinstance(timeout, tuple): 11:12:56 try: 11:12:56 connect, read = timeout 11:12:56 timeout = TimeoutSauce(connect=connect, read=read) 11:12:56 except ValueError: 11:12:56 raise ValueError( 11:12:56 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:12:56 f"or a single float to set both timeouts to the same value." 11:12:56 ) 11:12:56 elif isinstance(timeout, TimeoutSauce): 11:12:56 pass 11:12:56 else: 11:12:56 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:12:56 11:12:56 try: 11:12:56 > resp = conn.urlopen( 11:12:56 method=request.method, 11:12:56 url=url, 11:12:56 body=request.body, 11:12:56 headers=request.headers, 11:12:56 redirect=False, 11:12:56 assert_same_host=False, 11:12:56 preload_content=False, 11:12:56 decode_content=False, 11:12:56 retries=self.max_retries, 11:12:56 timeout=timeout, 11:12:56 chunked=chunked, 11:12:56 ) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:843: in urlopen 11:12:56 retries = retries.increment( 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 11:12:56 method = 'GET' 11:12:56 url = '/rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info' 11:12:56 response = None 11:12:56 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 11:12:56 _pool = 11:12:56 _stacktrace = 11:12:56 11:12:56 def increment( 11:12:56 self, 11:12:56 method: str | None = None, 11:12:56 url: str | None = None, 11:12:56 response: BaseHTTPResponse | None = None, 11:12:56 error: Exception | None = None, 11:12:56 _pool: ConnectionPool | None = None, 11:12:56 _stacktrace: TracebackType | None = None, 11:12:56 ) -> Self: 11:12:56 """Return a new Retry object with incremented retry counters. 11:12:56 11:12:56 :param response: A response object, or None, if the server did not 11:12:56 return a response. 11:12:56 :type response: :class:`~urllib3.response.BaseHTTPResponse` 11:12:56 :param Exception error: An error encountered during the request, or 11:12:56 None if the response was received successfully. 11:12:56 11:12:56 :return: A new ``Retry`` object. 11:12:56 """ 11:12:56 if self.total is False and error: 11:12:56 # Disabled, indicate to re-raise the error. 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 11:12:56 total = self.total 11:12:56 if total is not None: 11:12:56 total -= 1 11:12:56 11:12:56 connect = self.connect 11:12:56 read = self.read 11:12:56 redirect = self.redirect 11:12:56 status_count = self.status 11:12:56 other = self.other 11:12:56 cause = "unknown" 11:12:56 status = None 11:12:56 redirect_location = None 11:12:56 11:12:56 if error and self._is_connection_error(error): 11:12:56 # Connect retry? 11:12:56 if connect is False: 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 elif connect is not None: 11:12:56 connect -= 1 11:12:56 11:12:56 elif error and self._is_read_error(error): 11:12:56 # Read retry? 11:12:56 if read is False or method is None or not self._is_method_retryable(method): 11:12:56 raise reraise(type(error), error, _stacktrace) 11:12:56 elif read is not None: 11:12:56 read -= 1 11:12:56 11:12:56 elif error: 11:12:56 # Other retry? 11:12:56 if other is not None: 11:12:56 other -= 1 11:12:56 11:12:56 elif response and response.get_redirect_location(): 11:12:56 # Redirect retry? 11:12:56 if redirect is not None: 11:12:56 redirect -= 1 11:12:56 cause = "too many redirects" 11:12:56 response_redirect_location = response.get_redirect_location() 11:12:56 if response_redirect_location: 11:12:56 redirect_location = response_redirect_location 11:12:56 status = response.status 11:12:56 11:12:56 else: 11:12:56 # Incrementing because of a server error like a 500 in 11:12:56 # status_forcelist and the given method is in the allowed_methods 11:12:56 cause = ResponseError.GENERIC_ERROR 11:12:56 if response and response.status: 11:12:56 if status_count is not None: 11:12:56 status_count -= 1 11:12:56 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 11:12:56 status = response.status 11:12:56 11:12:56 history = self.history + ( 11:12:56 RequestHistory(method, url, error, status, redirect_location), 11:12:56 ) 11:12:56 11:12:56 new_retry = self.new( 11:12:56 total=total, 11:12:56 connect=connect, 11:12:56 read=read, 11:12:56 redirect=redirect, 11:12:56 status=status_count, 11:12:56 other=other, 11:12:56 history=history, 11:12:56 ) 11:12:56 11:12:56 if new_retry.is_exhausted(): 11:12:56 reason = error or ResponseError(cause) 11:12:56 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 11:12:56 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 11:12:56 11:12:56 During handling of the above exception, another exception occurred: 11:12:56 11:12:56 self = 11:12:56 11:12:56 def test_21_rdm_device_not_connected(self): 11:12:56 > response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) 11:12:56 11:12:56 transportpce_tests/1.2.1/test01_portmapping.py:223: 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 transportpce_tests/common/test_utils.py:470: in get_portmapping_node_attr 11:12:56 response = get_request(target_url) 11:12:56 transportpce_tests/common/test_utils.py:116: in get_request 11:12:56 return requests.request( 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 11:12:56 return session.request(method=method, url=url, **kwargs) 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 11:12:56 resp = self.send(prep, **send_kwargs) 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 11:12:56 r = adapter.send(request, **kwargs) 11:12:56 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:12:56 11:12:56 self = 11:12:56 request = , stream = False 11:12:56 timeout = Timeout(connect=10, read=10, total=None), verify = True, cert = None 11:12:56 proxies = OrderedDict() 11:12:56 11:12:56 def send( 11:12:56 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:12:56 ): 11:12:56 """Sends PreparedRequest object. Returns Response object. 11:12:56 11:12:56 :param request: The :class:`PreparedRequest ` being sent. 11:12:56 :param stream: (optional) Whether to stream the request content. 11:12:56 :param timeout: (optional) How long to wait for the server to send 11:12:56 data before giving up, as a float, or a :ref:`(connect timeout, 11:12:56 read timeout) ` tuple. 11:12:56 :type timeout: float or tuple or urllib3 Timeout object 11:12:56 :param verify: (optional) Either a boolean, in which case it controls whether 11:12:56 we verify the server's TLS certificate, or a string, in which case it 11:12:56 must be a path to a CA bundle to use 11:12:56 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:12:56 :param proxies: (optional) The proxies dictionary to apply to the request. 11:12:56 :rtype: requests.Response 11:12:56 """ 11:12:56 11:12:56 try: 11:12:56 conn = self.get_connection_with_tls_context( 11:12:56 request, verify, proxies=proxies, cert=cert 11:12:56 ) 11:12:56 except LocationValueError as e: 11:12:56 raise InvalidURL(e, request=request) 11:12:56 11:12:56 self.cert_verify(conn, request.url, verify, cert) 11:12:56 url = self.request_url(request, proxies) 11:12:56 self.add_headers( 11:12:56 request, 11:12:56 stream=stream, 11:12:56 timeout=timeout, 11:12:56 verify=verify, 11:12:56 cert=cert, 11:12:56 proxies=proxies, 11:12:56 ) 11:12:56 11:12:56 chunked = not (request.body is None or "Content-Length" in request.headers) 11:12:56 11:12:56 if isinstance(timeout, tuple): 11:12:56 try: 11:12:56 connect, read = timeout 11:12:56 timeout = TimeoutSauce(connect=connect, read=read) 11:12:56 except ValueError: 11:12:56 raise ValueError( 11:12:56 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:12:56 f"or a single float to set both timeouts to the same value." 11:12:56 ) 11:12:56 elif isinstance(timeout, TimeoutSauce): 11:12:56 pass 11:12:56 else: 11:12:56 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:12:56 11:12:56 try: 11:12:56 resp = conn.urlopen( 11:12:56 method=request.method, 11:12:56 url=url, 11:12:56 body=request.body, 11:12:56 headers=request.headers, 11:12:56 redirect=False, 11:12:56 assert_same_host=False, 11:12:56 preload_content=False, 11:12:56 decode_content=False, 11:12:56 retries=self.max_retries, 11:12:56 timeout=timeout, 11:12:56 chunked=chunked, 11:12:56 ) 11:12:56 11:12:56 except (ProtocolError, OSError) as err: 11:12:56 raise ConnectionError(err, request=request) 11:12:56 11:12:56 except MaxRetryError as e: 11:12:56 if isinstance(e.reason, ConnectTimeoutError): 11:12:56 # TODO: Remove this in 3.0.0: see #2811 11:12:56 if not isinstance(e.reason, NewConnectionError): 11:12:56 raise ConnectTimeout(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, ResponseError): 11:12:56 raise RetryError(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, _ProxyError): 11:12:56 raise ProxyError(e, request=request) 11:12:56 11:12:56 if isinstance(e.reason, _SSLError): 11:12:56 # This branch is for urllib3 v1.22 and later. 11:12:56 raise SSLError(e, request=request) 11:12:56 11:12:56 > raise ConnectionError(e, request=request) 11:12:56 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8182): Max retries exceeded with url: /rests/data/transportpce-portmapping:network/nodes=ROADMA01/node-info (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 11:12:56 11:12:56 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:700: ConnectionError 11:12:56 ----------------------------- Captured stdout call ----------------------------- 11:12:56 execution of test_21_rdm_device_not_connected 11:12:56 --------------------------- Captured stdout teardown --------------------------- 11:12:56 all processes killed 11:12:56 =========================== short test summary info ============================ 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_08_xpdr_device_connected 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_09_xpdr_portmapping_info 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_10_xpdr_portmapping_NETWORK1 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_11_xpdr_portmapping_NETWORK2 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_12_xpdr_portmapping_CLIENT1 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_13_xpdr_portmapping_CLIENT2 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_14_xpdr_portmapping_CLIENT3 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_15_xpdr_portmapping_CLIENT4 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_16_xpdr_device_disconnection 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_19_rdm_device_disconnection 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_20_rdm_device_disconnected 11:12:56 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TransportPCEPortMappingTesting::test_21_rdm_device_not_connected 11:12:56 12 failed, 9 passed in 795.92s (0:13:15) 11:12:56 tests221: FAIL ✖ in 2 minutes 6.5 seconds 11:12:56 tests121: exit 1 (796.17 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=36563 11:12:56 tests121: FAIL ✖ in 13 minutes 23.42 seconds 11:12:56 tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 11:13:02 tests_hybrid: freeze> python -m pip freeze --all 11:13:03 tests_hybrid: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 11:13:03 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 11:13:03 using environment variables from ./karaf121.env 11:13:03 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 11:13:47 ................................................... [100%] 11:18:33 51 passed in 329.96s (0:05:29) 11:18:33 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 11:19:17 ........................................................................ [ 66%] 11:23:37 ..................................... [100%] 11:25:43 109 passed in 430.38s (0:07:10) 11:25:43 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 11:26:30 ..................................................... [100%] 11:30:02 53 passed in 257.98s (0:04:17) 11:30:02 tests_hybrid: OK ✔ in 17 minutes 5.49 seconds 11:30:02 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 11:30:08 buildlighty: freeze> python -m pip freeze --all 11:30:08 buildlighty: bcrypt==4.2.0,certifi==2024.8.30,cffi==1.17.1,charset-normalizer==3.4.0,cryptography==43.0.3,dict2xml==1.7.6,idna==3.10,iniconfig==2.0.0,lxml==5.3.0,netconf-client==3.1.1,packaging==24.1,paramiko==3.5.0,pip==24.2,pluggy==1.5.0,psutil==6.1.0,pycparser==2.22,PyNaCl==1.5.0,pytest==8.3.3,requests==2.32.3,setuptools==75.2.0,urllib3==2.2.3,wheel==0.44.0 11:30:08 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 11:30:08 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 11:30:24 [ERROR] COMPILATION ERROR : 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 11:30:24 symbol: class YangModuleInfo 11:30:24 location: package org.opendaylight.yangtools.binding 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 11:30:24 symbol: class YangModuleInfo 11:30:24 location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 11:30:24 symbol: class YangModuleInfo 11:30:24 location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 11:30:24 symbol: class YangModuleInfo 11:30:24 location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [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: 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[17,42] cannot find symbol 11:30:24 [ERROR] symbol: class YangModuleInfo 11:30:24 [ERROR] location: package org.opendaylight.yangtools.binding 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[21,30] cannot find symbol 11:30:24 [ERROR] symbol: class YangModuleInfo 11:30:24 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[343,30] cannot find symbol 11:30:24 [ERROR] symbol: class YangModuleInfo 11:30:24 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [ERROR] /w/workspace/transportpce-tox-verify-transportpce-master/lighty/src/main/java/io/lighty/controllers/tpce/utils/TPCEUtils.java:[350,23] cannot find symbol 11:30:24 [ERROR] symbol: class YangModuleInfo 11:30:24 [ERROR] location: class io.lighty.controllers.tpce.utils.TPCEUtils 11:30:24 [ERROR] -> [Help 1] 11:30:24 [ERROR] 11:30:24 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 11:30:24 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 11:30:24 [ERROR] 11:30:24 [ERROR] For more information about the errors and possible solutions, please read the following articles: 11:30:24 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException 11:30:24 unzip: cannot find or open target/tpce-bin.zip, target/tpce-bin.zip.zip or target/tpce-bin.zip.ZIP. 11:30:24 buildlighty: exit 9 (16.10 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh pid=47414 11:30:24 buildlighty: command failed but is marked ignore outcome so handling it as success 11:30:24 buildcontroller: OK (115.60=setup[11.00]+cmd[104.59] seconds) 11:30:24 testsPCE: OK (343.66=setup[103.91]+cmd[239.75] seconds) 11:30:24 sims: OK (12.84=setup[8.22]+cmd[4.61] seconds) 11:30:24 build_karaf_tests121: OK (57.33=setup[8.19]+cmd[49.13] seconds) 11:30:24 tests121: FAIL code 1 (803.42=setup[7.25]+cmd[796.17] seconds) 11:30:24 build_karaf_tests221: OK (59.13=setup[8.25]+cmd[50.88] seconds) 11:30:24 tests_tapi: FAIL code 1 (539.64=setup[11.47]+cmd[528.17] seconds) 11:30:24 tests221: FAIL code 1 (126.50=setup[6.37]+cmd[120.13] seconds) 11:30:24 build_karaf_tests71: OK (53.60=setup[13.85]+cmd[39.75] seconds) 11:30:24 tests71: OK (411.88=setup[6.46]+cmd[405.42] seconds) 11:30:24 build_karaf_tests_hybrid: OK (62.64=setup[10.67]+cmd[51.98] seconds) 11:30:24 tests_hybrid: OK (1025.49=setup[6.47]+cmd[1019.02] seconds) 11:30:24 buildlighty: OK (22.52=setup[6.42]+cmd[16.10] seconds) 11:30:24 docs: OK (40.98=setup[38.88]+cmd[2.10] seconds) 11:30:24 docs-linkcheck: OK (42.58=setup[38.96]+cmd[3.62] seconds) 11:30:24 checkbashisms: OK (2.87=setup[2.00]+cmd[0.02,0.05,0.79] seconds) 11:30:24 pre-commit: OK (58.75=setup[5.85]+cmd[0.00,0.01,38.80,14.10] seconds) 11:30:24 pylint: OK (27.58=setup[5.77]+cmd[21.80] seconds) 11:30:24 evaluation failed :( (2310.78 seconds) 11:30:24 + tox_status=255 11:30:24 + echo '---> Completed tox runs' 11:30:24 ---> Completed tox runs 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/build_karaf_tests121/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=build_karaf_tests121 11:30:24 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/build_karaf_tests221/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=build_karaf_tests221 11:30:24 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/build_karaf_tests71/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=build_karaf_tests71 11:30:24 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/build_karaf_tests_hybrid/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=build_karaf_tests_hybrid 11:30:24 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/buildcontroller/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=buildcontroller 11:30:24 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/buildlighty/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=buildlighty 11:30:24 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/checkbashisms/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=checkbashisms 11:30:24 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/docs-linkcheck/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=docs-linkcheck 11:30:24 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/docs/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=docs 11:30:24 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/pre-commit/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=pre-commit 11:30:24 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/pylint/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=pylint 11:30:24 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/sims/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=sims 11:30:24 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/tests121/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=tests121 11:30:24 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/tests221/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=tests221 11:30:24 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/tests71/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=tests71 11:30:24 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/testsPCE/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=testsPCE 11:30:24 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/tests_hybrid/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=tests_hybrid 11:30:24 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 11:30:24 + for i in .tox/*/log 11:30:24 ++ echo .tox/tests_tapi/log 11:30:24 ++ awk -F/ '{print $2}' 11:30:24 + tox_env=tests_tapi 11:30:24 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 11:30:24 + DOC_DIR=docs/_build/html 11:30:24 + [[ -d docs/_build/html ]] 11:30:24 + echo '---> Archiving generated docs' 11:30:24 ---> Archiving generated docs 11:30:24 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 11:30:24 + echo '---> tox-run.sh ends' 11:30:24 ---> tox-run.sh ends 11:30:24 + test 255 -eq 0 11:30:24 + exit 255 11:30:24 ++ '[' 1 = 1 ']' 11:30:24 ++ '[' -x /usr/bin/clear_console ']' 11:30:24 ++ /usr/bin/clear_console -q 11:30:24 Build step 'Execute shell' marked build as failure 11:30:24 $ ssh-agent -k 11:30:24 unset SSH_AUTH_SOCK; 11:30:24 unset SSH_AGENT_PID; 11:30:24 echo Agent pid 12427 killed; 11:30:24 [ssh-agent] Stopped. 11:30:24 [PostBuildScript] - [INFO] Executing post build scripts. 11:30:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5421106119798923281.sh 11:30:24 ---> sysstat.sh 11:30:25 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16207312988370393895.sh 11:30:25 ---> package-listing.sh 11:30:25 ++ tr '[:upper:]' '[:lower:]' 11:30:25 ++ facter osfamily 11:30:25 + OS_FAMILY=debian 11:30:25 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 11:30:25 + START_PACKAGES=/tmp/packages_start.txt 11:30:25 + END_PACKAGES=/tmp/packages_end.txt 11:30:25 + DIFF_PACKAGES=/tmp/packages_diff.txt 11:30:25 + PACKAGES=/tmp/packages_start.txt 11:30:25 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 11:30:25 + PACKAGES=/tmp/packages_end.txt 11:30:25 + case "${OS_FAMILY}" in 11:30:25 + dpkg -l 11:30:25 + grep '^ii' 11:30:25 + '[' -f /tmp/packages_start.txt ']' 11:30:25 + '[' -f /tmp/packages_end.txt ']' 11:30:25 + diff /tmp/packages_start.txt /tmp/packages_end.txt 11:30:25 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 11:30:25 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 11:30:25 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 11:30:25 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15630891915901589470.sh 11:30:25 ---> capture-instance-metadata.sh 11:30:25 Setup pyenv: 11:30:25 system 11:30:25 3.8.13 11:30:25 3.9.13 11:30:25 3.10.13 11:30:25 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:30:26 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-pNr3 from file:/tmp/.os_lf_venv 11:30:27 lf-activate-venv(): INFO: Installing: lftools 11:30:38 lf-activate-venv(): INFO: Adding /tmp/venv-pNr3/bin to PATH 11:30:38 INFO: Running in OpenStack, capturing instance metadata 11:30:38 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10990142703490995260.sh 11:30:38 provisioning config files... 11:30:38 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #2116 11:30:38 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config13190764573106961546tmp 11:30:38 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 11:30:38 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 11:30:38 provisioning config files... 11:30:39 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 11:30:39 [EnvInject] - Injecting environment variables from a build step. 11:30:39 [EnvInject] - Injecting as environment variables the properties content 11:30:39 SERVER_ID=logs 11:30:39 11:30:39 [EnvInject] - Variables injected successfully. 11:30:39 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9046968752712457426.sh 11:30:39 ---> create-netrc.sh 11:30:39 WARN: Log server credential not found. 11:30:39 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6079157669580284490.sh 11:30:39 ---> python-tools-install.sh 11:30:39 Setup pyenv: 11:30:39 system 11:30:39 3.8.13 11:30:39 3.9.13 11:30:39 3.10.13 11:30:39 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:30:39 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-pNr3 from file:/tmp/.os_lf_venv 11:30:40 lf-activate-venv(): INFO: Installing: lftools 11:30:48 lf-activate-venv(): INFO: Adding /tmp/venv-pNr3/bin to PATH 11:30:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17757634335430403479.sh 11:30:48 ---> sudo-logs.sh 11:30:48 Archiving 'sudo' log.. 11:30:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins836116873161445565.sh 11:30:49 ---> job-cost.sh 11:30:49 Setup pyenv: 11:30:49 system 11:30:49 3.8.13 11:30:49 3.9.13 11:30:49 3.10.13 11:30:49 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:30:49 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-pNr3 from file:/tmp/.os_lf_venv 11:30:50 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 11:30:54 lf-activate-venv(): INFO: Adding /tmp/venv-pNr3/bin to PATH 11:30:54 INFO: No Stack... 11:30:55 INFO: Retrieving Pricing Info for: v3-standard-4 11:30:55 INFO: Archiving Costs 11:30:55 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins17368922702717210458.sh 11:30:55 ---> logs-deploy.sh 11:30:55 Setup pyenv: 11:30:55 system 11:30:55 3.8.13 11:30:55 3.9.13 11:30:55 3.10.13 11:30:55 * 3.11.7 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:30:55 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-pNr3 from file:/tmp/.os_lf_venv 11:30:56 lf-activate-venv(): INFO: Installing: lftools 11:31:05 lf-activate-venv(): INFO: Adding /tmp/venv-pNr3/bin to PATH 11:31:05 WARNING: Nexus logging server not set 11:31:05 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/2116/ 11:31:05 INFO: archiving logs to S3 11:31:07 ---> uname -a: 11:31:07 Linux prd-ubuntu2004-docker-4c-16g-2195 5.4.0-190-generic #210-Ubuntu SMP Fri Jul 5 17:03:38 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 11:31:07 11:31:07 11:31:07 ---> lscpu: 11:31:07 Architecture: x86_64 11:31:07 CPU op-mode(s): 32-bit, 64-bit 11:31:07 Byte Order: Little Endian 11:31:07 Address sizes: 40 bits physical, 48 bits virtual 11:31:07 CPU(s): 4 11:31:07 On-line CPU(s) list: 0-3 11:31:07 Thread(s) per core: 1 11:31:07 Core(s) per socket: 1 11:31:07 Socket(s): 4 11:31:07 NUMA node(s): 1 11:31:07 Vendor ID: AuthenticAMD 11:31:07 CPU family: 23 11:31:07 Model: 49 11:31:07 Model name: AMD EPYC-Rome Processor 11:31:07 Stepping: 0 11:31:07 CPU MHz: 2800.000 11:31:07 BogoMIPS: 5600.00 11:31:07 Virtualization: AMD-V 11:31:07 Hypervisor vendor: KVM 11:31:07 Virtualization type: full 11:31:07 L1d cache: 128 KiB 11:31:07 L1i cache: 128 KiB 11:31:07 L2 cache: 2 MiB 11:31:07 L3 cache: 64 MiB 11:31:07 NUMA node0 CPU(s): 0-3 11:31:07 Vulnerability Gather data sampling: Not affected 11:31:07 Vulnerability Itlb multihit: Not affected 11:31:07 Vulnerability L1tf: Not affected 11:31:07 Vulnerability Mds: Not affected 11:31:07 Vulnerability Meltdown: Not affected 11:31:07 Vulnerability Mmio stale data: Not affected 11:31:07 Vulnerability Retbleed: Vulnerable 11:31:07 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 11:31:07 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 11:31:07 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; IBRS_FW; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 11:31:07 Vulnerability Srbds: Not affected 11:31:07 Vulnerability Tsx async abort: Not affected 11:31:07 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 11:31:07 11:31:07 11:31:07 ---> nproc: 11:31:07 4 11:31:07 11:31:07 11:31:07 ---> df -h: 11:31:07 Filesystem Size Used Avail Use% Mounted on 11:31:07 udev 7.8G 0 7.8G 0% /dev 11:31:07 tmpfs 1.6G 1.1M 1.6G 1% /run 11:31:07 /dev/vda1 78G 17G 62G 21% / 11:31:07 tmpfs 7.9G 0 7.9G 0% /dev/shm 11:31:07 tmpfs 5.0M 0 5.0M 0% /run/lock 11:31:07 tmpfs 7.9G 0 7.9G 0% /sys/fs/cgroup 11:31:07 /dev/loop0 62M 62M 0 100% /snap/core20/1405 11:31:07 /dev/loop1 68M 68M 0 100% /snap/lxd/22753 11:31:07 /dev/vda15 105M 6.1M 99M 6% /boot/efi 11:31:07 tmpfs 1.6G 0 1.6G 0% /run/user/1001 11:31:07 /dev/loop3 39M 39M 0 100% /snap/snapd/21759 11:31:07 /dev/loop4 64M 64M 0 100% /snap/core20/2434 11:31:07 /dev/loop5 92M 92M 0 100% /snap/lxd/29619 11:31:07 11:31:07 11:31:07 ---> free -m: 11:31:07 total used free shared buff/cache available 11:31:07 Mem: 15997 650 5604 1 9742 15007 11:31:07 Swap: 1023 0 1023 11:31:07 11:31:07 11:31:07 ---> ip addr: 11:31:07 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 11:31:07 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 11:31:07 inet 127.0.0.1/8 scope host lo 11:31:07 valid_lft forever preferred_lft forever 11:31:07 inet6 ::1/128 scope host 11:31:07 valid_lft forever preferred_lft forever 11:31:07 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 11:31:07 link/ether fa:16:3e:fe:ae:84 brd ff:ff:ff:ff:ff:ff 11:31:07 inet 10.30.170.100/23 brd 10.30.171.255 scope global dynamic ens3 11:31:07 valid_lft 83928sec preferred_lft 83928sec 11:31:07 inet6 fe80::f816:3eff:fefe:ae84/64 scope link 11:31:07 valid_lft forever preferred_lft forever 11:31:07 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 11:31:07 link/ether 02:42:65:f3:89:5c brd ff:ff:ff:ff:ff:ff 11:31:07 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 11:31:07 valid_lft forever preferred_lft forever 11:31:07 11:31:07 11:31:07 ---> sar -b -r -n DEV: 11:31:07 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-2195) 10/28/24 _x86_64_ (4 CPU) 11:31:07 11:31:07 10:49:57 LINUX RESTART (4 CPU) 11:31:07 11:31:07 10:50:01 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 11:31:07 10:51:02 350.77 162.12 188.65 0.00 11797.63 93347.51 0.00 11:31:07 10:52:01 122.47 32.16 90.31 0.00 1243.51 12268.13 0.00 11:31:07 10:53:01 241.97 40.74 201.23 0.00 2722.43 50831.46 0.00 11:31:07 10:54:01 58.46 1.78 56.67 0.00 90.92 25164.87 0.00 11:31:07 10:55:01 143.13 1.03 142.09 0.00 71.19 137888.49 0.00 11:31:07 10:56:01 195.28 15.50 179.79 0.00 4870.52 77219.40 0.00 11:31:07 10:57:01 125.17 2.27 122.91 0.00 76.91 11812.20 0.00 11:31:07 10:58:01 58.11 1.57 56.55 0.00 188.07 1109.90 0.00 11:31:07 10:59:01 90.72 0.35 90.37 0.00 51.60 1712.40 0.00 11:31:07 11:00:01 105.20 0.33 104.87 0.00 57.58 2763.75 0.00 11:31:07 11:01:01 39.74 0.03 39.71 0.00 0.80 8118.78 0.00 11:31:07 11:02:01 2.83 0.00 2.83 0.00 0.00 65.98 0.00 11:31:07 11:03:01 1.92 0.00 1.92 0.00 0.00 35.99 0.00 11:31:07 11:04:01 10.41 0.00 10.41 0.00 0.00 686.15 0.00 11:31:07 11:05:01 164.34 0.78 163.56 0.00 15.86 10689.02 0.00 11:31:07 11:06:01 3.70 0.02 3.68 0.00 0.13 95.30 0.00 11:31:07 11:07:01 2.58 0.00 2.58 0.00 0.00 49.59 0.00 11:31:07 11:08:01 74.12 0.00 74.12 0.00 0.00 1076.89 0.00 11:31:07 11:09:01 2.12 0.00 2.12 0.00 0.00 43.73 0.00 11:31:07 11:10:01 74.60 0.00 74.60 0.00 0.00 1078.22 0.00 11:31:07 11:11:01 29.31 0.02 29.30 0.00 0.13 1241.93 0.00 11:31:07 11:12:01 60.59 0.00 60.59 0.00 0.00 2461.46 0.00 11:31:07 11:13:01 77.94 0.05 77.89 0.00 1.87 1599.33 0.00 11:31:07 11:14:01 106.03 0.00 106.03 0.00 0.00 9813.43 0.00 11:31:07 11:15:01 2.78 0.00 2.78 0.00 0.00 105.32 0.00 11:31:07 11:16:01 2.08 0.00 2.08 0.00 0.00 37.87 0.00 11:31:07 11:17:01 1.67 0.05 1.62 0.00 1.07 21.73 0.00 11:31:07 11:18:01 1.72 0.00 1.72 0.00 0.00 20.93 0.00 11:31:07 11:19:01 16.61 0.00 16.61 0.00 0.00 393.67 0.00 11:31:07 11:20:01 5.30 0.00 5.30 0.00 0.00 105.85 0.00 11:31:07 11:21:01 2.07 0.00 2.07 0.00 0.00 32.39 0.00 11:31:07 11:22:01 2.40 0.00 2.40 0.00 0.00 50.92 0.00 11:31:07 11:23:01 2.30 0.00 2.30 0.00 0.00 39.06 0.00 11:31:07 11:24:01 1.70 0.00 1.70 0.00 0.00 31.33 0.00 11:31:07 11:25:01 2.88 0.00 2.88 0.00 0.00 58.39 0.00 11:31:07 11:26:01 22.93 0.00 22.93 0.00 0.00 375.27 0.00 11:31:07 11:27:01 45.39 0.00 45.39 0.00 0.00 669.09 0.00 11:31:07 11:28:01 2.92 0.00 2.92 0.00 0.00 164.11 0.00 11:31:07 11:29:01 3.07 0.00 3.07 0.00 0.00 71.45 0.00 11:31:07 11:30:01 2.82 0.00 2.82 0.00 0.00 72.65 0.00 11:31:07 11:31:01 51.57 6.92 44.66 0.00 290.22 7874.02 0.00 11:31:07 Average: 56.36 6.47 49.89 0.00 523.63 11250.80 0.00 11:31:07 11:31:07 10:50:01 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 11:31:07 10:51:02 13558432 15433132 555864 3.39 55176 2026280 1312568 7.53 772796 1794100 108380 11:31:07 10:52:01 12917892 15280676 679796 4.15 86492 2452284 1584164 9.09 985016 2162276 276408 11:31:07 10:53:01 10511580 14349940 1605932 9.80 137528 3766352 2306920 13.24 2084612 3351688 277832 11:31:07 10:54:01 9401880 14944940 1010484 6.17 161336 5371960 2182808 12.52 1812044 4659288 1145372 11:31:07 10:55:01 6801772 14863408 1092332 6.67 198008 7747512 2028020 11.64 2852068 6111176 727820 11:31:07 10:56:01 4863000 14325048 1618024 9.88 225684 9063984 2444480 14.02 3828372 6998360 280472 11:31:07 10:57:01 173744 9338200 6602176 40.30 224864 8773844 8029100 46.07 8756992 6747728 144 11:31:07 10:58:01 168536 8705800 7234088 44.16 224664 8156028 8270088 47.45 9337968 6179768 252 11:31:07 10:59:01 6183876 14726880 1216664 7.43 227584 8158488 2142876 12.29 3362128 6162136 860 11:31:07 11:00:01 3215568 12004852 3936480 24.03 237056 8388456 5045952 28.95 6128256 6345348 226008 11:31:07 11:01:01 670520 9459600 6480424 39.56 238128 8386932 7383104 42.36 8673472 6336588 224 11:31:07 11:02:01 495640 9285376 6654544 40.62 238160 8387572 7497864 43.02 8850000 6336256 108 11:31:07 11:03:01 492860 9282800 6657112 40.64 238200 8387732 7497864 43.02 8850952 6336376 252 11:31:07 11:04:01 3403852 12430212 3511168 21.43 244232 8605388 4493128 25.78 5741000 6534328 218488 11:31:07 11:05:01 2681664 11722984 4218388 25.75 248716 8614708 5144284 29.51 6517268 6476016 1712 11:31:07 11:06:01 2597148 11638588 4302592 26.27 248768 8614848 5192800 29.79 6602492 6474320 208 11:31:07 11:07:01 2549368 11590996 4350052 26.55 248796 8614972 5242032 30.07 6649804 6473848 32 11:31:07 11:08:01 1853744 10897700 5042928 30.78 250892 8615152 5926824 34.00 7354812 6463044 216 11:31:07 11:09:01 1833464 10877620 5062992 30.91 250912 8615328 5926824 34.00 7374448 6463216 144 11:31:07 11:10:01 2324492 11370744 4570176 27.90 252728 8615496 5875032 33.71 6887332 6462112 328 11:31:07 11:11:01 3013364 12128660 3812224 23.27 255176 8675856 5012816 28.76 6136188 6521080 50464 11:31:07 11:12:01 4149308 13265468 2675020 16.33 256048 8675820 3605924 20.69 5003400 6521012 168 11:31:07 11:13:01 6180436 15350748 592076 3.61 259032 8722928 1397452 8.02 2952960 6547444 49124 11:31:07 11:14:01 2146656 11513196 4427624 27.03 265048 8903332 5226044 29.98 6833492 6676024 1856 11:31:07 11:15:01 2071364 11438084 4502736 27.49 265100 8903564 5310120 30.47 6909736 6675916 196 11:31:07 11:16:01 2006032 11372984 4567708 27.88 265116 8903772 5342976 30.65 6974396 6676052 60 11:31:07 11:17:01 2005380 11372360 4568312 27.89 265144 8903768 5342976 30.65 6974136 6676052 260 11:31:07 11:18:01 2004616 11371664 4568924 27.89 265164 8903804 5342976 30.65 6973964 6676072 36 11:31:07 11:19:01 3673308 13040768 2900772 17.71 265252 8904024 4165576 23.90 5331096 6657920 472 11:31:07 11:20:01 2149728 11517672 4422888 27.00 265424 8904320 5236356 30.04 6852084 6654724 312 11:31:07 11:21:01 2132796 11500932 4439676 27.10 265448 8904488 5268412 30.23 6869028 6654736 196 11:31:07 11:22:01 2108716 11477188 4463404 27.25 265500 8904764 5268412 30.23 6892780 6655004 104 11:31:07 11:23:01 2104052 11472728 4467836 27.27 265516 8904952 5268412 30.23 6896812 6655188 76 11:31:07 11:24:01 2090340 11459300 4481132 27.36 265528 8905212 5284788 30.32 6908616 6655452 248 11:31:07 11:25:01 2064920 11434224 4506236 27.51 265540 8905540 5301068 30.41 6934484 6655760 92 11:31:07 11:26:01 4579116 13948800 1993412 12.17 265692 8905724 3402492 19.52 4441972 6644580 512 11:31:07 11:27:01 1534536 10904780 5035440 30.74 266112 8905824 5844420 33.53 7475892 6644604 16 11:31:07 11:28:01 1425396 10796276 5143800 31.40 266132 8906384 5931376 34.03 7583700 6645000 208 11:31:07 11:29:01 1372372 10743996 5195988 31.72 266136 8907120 5963924 34.22 7634164 6645732 236 11:31:07 11:30:01 5252848 14624916 1316940 8.04 266144 8907540 2160668 12.40 3767012 6646136 96 11:31:07 11:31:01 5781816 15379724 563044 3.44 272084 9112392 1320492 7.58 3049460 6824032 18316 11:31:07 Average: 3574296 12162048 3781644 23.09 238884 8193523 4695717 26.94 5922371 6206744 82642 11:31:07 11:31:07 10:50:01 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 11:31:07 10:51:02 lo 1.70 1.70 0.16 0.16 0.00 0.00 0.00 0.00 11:31:07 10:51:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:51:02 ens3 393.35 253.69 1656.85 70.34 0.00 0.00 0.00 0.00 11:31:07 10:52:01 lo 1.08 1.08 0.11 0.11 0.00 0.00 0.00 0.00 11:31:07 10:52:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:52:01 ens3 74.08 64.59 841.64 10.02 0.00 0.00 0.00 0.00 11:31:07 10:53:01 lo 5.80 5.80 0.59 0.59 0.00 0.00 0.00 0.00 11:31:07 10:53:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:53:01 ens3 488.94 393.05 7466.10 39.98 0.00 0.00 0.00 0.00 11:31:07 10:54:01 lo 0.80 0.80 0.08 0.08 0.00 0.00 0.00 0.00 11:31:07 10:54:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:54:01 ens3 341.78 256.51 5650.29 25.54 0.00 0.00 0.00 0.00 11:31:07 10:55:01 lo 0.93 0.93 0.09 0.09 0.00 0.00 0.00 0.00 11:31:07 10:55:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:55:01 ens3 72.12 42.51 1788.38 6.60 0.00 0.00 0.00 0.00 11:31:07 10:56:01 lo 4.87 4.87 0.50 0.50 0.00 0.00 0.00 0.00 11:31:07 10:56:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:56:01 ens3 209.57 147.64 2769.73 10.15 0.00 0.00 0.00 0.00 11:31:07 10:57:01 lo 13.70 13.70 23.28 23.28 0.00 0.00 0.00 0.00 11:31:07 10:57:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:57:01 ens3 1.55 1.37 0.22 0.20 0.00 0.00 0.00 0.00 11:31:07 10:58:01 lo 44.19 44.19 30.95 30.95 0.00 0.00 0.00 0.00 11:31:07 10:58:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:58:01 ens3 1.28 1.43 0.25 0.24 0.00 0.00 0.00 0.00 11:31:07 10:59:01 lo 37.43 37.43 17.42 17.42 0.00 0.00 0.00 0.00 11:31:07 10:59:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 10:59:01 ens3 1.48 1.72 0.25 0.27 0.00 0.00 0.00 0.00 11:31:07 11:00:01 lo 5.33 5.33 1.25 1.25 0.00 0.00 0.00 0.00 11:31:07 11:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:00:01 ens3 1.75 2.17 0.79 0.71 0.00 0.00 0.00 0.00 11:31:07 11:01:01 lo 23.70 23.70 22.79 22.79 0.00 0.00 0.00 0.00 11:31:07 11:01:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:01:01 ens3 1.55 1.02 0.26 0.19 0.00 0.00 0.00 0.00 11:31:07 11:02:01 lo 23.34 23.34 13.89 13.89 0.00 0.00 0.00 0.00 11:31:07 11:02:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:02:01 ens3 0.73 0.62 0.35 0.29 0.00 0.00 0.00 0.00 11:31:07 11:03:01 lo 15.10 15.10 5.66 5.66 0.00 0.00 0.00 0.00 11:31:07 11:03:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:03:01 ens3 0.40 0.23 0.04 0.04 0.00 0.00 0.00 0.00 11:31:07 11:04:01 lo 20.90 20.90 7.44 7.44 0.00 0.00 0.00 0.00 11:31:07 11:04:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:04:01 ens3 2.05 2.15 0.86 0.79 0.00 0.00 0.00 0.00 11:31:07 11:05:01 lo 10.70 10.70 15.75 15.75 0.00 0.00 0.00 0.00 11:31:07 11:05:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:05:01 ens3 0.95 0.82 0.15 0.14 0.00 0.00 0.00 0.00 11:31:07 11:06:01 lo 27.89 27.89 12.16 12.16 0.00 0.00 0.00 0.00 11:31:07 11:06:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:06:01 ens3 1.27 1.05 0.30 0.27 0.00 0.00 0.00 0.00 11:31:07 11:07:01 lo 27.15 27.15 8.38 8.38 0.00 0.00 0.00 0.00 11:31:07 11:07:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:07:01 ens3 1.42 1.35 0.29 0.27 0.00 0.00 0.00 0.00 11:31:07 11:08:01 lo 17.25 17.25 11.06 11.06 0.00 0.00 0.00 0.00 11:31:07 11:08:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:08:01 ens3 0.88 0.77 0.15 0.14 0.00 0.00 0.00 0.00 11:31:07 11:09:01 lo 31.06 31.06 10.35 10.35 0.00 0.00 0.00 0.00 11:31:07 11:09:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:09:01 ens3 1.37 1.55 0.26 0.25 0.00 0.00 0.00 0.00 11:31:07 11:10:01 lo 24.58 24.58 10.44 10.44 0.00 0.00 0.00 0.00 11:31:07 11:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:10:01 ens3 1.77 1.88 1.63 0.23 0.00 0.00 0.00 0.00 11:31:07 11:11:01 lo 18.76 18.76 5.55 5.55 0.00 0.00 0.00 0.00 11:31:07 11:11:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:11:01 ens3 3.33 3.28 4.79 0.90 0.00 0.00 0.00 0.00 11:31:07 11:12:01 lo 14.96 14.96 10.08 10.08 0.00 0.00 0.00 0.00 11:31:07 11:12:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:12:01 ens3 1.43 1.33 0.29 0.26 0.00 0.00 0.00 0.00 11:31:07 11:13:01 lo 11.33 11.33 4.24 4.24 0.00 0.00 0.00 0.00 11:31:07 11:13:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:13:01 ens3 4.43 4.22 1.34 2.29 0.00 0.00 0.00 0.00 11:31:07 11:14:01 lo 35.64 35.64 32.62 32.62 0.00 0.00 0.00 0.00 11:31:07 11:14:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:14:01 ens3 0.83 0.93 0.12 0.13 0.00 0.00 0.00 0.00 11:31:07 11:15:01 lo 18.45 18.45 9.57 9.57 0.00 0.00 0.00 0.00 11:31:07 11:15:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:15:01 ens3 1.47 1.80 0.29 0.28 0.00 0.00 0.00 0.00 11:31:07 11:16:01 lo 19.07 19.07 5.45 5.45 0.00 0.00 0.00 0.00 11:31:07 11:16:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:16:01 ens3 0.97 0.40 0.18 0.11 0.00 0.00 0.00 0.00 11:31:07 11:17:01 lo 0.20 0.20 0.01 0.01 0.00 0.00 0.00 0.00 11:31:07 11:17:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:17:01 ens3 0.67 0.40 0.32 0.24 0.00 0.00 0.00 0.00 11:31:07 11:18:01 lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:18:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:18:01 ens3 0.03 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:19:01 lo 1.57 1.57 0.14 0.14 0.00 0.00 0.00 0.00 11:31:07 11:19:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:19:01 ens3 0.68 0.48 0.07 0.06 0.00 0.00 0.00 0.00 11:31:07 11:20:01 lo 35.16 35.16 17.95 17.95 0.00 0.00 0.00 0.00 11:31:07 11:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:20:01 ens3 0.87 0.88 0.18 0.16 0.00 0.00 0.00 0.00 11:31:07 11:21:01 lo 11.76 11.76 5.01 5.01 0.00 0.00 0.00 0.00 11:31:07 11:21:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:21:01 ens3 1.12 1.20 0.24 0.23 0.00 0.00 0.00 0.00 11:31:07 11:22:01 lo 25.78 25.78 9.67 9.67 0.00 0.00 0.00 0.00 11:31:07 11:22:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:22:01 ens3 0.37 0.37 0.06 0.06 0.00 0.00 0.00 0.00 11:31:07 11:23:01 lo 18.71 18.71 7.58 7.58 0.00 0.00 0.00 0.00 11:31:07 11:23:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:23:01 ens3 1.20 1.27 0.35 0.21 0.00 0.00 0.00 0.00 11:31:07 11:24:01 lo 27.13 27.13 8.64 8.64 0.00 0.00 0.00 0.00 11:31:07 11:24:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:24:01 ens3 0.43 0.50 0.08 0.08 0.00 0.00 0.00 0.00 11:31:07 11:25:01 lo 21.26 21.26 8.04 8.04 0.00 0.00 0.00 0.00 11:31:07 11:25:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:25:01 ens3 0.80 0.85 0.13 0.13 0.00 0.00 0.00 0.00 11:31:07 11:26:01 lo 37.88 37.88 12.01 12.01 0.00 0.00 0.00 0.00 11:31:07 11:26:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:26:01 ens3 1.12 1.32 0.25 0.25 0.00 0.00 0.00 0.00 11:31:07 11:27:01 lo 42.43 42.43 21.05 21.05 0.00 0.00 0.00 0.00 11:31:07 11:27:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:27:01 ens3 0.85 0.93 0.13 0.13 0.00 0.00 0.00 0.00 11:31:07 11:28:01 lo 41.18 41.18 15.17 15.17 0.00 0.00 0.00 0.00 11:31:07 11:28:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:28:01 ens3 0.90 1.10 0.17 0.18 0.00 0.00 0.00 0.00 11:31:07 11:29:01 lo 58.94 58.94 20.39 20.39 0.00 0.00 0.00 0.00 11:31:07 11:29:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:29:01 ens3 0.50 0.50 0.07 0.07 0.00 0.00 0.00 0.00 11:31:07 11:30:01 lo 74.42 74.42 24.27 24.27 0.00 0.00 0.00 0.00 11:31:07 11:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:30:01 ens3 0.78 0.95 0.35 0.31 0.00 0.00 0.00 0.00 11:31:07 11:31:01 lo 1.27 1.27 0.12 0.12 0.00 0.00 0.00 0.00 11:31:07 11:31:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 11:31:01 ens3 159.19 129.10 1962.89 21.08 0.00 0.00 0.00 0.00 11:31:07 Average: lo 20.82 20.82 10.00 10.00 0.00 0.00 0.00 0.00 11:31:07 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 11:31:07 Average: ens3 43.41 32.38 540.17 4.73 0.00 0.00 0.00 0.00 11:31:07 11:31:07 11:31:07 ---> sar -P ALL: 11:31:07 Linux 5.4.0-190-generic (prd-ubuntu2004-docker-4c-16g-2195) 10/28/24 _x86_64_ (4 CPU) 11:31:07 11:31:07 10:49:57 LINUX RESTART (4 CPU) 11:31:07 11:31:07 10:50:01 CPU %user %nice %system %iowait %steal %idle 11:31:07 10:51:02 all 16.25 18.29 15.33 3.09 0.12 46.92 11:31:07 10:51:02 0 17.01 16.95 15.50 3.07 0.12 47.36 11:31:07 10:51:02 1 12.34 19.31 16.15 3.47 0.12 48.62 11:31:07 10:51:02 2 16.19 19.18 14.91 3.38 0.12 46.22 11:31:07 10:51:02 3 19.49 17.71 14.77 2.43 0.12 45.48 11:31:07 10:52:01 all 21.26 3.51 4.49 5.82 0.06 64.85 11:31:07 10:52:01 0 21.33 2.39 4.47 14.26 0.08 57.47 11:31:07 10:52:01 1 20.10 4.55 4.56 3.88 0.05 66.87 11:31:07 10:52:01 2 23.45 4.16 5.04 2.57 0.07 64.71 11:31:07 10:52:01 3 20.16 2.96 3.89 2.52 0.05 70.42 11:31:07 10:53:01 all 76.90 0.00 4.17 10.44 0.14 8.34 11:31:07 10:53:01 0 77.16 0.00 3.88 6.26 0.15 12.54 11:31:07 10:53:01 1 75.42 0.00 4.86 12.35 0.15 7.22 11:31:07 10:53:01 2 75.53 0.00 4.02 14.15 0.14 6.15 11:31:07 10:53:01 3 79.51 0.00 3.92 8.94 0.14 7.49 11:31:07 10:54:01 all 50.60 0.00 2.76 3.05 0.19 43.39 11:31:07 10:54:01 0 77.47 0.00 4.06 2.23 0.26 15.99 11:31:07 10:54:01 1 50.89 0.00 2.47 1.88 0.14 44.63 11:31:07 10:54:01 2 27.12 0.00 2.43 6.73 0.17 63.55 11:31:07 10:54:01 3 47.32 0.00 2.10 1.36 0.20 49.02 11:31:07 10:55:01 all 72.89 0.00 3.95 14.89 0.14 8.14 11:31:07 10:55:01 0 79.08 0.00 2.98 5.61 0.14 12.19 11:31:07 10:55:01 1 77.18 0.00 3.88 8.92 0.10 9.92 11:31:07 10:55:01 2 70.05 0.00 3.62 23.71 0.17 2.46 11:31:07 10:55:01 3 65.33 0.00 5.29 21.19 0.14 8.05 11:31:07 10:56:01 all 80.89 0.00 4.29 8.18 0.13 6.51 11:31:07 10:56:01 0 80.86 0.00 4.75 8.97 0.14 5.29 11:31:07 10:56:01 1 82.08 0.00 3.88 6.12 0.12 7.79 11:31:07 10:56:01 2 81.39 0.00 4.12 10.73 0.14 3.63 11:31:07 10:56:01 3 79.22 0.00 4.40 6.95 0.12 9.31 11:31:07 10:57:01 all 63.71 0.00 2.01 0.48 0.11 33.69 11:31:07 10:57:01 0 65.50 0.00 2.12 0.12 0.10 32.16 11:31:07 10:57:01 1 63.92 0.00 1.84 0.68 0.12 33.45 11:31:07 10:57:01 2 59.48 0.00 1.82 0.47 0.10 38.14 11:31:07 10:57:01 3 65.98 0.00 2.28 0.66 0.12 30.97 11:31:07 10:58:01 all 34.32 0.00 1.28 0.47 0.11 63.82 11:31:07 10:58:01 0 32.78 0.00 1.39 0.18 0.13 65.51 11:31:07 10:58:01 1 31.45 0.00 0.99 0.35 0.10 67.11 11:31:07 10:58:01 2 35.46 0.00 1.51 0.24 0.12 62.68 11:31:07 10:58:01 3 37.59 0.00 1.23 1.13 0.10 59.95 11:31:07 10:59:01 all 36.30 0.00 1.93 0.51 0.11 61.15 11:31:07 10:59:01 0 35.27 0.00 2.07 0.32 0.10 62.24 11:31:07 10:59:01 1 35.76 0.00 2.10 1.41 0.12 60.61 11:31:07 10:59:01 2 35.65 0.00 1.43 0.15 0.10 62.67 11:31:07 10:59:01 3 38.53 0.00 2.12 0.19 0.10 59.06 11:31:07 11:00:01 all 86.17 0.00 2.83 0.36 0.14 10.51 11:31:07 11:00:01 0 86.48 0.00 2.91 0.39 0.13 10.09 11:31:07 11:00:01 1 84.77 0.00 2.73 0.12 0.14 12.24 11:31:07 11:00:01 2 86.32 0.00 2.76 0.76 0.15 10.01 11:31:07 11:00:01 3 87.10 0.00 2.91 0.17 0.14 9.69 11:31:07 11:01:01 all 32.67 0.00 1.33 1.17 0.10 64.74 11:31:07 11:01:01 0 33.75 0.00 1.64 1.89 0.10 62.62 11:31:07 11:01:01 1 31.39 0.00 1.22 2.57 0.08 64.73 11:31:07 11:01:01 2 31.73 0.00 1.25 0.22 0.08 66.72 11:31:07 11:01:01 3 33.79 0.00 1.20 0.00 0.12 64.89 11:31:07 11:31:07 11:01:01 CPU %user %nice %system %iowait %steal %idle 11:31:07 11:02:01 all 8.67 0.00 0.54 0.02 0.08 90.70 11:31:07 11:02:01 0 8.68 0.00 0.60 0.03 0.07 90.62 11:31:07 11:02:01 1 8.52 0.00 0.44 0.03 0.08 90.93 11:31:07 11:02:01 2 8.43 0.00 0.64 0.00 0.08 90.85 11:31:07 11:02:01 3 9.07 0.00 0.48 0.00 0.07 90.38 11:31:07 11:03:01 all 2.57 0.00 0.42 0.01 0.08 96.93 11:31:07 11:03:01 0 2.52 0.00 0.40 0.02 0.08 96.98 11:31:07 11:03:01 1 2.64 0.00 0.43 0.02 0.07 96.85 11:31:07 11:03:01 2 2.66 0.00 0.35 0.00 0.07 96.92 11:31:07 11:03:01 3 2.45 0.00 0.50 0.00 0.08 96.97 11:31:07 11:04:01 all 14.84 0.00 0.97 0.28 0.07 83.83 11:31:07 11:04:01 0 15.87 0.00 1.00 0.94 0.07 82.12 11:31:07 11:04:01 1 11.59 0.00 1.08 0.00 0.07 87.26 11:31:07 11:04:01 2 18.67 0.00 0.97 0.15 0.08 80.13 11:31:07 11:04:01 3 13.22 0.00 0.84 0.05 0.07 85.83 11:31:07 11:05:01 all 53.09 0.00 1.80 1.63 0.11 43.37 11:31:07 11:05:01 0 50.51 0.00 1.78 2.29 0.12 45.30 11:31:07 11:05:01 1 53.26 0.00 1.86 2.99 0.12 41.77 11:31:07 11:05:01 2 52.89 0.00 2.25 1.19 0.10 43.57 11:31:07 11:05:01 3 55.72 0.00 1.31 0.05 0.10 42.82 11:31:07 11:06:01 all 8.45 0.00 0.48 0.02 0.08 90.96 11:31:07 11:06:01 0 8.58 0.00 0.40 0.00 0.07 90.95 11:31:07 11:06:01 1 8.59 0.00 0.55 0.02 0.08 90.76 11:31:07 11:06:01 2 8.27 0.00 0.62 0.07 0.08 90.97 11:31:07 11:06:01 3 8.38 0.00 0.37 0.00 0.08 91.17 11:31:07 11:07:01 all 3.61 0.00 0.47 0.01 0.08 95.82 11:31:07 11:07:01 0 3.15 0.00 0.43 0.00 0.08 96.33 11:31:07 11:07:01 1 3.15 0.00 0.48 0.03 0.08 96.25 11:31:07 11:07:01 2 4.27 0.00 0.58 0.02 0.08 95.05 11:31:07 11:07:01 3 3.88 0.00 0.37 0.00 0.08 95.67 11:31:07 11:08:01 all 37.95 0.00 1.26 0.28 0.10 60.42 11:31:07 11:08:01 0 37.12 0.00 1.07 0.07 0.08 61.66 11:31:07 11:08:01 1 37.19 0.00 1.44 0.43 0.10 60.84 11:31:07 11:08:01 2 40.06 0.00 1.27 0.43 0.10 58.14 11:31:07 11:08:01 3 37.42 0.00 1.27 0.17 0.10 61.04 11:31:07 11:09:01 all 4.20 0.00 0.39 0.01 0.07 95.33 11:31:07 11:09:01 0 4.02 0.00 0.44 0.00 0.07 95.48 11:31:07 11:09:01 1 4.46 0.00 0.44 0.03 0.07 95.01 11:31:07 11:09:01 2 3.98 0.00 0.34 0.00 0.07 95.62 11:31:07 11:09:01 3 4.35 0.00 0.35 0.00 0.08 95.22 11:31:07 11:10:01 all 30.96 0.00 1.23 0.25 0.10 67.46 11:31:07 11:10:01 0 29.50 0.00 0.87 0.00 0.10 69.53 11:31:07 11:10:01 1 32.09 0.00 1.36 0.59 0.10 65.86 11:31:07 11:10:01 2 31.13 0.00 1.62 0.38 0.10 66.76 11:31:07 11:10:01 3 31.11 0.00 1.09 0.02 0.08 67.70 11:31:07 11:11:01 all 25.56 0.00 1.10 0.19 0.09 73.07 11:31:07 11:11:01 0 23.55 0.00 1.20 0.10 0.10 75.05 11:31:07 11:11:01 1 22.94 0.00 0.82 0.53 0.08 75.63 11:31:07 11:11:01 2 25.46 0.00 0.85 0.00 0.08 73.60 11:31:07 11:11:01 3 30.28 0.00 1.52 0.12 0.10 67.98 11:31:07 11:12:01 all 21.99 0.00 0.95 0.36 0.10 76.60 11:31:07 11:12:01 0 22.11 0.00 1.09 0.00 0.08 76.72 11:31:07 11:12:01 1 21.35 0.00 0.67 0.97 0.10 76.91 11:31:07 11:12:01 2 22.47 0.00 1.05 0.20 0.10 76.17 11:31:07 11:12:01 3 22.01 0.00 0.99 0.27 0.12 76.62 11:31:07 11:31:07 11:12:01 CPU %user %nice %system %iowait %steal %idle 11:31:07 11:13:01 all 37.64 0.00 1.54 0.38 0.09 60.36 11:31:07 11:13:01 0 34.66 0.00 1.42 0.12 0.10 63.70 11:31:07 11:13:01 1 37.36 0.00 1.65 0.97 0.10 59.91 11:31:07 11:13:01 2 42.69 0.00 1.72 0.43 0.08 55.07 11:31:07 11:13:01 3 35.81 0.00 1.35 0.00 0.07 62.78 11:31:07 11:14:01 all 58.31 0.00 1.84 1.65 0.10 38.10 11:31:07 11:14:01 0 60.89 0.00 2.04 0.97 0.10 36.00 11:31:07 11:14:01 1 55.95 0.00 2.03 0.72 0.10 41.20 11:31:07 11:14:01 2 56.38 0.00 1.83 3.07 0.10 38.63 11:31:07 11:14:01 3 60.02 0.00 1.46 1.83 0.12 36.58 11:31:07 11:15:01 all 3.12 0.00 0.20 0.04 0.07 96.57 11:31:07 11:15:01 0 2.76 0.00 0.12 0.00 0.05 97.07 11:31:07 11:15:01 1 3.15 0.00 0.29 0.00 0.08 96.48 11:31:07 11:15:01 2 3.05 0.00 0.27 0.13 0.07 96.49 11:31:07 11:15:01 3 3.51 0.00 0.13 0.03 0.07 96.25 11:31:07 11:16:01 all 2.66 0.00 0.19 0.03 0.09 97.02 11:31:07 11:16:01 0 2.44 0.00 0.18 0.02 0.10 97.26 11:31:07 11:16:01 1 3.33 0.00 0.13 0.00 0.07 96.47 11:31:07 11:16:01 2 2.58 0.00 0.30 0.00 0.12 97.01 11:31:07 11:16:01 3 2.31 0.00 0.15 0.12 0.07 97.36 11:31:07 11:17:01 all 0.40 0.00 0.12 0.03 0.08 99.38 11:31:07 11:17:01 0 0.42 0.00 0.08 0.00 0.05 99.45 11:31:07 11:17:01 1 0.42 0.00 0.17 0.00 0.10 99.31 11:31:07 11:17:01 2 0.57 0.00 0.17 0.10 0.08 99.08 11:31:07 11:17:01 3 0.20 0.00 0.05 0.00 0.07 99.68 11:31:07 11:18:01 all 0.63 0.00 0.14 0.01 0.05 99.17 11:31:07 11:18:01 0 0.12 0.00 0.05 0.00 0.03 99.80 11:31:07 11:18:01 1 1.62 0.00 0.18 0.00 0.05 98.14 11:31:07 11:18:01 2 0.38 0.00 0.15 0.00 0.05 99.41 11:31:07 11:18:01 3 0.38 0.00 0.17 0.03 0.07 99.35 11:31:07 11:19:01 all 31.83 0.00 1.34 0.17 0.11 66.54 11:31:07 11:19:01 0 32.75 0.00 1.54 0.00 0.12 65.59 11:31:07 11:19:01 1 30.57 0.00 1.38 0.03 0.14 67.88 11:31:07 11:19:01 2 34.12 0.00 1.47 0.20 0.10 64.10 11:31:07 11:19:01 3 29.88 0.00 0.98 0.46 0.10 68.58 11:31:07 11:20:01 all 24.95 0.00 0.85 0.84 0.10 73.26 11:31:07 11:20:01 0 23.73 0.00 0.62 0.05 0.08 75.52 11:31:07 11:20:01 1 25.68 0.00 0.82 0.39 0.13 72.98 11:31:07 11:20:01 2 24.38 0.00 1.04 0.40 0.10 74.07 11:31:07 11:20:01 3 26.00 0.00 0.92 2.50 0.10 70.47 11:31:07 11:21:01 all 2.77 0.00 0.26 0.13 0.05 96.78 11:31:07 11:21:01 0 2.66 0.00 0.30 0.02 0.05 96.98 11:31:07 11:21:01 1 2.89 0.00 0.25 0.02 0.05 96.79 11:31:07 11:21:01 2 2.72 0.00 0.30 0.00 0.05 96.93 11:31:07 11:21:01 3 2.80 0.00 0.20 0.50 0.07 96.43 11:31:07 11:22:01 all 3.35 0.00 0.27 0.12 0.05 96.21 11:31:07 11:22:01 0 3.31 0.00 0.22 0.00 0.05 96.43 11:31:07 11:22:01 1 3.46 0.00 0.22 0.38 0.07 95.87 11:31:07 11:22:01 2 3.40 0.00 0.38 0.08 0.05 96.08 11:31:07 11:22:01 3 3.23 0.00 0.25 0.02 0.05 96.45 11:31:07 11:23:01 all 2.26 0.00 0.28 0.01 0.06 97.38 11:31:07 11:23:01 0 2.38 0.00 0.23 0.00 0.05 97.33 11:31:07 11:23:01 1 2.12 0.00 0.22 0.05 0.05 97.56 11:31:07 11:23:01 2 2.39 0.00 0.33 0.00 0.08 97.20 11:31:07 11:23:01 3 2.16 0.00 0.35 0.00 0.07 97.42 11:31:07 11:31:07 11:23:01 CPU %user %nice %system %iowait %steal %idle 11:31:07 11:24:01 all 2.73 0.00 0.33 0.02 0.05 96.86 11:31:07 11:24:01 0 2.77 0.00 0.32 0.00 0.07 96.84 11:31:07 11:24:01 1 2.81 0.00 0.28 0.08 0.05 96.77 11:31:07 11:24:01 2 2.60 0.00 0.32 0.00 0.03 97.05 11:31:07 11:24:01 3 2.73 0.00 0.40 0.00 0.07 96.80 11:31:07 11:25:01 all 2.30 0.00 0.30 0.03 0.06 97.32 11:31:07 11:25:01 0 2.55 0.00 0.28 0.00 0.05 97.11 11:31:07 11:25:01 1 2.35 0.00 0.32 0.03 0.07 97.23 11:31:07 11:25:01 2 2.14 0.00 0.32 0.00 0.05 97.50 11:31:07 11:25:01 3 2.17 0.00 0.27 0.07 0.07 97.43 11:31:07 11:26:01 all 25.12 0.00 0.95 0.02 0.08 73.83 11:31:07 11:26:01 0 26.05 0.00 1.22 0.02 0.07 72.65 11:31:07 11:26:01 1 24.11 0.00 0.75 0.07 0.08 74.99 11:31:07 11:26:01 2 23.60 0.00 0.94 0.00 0.08 75.38 11:31:07 11:26:01 3 26.73 0.00 0.88 0.00 0.08 72.30 11:31:07 11:27:01 all 39.87 0.00 1.10 0.26 0.10 58.67 11:31:07 11:27:01 0 40.48 0.00 1.37 0.00 0.10 58.05 11:31:07 11:27:01 1 38.65 0.00 1.14 0.37 0.10 59.75 11:31:07 11:27:01 2 39.22 0.00 0.78 0.67 0.10 59.23 11:31:07 11:27:01 3 41.13 0.00 1.10 0.00 0.10 57.67 11:31:07 11:28:01 all 6.81 0.00 0.26 0.01 0.08 92.84 11:31:07 11:28:01 0 5.81 0.00 0.25 0.00 0.10 93.84 11:31:07 11:28:01 1 6.63 0.00 0.23 0.00 0.08 93.05 11:31:07 11:28:01 2 6.90 0.00 0.25 0.05 0.07 92.74 11:31:07 11:28:01 3 7.89 0.00 0.28 0.00 0.08 91.74 11:31:07 11:29:01 all 6.12 0.00 0.36 0.02 0.07 93.44 11:31:07 11:29:01 0 6.03 0.00 0.35 0.00 0.07 93.56 11:31:07 11:29:01 1 6.01 0.00 0.34 0.00 0.07 93.58 11:31:07 11:29:01 2 6.05 0.00 0.45 0.07 0.07 93.36 11:31:07 11:29:01 3 6.37 0.00 0.30 0.00 0.07 93.26 11:31:07 11:30:01 all 5.79 0.00 0.38 0.01 0.08 93.74 11:31:07 11:30:01 0 6.04 0.00 0.43 0.00 0.07 93.46 11:31:07 11:30:01 1 6.59 0.00 0.28 0.00 0.08 93.04 11:31:07 11:30:01 2 5.34 0.00 0.52 0.03 0.10 94.01 11:31:07 11:30:01 3 5.17 0.00 0.28 0.02 0.08 94.45 11:31:07 11:31:01 all 27.46 0.00 1.58 0.60 0.07 70.29 11:31:07 11:31:01 0 27.82 0.00 2.19 0.63 0.07 69.29 11:31:07 11:31:01 1 26.36 0.00 0.99 0.12 0.08 72.46 11:31:07 11:31:01 2 29.17 0.00 1.80 1.57 0.07 67.39 11:31:07 11:31:01 3 26.48 0.00 1.34 0.08 0.07 72.03 11:31:07 Average: all 25.94 0.53 1.61 1.35 0.09 70.49 11:31:07 Average: 0 26.59 0.47 1.65 1.17 0.09 70.03 11:31:07 Average: 1 25.54 0.58 1.60 1.23 0.09 70.96 11:31:07 Average: 2 25.49 0.56 1.62 1.74 0.09 70.50 11:31:07 Average: 3 26.15 0.50 1.55 1.25 0.09 70.46 11:31:07 11:31:07 11:31:07