13:50:55 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/122263 13:50:55 Running as SYSTEM 13:50:55 [EnvInject] - Loading node environment variables. 13:50:55 Building remotely on prd-ubuntu2204-docker-4c-16g-1496 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 13:50:57 [ssh-agent] Looking for ssh-agent implementation... 13:50:57 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 13:50:57 $ ssh-agent 13:50:57 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXpRjLgE/agent.1560 13:50:57 SSH_AGENT_PID=1562 13:50:57 [ssh-agent] Started. 13:50:57 Running ssh-add (command line suppressed) 13:50:57 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_13134456101617287672.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_13134456101617287672.key) 13:50:57 [ssh-agent] Using credentials jenkins (jenkins-ssh) 13:50:57 The recommended git tool is: NONE 13:50:59 using credential jenkins-ssh 13:50:59 Wiping out workspace first. 13:50:59 Cloning the remote Git repository 13:50:59 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 13:50:59 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 13:50:59 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:50:59 > git --version # timeout=10 13:50:59 > git --version # 'git version 2.34.1' 13:50:59 using GIT_SSH to set credentials jenkins-ssh 13:50:59 Verifying host key using known hosts file, will automatically accept unseen keys 13:50:59 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 13:51:07 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:51:07 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 13:51:07 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:51:07 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:51:07 using GIT_SSH to set credentials jenkins-ssh 13:51:07 Verifying host key using known hosts file, will automatically accept unseen keys 13:51:07 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/63/122263/3 # timeout=10 13:51:08 > git rev-parse c4c8cc1a092b2a28c1f331fcc48d23469053f0d9^{commit} # timeout=10 13:51:08 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 13:51:08 Checking out Revision c4c8cc1a092b2a28c1f331fcc48d23469053f0d9 (refs/changes/63/122263/3) 13:51:08 > git config core.sparsecheckout # timeout=10 13:51:08 > git checkout -f c4c8cc1a092b2a28c1f331fcc48d23469053f0d9 # timeout=10 13:51:08 Commit message: "Use openroadm-topology creating R2R TAPI links" 13:51:08 > git rev-parse FETCH_HEAD^{commit} # timeout=10 13:51:08 > git rev-list --no-walk 9172e5fdcc80219809b96be6c33a449ca81d2104 # timeout=10 13:51:08 > git remote # timeout=10 13:51:08 > git submodule init # timeout=10 13:51:08 > git submodule sync # timeout=10 13:51:08 > git config --get remote.origin.url # timeout=10 13:51:08 > git submodule init # timeout=10 13:51:08 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 13:51:08 ERROR: No submodules found. 13:51:11 provisioning config files... 13:51:11 copy managed file [npmrc] to file:/home/jenkins/.npmrc 13:51:11 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 13:51:11 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5834835571893968548.sh 13:51:11 ---> python-tools-install.sh 13:51:11 Setup pyenv: 13:51:12 * system (set by /opt/pyenv/version) 13:51:12 * 3.8.20 (set by /opt/pyenv/version) 13:51:12 * 3.9.20 (set by /opt/pyenv/version) 13:51:12 3.10.15 13:51:12 3.11.10 13:51:17 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-N0Ma 13:51:17 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 13:51:17 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:51:17 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:51:22 lf-activate-venv(): INFO: Base packages installed successfully 13:51:22 lf-activate-venv(): INFO: Installing additional packages: lftools 13:51:54 lf-activate-venv(): INFO: Adding /tmp/venv-N0Ma/bin to PATH 13:51:54 Generating Requirements File 13:52:14 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. 13:52:14 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 13:52:14 Python 3.11.10 13:52:14 pip 26.0.1 from /tmp/venv-N0Ma/lib/python3.11/site-packages/pip (python 3.11) 13:52:15 appdirs==1.4.4 13:52:15 argcomplete==3.6.3 13:52:15 aspy.yaml==1.3.0 13:52:15 attrs==26.1.0 13:52:15 autopage==0.6.0 13:52:15 beautifulsoup4==4.14.3 13:52:15 boto3==1.42.86 13:52:15 botocore==1.42.86 13:52:15 bs4==0.0.2 13:52:15 certifi==2026.2.25 13:52:15 cffi==2.0.0 13:52:15 cfgv==3.5.0 13:52:15 chardet==7.4.1 13:52:15 charset-normalizer==3.4.7 13:52:15 click==8.3.2 13:52:15 cliff==4.13.3 13:52:15 cmd2==3.4.0 13:52:15 cryptography==3.3.2 13:52:15 debtcollector==3.1.0 13:52:15 decorator==5.2.1 13:52:15 defusedxml==0.7.1 13:52:15 Deprecated==1.3.1 13:52:15 distlib==0.4.0 13:52:15 dnspython==2.8.0 13:52:15 docker==7.1.0 13:52:15 dogpile.cache==1.5.0 13:52:15 durationpy==0.10 13:52:15 email-validator==2.3.0 13:52:15 filelock==3.25.2 13:52:15 future==1.0.0 13:52:15 gitdb==4.0.12 13:52:15 GitPython==3.1.46 13:52:15 httplib2==0.30.2 13:52:15 identify==2.6.18 13:52:15 idna==3.11 13:52:15 importlib-resources==1.5.0 13:52:15 iso8601==2.1.0 13:52:15 Jinja2==3.1.6 13:52:15 jmespath==1.1.0 13:52:15 jsonpatch==1.33 13:52:15 jsonpointer==3.1.1 13:52:15 jsonschema==4.26.0 13:52:15 jsonschema-specifications==2025.9.1 13:52:15 keystoneauth1==5.13.1 13:52:15 kubernetes==35.0.0 13:52:15 lftools==0.37.22 13:52:15 lxml==6.0.2 13:52:15 markdown-it-py==4.0.0 13:52:15 MarkupSafe==3.0.3 13:52:15 mdurl==0.1.2 13:52:15 msgpack==1.1.2 13:52:15 multi_key_dict==2.0.3 13:52:15 munch==4.0.0 13:52:15 netaddr==1.3.0 13:52:15 niet==1.4.2 13:52:15 nodeenv==1.10.0 13:52:15 oauth2client==4.1.3 13:52:15 oauthlib==3.3.1 13:52:15 openstacksdk==4.10.0 13:52:15 os-service-types==1.8.2 13:52:15 osc-lib==4.4.0 13:52:15 oslo.config==10.3.0 13:52:15 oslo.context==6.3.0 13:52:15 oslo.i18n==6.7.2 13:52:15 oslo.log==8.1.0 13:52:15 oslo.serialization==5.9.1 13:52:15 oslo.utils==10.0.1 13:52:15 packaging==26.0 13:52:15 pbr==7.0.3 13:52:15 platformdirs==4.9.6 13:52:15 prettytable==3.17.0 13:52:15 psutil==7.2.2 13:52:15 pyasn1==0.6.3 13:52:15 pyasn1_modules==0.4.2 13:52:15 pycparser==3.0 13:52:15 pygerrit2==2.0.15 13:52:15 PyGithub==2.9.0 13:52:15 Pygments==2.20.0 13:52:15 PyJWT==2.12.1 13:52:15 PyNaCl==1.6.2 13:52:15 pyparsing==2.4.7 13:52:15 pyperclip==1.11.0 13:52:15 pyrsistent==0.20.0 13:52:15 python-cinderclient==9.9.0 13:52:15 python-dateutil==2.9.0.post0 13:52:15 python-discovery==1.2.2 13:52:15 python-heatclient==5.1.0 13:52:15 python-jenkins==1.8.3 13:52:15 python-keystoneclient==5.8.0 13:52:15 python-magnumclient==4.10.0 13:52:15 python-openstackclient==9.0.0 13:52:15 python-swiftclient==4.10.0 13:52:15 PyYAML==6.0.3 13:52:15 referencing==0.37.0 13:52:15 requests==2.33.1 13:52:15 requests-oauthlib==2.0.0 13:52:15 requestsexceptions==1.4.0 13:52:15 rfc3986==2.0.0 13:52:15 rich==14.3.3 13:52:15 rich-argparse==1.7.2 13:52:15 rpds-py==0.30.0 13:52:15 rsa==4.9.1 13:52:15 ruamel.yaml==0.19.1 13:52:15 ruamel.yaml.clib==0.2.15 13:52:15 s3transfer==0.16.0 13:52:15 simplejson==3.20.2 13:52:15 six==1.17.0 13:52:15 smmap==5.0.3 13:52:15 soupsieve==2.8.3 13:52:15 stevedore==5.7.0 13:52:15 tabulate==0.10.0 13:52:15 toml==0.10.2 13:52:15 tomlkit==0.14.0 13:52:15 tqdm==4.67.3 13:52:15 typing_extensions==4.15.0 13:52:15 urllib3==1.26.20 13:52:15 virtualenv==21.2.0 13:52:15 wcwidth==0.6.0 13:52:15 websocket-client==1.9.0 13:52:15 wrapt==2.1.2 13:52:15 xdg==6.0.0 13:52:15 xmltodict==1.0.4 13:52:15 yq==3.4.3 13:52:15 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins11913834059491387856.sh 13:52:15 ---> uv-install.sh 13:52:15 Installing uv/uvx (latest) using shell installer 13:52:15 2026-04-09 13:52:15 URL:https://release-assets.githubusercontent.com/github-production-release-asset/699532645/e5a89072-3ff8-4346-b98a-88e3a5e84d39?sp=r&sv=2018-11-09&sr=b&spr=https&se=2026-04-09T14%3A47%3A31Z&rscd=attachment%3B+filename%3Duv-installer.sh&rsct=application%2Foctet-stream&skoid=96c2d410-5711-43a1-aedd-ab1947aa7ab0&sktid=398a6654-997b-47e9-b12b-9515b896b4de&skt=2026-04-09T13%3A47%3A22Z&ske=2026-04-09T14%3A47%3A31Z&sks=b&skv=2018-11-09&sig=QUFqD%2FrEankG2OV0d9PuEg%2B6sEA7EgAt2Kjq79sja8U%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NTc0MjkzNSwibmJmIjoxNzc1NzQyNjM1LCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.f9RCxU5xriujLzHUJ8w94Yqq99WgRrRcbIUPB9n4PSI&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [71225/71225] -> "/tmp/uv-install-jkyThO.sh" [1] 13:52:15 downloading uv 0.11.6 x86_64-unknown-linux-gnu 13:52:16 installing to /home/jenkins/.local/bin 13:52:16 uv 13:52:16 uvx 13:52:16 everything's installed! 13:52:16 13:52:16 To add $HOME/.local/bin to your PATH, either restart your shell or run: 13:52:16 13:52:16 source $HOME/.local/bin/env (sh, bash, zsh) 13:52:16 source $HOME/.local/bin/env.fish (fish) 13:52:16 Adding install location to PATH 13:52:16 ---> Validating uv/uvx install 13:52:16 uvx 0.11.6 (x86_64-unknown-linux-gnu) 13:52:16 [EnvInject] - Injecting environment variables from a build step. 13:52:16 [EnvInject] - Injecting as environment variables the properties content 13:52:16 PYTHON=python3 13:52:16 13:52:16 [EnvInject] - Variables injected successfully. 13:52:16 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins1617753608573150432.sh 13:52:16 ---> tox-install.sh 13:52:16 + source /home/jenkins/lf-env.sh 13:52:16 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:52:16 ++ mktemp -d /tmp/venv-XXXX 13:52:16 + lf_venv=/tmp/venv-txmW 13:52:16 + local venv_file=/tmp/.os_lf_venv 13:52:16 + local python=python3 13:52:16 + local options 13:52:16 + local set_path=true 13:52:16 + local install_args= 13:52:16 ++ 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 13:52:16 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:52:16 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:52:16 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:52:16 + true 13:52:16 + case $1 in 13:52:16 + venv_file=/tmp/.toxenv 13:52:16 + shift 2 13:52:16 + true 13:52:16 + case $1 in 13:52:16 + shift 13:52:16 + break 13:52:16 + case $python in 13:52:16 + local pkg_list= 13:52:16 + [[ -d /opt/pyenv ]] 13:52:16 + echo 'Setup pyenv:' 13:52:16 Setup pyenv: 13:52:16 + export PYENV_ROOT=/opt/pyenv 13:52:16 + PYENV_ROOT=/opt/pyenv 13:52:16 + 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 13:52:16 + 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 13:52:16 + pyenv versions 13:52:16 system 13:52:16 3.8.20 13:52:16 3.9.20 13:52:16 3.10.15 13:52:16 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:52:16 + command -v pyenv 13:52:16 ++ pyenv init - --no-rehash 13:52:16 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:52:16 for i in ${!paths[@]}; do 13:52:16 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:52:16 fi; done; 13:52:16 echo "${paths[*]}"'\'')" 13:52:16 export PATH="/opt/pyenv/shims:${PATH}" 13:52:16 export PYENV_SHELL=bash 13:52:16 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:52:16 pyenv() { 13:52:16 local command 13:52:16 command="${1:-}" 13:52:16 if [ "$#" -gt 0 ]; then 13:52:16 shift 13:52:16 fi 13:52:16 13:52:16 case "$command" in 13:52:16 rehash|shell) 13:52:16 eval "$(pyenv "sh-$command" "$@")" 13:52:16 ;; 13:52:16 *) 13:52:16 command pyenv "$command" "$@" 13:52:16 ;; 13:52:16 esac 13:52:16 }' 13:52:16 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:52:16 for i in ${!paths[@]}; do 13:52:16 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:52:16 fi; done; 13:52:16 echo "${paths[*]}"' 13:52:16 ++ 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 13:52:16 ++ 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 13:52:16 ++ 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 13:52:16 ++ export PYENV_SHELL=bash 13:52:16 ++ PYENV_SHELL=bash 13:52:16 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:52:16 +++ complete -F _pyenv pyenv 13:52:16 ++ lf-pyver python3 13:52:16 ++ local py_version_xy=python3 13:52:16 ++ local py_version_xyz= 13:52:16 ++ pyenv versions 13:52:16 ++ local command 13:52:16 ++ command=versions 13:52:16 ++ '[' 1 -gt 0 ']' 13:52:16 ++ shift 13:52:16 ++ case "$command" in 13:52:16 ++ command pyenv versions 13:52:16 ++ sed 's/^[ *]* //' 13:52:16 ++ grep -E '^[0-9.]*[0-9]$' 13:52:16 ++ awk '{ print $1 }' 13:52:16 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:52:16 +++ grep '^3' /tmp/.pyenv_versions 13:52:16 +++ tail -n 1 13:52:16 +++ sort -V 13:52:16 ++ py_version_xyz=3.11.10 13:52:16 ++ [[ -z 3.11.10 ]] 13:52:16 ++ echo 3.11.10 13:52:16 ++ return 0 13:52:16 + pyenv local 3.11.10 13:52:16 + local command 13:52:16 + command=local 13:52:16 + '[' 2 -gt 0 ']' 13:52:16 + shift 13:52:16 + case "$command" in 13:52:16 + command pyenv local 3.11.10 13:52:16 + for arg in "$@" 13:52:16 + case $arg in 13:52:16 + pkg_list+='tox ' 13:52:16 + for arg in "$@" 13:52:16 + case $arg in 13:52:16 + pkg_list+='virtualenv ' 13:52:16 + for arg in "$@" 13:52:16 + case $arg in 13:52:16 + pkg_list+='urllib3~=1.26.15 ' 13:52:16 + [[ -f /tmp/.toxenv ]] 13:52:16 + [[ ! -f /tmp/.toxenv ]] 13:52:16 + [[ -n '' ]] 13:52:16 + python3 -m venv /tmp/venv-txmW 13:52:20 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-txmW' 13:52:20 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-txmW 13:52:20 + echo /tmp/venv-txmW 13:52:20 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 13:52:20 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 13:52:20 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 13:52:20 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:52:20 + local 'pip_opts=--upgrade --quiet' 13:52:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 13:52:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 13:52:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 13:52:20 + [[ -n '' ]] 13:52:20 + [[ -n '' ]] 13:52:20 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 13:52:20 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:52:20 + /tmp/venv-txmW/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 13:52:25 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 13:52:25 lf-activate-venv(): INFO: Base packages installed successfully 13:52:25 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:52:25 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 13:52:25 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 13:52:25 + /tmp/venv-txmW/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 13:52:27 + type python3 13:52:27 + true 13:52:27 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-txmW/bin to PATH' 13:52:27 lf-activate-venv(): INFO: Adding /tmp/venv-txmW/bin to PATH 13:52:27 + PATH=/tmp/venv-txmW/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 13:52:27 + return 0 13:52:27 + python3 --version 13:52:27 Python 3.11.10 13:52:27 + python3 -m pip --version 13:52:27 pip 26.0.1 from /tmp/venv-txmW/lib/python3.11/site-packages/pip (python 3.11) 13:52:27 + python3 -m pip freeze 13:52:28 cachetools==7.0.5 13:52:28 colorama==0.4.6 13:52:28 distlib==0.4.0 13:52:28 filelock==3.25.2 13:52:28 packaging==26.0 13:52:28 platformdirs==4.9.6 13:52:28 pluggy==1.6.0 13:52:28 pyproject-api==1.10.0 13:52:28 python-discovery==1.2.2 13:52:28 tomli_w==1.2.0 13:52:28 tox==4.52.0 13:52:28 urllib3==1.26.20 13:52:28 virtualenv==21.2.0 13:52:28 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins5808175108574795515.sh 13:52:28 [EnvInject] - Injecting environment variables from a build step. 13:52:28 [EnvInject] - Injecting as environment variables the properties content 13:52:28 PARALLEL=True 13:52:28 13:52:28 [EnvInject] - Variables injected successfully. 13:52:28 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins11647196935045808868.sh 13:52:28 ---> tox-run.sh 13:52:28 + PATH=/home/jenkins/.local/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 13:52:28 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:52:28 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:52:28 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:52:28 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 13:52:28 + source /home/jenkins/lf-env.sh 13:52:28 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:52:28 ++ mktemp -d /tmp/venv-XXXX 13:52:28 + lf_venv=/tmp/venv-telV 13:52:28 + local venv_file=/tmp/.os_lf_venv 13:52:28 + local python=python3 13:52:28 + local options 13:52:28 + local set_path=true 13:52:28 + local install_args= 13:52:28 ++ 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 13:52:28 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:52:28 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:52:28 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:52:28 + true 13:52:28 + case $1 in 13:52:28 + venv_file=/tmp/.toxenv 13:52:28 + shift 2 13:52:28 + true 13:52:28 + case $1 in 13:52:28 + shift 13:52:28 + break 13:52:28 + case $python in 13:52:28 + local pkg_list= 13:52:28 + [[ -d /opt/pyenv ]] 13:52:28 + echo 'Setup pyenv:' 13:52:28 Setup pyenv: 13:52:28 + export PYENV_ROOT=/opt/pyenv 13:52:28 + PYENV_ROOT=/opt/pyenv 13:52:28 + export PATH=/opt/pyenv/bin:/home/jenkins/.local/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 13:52:28 + PATH=/opt/pyenv/bin:/home/jenkins/.local/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 13:52:28 + pyenv versions 13:52:28 system 13:52:28 3.8.20 13:52:28 3.9.20 13:52:28 3.10.15 13:52:28 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:52:28 + command -v pyenv 13:52:28 ++ pyenv init - --no-rehash 13:52:28 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:52:28 for i in ${!paths[@]}; do 13:52:28 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:52:28 fi; done; 13:52:28 echo "${paths[*]}"'\'')" 13:52:28 export PATH="/opt/pyenv/shims:${PATH}" 13:52:28 export PYENV_SHELL=bash 13:52:28 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:52:28 pyenv() { 13:52:28 local command 13:52:28 command="${1:-}" 13:52:28 if [ "$#" -gt 0 ]; then 13:52:28 shift 13:52:28 fi 13:52:28 13:52:28 case "$command" in 13:52:28 rehash|shell) 13:52:28 eval "$(pyenv "sh-$command" "$@")" 13:52:28 ;; 13:52:28 *) 13:52:28 command pyenv "$command" "$@" 13:52:28 ;; 13:52:28 esac 13:52:28 }' 13:52:28 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:52:28 for i in ${!paths[@]}; do 13:52:28 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:52:28 fi; done; 13:52:28 echo "${paths[*]}"' 13:52:28 ++ PATH=/opt/pyenv/bin:/home/jenkins/.local/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 13:52:28 ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/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 13:52:28 ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/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 13:52:28 ++ export PYENV_SHELL=bash 13:52:28 ++ PYENV_SHELL=bash 13:52:28 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:52:28 +++ complete -F _pyenv pyenv 13:52:28 ++ lf-pyver python3 13:52:28 ++ local py_version_xy=python3 13:52:28 ++ local py_version_xyz= 13:52:28 ++ pyenv versions 13:52:28 ++ local command 13:52:28 ++ command=versions 13:52:28 ++ '[' 1 -gt 0 ']' 13:52:28 ++ shift 13:52:28 ++ case "$command" in 13:52:28 ++ command pyenv versions 13:52:28 ++ sed 's/^[ *]* //' 13:52:28 ++ grep -E '^[0-9.]*[0-9]$' 13:52:28 ++ awk '{ print $1 }' 13:52:28 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:52:28 +++ grep '^3' /tmp/.pyenv_versions 13:52:28 +++ sort -V 13:52:28 +++ tail -n 1 13:52:28 ++ py_version_xyz=3.11.10 13:52:28 ++ [[ -z 3.11.10 ]] 13:52:28 ++ echo 3.11.10 13:52:28 ++ return 0 13:52:28 + pyenv local 3.11.10 13:52:28 + local command 13:52:28 + command=local 13:52:28 + '[' 2 -gt 0 ']' 13:52:28 + shift 13:52:28 + case "$command" in 13:52:28 + command pyenv local 3.11.10 13:52:28 + for arg in "$@" 13:52:28 + case $arg in 13:52:28 + pkg_list+='tox ' 13:52:28 + for arg in "$@" 13:52:28 + case $arg in 13:52:28 + pkg_list+='virtualenv ' 13:52:28 + for arg in "$@" 13:52:28 + case $arg in 13:52:28 + pkg_list+='urllib3~=1.26.15 ' 13:52:28 + [[ -f /tmp/.toxenv ]] 13:52:28 ++ cat /tmp/.toxenv 13:52:28 + lf_venv=/tmp/venv-txmW 13:52:28 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-txmW from' file:/tmp/.toxenv 13:52:28 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-txmW from file:/tmp/.toxenv 13:52:28 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 13:52:28 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:52:28 + local 'pip_opts=--upgrade --quiet' 13:52:28 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 13:52:28 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 13:52:28 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 13:52:28 + [[ -n '' ]] 13:52:28 + [[ -n '' ]] 13:52:28 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 13:52:28 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:52:28 + /tmp/venv-txmW/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 13:52:29 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 13:52:29 lf-activate-venv(): INFO: Base packages installed successfully 13:52:29 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:52:29 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 13:52:29 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 13:52:29 + /tmp/venv-txmW/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 13:52:31 + type python3 13:52:31 + true 13:52:31 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-txmW/bin to PATH' 13:52:31 lf-activate-venv(): INFO: Adding /tmp/venv-txmW/bin to PATH 13:52:31 + PATH=/tmp/venv-txmW/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/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 13:52:31 + return 0 13:52:31 + [[ -d /opt/pyenv ]] 13:52:31 + echo '---> Setting up pyenv' 13:52:31 ---> Setting up pyenv 13:52:31 + export PYENV_ROOT=/opt/pyenv 13:52:31 + PYENV_ROOT=/opt/pyenv 13:52:31 + export PATH=/opt/pyenv/bin:/tmp/venv-txmW/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/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 13:52:31 + PATH=/opt/pyenv/bin:/tmp/venv-txmW/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/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 13:52:31 ++ pwd 13:52:31 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 13:52:31 + export PYTHONPATH 13:52:31 + export TOX_TESTENV_PASSENV=PYTHONPATH 13:52:31 + TOX_TESTENV_PASSENV=PYTHONPATH 13:52:31 + tox --version 13:52:31 4.52.0 from /tmp/venv-txmW/lib/python3.11/site-packages/tox/__init__.py 13:52:31 + PARALLEL=True 13:52:31 + TOX_OPTIONS_LIST= 13:52:31 + [[ -n '' ]] 13:52:31 + case ${PARALLEL,,} in 13:52:31 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 13:52:31 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 13:52:31 + tox --parallel auto --parallel-live 13:52:33 docs: install_deps> python -I -m pip install -r docs/requirements.txt 13:52:33 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 13:52:33 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 13:52:33 checkbashisms: freeze> python -m pip freeze --all 13:52:34 checkbashisms: pip==26.0.1,setuptools==82.0.0 13:52:34 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:52:34 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)' 13:52:34 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 13:52:35 checkbashisms: OK ✔ in 3.53 seconds 13:52:35 pre-commit: install_deps> python -I -m pip install pre-commit 13:52:38 pre-commit: freeze> python -m pip freeze --all 13:52:38 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.25.2,identify==2.6.18,nodeenv==1.10.0,pip==26.0.1,platformdirs==4.9.6,pre_commit==4.5.1,python-discovery==1.2.2,PyYAML==6.0.3,setuptools==82.0.0,virtualenv==21.2.0 13:52:38 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:52:38 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)' 13:52:38 /usr/bin/cpan 13:52:38 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 13:52:39 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 13:52:39 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 13:52:40 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 13:52:40 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:52:41 [INFO] Initializing environment for https://github.com/hhatto/autopep8. 13:52:41 buildcontroller: freeze> python -m pip freeze --all 13:52:41 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 13:52:41 buildcontroller: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:52:41 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 13:52:41 + update-java-alternatives -l 13:52:41 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 13:52:41 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 13:52:41 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 13:52:41 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 13:52:41 update-alternatives: error: no alternatives for jaotc 13:52:41 update-alternatives: error: no alternatives for rmic 13:52:42 + java -version 13:52:42 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 13:52:42 + JAVA_VER=21 13:52:42 + echo 21 13:52:42 21 13:52:42 + javac -version 13:52:42 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 13:52:42 + JAVAC_VER=21 13:52:42 + echo 21 13:52:42 + [ 21 -ge 21 ] 13:52:42 + [ 21 -ge 21 ] 13:52:42 + echo ok, java is 21 or newer 13:52:42 21 13:52:42 ok, java is 21 or newer 13:52:42 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 13:52:42 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 13:52:42 2026-04-09 13:52:42 URL:https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz [9238692/9238692] -> "/tmp/apache-maven-3.9.14-bin.tar.gz" [1] 13:52:42 + sudo mkdir -p /opt 13:52:42 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 13:52:42 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 13:52:42 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 13:52:42 + mvn --version 13:52:42 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 13:52:43 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 13:52:43 Maven home: /opt/maven 13:52:43 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 13:52:43 Default locale: en, platform encoding: UTF-8 13:52:43 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 13:52:43 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 13:52:43 NOTE: Picked up JDK_JAVA_OPTIONS: 13:52:43 --add-opens=java.base/java.io=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.lang=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.net=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.nio=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.util=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:52:43 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:52:43 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:52:43 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:52:43 -Xlog:disable 13:52:43 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 13:52:44 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 13:52:44 [INFO] Once installed this environment will be reused. 13:52:44 [INFO] This may take a few minutes... 13:52:51 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:52:51 [INFO] Once installed this environment will be reused. 13:52:51 [INFO] This may take a few minutes... 13:53:00 [INFO] Installing environment for https://github.com/hhatto/autopep8. 13:53:00 [INFO] Once installed this environment will be reused. 13:53:00 [INFO] This may take a few minutes... 13:53:06 docs: freeze> python -m pip freeze --all 13:53:06 docs-linkcheck: freeze> python -m pip freeze --all 13:53:06 docs-linkcheck: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.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-tabs==3.5.0,sphinx_rtd_theme==3.1.0,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.6.3,webcolors==25.10.0 13:53: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 13:53:07 docs: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.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-tabs==3.5.0,sphinx_rtd_theme==3.1.0,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.6.3,webcolors==25.10.0 13:53:07 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 13:53:07 [INFO] Installing environment for https://github.com/perltidy/perltidy. 13:53:07 [INFO] Once installed this environment will be reused. 13:53:07 [INFO] This may take a few minutes... 13:53:11 docs: OK ✔ in 39.78 seconds 13:53:11 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 13:53:16 docs-linkcheck: OK ✔ in 40.15 seconds 13:53:16 pylint: freeze> python -m pip freeze --all 13:53:17 pylint: astroid==4.0.4,dill==0.4.1,isort==8.0.1,mccabe==0.7.0,pip==26.0.1,platformdirs==4.9.6,pylint==4.0.5,setuptools==82.0.0,tomlkit==0.14.0 13:53:17 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}$' '{}' + 13:53:23 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 13:53:23 [INFO] Once installed this environment will be reused. 13:53:23 [INFO] This may take a few minutes... 13:53:28 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 13:53:28 [INFO] Once installed this environment will be reused. 13:53:28 [INFO] This may take a few minutes... 13:53:33 trim trailing whitespace.................................................Passed 13:53:34 fix end of files.........................................................Passed 13:53:34 check for added large files..............................................Passed 13:53:34 check for merge conflicts................................................Passed 13:53:35 check for case conflicts.................................................Passed 13:53:35 check json...............................................................Passed 13:53:35 mixed line ending........................................................Passed 13:53:36 Tabs remover.............................................................Passed 13:53:36 autopep8.................................................................Passed 13:53:41 perltidy.................................................................Passed 13:53:42 ShellCheck v0.11.0.......................................................Passed 13:53:46 prettier.................................................................Passed 13:53:49 yamllint.................................................................Passed 13:53:49 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 13:53:50 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 13:53:50 [INFO] Once installed this environment will be reused. 13:53:50 [INFO] This may take a few minutes... 13:53:52 13:53:52 ------------------------------------ 13:53:52 Your code has been rated at 10.00/10 13:53:52 13:54:00 gitlint..................................................................Passed 13:54:44 pylint: OK ✔ in 43.68 seconds 13:54:44 pre-commit: OK ✔ in 1 minute 25.27 seconds 13:54:44 buildcontroller: OK ✔ in 2 minutes 11.72 seconds 13:54:44 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 13:54:44 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 13:54:44 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 13:54:44 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 13:54:51 build_karaf_tests221: freeze> python -m pip freeze --all 13:54:51 build_karaf_tests121: freeze> python -m pip freeze --all 13:54:51 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:54:51 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:54:51 build karaf in karaf221 with ./karaf221.env 13:54:51 NOTE: Picked up JDK_JAVA_OPTIONS: 13:54:51 --add-opens=java.base/java.io=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.net=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:54:51 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:54:51 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:54:51 -Xlog:disable 13:54:51 build_karaf_tests190: freeze> python -m pip freeze --all 13:54:51 build_karaf_tests71: freeze> python -m pip freeze --all 13:54:51 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:54:51 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:54:51 build karaf in karaf121 with ./karaf121.env 13:54:51 NOTE: Picked up JDK_JAVA_OPTIONS: 13:54:51 --add-opens=java.base/java.io=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.net=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:54:51 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:54:51 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:54:51 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:54:51 -Xlog:disable 13:54:51 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:54:51 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:54:52 build karaf in karaf71 with ./karaf71.env 13:54:52 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:54:52 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:54:52 NOTE: Picked up JDK_JAVA_OPTIONS: 13:54:52 --add-opens=java.base/java.io=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.net=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:54:52 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:54:52 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:54:52 -Xlog:disable 13:54:52 build karaf in karafoc with ./karafoc.env 13:54:52 NOTE: Picked up JDK_JAVA_OPTIONS: 13:54:52 --add-opens=java.base/java.io=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.net=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:54:52 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:54:52 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:54:52 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:54:52 -Xlog:disable 13:55:49 build_karaf_tests221: OK ✔ in 1 minute 5.53 seconds 13:55:49 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 13:55:51 build_karaf_tests121: OK ✔ in 1 minute 7.57 seconds 13:55:51 build_karaf_tests71: OK ✔ in 1 minute 7.64 seconds 13:55:51 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 13:55:53 build_karaf_tests190: OK ✔ in 1 minute 9.38 seconds 13:55:53 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 13:56:01 buildlighty: freeze> python -m pip freeze --all 13:56:02 buildlighty: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:56:02 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 13:56:02 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 13:56:02 sims: freeze> python -m pip freeze --all 13:56:02 sims: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 13:56:02 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 13:56:02 Using lighynode version 22.1.0.6 13:56:02 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 13:56:50 sims: OK ✔ in 19.06 seconds 13:56:50 buildlighty: OK ✔ in 36.19 seconds 13:56:50 testsPCE: freeze> python -m pip freeze --all 13:56:50 testsPCE: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,click==8.3.2,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.8,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.62.1,gnpy4tpce==2.4.7,idna==3.11,iniconfig==2.3.0,injector==0.24.0,invoke==3.0.3,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.5.0,lxml==6.0.2,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.2.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.3,python-dateutil==2.9.0.post0,pytz==2026.1.post1,requests==2.33.1,scipy==1.17.1,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 13:56:50 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 13:56:50 pytest -q transportpce_tests/pce/test01_pce.py 13:57:38 .................... [100%] 13:58:42 20 passed in 111.33s (0:01:51) 13:58:42 pytest -q transportpce_tests/pce/test02_pce_400G.py 13:58:59 ............ [100%] 13:59:29 12 passed in 47.46s 13:59:30 pytest -q transportpce_tests/pce/test03_gnpy.py 13:59:48 ........ [100%] 14:00:09 8 passed in 39.24s 14:00:09 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 14:00:43 ... [100%] 14:00:48 3 passed in 38.21s 14:00:49 testsPCE: OK ✔ in 4 minutes 55.31 seconds 14:00:49 tests190: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 14:00:49 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 14:00:49 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 14:00:56 tests190: freeze> python -m pip freeze --all 14:00:56 tests121: freeze> python -m pip freeze --all 14:00:56 tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 14:00:56 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 14:00:56 using environment variables from ./karafoc.env 14:00:56 pytest -q transportpce_tests/oc/test01_portmapping.py 14:00:56 tests_tapi: freeze> python -m pip freeze --all 14:00:56 tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 14:00:56 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 14:00:56 using environment variables from ./karaf121.env 14:00:56 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 14:00:57 tests_tapi: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 14:00:57 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 14:00:57 using environment variables from ./karaf221.env 14:00:57 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 14:02:17 ........... [100%] 14:02:36 10 passed in 98.83s (0:01:38) 14:02:36 pytest -q transportpce_tests/oc/test02_topology.py 14:02:42 ........................ [100%] 14:03:22 21 passed in 145.42s (0:02:25) 14:03:23 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 14:03:27 .............................. [100%] 14:03:52 14 passed in 75.46s (0:01:15) 14:03:52 pytest -q transportpce_tests/oc/test03_renderer.py 14:03:54 ...................... [100%] 14:04:39 6 passed in 75.97s (0:01:15) 14:04:39 pytest -q transportpce_tests/1.2.1/test03_topology.py 14:04:40 .................... [100%] 14:05:00 19 passed in 67.31s (0:01:07) 14:05:00 tests190: OK ✔ in 4 minutes 12.02 seconds 14:05:00 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 14:05:07 .tests71: freeze> python -m pip freeze --all 14:05:08 tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 14:05:08 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 14:05:08 using environment variables from ./karaf71.env 14:05:08 pytest -q transportpce_tests/7.1/test01_portmapping.py 14:05:27 ................................ [100%] 14:06:10 12 passed in 61.70s (0:01:01) 14:06:10 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 14:06:12 .................................................. [100%] 14:07:22 44 passed in 162.09s (0:02:42) 14:07:22 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 14:07:23 ................................................................... [100%] 14:08:51 24 passed in 88.30s (0:01:28) 14:08:51 pytest -q transportpce_tests/1.2.1/test05_olm.py 14:08:51 .. [100%] 14:08:56 62 passed in 164.80s (0:02:44) 14:08:56 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 14:09:51 .............................................................................. [100%] 14:11:37 48 passed in 161.35s (0:02:41) 14:11:37 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 14:11:41 ................. [100%] 14:12:21 40 passed in 210.10s (0:03:30) 14:12:21 pytest -q transportpce_tests/1.2.1/test06_end2end.py 14:12:23 ................ [100%] 14:12:58 22 passed in 80.31s (0:01:20) 14:13:12 ...................................... [100%] 14:15:48 51 passed in 891.29s (0:14:51) 14:15:48 pytest -q transportpce_tests/tapi/test02_full_topology.py 14:15:55 .........................F......................... [100%] 14:21:29 54 passed in 547.80s (0:09:07) 14:23:55 ...F [100%] 14:25:01 =================================== FAILURES =================================== 14:25:01 ________ TestTransportPCEFullTopology.test_13_get_tapi_topology_details ________ 14:25:01 14:25:01 self = 14:25:01 14:25:01 def test_13_get_tapi_topology_details(self): 14:25:01 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 14:25:01 response = test_utils.transportpce_api_rpc_request( 14:25:01 'tapi-topology', 'get-topology-details', self.tapi_topo) 14:25:01 time.sleep(2) 14:25:01 self.assertEqual(response['status_code'], requests.codes.ok) 14:25:01 self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 14:25:01 > self.assertEqual(len(response['output']['topology']['link']), 3, 'There should be 3 TAPI links') 14:25:01 E AssertionError: 2 != 3 : There should be 3 TAPI links 14:25:01 14:25:01 transportpce_tests/tapi/test02_full_topology.py:307: AssertionError 14:25:01 ______ TestTransportPCEFullTopology.test_35_check_uninstall_Tapi_Feature _______ 14:25:01 14:25:01 self = 14:25:01 conn = 14:25:01 method = 'GET' 14:25:01 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 14:25:01 body = None 14:25:01 headers = {'User-Agent': 'python-requests/2.33.1', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 14:25:01 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 14:25:01 timeout = Timeout(connect=30, read=30, total=None), chunked = False 14:25:01 response_conn = 14:25:01 preload_content = False, decode_content = False, enforce_content_length = True 14:25:01 14:25:01 def _make_request( 14:25:01 self, 14:25:01 conn: BaseHTTPConnection, 14:25:01 method: str, 14:25:01 url: str, 14:25:01 body: _TYPE_BODY | None = None, 14:25:01 headers: typing.Mapping[str, str] | None = None, 14:25:01 retries: Retry | None = None, 14:25:01 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 14:25:01 chunked: bool = False, 14:25:01 response_conn: BaseHTTPConnection | None = None, 14:25:01 preload_content: bool = True, 14:25:01 decode_content: bool = True, 14:25:01 enforce_content_length: bool = True, 14:25:01 ) -> BaseHTTPResponse: 14:25:01 """ 14:25:01 Perform a request on a given urllib connection object taken from our 14:25:01 pool. 14:25:01 14:25:01 :param conn: 14:25:01 a connection from one of our connection pools 14:25:01 14:25:01 :param method: 14:25:01 HTTP request method (such as GET, POST, PUT, etc.) 14:25:01 14:25:01 :param url: 14:25:01 The URL to perform the request on. 14:25:01 14:25:01 :param body: 14:25:01 Data to send in the request body, either :class:`str`, :class:`bytes`, 14:25:01 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 14:25:01 14:25:01 :param headers: 14:25:01 Dictionary of custom headers to send, such as User-Agent, 14:25:01 If-None-Match, etc. If None, pool headers are used. If provided, 14:25:01 these headers completely replace any pool-specific headers. 14:25:01 14:25:01 :param retries: 14:25:01 Configure the number of retries to allow before raising a 14:25:01 :class:`~urllib3.exceptions.MaxRetryError` exception. 14:25:01 14:25:01 Pass ``None`` to retry until you receive a response. Pass a 14:25:01 :class:`~urllib3.util.retry.Retry` object for fine-grained control 14:25:01 over different types of retries. 14:25:01 Pass an integer number to retry connection errors that many times, 14:25:01 but no other types of errors. Pass zero to never retry. 14:25:01 14:25:01 If ``False``, then retries are disabled and any exception is raised 14:25:01 immediately. Also, instead of raising a MaxRetryError on redirects, 14:25:01 the redirect response will be returned. 14:25:01 14:25:01 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 14:25:01 14:25:01 :param timeout: 14:25:01 If specified, overrides the default timeout for this one 14:25:01 request. It may be a float (in seconds) or an instance of 14:25:01 :class:`urllib3.util.Timeout`. 14:25:01 14:25:01 :param chunked: 14:25:01 If True, urllib3 will send the body using chunked transfer 14:25:01 encoding. Otherwise, urllib3 will send the body using the standard 14:25:01 content-length form. Defaults to False. 14:25:01 14:25:01 :param response_conn: 14:25:01 Set this to ``None`` if you will handle releasing the connection or 14:25:01 set the connection to have the response release it. 14:25:01 14:25:01 :param preload_content: 14:25:01 If True, the response's body will be preloaded during construction. 14:25:01 14:25:01 :param decode_content: 14:25:01 If True, will attempt to decode the body based on the 14:25:01 'content-encoding' header. 14:25:01 14:25:01 :param enforce_content_length: 14:25:01 Enforce content length checking. Body returned by server must match 14:25:01 value of Content-Length header, if present. Otherwise, raise error. 14:25:01 """ 14:25:01 self.num_requests += 1 14:25:01 14:25:01 timeout_obj = self._get_timeout(timeout) 14:25:01 timeout_obj.start_connect() 14:25:01 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 14:25:01 14:25:01 try: 14:25:01 # Trigger any extra validation we need to do. 14:25:01 try: 14:25:01 self._validate_conn(conn) 14:25:01 except (SocketTimeout, BaseSSLError) as e: 14:25:01 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 14:25:01 raise 14:25:01 14:25:01 # _validate_conn() starts the connection to an HTTPS proxy 14:25:01 # so we need to wrap errors with 'ProxyError' here too. 14:25:01 except ( 14:25:01 OSError, 14:25:01 NewConnectionError, 14:25:01 TimeoutError, 14:25:01 BaseSSLError, 14:25:01 CertificateError, 14:25:01 SSLError, 14:25:01 ) as e: 14:25:01 new_e: Exception = e 14:25:01 if isinstance(e, (BaseSSLError, CertificateError)): 14:25:01 new_e = SSLError(e) 14:25:01 # If the connection didn't successfully connect to it's proxy 14:25:01 # then there 14:25:01 if isinstance( 14:25:01 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 14:25:01 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 14:25:01 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 14:25:01 raise new_e 14:25:01 14:25:01 # conn.request() calls http.client.*.request, not the method in 14:25:01 # urllib3.request. It also calls makefile (recv) on the socket. 14:25:01 try: 14:25:01 conn.request( 14:25:01 method, 14:25:01 url, 14:25:01 body=body, 14:25:01 headers=headers, 14:25:01 chunked=chunked, 14:25:01 preload_content=preload_content, 14:25:01 decode_content=decode_content, 14:25:01 enforce_content_length=enforce_content_length, 14:25:01 ) 14:25:01 14:25:01 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 14:25:01 # legitimately able to close the connection after sending a valid response. 14:25:01 # With this behaviour, the received response is still readable. 14:25:01 except BrokenPipeError: 14:25:01 pass 14:25:01 except OSError as e: 14:25:01 # MacOS/Linux 14:25:01 # EPROTOTYPE and ECONNRESET are needed on macOS 14:25:01 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 14:25:01 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 14:25:01 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 14:25:01 raise 14:25:01 14:25:01 # Reset the timeout for the recv() on the socket 14:25:01 read_timeout = timeout_obj.read_timeout 14:25:01 14:25:01 if not conn.is_closed: 14:25:01 # In Python 3 socket.py will catch EAGAIN and return None when you 14:25:01 # try and read into the file pointer created by http.client, which 14:25:01 # instead raises a BadStatusLine exception. Instead of catching 14:25:01 # the exception and assuming all BadStatusLine exceptions are read 14:25:01 # timeouts, check for a zero timeout before making the request. 14:25:01 if read_timeout == 0: 14:25:01 raise ReadTimeoutError( 14:25:01 self, url, f"Read timed out. (read timeout={read_timeout})" 14:25:01 ) 14:25:01 conn.timeout = read_timeout 14:25:01 14:25:01 # Receive the response from the server 14:25:01 try: 14:25:01 > response = conn.getresponse() 14:25:01 ^^^^^^^^^^^^^^^^^^ 14:25:01 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 14:25:01 httplib_response = super().getresponse() 14:25:01 ^^^^^^^^^^^^^^^^^^^^^ 14:25:01 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 14:25:01 response.begin() 14:25:01 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 14:25:01 version, status, reason = self._read_status() 14:25:01 ^^^^^^^^^^^^^^^^^^^ 14:25:01 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 14:25:01 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 14:25:01 self = 14:25:01 b = 14:25:01 14:25:01 def readinto(self, b): 14:25:01 """Read up to len(b) bytes into the writable buffer *b* and return 14:25:01 the number of bytes read. If the socket is non-blocking and no bytes 14:25:01 are available, None is returned. 14:25:01 14:25:01 If *b* is non-empty, a 0 return value indicates that the connection 14:25:01 was shutdown at the other end. 14:25:01 """ 14:25:01 self._checkClosed() 14:25:01 self._checkReadable() 14:25:01 if self._timeout_occurred: 14:25:01 raise OSError("cannot read from timed out object") 14:25:01 while True: 14:25:01 try: 14:25:01 > return self._sock.recv_into(b) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 E TimeoutError: timed out 14:25:01 14:25:01 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 14:25:01 14:25:01 The above exception was the direct cause of the following exception: 14:25:01 14:25:01 self = 14:25:01 request = , stream = False 14:25:01 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 14:25:01 proxies = OrderedDict() 14:25:01 14:25:01 def send( 14:25:01 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 14:25:01 ): 14:25:01 """Sends PreparedRequest object. Returns Response object. 14:25:01 14:25:01 :param request: The :class:`PreparedRequest ` being sent. 14:25:01 :param stream: (optional) Whether to stream the request content. 14:25:01 :param timeout: (optional) How long to wait for the server to send 14:25:01 data before giving up, as a float, or a :ref:`(connect timeout, 14:25:01 read timeout) ` tuple. 14:25:01 :type timeout: float or tuple or urllib3 Timeout object 14:25:01 :param verify: (optional) Either a boolean, in which case it controls whether 14:25:01 we verify the server's TLS certificate, or a string, in which case it 14:25:01 must be a path to a CA bundle to use 14:25:01 :param cert: (optional) Any user-provided SSL certificate to be trusted. 14:25:01 :param proxies: (optional) The proxies dictionary to apply to the request. 14:25:01 :rtype: requests.Response 14:25:01 """ 14:25:01 14:25:01 try: 14:25:01 conn = self.get_connection_with_tls_context( 14:25:01 request, verify, proxies=proxies, cert=cert 14:25:01 ) 14:25:01 except LocationValueError as e: 14:25:01 raise InvalidURL(e, request=request) 14:25:01 14:25:01 self.cert_verify(conn, request.url, verify, cert) 14:25:01 url = self.request_url(request, proxies) 14:25:01 self.add_headers( 14:25:01 request, 14:25:01 stream=stream, 14:25:01 timeout=timeout, 14:25:01 verify=verify, 14:25:01 cert=cert, 14:25:01 proxies=proxies, 14:25:01 ) 14:25:01 14:25:01 chunked = not (request.body is None or "Content-Length" in request.headers) 14:25:01 14:25:01 if isinstance(timeout, tuple): 14:25:01 try: 14:25:01 connect, read = timeout 14:25:01 timeout = TimeoutSauce(connect=connect, read=read) 14:25:01 except ValueError: 14:25:01 raise ValueError( 14:25:01 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 14:25:01 f"or a single float to set both timeouts to the same value." 14:25:01 ) 14:25:01 elif isinstance(timeout, TimeoutSauce): 14:25:01 pass 14:25:01 else: 14:25:01 timeout = TimeoutSauce(connect=timeout, read=timeout) 14:25:01 14:25:01 try: 14:25:01 > resp = conn.urlopen( 14:25:01 method=request.method, 14:25:01 url=url, 14:25:01 body=request.body, 14:25:01 headers=request.headers, 14:25:01 redirect=False, 14:25:01 assert_same_host=False, 14:25:01 preload_content=False, 14:25:01 decode_content=False, 14:25:01 retries=self.max_retries, 14:25:01 timeout=timeout, 14:25:01 chunked=chunked, 14:25:01 ) 14:25:01 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:645: 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 14:25:01 retries = retries.increment( 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 14:25:01 raise reraise(type(error), error, _stacktrace) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 14:25:01 raise value 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 14:25:01 response = self._make_request( 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 14:25:01 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 14:25:01 self = 14:25:01 err = TimeoutError('timed out') 14:25:01 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 14:25:01 timeout_value = 30 14:25:01 14:25:01 def _raise_timeout( 14:25:01 self, 14:25:01 err: BaseSSLError | OSError | SocketTimeout, 14:25:01 url: str, 14:25:01 timeout_value: _TYPE_TIMEOUT | None, 14:25:01 ) -> None: 14:25:01 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 14:25:01 14:25:01 if isinstance(err, SocketTimeout): 14:25:01 > raise ReadTimeoutError( 14:25:01 self, url, f"Read timed out. (read timeout={timeout_value})" 14:25:01 ) from err 14:25:01 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 14:25:01 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 14:25:01 14:25:01 During handling of the above exception, another exception occurred: 14:25:01 14:25:01 self = 14:25:01 14:25:01 def test_35_check_uninstall_Tapi_Feature(self): 14:25:01 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 14:25:01 time.sleep(16) 14:25:01 print("Tapi Feature uninstalled") 14:25:01 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 14:25:01 transportpce_tests/tapi/test02_full_topology.py:787: 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 14:25:01 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 transportpce_tests/common/test_utils.py:117: in get_request 14:25:01 return requests.request( 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 14:25:01 return session.request(method=method, url=url, **kwargs) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:592: in request 14:25:01 resp = self.send(prep, **send_kwargs) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:706: in send 14:25:01 r = adapter.send(request, **kwargs) 14:25:01 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 14:25:01 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 14:25:01 14:25:01 self = 14:25:01 request = , stream = False 14:25:01 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 14:25:01 proxies = OrderedDict() 14:25:01 14:25:01 def send( 14:25:01 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 14:25:01 ): 14:25:01 """Sends PreparedRequest object. Returns Response object. 14:25:01 14:25:01 :param request: The :class:`PreparedRequest ` being sent. 14:25:01 :param stream: (optional) Whether to stream the request content. 14:25:01 :param timeout: (optional) How long to wait for the server to send 14:25:01 data before giving up, as a float, or a :ref:`(connect timeout, 14:25:01 read timeout) ` tuple. 14:25:01 :type timeout: float or tuple or urllib3 Timeout object 14:25:01 :param verify: (optional) Either a boolean, in which case it controls whether 14:25:01 we verify the server's TLS certificate, or a string, in which case it 14:25:01 must be a path to a CA bundle to use 14:25:01 :param cert: (optional) Any user-provided SSL certificate to be trusted. 14:25:01 :param proxies: (optional) The proxies dictionary to apply to the request. 14:25:01 :rtype: requests.Response 14:25:01 """ 14:25:01 14:25:01 try: 14:25:01 conn = self.get_connection_with_tls_context( 14:25:01 request, verify, proxies=proxies, cert=cert 14:25:01 ) 14:25:01 except LocationValueError as e: 14:25:01 raise InvalidURL(e, request=request) 14:25:01 14:25:01 self.cert_verify(conn, request.url, verify, cert) 14:25:01 url = self.request_url(request, proxies) 14:25:01 self.add_headers( 14:25:01 request, 14:25:01 stream=stream, 14:25:01 timeout=timeout, 14:25:01 verify=verify, 14:25:01 cert=cert, 14:25:01 proxies=proxies, 14:25:01 ) 14:25:01 14:25:01 chunked = not (request.body is None or "Content-Length" in request.headers) 14:25:01 14:25:01 if isinstance(timeout, tuple): 14:25:01 try: 14:25:01 connect, read = timeout 14:25:01 timeout = TimeoutSauce(connect=connect, read=read) 14:25:01 except ValueError: 14:25:01 raise ValueError( 14:25:01 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 14:25:01 f"or a single float to set both timeouts to the same value." 14:25:01 ) 14:25:01 elif isinstance(timeout, TimeoutSauce): 14:25:01 pass 14:25:01 else: 14:25:01 timeout = TimeoutSauce(connect=timeout, read=timeout) 14:25:01 14:25:01 try: 14:25:01 resp = conn.urlopen( 14:25:01 method=request.method, 14:25:01 url=url, 14:25:01 body=request.body, 14:25:01 headers=request.headers, 14:25:01 redirect=False, 14:25:01 assert_same_host=False, 14:25:01 preload_content=False, 14:25:01 decode_content=False, 14:25:01 retries=self.max_retries, 14:25:01 timeout=timeout, 14:25:01 chunked=chunked, 14:25:01 ) 14:25:01 14:25:01 except (ProtocolError, OSError) as err: 14:25:01 raise ConnectionError(err, request=request) 14:25:01 14:25:01 except MaxRetryError as e: 14:25:01 if isinstance(e.reason, ConnectTimeoutError): 14:25:01 # TODO: Remove this in 3.0.0: see #2811 14:25:01 if not isinstance(e.reason, NewConnectionError): 14:25:01 raise ConnectTimeout(e, request=request) 14:25:01 14:25:01 if isinstance(e.reason, ResponseError): 14:25:01 raise RetryError(e, request=request) 14:25:01 14:25:01 if isinstance(e.reason, _ProxyError): 14:25:01 raise ProxyError(e, request=request) 14:25:01 14:25:01 if isinstance(e.reason, _SSLError): 14:25:01 # This branch is for urllib3 v1.22 and later. 14:25:01 raise SSLError(e, request=request) 14:25:01 14:25:01 raise ConnectionError(e, request=request) 14:25:01 14:25:01 except ClosedPoolError as e: 14:25:01 raise ConnectionError(e, request=request) 14:25:01 14:25:01 except _ProxyError as e: 14:25:01 raise ProxyError(e) 14:25:01 14:25:01 except (_SSLError, _HTTPError) as e: 14:25:01 if isinstance(e, _SSLError): 14:25:01 # This branch is for urllib3 versions earlier than v1.22 14:25:01 raise SSLError(e, request=request) 14:25:01 elif isinstance(e, ReadTimeoutError): 14:25:01 > raise ReadTimeout(e, request=request) 14:25:01 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 14:25:01 14:25:01 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:691: ReadTimeout 14:25:01 ----------------------------- Captured stdout call ----------------------------- 14:25:01 uninstalling feature odl-transportpce-tapi 14:25:01 client: JAVA_HOME not set; results may vary 14:25:01 odl-transportpce-tapi │ 13.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 14:25:01 Tapi Feature uninstalled 14:25:01 --------------------------- Captured stdout teardown --------------------------- 14:25:01 all processes killed 14:25:01 ODL log file stored 14:25:01 =========================== short test summary info ============================ 14:25:01 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_13_get_tapi_topology_details 14:25:01 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_35_check_uninstall_Tapi_Feature 14:25:01 2 failed, 34 passed in 552.48s (0:09:12) 14:25:01 tests71: OK ✔ in 7 minutes 58.35 seconds 14:25:01 tests121: OK ✔ in 20 minutes 41.54 seconds 14:25:01 tests_tapi: exit 1 (1444.72 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7695 14:25:01 tests_tapi: FAIL ✖ in 24 minutes 13.56 seconds 14:25:01 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 14:25:09 tests221: freeze> python -m pip freeze --all 14:25:09 tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 14:25:09 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 14:25:09 using environment variables from ./karaf221.env 14:25:09 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 14:25:48 ................................... [100%] 14:26:28 35 passed in 78.26s (0:01:18) 14:26:28 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 14:27:02 ...... [100%] 14:27:17 6 passed in 48.77s 14:27:17 pytest -q transportpce_tests/2.2.1/test03_topology.py 14:28:02 ............................................ [100%] 14:29:37 44 passed in 140.28s (0:02:20) 14:29:37 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 14:30:15 ............ [100%] 14:30:40 12 passed in 61.85s (0:01:01) 14:30:40 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 14:31:08 ................ [100%] 14:32:37 16 passed in 117.13s (0:01:57) 14:32:37 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 14:33:10 ............................... [100%] 14:33:17 31 passed in 39.24s 14:33:17 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 14:33:55 .......................... [100%] 14:34:50 26 passed in 93.20s (0:01:33) 14:34:50 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 14:35:29 ...................... [100%] 14:36:34 22 passed in 103.31s (0:01:43) 14:36:34 pytest -q transportpce_tests/2.2.1/test09_olm.py 14:37:21 ........................................ [100%] 14:39:45 40 passed in 191.23s (0:03:11) 14:39:46 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 14:40:34 ........................................................................ [ 74%] 14:46:12 ......................... [100%] 14:48:04 97 passed in 498.09s (0:08:18) 14:48:04 pytest -q transportpce_tests/2.2.1/test12_end2end.py 14:48:46 ...................................................... [100%] 14:55:34 54 passed in 450.20s (0:07:30) 14:55:34 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 14:56:30 ........................................................................ [ 71%] 15:01:39 ............................. [100%] 15:06:48 101 passed in 673.16s (0:11:13) 15:06:48 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 15:07:43 ........................................................................ [ 67%] 15:13:30 ................................... [100%] 15:16:51 107 passed in 602.31s (0:10:02) 15:16:51 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 15:17:34 ............................................. [100%] 15:20:11 45 passed in 200.46s (0:03:20) 15:20:12 tests221: OK ✔ in 55 minutes 10 seconds 15:20:12 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 15:20:19 tests_hybrid: freeze> python -m pip freeze --all 15:20:19 tests_hybrid: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 15:20:19 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 15:20:19 using environment variables from ./karaf221.env 15:20:19 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 15:21:01 ................................................... [100%] 15:22:48 51 passed in 148.81s (0:02:28) 15:22:48 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 15:23:31 ........................................................................ [ 66%] 15:27:53 ..................................... [100%] 15:32:59 109 passed in 610.44s (0:10:10) 15:32:59 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 15:33:48 ..................................................... [100%] 15:40:21 53 passed in 441.68s (0:07:21) 15:40:21 buildcontroller: OK (131.72=setup[9.91]+cmd[121.81] seconds) 15:40:21 sims: OK (19.06=setup[11.58]+cmd[7.48] seconds) 15:40:21 build_karaf_tests121: OK (67.57=setup[7.92]+cmd[59.65] seconds) 15:40:21 testsPCE: OK (295.31=setup[57.46]+cmd[237.86] seconds) 15:40:21 tests121: OK (1241.54=setup[8.62]+cmd[1232.92] seconds) 15:40:21 build_karaf_tests221: OK (65.53=setup[7.72]+cmd[57.81] seconds) 15:40:21 tests_tapi: FAIL code 1 (1453.55=setup[8.83]+cmd[1444.72] seconds) 15:40:21 tests221: OK (3310.00=setup[7.79]+cmd[3302.22] seconds) 15:40:21 build_karaf_tests71: OK (67.64=setup[8.39]+cmd[59.26] seconds) 15:40:21 tests71: OK (478.35=setup[8.41]+cmd[469.94] seconds) 15:40:21 build_karaf_tests190: OK (69.38=setup[8.47]+cmd[60.91] seconds) 15:40:21 tests190: OK (252.02=setup[8.51]+cmd[243.50] seconds) 15:40:21 tests_hybrid: OK (1209.54=setup[7.67]+cmd[1201.87] seconds) 15:40:21 buildlighty: OK (36.19=setup[13.18]+cmd[23.01] seconds) 15:40:21 docs: OK (39.77=setup[35.23]+cmd[4.54] seconds) 15:40:21 docs-linkcheck: OK (40.15=setup[35.11]+cmd[5.05] seconds) 15:40:21 checkbashisms: OK (3.53=setup[2.22]+cmd[0.01,0.05,1.25] seconds) 15:40:21 pre-commit: OK (85.27=setup[3.42]+cmd[0.00,0.01,70.85,10.98] seconds) 15:40:21 pylint: OK (43.68=setup[5.54]+cmd[38.14] seconds) 15:40:21 evaluation failed :( (6469.59 seconds) 15:40:21 + tox_status=1 15:40:21 + echo '---> Completed tox runs' 15:40:21 ---> Completed tox runs 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/build_karaf_tests121/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=build_karaf_tests121 15:40:21 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/build_karaf_tests190/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=build_karaf_tests190 15:40:21 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/build_karaf_tests221/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=build_karaf_tests221 15:40:21 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/build_karaf_tests71/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=build_karaf_tests71 15:40:21 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/buildcontroller/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=buildcontroller 15:40:21 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/buildlighty/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=buildlighty 15:40:21 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/checkbashisms/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=checkbashisms 15:40:21 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/docs-linkcheck/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=docs-linkcheck 15:40:21 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/docs/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=docs 15:40:21 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/pre-commit/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=pre-commit 15:40:21 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/pylint/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=pylint 15:40:21 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/sims/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=sims 15:40:21 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests121/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests121 15:40:21 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests190/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests190 15:40:21 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests221/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests221 15:40:21 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests71/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests71 15:40:21 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/testsPCE/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=testsPCE 15:40:21 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests_hybrid/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests_hybrid 15:40:21 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 15:40:21 + for i in .tox/*/log 15:40:21 ++ echo .tox/tests_tapi/log 15:40:21 ++ awk -F/ '{print $2}' 15:40:21 + tox_env=tests_tapi 15:40:21 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 15:40:21 + DOC_DIR=docs/_build/html 15:40:21 + [[ -d docs/_build/html ]] 15:40:21 + echo '---> Archiving generated docs' 15:40:21 ---> Archiving generated docs 15:40:21 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 15:40:21 + echo '---> tox-run.sh ends' 15:40:21 ---> tox-run.sh ends 15:40:21 + test 1 -eq 0 15:40:21 + exit 1 15:40:21 ++ '[' 1 = 1 ']' 15:40:21 ++ '[' -x /usr/bin/clear_console ']' 15:40:21 ++ /usr/bin/clear_console -q 15:40:21 Build step 'Execute shell' marked build as failure 15:40:21 $ ssh-agent -k 15:40:21 unset SSH_AUTH_SOCK; 15:40:21 unset SSH_AGENT_PID; 15:40:21 echo Agent pid 1562 killed; 15:40:21 [ssh-agent] Stopped. 15:40:22 [PostBuildScript] - [INFO] Executing post build scripts. 15:40:22 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16895919826967449100.sh 15:40:22 ---> sysstat.sh 15:40:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4139622960448209421.sh 15:40:23 ---> package-listing.sh 15:40:23 ++ facter osfamily 15:40:23 ++ tr '[:upper:]' '[:lower:]' 15:40:23 + OS_FAMILY=debian 15:40:23 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 15:40:23 + START_PACKAGES=/tmp/packages_start.txt 15:40:23 + END_PACKAGES=/tmp/packages_end.txt 15:40:23 + DIFF_PACKAGES=/tmp/packages_diff.txt 15:40:23 + PACKAGES=/tmp/packages_start.txt 15:40:23 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 15:40:23 + PACKAGES=/tmp/packages_end.txt 15:40:23 + case "${OS_FAMILY}" in 15:40:23 + dpkg -l 15:40:23 + grep '^ii' 15:40:23 + '[' -f /tmp/packages_start.txt ']' 15:40:23 + '[' -f /tmp/packages_end.txt ']' 15:40:23 + diff /tmp/packages_start.txt /tmp/packages_end.txt 15:40:23 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 15:40:23 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 15:40:23 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 15:40:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7107167473766383565.sh 15:40:23 ---> capture-instance-metadata.sh 15:40:23 Setup pyenv: 15:40:23 system 15:40:23 3.8.20 15:40:23 3.9.20 15:40:23 3.10.15 15:40:23 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:40:23 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-N0Ma from file:/tmp/.os_lf_venv 15:40:23 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 15:40:23 lf-activate-venv(): INFO: Attempting to install with network-safe options... 15:40:26 lf-activate-venv(): INFO: Base packages installed successfully 15:40:26 lf-activate-venv(): INFO: Installing additional packages: lftools 15:40:48 lf-activate-venv(): INFO: Adding /tmp/venv-N0Ma/bin to PATH 15:40:48 INFO: Running in OpenStack, capturing instance metadata 15:40:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2775574496951803139.sh 15:40:49 provisioning config files... 15:40:49 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #5093 15:40:49 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config6794171671092879058tmp 15:40:49 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 15:40:49 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 15:40:49 provisioning config files... 15:40:49 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 15:40:49 [EnvInject] - Injecting environment variables from a build step. 15:40:49 [EnvInject] - Injecting as environment variables the properties content 15:40:49 SERVER_ID=logs 15:40:49 15:40:49 [EnvInject] - Variables injected successfully. 15:40:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14214973744638865570.sh 15:40:49 ---> create-netrc.sh 15:40:49 WARN: Log server credential not found. 15:40:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13781955357545925907.sh 15:40:49 ---> python-tools-install.sh 15:40:49 Setup pyenv: 15:40:50 system 15:40:50 3.8.20 15:40:50 3.9.20 15:40:50 3.10.15 15:40:50 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:40:50 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-N0Ma from file:/tmp/.os_lf_venv 15:40:50 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 15:40:50 lf-activate-venv(): INFO: Attempting to install with network-safe options... 15:40:52 lf-activate-venv(): INFO: Base packages installed successfully 15:40:52 lf-activate-venv(): INFO: Installing additional packages: lftools 15:41:01 lf-activate-venv(): INFO: Adding /tmp/venv-N0Ma/bin to PATH 15:41:01 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins11344066685152811796.sh 15:41:01 ---> uv-install.sh 15:41:01 uv 0.11.6 is already installed 15:41:01 uvx 0.11.6 (x86_64-unknown-linux-gnu) 15:41:01 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2546457308965541672.sh 15:41:01 ---> sudo-logs.sh 15:41:01 Archiving 'sudo' log.. 15:41:01 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12092028559521299637.sh 15:41:01 ---> job-cost.sh 15:41:01 INFO: Activating Python virtual environment... 15:41:01 Setup pyenv: 15:41:01 system 15:41:01 3.8.20 15:41:01 3.9.20 15:41:01 3.10.15 15:41:01 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:41:02 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-N0Ma from file:/tmp/.os_lf_venv 15:41:02 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 15:41:02 lf-activate-venv(): INFO: Attempting to install with network-safe options... 15:41:04 lf-activate-venv(): INFO: Base packages installed successfully 15:41:04 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 15:41:10 lf-activate-venv(): INFO: Adding /tmp/venv-N0Ma/bin to PATH 15:41:10 INFO: No stack-cost file found 15:41:10 INFO: Instance uptime: 6666s 15:41:10 INFO: Fetching instance metadata (attempt 1 of 3)... 15:41:10 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 15:41:10 INFO: Successfully fetched instance metadata 15:41:10 INFO: Instance type: v3-standard-4 15:41:10 INFO: Retrieving pricing info for: v3-standard-4 15:41:10 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 15:41:10 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=6666 15:41:11 INFO: Successfully fetched Vexxhost pricing API 15:41:11 INFO: Retrieved cost: 0.22 15:41:11 INFO: Retrieved resource: v3-standard-4 15:41:11 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 15:41:11 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 15:41:11 INFO: Successfully archived job cost data 15:41:11 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,5093,2026-04-09 15:41:11,v3-standard-4,6666,0.22,0.00,FAILURE 15:41:11 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins7831078938453757601.sh 15:41:11 ---> logs-deploy.sh 15:41:11 Setup pyenv: 15:41:11 system 15:41:11 3.8.20 15:41:11 3.9.20 15:41:11 3.10.15 15:41:11 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 15:41:11 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-N0Ma from file:/tmp/.os_lf_venv 15:41:11 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 15:41:11 lf-activate-venv(): INFO: Attempting to install with network-safe options... 15:41:13 lf-activate-venv(): INFO: Base packages installed successfully 15:41:13 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 15:41:23 lf-activate-venv(): INFO: Adding /tmp/venv-N0Ma/bin to PATH 15:41:23 WARNING: Nexus logging server not set 15:41:23 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/5093/ 15:41:23 INFO: archiving logs to S3 15:41:25 ---> uname -a: 15:41:25 Linux prd-ubuntu2204-docker-4c-16g-1496 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 15:41:25 15:41:25 15:41:25 ---> lscpu: 15:41:25 Architecture: x86_64 15:41:25 CPU op-mode(s): 32-bit, 64-bit 15:41:25 Address sizes: 40 bits physical, 48 bits virtual 15:41:25 Byte Order: Little Endian 15:41:25 CPU(s): 4 15:41:25 On-line CPU(s) list: 0-3 15:41:25 Vendor ID: AuthenticAMD 15:41:25 Model name: AMD EPYC-Rome Processor 15:41:25 CPU family: 23 15:41:25 Model: 49 15:41:25 Thread(s) per core: 1 15:41:25 Core(s) per socket: 1 15:41:25 Socket(s): 4 15:41:25 Stepping: 0 15:41:25 BogoMIPS: 5599.99 15:41:25 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 15:41:25 Virtualization: AMD-V 15:41:25 Hypervisor vendor: KVM 15:41:25 Virtualization type: full 15:41:25 L1d cache: 128 KiB (4 instances) 15:41:25 L1i cache: 128 KiB (4 instances) 15:41:25 L2 cache: 2 MiB (4 instances) 15:41:25 L3 cache: 64 MiB (4 instances) 15:41:25 NUMA node(s): 1 15:41:25 NUMA node0 CPU(s): 0-3 15:41:25 Vulnerability Gather data sampling: Not affected 15:41:25 Vulnerability Indirect target selection: Not affected 15:41:25 Vulnerability Itlb multihit: Not affected 15:41:25 Vulnerability L1tf: Not affected 15:41:25 Vulnerability Mds: Not affected 15:41:25 Vulnerability Meltdown: Not affected 15:41:25 Vulnerability Mmio stale data: Not affected 15:41:25 Vulnerability Reg file data sampling: Not affected 15:41:25 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 15:41:25 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 15:41:25 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 15:41:25 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 15:41:25 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 15:41:25 Vulnerability Srbds: Not affected 15:41:25 Vulnerability Tsa: Not affected 15:41:25 Vulnerability Tsx async abort: Not affected 15:41:25 Vulnerability Vmscape: Not affected 15:41:25 15:41:25 15:41:25 ---> nproc: 15:41:25 4 15:41:25 15:41:25 15:41:25 ---> df -h: 15:41:25 Filesystem Size Used Avail Use% Mounted on 15:41:25 tmpfs 1.6G 1.1M 1.6G 1% /run 15:41:25 /dev/vda1 78G 18G 61G 23% / 15:41:25 tmpfs 7.9G 0 7.9G 0% /dev/shm 15:41:25 tmpfs 5.0M 0 5.0M 0% /run/lock 15:41:25 /dev/vda15 105M 6.1M 99M 6% /boot/efi 15:41:25 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 15:41:25 15:41:25 15:41:25 ---> free -m: 15:41:25 total used free shared buff/cache available 15:41:25 Mem: 15989 698 11822 4 3468 14948 15:41:25 Swap: 1023 19 1004 15:41:25 15:41:25 15:41:25 ---> ip addr: 15:41:25 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 15:41:25 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 15:41:25 inet 127.0.0.1/8 scope host lo 15:41:25 valid_lft forever preferred_lft forever 15:41:25 inet6 ::1/128 scope host 15:41:25 valid_lft forever preferred_lft forever 15:41:25 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 15:41:25 link/ether fa:16:3e:32:b6:9a brd ff:ff:ff:ff:ff:ff 15:41:25 altname enp0s3 15:41:25 inet 10.30.171.55/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 15:41:25 valid_lft 79727sec preferred_lft 79727sec 15:41:25 inet6 fe80::f816:3eff:fe32:b69a/64 scope link 15:41:25 valid_lft forever preferred_lft forever 15:41:25 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 15:41:25 link/ether 2e:f7:32:c1:e8:b3 brd ff:ff:ff:ff:ff:ff 15:41:25 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 15:41:25 valid_lft forever preferred_lft forever 15:41:25 inet6 fe80::2cf7:32ff:fec1:e8b3/64 scope link 15:41:25 valid_lft forever preferred_lft forever 15:41:25 15:41:25 15:41:25 ---> sar -b -r -n DEV: 15:41:25 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1496) 04/09/26 _x86_64_ (4 CPU) 15:41:25 15:41:25 13:50:15 LINUX RESTART (4 CPU) 15:41:25 15:41:25 14:00:16 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 15:41:25 14:10:01 75.69 22.12 50.51 3.06 329.41 5605.40 5570.21 15:41:25 14:20:04 19.44 8.60 10.30 0.55 161.08 403.31 1171.37 15:41:25 14:30:16 12.78 0.22 11.95 0.61 10.00 595.56 767.68 15:41:25 14:40:01 31.48 0.07 14.94 16.47 1.98 375.29 216375.89 15:41:25 14:50:06 5.85 0.02 5.55 0.28 0.78 156.07 115.03 15:41:25 15:00:06 7.53 2.49 4.83 0.20 43.99 133.79 427.73 15:41:25 15:10:01 5.42 0.11 5.13 0.18 2.65 133.93 109.07 15:41:25 15:20:13 5.27 0.08 5.03 0.17 4.95 136.27 55.94 15:41:25 15:30:09 9.40 0.17 8.84 0.39 5.70 557.97 579.32 15:41:25 15:40:01 4.69 0.02 4.49 0.18 0.77 141.76 304.25 15:41:25 Average: 17.57 3.35 12.05 2.17 55.55 812.47 22072.23 15:41:25 15:41:25 14:00:16 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 15:41:25 14:10:01 168632 2896868 13036784 79.62 271072 2491668 14064404 80.73 2020780 13645880 372 15:41:25 14:20:04 4780404 7249008 8689072 53.07 272332 2252332 9499032 54.52 1942348 9145952 676 15:41:25 14:30:16 11114676 13685228 2257724 13.79 277152 2349488 3045480 17.48 1987588 2786100 144 15:41:25 14:40:01 12011424 14628524 1315248 8.03 279660 2393560 2108960 12.11 1998944 1895804 7876 15:41:25 14:50:06 8918344 11548060 4393620 26.83 280612 2405224 5218816 29.96 2000772 4961148 248 15:41:25 15:00:06 7368304 10013988 5926848 36.20 281124 2420680 6716668 38.55 2013996 6489096 216 15:41:25 15:10:01 7287592 9948976 5991732 36.60 281652 2435852 6796236 39.01 2018008 6568296 240 15:41:25 15:20:13 12605404 15321880 621576 3.80 283788 2488784 1362660 7.82 2023564 1249804 35460 15:41:25 15:30:09 8417456 11218276 4723360 28.85 286592 2569980 5319608 30.53 2036376 5423684 116 15:41:25 15:40:01 7575844 10397152 5544032 33.86 287140 2589912 6198476 35.58 2046864 6258388 260 15:41:25 Average: 8024808 10690796 5250000 32.06 280112 2439748 6033034 34.63 2008924 5842415 4561 15:41:25 15:41:25 14:00:16 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 15:41:25 14:10:01 lo 26.68 26.68 18.56 18.56 0.00 0.00 0.00 0.00 15:41:25 14:10:01 ens3 2.70 2.11 0.90 0.72 0.00 0.00 0.00 0.00 15:41:25 14:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 14:20:04 lo 37.25 37.25 14.79 14.79 0.00 0.00 0.00 0.00 15:41:25 14:20:04 ens3 1.21 0.86 0.30 0.23 0.00 0.00 0.00 0.00 15:41:25 14:20:04 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 14:30:16 lo 10.43 10.43 4.67 4.67 0.00 0.00 0.00 0.00 15:41:25 14:30:16 ens3 0.91 0.70 0.22 0.21 0.00 0.00 0.00 0.00 15:41:25 14:30:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 14:40:01 lo 17.46 17.46 8.09 8.09 0.00 0.00 0.00 0.00 15:41:25 14:40:01 ens3 0.81 0.66 0.16 0.13 0.00 0.00 0.00 0.00 15:41:25 14:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 14:50:06 lo 18.40 18.40 9.15 9.15 0.00 0.00 0.00 0.00 15:41:25 14:50:06 ens3 0.71 0.55 0.14 0.11 0.00 0.00 0.00 0.00 15:41:25 14:50:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:00:06 lo 27.21 27.21 11.04 11.04 0.00 0.00 0.00 0.00 15:41:25 15:00:06 ens3 1.31 1.52 0.21 1.54 0.00 0.00 0.00 0.00 15:41:25 15:00:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:10:01 lo 16.11 16.11 8.45 8.45 0.00 0.00 0.00 0.00 15:41:25 15:10:01 ens3 0.57 0.45 0.11 0.25 0.00 0.00 0.00 0.00 15:41:25 15:10:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:20:13 lo 14.89 14.89 8.30 8.30 0.00 0.00 0.00 0.00 15:41:25 15:20:13 ens3 0.63 0.53 0.14 0.11 0.00 0.00 0.00 0.00 15:41:25 15:20:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:30:09 lo 23.31 23.31 10.98 10.98 0.00 0.00 0.00 0.00 15:41:25 15:30:09 ens3 1.45 1.29 9.22 0.23 0.00 0.00 0.00 0.00 15:41:25 15:30:09 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:40:01 lo 20.39 20.39 8.01 8.01 0.00 0.00 0.00 0.00 15:41:25 15:40:01 ens3 0.50 0.32 0.12 0.08 0.00 0.00 0.00 0.00 15:41:25 15:40:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 Average: lo 21.18 21.18 10.18 10.18 0.00 0.00 0.00 0.00 15:41:25 Average: ens3 1.08 0.90 1.15 0.36 0.00 0.00 0.00 0.00 15:41:25 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 15:41:25 15:41:25 15:41:25 ---> sar -P ALL: 15:41:25 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1496) 04/09/26 _x86_64_ (4 CPU) 15:41:25 15:41:25 13:50:15 LINUX RESTART (4 CPU) 15:41:25 15:41:25 14:00:16 CPU %user %nice %system %iowait %steal %idle 15:41:25 14:10:01 all 68.04 0.00 2.79 0.10 0.21 28.86 15:41:25 14:10:01 0 67.60 0.00 2.71 0.05 0.21 29.43 15:41:25 14:10:01 1 67.22 0.00 2.89 0.16 0.22 29.51 15:41:25 14:10:01 2 68.18 0.00 2.97 0.11 0.21 28.52 15:41:25 14:10:01 3 69.16 0.00 2.58 0.06 0.21 27.98 15:41:25 14:20:04 all 26.05 0.00 1.18 0.09 0.14 72.55 15:41:25 14:20:04 0 24.93 0.00 1.14 0.11 0.14 73.68 15:41:25 14:20:04 1 26.27 0.00 1.08 0.06 0.14 72.45 15:41:25 14:20:04 2 26.07 0.00 1.20 0.08 0.14 72.52 15:41:25 14:20:04 3 26.92 0.00 1.29 0.11 0.14 71.54 15:41:25 14:30:16 all 19.40 0.00 0.74 0.04 0.08 79.73 15:41:25 14:30:16 0 19.74 0.00 0.68 0.03 0.08 79.48 15:41:25 14:30:16 1 18.57 0.00 0.71 0.03 0.08 80.61 15:41:25 14:30:16 2 19.33 0.00 0.83 0.03 0.09 79.72 15:41:25 14:30:16 3 19.97 0.00 0.75 0.07 0.07 79.13 15:41:25 14:40:01 all 27.11 0.00 0.98 0.06 0.09 71.76 15:41:25 14:40:01 0 27.55 0.00 1.02 0.06 0.08 71.28 15:41:25 14:40:01 1 26.39 0.00 1.02 0.02 0.08 72.50 15:41:25 14:40:01 2 27.68 0.00 0.96 0.05 0.09 71.21 15:41:25 14:40:01 3 26.83 0.00 0.93 0.10 0.09 72.05 15:41:25 14:50:06 all 12.39 0.00 0.44 0.02 0.07 87.08 15:41:25 14:50:06 0 13.02 0.00 0.45 0.05 0.07 86.41 15:41:25 14:50:06 1 12.27 0.00 0.52 0.01 0.07 87.13 15:41:25 14:50:06 2 12.18 0.00 0.45 0.01 0.07 87.29 15:41:25 14:50:06 3 12.09 0.00 0.35 0.02 0.07 87.47 15:41:25 15:00:06 all 10.68 0.00 0.44 0.03 0.06 88.79 15:41:25 15:00:06 0 10.47 0.00 0.44 0.05 0.06 88.98 15:41:25 15:00:06 1 10.16 0.00 0.48 0.04 0.07 89.26 15:41:25 15:00:06 2 11.11 0.00 0.40 0.02 0.07 88.40 15:41:25 15:00:06 3 10.99 0.00 0.43 0.01 0.06 88.51 15:41:25 15:10:01 all 9.74 0.00 0.41 0.02 0.06 89.76 15:41:25 15:10:01 0 9.75 0.00 0.41 0.02 0.06 89.75 15:41:25 15:10:01 1 9.60 0.00 0.41 0.01 0.06 89.91 15:41:25 15:10:01 2 9.53 0.00 0.39 0.03 0.06 89.99 15:41:25 15:10:01 3 10.10 0.00 0.42 0.02 0.06 89.40 15:41:25 15:20:13 all 7.58 0.00 0.40 0.02 0.07 91.94 15:41:25 15:20:13 0 6.92 0.00 0.42 0.03 0.07 92.56 15:41:25 15:20:13 1 7.95 0.00 0.44 0.01 0.07 91.52 15:41:25 15:20:13 2 7.76 0.00 0.39 0.02 0.07 91.77 15:41:25 15:20:13 3 7.67 0.00 0.34 0.01 0.07 91.91 15:41:25 15:30:09 all 14.40 0.00 0.50 0.04 0.07 84.99 15:41:25 15:30:09 0 14.40 0.00 0.41 0.04 0.07 85.08 15:41:25 15:30:09 1 14.41 0.00 0.59 0.05 0.08 84.88 15:41:25 15:30:09 2 14.11 0.00 0.44 0.02 0.07 85.35 15:41:25 15:30:09 3 14.69 0.00 0.54 0.03 0.08 84.66 15:41:25 15:40:01 all 9.49 0.00 0.41 0.02 0.06 90.02 15:41:25 15:40:01 0 8.89 0.00 0.37 0.04 0.06 90.63 15:41:25 15:40:01 1 9.51 0.00 0.39 0.01 0.07 90.02 15:41:25 15:40:01 2 10.12 0.00 0.44 0.03 0.06 89.35 15:41:25 15:40:01 3 9.45 0.00 0.42 0.00 0.06 90.07 15:41:25 Average: all 20.35 0.00 0.82 0.04 0.09 78.69 15:41:25 Average: 0 20.21 0.00 0.80 0.05 0.09 78.86 15:41:25 Average: 1 20.09 0.00 0.85 0.04 0.09 78.93 15:41:25 Average: 2 20.46 0.00 0.84 0.04 0.09 78.57 15:41:25 Average: 3 20.66 0.00 0.80 0.04 0.09 78.41 15:41:25 15:41:25 15:41:25