18:46:11 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/117008 18:46:11 Running as SYSTEM 18:46:11 [EnvInject] - Loading node environment variables. 18:46:11 Building remotely on prd-ubuntu2204-docker-4c-16g-11655 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 18:46:11 [ssh-agent] Looking for ssh-agent implementation... 18:46:11 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 18:46:11 $ ssh-agent 18:46:11 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXiMWcsE/agent.1571 18:46:11 SSH_AGENT_PID=1573 18:46:11 [ssh-agent] Started. 18:46:11 Running ssh-add (command line suppressed) 18:46:11 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_10271365460378781138.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_10271365460378781138.key) 18:46:11 [ssh-agent] Using credentials jenkins (jenkins-ssh) 18:46:11 The recommended git tool is: NONE 18:46:13 using credential jenkins-ssh 18:46:13 Wiping out workspace first. 18:46:13 Cloning the remote Git repository 18:46:13 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 18:46:13 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 18:46:13 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 18:46:13 > git --version # timeout=10 18:46:13 > git --version # 'git version 2.34.1' 18:46:13 using GIT_SSH to set credentials jenkins-ssh 18:46:13 Verifying host key using known hosts file 18:46:13 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. 18:46:13 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 18:46:17 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 18:46:17 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 18:46:17 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 18:46:17 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 18:46:17 using GIT_SSH to set credentials jenkins-ssh 18:46:17 Verifying host key using known hosts file 18:46:17 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. 18:46:17 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/08/117008/22 # timeout=10 18:46:18 > git rev-parse 615beafd7bcd773f7165cb757edc25fa18852fd1^{commit} # timeout=10 18:46:18 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 18:46:18 Checking out Revision 615beafd7bcd773f7165cb757edc25fa18852fd1 (refs/changes/08/117008/22) 18:46:18 > git config core.sparsecheckout # timeout=10 18:46:18 > git checkout -f 615beafd7bcd773f7165cb757edc25fa18852fd1 # timeout=10 18:46:18 Commit message: "Consolidation of TAPI PCE & func tests" 18:46:18 > git rev-parse FETCH_HEAD^{commit} # timeout=10 18:46:18 > git rev-list --no-walk 57e50e05598fe5e4d8a076b20dcf6eb0e1925c45 # timeout=10 18:46:18 > git remote # timeout=10 18:46:18 > git submodule init # timeout=10 18:46:18 > git submodule sync # timeout=10 18:46:18 > git config --get remote.origin.url # timeout=10 18:46:18 > git submodule init # timeout=10 18:46:18 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 18:46:18 ERROR: No submodules found. 18:46:22 provisioning config files... 18:46:22 copy managed file [npmrc] to file:/home/jenkins/.npmrc 18:46:22 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 18:46:22 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17638655634976017622.sh 18:46:22 ---> python-tools-install.sh 18:46:22 Setup pyenv: 18:46:22 * system (set by /opt/pyenv/version) 18:46:22 * 3.8.20 (set by /opt/pyenv/version) 18:46:22 * 3.9.20 (set by /opt/pyenv/version) 18:46:22 3.10.15 18:46:22 3.11.10 18:46:27 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-SByH 18:46:27 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 18:46:27 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 18:46:27 lf-activate-venv(): INFO: Attempting to install with network-safe options... 18:46:31 lf-activate-venv(): INFO: Base packages installed successfully 18:46:31 lf-activate-venv(): INFO: Installing additional packages: lftools 18:46:59 lf-activate-venv(): INFO: Adding /tmp/venv-SByH/bin to PATH 18:46:59 Generating Requirements File 18:47:22 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. 18:47:22 httplib2 0.31.0 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 18:47:22 Python 3.11.10 18:47:22 pip 25.3 from /tmp/venv-SByH/lib/python3.11/site-packages/pip (python 3.11) 18:47:22 appdirs==1.4.4 18:47:22 argcomplete==3.6.3 18:47:22 aspy.yaml==1.3.0 18:47:22 attrs==25.4.0 18:47:22 autopage==0.5.2 18:47:22 beautifulsoup4==4.14.2 18:47:22 boto3==1.40.75 18:47:22 botocore==1.40.75 18:47:22 bs4==0.0.2 18:47:22 cachetools==6.2.2 18:47:22 certifi==2025.11.12 18:47:22 cffi==2.0.0 18:47:22 cfgv==3.4.0 18:47:22 chardet==5.2.0 18:47:22 charset-normalizer==3.4.4 18:47:22 click==8.3.1 18:47:22 cliff==4.11.0 18:47:22 cmd2==2.7.0 18:47:22 cryptography==3.3.2 18:47:22 debtcollector==3.0.0 18:47:22 decorator==5.2.1 18:47:22 defusedxml==0.7.1 18:47:22 Deprecated==1.3.1 18:47:22 distlib==0.4.0 18:47:22 dnspython==2.8.0 18:47:22 docker==7.1.0 18:47:22 dogpile.cache==1.5.0 18:47:22 durationpy==0.10 18:47:22 email-validator==2.3.0 18:47:22 filelock==3.20.0 18:47:22 future==1.0.0 18:47:22 gitdb==4.0.12 18:47:22 GitPython==3.1.45 18:47:22 google-auth==2.43.0 18:47:22 httplib2==0.31.0 18:47:22 identify==2.6.15 18:47:22 idna==3.11 18:47:22 importlib-resources==1.5.0 18:47:22 iso8601==2.1.0 18:47:22 Jinja2==3.1.6 18:47:22 jmespath==1.0.1 18:47:22 jsonpatch==1.33 18:47:22 jsonpointer==3.0.0 18:47:22 jsonschema==4.25.1 18:47:22 jsonschema-specifications==2025.9.1 18:47:22 keystoneauth1==5.12.0 18:47:22 kubernetes==34.1.0 18:47:22 lftools==0.37.15 18:47:22 lxml==6.0.2 18:47:22 markdown-it-py==4.0.0 18:47:22 MarkupSafe==3.0.3 18:47:22 mdurl==0.1.2 18:47:22 msgpack==1.1.2 18:47:22 multi_key_dict==2.0.3 18:47:22 munch==4.0.0 18:47:22 netaddr==1.3.0 18:47:22 niet==1.4.2 18:47:22 nodeenv==1.9.1 18:47:22 oauth2client==4.1.3 18:47:22 oauthlib==3.3.1 18:47:22 openstacksdk==4.8.0 18:47:22 os-service-types==1.8.1 18:47:22 osc-lib==4.2.0 18:47:22 oslo.config==10.1.0 18:47:22 oslo.context==6.1.0 18:47:22 oslo.i18n==6.7.0 18:47:22 oslo.log==7.2.1 18:47:22 oslo.serialization==5.8.0 18:47:22 oslo.utils==9.1.0 18:47:22 packaging==25.0 18:47:22 pbr==7.0.3 18:47:22 platformdirs==4.5.0 18:47:22 prettytable==3.17.0 18:47:22 psutil==7.1.3 18:47:22 pyasn1==0.6.1 18:47:22 pyasn1_modules==0.4.2 18:47:22 pycparser==2.23 18:47:22 pygerrit2==2.0.15 18:47:22 PyGithub==2.8.1 18:47:22 Pygments==2.19.2 18:47:22 PyJWT==2.10.1 18:47:22 PyNaCl==1.6.1 18:47:22 pyparsing==2.4.7 18:47:22 pyperclip==1.11.0 18:47:22 pyrsistent==0.20.0 18:47:22 python-cinderclient==9.8.0 18:47:22 python-dateutil==2.9.0.post0 18:47:22 python-heatclient==4.3.0 18:47:22 python-jenkins==1.8.3 18:47:22 python-keystoneclient==5.7.0 18:47:22 python-magnumclient==4.9.0 18:47:22 python-openstackclient==8.2.0 18:47:22 python-swiftclient==4.9.0 18:47:22 PyYAML==6.0.3 18:47:22 referencing==0.37.0 18:47:22 requests==2.32.5 18:47:22 requests-oauthlib==2.0.0 18:47:22 requestsexceptions==1.4.0 18:47:22 rfc3986==2.0.0 18:47:22 rich==14.2.0 18:47:22 rich-argparse==1.7.2 18:47:22 rpds-py==0.29.0 18:47:22 rsa==4.9.1 18:47:22 ruamel.yaml==0.18.16 18:47:22 ruamel.yaml.clib==0.2.15 18:47:22 s3transfer==0.14.0 18:47:22 simplejson==3.20.2 18:47:22 six==1.17.0 18:47:22 smmap==5.0.2 18:47:22 soupsieve==2.8 18:47:22 stevedore==5.5.0 18:47:22 tabulate==0.9.0 18:47:22 toml==0.10.2 18:47:22 tomlkit==0.13.3 18:47:22 tqdm==4.67.1 18:47:22 typing_extensions==4.15.0 18:47:22 tzdata==2025.2 18:47:22 urllib3==1.26.20 18:47:22 virtualenv==20.35.4 18:47:22 wcwidth==0.2.14 18:47:22 websocket-client==1.9.0 18:47:22 wrapt==2.0.1 18:47:22 xdg==6.0.0 18:47:22 xmltodict==1.0.2 18:47:22 yq==3.4.3 18:47:23 [EnvInject] - Injecting environment variables from a build step. 18:47:23 [EnvInject] - Injecting as environment variables the properties content 18:47:23 PYTHON=python3 18:47:23 18:47:23 [EnvInject] - Variables injected successfully. 18:47:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins1404709248928779104.sh 18:47:23 ---> tox-install.sh 18:47:23 + source /home/jenkins/lf-env.sh 18:47:23 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 18:47:23 ++ mktemp -d /tmp/venv-XXXX 18:47:23 + lf_venv=/tmp/venv-JOVM 18:47:23 + local venv_file=/tmp/.os_lf_venv 18:47:23 + local python=python3 18:47:23 + local options 18:47:23 + local set_path=true 18:47:23 + local install_args= 18:47:23 ++ 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 18:47:23 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 18:47:23 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 18:47:23 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 18:47:23 + true 18:47:23 + case $1 in 18:47:23 + venv_file=/tmp/.toxenv 18:47:23 + shift 2 18:47:23 + true 18:47:23 + case $1 in 18:47:23 + shift 18:47:23 + break 18:47:23 + case $python in 18:47:23 + local pkg_list= 18:47:23 + [[ -d /opt/pyenv ]] 18:47:23 + echo 'Setup pyenv:' 18:47:23 Setup pyenv: 18:47:23 + export PYENV_ROOT=/opt/pyenv 18:47:23 + PYENV_ROOT=/opt/pyenv 18:47:23 + 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 18:47:23 + 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 18:47:23 + pyenv versions 18:47:23 system 18:47:23 3.8.20 18:47:23 3.9.20 18:47:23 3.10.15 18:47:23 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:47:23 + command -v pyenv 18:47:23 ++ pyenv init - --no-rehash 18:47:23 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 18:47:23 for i in ${!paths[@]}; do 18:47:23 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 18:47:23 fi; done; 18:47:23 echo "${paths[*]}"'\'')" 18:47:23 export PATH="/opt/pyenv/shims:${PATH}" 18:47:23 export PYENV_SHELL=bash 18:47:23 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 18:47:23 pyenv() { 18:47:23 local command 18:47:23 command="${1:-}" 18:47:23 if [ "$#" -gt 0 ]; then 18:47:23 shift 18:47:23 fi 18:47:23 18:47:23 case "$command" in 18:47:23 rehash|shell) 18:47:23 eval "$(pyenv "sh-$command" "$@")" 18:47:23 ;; 18:47:23 *) 18:47:23 command pyenv "$command" "$@" 18:47:23 ;; 18:47:23 esac 18:47:23 }' 18:47:23 +++ bash --norc -ec 'IFS=:; paths=($PATH); 18:47:23 for i in ${!paths[@]}; do 18:47:23 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 18:47:23 fi; done; 18:47:23 echo "${paths[*]}"' 18:47:23 ++ 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 18:47:23 ++ 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 18:47:23 ++ 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 18:47:23 ++ export PYENV_SHELL=bash 18:47:23 ++ PYENV_SHELL=bash 18:47:23 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 18:47:23 +++ complete -F _pyenv pyenv 18:47:23 ++ lf-pyver python3 18:47:23 ++ local py_version_xy=python3 18:47:23 ++ local py_version_xyz= 18:47:23 ++ pyenv versions 18:47:23 ++ sed 's/^[ *]* //' 18:47:23 ++ local command 18:47:23 ++ grep -E '^[0-9.]*[0-9]$' 18:47:23 ++ command=versions 18:47:23 ++ '[' 1 -gt 0 ']' 18:47:23 ++ shift 18:47:23 ++ case "$command" in 18:47:23 ++ command pyenv versions 18:47:23 ++ awk '{ print $1 }' 18:47:23 ++ [[ ! -s /tmp/.pyenv_versions ]] 18:47:23 +++ grep '^3' /tmp/.pyenv_versions 18:47:23 +++ sort -V 18:47:23 +++ tail -n 1 18:47:23 ++ py_version_xyz=3.11.10 18:47:23 ++ [[ -z 3.11.10 ]] 18:47:23 ++ echo 3.11.10 18:47:23 ++ return 0 18:47:23 + pyenv local 3.11.10 18:47:23 + local command 18:47:23 + command=local 18:47:23 + '[' 2 -gt 0 ']' 18:47:23 + shift 18:47:23 + case "$command" in 18:47:23 + command pyenv local 3.11.10 18:47:23 + for arg in "$@" 18:47:23 + case $arg in 18:47:23 + pkg_list+='tox ' 18:47:23 + for arg in "$@" 18:47:23 + case $arg in 18:47:23 + pkg_list+='virtualenv ' 18:47:23 + for arg in "$@" 18:47:23 + case $arg in 18:47:23 + pkg_list+='urllib3~=1.26.15 ' 18:47:23 + [[ -f /tmp/.toxenv ]] 18:47:23 + [[ ! -f /tmp/.toxenv ]] 18:47:23 + [[ -n '' ]] 18:47:23 + python3 -m venv /tmp/venv-JOVM 18:47:27 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-JOVM' 18:47:27 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-JOVM 18:47:27 + echo /tmp/venv-JOVM 18:47:27 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 18:47:27 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 18:47:27 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 18:47:27 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 18:47:27 + local 'pip_opts=--upgrade --quiet' 18:47:27 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 18:47:27 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 18:47:27 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 18:47:27 + [[ -n '' ]] 18:47:27 + [[ -n '' ]] 18:47:27 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 18:47:27 lf-activate-venv(): INFO: Attempting to install with network-safe options... 18:47:27 + /tmp/venv-JOVM/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 18:47:31 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 18:47:31 lf-activate-venv(): INFO: Base packages installed successfully 18:47:31 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 18:47:31 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 18:47:31 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 18:47:31 + /tmp/venv-JOVM/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 18:47:33 + type python3 18:47:33 + true 18:47:33 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-JOVM/bin to PATH' 18:47:33 lf-activate-venv(): INFO: Adding /tmp/venv-JOVM/bin to PATH 18:47:33 + PATH=/tmp/venv-JOVM/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 18:47:33 + return 0 18:47:33 + python3 --version 18:47:33 Python 3.11.10 18:47:33 + python3 -m pip --version 18:47:33 pip 25.3 from /tmp/venv-JOVM/lib/python3.11/site-packages/pip (python 3.11) 18:47:33 + python3 -m pip freeze 18:47:33 cachetools==6.2.2 18:47:33 chardet==5.2.0 18:47:33 colorama==0.4.6 18:47:33 distlib==0.4.0 18:47:33 filelock==3.20.0 18:47:33 packaging==25.0 18:47:33 platformdirs==4.5.0 18:47:33 pluggy==1.6.0 18:47:33 pyproject-api==1.10.0 18:47:33 tox==4.32.0 18:47:33 urllib3==1.26.20 18:47:33 virtualenv==20.35.4 18:47:33 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins14195936138756127412.sh 18:47:33 [EnvInject] - Injecting environment variables from a build step. 18:47:33 [EnvInject] - Injecting as environment variables the properties content 18:47:33 PARALLEL=True 18:47:33 18:47:33 [EnvInject] - Variables injected successfully. 18:47:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins13337492408129766293.sh 18:47:33 ---> tox-run.sh 18:47:33 + 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 18:47:33 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 18:47:33 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 18:47:33 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 18:47:33 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 18:47:33 + source /home/jenkins/lf-env.sh 18:47:33 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 18:47:33 ++ mktemp -d /tmp/venv-XXXX 18:47:33 + lf_venv=/tmp/venv-LYxk 18:47:33 + local venv_file=/tmp/.os_lf_venv 18:47:33 + local python=python3 18:47:33 + local options 18:47:33 + local set_path=true 18:47:33 + local install_args= 18:47:33 ++ 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 18:47:33 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 18:47:33 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 18:47:33 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 18:47:33 + true 18:47:33 + case $1 in 18:47:33 + venv_file=/tmp/.toxenv 18:47:33 + shift 2 18:47:33 + true 18:47:33 + case $1 in 18:47:33 + shift 18:47:33 + break 18:47:33 + case $python in 18:47:33 + local pkg_list= 18:47:33 + [[ -d /opt/pyenv ]] 18:47:33 + echo 'Setup pyenv:' 18:47:33 Setup pyenv: 18:47:33 + export PYENV_ROOT=/opt/pyenv 18:47:33 + PYENV_ROOT=/opt/pyenv 18:47:33 + 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 18:47:33 + 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 18:47:33 + pyenv versions 18:47:34 system 18:47:34 3.8.20 18:47:34 3.9.20 18:47:34 3.10.15 18:47:34 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 18:47:34 + command -v pyenv 18:47:34 ++ pyenv init - --no-rehash 18:47:34 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 18:47:34 for i in ${!paths[@]}; do 18:47:34 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 18:47:34 fi; done; 18:47:34 echo "${paths[*]}"'\'')" 18:47:34 export PATH="/opt/pyenv/shims:${PATH}" 18:47:34 export PYENV_SHELL=bash 18:47:34 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 18:47:34 pyenv() { 18:47:34 local command 18:47:34 command="${1:-}" 18:47:34 if [ "$#" -gt 0 ]; then 18:47:34 shift 18:47:34 fi 18:47:34 18:47:34 case "$command" in 18:47:34 rehash|shell) 18:47:34 eval "$(pyenv "sh-$command" "$@")" 18:47:34 ;; 18:47:34 *) 18:47:34 command pyenv "$command" "$@" 18:47:34 ;; 18:47:34 esac 18:47:34 }' 18:47:34 +++ bash --norc -ec 'IFS=:; paths=($PATH); 18:47:34 for i in ${!paths[@]}; do 18:47:34 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 18:47:34 fi; done; 18:47:34 echo "${paths[*]}"' 18:47:34 ++ 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 18:47:34 ++ 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 18:47:34 ++ 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 18:47:34 ++ export PYENV_SHELL=bash 18:47:34 ++ PYENV_SHELL=bash 18:47:34 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 18:47:34 +++ complete -F _pyenv pyenv 18:47:34 ++ lf-pyver python3 18:47:34 ++ local py_version_xy=python3 18:47:34 ++ local py_version_xyz= 18:47:34 ++ pyenv versions 18:47:34 ++ sed 's/^[ *]* //' 18:47:34 ++ local command 18:47:34 ++ command=versions 18:47:34 ++ '[' 1 -gt 0 ']' 18:47:34 ++ shift 18:47:34 ++ case "$command" in 18:47:34 ++ command pyenv versions 18:47:34 ++ awk '{ print $1 }' 18:47:34 ++ grep -E '^[0-9.]*[0-9]$' 18:47:34 ++ [[ ! -s /tmp/.pyenv_versions ]] 18:47:34 +++ grep '^3' /tmp/.pyenv_versions 18:47:34 +++ sort -V 18:47:34 +++ tail -n 1 18:47:34 ++ py_version_xyz=3.11.10 18:47:34 ++ [[ -z 3.11.10 ]] 18:47:34 ++ echo 3.11.10 18:47:34 ++ return 0 18:47:34 + pyenv local 3.11.10 18:47:34 + local command 18:47:34 + command=local 18:47:34 + '[' 2 -gt 0 ']' 18:47:34 + shift 18:47:34 + case "$command" in 18:47:34 + command pyenv local 3.11.10 18:47:34 + for arg in "$@" 18:47:34 + case $arg in 18:47:34 + pkg_list+='tox ' 18:47:34 + for arg in "$@" 18:47:34 + case $arg in 18:47:34 + pkg_list+='virtualenv ' 18:47:34 + for arg in "$@" 18:47:34 + case $arg in 18:47:34 + pkg_list+='urllib3~=1.26.15 ' 18:47:34 + [[ -f /tmp/.toxenv ]] 18:47:34 ++ cat /tmp/.toxenv 18:47:34 + lf_venv=/tmp/venv-JOVM 18:47:34 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-JOVM from' file:/tmp/.toxenv 18:47:34 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-JOVM from file:/tmp/.toxenv 18:47:34 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 18:47:34 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 18:47:34 + local 'pip_opts=--upgrade --quiet' 18:47:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 18:47:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 18:47:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 18:47:34 + [[ -n '' ]] 18:47:34 + [[ -n '' ]] 18:47:34 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 18:47:34 lf-activate-venv(): INFO: Attempting to install with network-safe options... 18:47:34 + /tmp/venv-JOVM/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 18:47:35 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 18:47:35 lf-activate-venv(): INFO: Base packages installed successfully 18:47:35 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 18:47:35 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 18:47:35 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 18:47:35 + /tmp/venv-JOVM/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 18:47:36 + type python3 18:47:36 + true 18:47:36 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-JOVM/bin to PATH' 18:47:36 lf-activate-venv(): INFO: Adding /tmp/venv-JOVM/bin to PATH 18:47:36 + PATH=/tmp/venv-JOVM/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 18:47:36 + return 0 18:47:36 + [[ -d /opt/pyenv ]] 18:47:36 + echo '---> Setting up pyenv' 18:47:36 ---> Setting up pyenv 18:47:36 + export PYENV_ROOT=/opt/pyenv 18:47:36 + PYENV_ROOT=/opt/pyenv 18:47:36 + export PATH=/opt/pyenv/bin:/tmp/venv-JOVM/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 18:47:36 + PATH=/opt/pyenv/bin:/tmp/venv-JOVM/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 18:47:36 ++ pwd 18:47:36 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 18:47:36 + export PYTHONPATH 18:47:36 + export TOX_TESTENV_PASSENV=PYTHONPATH 18:47:36 + TOX_TESTENV_PASSENV=PYTHONPATH 18:47:36 + tox --version 18:47:36 4.32.0 from /tmp/venv-JOVM/lib/python3.11/site-packages/tox/__init__.py 18:47:36 + PARALLEL=True 18:47:36 + TOX_OPTIONS_LIST= 18:47:36 + [[ -n '' ]] 18:47:36 + case ${PARALLEL,,} in 18:47:36 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 18:47:36 + tox --parallel auto --parallel-live 18:47:36 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 18:47:38 checkbashisms: freeze> python -m pip freeze --all 18:47:38 docs: install_deps> python -I -m pip install -r docs/requirements.txt 18:47:38 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 18:47:38 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 18:47:39 checkbashisms: pip==25.3,setuptools==80.9.0 18:47:39 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 18:47:39 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)' 18:47:39 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 18:47:40 checkbashisms: OK ✔ in 3.53 seconds 18:47:40 pre-commit: install_deps> python -I -m pip install pre-commit 18:47:43 pre-commit: freeze> python -m pip freeze --all 18:47:43 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 18:47:43 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 18:47:43 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)' 18:47:43 /usr/bin/cpan 18:47:43 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 18:47:43 [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. 18:47:43 [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. 18:47:43 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 18:47:44 [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. 18:47:44 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 18:47:44 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 18:47:44 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 18:47:45 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 18:47:45 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 18:47:45 buildcontroller: freeze> python -m pip freeze --all 18:47:45 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 18:47:45 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 18:47:45 + update-java-alternatives -l 18:47:45 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 18:47:45 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 18:47:45 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 18:47:45 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 18:47:45 update-alternatives: error: no alternatives for jaotc 18:47:45 update-alternatives: error: no alternatives for rmic 18:47:46 + java -version 18:47:46 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 18:47:46 + JAVA_VER=21 18:47:46 + echo 21 18:47:46 21 18:47:46 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 18:47:46 + javac -version 18:47:46 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 18:47:46 [INFO] Once installed this environment will be reused. 18:47:46 [INFO] This may take a few minutes... 18:47:46 + JAVAC_VER=21 18:47:46 + echo 21 18:47:46 21 18:47:46 ok, java is 21 or newer 18:47:46 + [ 21 -ge 21 ] 18:47:46 + [ 21 -ge 21 ] 18:47:46 + echo ok, java is 21 or newer 18:47:46 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz -P /tmp 18:47:47 2025-11-18 18:47:47 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] 18:47:47 + sudo mkdir -p /opt 18:47:47 + sudo tar xf /tmp/apache-maven-3.9.11-bin.tar.gz -C /opt 18:47:47 + sudo ln -s /opt/apache-maven-3.9.11 /opt/maven 18:47:47 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 18:47:47 + mvn --version 18:47:47 Apache Maven 3.9.11 (3e54c93a704957b63ee3494413a2b544fd3d825b) 18:47:47 Maven home: /opt/maven 18:47:47 Java version: 21.0.8, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 18:47:47 Default locale: en, platform encoding: UTF-8 18:47:47 OS name: "linux", version: "5.15.0-153-generic", arch: "amd64", family: "unix" 18:47:48 NOTE: Picked up JDK_JAVA_OPTIONS: 18:47:48 --add-opens=java.base/java.io=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.lang=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.net=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.nio=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.nio.file=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.util=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.util.jar=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.util.stream=ALL-UNNAMED 18:47:48 --add-opens=java.base/java.util.zip=ALL-UNNAMED 18:47:48 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 18:47:48 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 18:47:48 -Xlog:disable 18:47:51 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 18:47:51 [INFO] Once installed this environment will be reused. 18:47:51 [INFO] This may take a few minutes... 18:47:59 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 18:47:59 [INFO] Once installed this environment will be reused. 18:47:59 [INFO] This may take a few minutes... 18:48:03 [INFO] Installing environment for https://github.com/perltidy/perltidy. 18:48:03 [INFO] Once installed this environment will be reused. 18:48:03 [INFO] This may take a few minutes... 18:48:06 docs-linkcheck: freeze> python -m pip freeze --all 18:48:06 docs: freeze> python -m pip freeze --all 18:48:06 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 18:48:06 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 18:48:06 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 18:48:06 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 18:48:08 docs: OK ✔ in 31.48 seconds 18:48:08 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 18:48:11 docs-linkcheck: OK ✔ in 34.16 seconds 18:48:11 pylint: freeze> python -m pip freeze --all 18:48:11 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 18:48:11 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}$' '{}' + 18:48:12 trim trailing whitespace.................................................Passed 18:48:12 Tabs remover.............................................................Passed 18:48:13 autopep8.................................................................Passed 18:48:16 perltidy.................................................................Passed 18:48:16 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 18:48:17 [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. 18:48:17 [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. 18:48:17 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 18:48:17 [INFO] Once installed this environment will be reused. 18:48:17 [INFO] This may take a few minutes... 18:48:23 gitlint..................................................................Passed 18:48:32 ************* Module test03_tapi_device_change_notifications 18:48:32 transportpce_tests/tapi/test03_tapi_device_change_notifications.py:15:0: C0302: Too many lines in module (1011/1000) (too-many-lines) 18:48:32 18:48:32 ------------------------------------ 18:48:32 Your code has been rated at 10.00/10 18:48:32 18:48:33 pre-commit: OK ✔ in 42.67 seconds 18:48:33 pylint: exit 1 (22.35 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> find transportpce_tests/ -name '*.py' -exec pylint --fail-under=10 --max-line-length=120 --disable=missing-docstring,import-error --disable=fixme --disable=duplicate-code '--module-rgx=([a-z0-9_]+$)|([0-9.]{1,30}$)' '--method-rgx=(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$' '--variable-rgx=[a-zA-Z_][a-zA-Z0-9_]{1,30}$' '{}' + pid=3282 18:50:06 pylint: FAIL ✖ in 25.55 seconds 18:50:06 buildcontroller: OK ✔ in 2 minutes 28.89 seconds 18:50:06 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 18:50:06 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 18:50:06 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 18:50:06 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 18:50:14 build_karaf_tests221: freeze> python -m pip freeze --all 18:50:14 build_karaf_tests190: freeze> python -m pip freeze --all 18:50:14 build_karaf_tests121: freeze> python -m pip freeze --all 18:50:14 build_karaf_tests71: freeze> python -m pip freeze --all 18:50:14 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 18:50:14 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 18:50:14 build karaf in karafoc with ./karafoc.env 18:50:14 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 18:50:14 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 18:50:14 build karaf in karaf221 with ./karaf221.env 18:50:14 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 18:50:14 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 18:50:14 build karaf in karaf121 with ./karaf121.env 18:50:14 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 18:50:14 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 18:50:14 build karaf in karaf71 with ./karaf71.env 18:50:14 NOTE: Picked up JDK_JAVA_OPTIONS: 18:50:14 --add-opens=java.base/java.io=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.net=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.file=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.jar=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.stream=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.zip=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 18:50:14 -Xlog:disable 18:50:14 NOTE: Picked up JDK_JAVA_OPTIONS: 18:50:14 --add-opens=java.base/java.io=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.net=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.file=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.jar=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.stream=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.zip=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 18:50:14 -Xlog:disable 18:50:14 NOTE: Picked up JDK_JAVA_OPTIONS: 18:50:14 --add-opens=java.base/java.io=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.net=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.file=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.jar=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.stream=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.zip=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 18:50:14 -Xlog:disable 18:50:14 NOTE: Picked up JDK_JAVA_OPTIONS: 18:50:14 --add-opens=java.base/java.io=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.net=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.nio.file=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.jar=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.stream=ALL-UNNAMED 18:50:14 --add-opens=java.base/java.util.zip=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 18:50:14 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 18:50:14 -Xlog:disable 18:51:09 build_karaf_tests190: OK ✔ in 1 minute 3.27 seconds 18:51:09 buildlighty: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 18:51:10 [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] 18:51:10 [ERROR] 18:51:10 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. 18:51:10 [ERROR] Re-run Maven using the -X switch to enable full debug logging. 18:51:10 [ERROR] 18:51:10 [ERROR] For more information about the errors and possible solutions, please read the following articles: 18:51:10 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException 18:51:10 build_karaf_tests221: OK ✔ in 1 minute 4.9 seconds 18:51:10 build_karaf_tests71: OK ✔ in 1 minute 4.9 seconds 18:51:10 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 18:51:11 build_karaf_tests121: OK ✔ in 1 minute 5.1 seconds 18:51:11 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 18:51:17 sims: freeze> python -m pip freeze --all 18:51:17 buildlighty: freeze> python -m pip freeze --all 18:51:17 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 18:51:17 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 18:51:17 Using lighynode version 20.1.0.5 18:51:17 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 18:51:17 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 18:51:17 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 18:51:17 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 18:52:04 sims: OK ✔ in 12.91 seconds 18:52:04 buildlighty: OK ✔ in 43.52 seconds 18:52:04 testsPCE: freeze> python -m pip freeze --all 18:52:04 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 18:52:04 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 18:52:04 pytest -q transportpce_tests/pce/test01_pce.py 18:52:51 .................... [100%] 18:53:55 20 passed in 109.89s (0:01:49) 18:53:55 pytest -q transportpce_tests/pce/test02_pce_400G.py 18:54:12 ............ [100%] 18:54:42 12 passed in 46.97s 18:54:42 pytest -q transportpce_tests/pce/test03_gnpy.py 18:54:59 ........ [100%] 18:55:20 8 passed in 37.62s 18:55:20 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 18:55:51 ... [100%] 18:55:56 3 passed in 35.84s 18:55:57 testsPCE: OK ✔ in 4 minutes 45.45 seconds 18:55:57 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 18:55:57 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 18:55:57 tests121: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 18:56:04 tests190: freeze> python -m pip freeze --all 18:56:04 tests_tapi: freeze> python -m pip freeze --all 18:56:04 tests121: freeze> python -m pip freeze --all 18:56:04 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 18:56:04 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 18:56:04 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 18:56:04 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 18:56:04 using environment variables from ./karafoc.env 18:56:04 using environment variables from ./karaf221.env 18:56:04 pytest -q transportpce_tests/oc/test01_portmapping.py 18:56:04 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 18:56:04 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 18:56:04 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 18:56:04 using environment variables from ./karaf121.env 18:56:04 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 18:57:14 .......... [100%] 18:57:30 10 passed in 85.02s (0:01:25) 18:57:30 pytest -q transportpce_tests/oc/test02_topology.py 18:57:43 ......................................................... [100%] 18:58:33 21 passed in 148.37s (0:02:28) 18:58:33 .pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 18:58:34 ....... [100%] 18:58:40 14 passed in 69.18s (0:01:09) 18:58:40 pytest -q transportpce_tests/oc/test03_renderer.py 18:58:57 ........................... [100%] 18:59:41 6 passed in 67.63s (0:01:07) 18:59:41 pytest -q transportpce_tests/1.2.1/test03_topology.py 18:59:41 ...... [100%] 18:59:48 19 passed in 66.81s (0:01:06) 18:59:48 tests190: OK ✔ in 3 minutes 52.02 seconds 18:59:48 tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 19:00:01 ......tests71: freeze> python -m pip freeze --all 19:00:04 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 19:00:04 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 19:00:04 using environment variables from ./karaf71.env 19:00:04 pytest -q transportpce_tests/7.1/test01_portmapping.py 19:00:33 .......................... [100%] 19:01:04 12 passed in 59.54s 19:01:04 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 19:01:05 ................................................ [100%] 19:02:10 44 passed in 148.88s (0:02:28) 19:02:10 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 19:02:11 ...................................................................... [100%] 19:03:35 24 passed in 84.19s (0:01:24) 19:03:35 pytest -q transportpce_tests/1.2.1/test05_olm.py 19:03:35 .... [100%] 19:03:43 62 passed in 159.31s (0:02:39) 19:03:43 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 19:04:18 . [100%] 19:04:22 51 passed in 497.86s (0:08:17) 19:04:22 pytest -q transportpce_tests/tapi/test02_full_topology.py 19:04:29 .......................................................................................... [100%] 19:06:15 48 passed in 151.31s (0:02:31) 19:06:15 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 19:06:17 ...................... [100%] 19:06:58 40 passed in 203.33s (0:03:23) 19:06:58 pytest -q transportpce_tests/1.2.1/test06_end2end.py 19:06:59 .................. [100%] 19:07:33 22 passed in 77.74s (0:01:17) 19:07:34 ................................................... [100%] 19:10:07 36 passed in 343.39s (0:05:43) 19:10:07 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 19:10:21 ..................................................................................... [100%] 19:15:26 71 passed in 319.57s (0:05:19) 19:15:27 pytest -q transportpce_tests/tapi/test04_topo_extension.py 19:15:52 ..... [100%] 19:15:56 54 passed in 537.05s (0:08:57) 19:16:21 ................... [100%] 19:17:52 19 passed in 145.26s (0:02:25) 19:17:52 pytest -q transportpce_tests/tapi/test05_pce_tapi.py 19:19:58 ......................E [100%] 19:25:31 ==================================== ERRORS ==================================== 19:25:31 ______ ERROR at teardown of TransportPCEtest.test_22_get_no_tapi_services ______ 19:25:31 19:25:31 self = 19:25:31 19:25:31 def _new_conn(self) -> socket.socket: 19:25:31 """Establish a socket connection and set nodelay settings on it. 19:25:31 19:25:31 :return: New socket connection. 19:25:31 """ 19:25:31 try: 19:25:31 > sock = connection.create_connection( 19:25:31 (self._dns_host, self.port), 19:25:31 self.timeout, 19:25:31 source_address=self.source_address, 19:25:31 socket_options=self.socket_options, 19:25:31 ) 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:198: 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/connection.py:85: in create_connection 19:25:31 raise err 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 19:25:31 address = ('localhost', 8183), timeout = 30, source_address = None 19:25:31 socket_options = [(6, 1, 1)] 19:25:31 19:25:31 def create_connection( 19:25:31 address: tuple[str, int], 19:25:31 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 19:25:31 source_address: tuple[str, int] | None = None, 19:25:31 socket_options: _TYPE_SOCKET_OPTIONS | None = None, 19:25:31 ) -> socket.socket: 19:25:31 """Connect to *address* and return the socket object. 19:25:31 19:25:31 Convenience function. Connect to *address* (a 2-tuple ``(host, 19:25:31 port)``) and return the socket object. Passing the optional 19:25:31 *timeout* parameter will set the timeout on the socket instance 19:25:31 before attempting to connect. If no *timeout* is supplied, the 19:25:31 global default timeout setting returned by :func:`socket.getdefaulttimeout` 19:25:31 is used. If *source_address* is set it must be a tuple of (host, port) 19:25:31 for the socket to bind as a source address before making the connection. 19:25:31 An host of '' or port 0 tells the OS to use the default. 19:25:31 """ 19:25:31 19:25:31 host, port = address 19:25:31 if host.startswith("["): 19:25:31 host = host.strip("[]") 19:25:31 err = None 19:25:31 19:25:31 # Using the value from allowed_gai_family() in the context of getaddrinfo lets 19:25:31 # us select whether to work with IPv4 DNS records, IPv6 records, or both. 19:25:31 # The original create_connection function always returns all records. 19:25:31 family = allowed_gai_family() 19:25:31 19:25:31 try: 19:25:31 host.encode("idna") 19:25:31 except UnicodeError: 19:25:31 raise LocationParseError(f"'{host}', label empty or too long") from None 19:25:31 19:25:31 for res in socket.getaddrinfo(host, port, family, socket.SOCK_STREAM): 19:25:31 af, socktype, proto, canonname, sa = res 19:25:31 sock = None 19:25:31 try: 19:25:31 sock = socket.socket(af, socktype, proto) 19:25:31 19:25:31 # If provided, set socket level options before connecting. 19:25:31 _set_socket_options(sock, socket_options) 19:25:31 19:25:31 if timeout is not _DEFAULT_TIMEOUT: 19:25:31 sock.settimeout(timeout) 19:25:31 if source_address: 19:25:31 sock.bind(source_address) 19:25:31 > sock.connect(sa) 19:25:31 E ConnectionRefusedError: [Errno 111] Connection refused 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/connection.py:73: ConnectionRefusedError 19:25:31 19:25:31 The above exception was the direct cause of the following exception: 19:25:31 19:25:31 self = 19:25:31 method = 'GET' 19:25:31 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 19:25:31 body = None 19:25:31 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='} 19:25:31 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 19:25:31 redirect = False, assert_same_host = False 19:25:31 timeout = Timeout(connect=30, read=30, total=None), pool_timeout = None 19:25:31 release_conn = False, chunked = False, body_pos = None, preload_content = False 19:25:31 decode_content = False, response_kw = {} 19:25:31 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) 19:25:31 destination_scheme = None, conn = None, release_this_conn = True 19:25:31 http_tunnel_required = False, err = None, clean_exit = False 19:25:31 19:25:31 def urlopen( # type: ignore[override] 19:25:31 self, 19:25:31 method: str, 19:25:31 url: str, 19:25:31 body: _TYPE_BODY | None = None, 19:25:31 headers: typing.Mapping[str, str] | None = None, 19:25:31 retries: Retry | bool | int | None = None, 19:25:31 redirect: bool = True, 19:25:31 assert_same_host: bool = True, 19:25:31 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 19:25:31 pool_timeout: int | None = None, 19:25:31 release_conn: bool | None = None, 19:25:31 chunked: bool = False, 19:25:31 body_pos: _TYPE_BODY_POSITION | None = None, 19:25:31 preload_content: bool = True, 19:25:31 decode_content: bool = True, 19:25:31 **response_kw: typing.Any, 19:25:31 ) -> BaseHTTPResponse: 19:25:31 """ 19:25:31 Get a connection from the pool and perform an HTTP request. This is the 19:25:31 lowest level call for making a request, so you'll need to specify all 19:25:31 the raw details. 19:25:31 19:25:31 .. note:: 19:25:31 19:25:31 More commonly, it's appropriate to use a convenience method 19:25:31 such as :meth:`request`. 19:25:31 19:25:31 .. note:: 19:25:31 19:25:31 `release_conn` will only behave as expected if 19:25:31 `preload_content=False` because we want to make 19:25:31 `preload_content=False` the default behaviour someday soon without 19:25:31 breaking backwards compatibility. 19:25:31 19:25:31 :param method: 19:25:31 HTTP request method (such as GET, POST, PUT, etc.) 19:25:31 19:25:31 :param url: 19:25:31 The URL to perform the request on. 19:25:31 19:25:31 :param body: 19:25:31 Data to send in the request body, either :class:`str`, :class:`bytes`, 19:25:31 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 19:25:31 19:25:31 :param headers: 19:25:31 Dictionary of custom headers to send, such as User-Agent, 19:25:31 If-None-Match, etc. If None, pool headers are used. If provided, 19:25:31 these headers completely replace any pool-specific headers. 19:25:31 19:25:31 :param retries: 19:25:31 Configure the number of retries to allow before raising a 19:25:31 :class:`~urllib3.exceptions.MaxRetryError` exception. 19:25:31 19:25:31 If ``None`` (default) will retry 3 times, see ``Retry.DEFAULT``. Pass a 19:25:31 :class:`~urllib3.util.retry.Retry` object for fine-grained control 19:25:31 over different types of retries. 19:25:31 Pass an integer number to retry connection errors that many times, 19:25:31 but no other types of errors. Pass zero to never retry. 19:25:31 19:25:31 If ``False``, then retries are disabled and any exception is raised 19:25:31 immediately. Also, instead of raising a MaxRetryError on redirects, 19:25:31 the redirect response will be returned. 19:25:31 19:25:31 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 19:25:31 19:25:31 :param redirect: 19:25:31 If True, automatically handle redirects (status codes 301, 302, 19:25:31 303, 307, 308). Each redirect counts as a retry. Disabling retries 19:25:31 will disable redirect, too. 19:25:31 19:25:31 :param assert_same_host: 19:25:31 If ``True``, will make sure that the host of the pool requests is 19:25:31 consistent else will raise HostChangedError. When ``False``, you can 19:25:31 use the pool on an HTTP proxy and request foreign hosts. 19:25:31 19:25:31 :param timeout: 19:25:31 If specified, overrides the default timeout for this one 19:25:31 request. It may be a float (in seconds) or an instance of 19:25:31 :class:`urllib3.util.Timeout`. 19:25:31 19:25:31 :param pool_timeout: 19:25:31 If set and the pool is set to block=True, then this method will 19:25:31 block for ``pool_timeout`` seconds and raise EmptyPoolError if no 19:25:31 connection is available within the time period. 19:25:31 19:25:31 :param bool preload_content: 19:25:31 If True, the response's body will be preloaded into memory. 19:25:31 19:25:31 :param bool decode_content: 19:25:31 If True, will attempt to decode the body based on the 19:25:31 'content-encoding' header. 19:25:31 19:25:31 :param release_conn: 19:25:31 If False, then the urlopen call will not release the connection 19:25:31 back into the pool once a response is received (but will release if 19:25:31 you read the entire contents of the response such as when 19:25:31 `preload_content=True`). This is useful if you're not preloading 19:25:31 the response's content immediately. You will need to call 19:25:31 ``r.release_conn()`` on the response ``r`` to return the connection 19:25:31 back into the pool. If None, it takes the value of ``preload_content`` 19:25:31 which defaults to ``True``. 19:25:31 19:25:31 :param bool chunked: 19:25:31 If True, urllib3 will send the body using chunked transfer 19:25:31 encoding. Otherwise, urllib3 will send the body using the standard 19:25:31 content-length form. Defaults to False. 19:25:31 19:25:31 :param int body_pos: 19:25:31 Position to seek to in file-like body in the event of a retry or 19:25:31 redirect. Typically this won't need to be set because urllib3 will 19:25:31 auto-populate the value when needed. 19:25:31 """ 19:25:31 parsed_url = parse_url(url) 19:25:31 destination_scheme = parsed_url.scheme 19:25:31 19:25:31 if headers is None: 19:25:31 headers = self.headers 19:25:31 19:25:31 if not isinstance(retries, Retry): 19:25:31 retries = Retry.from_int(retries, redirect=redirect, default=self.retries) 19:25:31 19:25:31 if release_conn is None: 19:25:31 release_conn = preload_content 19:25:31 19:25:31 # Check host 19:25:31 if assert_same_host and not self.is_same_host(url): 19:25:31 raise HostChangedError(self, url, retries) 19:25:31 19:25:31 # Ensure that the URL we're connecting to is properly encoded 19:25:31 if url.startswith("/"): 19:25:31 url = to_str(_encode_target(url)) 19:25:31 else: 19:25:31 url = to_str(parsed_url.url) 19:25:31 19:25:31 conn = None 19:25:31 19:25:31 # Track whether `conn` needs to be released before 19:25:31 # returning/raising/recursing. Update this variable if necessary, and 19:25:31 # leave `release_conn` constant throughout the function. That way, if 19:25:31 # the function recurses, the original value of `release_conn` will be 19:25:31 # passed down into the recursive call, and its value will be respected. 19:25:31 # 19:25:31 # See issue #651 [1] for details. 19:25:31 # 19:25:31 # [1] 19:25:31 release_this_conn = release_conn 19:25:31 19:25:31 http_tunnel_required = connection_requires_http_tunnel( 19:25:31 self.proxy, self.proxy_config, destination_scheme 19:25:31 ) 19:25:31 19:25:31 # Merge the proxy headers. Only done when not using HTTP CONNECT. We 19:25:31 # have to copy the headers dict so we can safely change it without those 19:25:31 # changes being reflected in anyone else's copy. 19:25:31 if not http_tunnel_required: 19:25:31 headers = headers.copy() # type: ignore[attr-defined] 19:25:31 headers.update(self.proxy_headers) # type: ignore[union-attr] 19:25:31 19:25:31 # Must keep the exception bound to a separate variable or else Python 3 19:25:31 # complains about UnboundLocalError. 19:25:31 err = None 19:25:31 19:25:31 # Keep track of whether we cleanly exited the except block. This 19:25:31 # ensures we do proper cleanup in finally. 19:25:31 clean_exit = False 19:25:31 19:25:31 # Rewind body position, if needed. Record current position 19:25:31 # for future rewinds in the event of a redirect/retry. 19:25:31 body_pos = set_file_position(body, body_pos) 19:25:31 19:25:31 try: 19:25:31 # Request a connection from the queue. 19:25:31 timeout_obj = self._get_timeout(timeout) 19:25:31 conn = self._get_conn(timeout=pool_timeout) 19:25:31 19:25:31 conn.timeout = timeout_obj.connect_timeout # type: ignore[assignment] 19:25:31 19:25:31 # Is this a closed/new connection that requires CONNECT tunnelling? 19:25:31 if self.proxy is not None and http_tunnel_required and conn.is_closed: 19:25:31 try: 19:25:31 self._prepare_proxy(conn) 19:25:31 except (BaseSSLError, OSError, SocketTimeout) as e: 19:25:31 self._raise_timeout( 19:25:31 err=e, url=self.proxy.url, timeout_value=conn.timeout 19:25:31 ) 19:25:31 raise 19:25:31 19:25:31 # If we're going to release the connection in ``finally:``, then 19:25:31 # the response doesn't need to know about the connection. Otherwise 19:25:31 # it will also try to release it and we'll have a double-release 19:25:31 # mess. 19:25:31 response_conn = conn if not release_conn else None 19:25:31 19:25:31 # Make the request on the HTTPConnection object 19:25:31 > response = self._make_request( 19:25:31 conn, 19:25:31 method, 19:25:31 url, 19:25:31 timeout=timeout_obj, 19:25:31 body=body, 19:25:31 headers=headers, 19:25:31 chunked=chunked, 19:25:31 retries=retries, 19:25:31 response_conn=response_conn, 19:25:31 preload_content=preload_content, 19:25:31 decode_content=decode_content, 19:25:31 **response_kw, 19:25:31 ) 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:493: in _make_request 19:25:31 conn.request( 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:494: in request 19:25:31 self.endheaders() 19:25:31 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1298: in endheaders 19:25:31 self._send_output(message_body, encode_chunked=encode_chunked) 19:25:31 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1058: in _send_output 19:25:31 self.send(msg) 19:25:31 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:996: in send 19:25:31 self.connect() 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:325: in connect 19:25:31 self.sock = self._new_conn() 19:25:31 ^^^^^^^^^^^^^^^^ 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 19:25:31 self = 19:25:31 19:25:31 def _new_conn(self) -> socket.socket: 19:25:31 """Establish a socket connection and set nodelay settings on it. 19:25:31 19:25:31 :return: New socket connection. 19:25:31 """ 19:25:31 try: 19:25:31 sock = connection.create_connection( 19:25:31 (self._dns_host, self.port), 19:25:31 self.timeout, 19:25:31 source_address=self.source_address, 19:25:31 socket_options=self.socket_options, 19:25:31 ) 19:25:31 except socket.gaierror as e: 19:25:31 raise NameResolutionError(self.host, self, e) from e 19:25:31 except SocketTimeout as e: 19:25:31 raise ConnectTimeoutError( 19:25:31 self, 19:25:31 f"Connection to {self.host} timed out. (connect timeout={self.timeout})", 19:25:31 ) from e 19:25:31 19:25:31 except OSError as e: 19:25:31 > raise NewConnectionError( 19:25:31 self, f"Failed to establish a new connection: {e}" 19:25:31 ) from e 19:25:31 E urllib3.exceptions.NewConnectionError: : Failed to establish a new connection: [Errno 111] Connection refused 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:213: NewConnectionError 19:25:31 19:25:31 The above exception was the direct cause of the following exception: 19:25:31 19:25:31 self = 19:25:31 request = , stream = False 19:25:31 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 19:25:31 proxies = OrderedDict() 19:25:31 19:25:31 def send( 19:25:31 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 19:25:31 ): 19:25:31 """Sends PreparedRequest object. Returns Response object. 19:25:31 19:25:31 :param request: The :class:`PreparedRequest ` being sent. 19:25:31 :param stream: (optional) Whether to stream the request content. 19:25:31 :param timeout: (optional) How long to wait for the server to send 19:25:31 data before giving up, as a float, or a :ref:`(connect timeout, 19:25:31 read timeout) ` tuple. 19:25:31 :type timeout: float or tuple or urllib3 Timeout object 19:25:31 :param verify: (optional) Either a boolean, in which case it controls whether 19:25:31 we verify the server's TLS certificate, or a string, in which case it 19:25:31 must be a path to a CA bundle to use 19:25:31 :param cert: (optional) Any user-provided SSL certificate to be trusted. 19:25:31 :param proxies: (optional) The proxies dictionary to apply to the request. 19:25:31 :rtype: requests.Response 19:25:31 """ 19:25:31 19:25:31 try: 19:25:31 conn = self.get_connection_with_tls_context( 19:25:31 request, verify, proxies=proxies, cert=cert 19:25:31 ) 19:25:31 except LocationValueError as e: 19:25:31 raise InvalidURL(e, request=request) 19:25:31 19:25:31 self.cert_verify(conn, request.url, verify, cert) 19:25:31 url = self.request_url(request, proxies) 19:25:31 self.add_headers( 19:25:31 request, 19:25:31 stream=stream, 19:25:31 timeout=timeout, 19:25:31 verify=verify, 19:25:31 cert=cert, 19:25:31 proxies=proxies, 19:25:31 ) 19:25:31 19:25:31 chunked = not (request.body is None or "Content-Length" in request.headers) 19:25:31 19:25:31 if isinstance(timeout, tuple): 19:25:31 try: 19:25:31 connect, read = timeout 19:25:31 timeout = TimeoutSauce(connect=connect, read=read) 19:25:31 except ValueError: 19:25:31 raise ValueError( 19:25:31 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 19:25:31 f"or a single float to set both timeouts to the same value." 19:25:31 ) 19:25:31 elif isinstance(timeout, TimeoutSauce): 19:25:31 pass 19:25:31 else: 19:25:31 timeout = TimeoutSauce(connect=timeout, read=timeout) 19:25:31 19:25:31 try: 19:25:31 > resp = conn.urlopen( 19:25:31 method=request.method, 19:25:31 url=url, 19:25:31 body=request.body, 19:25:31 headers=request.headers, 19:25:31 redirect=False, 19:25:31 assert_same_host=False, 19:25:31 preload_content=False, 19:25:31 decode_content=False, 19:25:31 retries=self.max_retries, 19:25:31 timeout=timeout, 19:25:31 chunked=chunked, 19:25:31 ) 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:644: 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 19:25:31 retries = retries.increment( 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 19:25:31 self = Retry(total=0, connect=None, read=False, redirect=None, status=None) 19:25:31 method = 'GET' 19:25:31 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 19:25:31 response = None 19:25:31 error = NewConnectionError(': Failed to establish a new connection: [Errno 111] Connection refused') 19:25:31 _pool = 19:25:31 _stacktrace = 19:25:31 19:25:31 def increment( 19:25:31 self, 19:25:31 method: str | None = None, 19:25:31 url: str | None = None, 19:25:31 response: BaseHTTPResponse | None = None, 19:25:31 error: Exception | None = None, 19:25:31 _pool: ConnectionPool | None = None, 19:25:31 _stacktrace: TracebackType | None = None, 19:25:31 ) -> Self: 19:25:31 """Return a new Retry object with incremented retry counters. 19:25:31 19:25:31 :param response: A response object, or None, if the server did not 19:25:31 return a response. 19:25:31 :type response: :class:`~urllib3.response.BaseHTTPResponse` 19:25:31 :param Exception error: An error encountered during the request, or 19:25:31 None if the response was received successfully. 19:25:31 19:25:31 :return: A new ``Retry`` object. 19:25:31 """ 19:25:31 if self.total is False and error: 19:25:31 # Disabled, indicate to re-raise the error. 19:25:31 raise reraise(type(error), error, _stacktrace) 19:25:31 19:25:31 total = self.total 19:25:31 if total is not None: 19:25:31 total -= 1 19:25:31 19:25:31 connect = self.connect 19:25:31 read = self.read 19:25:31 redirect = self.redirect 19:25:31 status_count = self.status 19:25:31 other = self.other 19:25:31 cause = "unknown" 19:25:31 status = None 19:25:31 redirect_location = None 19:25:31 19:25:31 if error and self._is_connection_error(error): 19:25:31 # Connect retry? 19:25:31 if connect is False: 19:25:31 raise reraise(type(error), error, _stacktrace) 19:25:31 elif connect is not None: 19:25:31 connect -= 1 19:25:31 19:25:31 elif error and self._is_read_error(error): 19:25:31 # Read retry? 19:25:31 if read is False or method is None or not self._is_method_retryable(method): 19:25:31 raise reraise(type(error), error, _stacktrace) 19:25:31 elif read is not None: 19:25:31 read -= 1 19:25:31 19:25:31 elif error: 19:25:31 # Other retry? 19:25:31 if other is not None: 19:25:31 other -= 1 19:25:31 19:25:31 elif response and response.get_redirect_location(): 19:25:31 # Redirect retry? 19:25:31 if redirect is not None: 19:25:31 redirect -= 1 19:25:31 cause = "too many redirects" 19:25:31 response_redirect_location = response.get_redirect_location() 19:25:31 if response_redirect_location: 19:25:31 redirect_location = response_redirect_location 19:25:31 status = response.status 19:25:31 19:25:31 else: 19:25:31 # Incrementing because of a server error like a 500 in 19:25:31 # status_forcelist and the given method is in the allowed_methods 19:25:31 cause = ResponseError.GENERIC_ERROR 19:25:31 if response and response.status: 19:25:31 if status_count is not None: 19:25:31 status_count -= 1 19:25:31 cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) 19:25:31 status = response.status 19:25:31 19:25:31 history = self.history + ( 19:25:31 RequestHistory(method, url, error, status, redirect_location), 19:25:31 ) 19:25:31 19:25:31 new_retry = self.new( 19:25:31 total=total, 19:25:31 connect=connect, 19:25:31 read=read, 19:25:31 redirect=redirect, 19:25:31 status=status_count, 19:25:31 other=other, 19:25:31 history=history, 19:25:31 ) 19:25:31 19:25:31 if new_retry.is_exhausted(): 19:25:31 reason = error or ResponseError(cause) 19:25:31 > raise MaxRetryError(_pool, url, reason) from reason # type: ignore[arg-type] 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 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')) 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:519: MaxRetryError 19:25:31 19:25:31 During handling of the above exception, another exception occurred: 19:25:31 19:25:31 cls = 19:25:31 19:25:31 @classmethod 19:25:31 def tearDownClass(cls): 19:25:31 test_utils_generate_tapi_topo.cleanup_and_disconnect_devices() 19:25:31 # pylint: disable=not-an-iterable 19:25:31 for process in cls.processes: 19:25:31 test_utils.shutdown_process(process) 19:25:31 print("all processes killed") 19:25:31 test_utils.copy_karaf_log(cls.__name__) 19:25:31 > test_utils_generate_tapi_topo.uninstall_Tapi_Feature() 19:25:31 19:25:31 transportpce_tests/tapi/test05_pce_tapi.py:345: 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 transportpce_tests/common/test_utils_generate_tapi_topo.py:383: in uninstall_Tapi_Feature 19:25:31 response = test_utils.get_ietf_network_request('otn-topology', 'config') 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 19:25:31 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 transportpce_tests/common/test_utils.py:117: in get_request 19:25:31 return requests.request( 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 19:25:31 return session.request(method=method, url=url, **kwargs) 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:589: in request 19:25:31 resp = self.send(prep, **send_kwargs) 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:703: in send 19:25:31 r = adapter.send(request, **kwargs) 19:25:31 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:25:31 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:25:31 19:25:31 self = 19:25:31 request = , stream = False 19:25:31 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 19:25:31 proxies = OrderedDict() 19:25:31 19:25:31 def send( 19:25:31 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 19:25:31 ): 19:25:31 """Sends PreparedRequest object. Returns Response object. 19:25:31 19:25:31 :param request: The :class:`PreparedRequest ` being sent. 19:25:31 :param stream: (optional) Whether to stream the request content. 19:25:31 :param timeout: (optional) How long to wait for the server to send 19:25:31 data before giving up, as a float, or a :ref:`(connect timeout, 19:25:31 read timeout) ` tuple. 19:25:31 :type timeout: float or tuple or urllib3 Timeout object 19:25:31 :param verify: (optional) Either a boolean, in which case it controls whether 19:25:31 we verify the server's TLS certificate, or a string, in which case it 19:25:31 must be a path to a CA bundle to use 19:25:31 :param cert: (optional) Any user-provided SSL certificate to be trusted. 19:25:31 :param proxies: (optional) The proxies dictionary to apply to the request. 19:25:31 :rtype: requests.Response 19:25:31 """ 19:25:31 19:25:31 try: 19:25:31 conn = self.get_connection_with_tls_context( 19:25:31 request, verify, proxies=proxies, cert=cert 19:25:31 ) 19:25:31 except LocationValueError as e: 19:25:31 raise InvalidURL(e, request=request) 19:25:31 19:25:31 self.cert_verify(conn, request.url, verify, cert) 19:25:31 url = self.request_url(request, proxies) 19:25:31 self.add_headers( 19:25:31 request, 19:25:31 stream=stream, 19:25:31 timeout=timeout, 19:25:31 verify=verify, 19:25:31 cert=cert, 19:25:31 proxies=proxies, 19:25:31 ) 19:25:31 19:25:31 chunked = not (request.body is None or "Content-Length" in request.headers) 19:25:31 19:25:31 if isinstance(timeout, tuple): 19:25:31 try: 19:25:31 connect, read = timeout 19:25:31 timeout = TimeoutSauce(connect=connect, read=read) 19:25:31 except ValueError: 19:25:31 raise ValueError( 19:25:31 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 19:25:31 f"or a single float to set both timeouts to the same value." 19:25:31 ) 19:25:31 elif isinstance(timeout, TimeoutSauce): 19:25:31 pass 19:25:31 else: 19:25:31 timeout = TimeoutSauce(connect=timeout, read=timeout) 19:25:31 19:25:31 try: 19:25:31 resp = conn.urlopen( 19:25:31 method=request.method, 19:25:31 url=url, 19:25:31 body=request.body, 19:25:31 headers=request.headers, 19:25:31 redirect=False, 19:25:31 assert_same_host=False, 19:25:31 preload_content=False, 19:25:31 decode_content=False, 19:25:31 retries=self.max_retries, 19:25:31 timeout=timeout, 19:25:31 chunked=chunked, 19:25:31 ) 19:25:31 19:25:31 except (ProtocolError, OSError) as err: 19:25:31 raise ConnectionError(err, request=request) 19:25:31 19:25:31 except MaxRetryError as e: 19:25:31 if isinstance(e.reason, ConnectTimeoutError): 19:25:31 # TODO: Remove this in 3.0.0: see #2811 19:25:31 if not isinstance(e.reason, NewConnectionError): 19:25:31 raise ConnectTimeout(e, request=request) 19:25:31 19:25:31 if isinstance(e.reason, ResponseError): 19:25:31 raise RetryError(e, request=request) 19:25:31 19:25:31 if isinstance(e.reason, _ProxyError): 19:25:31 raise ProxyError(e, request=request) 19:25:31 19:25:31 if isinstance(e.reason, _SSLError): 19:25:31 # This branch is for urllib3 v1.22 and later. 19:25:31 raise SSLError(e, request=request) 19:25:31 19:25:31 > raise ConnectionError(e, request=request) 19:25:31 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')) 19:25:31 19:25:31 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:677: ConnectionError 19:25:31 --------------------------- Captured stdout teardown --------------------------- 19:25:31 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 19:25:31 ODL log file stored 19:25:31 uninstalling feature odl-transportpce-tapi 19:25:31 client: JAVA_HOME not set; results may vary 19:25:31 --------------------------- Captured stderr teardown --------------------------- 19:25:31 Failed to get the session. 19:25:31 =========================== short test summary info ============================ 19:25:31 ERROR transportpce_tests/tapi/test05_pce_tapi.py::TransportPCEtest::test_22_get_no_tapi_services 19:25:31 22 passed, 1 error in 458.68s (0:07:38) 19:25:31 tests71: OK ✔ in 7 minutes 45.16 seconds 19:25:31 tests121: OK ✔ in 19 minutes 59.71 seconds 19:25:31 tests_tapi: exit 1 (1766.76 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7586 19:25:31 tests_tapi: FAIL ✖ in 29 minutes 35.1 seconds 19:25:31 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 19:25:38 tests221: freeze> python -m pip freeze --all 19:25:39 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 19:25:39 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 19:25:39 using environment variables from ./karaf221.env 19:25:39 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 19:26:17 ................................... [100%] 19:26:57 35 passed in 77.76s (0:01:17) 19:26:57 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 19:27:30 .F..F. [100%] 19:27:43 =================================== FAILURES =================================== 19:27:43 _ TestTransportPCETopoPortmapping.test_02_compareOpenroadmTopologyPortMapping_rdm _ 19:27:43 19:27:43 self = 19:27:43 19:27:43 def test_02_compareOpenroadmTopologyPortMapping_rdm(self): 19:27:43 resTopo = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:27:43 self.assertEqual(resTopo['status_code'], requests.codes.ok) 19:27:43 nbMapCumul = 0 19:27:43 nbMappings = 0 19:27:43 for node in resTopo['network'][0]['node']: 19:27:43 nodeId = node['node-id'] 19:27:43 # pylint: disable=consider-using-f-string 19:27:43 print("nodeId={}".format(nodeId)) 19:27:43 nodeMapId = nodeId.split("-")[0] + "-" + nodeId.split("-")[1] 19:27:43 print("nodeMapId={}".format(nodeMapId)) 19:27:43 response = test_utils.get_portmapping_node_attr(nodeMapId, "node-info", None) 19:27:43 > self.assertEqual(response['status_code'], requests.codes.ok) 19:27:43 E AssertionError: 409 != 200 19:27:43 19:27:43 transportpce_tests/2.2.1/test02_topo_portmapping.py:65: AssertionError 19:27:43 ----------------------------- Captured stdout call ----------------------------- 19:27:43 nodeId=ROADM-A1-SRG3 19:27:43 nodeMapId=ROADM-A1 19:27:43 nodeId=ROADM-A1-DEG1 19:27:43 nodeMapId=ROADM-A1 19:27:43 nodeId=TAPI-SBI-ABS-NODE 19:27:43 nodeMapId=TAPI-SBI 19:27:43 _ TestTransportPCETopoPortmapping.test_05_compareOpenroadmTopologyPortMapping_xpdr _ 19:27:43 19:27:43 self = 19:27:43 19:27:43 def test_05_compareOpenroadmTopologyPortMapping_xpdr(self): 19:27:43 > self.test_02_compareOpenroadmTopologyPortMapping_rdm() 19:27:43 19:27:43 transportpce_tests/2.2.1/test02_topo_portmapping.py:92: 19:27:43 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:27:43 transportpce_tests/2.2.1/test02_topo_portmapping.py:65: in test_02_compareOpenroadmTopologyPortMapping_rdm 19:27:43 self.assertEqual(response['status_code'], requests.codes.ok) 19:27:43 E AssertionError: 409 != 200 19:27:43 ----------------------------- Captured stdout call ----------------------------- 19:27:43 nodeId=TAPI-SBI-ABS-NODE 19:27:43 nodeMapId=TAPI-SBI 19:27:43 =========================== short test summary info ============================ 19:27:43 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_02_compareOpenroadmTopologyPortMapping_rdm 19:27:43 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_05_compareOpenroadmTopologyPortMapping_xpdr 19:27:43 2 failed, 4 passed in 46.29s 19:27:43 tests221: exit 1 (124.71 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 pid=27593 19:27:43 tests221: FAIL ✖ in 2 minutes 12.21 seconds 19:27:43 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 19:27:51 tests_hybrid: freeze> python -m pip freeze --all 19:27:51 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 19:27:51 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 19:27:51 using environment variables from ./karaf221.env 19:27:51 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 19:28:32 ..............F...F...F..F...F..F...F..F...F....... [100%] 19:30:10 =================================== FAILURES =================================== 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_15_check_update_openroadm_topo _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_15_check_update_openroadm_topo(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 nb_updated_tp = 0 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:237: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_15_check_update_openroadm_topo 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_19_check_update_openroadm_topo_ok _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_19_check_update_openroadm_topo_ok(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_19_check_update_openroadm_topo_ok 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_23_check_update_openroadm_topo _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_23_check_update_openroadm_topo(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 nb_updated_tp = 0 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:351: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_23_check_update_openroadm_topo 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_26_check_update_openroadm_topo_ok _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_26_check_update_openroadm_topo_ok(self): 19:30:10 > self.test_19_check_update_openroadm_topo_ok() 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:393: 19:30:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_19_check_update_openroadm_topo_ok(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_26_check_update_openroadm_topo_ok 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_30_check_update_openroadm_topo _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_30_check_update_openroadm_topo(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 nb_updated_tp = 0 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:435: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_30_check_update_openroadm_topo 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_33_check_update_openroadm_topo_ok _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_33_check_update_openroadm_topo_ok(self): 19:30:10 > self.test_19_check_update_openroadm_topo_ok() 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:477: 19:30:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_19_check_update_openroadm_topo_ok(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_33_check_update_openroadm_topo_ok 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_37_check_update_openroadm_topo _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_37_check_update_openroadm_topo(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 nb_updated_tp = 0 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:517: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_37_check_update_openroadm_topo 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_40_check_update_openroadm_topo_ok _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_40_check_update_openroadm_topo_ok(self): 19:30:10 > self.test_19_check_update_openroadm_topo_ok() 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:557: 19:30:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_19_check_update_openroadm_topo_ok(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:300: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_40_check_update_openroadm_topo_ok 19:30:10 _ TestTransportPCEDeviceChangeNotifications.test_44_check_update_openroadm_topo _ 19:30:10 19:30:10 self = 19:30:10 19:30:10 def test_44_check_update_openroadm_topo(self): 19:30:10 response = test_utils.get_ietf_network_request('openroadm-topology', 'config') 19:30:10 self.assertEqual(response['status_code'], requests.codes.ok) 19:30:10 node_list = response['network'][0]['node'] 19:30:10 nb_updated_tp = 0 19:30:10 for node in node_list: 19:30:10 self.assertEqual(node['org-openroadm-common-network:operational-state'], 'inService') 19:30:10 self.assertEqual(node['org-openroadm-common-network:administrative-state'], 'inService') 19:30:10 > tp_list = node['ietf-network-topology:termination-point'] 19:30:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 19:30:10 E KeyError: 'ietf-network-topology:termination-point' 19:30:10 19:30:10 transportpce_tests/hybrid/test01_device_change_notifications.py:599: KeyError 19:30:10 ----------------------------- Captured stdout call ----------------------------- 19:30:10 execution of test_44_check_update_openroadm_topo 19:30:10 =========================== short test summary info ============================ 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_15_check_update_openroadm_topo 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_19_check_update_openroadm_topo_ok 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_23_check_update_openroadm_topo 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_26_check_update_openroadm_topo_ok 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_30_check_update_openroadm_topo 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_33_check_update_openroadm_topo_ok 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_37_check_update_openroadm_topo 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_40_check_update_openroadm_topo_ok 19:30:10 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TestTransportPCEDeviceChangeNotifications::test_44_check_update_openroadm_topo 19:30:10 9 failed, 42 passed in 139.17s (0:02:19) 19:30:10 tests_hybrid: exit 1 (139.48 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid pid=29354 19:30:10 buildcontroller: OK (148.89=setup[8.84]+cmd[140.05] seconds) 19:30:10 sims: OK (12.91=setup[6.84]+cmd[6.07] seconds) 19:30:10 build_karaf_tests121: OK (65.10=setup[8.77]+cmd[56.33] seconds) 19:30:10 testsPCE: OK (285.45=setup[53.93]+cmd[231.52] seconds) 19:30:10 tests121: OK (1199.71=setup[8.34]+cmd[1191.37] seconds) 19:30:10 build_karaf_tests221: OK (64.90=setup[8.75]+cmd[56.15] seconds) 19:30:10 tests_tapi: FAIL code 1 (1775.10=setup[8.33]+cmd[1766.76] seconds) 19:30:10 tests221: FAIL code 1 (132.21=setup[7.50]+cmd[124.71] seconds) 19:30:10 build_karaf_tests71: OK (64.90=setup[8.78]+cmd[56.12] seconds) 19:30:10 tests71: OK (465.16=setup[15.86]+cmd[449.30] seconds) 19:30:10 build_karaf_tests190: OK (63.26=setup[8.72]+cmd[54.54] seconds) 19:30:10 tests190: OK (232.02=setup[8.33]+cmd[223.69] seconds) 19:30:10 tests_hybrid: FAIL code 1 (147.15=setup[7.67]+cmd[139.48] seconds) 19:30:10 buildlighty: OK (43.52=setup[8.49]+cmd[35.03] seconds) 19:30:10 docs: OK (31.47=setup[29.44]+cmd[2.03] seconds) 19:30:10 docs-linkcheck: OK (34.16=setup[29.35]+cmd[4.82] seconds) 19:30:10 checkbashisms: OK (3.53=setup[2.23]+cmd[0.01,0.05,1.24] seconds) 19:30:10 pre-commit: OK (42.67=setup[3.01]+cmd[0.00,0.00,33.43,6.22] seconds) 19:30:10 pylint: FAIL code 1 (25.55=setup[3.20]+cmd[22.35] seconds) 19:30:10 evaluation failed :( (2553.96 seconds) 19:30:10 + tox_status=255 19:30:10 + echo '---> Completed tox runs' 19:30:10 ---> Completed tox runs 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/build_karaf_tests121/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=build_karaf_tests121 19:30:10 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/build_karaf_tests190/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=build_karaf_tests190 19:30:10 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/build_karaf_tests221/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=build_karaf_tests221 19:30:10 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/build_karaf_tests71/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=build_karaf_tests71 19:30:10 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/buildcontroller/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=buildcontroller 19:30:10 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/buildlighty/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=buildlighty 19:30:10 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/checkbashisms/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=checkbashisms 19:30:10 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 19:30:10 + for i in .tox/*/log 19:30:10 ++ echo .tox/docs-linkcheck/log 19:30:10 ++ awk -F/ '{print $2}' 19:30:10 + tox_env=docs-linkcheck 19:30:10 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/docs/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=docs 19:30:11 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/pre-commit/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=pre-commit 19:30:11 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/pylint/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=pylint 19:30:11 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/sims/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=sims 19:30:11 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests121/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests121 19:30:11 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests190/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests190 19:30:11 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests221/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests221 19:30:11 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests71/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests71 19:30:11 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/testsPCE/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=testsPCE 19:30:11 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests_hybrid/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests_hybrid 19:30:11 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 19:30:11 + for i in .tox/*/log 19:30:11 ++ echo .tox/tests_tapi/log 19:30:11 ++ awk -F/ '{print $2}' 19:30:11 + tox_env=tests_tapi 19:30:11 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 19:30:11 + DOC_DIR=docs/_build/html 19:30:11 + [[ -d docs/_build/html ]] 19:30:11 + echo '---> Archiving generated docs' 19:30:11 ---> Archiving generated docs 19:30:11 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 19:30:11 + echo '---> tox-run.sh ends' 19:30:11 ---> tox-run.sh ends 19:30:11 + test 255 -eq 0 19:30:11 + exit 255 19:30:11 ++ '[' 1 = 1 ']' 19:30:11 ++ '[' -x /usr/bin/clear_console ']' 19:30:11 ++ /usr/bin/clear_console -q 19:30:11 Build step 'Execute shell' marked build as failure 19:30:11 $ ssh-agent -k 19:30:11 unset SSH_AUTH_SOCK; 19:30:11 unset SSH_AGENT_PID; 19:30:11 echo Agent pid 1573 killed; 19:30:11 [ssh-agent] Stopped. 19:30:11 [PostBuildScript] - [INFO] Executing post build scripts. 19:30:11 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14179436242378070710.sh 19:30:11 ---> sysstat.sh 19:30:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12756074241211134652.sh 19:30:12 ---> package-listing.sh 19:30:12 ++ facter osfamily 19:30:12 ++ tr '[:upper:]' '[:lower:]' 19:30:12 + OS_FAMILY=debian 19:30:12 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 19:30:12 + START_PACKAGES=/tmp/packages_start.txt 19:30:12 + END_PACKAGES=/tmp/packages_end.txt 19:30:12 + DIFF_PACKAGES=/tmp/packages_diff.txt 19:30:12 + PACKAGES=/tmp/packages_start.txt 19:30:12 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 19:30:12 + PACKAGES=/tmp/packages_end.txt 19:30:12 + case "${OS_FAMILY}" in 19:30:12 + dpkg -l 19:30:12 + grep '^ii' 19:30:12 + '[' -f /tmp/packages_start.txt ']' 19:30:12 + '[' -f /tmp/packages_end.txt ']' 19:30:12 + diff /tmp/packages_start.txt /tmp/packages_end.txt 19:30:12 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 19:30:12 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 19:30:12 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 19:30:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins594212215952463695.sh 19:30:12 ---> capture-instance-metadata.sh 19:30:12 Setup pyenv: 19:30:12 system 19:30:12 3.8.20 19:30:12 3.9.20 19:30:12 3.10.15 19:30:12 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 19:30:12 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SByH from file:/tmp/.os_lf_venv 19:30:12 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 19:30:12 lf-activate-venv(): INFO: Attempting to install with network-safe options... 19:30:15 lf-activate-venv(): INFO: Base packages installed successfully 19:30:15 lf-activate-venv(): INFO: Installing additional packages: lftools 19:30:30 lf-activate-venv(): INFO: Adding /tmp/venv-SByH/bin to PATH 19:30:30 INFO: Running in OpenStack, capturing instance metadata 19:30:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17768366241403928214.sh 19:30:33 provisioning config files... 19:30:34 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #3923 19:30:34 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config11749263376989387782tmp 19:30:34 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 19:30:34 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 19:30:34 provisioning config files... 19:30:34 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 19:30:34 [EnvInject] - Injecting environment variables from a build step. 19:30:34 [EnvInject] - Injecting as environment variables the properties content 19:30:34 SERVER_ID=logs 19:30:34 19:30:34 [EnvInject] - Variables injected successfully. 19:30:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9918001970220101600.sh 19:30:34 ---> create-netrc.sh 19:30:34 WARN: Log server credential not found. 19:30:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8536500431224528696.sh 19:30:34 ---> python-tools-install.sh 19:30:34 Setup pyenv: 19:30:34 system 19:30:34 3.8.20 19:30:34 3.9.20 19:30:34 3.10.15 19:30:34 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 19:30:34 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SByH from file:/tmp/.os_lf_venv 19:30:34 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 19:30:34 lf-activate-venv(): INFO: Attempting to install with network-safe options... 19:30:36 lf-activate-venv(): INFO: Base packages installed successfully 19:30:36 lf-activate-venv(): INFO: Installing additional packages: lftools 19:30:47 lf-activate-venv(): INFO: Adding /tmp/venv-SByH/bin to PATH 19:30:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4646738443342747752.sh 19:30:47 ---> sudo-logs.sh 19:30:47 Archiving 'sudo' log.. 19:30:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5969573795346183484.sh 19:30:47 ---> job-cost.sh 19:30:47 Setup pyenv: 19:30:47 system 19:30:47 3.8.20 19:30:47 3.9.20 19:30:47 3.10.15 19:30:47 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 19:30:47 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SByH from file:/tmp/.os_lf_venv 19:30:47 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 19:30:47 lf-activate-venv(): INFO: Attempting to install with network-safe options... 19:30:49 lf-activate-venv(): INFO: Base packages installed successfully 19:30:49 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 19:30:56 lf-activate-venv(): INFO: Adding /tmp/venv-SByH/bin to PATH 19:30:56 INFO: No Stack... 19:30:56 INFO: Retrieving Pricing Info for: v3-standard-4 19:30:57 INFO: Archiving Costs 19:30:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins7986583397433523622.sh 19:30:57 ---> logs-deploy.sh 19:30:57 Setup pyenv: 19:30:57 system 19:30:57 3.8.20 19:30:57 3.9.20 19:30:57 3.10.15 19:30:57 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 19:30:57 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-SByH from file:/tmp/.os_lf_venv 19:30:57 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 19:30:57 lf-activate-venv(): INFO: Attempting to install with network-safe options... 19:30:59 lf-activate-venv(): INFO: Base packages installed successfully 19:30:59 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 19:31:09 lf-activate-venv(): INFO: Adding /tmp/venv-SByH/bin to PATH 19:31:09 WARNING: Nexus logging server not set 19:31:09 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/3923/ 19:31:09 INFO: archiving logs to S3 19:31:11 ---> uname -a: 19:31:11 Linux prd-ubuntu2204-docker-4c-16g-11655 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux 19:31:11 19:31:11 19:31:11 ---> lscpu: 19:31:11 Architecture: x86_64 19:31:11 CPU op-mode(s): 32-bit, 64-bit 19:31:11 Address sizes: 40 bits physical, 48 bits virtual 19:31:11 Byte Order: Little Endian 19:31:11 CPU(s): 4 19:31:11 On-line CPU(s) list: 0-3 19:31:11 Vendor ID: AuthenticAMD 19:31:11 Model name: AMD EPYC-Rome Processor 19:31:11 CPU family: 23 19:31:11 Model: 49 19:31:11 Thread(s) per core: 1 19:31:11 Core(s) per socket: 1 19:31:11 Socket(s): 4 19:31:11 Stepping: 0 19:31:11 BogoMIPS: 5599.99 19:31:11 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 19:31:11 Virtualization: AMD-V 19:31:11 Hypervisor vendor: KVM 19:31:11 Virtualization type: full 19:31:11 L1d cache: 128 KiB (4 instances) 19:31:11 L1i cache: 128 KiB (4 instances) 19:31:11 L2 cache: 2 MiB (4 instances) 19:31:11 L3 cache: 64 MiB (4 instances) 19:31:11 NUMA node(s): 1 19:31:11 NUMA node0 CPU(s): 0-3 19:31:11 Vulnerability Gather data sampling: Not affected 19:31:11 Vulnerability Indirect target selection: Not affected 19:31:11 Vulnerability Itlb multihit: Not affected 19:31:11 Vulnerability L1tf: Not affected 19:31:11 Vulnerability Mds: Not affected 19:31:11 Vulnerability Meltdown: Not affected 19:31:11 Vulnerability Mmio stale data: Not affected 19:31:11 Vulnerability Reg file data sampling: Not affected 19:31:11 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 19:31:11 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 19:31:11 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 19:31:11 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 19:31:11 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB disabled; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 19:31:11 Vulnerability Srbds: Not affected 19:31:11 Vulnerability Tsx async abort: Not affected 19:31:11 19:31:11 19:31:11 ---> nproc: 19:31:11 4 19:31:11 19:31:11 19:31:11 ---> df -h: 19:31:11 Filesystem Size Used Avail Use% Mounted on 19:31:11 tmpfs 1.6G 1.1M 1.6G 1% /run 19:31:11 /dev/vda1 78G 17G 61G 22% / 19:31:11 tmpfs 7.9G 0 7.9G 0% /dev/shm 19:31:11 tmpfs 5.0M 0 5.0M 0% /run/lock 19:31:11 /dev/vda15 105M 6.1M 99M 6% /boot/efi 19:31:11 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 19:31:11 19:31:11 19:31:11 ---> free -m: 19:31:11 total used free shared buff/cache available 19:31:11 Mem: 15989 685 11731 3 3573 14961 19:31:11 Swap: 1023 0 1023 19:31:11 19:31:11 19:31:11 ---> ip addr: 19:31:11 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 19:31:11 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 19:31:11 inet 127.0.0.1/8 scope host lo 19:31:11 valid_lft forever preferred_lft forever 19:31:11 inet6 ::1/128 scope host 19:31:11 valid_lft forever preferred_lft forever 19:31:11 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 19:31:11 link/ether fa:16:3e:17:d9:67 brd ff:ff:ff:ff:ff:ff 19:31:11 altname enp0s3 19:31:11 inet 10.30.171.177/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 19:31:11 valid_lft 83665sec preferred_lft 83665sec 19:31:11 inet6 fe80::f816:3eff:fe17:d967/64 scope link 19:31:11 valid_lft forever preferred_lft forever 19:31:11 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 19:31:11 link/ether c6:e9:ec:8a:36:64 brd ff:ff:ff:ff:ff:ff 19:31:11 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 19:31:11 valid_lft forever preferred_lft forever 19:31:11 19:31:11 19:31:11 ---> sar -b -r -n DEV: 19:31:11 Linux 5.15.0-153-generic (prd-ubuntu2204-docker-4c-16g-11655) 11/18/25 _x86_64_ (4 CPU) 19:31:11 19:31:11 18:45:39 LINUX RESTART (4 CPU) 19:31:11 19:31:11 18:50:08 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 19:31:11 19:00:04 76.35 4.31 67.60 4.44 732.77 31609.74 33208.84 19:31:11 19:10:07 53.34 28.47 23.51 1.36 341.27 1611.81 1517.35 19:31:11 19:20:08 10.30 0.14 9.60 0.56 6.83 337.18 438.07 19:31:11 19:30:08 11.87 0.33 10.93 0.61 15.44 898.01 722.35 19:31:11 Average: 37.91 8.34 27.83 1.74 273.27 8564.31 8919.10 19:31:11 19:31:11 18:50:08 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 19:31:11 19:00:04 2388480 6701464 9225872 56.35 259128 3960616 11711340 67.22 2154028 11172304 79552 19:31:11 19:10:07 8504624 11345640 4590816 28.04 262264 2620468 5324092 30.56 1997388 5356524 4772 19:31:11 19:20:08 6254816 9123808 6815768 41.63 263544 2646968 8281448 47.54 2007248 7610340 296 19:31:11 19:30:08 12255560 15324064 617588 3.77 271284 2838592 1323328 7.60 2053188 1551496 284 19:31:11 Average: 7350870 10623744 5312511 32.45 264055 3016661 6660052 38.23 2052963 6422666 21226 19:31:11 19:31:11 18:50:08 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 19:31:11 19:00:04 lo 14.94 14.94 12.94 12.94 0.00 0.00 0.00 0.00 19:31:11 19:00:04 ens3 43.24 32.54 771.26 3.64 0.00 0.00 0.00 0.00 19:31:11 19:00:04 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 19:31:11 19:10:07 lo 43.11 43.11 20.06 20.06 0.00 0.00 0.00 0.00 19:31:11 19:10:07 ens3 2.09 1.58 0.46 0.35 0.00 0.00 0.00 0.00 19:31:11 19:10:07 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 19:31:11 19:20:08 lo 23.26 23.26 10.85 10.85 0.00 0.00 0.00 0.00 19:31:11 19:20:08 ens3 0.76 0.74 0.15 0.12 0.00 0.00 0.00 0.00 19:31:11 19:20:08 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 19:31:11 19:30:08 lo 16.14 16.14 8.55 8.55 0.00 0.00 0.00 0.00 19:31:11 19:30:08 ens3 1.04 0.93 0.32 0.32 0.00 0.00 0.00 0.00 19:31:11 19:30:08 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 19:31:11 Average: lo 24.40 24.40 13.11 13.11 0.00 0.00 0.00 0.00 19:31:11 Average: ens3 11.71 8.90 191.78 1.10 0.00 0.00 0.00 0.00 19:31:11 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 19:31:11 19:31:11 19:31:11 ---> sar -P ALL: 19:31:11 Linux 5.15.0-153-generic (prd-ubuntu2204-docker-4c-16g-11655) 11/18/25 _x86_64_ (4 CPU) 19:31:11 19:31:11 18:45:39 LINUX RESTART (4 CPU) 19:31:11 19:31:11 18:50:08 CPU %user %nice %system %iowait %steal %idle 19:31:11 19:00:04 all 53.19 0.00 2.46 1.85 0.13 42.38 19:31:11 19:00:04 0 53.80 0.00 2.51 0.80 0.13 42.77 19:31:11 19:00:04 1 52.98 0.00 2.31 1.03 0.13 43.55 19:31:11 19:00:04 2 52.17 0.00 2.44 1.33 0.12 43.93 19:31:11 19:00:04 3 53.81 0.00 2.58 4.22 0.12 39.26 19:31:11 19:10:07 all 42.62 0.00 1.83 0.50 0.13 54.92 19:31:11 19:10:07 0 42.85 0.00 1.95 0.36 0.13 54.71 19:31:11 19:10:07 1 43.16 0.00 1.79 0.36 0.13 54.56 19:31:11 19:10:07 2 43.31 0.00 1.82 0.49 0.13 54.25 19:31:11 19:10:07 3 41.17 0.00 1.75 0.79 0.12 56.16 19:31:11 19:20:08 all 23.70 0.00 1.01 0.06 0.11 75.12 19:31:11 19:20:08 0 23.40 0.00 0.87 0.08 0.10 75.55 19:31:11 19:20:08 1 23.51 0.00 1.02 0.04 0.11 75.33 19:31:11 19:20:08 2 23.90 0.00 1.10 0.12 0.11 74.77 19:31:11 19:20:08 3 24.00 0.00 1.05 0.02 0.11 74.83 19:31:11 19:30:08 all 17.33 0.00 0.74 0.08 0.10 81.75 19:31:11 19:30:08 0 17.28 0.00 0.67 0.08 0.09 81.88 19:31:11 19:30:08 1 17.76 0.00 0.68 0.03 0.10 81.43 19:31:11 19:30:08 2 17.55 0.00 0.81 0.04 0.10 81.51 19:31:11 19:30:08 3 16.73 0.00 0.81 0.16 0.11 82.20 19:31:11 Average: all 34.20 0.00 1.51 0.62 0.12 63.56 19:31:11 Average: 0 34.32 0.00 1.50 0.33 0.11 63.75 19:31:11 Average: 1 34.34 0.00 1.45 0.36 0.12 63.73 19:31:11 Average: 2 34.22 0.00 1.54 0.49 0.12 63.63 19:31:11 Average: 3 33.91 0.00 1.55 1.29 0.11 63.14 19:31:11 19:31:11 19:31:11