08:29:43 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/117008 08:29:43 Running as SYSTEM 08:29:43 [EnvInject] - Loading node environment variables. 08:29:43 Building remotely on prd-ubuntu2204-docker-4c-16g-11877 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 08:29:44 [ssh-agent] Looking for ssh-agent implementation... 08:29:44 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 08:29:44 $ ssh-agent 08:29:44 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXMwx9tG/agent.1567 08:29:44 SSH_AGENT_PID=1569 08:29:44 [ssh-agent] Started. 08:29:44 Running ssh-add (command line suppressed) 08:29:44 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_7331332191867088970.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_7331332191867088970.key) 08:29:44 [ssh-agent] Using credentials jenkins (jenkins-ssh) 08:29:44 The recommended git tool is: NONE 08:29:46 using credential jenkins-ssh 08:29:46 Wiping out workspace first. 08:29:46 Cloning the remote Git repository 08:29:46 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 08:29:46 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 08:29:46 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 08:29:46 > git --version # timeout=10 08:29:46 > git --version # 'git version 2.34.1' 08:29:46 using GIT_SSH to set credentials jenkins-ssh 08:29:46 Verifying host key using known hosts file 08:29:46 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. 08:29:46 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 08:29:50 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 08:29:50 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 08:29:50 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 08:29:50 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 08:29:50 using GIT_SSH to set credentials jenkins-ssh 08:29:50 Verifying host key using known hosts file 08:29:50 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. 08:29:50 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/08/117008/23 # timeout=10 08:29:50 > git rev-parse 2428cba03f3dfe9ac7d4235aa37165325aaf8b49^{commit} # timeout=10 08:29:50 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 08:29:50 Checking out Revision 2428cba03f3dfe9ac7d4235aa37165325aaf8b49 (refs/changes/08/117008/23) 08:29:50 > git config core.sparsecheckout # timeout=10 08:29:50 > git checkout -f 2428cba03f3dfe9ac7d4235aa37165325aaf8b49 # timeout=10 08:29:51 Commit message: "Consolidation of TAPI PCE & func tests" 08:29:51 > git rev-parse FETCH_HEAD^{commit} # timeout=10 08:29:51 > git rev-list --no-walk 57e50e05598fe5e4d8a076b20dcf6eb0e1925c45 # timeout=10 08:29:51 > git remote # timeout=10 08:29:51 > git submodule init # timeout=10 08:29:51 > git submodule sync # timeout=10 08:29:51 > git config --get remote.origin.url # timeout=10 08:29:51 > git submodule init # timeout=10 08:29:51 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 08:29:51 ERROR: No submodules found. 08:29:54 provisioning config files... 08:29:54 copy managed file [npmrc] to file:/home/jenkins/.npmrc 08:29:54 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 08:29:54 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9061938855269453474.sh 08:29:54 ---> python-tools-install.sh 08:29:54 Setup pyenv: 08:29:54 * system (set by /opt/pyenv/version) 08:29:54 * 3.8.20 (set by /opt/pyenv/version) 08:29:54 * 3.9.20 (set by /opt/pyenv/version) 08:29:54 3.10.15 08:29:54 3.11.10 08:29:59 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-l63k 08:29:59 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 08:29:59 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 08:29:59 lf-activate-venv(): INFO: Attempting to install with network-safe options... 08:30:03 lf-activate-venv(): INFO: Base packages installed successfully 08:30:03 lf-activate-venv(): INFO: Installing additional packages: lftools 08:30:28 lf-activate-venv(): INFO: Adding /tmp/venv-l63k/bin to PATH 08:30:28 Generating Requirements File 08:30:49 ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts. 08:30:49 httplib2 0.31.0 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 08:30:49 Python 3.11.10 08:30:49 pip 25.3 from /tmp/venv-l63k/lib/python3.11/site-packages/pip (python 3.11) 08:30:49 appdirs==1.4.4 08:30:49 argcomplete==3.6.3 08:30:49 aspy.yaml==1.3.0 08:30:49 attrs==25.4.0 08:30:49 autopage==0.5.2 08:30:49 beautifulsoup4==4.14.2 08:30:49 boto3==1.40.76 08:30:49 botocore==1.40.76 08:30:49 bs4==0.0.2 08:30:49 cachetools==6.2.2 08:30:49 certifi==2025.11.12 08:30:49 cffi==2.0.0 08:30:49 cfgv==3.4.0 08:30:49 chardet==5.2.0 08:30:49 charset-normalizer==3.4.4 08:30:49 click==8.3.1 08:30:49 cliff==4.11.0 08:30:49 cmd2==2.7.0 08:30:49 cryptography==3.3.2 08:30:49 debtcollector==3.0.0 08:30:49 decorator==5.2.1 08:30:49 defusedxml==0.7.1 08:30:49 Deprecated==1.3.1 08:30:49 distlib==0.4.0 08:30:49 dnspython==2.8.0 08:30:49 docker==7.1.0 08:30:49 dogpile.cache==1.5.0 08:30:49 durationpy==0.10 08:30:49 email-validator==2.3.0 08:30:49 filelock==3.20.0 08:30:49 future==1.0.0 08:30:49 gitdb==4.0.12 08:30:49 GitPython==3.1.45 08:30:49 google-auth==2.43.0 08:30:49 httplib2==0.31.0 08:30:49 identify==2.6.15 08:30:49 idna==3.11 08:30:49 importlib-resources==1.5.0 08:30:49 iso8601==2.1.0 08:30:49 Jinja2==3.1.6 08:30:49 jmespath==1.0.1 08:30:49 jsonpatch==1.33 08:30:49 jsonpointer==3.0.0 08:30:49 jsonschema==4.25.1 08:30:49 jsonschema-specifications==2025.9.1 08:30:49 keystoneauth1==5.12.0 08:30:49 kubernetes==34.1.0 08:30:49 lftools==0.37.15 08:30:49 lxml==6.0.2 08:30:49 markdown-it-py==4.0.0 08:30:49 MarkupSafe==3.0.3 08:30:49 mdurl==0.1.2 08:30:49 msgpack==1.1.2 08:30:49 multi_key_dict==2.0.3 08:30:49 munch==4.0.0 08:30:49 netaddr==1.3.0 08:30:49 niet==1.4.2 08:30:49 nodeenv==1.9.1 08:30:49 oauth2client==4.1.3 08:30:49 oauthlib==3.3.1 08:30:49 openstacksdk==4.8.0 08:30:49 os-service-types==1.8.1 08:30:49 osc-lib==4.2.0 08:30:49 oslo.config==10.1.0 08:30:49 oslo.context==6.1.0 08:30:49 oslo.i18n==6.7.0 08:30:49 oslo.log==7.2.1 08:30:49 oslo.serialization==5.8.0 08:30:49 oslo.utils==9.1.0 08:30:49 packaging==25.0 08:30:49 pbr==7.0.3 08:30:49 platformdirs==4.5.0 08:30:49 prettytable==3.17.0 08:30:49 psutil==7.1.3 08:30:49 pyasn1==0.6.1 08:30:49 pyasn1_modules==0.4.2 08:30:49 pycparser==2.23 08:30:49 pygerrit2==2.0.15 08:30:49 PyGithub==2.8.1 08:30:49 Pygments==2.19.2 08:30:49 PyJWT==2.10.1 08:30:49 PyNaCl==1.6.1 08:30:49 pyparsing==2.4.7 08:30:49 pyperclip==1.11.0 08:30:49 pyrsistent==0.20.0 08:30:49 python-cinderclient==9.8.0 08:30:49 python-dateutil==2.9.0.post0 08:30:49 python-heatclient==4.3.0 08:30:49 python-jenkins==1.8.3 08:30:49 python-keystoneclient==5.7.0 08:30:49 python-magnumclient==4.9.0 08:30:49 python-openstackclient==8.2.0 08:30:49 python-swiftclient==4.9.0 08:30:49 PyYAML==6.0.3 08:30:49 referencing==0.37.0 08:30:49 requests==2.32.5 08:30:49 requests-oauthlib==2.0.0 08:30:49 requestsexceptions==1.4.0 08:30:49 rfc3986==2.0.0 08:30:49 rich==14.2.0 08:30:49 rich-argparse==1.7.2 08:30:49 rpds-py==0.29.0 08:30:49 rsa==4.9.1 08:30:49 ruamel.yaml==0.18.16 08:30:49 ruamel.yaml.clib==0.2.15 08:30:49 s3transfer==0.14.0 08:30:49 simplejson==3.20.2 08:30:49 six==1.17.0 08:30:49 smmap==5.0.2 08:30:49 soupsieve==2.8 08:30:49 stevedore==5.5.0 08:30:49 tabulate==0.9.0 08:30:49 toml==0.10.2 08:30:49 tomlkit==0.13.3 08:30:49 tqdm==4.67.1 08:30:49 typing_extensions==4.15.0 08:30:49 tzdata==2025.2 08:30:49 urllib3==1.26.20 08:30:49 virtualenv==20.35.4 08:30:49 wcwidth==0.2.14 08:30:49 websocket-client==1.9.0 08:30:49 wrapt==2.0.1 08:30:49 xdg==6.0.0 08:30:49 xmltodict==1.0.2 08:30:49 yq==3.4.3 08:30:50 [EnvInject] - Injecting environment variables from a build step. 08:30:50 [EnvInject] - Injecting as environment variables the properties content 08:30:50 PYTHON=python3 08:30:50 08:30:50 [EnvInject] - Variables injected successfully. 08:30:50 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins11739390628447202717.sh 08:30:50 ---> tox-install.sh 08:30:50 + source /home/jenkins/lf-env.sh 08:30:50 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 08:30:50 ++ mktemp -d /tmp/venv-XXXX 08:30:50 + lf_venv=/tmp/venv-eEbk 08:30:50 + local venv_file=/tmp/.os_lf_venv 08:30:50 + local python=python3 08:30:50 + local options 08:30:50 + local set_path=true 08:30:50 + local install_args= 08:30:50 ++ 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 08:30:50 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 08:30:50 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 08:30:50 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 08:30:50 + true 08:30:50 + case $1 in 08:30:50 + venv_file=/tmp/.toxenv 08:30:50 + shift 2 08:30:50 + true 08:30:50 + case $1 in 08:30:50 + shift 08:30:50 + break 08:30:50 + case $python in 08:30:50 + local pkg_list= 08:30:50 + [[ -d /opt/pyenv ]] 08:30:50 + echo 'Setup pyenv:' 08:30:50 Setup pyenv: 08:30:50 + export PYENV_ROOT=/opt/pyenv 08:30:50 + PYENV_ROOT=/opt/pyenv 08:30:50 + 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 08:30:50 + 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 08:30:50 + pyenv versions 08:30:50 system 08:30:50 3.8.20 08:30:50 3.9.20 08:30:50 3.10.15 08:30:50 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 08:30:50 + command -v pyenv 08:30:50 ++ pyenv init - --no-rehash 08:30:50 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 08:30:50 for i in ${!paths[@]}; do 08:30:50 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 08:30:50 fi; done; 08:30:50 echo "${paths[*]}"'\'')" 08:30:50 export PATH="/opt/pyenv/shims:${PATH}" 08:30:50 export PYENV_SHELL=bash 08:30:50 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 08:30:50 pyenv() { 08:30:50 local command 08:30:50 command="${1:-}" 08:30:50 if [ "$#" -gt 0 ]; then 08:30:50 shift 08:30:50 fi 08:30:50 08:30:50 case "$command" in 08:30:50 rehash|shell) 08:30:50 eval "$(pyenv "sh-$command" "$@")" 08:30:50 ;; 08:30:50 *) 08:30:50 command pyenv "$command" "$@" 08:30:50 ;; 08:30:50 esac 08:30:50 }' 08:30:50 +++ bash --norc -ec 'IFS=:; paths=($PATH); 08:30:50 for i in ${!paths[@]}; do 08:30:50 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 08:30:50 fi; done; 08:30:50 echo "${paths[*]}"' 08:30:50 ++ 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 08:30:50 ++ 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 08:30:50 ++ 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 08:30:50 ++ export PYENV_SHELL=bash 08:30:50 ++ PYENV_SHELL=bash 08:30:50 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 08:30:50 +++ complete -F _pyenv pyenv 08:30:50 ++ lf-pyver python3 08:30:50 ++ local py_version_xy=python3 08:30:50 ++ local py_version_xyz= 08:30:50 ++ sed 's/^[ *]* //' 08:30:50 ++ awk '{ print $1 }' 08:30:50 ++ pyenv versions 08:30:50 ++ local command 08:30:50 ++ command=versions 08:30:50 ++ '[' 1 -gt 0 ']' 08:30:50 ++ shift 08:30:50 ++ case "$command" in 08:30:50 ++ command pyenv versions 08:30:50 ++ grep -E '^[0-9.]*[0-9]$' 08:30:50 ++ [[ ! -s /tmp/.pyenv_versions ]] 08:30:50 +++ grep '^3' /tmp/.pyenv_versions 08:30:50 +++ sort -V 08:30:50 +++ tail -n 1 08:30:50 ++ py_version_xyz=3.11.10 08:30:50 ++ [[ -z 3.11.10 ]] 08:30:50 ++ echo 3.11.10 08:30:50 ++ return 0 08:30:50 + pyenv local 3.11.10 08:30:50 + local command 08:30:50 + command=local 08:30:50 + '[' 2 -gt 0 ']' 08:30:50 + shift 08:30:50 + case "$command" in 08:30:50 + command pyenv local 3.11.10 08:30:50 + for arg in "$@" 08:30:50 + case $arg in 08:30:50 + pkg_list+='tox ' 08:30:50 + for arg in "$@" 08:30:50 + case $arg in 08:30:50 + pkg_list+='virtualenv ' 08:30:50 + for arg in "$@" 08:30:50 + case $arg in 08:30:50 + pkg_list+='urllib3~=1.26.15 ' 08:30:50 + [[ -f /tmp/.toxenv ]] 08:30:50 + [[ ! -f /tmp/.toxenv ]] 08:30:50 + [[ -n '' ]] 08:30:50 + python3 -m venv /tmp/venv-eEbk 08:30:54 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-eEbk' 08:30:54 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-eEbk 08:30:54 + echo /tmp/venv-eEbk 08:30:54 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 08:30:54 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 08:30:54 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 08:30:54 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 08:30:54 + local 'pip_opts=--upgrade --quiet' 08:30:54 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 08:30:54 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 08:30:54 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 08:30:54 + [[ -n '' ]] 08:30:54 + [[ -n '' ]] 08:30:54 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 08:30:54 lf-activate-venv(): INFO: Attempting to install with network-safe options... 08:30:54 + /tmp/venv-eEbk/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org pip 'setuptools<66' virtualenv 08:30:58 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 08:30:58 lf-activate-venv(): INFO: Base packages installed successfully 08:30:58 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 08:30:58 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 08:30:58 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 08:30:58 + /tmp/venv-eEbk/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 08:31:00 + type python3 08:31:00 + true 08:31:00 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-eEbk/bin to PATH' 08:31:00 lf-activate-venv(): INFO: Adding /tmp/venv-eEbk/bin to PATH 08:31:00 + PATH=/tmp/venv-eEbk/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 08:31:00 + return 0 08:31:00 + python3 --version 08:31:00 Python 3.11.10 08:31:00 + python3 -m pip --version 08:31:00 pip 25.3 from /tmp/venv-eEbk/lib/python3.11/site-packages/pip (python 3.11) 08:31:00 + python3 -m pip freeze 08:31:00 cachetools==6.2.2 08:31:00 chardet==5.2.0 08:31:00 colorama==0.4.6 08:31:00 distlib==0.4.0 08:31:00 filelock==3.20.0 08:31:00 packaging==25.0 08:31:00 platformdirs==4.5.0 08:31:00 pluggy==1.6.0 08:31:00 pyproject-api==1.10.0 08:31:00 tox==4.32.0 08:31:00 urllib3==1.26.20 08:31:00 virtualenv==20.35.4 08:31:00 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins8143574629356992380.sh 08:31:00 [EnvInject] - Injecting environment variables from a build step. 08:31:00 [EnvInject] - Injecting as environment variables the properties content 08:31:00 PARALLEL=True 08:31:00 08:31:00 [EnvInject] - Variables injected successfully. 08:31:00 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins15397258004421221861.sh 08:31:00 ---> tox-run.sh 08:31:00 + 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 08:31:00 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 08:31:00 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 08:31:00 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 08:31:00 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 08:31:00 + source /home/jenkins/lf-env.sh 08:31:00 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 08:31:00 ++ mktemp -d /tmp/venv-XXXX 08:31:00 + lf_venv=/tmp/venv-Rzgp 08:31:00 + local venv_file=/tmp/.os_lf_venv 08:31:00 + local python=python3 08:31:00 + local options 08:31:00 + local set_path=true 08:31:00 + local install_args= 08:31:00 ++ 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 08:31:00 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 08:31:00 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 08:31:00 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 08:31:00 + true 08:31:00 + case $1 in 08:31:00 + venv_file=/tmp/.toxenv 08:31:00 + shift 2 08:31:00 + true 08:31:00 + case $1 in 08:31:00 + shift 08:31:00 + break 08:31:00 + case $python in 08:31:00 + local pkg_list= 08:31:00 + [[ -d /opt/pyenv ]] 08:31:00 + echo 'Setup pyenv:' 08:31:00 Setup pyenv: 08:31:00 + export PYENV_ROOT=/opt/pyenv 08:31:00 + PYENV_ROOT=/opt/pyenv 08:31:00 + 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 08:31:00 + 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 08:31:00 + pyenv versions 08:31:00 system 08:31:00 3.8.20 08:31:00 3.9.20 08:31:00 3.10.15 08:31:00 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 08:31:00 + command -v pyenv 08:31:00 ++ pyenv init - --no-rehash 08:31:00 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 08:31:00 for i in ${!paths[@]}; do 08:31:00 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 08:31:00 fi; done; 08:31:00 echo "${paths[*]}"'\'')" 08:31:00 export PATH="/opt/pyenv/shims:${PATH}" 08:31:00 export PYENV_SHELL=bash 08:31:00 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 08:31:00 pyenv() { 08:31:00 local command 08:31:00 command="${1:-}" 08:31:00 if [ "$#" -gt 0 ]; then 08:31:00 shift 08:31:00 fi 08:31:00 08:31:00 case "$command" in 08:31:00 rehash|shell) 08:31:00 eval "$(pyenv "sh-$command" "$@")" 08:31:00 ;; 08:31:00 *) 08:31:00 command pyenv "$command" "$@" 08:31:00 ;; 08:31:00 esac 08:31:00 }' 08:31:00 +++ bash --norc -ec 'IFS=:; paths=($PATH); 08:31:00 for i in ${!paths[@]}; do 08:31:00 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 08:31:00 fi; done; 08:31:00 echo "${paths[*]}"' 08:31:00 ++ 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 08:31:00 ++ 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 08:31:00 ++ 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 08:31:00 ++ export PYENV_SHELL=bash 08:31:00 ++ PYENV_SHELL=bash 08:31:00 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 08:31:00 +++ complete -F _pyenv pyenv 08:31:00 ++ lf-pyver python3 08:31:00 ++ local py_version_xy=python3 08:31:00 ++ local py_version_xyz= 08:31:00 ++ pyenv versions 08:31:00 ++ local command 08:31:00 ++ command=versions 08:31:00 ++ '[' 1 -gt 0 ']' 08:31:00 ++ shift 08:31:00 ++ case "$command" in 08:31:00 ++ command pyenv versions 08:31:00 ++ sed 's/^[ *]* //' 08:31:00 ++ grep -E '^[0-9.]*[0-9]$' 08:31:00 ++ awk '{ print $1 }' 08:31:00 ++ [[ ! -s /tmp/.pyenv_versions ]] 08:31:00 +++ grep '^3' /tmp/.pyenv_versions 08:31:00 +++ tail -n 1 08:31:00 +++ sort -V 08:31:00 ++ py_version_xyz=3.11.10 08:31:00 ++ [[ -z 3.11.10 ]] 08:31:00 ++ echo 3.11.10 08:31:00 ++ return 0 08:31:00 + pyenv local 3.11.10 08:31:00 + local command 08:31:00 + command=local 08:31:00 + '[' 2 -gt 0 ']' 08:31:00 + shift 08:31:00 + case "$command" in 08:31:00 + command pyenv local 3.11.10 08:31:00 + for arg in "$@" 08:31:00 + case $arg in 08:31:00 + pkg_list+='tox ' 08:31:00 + for arg in "$@" 08:31:00 + case $arg in 08:31:00 + pkg_list+='virtualenv ' 08:31:00 + for arg in "$@" 08:31:00 + case $arg in 08:31:00 + pkg_list+='urllib3~=1.26.15 ' 08:31:00 + [[ -f /tmp/.toxenv ]] 08:31:00 ++ cat /tmp/.toxenv 08:31:00 + lf_venv=/tmp/venv-eEbk 08:31:00 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-eEbk from' file:/tmp/.toxenv 08:31:00 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-eEbk from file:/tmp/.toxenv 08:31:00 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 08:31:00 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 08:31:00 + local 'pip_opts=--upgrade --quiet' 08:31:00 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 08:31:00 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 08:31:00 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 08:31:00 + [[ -n '' ]] 08:31:00 + [[ -n '' ]] 08:31:00 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 08:31:00 lf-activate-venv(): INFO: Attempting to install with network-safe options... 08:31:00 + /tmp/venv-eEbk/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org pip 'setuptools<66' virtualenv 08:31:01 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 08:31:01 lf-activate-venv(): INFO: Base packages installed successfully 08:31:01 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 08:31:01 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 08:31:01 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 08:31:01 + /tmp/venv-eEbk/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 08:31:03 + type python3 08:31:03 + true 08:31:03 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-eEbk/bin to PATH' 08:31:03 lf-activate-venv(): INFO: Adding /tmp/venv-eEbk/bin to PATH 08:31:03 + PATH=/tmp/venv-eEbk/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 08:31:03 + return 0 08:31:03 + [[ -d /opt/pyenv ]] 08:31:03 + echo '---> Setting up pyenv' 08:31:03 ---> Setting up pyenv 08:31:03 + export PYENV_ROOT=/opt/pyenv 08:31:03 + PYENV_ROOT=/opt/pyenv 08:31:03 + export PATH=/opt/pyenv/bin:/tmp/venv-eEbk/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 08:31:03 + PATH=/opt/pyenv/bin:/tmp/venv-eEbk/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 08:31:03 ++ pwd 08:31:03 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 08:31:03 + export PYTHONPATH 08:31:03 + export TOX_TESTENV_PASSENV=PYTHONPATH 08:31:03 + TOX_TESTENV_PASSENV=PYTHONPATH 08:31:03 + tox --version 08:31:03 4.32.0 from /tmp/venv-eEbk/lib/python3.11/site-packages/tox/__init__.py 08:31:03 + PARALLEL=True 08:31:03 + TOX_OPTIONS_LIST= 08:31:03 + [[ -n '' ]] 08:31:03 + case ${PARALLEL,,} in 08:31:03 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 08:31:03 + tox --parallel auto --parallel-live 08:31:03 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 08:31:04 docs: install_deps> python -I -m pip install -r docs/requirements.txt 08:31:04 checkbashisms: freeze> python -m pip freeze --all 08:31:04 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 08:31:04 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 08:31:05 checkbashisms: pip==25.3,setuptools==80.9.0 08:31:05 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 08:31:05 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)' 08:31:05 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 08:31:06 checkbashisms: OK ✔ in 3.11 seconds 08:31:06 pre-commit: install_deps> python -I -m pip install pre-commit 08:31:09 pre-commit: freeze> python -m pip freeze --all 08:31:09 pre-commit: cfgv==3.4.0,distlib==0.4.0,filelock==3.20.0,identify==2.6.15,nodeenv==1.9.1,pip==25.3,platformdirs==4.5.0,pre_commit==4.4.0,PyYAML==6.0.3,setuptools==80.9.0,virtualenv==20.35.4 08:31:09 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 08:31:09 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)' 08:31:09 /usr/bin/cpan 08:31:09 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 08:31:09 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 08:31:09 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 08:31:09 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 08:31:10 [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. 08:31:10 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 08:31:10 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 08:31:10 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 08:31:11 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 08:31:11 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 08:31:12 buildcontroller: freeze> python -m pip freeze --all 08:31:12 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 08:31:12 [INFO] Once installed this environment will be reused. 08:31:12 [INFO] This may take a few minutes... 08:31:12 buildcontroller: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:31:12 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 08:31:12 + update-java-alternatives -l 08:31:12 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 08:31:12 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 08:31:12 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 08:31:12 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 08:31:12 update-alternatives: error: no alternatives for jaotc 08:31:13 update-alternatives: error: no alternatives for rmic 08:31:13 + java -version 08:31:13 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 08:31:13 + JAVA_VER=21 08:31:13 + echo 21 08:31:13 21 08:31:13 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 08:31:13 + javac -version 08:31:13 + JAVAC_VER=21 08:31:13 + echo 21 08:31:13 21 08:31:13 ok, java is 21 or newer 08:31:13 + [ 21 -ge 21 ] 08:31:13 + [ 21 -ge 21 ] 08:31:13 + echo ok, java is 21 or newer 08:31:13 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz -P /tmp 08:31:14 2025-11-19 08:31:14 URL:https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz [9160848/9160848] -> "/tmp/apache-maven-3.9.11-bin.tar.gz" [1] 08:31:14 + sudo mkdir -p /opt 08:31:14 + sudo tar xf /tmp/apache-maven-3.9.11-bin.tar.gz -C /opt 08:31:14 + sudo ln -s /opt/apache-maven-3.9.11 /opt/maven 08:31:14 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 08:31:14 + mvn --version 08:31:15 Apache Maven 3.9.11 (3e54c93a704957b63ee3494413a2b544fd3d825b) 08:31:15 Maven home: /opt/maven 08:31:15 Java version: 21.0.8, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 08:31:15 Default locale: en, platform encoding: UTF-8 08:31:15 OS name: "linux", version: "5.15.0-153-generic", arch: "amd64", family: "unix" 08:31:15 NOTE: Picked up JDK_JAVA_OPTIONS: 08:31:15 --add-opens=java.base/java.io=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.lang=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.net=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.nio=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.nio.file=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.util=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.util.jar=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.util.stream=ALL-UNNAMED 08:31:15 --add-opens=java.base/java.util.zip=ALL-UNNAMED 08:31:15 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 08:31:15 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 08:31:15 -Xlog:disable 08:31:17 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 08:31:17 [INFO] Once installed this environment will be reused. 08:31:17 [INFO] This may take a few minutes... 08:31:25 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 08:31:25 [INFO] Once installed this environment will be reused. 08:31:25 [INFO] This may take a few minutes... 08:31:29 [INFO] Installing environment for https://github.com/perltidy/perltidy. 08:31:29 [INFO] Once installed this environment will be reused. 08:31:29 [INFO] This may take a few minutes... 08:31:30 docs-linkcheck: freeze> python -m pip freeze --all 08:31:31 docs-linkcheck: alabaster==1.0.0,attrs==25.4.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.11.12,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.60.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs-conf==0.9.0,MarkupSafe==3.0.3,matplotlib==3.10.7,numpy==2.3.5,nwdiag==3.0.0,packaging==25.0,pillow==12.0.0,pip==25.3,Pygments==2.19.2,pyparsing==3.2.5,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,requests-file==1.5.1,roman-numerals-py==3.1.0,seqdiag==3.0.0,setuptools==80.9.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.2,sphinx-tabs==3.4.7,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.5.0,webcolors==25.10.0 08:31:31 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 08:31:31 docs: freeze> python -m pip freeze --all 08:31:31 docs: alabaster==1.0.0,attrs==25.4.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.11.12,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.60.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs-conf==0.9.0,MarkupSafe==3.0.3,matplotlib==3.10.7,numpy==2.3.5,nwdiag==3.0.0,packaging==25.0,pillow==12.0.0,pip==25.3,Pygments==2.19.2,pyparsing==3.2.5,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,requests-file==1.5.1,roman-numerals-py==3.1.0,seqdiag==3.0.0,setuptools==80.9.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-rtd-theme==3.0.2,sphinx-tabs==3.4.7,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.5.0,webcolors==25.10.0 08:31:31 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 08:31:35 docs: OK ✔ in 31.3 seconds 08:31:35 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 08:31:38 docs-linkcheck: OK ✔ in 32.53 seconds 08:31:38 pylint: freeze> python -m pip freeze --all 08:31:38 pylint: astroid==4.0.2,dill==0.4.0,isort==7.0.0,mccabe==0.7.0,pip==25.3,platformdirs==4.5.0,pylint==4.0.3,setuptools==80.9.0,tomlkit==0.13.3 08:31:38 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}$' '{}' + 08:31:40 trim trailing whitespace.................................................Passed 08:31:41 Tabs remover.............................................................Passed 08:31:41 autopep8.................................................................Passed 08:31:47 perltidy.................................................................Passed 08:31:48 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 08:31:48 [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. 08:31:48 [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. 08:31:48 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 08:31:48 [INFO] Once installed this environment will be reused. 08:31:48 [INFO] This may take a few minutes... 08:31:56 gitlint..................................................................Passed 08:32:04 08:32:04 ------------------------------------ 08:32:04 Your code has been rated at 10.00/10 08:32:04 08:33:00 pre-commit: OK ✔ in 49.49 seconds 08:33:00 pylint: OK ✔ in 31.04 seconds 08:33:00 buildcontroller: OK ✔ in 1 minute 56.33 seconds 08:33:00 build_karaf_tests190: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 08:33:00 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 08:33:00 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 08:33:00 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 08:33:07 build_karaf_tests190: freeze> python -m pip freeze --all 08:33:07 build_karaf_tests71: freeze> python -m pip freeze --all 08:33:08 build_karaf_tests221: freeze> python -m pip freeze --all 08:33:08 build_karaf_tests121: freeze> python -m pip freeze --all 08:33:08 build_karaf_tests190: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:33:08 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 08:33:08 build_karaf_tests71: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:33:08 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 08:33:08 build karaf in karafoc with ./karafoc.env 08:33:08 build karaf in karaf71 with ./karaf71.env 08:33:08 NOTE: Picked up JDK_JAVA_OPTIONS: 08:33:08 --add-opens=java.base/java.io=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.net=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.file=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.jar=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.stream=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.zip=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 08:33:08 -Xlog:disable 08:33:08 build_karaf_tests221: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:33:08 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 08:33:08 build karaf in karaf221 with ./karaf221.env 08:33:08 build_karaf_tests121: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:33:08 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 08:33:08 build karaf in karaf121 with ./karaf121.env 08:33:08 NOTE: Picked up JDK_JAVA_OPTIONS: 08:33:08 --add-opens=java.base/java.io=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.net=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.file=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.jar=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.stream=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.zip=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 08:33:08 -Xlog:disable 08:33:08 NOTE: Picked up JDK_JAVA_OPTIONS: 08:33:08 --add-opens=java.base/java.io=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.net=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.file=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.jar=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.stream=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.zip=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 08:33:08 -Xlog:disable 08:33:08 NOTE: Picked up JDK_JAVA_OPTIONS: 08:33:08 --add-opens=java.base/java.io=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.net=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.nio.file=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.jar=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.stream=ALL-UNNAMED 08:33:08 --add-opens=java.base/java.util.zip=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 08:33:08 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 08:33:08 -Xlog:disable 08:34:02 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-install-plugin:3.1.4:install (default-install) on project transportpce-karaf: Failed to install metadata org.opendaylight.transportpce:transportpce-karaf:12.0.0-SNAPSHOT/maven-metadata.xml: Could not read metadata /home/jenkins/.m2/repository/org/opendaylight/transportpce/transportpce-karaf/12.0.0-SNAPSHOT/maven-metadata-local.xml: input contained no data -> [Help 1] 08:34:02 [ERROR] 08:34:02 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 08:34:02 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 08:34:02 [ERROR] 08:34:02 [ERROR] For more information about the errors and possible solutions, please read the following articles: 08:34:02 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException 08:34:03 build_karaf_tests190: OK ✔ in 1 minute 2.87 seconds 08:34:03 build_karaf_tests71: OK ✔ in 1 minute 2.89 seconds 08:34:03 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 08:34:03 sims: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 08:34:05 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-install-plugin:3.1.4:install (default-install) on project transportpce-karaf: Failed to install metadata org.opendaylight.transportpce:transportpce-karaf:12.0.0-SNAPSHOT/maven-metadata.xml: Could not read metadata /home/jenkins/.m2/repository/org/opendaylight/transportpce/transportpce-karaf/12.0.0-SNAPSHOT/maven-metadata-local.xml: input contained no data -> [Help 1] 08:34:05 [ERROR] 08:34:05 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 08:34:05 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 08:34:05 [ERROR] 08:34:05 [ERROR] For more information about the errors and possible solutions, please read the following articles: 08:34:05 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException 08:34:05 build_karaf_tests121: OK ✔ in 1 minute 5.74 seconds 08:34:05 build_karaf_tests221: OK ✔ in 1 minute 5.74 seconds 08:34:05 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 08:34:12 buildlighty: freeze> python -m pip freeze --all 08:34:12 sims: freeze> python -m pip freeze --all 08:34:12 buildlighty: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:34:12 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 08:34:12 sims: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:34:12 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 08:34:12 Using lighynode version 20.1.0.5 08:34:12 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 08:34:13 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 08:34:57 sims: OK ✔ in 12.95 seconds 08:34:57 buildlighty: OK ✔ in 37.38 seconds 08:34:57 testsPCE: freeze> python -m pip freeze --all 08:34:57 testsPCE: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,click==8.3.1,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.7,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.60.1,gnpy4tpce==2.4.7,idna==3.11,iniconfig==2.3.0,injector==0.22.0,invoke==2.2.1,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.4.9,lxml==6.0.2,MarkupSafe==3.0.3,matplotlib==3.10.7,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==25.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pyparsing==3.2.5,pytest==9.0.1,python-dateutil==2.9.0.post0,pytz==2025.2,requests==2.32.5,scipy==1.16.3,setuptools==50.3.2,six==1.17.0,urllib3==2.5.0,Werkzeug==2.0.3,xlrd==1.2.0 08:34:57 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 08:34:57 pytest -q transportpce_tests/pce/test01_pce.py 08:35:45 .................... [100%] 08:36:49 20 passed in 111.57s (0:01:51) 08:36:49 pytest -q transportpce_tests/pce/test02_pce_400G.py 08:37:06 ............ [100%] 08:37:36 12 passed in 47.25s 08:37:36 pytest -q transportpce_tests/pce/test03_gnpy.py 08:37:53 ........ [100%] 08:38:15 8 passed in 38.04s 08:38:15 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 08:38:48 ... [100%] 08:38:53 3 passed in 38.18s 08:38:54 testsPCE: OK ✔ in 4 minutes 48.11 seconds 08:38:54 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 08:38:54 tests190: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 08:38:54 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 08:39:01 tests_tapi: freeze> python -m pip freeze --all 08:39:01 tests121: freeze> python -m pip freeze --all 08:39:01 tests190: freeze> python -m pip freeze --all 08:39:01 tests_tapi: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:39:01 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 08:39:01 using environment variables from ./karaf221.env 08:39:01 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 08:39:01 tests121: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:39:01 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 08:39:01 using environment variables from ./karaf121.env 08:39:01 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 08:39:01 tests190: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:39:01 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 08:39:01 using environment variables from ./karafoc.env 08:39:01 pytest -q transportpce_tests/oc/test01_portmapping.py 08:40:11 ........... [100%] 08:40:27 10 passed in 86.00s (0:01:25) 08:40:28 pytest -q transportpce_tests/oc/test02_topology.py 08:40:35 .................................. [100%] 08:41:15 21 passed in 133.35s (0:02:13) 08:41:15 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 08:41:15 .......................... [100%] 08:41:35 14 passed in 67.03s (0:01:07) 08:41:35 pytest -q transportpce_tests/oc/test03_renderer.py 08:41:36 ................ [100%] 08:42:16 6 passed in 61.25s (0:01:01) 08:42:16 pytest -q transportpce_tests/1.2.1/test03_topology.py 08:42:16 .................... [100%] 08:42:35 19 passed in 59.64s 08:42:35 tests190: OK ✔ in 3 minutes 41.86 seconds 08:42:35 tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 08:42:40 .tests71: freeze> python -m pip freeze --all 08:42:44 tests71: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 08:42:44 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 08:42:44 using environment variables from ./karaf71.env 08:42:44 pytest -q transportpce_tests/7.1/test01_portmapping.py 08:43:01 .............................. [100%] 08:43:37 12 passed in 52.52s 08:43:37 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 08:43:40 .................................................... [100%] 08:44:47 44 passed in 150.90s (0:02:30) 08:44:48 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 08:44:48 ....................................................................... [100%] 08:46:12 24 passed in 84.43s (0:01:24) 08:46:12 pytest -q transportpce_tests/1.2.1/test05_olm.py 08:46:13 . [100%] 08:46:16 62 passed in 158.13s (0:02:38) 08:46:16 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 08:47:06 ........... [100%] 08:47:22 51 passed in 501.17s (0:08:21) 08:47:23 .pytest -q transportpce_tests/tapi/test02_full_topology.py 08:47:23 ......................................................................... [100%] 08:48:51 48 passed in 155.06s (0:02:35) 08:48:51 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 08:48:55 ............................ [100%] 08:49:38 40 passed in 205.20s (0:03:25) 08:49:38 pytest -q transportpce_tests/1.2.1/test06_end2end.py 08:49:39 ................. [100%] 08:50:09 22 passed in 77.50s (0:01:17) 08:50:15 .................................................... [100%] 08:52:59 36 passed in 335.67s (0:05:35) 08:52:59 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 08:53:00 ......................................................................................... [100%] 09:01:30 71 passed in 510.64s (0:08:30) 09:01:30 pytest -q transportpce_tests/tapi/test04_topo_extension.py 09:01:32 . [100%] 09:01:35 54 passed in 717.04s (0:11:57) 09:02:21 ................... [100%] 09:03:52 19 passed in 142.32s (0:02:22) 09:03:52 pytest -q transportpce_tests/tapi/test05_pce_tapi.py 09:05:53 ......................E [100%] 09:11:26 ==================================== ERRORS ==================================== 09:11:26 ______ ERROR at teardown of TransportPCEtest.test_22_get_no_tapi_services ______ 09:11:26 09:11:26 self = 09:11:26 09:11:26 def _new_conn(self) -> socket.socket: 09:11:26 """Establish a socket connection and set nodelay settings on it. 09:11:26 09:11:26 :return: New socket connection. 09:11:26 """ 09:11:26 try: 09:11:26 > sock = connection.create_connection( 09:11:26 (self._dns_host, self.port), 09:11:26 self.timeout, 09:11:26 source_address=self.source_address, 09:11:26 socket_options=self.socket_options, 09:11:26 ) 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:198: 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 09:11:26 raise err 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 09:11:26 address = ('localhost', 8183), timeout = 30, source_address = None 09:11:26 socket_options = [(6, 1, 1)] 09:11:26 09:11:26 def create_connection( 09:11:26 address: tuple[str, int], 09:11:26 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 09:11:26 source_address: tuple[str, int] | None = None, 09:11:26 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 09:11:26 ) -> socket.socket: 09:11:26 """Connect to *address* and return the socket object. 09:11:26 09:11:26 Convenience function. Connect to *address* (a 2-tuple ``(host, 09:11:26 port)``) and return the socket object. Passing the optional 09:11:26 *timeout* parameter will set the timeout on the socket instance 09:11:26 before attempting to connect. If no *timeout* is supplied, the 09:11:26 global default timeout setting returned by :func:`socket.getdefaulttimeout` 09:11:26 is used. If *source_address* is set it must be a tuple of (host, port) 09:11:26 for the socket to bind as a source address before making the connection. 09:11:26 An host of '' or port 0 tells the OS to use the default. 09:11:26 """ 09:11:26 09:11:26 host, port = address 09:11:26 if host.startswith("["): 09:11:26 host = host.strip("[]") 09:11:26 err = None 09:11:26 09:11:26 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 09:11:26 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 09:11:26 # The original create_connection function always returns all records. 09:11:26 family = allowed_gai_family() 09:11:26 09:11:26 try: 09:11:26 host.encode("idna") 09:11:26 except UnicodeError: 09:11:26 raise LocationParseError(f"'{host}', label empty or too long") from None 09:11:26 09:11:26 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 09:11:26 af, socktype, proto, canonname, sa = res 09:11:26 sock = None 09:11:26 try: 09:11:26 sock = socket.socket(af, socktype, proto) 09:11:26 09:11:26 # If provided, set socket level options before connecting. 09:11:26 _set_socket_options(sock, socket_options) 09:11:26 09:11:26 if timeout is not _DEFAULT_TIMEOUT: 09:11:26 sock.settimeout(timeout) 09:11:26 if source_address: 09:11:26 sock.bind(source_address) 09:11:26 > sock.connect(sa) 09:11:26 E ConnectionRefusedError: [Errno 111] Connection refused 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 09:11:26 09:11:26 The above exception was the direct cause of the following exception: 09:11:26 09:11:26 self = 09:11:26 method = 'GET' 09:11:26 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 09:11:26 body = None 09:11:26 headers = {'User-Agent': 'python-requests/2.32.5', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 09:11:26 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 09:11:26 redirect = False, assert_same_host = False 09:11:26 timeout = Timeout(connect=30, read=30, total=None), pool_timeout = None 09:11:26 release_conn = False, chunked = False, body_pos = None, preload_content = False 09:11:26 decode_content = False, response_kw = {} 09:11:26 parsed_url = Url(scheme=None, auth=None, host=None, port=None, path='/rests/data/ietf-network:networks/network=otn-topology', query='content=config', fragment=None) 09:11:26 destination_scheme = None, conn = None, release_this_conn = True 09:11:26 http_tunnel_required = False, err = None, clean_exit = False 09:11:26 09:11:26 def urlopen( # type: ignore[override] 09:11:26 self, 09:11:26 method: str, 09:11:26 url: str, 09:11:26 body: _TYPE_BODY | None = None, 09:11:26 headers: typing.Mapping[str, str] | None = None, 09:11:26 retries: Retry | bool | int | None = None, 09:11:26 redirect: bool = True, 09:11:26 assert_same_host: bool = True, 09:11:26 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 09:11:26 pool_timeout: int | None = None, 09:11:26 release_conn: bool | None = None, 09:11:26 chunked: bool = False, 09:11:26 body_pos: _TYPE_BODY_POSITION | None = None, 09:11:26 preload_content: bool = True, 09:11:26 decode_content: bool = True, 09:11:26 **response_kw: typing.Any, 09:11:26 ) -> BaseHTTPResponse: 09:11:26 """ 09:11:26 Get a connection from the pool and perform an HTTP request. This is the 09:11:26 lowest level call for making a request, so you'll need to specify all 09:11:26 the raw details. 09:11:26 09:11:26 .. note:: 09:11:26 09:11:26 More commonly, it's appropriate to use a convenience method 09:11:26 such as :meth:`request`. 09:11:26 09:11:26 .. note:: 09:11:26 09:11:26 `release_conn` will only behave as expected if 09:11:26 `preload_content=False` because we want to make 09:11:26 `preload_content=False` the default behaviour someday soon without 09:11:26 breaking backwards compatibility. 09:11:26 09:11:26 :param method: 09:11:26 HTTP request method (such as GET, POST, PUT, etc.) 09:11:26 09:11:26 :param url: 09:11:26 The URL to perform the request on. 09:11:26 09:11:26 :param body: 09:11:26 Data to send in the request body, either :class:`str`, :class:`bytes`, 09:11:26 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 09:11:26 09:11:26 :param headers: 09:11:26 Dictionary of custom headers to send, such as User-Agent, 09:11:26 If-None-Match, etc. If None, pool headers are used. If provided, 09:11:26 these headers completely replace any pool-specific headers. 09:11:26 09:11:26 :param retries: 09:11:26 Configure the number of retries to allow before raising a 09:11:26 :class:`~urllib3.exceptions.MaxRetryError` exception. 09:11:26 09:11:26 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 09:11:26 :class:`~urllib3.util.retry.Retry` object for fine-grained control 09:11:26 over different types of retries. 09:11:26 Pass an integer number to retry connection errors that many times, 09:11:26 but no other types of errors. Pass zero to never retry. 09:11:26 09:11:26 If ``False``, then retries are disabled and any exception is raised 09:11:26 immediately. Also, instead of raising a MaxRetryError on redirects, 09:11:26 the redirect response will be returned. 09:11:26 09:11:26 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 09:11:26 09:11:26 :param redirect: 09:11:26 If True, automatically handle redirects (status codes 301, 302, 09:11:26 303, 307, 308). Each redirect counts as a retry. Disabling retries 09:11:26 will disable redirect, too. 09:11:26 09:11:26 :param assert_same_host: 09:11:26 If ``True``, will make sure that the host of the pool requests is 09:11:26 consistent else will raise HostChangedError. When ``False``, you can 09:11:26 use the pool on an HTTP proxy and request foreign hosts. 09:11:26 09:11:26 :param timeout: 09:11:26 If specified, overrides the default timeout for this one 09:11:26 request. It may be a float (in seconds) or an instance of 09:11:26 :class:`urllib3.util.Timeout`. 09:11:26 09:11:26 :param pool_timeout: 09:11:26 If set and the pool is set to block=True, then this method will 09:11:26 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 09:11:26 connection is available within the time period. 09:11:26 09:11:26 :param bool preload_content: 09:11:26 If True, the response's body will be preloaded into memory. 09:11:26 09:11:26 :param bool decode_content: 09:11:26 If True, will attempt to decode the body based on the 09:11:26 'content-encoding' header. 09:11:26 09:11:26 :param release_conn: 09:11:26 If False, then the urlopen call will not release the connection 09:11:26 back into the pool once a response is received (but will release if 09:11:26 you read the entire contents of the response such as when 09:11:26 `preload_content=True`). This is useful if you're not preloading 09:11:26 the response's content immediately. You will need to call 09:11:26 ``r.release_conn()`` on the response ``r`` to return the connection 09:11:26 back into the pool. If None, it takes the value of ``preload_content`` 09:11:26 which defaults to ``True``. 09:11:26 09:11:26 :param bool chunked: 09:11:26 If True, urllib3 will send the body using chunked transfer 09:11:26 encoding. Otherwise, urllib3 will send the body using the standard 09:11:26 content-length form. Defaults to False. 09:11:26 09:11:26 :param int body_pos: 09:11:26 Position to seek to in file-like body in the event of a retry or 09:11:26 redirect. Typically this won't need to be set because urllib3 will 09:11:26 auto-populate the value when needed. 09:11:26 """ 09:11:26 parsed_url = parse_url(url) 09:11:26 destination_scheme = parsed_url.scheme 09:11:26 09:11:26 if headers is None: 09:11:26 headers = self.headers 09:11:26 09:11:26 if not isinstance(retries, Retry): 09:11:26 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 09:11:26 09:11:26 if release_conn is None: 09:11:26 release_conn = preload_content 09:11:26 09:11:26 # Check host 09:11:26 if assert_same_host and not self.is_same_host(url): 09:11:26 raise HostChangedError(self, url, retries) 09:11:26 09:11:26 # Ensure that the URL we're connecting to is properly encoded 09:11:26 if url.startswith("/"): 09:11:26 url = to_str(_encode_target(url)) 09:11:26 else: 09:11:26 url = to_str(parsed_url.url) 09:11:26 09:11:26 conn = None 09:11:26 09:11:26 # Track whether `conn` needs to be released before 09:11:26 # returning/raising/recursing. Update this variable if necessary, and 09:11:26 # leave `release_conn` constant throughout the function. That way, if 09:11:26 # the function recurses, the original value of `release_conn` will be 09:11:26 # passed down into the recursive call, and its value will be respected. 09:11:26 # 09:11:26 # See issue #651 [1] for details. 09:11:26 # 09:11:26 # [1] 09:11:26 release_this_conn = release_conn 09:11:26 09:11:26 http_tunnel_required = connection_requires_http_tunnel( 09:11:26 self.proxy, self.proxy_config, destination_scheme 09:11:26 ) 09:11:26 09:11:26 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 09:11:26 # have to copy the headers dict so we can safely change it without those 09:11:26 # changes being reflected in anyone else's copy. 09:11:26 if not http_tunnel_required: 09:11:26 headers = headers.copy() # type: ignore[attr-defined] 09:11:26 headers.update(self.proxy_headers) # type: ignore[union-attr] 09:11:26 09:11:26 # Must keep the exception bound to a separate variable or else Python 3 09:11:26 # complains about UnboundLocalError. 09:11:26 err = None 09:11:26 09:11:26 # Keep track of whether we cleanly exited the except block. This 09:11:26 # ensures we do proper cleanup in finally. 09:11:26 clean_exit = False 09:11:26 09:11:26 # Rewind body position, if needed. Record current position 09:11:26 # for future rewinds in the event of a redirect/retry. 09:11:26 body_pos = set_file_position(body, body_pos) 09:11:26 09:11:26 try: 09:11:26 # Request a connection from the queue. 09:11:26 timeout_obj = self._get_timeout(timeout) 09:11:26 conn = self._get_conn(timeout=pool_timeout) 09:11:26 09:11:26 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 09:11:26 09:11:26 # Is this a closed/new connection that requires CONNECT tunnelling? 09:11:26 if self.proxy is not None and http_tunnel_required and conn.is_closed: 09:11:26 try: 09:11:26 self._prepare_proxy(conn) 09:11:26 except (BaseSSLError, OSError, SocketTimeout) as e: 09:11:26 self._raise_timeout( 09:11:26 err=e, url=self.proxy.url, timeout_value=conn.timeout 09:11:26 ) 09:11:26 raise 09:11:26 09:11:26 # If we're going to release the connection in ``finally:``, then 09:11:26 # the response doesn't need to know about the connection. Otherwise 09:11:26 # it will also try to release it and we'll have a double-release 09:11:26 # mess. 09:11:26 response_conn = conn if not release_conn else None 09:11:26 09:11:26 # Make the request on the HTTPConnection object 09:11:26 > response = self._make_request( 09:11:26 conn, 09:11:26 method, 09:11:26 url, 09:11:26 timeout=timeout_obj, 09:11:26 body=body, 09:11:26 headers=headers, 09:11:26 chunked=chunked, 09:11:26 retries=retries, 09:11:26 response_conn=response_conn, 09:11:26 preload_content=preload_content, 09:11:26 decode_content=decode_content, 09:11:26 **response_kw, 09:11:26 ) 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:493: in _make_request 09:11:26 conn.request( 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:494: in request 09:11:26 self.endheaders() 09:11:26 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 09:11:26 self._send_output(message_body, encode_chunked=encode_chunked) 09:11:26 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 09:11:26 self.send(msg) 09:11:26 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 09:11:26 self.connect() 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:325: in connect 09:11:26 self.sock = self._new_conn() 09:11:26 ^^^^^^^^^^^^^^^^ 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 09:11:26 self = 09:11:26 09:11:26 def _new_conn(self) -> socket.socket: 09:11:26 """Establish a socket connection and set nodelay settings on it. 09:11:26 09:11:26 :return: New socket connection. 09:11:26 """ 09:11:26 try: 09:11:26 sock = connection.create_connection( 09:11:26 (self._dns_host, self.port), 09:11:26 self.timeout, 09:11:26 source_address=self.source_address, 09:11:26 socket_options=self.socket_options, 09:11:26 ) 09:11:26 except socket.gaierror as e: 09:11:26 raise NameResolutionError(self.host, self, e) from e 09:11:26 except SocketTimeout as e: 09:11:26 raise ConnectTimeoutError( 09:11:26 self, 09:11:26 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 09:11:26 ) from e 09:11:26 09:11:26 except OSError as e: 09:11:26 > raise NewConnectionError( 09:11:26 self, f"Failed to establish a new connection: {e}" 09:11:26 ) from e 09:11:26 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:213: NewConnectionError 09:11:26 09:11:26 The above exception was the direct cause of the following exception: 09:11:26 09:11:26 self = 09:11:26 request = , stream = False 09:11:26 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 09:11:26 proxies = OrderedDict() 09:11:26 09:11:26 def send( 09:11:26 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 09:11:26 ): 09:11:26 """Sends PreparedRequest object. Returns Response object. 09:11:26 09:11:26 :param request: The :class:`PreparedRequest ` being sent. 09:11:26 :param stream: (optional) Whether to stream the request content. 09:11:26 :param timeout: (optional) How long to wait for the server to send 09:11:26 data before giving up, as a float, or a :ref:`(connect timeout, 09:11:26 read timeout) ` tuple. 09:11:26 :type timeout: float or tuple or urllib3 Timeout object 09:11:26 :param verify: (optional) Either a boolean, in which case it controls whether 09:11:26 we verify the server's TLS certificate, or a string, in which case it 09:11:26 must be a path to a CA bundle to use 09:11:26 :param cert: (optional) Any user-provided SSL certificate to be trusted. 09:11:26 :param proxies: (optional) The proxies dictionary to apply to the request. 09:11:26 :rtype: requests.Response 09:11:26 """ 09:11:26 09:11:26 try: 09:11:26 conn = self.get_connection_with_tls_context( 09:11:26 request, verify, proxies=proxies, cert=cert 09:11:26 ) 09:11:26 except LocationValueError as e: 09:11:26 raise InvalidURL(e, request=request) 09:11:26 09:11:26 self.cert_verify(conn, request.url, verify, cert) 09:11:26 url = self.request_url(request, proxies) 09:11:26 self.add_headers( 09:11:26 request, 09:11:26 stream=stream, 09:11:26 timeout=timeout, 09:11:26 verify=verify, 09:11:26 cert=cert, 09:11:26 proxies=proxies, 09:11:26 ) 09:11:26 09:11:26 chunked = not (request.body is None or "Content-Length" in request.headers) 09:11:26 09:11:26 if isinstance(timeout, tuple): 09:11:26 try: 09:11:26 connect, read = timeout 09:11:26 timeout = TimeoutSauce(connect=connect, read=read) 09:11:26 except ValueError: 09:11:26 raise ValueError( 09:11:26 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 09:11:26 f"or a single float to set both timeouts to the same value." 09:11:26 ) 09:11:26 elif isinstance(timeout, TimeoutSauce): 09:11:26 pass 09:11:26 else: 09:11:26 timeout = TimeoutSauce(connect=timeout, read=timeout) 09:11:26 09:11:26 try: 09:11:26 > resp = conn.urlopen( 09:11:26 method=request.method, 09:11:26 url=url, 09:11:26 body=request.body, 09:11:26 headers=request.headers, 09:11:26 redirect=False, 09:11:26 assert_same_host=False, 09:11:26 preload_content=False, 09:11:26 decode_content=False, 09:11:26 retries=self.max_retries, 09:11:26 timeout=timeout, 09:11:26 chunked=chunked, 09:11:26 ) 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:644: 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 09:11:26 retries = retries.increment( 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 09:11:26 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 09:11:26 method = 'GET' 09:11:26 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 09:11:26 response = None 09:11:26 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 09:11:26 _pool = 09:11:26 _stacktrace = 09:11:26 09:11:26 def increment( 09:11:26 self, 09:11:26 method: str | None = None, 09:11:26 url: str | None = None, 09:11:26 response: BaseHTTPResponse | None = None, 09:11:26 error: Exception | None = None, 09:11:26 _pool: ConnectionPool | None = None, 09:11:26 _stacktrace: TracebackType | None = None, 09:11:26 ) -> Self: 09:11:26 """Return a new Retry object with incremented retry counters. 09:11:26 09:11:26 :param response: A response object, or None, if the server did not 09:11:26 return a response. 09:11:26 :type response: :class:`~urllib3.response.BaseHTTPResponse` 09:11:26 :param Exception error: An error encountered during the request, or 09:11:26 None if the response was received successfully. 09:11:26 09:11:26 :return: A new ``Retry`` object. 09:11:26 """ 09:11:26 if self.total is False and error: 09:11:26 # Disabled, indicate to re-raise the error. 09:11:26 raise reraise(type(error), error, _stacktrace) 09:11:26 09:11:26 total = self.total 09:11:26 if total is not None: 09:11:26 total -= 1 09:11:26 09:11:26 connect = self.connect 09:11:26 read = self.read 09:11:26 redirect = self.redirect 09:11:26 status_count = self.status 09:11:26 other = self.other 09:11:26 cause = "unknown" 09:11:26 status = None 09:11:26 redirect_location = None 09:11:26 09:11:26 if error and self._is_connection_error(error): 09:11:26 # Connect retry? 09:11:26 if connect is False: 09:11:26 raise reraise(type(error), error, _stacktrace) 09:11:26 elif connect is not None: 09:11:26 connect -= 1 09:11:26 09:11:26 elif error and self._is_read_error(error): 09:11:26 # Read retry? 09:11:26 if read is False or method is None or not self._is_method_retryable(method): 09:11:26 raise reraise(type(error), error, _stacktrace) 09:11:26 elif read is not None: 09:11:26 read -= 1 09:11:26 09:11:26 elif error: 09:11:26 # Other retry? 09:11:26 if other is not None: 09:11:26 other -= 1 09:11:26 09:11:26 elif response and response.get_redirect_location(): 09:11:26 # Redirect retry? 09:11:26 if redirect is not None: 09:11:26 redirect -= 1 09:11:26 cause = "too many redirects" 09:11:26 response_redirect_location = response.get_redirect_location() 09:11:26 if response_redirect_location: 09:11:26 redirect_location = response_redirect_location 09:11:26 status = response.status 09:11:26 09:11:26 else: 09:11:26 # Incrementing because of a server error like a 500 in 09:11:26 # status_forcelist and the given method is in the allowed_methods 09:11:26 cause = ResponseError.GENERIC_ERROR 09:11:26 if response and response.status: 09:11:26 if status_count is not None: 09:11:26 status_count -= 1 09:11:26 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 09:11:26 status = response.status 09:11:26 09:11:26 history = self.history + ( 09:11:26 RequestHistory(method, url, error, status, redirect_location), 09:11:26 ) 09:11:26 09:11:26 new_retry = self.new( 09:11:26 total=total, 09:11:26 connect=connect, 09:11:26 read=read, 09:11:26 redirect=redirect, 09:11:26 status=status_count, 09:11:26 other=other, 09:11:26 history=history, 09:11:26 ) 09:11:26 09:11:26 if new_retry.is_exhausted(): 09:11:26 reason = error or ResponseError(cause) 09:11:26 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 E urllib3.exceptions.MaxRetryError: HTTPConnectionPool(host='localhost', port=8183): Max retries exceeded with url: /rests/data/ietf-network:networks/network=otn-topology?content=config (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 09:11:26 09:11:26 During handling of the above exception, another exception occurred: 09:11:26 09:11:26 cls = 09:11:26 09:11:26 @classmethod 09:11:26 def tearDownClass(cls): 09:11:26 test_utils_generate_tapi_topo.cleanup_and_disconnect_devices() 09:11:26 # pylint: disable=not-an-iterable 09:11:26 for process in cls.processes: 09:11:26 test_utils.shutdown_process(process) 09:11:26 print("all processes killed") 09:11:26 test_utils.copy_karaf_log(cls.__name__) 09:11:26 > test_utils_generate_tapi_topo.uninstall_Tapi_Feature() 09:11:26 09:11:26 transportpce_tests/tapi/test05_pce_tapi.py:345: 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 transportpce_tests/common/test_utils_generate_tapi_topo.py:383: in uninstall_Tapi_Feature 09:11:26 response = test_utils.get_ietf_network_request('otn-topology', 'config') 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 09:11:26 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 transportpce_tests/common/test_utils.py:117: in get_request 09:11:26 return requests.request( 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 09:11:26 return session.request(method=method, url=url, **kwargs) 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:589: in request 09:11:26 resp = self.send(prep, **send_kwargs) 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:703: in send 09:11:26 r = adapter.send(request, **kwargs) 09:11:26 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:11:26 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:11:26 09:11:26 self = 09:11:26 request = , stream = False 09:11:26 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 09:11:26 proxies = OrderedDict() 09:11:26 09:11:26 def send( 09:11:26 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 09:11:26 ): 09:11:26 """Sends PreparedRequest object. Returns Response object. 09:11:26 09:11:26 :param request: The :class:`PreparedRequest ` being sent. 09:11:26 :param stream: (optional) Whether to stream the request content. 09:11:26 :param timeout: (optional) How long to wait for the server to send 09:11:26 data before giving up, as a float, or a :ref:`(connect timeout, 09:11:26 read timeout) ` tuple. 09:11:26 :type timeout: float or tuple or urllib3 Timeout object 09:11:26 :param verify: (optional) Either a boolean, in which case it controls whether 09:11:26 we verify the server's TLS certificate, or a string, in which case it 09:11:26 must be a path to a CA bundle to use 09:11:26 :param cert: (optional) Any user-provided SSL certificate to be trusted. 09:11:26 :param proxies: (optional) The proxies dictionary to apply to the request. 09:11:26 :rtype: requests.Response 09:11:26 """ 09:11:26 09:11:26 try: 09:11:26 conn = self.get_connection_with_tls_context( 09:11:26 request, verify, proxies=proxies, cert=cert 09:11:26 ) 09:11:26 except LocationValueError as e: 09:11:26 raise InvalidURL(e, request=request) 09:11:26 09:11:26 self.cert_verify(conn, request.url, verify, cert) 09:11:26 url = self.request_url(request, proxies) 09:11:26 self.add_headers( 09:11:26 request, 09:11:26 stream=stream, 09:11:26 timeout=timeout, 09:11:26 verify=verify, 09:11:26 cert=cert, 09:11:26 proxies=proxies, 09:11:26 ) 09:11:26 09:11:26 chunked = not (request.body is None or "Content-Length" in request.headers) 09:11:26 09:11:26 if isinstance(timeout, tuple): 09:11:26 try: 09:11:26 connect, read = timeout 09:11:26 timeout = TimeoutSauce(connect=connect, read=read) 09:11:26 except ValueError: 09:11:26 raise ValueError( 09:11:26 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 09:11:26 f"or a single float to set both timeouts to the same value." 09:11:26 ) 09:11:26 elif isinstance(timeout, TimeoutSauce): 09:11:26 pass 09:11:26 else: 09:11:26 timeout = TimeoutSauce(connect=timeout, read=timeout) 09:11:26 09:11:26 try: 09:11:26 resp = conn.urlopen( 09:11:26 method=request.method, 09:11:26 url=url, 09:11:26 body=request.body, 09:11:26 headers=request.headers, 09:11:26 redirect=False, 09:11:26 assert_same_host=False, 09:11:26 preload_content=False, 09:11:26 decode_content=False, 09:11:26 retries=self.max_retries, 09:11:26 timeout=timeout, 09:11:26 chunked=chunked, 09:11:26 ) 09:11:26 09:11:26 except (ProtocolError, OSError) as err: 09:11:26 raise ConnectionError(err, request=request) 09:11:26 09:11:26 except MaxRetryError as e: 09:11:26 if isinstance(e.reason, ConnectTimeoutError): 09:11:26 # TODO: Remove this in 3.0.0: see #2811 09:11:26 if not isinstance(e.reason, NewConnectionError): 09:11:26 raise ConnectTimeout(e, request=request) 09:11:26 09:11:26 if isinstance(e.reason, ResponseError): 09:11:26 raise RetryError(e, request=request) 09:11:26 09:11:26 if isinstance(e.reason, _ProxyError): 09:11:26 raise ProxyError(e, request=request) 09:11:26 09:11:26 if isinstance(e.reason, _SSLError): 09:11:26 # This branch is for urllib3 v1.22 and later. 09:11:26 raise SSLError(e, request=request) 09:11:26 09:11:26 > raise ConnectionError(e, request=request) 09:11:26 E requests.exceptions.ConnectionError: HTTPConnectionPool(host='localhost', port=8183): Max retries exceeded with url: /rests/data/ietf-network:networks/network=otn-topology?content=config (Caused by NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused')) 09:11:26 09:11:26 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:677: ConnectionError 09:11:26 --------------------------- Captured stdout teardown --------------------------- 09:11:26 Searching for patterns in karaf.log... Pattern found! Node XPDR-A1 correctly deleted from tpce topology... Searching for patterns in karaf.log... Pattern found! Node SPDR-SA1 correctly deleted from tpce topology... all processes killed 09:11:26 ODL log file stored 09:11:26 uninstalling feature odl-transportpce-tapi 09:11:26 client: JAVA_HOME not set; results may vary 09:11:26 --------------------------- Captured stderr teardown --------------------------- 09:11:26 Failed to get the session. 09:11:26 =========================== short test summary info ============================ 09:11:26 ERROR transportpce_tests/tapi/test05_pce_tapi.py::TransportPCEtest::test_22_get_no_tapi_services 09:11:26 22 passed, 1 error in 453.44s (0:07:33) 09:11:26 tests71: OK ✔ in 7 minutes 34.06 seconds 09:11:26 tests121: OK ✔ in 22 minutes 42.01 seconds 09:11:26 tests_tapi: exit 1 (1944.92 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7180 09:11:26 tests_tapi: FAIL ✖ in 32 minutes 32.66 seconds 09:11:26 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 09:11:33 tests221: freeze> python -m pip freeze --all 09:11:34 tests221: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 09:11:34 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 09:11:34 using environment variables from ./karaf221.env 09:11:34 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 09:12:10 ................................... [100%] 09:12:50 35 passed in 76.36s (0:01:16) 09:12:50 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 09:13:23 .F..F. [100%] 09:13:36 =================================== FAILURES =================================== 09:13:36 _ TestTransportPCETopoPortmapping.test_02_compareOpenroadmTopologyPortMapping_rdm _ 09:13:36 09:13:36 self = 09:13:36 09:13:36 def test_02_compareOpenroadmTopologyPortMapping_rdm(self): 09:13:36 resTopo = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:13:36 self.assertEqual(resTopo['status_code'], requests.codes.ok) 09:13:36 nbMapCumul = 0 09:13:36 nbMappings = 0 09:13:36 for node in resTopo['network'][0]['node']: 09:13:36 nodeId = node['node-id'] 09:13:36 # pylint: disable=consider-using-f-string 09:13:36 print("nodeId={}".format(nodeId)) 09:13:36 nodeMapId = nodeId.split("-")[0] + "-" + nodeId.split("-")[1] 09:13:36 print("nodeMapId={}".format(nodeMapId)) 09:13:36 response = test_utils.get_portmapping_node_attr(nodeMapId, "node-info", None) 09:13:36 > self.assertEqual(response['status_code'], requests.codes.ok) 09:13:36 E AssertionError: 409 != 200 09:13:36 09:13:36 transportpce_tests/2.2.1/test02_topo_portmapping.py:65: AssertionError 09:13:36 ----------------------------- Captured stdout call ----------------------------- 09:13:36 nodeId=ROADM-A1-SRG3 09:13:36 nodeMapId=ROADM-A1 09:13:36 nodeId=ROADM-A1-DEG1 09:13:36 nodeMapId=ROADM-A1 09:13:36 nodeId=TAPI-SBI-ABS-NODE 09:13:36 nodeMapId=TAPI-SBI 09:13:36 _ TestTransportPCETopoPortmapping.test_05_compareOpenroadmTopologyPortMapping_xpdr _ 09:13:36 09:13:36 self = 09:13:36 09:13:36 def test_05_compareOpenroadmTopologyPortMapping_xpdr(self): 09:13:36 > self.test_02_compareOpenroadmTopologyPortMapping_rdm() 09:13:36 09:13:36 transportpce_tests/2.2.1/test02_topo_portmapping.py:92: 09:13:36 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:13:36 transportpce_tests/2.2.1/test02_topo_portmapping.py:65: in test_02_compareOpenroadmTopologyPortMapping_rdm 09:13:36 self.assertEqual(response['status_code'], requests.codes.ok) 09:13:36 E AssertionError: 409 != 200 09:13:36 ----------------------------- Captured stdout call ----------------------------- 09:13:36 nodeId=TAPI-SBI-ABS-NODE 09:13:36 nodeMapId=TAPI-SBI 09:13:36 =========================== short test summary info ============================ 09:13:36 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_02_compareOpenroadmTopologyPortMapping_rdm 09:13:36 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_05_compareOpenroadmTopologyPortMapping_xpdr 09:13:36 2 failed, 4 passed in 45.72s 09:13:36 tests221: exit 1 (122.66 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 pid=27529 09:13:37 tests221: FAIL ✖ in 2 minutes 10.45 seconds 09:13:37 tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 09:13:43 tests_hybrid: freeze> python -m pip freeze --all 09:13:44 tests_hybrid: bcrypt==5.0.0,certifi==2025.11.12,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,dict2xml==1.7.7,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.3,pluggy==1.6.0,psutil==7.1.3,pycparser==2.23,Pygments==2.19.2,PyNaCl==1.6.1,pytest==9.0.1,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 09:13:44 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 09:13:44 using environment variables from ./karaf221.env 09:13:44 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 09:14:25 ..............F...F...F..F...F..F...F..F...F....... [100%] 09:19:03 =================================== FAILURES =================================== 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_15_check_update_openroadm_topo _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_15_check_update_openroadm_topo(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 nb_updated_tp = 0 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:237: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_15_check_update_openroadm_topo 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_19_check_update_openroadm_topo_ok _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_19_check_update_openroadm_topo_ok(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_19_check_update_openroadm_topo_ok 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_23_check_update_openroadm_topo _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_23_check_update_openroadm_topo(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 nb_updated_tp = 0 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:351: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_23_check_update_openroadm_topo 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_26_check_update_openroadm_topo_ok _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_26_check_update_openroadm_topo_ok(self): 09:19:03 > self.test_19_check_update_openroadm_topo_ok() 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:393: 09:19:03 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_19_check_update_openroadm_topo_ok(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_26_check_update_openroadm_topo_ok 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_30_check_update_openroadm_topo _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_30_check_update_openroadm_topo(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 nb_updated_tp = 0 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:435: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_30_check_update_openroadm_topo 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_33_check_update_openroadm_topo_ok _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_33_check_update_openroadm_topo_ok(self): 09:19:03 > self.test_19_check_update_openroadm_topo_ok() 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:477: 09:19:03 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_19_check_update_openroadm_topo_ok(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_33_check_update_openroadm_topo_ok 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_37_check_update_openroadm_topo _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_37_check_update_openroadm_topo(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 nb_updated_tp = 0 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:517: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_37_check_update_openroadm_topo 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_40_check_update_openroadm_topo_ok _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_40_check_update_openroadm_topo_ok(self): 09:19:03 > self.test_19_check_update_openroadm_topo_ok() 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:557: 09:19:03 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_19_check_update_openroadm_topo_ok(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_40_check_update_openroadm_topo_ok 09:19:03 _ TestTransportPCEDeviceChangeNotifications.test_44_check_update_openroadm_topo _ 09:19:03 09:19:03 self = 09:19:03 09:19:03 def test_44_check_update_openroadm_topo(self): 09:19:03 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 09:19:03 self.assertEqual(response['status_code'], requests.codes.ok) 09:19:03 node_list = response['network'][0]['node'] 09:19:03 nb_updated_tp = 0 09:19:03 for node in node_list: 09:19:03 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 09:19:03 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 09:19:03 > tp_list = node['ietf-network-topology:termination-point'] 09:19:03 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 09:19:03 E KeyError: 'ietf-network-topology:termination-point' 09:19:03 09:19:03 transportpce_tests/hybrid/test01_device_change_notifications.py:599: KeyError 09:19:03 ----------------------------- Captured stdout call ----------------------------- 09:19:03 execution of test_44_check_update_openroadm_topo 09:19:03 =========================== short test summary info ============================ 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_15_check_update_openroadm_topo 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_19_check_update_openroadm_topo_ok 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_23_check_update_openroadm_topo 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_26_check_update_openroadm_topo_ok 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_30_check_update_openroadm_topo 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_33_check_update_openroadm_topo_ok 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_37_check_update_openroadm_topo 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_40_check_update_openroadm_topo_ok 09:19:03 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_44_check_update_openroadm_topo 09:19:03 9 failed, 42 passed in 318.96s (0:05:18) 09:19:03 tests_hybrid: exit 1 (319.28 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid pid=29234 09:19:03 buildcontroller: OK (116.33=setup[8.99]+cmd[107.34] seconds) 09:19:03 sims: OK (12.95=setup[10.14]+cmd[2.81] seconds) 09:19:03 build_karaf_tests121: OK (65.74=setup[8.41]+cmd[57.33] seconds) 09:19:03 testsPCE: OK (288.11=setup[51.75]+cmd[236.36] seconds) 09:19:03 tests121: OK (1362.01=setup[7.78]+cmd[1354.23] seconds) 09:19:03 build_karaf_tests221: OK (65.74=setup[8.39]+cmd[57.35] seconds) 09:19:03 tests_tapi: FAIL code 1 (1952.66=setup[7.74]+cmd[1944.92] seconds) 09:19:03 tests221: FAIL code 1 (130.45=setup[7.79]+cmd[122.66] seconds) 09:19:03 build_karaf_tests71: OK (62.89=setup[8.30]+cmd[54.59] seconds) 09:19:03 tests71: OK (454.06=setup[9.26]+cmd[444.81] seconds) 09:19:03 build_karaf_tests190: OK (62.86=setup[8.30]+cmd[54.56] seconds) 09:19:03 tests190: OK (221.86=setup[7.85]+cmd[214.01] seconds) 09:19:03 tests_hybrid: FAIL code 1 (326.58=setup[7.30]+cmd[319.28] seconds) 09:19:03 buildlighty: OK (37.38=setup[10.17]+cmd[27.22] seconds) 09:19:03 docs: OK (31.30=setup[28.20]+cmd[3.10] seconds) 09:19:03 docs-linkcheck: OK (32.53=setup[27.64]+cmd[4.89] seconds) 09:19:03 checkbashisms: OK (3.10=setup[1.84]+cmd[0.01,0.06,1.19] seconds) 09:19:03 pre-commit: OK (49.49=setup[2.83]+cmd[0.01,0.01,38.51,8.13] seconds) 09:19:03 pylint: OK (31.04=setup[4.05]+cmd[26.99] seconds) 09:19:03 evaluation failed :( (2879.93 seconds) 09:19:03 + tox_status=255 09:19:03 + echo '---> Completed tox runs' 09:19:03 ---> Completed tox runs 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/build_karaf_tests121/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=build_karaf_tests121 09:19:03 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/build_karaf_tests190/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=build_karaf_tests190 09:19:03 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/build_karaf_tests221/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=build_karaf_tests221 09:19:03 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/build_karaf_tests71/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=build_karaf_tests71 09:19:03 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/buildcontroller/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=buildcontroller 09:19:03 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/buildlighty/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=buildlighty 09:19:03 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/checkbashisms/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=checkbashisms 09:19:03 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/docs-linkcheck/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=docs-linkcheck 09:19:03 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/docs/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=docs 09:19:03 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/pre-commit/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=pre-commit 09:19:03 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/pylint/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=pylint 09:19:03 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/sims/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=sims 09:19:03 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests121/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests121 09:19:03 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests190/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests190 09:19:03 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests221/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests221 09:19:03 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests71/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests71 09:19:03 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/testsPCE/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=testsPCE 09:19:03 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests_hybrid/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests_hybrid 09:19:03 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 09:19:03 + for i in .tox/*/log 09:19:03 ++ echo .tox/tests_tapi/log 09:19:03 ++ awk -F/ '{print $2}' 09:19:03 + tox_env=tests_tapi 09:19:03 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 09:19:03 + DOC_DIR=docs/_build/html 09:19:03 + [[ -d docs/_build/html ]] 09:19:03 + echo '---> Archiving generated docs' 09:19:03 ---> Archiving generated docs 09:19:03 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 09:19:03 + echo '---> tox-run.sh ends' 09:19:03 ---> tox-run.sh ends 09:19:03 + test 255 -eq 0 09:19:03 + exit 255 09:19:03 ++ '[' 1 = 1 ']' 09:19:03 ++ '[' -x /usr/bin/clear_console ']' 09:19:03 ++ /usr/bin/clear_console -q 09:19:03 Build step 'Execute shell' marked build as failure 09:19:03 $ ssh-agent -k 09:19:03 unset SSH_AUTH_SOCK; 09:19:03 unset SSH_AGENT_PID; 09:19:03 echo Agent pid 1569 killed; 09:19:03 [ssh-agent] Stopped. 09:19:03 [PostBuildScript] - [INFO] Executing post build scripts. 09:19:03 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15881339848459733368.sh 09:19:03 ---> sysstat.sh 09:19:04 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8134851671663175807.sh 09:19:04 ---> package-listing.sh 09:19:04 ++ tr '[:upper:]' '[:lower:]' 09:19:04 ++ facter osfamily 09:19:04 + OS_FAMILY=debian 09:19:04 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 09:19:04 + START_PACKAGES=/tmp/packages_start.txt 09:19:04 + END_PACKAGES=/tmp/packages_end.txt 09:19:04 + DIFF_PACKAGES=/tmp/packages_diff.txt 09:19:04 + PACKAGES=/tmp/packages_start.txt 09:19:04 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:19:04 + PACKAGES=/tmp/packages_end.txt 09:19:04 + case "${OS_FAMILY}" in 09:19:04 + dpkg -l 09:19:04 + grep '^ii' 09:19:04 + '[' -f /tmp/packages_start.txt ']' 09:19:04 + '[' -f /tmp/packages_end.txt ']' 09:19:04 + diff /tmp/packages_start.txt /tmp/packages_end.txt 09:19:04 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:19:04 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:19:04 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:19:04 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5945560408877141387.sh 09:19:04 ---> capture-instance-metadata.sh 09:19:04 Setup pyenv: 09:19:05 system 09:19:05 3.8.20 09:19:05 3.9.20 09:19:05 3.10.15 09:19:05 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:19:05 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-l63k from file:/tmp/.os_lf_venv 09:19:05 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:19:05 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:19:07 lf-activate-venv(): INFO: Base packages installed successfully 09:19:07 lf-activate-venv(): INFO: Installing additional packages: lftools 09:19:18 lf-activate-venv(): INFO: Adding /tmp/venv-l63k/bin to PATH 09:19:18 INFO: Running in OpenStack, capturing instance metadata 09:19:19 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14395711978244484393.sh 09:19:19 provisioning config files... 09:19:19 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #3924 09:19:19 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config10247606172113214275tmp 09:19:19 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 09:19:19 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 09:19:19 provisioning config files... 09:19:19 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 09:19:19 [EnvInject] - Injecting environment variables from a build step. 09:19:19 [EnvInject] - Injecting as environment variables the properties content 09:19:19 SERVER_ID=logs 09:19:19 09:19:19 [EnvInject] - Variables injected successfully. 09:19:19 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3769389461863269349.sh 09:19:19 ---> create-netrc.sh 09:19:19 WARN: Log server credential not found. 09:19:19 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11302779692649785145.sh 09:19:19 ---> python-tools-install.sh 09:19:19 Setup pyenv: 09:19:19 system 09:19:19 3.8.20 09:19:19 3.9.20 09:19:19 3.10.15 09:19:19 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:19:20 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-l63k from file:/tmp/.os_lf_venv 09:19:20 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:19:20 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:19:22 lf-activate-venv(): INFO: Base packages installed successfully 09:19:22 lf-activate-venv(): INFO: Installing additional packages: lftools 09:19:35 lf-activate-venv(): INFO: Adding /tmp/venv-l63k/bin to PATH 09:19:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14193664736600603314.sh 09:19:35 ---> sudo-logs.sh 09:19:35 Archiving 'sudo' log.. 09:19:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2682053981243802361.sh 09:19:35 ---> job-cost.sh 09:19:35 Setup pyenv: 09:19:35 system 09:19:35 3.8.20 09:19:35 3.9.20 09:19:35 3.10.15 09:19:35 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:19:36 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-l63k from file:/tmp/.os_lf_venv 09:19:36 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:19:36 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:19:37 lf-activate-venv(): INFO: Base packages installed successfully 09:19:37 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 09:19:43 lf-activate-venv(): INFO: Adding /tmp/venv-l63k/bin to PATH 09:19:43 INFO: No Stack... 09:19:44 INFO: Retrieving Pricing Info for: v3-standard-4 09:19:44 INFO: Archiving Costs 09:19:44 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins12439237527923640369.sh 09:19:44 ---> logs-deploy.sh 09:19:44 Setup pyenv: 09:19:44 system 09:19:44 3.8.20 09:19:44 3.9.20 09:19:44 3.10.15 09:19:44 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:19:44 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-l63k from file:/tmp/.os_lf_venv 09:19:44 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:19:44 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:19:46 lf-activate-venv(): INFO: Base packages installed successfully 09:19:46 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 09:19:57 lf-activate-venv(): INFO: Adding /tmp/venv-l63k/bin to PATH 09:19:57 WARNING: Nexus logging server not set 09:19:57 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/3924/ 09:19:57 INFO: archiving logs to S3 09:19:58 ---> uname -a: 09:19:58 Linux prd-ubuntu2204-docker-4c-16g-11877 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux 09:19:58 09:19:58 09:19:58 ---> lscpu: 09:19:58 Architecture: x86_64 09:19:58 CPU op-mode(s): 32-bit, 64-bit 09:19:58 Address sizes: 40 bits physical, 48 bits virtual 09:19:58 Byte Order: Little Endian 09:19:58 CPU(s): 4 09:19:58 On-line CPU(s) list: 0-3 09:19:58 Vendor ID: AuthenticAMD 09:19:58 Model name: AMD EPYC-Rome Processor 09:19:58 CPU family: 23 09:19:58 Model: 49 09:19:58 Thread(s) per core: 1 09:19:58 Core(s) per socket: 1 09:19:58 Socket(s): 4 09:19:58 Stepping: 0 09:19:58 BogoMIPS: 5600.00 09:19:58 Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm rep_good nopl cpuid extd_apicid tsc_known_freq pni pclmulqdq ssse3 fma cx16 sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm cmp_legacy svm cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw topoext perfctr_core ssbd ibrs ibpb stibp vmmcall fsgsbase tsc_adjust bmi1 avx2 smep bmi2 rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 clzero xsaveerptr wbnoinvd arat npt nrip_save umip rdpid arch_capabilities 09:19:58 Virtualization: AMD-V 09:19:58 Hypervisor vendor: KVM 09:19:58 Virtualization type: full 09:19:58 L1d cache: 128 KiB (4 instances) 09:19:58 L1i cache: 128 KiB (4 instances) 09:19:58 L2 cache: 2 MiB (4 instances) 09:19:58 L3 cache: 64 MiB (4 instances) 09:19:58 NUMA node(s): 1 09:19:58 NUMA node0 CPU(s): 0-3 09:19:58 Vulnerability Gather data sampling: Not affected 09:19:58 Vulnerability Indirect target selection: Not affected 09:19:58 Vulnerability Itlb multihit: Not affected 09:19:58 Vulnerability L1tf: Not affected 09:19:58 Vulnerability Mds: Not affected 09:19:58 Vulnerability Meltdown: Not affected 09:19:58 Vulnerability Mmio stale data: Not affected 09:19:58 Vulnerability Reg file data sampling: Not affected 09:19:58 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 09:19:58 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 09:19:58 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 09:19:58 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 09:19:58 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB disabled; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 09:19:58 Vulnerability Srbds: Not affected 09:19:58 Vulnerability Tsx async abort: Not affected 09:19:58 09:19:58 09:19:58 ---> nproc: 09:19:58 4 09:19:58 09:19:58 09:19:58 ---> df -h: 09:19:58 Filesystem Size Used Avail Use% Mounted on 09:19:58 tmpfs 1.6G 1.1M 1.6G 1% /run 09:19:58 /dev/vda1 78G 17G 61G 22% / 09:19:58 tmpfs 7.9G 0 7.9G 0% /dev/shm 09:19:58 tmpfs 5.0M 0 5.0M 0% /run/lock 09:19:58 /dev/vda15 105M 6.1M 99M 6% /boot/efi 09:19:58 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 09:19:58 09:19:58 09:19:58 ---> free -m: 09:19:58 total used free shared buff/cache available 09:19:58 Mem: 15989 704 11680 3 3604 14942 09:19:58 Swap: 1023 1 1022 09:19:58 09:19:58 09:19:58 ---> ip addr: 09:19:58 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 09:19:58 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 09:19:58 inet 127.0.0.1/8 scope host lo 09:19:58 valid_lft forever preferred_lft forever 09:19:58 inet6 ::1/128 scope host 09:19:58 valid_lft forever preferred_lft forever 09:19:58 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 09:19:58 link/ether fa:16:3e:a5:fa:c8 brd ff:ff:ff:ff:ff:ff 09:19:58 altname enp0s3 09:19:58 inet 10.30.170.39/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 09:19:58 valid_lft 83347sec preferred_lft 83347sec 09:19:58 inet6 fe80::f816:3eff:fea5:fac8/64 scope link 09:19:58 valid_lft forever preferred_lft forever 09:19:58 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 09:19:58 link/ether 16:d6:b1:f6:af:78 brd ff:ff:ff:ff:ff:ff 09:19:58 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 09:19:58 valid_lft forever preferred_lft forever 09:19:58 09:19:58 09:19:58 ---> sar -b -r -n DEV: 09:19:58 Linux 5.15.0-153-generic (prd-ubuntu2204-docker-4c-16g-11877) 11/19/25 _x86_64_ (4 CPU) 09:19:58 09:19:58 08:29:08 LINUX RESTART (4 CPU) 09:19:58 09:19:58 08:30:26 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 09:19:58 08:40:01 98.09 4.55 87.54 6.01 548.09 39568.16 26024.46 09:19:58 08:50:26 61.93 25.25 34.67 2.01 381.07 1891.23 1995.97 09:19:58 09:00:26 6.10 0.31 5.52 0.27 10.04 166.63 154.99 09:19:58 09:10:26 7.65 0.02 7.23 0.40 0.63 255.64 207.41 09:19:58 Average: 43.06 7.75 33.18 2.13 233.18 10075.43 6843.75 09:19:58 09:19:58 08:30:26 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 09:19:58 08:40:01 386644 11671092 4247564 25.94 258120 10769212 6005896 34.47 2189464 12965728 5184 09:19:58 08:50:26 3637684 6510492 9425992 57.57 263912 2639340 10793256 61.95 2030332 10168856 3020 09:19:58 09:00:26 4191532 7078756 8858484 54.10 264788 2652876 9592788 55.06 2041284 9598740 108 09:19:58 09:10:26 6834672 9745288 6194648 37.83 265860 2675200 6903532 39.63 2046732 6972812 392 09:19:58 Average: 3762633 8751407 7181672 43.86 263170 4684157 8323868 47.78 2076953 9926534 2176 09:19:58 09:19:58 08:30:26 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 09:19:58 08:40:01 lo 3.27 3.27 2.51 2.51 0.00 0.00 0.00 0.00 09:19:58 08:40:01 ens3 124.89 94.82 1974.80 10.58 0.00 0.00 0.00 0.00 09:19:58 08:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:19:58 08:50:26 lo 43.11 43.11 25.88 25.88 0.00 0.00 0.00 0.00 09:19:58 08:50:26 ens3 2.12 1.90 0.52 0.44 0.00 0.00 0.00 0.00 09:19:58 08:50:26 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:19:58 09:00:26 lo 29.34 29.34 10.84 10.84 0.00 0.00 0.00 0.00 09:19:58 09:00:26 ens3 1.07 0.89 0.26 1.11 0.00 0.00 0.00 0.00 09:19:58 09:00:26 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:19:58 09:10:26 lo 9.77 9.77 6.20 6.20 0.00 0.00 0.00 0.00 09:19:58 09:10:26 ens3 0.83 0.46 0.21 0.14 0.00 0.00 0.00 0.00 09:19:58 09:10:26 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:19:58 Average: lo 21.79 21.79 11.60 11.60 0.00 0.00 0.00 0.00 09:19:58 Average: ens3 30.94 23.54 473.26 2.96 0.00 0.00 0.00 0.00 09:19:58 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:19:58 09:19:58 09:19:58 ---> sar -P ALL: 09:19:58 Linux 5.15.0-153-generic (prd-ubuntu2204-docker-4c-16g-11877) 11/19/25 _x86_64_ (4 CPU) 09:19:58 09:19:58 08:29:08 LINUX RESTART (4 CPU) 09:19:58 09:19:58 08:30:26 CPU %user %nice %system %iowait %steal %idle 09:19:58 08:40:01 all 49.71 0.00 2.66 1.44 0.10 46.09 09:19:58 08:40:01 0 51.93 0.00 2.80 1.65 0.10 43.52 09:19:58 08:40:01 1 53.16 0.00 2.76 1.41 0.10 42.55 09:19:58 08:40:01 2 47.42 0.00 2.58 1.40 0.10 48.50 09:19:58 08:40:01 3 46.32 0.00 2.50 1.30 0.10 49.79 09:19:58 08:50:26 all 60.32 0.00 2.50 0.12 0.11 36.94 09:19:58 08:50:26 0 60.23 0.00 2.50 0.14 0.12 37.01 09:19:58 08:50:26 1 60.72 0.00 2.51 0.08 0.12 36.58 09:19:58 08:50:26 2 59.33 0.00 2.61 0.18 0.11 37.77 09:19:58 08:50:26 3 61.01 0.00 2.39 0.09 0.11 36.40 09:19:58 09:00:26 all 10.76 0.00 0.69 0.32 0.25 87.98 09:19:58 09:00:26 0 10.77 0.00 0.61 0.70 0.26 87.66 09:19:58 09:00:26 1 10.92 0.00 0.72 0.05 0.18 88.13 09:19:58 09:00:26 2 11.08 0.00 0.67 0.08 0.24 87.93 09:19:58 09:00:26 3 10.27 0.00 0.75 0.47 0.33 88.18 09:19:58 09:10:26 all 15.92 0.00 0.64 0.04 0.07 83.34 09:19:58 09:10:26 0 15.55 0.00 0.60 0.03 0.07 83.76 09:19:58 09:10:26 1 15.70 0.00 0.72 0.07 0.07 83.44 09:19:58 09:10:26 2 15.95 0.00 0.58 0.03 0.07 83.38 09:19:58 09:10:26 3 16.48 0.00 0.65 0.03 0.07 82.77 09:19:58 Average: all 34.30 0.00 1.62 0.47 0.13 63.48 09:19:58 Average: 0 34.73 0.00 1.62 0.62 0.13 62.89 09:19:58 Average: 1 35.21 0.00 1.68 0.39 0.12 62.61 09:19:58 Average: 2 33.57 0.00 1.61 0.41 0.13 64.28 09:19:58 Average: 3 33.68 0.00 1.57 0.46 0.15 64.13 09:19:58 09:19:58 09:19:58