14:56:22 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/122294 14:56:22 Running as SYSTEM 14:56:22 [EnvInject] - Loading node environment variables. 14:56:22 Building remotely on prd-ubuntu2204-docker-4c-16g-3048 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 14:56:24 [ssh-agent] Looking for ssh-agent implementation... 14:56:24 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 14:56:24 $ ssh-agent 14:56:24 SSH_AUTH_SOCK=/tmp/ssh-XXXXXX50THaE/agent.1567 14:56:24 SSH_AGENT_PID=1569 14:56:24 [ssh-agent] Started. 14:56:24 Running ssh-add (command line suppressed) 14:56:24 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_5503095659405861369.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_5503095659405861369.key) 14:56:24 [ssh-agent] Using credentials jenkins (jenkins-ssh) 14:56:24 The recommended git tool is: NONE 14:56:29 using credential jenkins-ssh 14:56:29 Wiping out workspace first. 14:56:29 Cloning the remote Git repository 14:56:29 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 14:56:29 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 14:56:29 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 14:56:29 > git --version # timeout=10 14:56:29 > git --version # 'git version 2.34.1' 14:56:29 using GIT_SSH to set credentials jenkins-ssh 14:56:29 Verifying host key using known hosts file, will automatically accept unseen keys 14:56:29 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 14:56:35 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 14:56:35 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 14:56:36 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 14:56:36 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 14:56:36 using GIT_SSH to set credentials jenkins-ssh 14:56:36 Verifying host key using known hosts file, will automatically accept unseen keys 14:56:36 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/94/122294/4 # timeout=10 14:56:36 > git rev-parse 52f1cff09dd53bcb67d78570af08bfdd4c24962d^{commit} # timeout=10 14:56:36 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 14:56:36 Checking out Revision 52f1cff09dd53bcb67d78570af08bfdd4c24962d (refs/changes/94/122294/4) 14:56:36 > git config core.sparsecheckout # timeout=10 14:56:36 > git checkout -f 52f1cff09dd53bcb67d78570af08bfdd4c24962d # timeout=10 14:56:37 Commit message: "Use openroadm-topology in OR link listener" 14:56:37 > git rev-parse FETCH_HEAD^{commit} # timeout=10 14:56:37 > git rev-list --no-walk d3871541b0c147f4260db2b664d1662553c5c7a0 # timeout=10 14:56:37 > git remote # timeout=10 14:56:37 > git submodule init # timeout=10 14:56:37 > git submodule sync # timeout=10 14:56:37 > git config --get remote.origin.url # timeout=10 14:56:37 > git submodule init # timeout=10 14:56:37 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 14:56:37 ERROR: No submodules found. 14:56:40 provisioning config files... 14:56:40 copy managed file [npmrc] to file:/home/jenkins/.npmrc 14:56:40 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 14:56:40 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10863580082590928111.sh 14:56:40 ---> python-tools-install.sh 14:56:40 Setup pyenv: 14:56:40 * system (set by /opt/pyenv/version) 14:56:40 * 3.8.20 (set by /opt/pyenv/version) 14:56:40 * 3.9.20 (set by /opt/pyenv/version) 14:56:40 3.10.15 14:56:40 3.11.10 14:56:45 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-PzJx 14:56:45 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 14:56:45 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 14:56:45 lf-activate-venv(): INFO: Attempting to install with network-safe options... 14:56:49 lf-activate-venv(): INFO: Base packages installed successfully 14:56:49 lf-activate-venv(): INFO: Installing additional packages: lftools 14:57:15 lf-activate-venv(): INFO: Adding /tmp/venv-PzJx/bin to PATH 14:57:15 Generating Requirements File 14:57:33 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. 14:57:33 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 14:57:33 Python 3.11.10 14:57:33 pip 26.0.1 from /tmp/venv-PzJx/lib/python3.11/site-packages/pip (python 3.11) 14:57:33 appdirs==1.4.4 14:57:33 argcomplete==3.6.3 14:57:33 aspy.yaml==1.3.0 14:57:33 attrs==26.1.0 14:57:33 autopage==0.6.0 14:57:33 beautifulsoup4==4.14.3 14:57:33 boto3==1.42.89 14:57:33 botocore==1.42.89 14:57:33 bs4==0.0.2 14:57:33 certifi==2026.2.25 14:57:33 cffi==2.0.0 14:57:33 cfgv==3.5.0 14:57:33 chardet==7.4.3 14:57:33 charset-normalizer==3.4.7 14:57:33 click==8.3.2 14:57:33 cliff==4.13.3 14:57:33 cmd2==3.5.0 14:57:33 cryptography==3.3.2 14:57:33 debtcollector==3.1.0 14:57:33 decorator==5.2.1 14:57:33 defusedxml==0.7.1 14:57:33 Deprecated==1.3.1 14:57:33 distlib==0.4.0 14:57:33 dnspython==2.8.0 14:57:33 docker==7.1.0 14:57:33 dogpile.cache==1.5.0 14:57:33 durationpy==0.10 14:57:33 email-validator==2.3.0 14:57:33 filelock==3.28.0 14:57:33 future==1.0.0 14:57:33 gitdb==4.0.12 14:57:33 GitPython==3.1.46 14:57:33 httplib2==0.30.2 14:57:33 identify==2.6.18 14:57:33 idna==3.11 14:57:33 importlib-resources==1.5.0 14:57:33 iso8601==2.1.0 14:57:33 Jinja2==3.1.6 14:57:33 jmespath==1.1.0 14:57:33 jsonpatch==1.33 14:57:33 jsonpointer==3.1.1 14:57:33 jsonschema==4.26.0 14:57:33 jsonschema-specifications==2025.9.1 14:57:33 keystoneauth1==5.13.1 14:57:33 kubernetes==35.0.0 14:57:33 lftools==0.37.22 14:57:33 lxml==6.0.4 14:57:33 markdown-it-py==4.0.0 14:57:33 MarkupSafe==3.0.3 14:57:33 mdurl==0.1.2 14:57:33 msgpack==1.1.2 14:57:33 multi_key_dict==2.0.3 14:57:33 munch==4.0.0 14:57:33 netaddr==1.3.0 14:57:33 niet==1.4.2 14:57:33 nodeenv==1.10.0 14:57:33 oauth2client==4.1.3 14:57:33 oauthlib==3.3.1 14:57:33 openstacksdk==4.11.0 14:57:33 os-service-types==1.8.2 14:57:33 osc-lib==4.5.0 14:57:33 oslo.config==10.3.0 14:57:33 oslo.context==6.3.0 14:57:33 oslo.i18n==6.7.2 14:57:33 oslo.log==8.1.0 14:57:33 oslo.serialization==5.9.1 14:57:33 oslo.utils==10.0.1 14:57:33 packaging==26.1 14:57:33 pbr==7.0.3 14:57:33 platformdirs==4.9.6 14:57:33 prettytable==3.17.0 14:57:33 psutil==7.2.2 14:57:33 pyasn1==0.6.3 14:57:33 pyasn1_modules==0.4.2 14:57:33 pycparser==3.0 14:57:33 pygerrit2==2.0.15 14:57:33 PyGithub==2.9.1 14:57:33 Pygments==2.20.0 14:57:33 PyJWT==2.12.1 14:57:33 PyNaCl==1.6.2 14:57:33 pyparsing==2.4.7 14:57:33 pyperclip==1.11.0 14:57:33 pyrsistent==0.20.0 14:57:33 python-cinderclient==9.9.0 14:57:33 python-dateutil==2.9.0.post0 14:57:33 python-discovery==1.2.2 14:57:33 python-heatclient==5.1.0 14:57:33 python-jenkins==1.8.3 14:57:33 python-keystoneclient==5.8.0 14:57:33 python-magnumclient==4.10.0 14:57:33 python-openstackclient==9.0.0 14:57:33 python-swiftclient==4.10.0 14:57:33 PyYAML==6.0.3 14:57:33 referencing==0.37.0 14:57:33 requests==2.33.1 14:57:33 requests-oauthlib==2.0.0 14:57:33 rfc3986==2.0.0 14:57:33 rich==15.0.0 14:57:33 rich-argparse==1.7.2 14:57:33 rpds-py==0.30.0 14:57:33 rsa==4.9.1 14:57:33 ruamel.yaml==0.19.1 14:57:33 ruamel.yaml.clib==0.2.15 14:57:33 s3transfer==0.16.0 14:57:33 simplejson==3.20.2 14:57:33 six==1.17.0 14:57:33 smmap==5.0.3 14:57:33 soupsieve==2.8.3 14:57:33 stevedore==5.7.0 14:57:33 tabulate==0.10.0 14:57:33 toml==0.10.2 14:57:33 tomlkit==0.14.0 14:57:33 tqdm==4.67.3 14:57:33 typing_extensions==4.15.0 14:57:33 urllib3==1.26.20 14:57:33 virtualenv==21.2.4 14:57:33 wcwidth==0.6.0 14:57:33 websocket-client==1.9.0 14:57:33 wrapt==2.1.2 14:57:33 xdg==6.0.0 14:57:33 xmltodict==1.0.4 14:57:33 yq==3.4.3 14:57:33 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins419251252327406769.sh 14:57:33 ---> uv-install.sh 14:57:33 Installing uv/uvx (latest) using shell installer 14:57:34 2026-04-15 14:57:34 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-15T15%3A36%3A27Z&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-15T14%3A36%3A09Z&ske=2026-04-15T15%3A36%3A27Z&sks=b&skv=2018-11-09&sig=MEV6U5RM4LOTmBVaRUXkjLFXwQE7HHYnZsfDgazzhNg%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NjI2NTI0NiwibmJmIjoxNzc2MjY0OTQ2LCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.zRN-akUJq86I23H9Bc05ATzyuindWFi17_0kCjXq4EE&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [71225/71225] -> "/tmp/uv-install-cOeNoh.sh" [1] 14:57:34 downloading uv 0.11.6 x86_64-unknown-linux-gnu 14:57:35 installing to /home/jenkins/.local/bin 14:57:35 uv 14:57:35 uvx 14:57:35 everything's installed! 14:57:35 14:57:35 To add $HOME/.local/bin to your PATH, either restart your shell or run: 14:57:35 14:57:35 source $HOME/.local/bin/env (sh, bash, zsh) 14:57:35 source $HOME/.local/bin/env.fish (fish) 14:57:35 Adding install location to PATH 14:57:35 ---> Validating uv/uvx install 14:57:35 uvx 0.11.6 (x86_64-unknown-linux-gnu) 14:57:35 [EnvInject] - Injecting environment variables from a build step. 14:57:35 [EnvInject] - Injecting as environment variables the properties content 14:57:35 PYTHON=python3 14:57:35 14:57:35 [EnvInject] - Variables injected successfully. 14:57:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins2492861418120071340.sh 14:57:35 ---> tox-install.sh 14:57:35 + source /home/jenkins/lf-env.sh 14:57:35 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 14:57:35 ++ mktemp -d /tmp/venv-XXXX 14:57:35 + lf_venv=/tmp/venv-Qnx8 14:57:35 + local venv_file=/tmp/.os_lf_venv 14:57:35 + local python=python3 14:57:35 + local options 14:57:35 + local set_path=true 14:57:35 + local install_args= 14:57:35 ++ 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 14:57:35 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 14:57:35 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 14:57:35 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 14:57:35 + true 14:57:35 + case $1 in 14:57:35 + venv_file=/tmp/.toxenv 14:57:35 + shift 2 14:57:35 + true 14:57:35 + case $1 in 14:57:35 + shift 14:57:35 + break 14:57:35 + case $python in 14:57:35 + local pkg_list= 14:57:35 + [[ -d /opt/pyenv ]] 14:57:35 + echo 'Setup pyenv:' 14:57:35 Setup pyenv: 14:57:35 + export PYENV_ROOT=/opt/pyenv 14:57:35 + PYENV_ROOT=/opt/pyenv 14:57:35 + 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 14:57:35 + 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 14:57:35 + pyenv versions 14:57:35 system 14:57:35 3.8.20 14:57:35 3.9.20 14:57:35 3.10.15 14:57:35 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 14:57:35 + command -v pyenv 14:57:35 ++ pyenv init - --no-rehash 14:57:35 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 14:57:35 for i in ${!paths[@]}; do 14:57:35 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 14:57:35 fi; done; 14:57:35 echo "${paths[*]}"'\'')" 14:57:35 export PATH="/opt/pyenv/shims:${PATH}" 14:57:35 export PYENV_SHELL=bash 14:57:35 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 14:57:35 pyenv() { 14:57:35 local command 14:57:35 command="${1:-}" 14:57:35 if [ "$#" -gt 0 ]; then 14:57:35 shift 14:57:35 fi 14:57:35 14:57:35 case "$command" in 14:57:35 rehash|shell) 14:57:35 eval "$(pyenv "sh-$command" "$@")" 14:57:35 ;; 14:57:35 *) 14:57:35 command pyenv "$command" "$@" 14:57:35 ;; 14:57:35 esac 14:57:35 }' 14:57:35 +++ bash --norc -ec 'IFS=:; paths=($PATH); 14:57:35 for i in ${!paths[@]}; do 14:57:35 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 14:57:35 fi; done; 14:57:35 echo "${paths[*]}"' 14:57:35 ++ 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 14:57:35 ++ 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 14:57:35 ++ 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 14:57:35 ++ export PYENV_SHELL=bash 14:57:35 ++ PYENV_SHELL=bash 14:57:35 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 14:57:35 +++ complete -F _pyenv pyenv 14:57:35 ++ lf-pyver python3 14:57:35 ++ local py_version_xy=python3 14:57:35 ++ local py_version_xyz= 14:57:35 ++ pyenv versions 14:57:35 ++ local command 14:57:35 ++ sed 's/^[ *]* //' 14:57:35 ++ command=versions 14:57:35 ++ '[' 1 -gt 0 ']' 14:57:35 ++ shift 14:57:35 ++ awk '{ print $1 }' 14:57:35 ++ case "$command" in 14:57:35 ++ grep -E '^[0-9.]*[0-9]$' 14:57:35 ++ command pyenv versions 14:57:35 ++ [[ ! -s /tmp/.pyenv_versions ]] 14:57:35 +++ grep '^3' /tmp/.pyenv_versions 14:57:35 +++ sort -V 14:57:35 +++ tail -n 1 14:57:35 ++ py_version_xyz=3.11.10 14:57:35 ++ [[ -z 3.11.10 ]] 14:57:35 ++ echo 3.11.10 14:57:35 ++ return 0 14:57:35 + pyenv local 3.11.10 14:57:35 + local command 14:57:35 + command=local 14:57:35 + '[' 2 -gt 0 ']' 14:57:35 + shift 14:57:35 + case "$command" in 14:57:35 + command pyenv local 3.11.10 14:57:35 + for arg in "$@" 14:57:35 + case $arg in 14:57:35 + pkg_list+='tox ' 14:57:35 + for arg in "$@" 14:57:35 + case $arg in 14:57:35 + pkg_list+='virtualenv ' 14:57:35 + for arg in "$@" 14:57:35 + case $arg in 14:57:35 + pkg_list+='urllib3~=1.26.15 ' 14:57:35 + [[ -f /tmp/.toxenv ]] 14:57:35 + [[ ! -f /tmp/.toxenv ]] 14:57:35 + [[ -n '' ]] 14:57:35 + python3 -m venv /tmp/venv-Qnx8 14:57:39 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-Qnx8' 14:57:39 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-Qnx8 14:57:39 + echo /tmp/venv-Qnx8 14:57:39 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 14:57:39 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 14:57:39 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 14:57:39 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 14:57:39 + local 'pip_opts=--upgrade --quiet' 14:57:39 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 14:57:39 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 14:57:39 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 14:57:39 + [[ -n '' ]] 14:57:39 + [[ -n '' ]] 14:57:39 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 14:57:39 lf-activate-venv(): INFO: Attempting to install with network-safe options... 14:57:39 + /tmp/venv-Qnx8/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 14:57:43 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 14:57:43 lf-activate-venv(): INFO: Base packages installed successfully 14:57:43 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 14:57:43 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 14:57:43 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 14:57:43 + /tmp/venv-Qnx8/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 14:57:45 + type python3 14:57:45 + true 14:57:45 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-Qnx8/bin to PATH' 14:57:45 lf-activate-venv(): INFO: Adding /tmp/venv-Qnx8/bin to PATH 14:57:45 + PATH=/tmp/venv-Qnx8/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 14:57:45 + return 0 14:57:45 + python3 --version 14:57:45 Python 3.11.10 14:57:45 + python3 -m pip --version 14:57:45 pip 26.0.1 from /tmp/venv-Qnx8/lib/python3.11/site-packages/pip (python 3.11) 14:57:45 + python3 -m pip freeze 14:57:45 cachetools==7.0.5 14:57:45 colorama==0.4.6 14:57:45 distlib==0.4.0 14:57:45 filelock==3.28.0 14:57:45 packaging==26.1 14:57:45 platformdirs==4.9.6 14:57:45 pluggy==1.6.0 14:57:45 pyproject-api==1.10.0 14:57:45 python-discovery==1.2.2 14:57:45 tomli_w==1.2.0 14:57:45 tox==4.53.0 14:57:45 urllib3==1.26.20 14:57:45 virtualenv==21.2.4 14:57:45 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins877884016752201054.sh 14:57:45 [EnvInject] - Injecting environment variables from a build step. 14:57:45 [EnvInject] - Injecting as environment variables the properties content 14:57:45 PARALLEL=True 14:57:45 14:57:45 [EnvInject] - Variables injected successfully. 14:57:45 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins4596489649025141006.sh 14:57:45 ---> tox-run.sh 14:57:45 + 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 14:57:45 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 14:57:45 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 14:57:45 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 14:57:45 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 14:57:45 + source /home/jenkins/lf-env.sh 14:57:45 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 14:57:45 ++ mktemp -d /tmp/venv-XXXX 14:57:45 + lf_venv=/tmp/venv-ph8X 14:57:45 + local venv_file=/tmp/.os_lf_venv 14:57:45 + local python=python3 14:57:45 + local options 14:57:45 + local set_path=true 14:57:45 + local install_args= 14:57:45 ++ 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 14:57:45 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 14:57:45 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 14:57:45 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 14:57:45 + true 14:57:45 + case $1 in 14:57:45 + venv_file=/tmp/.toxenv 14:57:45 + shift 2 14:57:45 + true 14:57:45 + case $1 in 14:57:45 + shift 14:57:45 + break 14:57:45 + case $python in 14:57:45 + local pkg_list= 14:57:45 + [[ -d /opt/pyenv ]] 14:57:45 + echo 'Setup pyenv:' 14:57:45 Setup pyenv: 14:57:45 + export PYENV_ROOT=/opt/pyenv 14:57:45 + PYENV_ROOT=/opt/pyenv 14:57:45 + 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 14:57:45 + 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 14:57:45 + pyenv versions 14:57:45 system 14:57:45 3.8.20 14:57:45 3.9.20 14:57:45 3.10.15 14:57:45 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 14:57:45 + command -v pyenv 14:57:45 ++ pyenv init - --no-rehash 14:57:45 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 14:57:45 for i in ${!paths[@]}; do 14:57:45 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 14:57:45 fi; done; 14:57:45 echo "${paths[*]}"'\'')" 14:57:45 export PATH="/opt/pyenv/shims:${PATH}" 14:57:45 export PYENV_SHELL=bash 14:57:45 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 14:57:45 pyenv() { 14:57:45 local command 14:57:45 command="${1:-}" 14:57:45 if [ "$#" -gt 0 ]; then 14:57:45 shift 14:57:45 fi 14:57:45 14:57:45 case "$command" in 14:57:45 rehash|shell) 14:57:45 eval "$(pyenv "sh-$command" "$@")" 14:57:45 ;; 14:57:45 *) 14:57:45 command pyenv "$command" "$@" 14:57:45 ;; 14:57:45 esac 14:57:45 }' 14:57:45 +++ bash --norc -ec 'IFS=:; paths=($PATH); 14:57:45 for i in ${!paths[@]}; do 14:57:45 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 14:57:45 fi; done; 14:57:45 echo "${paths[*]}"' 14:57:45 ++ 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 14:57:45 ++ 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 14:57:45 ++ 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 14:57:45 ++ export PYENV_SHELL=bash 14:57:45 ++ PYENV_SHELL=bash 14:57:45 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 14:57:45 +++ complete -F _pyenv pyenv 14:57:45 ++ lf-pyver python3 14:57:45 ++ local py_version_xy=python3 14:57:45 ++ local py_version_xyz= 14:57:45 ++ pyenv versions 14:57:45 ++ local command 14:57:45 ++ command=versions 14:57:45 ++ '[' 1 -gt 0 ']' 14:57:45 ++ shift 14:57:45 ++ case "$command" in 14:57:45 ++ command pyenv versions 14:57:45 ++ sed 's/^[ *]* //' 14:57:45 ++ awk '{ print $1 }' 14:57:45 ++ grep -E '^[0-9.]*[0-9]$' 14:57:45 ++ [[ ! -s /tmp/.pyenv_versions ]] 14:57:45 +++ grep '^3' /tmp/.pyenv_versions 14:57:45 +++ sort -V 14:57:45 +++ tail -n 1 14:57:45 ++ py_version_xyz=3.11.10 14:57:45 ++ [[ -z 3.11.10 ]] 14:57:45 ++ echo 3.11.10 14:57:45 ++ return 0 14:57:45 + pyenv local 3.11.10 14:57:45 + local command 14:57:45 + command=local 14:57:45 + '[' 2 -gt 0 ']' 14:57:45 + shift 14:57:45 + case "$command" in 14:57:45 + command pyenv local 3.11.10 14:57:46 + for arg in "$@" 14:57:46 + case $arg in 14:57:46 + pkg_list+='tox ' 14:57:46 + for arg in "$@" 14:57:46 + case $arg in 14:57:46 + pkg_list+='virtualenv ' 14:57:46 + for arg in "$@" 14:57:46 + case $arg in 14:57:46 + pkg_list+='urllib3~=1.26.15 ' 14:57:46 + [[ -f /tmp/.toxenv ]] 14:57:46 ++ cat /tmp/.toxenv 14:57:46 + lf_venv=/tmp/venv-Qnx8 14:57:46 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-Qnx8 from' file:/tmp/.toxenv 14:57:46 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-Qnx8 from file:/tmp/.toxenv 14:57:46 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 14:57:46 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 14:57:46 + local 'pip_opts=--upgrade --quiet' 14:57:46 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 14:57:46 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 14:57:46 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 14:57:46 + [[ -n '' ]] 14:57:46 + [[ -n '' ]] 14:57:46 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 14:57:46 lf-activate-venv(): INFO: Attempting to install with network-safe options... 14:57:46 + /tmp/venv-Qnx8/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 14:57:49 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 14:57:49 lf-activate-venv(): INFO: Base packages installed successfully 14:57:49 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 14:57:49 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 14:57:49 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 14:57:49 + /tmp/venv-Qnx8/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 14:57:50 + type python3 14:57:50 + true 14:57:50 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-Qnx8/bin to PATH' 14:57:50 lf-activate-venv(): INFO: Adding /tmp/venv-Qnx8/bin to PATH 14:57:50 + PATH=/tmp/venv-Qnx8/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 14:57:50 + return 0 14:57:50 + [[ -d /opt/pyenv ]] 14:57:50 + echo '---> Setting up pyenv' 14:57:50 ---> Setting up pyenv 14:57:50 + export PYENV_ROOT=/opt/pyenv 14:57:50 + PYENV_ROOT=/opt/pyenv 14:57:50 + export PATH=/opt/pyenv/bin:/tmp/venv-Qnx8/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 14:57:50 + PATH=/opt/pyenv/bin:/tmp/venv-Qnx8/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 14:57:50 ++ pwd 14:57:50 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 14:57:50 + export PYTHONPATH 14:57:50 + export TOX_TESTENV_PASSENV=PYTHONPATH 14:57:50 + TOX_TESTENV_PASSENV=PYTHONPATH 14:57:50 + tox --version 14:57:50 4.53.0 from /tmp/venv-Qnx8/lib/python3.11/site-packages/tox/__init__.py 14:57:50 + PARALLEL=True 14:57:50 + TOX_OPTIONS_LIST= 14:57:50 + [[ -n '' ]] 14:57:50 + case ${PARALLEL,,} in 14:57:50 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 14:57:50 + tox --parallel auto --parallel-live 14:57:50 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 14:57:52 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 14:57:52 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 14:57:52 checkbashisms: freeze> python -m pip freeze --all 14:57:52 docs: install_deps> python -I -m pip install -r docs/requirements.txt 14:57:53 checkbashisms: pip==26.0.1,setuptools==82.0.1 14:57:53 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 14:57:53 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)' 14:57:53 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 14:57:54 checkbashisms: OK ✔ in 3.36 seconds 14:57:54 pre-commit: install_deps> python -I -m pip install pre-commit 14:57:56 pre-commit: freeze> python -m pip freeze --all 14:57:57 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.28.0,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.1,virtualenv==21.2.4 14:57:57 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 14:57:57 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)' 14:57:57 /usr/bin/cpan 14:57:57 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 14:57:57 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 14:57:57 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 14:57:58 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 14:57:58 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 14:57:58 [INFO] Initializing environment for https://github.com/hhatto/autopep8. 14:57:59 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 14:57:59 buildcontroller: freeze> python -m pip freeze --all 14:57:59 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.4,netconf-client==3.5.0,packaging==26.1,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 14:57:59 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 14:57:59 + update-java-alternatives -l 14:57:59 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 14:57:59 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 14:57:59 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 14:57:59 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 14:57:59 update-alternatives: error: no alternatives for jaotc 14:57:59 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 14:57:59 update-alternatives: error: no alternatives for rmic 14:57:59 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 14:57:59 + java -version 14:58:00 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 14:58:00 + JAVA_VER=21 14:58:00 + echo 21 14:58:00 21 14:58:00 + javac -version 14:58:00 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 14:58:00 + JAVAC_VER=21 14:58:00 + echo 21 14:58:00 + [ 21 -ge 21 ] 14:58:00 + [ 21 -ge 21 ] 14:58:00 + echo ok, java is 21 or newer 14:58:00 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 14:58:00 21 14:58:00 ok, java is 21 or newer 14:58:00 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 14:58:00 2026-04-15 14:58:00 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] 14:58:00 + sudo mkdir -p /opt 14:58:00 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 14:58:00 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 14:58:00 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 14:58:00 + mvn --version 14:58:00 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 14:58:00 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 14:58:00 Maven home: /opt/maven 14:58:00 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 14:58:00 Default locale: en, platform encoding: UTF-8 14:58:00 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 14:58:00 NOTE: Picked up JDK_JAVA_OPTIONS: 14:58:00 --add-opens=java.base/java.io=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.lang=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.net=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.nio=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.nio.file=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.util=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.util.jar=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.util.stream=ALL-UNNAMED 14:58:00 --add-opens=java.base/java.util.zip=ALL-UNNAMED 14:58:00 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 14:58:00 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 14:58:00 -Xlog:disable 14:58:01 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 14:58:01 [INFO] Once installed this environment will be reused. 14:58:01 [INFO] This may take a few minutes... 14:58:06 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 14:58:06 [INFO] Once installed this environment will be reused. 14:58:06 [INFO] This may take a few minutes... 14:58:12 [INFO] Installing environment for https://github.com/hhatto/autopep8. 14:58:12 [INFO] Once installed this environment will be reused. 14:58:12 [INFO] This may take a few minutes... 14:58:16 docs: freeze> python -m pip freeze --all 14:58:17 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.1,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.1,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 14:58:17 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 14:58:17 docs-linkcheck: freeze> python -m pip freeze --all 14:58:17 [INFO] Installing environment for https://github.com/perltidy/perltidy. 14:58:17 [INFO] Once installed this environment will be reused. 14:58:17 [INFO] This may take a few minutes... 14:58:17 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.1,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.1,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 14:58:17 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 14:58:20 docs: OK ✔ in 29.15 seconds 14:58:20 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 14:58:23 docs-linkcheck: OK ✔ in 31.24 seconds 14:58:23 pylint: freeze> python -m pip freeze --all 14:58:24 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.1,tomlkit==0.14.0 14:58:24 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}$' '{}' + 14:58:28 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 14:58:28 [INFO] Once installed this environment will be reused. 14:58:28 [INFO] This may take a few minutes... 14:58:32 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 14:58:32 [INFO] Once installed this environment will be reused. 14:58:32 [INFO] This may take a few minutes... 14:58:37 trim trailing whitespace.................................................Passed 14:58:38 fix end of files.........................................................Passed 14:58:38 check for added large files..............................................Passed 14:58:38 check for merge conflicts................................................Passed 14:58:38 check for case conflicts.................................................Passed 14:58:38 check json...............................................................Passed 14:58:39 mixed line ending........................................................Passed 14:58:39 Tabs remover.............................................................Passed 14:58:39 autopep8.................................................................Passed 14:58:43 perltidy.................................................................Passed 14:58:43 ShellCheck v0.11.0.......................................................Passed 14:58:49 prettier.................................................................Passed 14:58:51 14:58:51 ------------------------------------ 14:58:51 Your code has been rated at 10.00/10 14:58:51 14:58:51 yamllint.................................................................Passed 14:58:52 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 14:58:52 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 14:58:52 [INFO] Once installed this environment will be reused. 14:58:52 [INFO] This may take a few minutes... 14:59:01 gitlint..................................................................Passed 14:59:48 pylint: OK ✔ in 33.96 seconds 14:59:48 pre-commit: OK ✔ in 1 minute 6.76 seconds 14:59:48 buildcontroller: OK ✔ in 1 minute 56.02 seconds 14:59:48 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 14:59:48 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 14:59:48 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 14:59:48 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 14:59:54 build_karaf_tests121: freeze> python -m pip freeze --all 14:59:55 build_karaf_tests71: freeze> python -m pip freeze --all 14:59:55 build_karaf_tests221: freeze> python -m pip freeze --all 14:59:55 build_karaf_tests190: freeze> python -m pip freeze --all 14:59:55 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.4,netconf-client==3.5.0,packaging==26.1,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 14:59:55 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 14:59:55 build karaf in karaf121 with ./karaf121.env 14:59:55 NOTE: Picked up JDK_JAVA_OPTIONS: 14:59:55 --add-opens=java.base/java.io=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.net=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.file=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.jar=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.stream=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.zip=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 14:59:55 -Xlog:disable 14:59:55 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.4,netconf-client==3.5.0,packaging==26.1,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 14:59:55 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 14:59:55 build karaf in karaf71 with ./karaf71.env 14:59:55 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.4,netconf-client==3.5.0,packaging==26.1,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 14:59:55 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 14:59:55 build karaf in karaf221 with ./karaf221.env 14:59:55 NOTE: Picked up JDK_JAVA_OPTIONS: 14:59:55 --add-opens=java.base/java.io=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.net=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.file=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.jar=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.stream=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.zip=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 14:59:55 -Xlog:disable 14:59:55 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.4,netconf-client==3.5.0,packaging==26.1,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 14:59:55 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 14:59:55 build karaf in karafoc with ./karafoc.env 14:59:55 NOTE: Picked up JDK_JAVA_OPTIONS: 14:59:55 --add-opens=java.base/java.io=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.net=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.file=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.jar=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.stream=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.zip=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 14:59:55 -Xlog:disable 14:59:55 NOTE: Picked up JDK_JAVA_OPTIONS: 14:59:55 --add-opens=java.base/java.io=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.net=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.nio.file=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.jar=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.stream=ALL-UNNAMED 14:59:55 --add-opens=java.base/java.util.zip=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 14:59:55 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 14:59:55 -Xlog:disable 15:01:01 build_karaf_tests121: OK ✔ in 1 minute 14.21 seconds 15:01:01 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 15:01:07 build_karaf_tests71: OK ✔ in 1 minute 20.07 seconds 15:01:07 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 15:01:12 build_karaf_tests221: OK ✔ in 1 minute 23.91 seconds 15:01:12 build_karaf_tests190: OK ✔ in 1 minute 24.66 seconds 15:01:12 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 15:01:19 sims: freeze> python -m pip freeze --all 15:01:19 buildlighty: freeze> python -m pip freeze --all 15:01:19 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.4,netconf-client==3.5.0,packaging==26.1,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:01:19 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 15:01:19 Using lighynode version 22.1.0.6 15:01:19 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 15:01:19 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.4,netconf-client==3.5.0,packaging==26.1,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:01:19 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 15:01:19 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 15:02:01 sims: OK ✔ in 16.88 seconds 15:02:01 buildlighty: OK ✔ in 39.22 seconds 15:02:01 testsPCE: freeze> python -m pip freeze --all 15:02:02 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.4,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.1,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 15:02:02 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 15:02:02 pytest -q transportpce_tests/pce/test01_pce.py 15:02:48 .................... [100%] 15:03:52 20 passed in 109.98s (0:01:49) 15:03:52 pytest -q transportpce_tests/pce/test02_pce_400G.py 15:04:09 ............ [100%] 15:04:40 12 passed in 47.38s 15:04:40 pytest -q transportpce_tests/pce/test03_gnpy.py 15:04:57 ........ [100%] 15:05:18 8 passed in 37.85s 15:05:18 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 15:05:50 ... [100%] 15:05:55 3 passed in 36.51s 15:05:55 testsPCE: OK ✔ in 4 minutes 43.52 seconds 15:05:55 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 15:05:56 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 15:05:56 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 15:06:02 tests190: freeze> python -m pip freeze --all 15:06:02 tests121: freeze> python -m pip freeze --all 15:06:02 tests_tapi: freeze> python -m pip freeze --all 15:06:02 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.4,netconf-client==3.5.0,packaging==26.1,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:06:02 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 15:06:02 using environment variables from ./karafoc.env 15:06:02 pytest -q transportpce_tests/oc/test01_portmapping.py 15:06:02 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.4,netconf-client==3.5.0,packaging==26.1,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:06:02 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 15:06:02 using environment variables from ./karaf121.env 15:06:02 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 15:06:02 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.4,netconf-client==3.5.0,packaging==26.1,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:06:02 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 15:06:02 using environment variables from ./karaf221.env 15:06:02 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 15:07:06 ........... [100%] 15:07:22 10 passed in 80.06s (0:01:20) 15:07:22 pytest -q transportpce_tests/oc/test02_topology.py 15:07:28 ................................ [100%] 15:08:09 21 passed in 126.52s (0:02:06) 15:08:09 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 15:08:09 ........................... [100%] 15:08:29 14 passed in 66.39s (0:01:06) 15:08:29 pytest -q transportpce_tests/oc/test03_renderer.py 15:08:31 .................. [100%] 15:09:10 6 passed in 61.04s (0:01:01) 15:09:10 pytest -q transportpce_tests/1.2.1/test03_topology.py 15:09:11 ................... [100%] 15:09:29 19 passed in 59.06s 15:09:29 tests190: OK ✔ in 3 minutes 34.01 seconds 15:09:29 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 15:09:36 tests71: freeze> python -m pip freeze --all 15:09:36 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.4,netconf-client==3.5.0,packaging==26.1,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:09:36 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 15:09:36 using environment variables from ./karaf71.env 15:09:36 pytest -q transportpce_tests/7.1/test01_portmapping.py 15:09:37 .................................. [100%] 15:10:33 12 passed in 56.62s 15:10:33 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 15:10:37 ..................................................... [100%] 15:11:45 44 passed in 154.50s (0:02:34) 15:11:45 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 15:11:46 .................................................................... [100%] 15:13:10 24 passed in 84.99s (0:01:24) 15:13:11 pytest -q transportpce_tests/1.2.1/test05_olm.py 15:13:12 [100%] 15:13:12 62 passed in 158.67s (0:02:38) 15:13:13 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 15:14:01 ............ [100%] 15:14:18 51 passed in 495.94s (0:08:15) 15:14:18 pytest -q transportpce_tests/tapi/test02_full_topology.py 15:14:19 ........................................................................ [100%] 15:15:47 48 passed in 153.80s (0:02:33) 15:15:47 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 15:15:47 .........F................... [100%] 15:16:33 40 passed in 202.12s (0:03:22) 15:16:33 pytest -q transportpce_tests/1.2.1/test06_end2end.py 15:16:35 ................. [100%] 15:17:05 22 passed in 77.57s (0:01:17) 15:17:11 ..........................................................F. [100%] 15:20:28 =================================== FAILURES =================================== 15:20:28 ________ TestTransportPCEFullTopology.test_13_get_tapi_topology_details ________ 15:20:28 15:20:28 self = 15:20:28 15:20:28 def test_13_get_tapi_topology_details(self): 15:20:28 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 15:20:28 response = test_utils.transportpce_api_rpc_request( 15:20:28 'tapi-topology', 'get-topology-details', self.tapi_topo) 15:20:28 time.sleep(2) 15:20:28 self.assertEqual(response['status_code'], requests.codes.ok) 15:20:28 self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 15:20:28 > self.assertEqual(len(response['output']['topology']['link']), 3, 'There should be 3 TAPI links') 15:20:28 E AssertionError: 1 != 3 : There should be 3 TAPI links 15:20:28 15:20:28 transportpce_tests/tapi/test02_full_topology.py:307: AssertionError 15:20:28 ______ TestTransportPCEFullTopology.test_35_check_uninstall_Tapi_Feature _______ 15:20:28 15:20:28 self = 15:20:28 conn = 15:20:28 method = 'GET' 15:20:28 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 15:20:28 body = None 15:20:28 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='} 15:20:28 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 15:20:28 timeout = Timeout(connect=30, read=30, total=None), chunked = False 15:20:28 response_conn = 15:20:28 preload_content = False, decode_content = False, enforce_content_length = True 15:20:28 15:20:28 def _make_request( 15:20:28 self, 15:20:28 conn: BaseHTTPConnection, 15:20:28 method: str, 15:20:28 url: str, 15:20:28 body: _TYPE_BODY | None = None, 15:20:28 headers: typing.Mapping[str, str] | None = None, 15:20:28 retries: Retry | None = None, 15:20:28 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 15:20:28 chunked: bool = False, 15:20:28 response_conn: BaseHTTPConnection | None = None, 15:20:28 preload_content: bool = True, 15:20:28 decode_content: bool = True, 15:20:28 enforce_content_length: bool = True, 15:20:28 ) -> BaseHTTPResponse: 15:20:28 """ 15:20:28 Perform a request on a given urllib connection object taken from our 15:20:28 pool. 15:20:28 15:20:28 :param conn: 15:20:28 a connection from one of our connection pools 15:20:28 15:20:28 :param method: 15:20:28 HTTP request method (such as GET, POST, PUT, etc.) 15:20:28 15:20:28 :param url: 15:20:28 The URL to perform the request on. 15:20:28 15:20:28 :param body: 15:20:28 Data to send in the request body, either :class:`str`, :class:`bytes`, 15:20:28 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 15:20:28 15:20:28 :param headers: 15:20:28 Dictionary of custom headers to send, such as User-Agent, 15:20:28 If-None-Match, etc. If None, pool headers are used. If provided, 15:20:28 these headers completely replace any pool-specific headers. 15:20:28 15:20:28 :param retries: 15:20:28 Configure the number of retries to allow before raising a 15:20:28 :class:`~urllib3.exceptions.MaxRetryError` exception. 15:20:28 15:20:28 Pass ``None`` to retry until you receive a response. Pass a 15:20:28 :class:`~urllib3.util.retry.Retry` object for fine-grained control 15:20:28 over different types of retries. 15:20:28 Pass an integer number to retry connection errors that many times, 15:20:28 but no other types of errors. Pass zero to never retry. 15:20:28 15:20:28 If ``False``, then retries are disabled and any exception is raised 15:20:28 immediately. Also, instead of raising a MaxRetryError on redirects, 15:20:28 the redirect response will be returned. 15:20:28 15:20:28 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 15:20:28 15:20:28 :param timeout: 15:20:28 If specified, overrides the default timeout for this one 15:20:28 request. It may be a float (in seconds) or an instance of 15:20:28 :class:`urllib3.util.Timeout`. 15:20:28 15:20:28 :param chunked: 15:20:28 If True, urllib3 will send the body using chunked transfer 15:20:28 encoding. Otherwise, urllib3 will send the body using the standard 15:20:28 content-length form. Defaults to False. 15:20:28 15:20:28 :param response_conn: 15:20:28 Set this to ``None`` if you will handle releasing the connection or 15:20:28 set the connection to have the response release it. 15:20:28 15:20:28 :param preload_content: 15:20:28 If True, the response's body will be preloaded during construction. 15:20:28 15:20:28 :param decode_content: 15:20:28 If True, will attempt to decode the body based on the 15:20:28 'content-encoding' header. 15:20:28 15:20:28 :param enforce_content_length: 15:20:28 Enforce content length checking. Body returned by server must match 15:20:28 value of Content-Length header, if present. Otherwise, raise error. 15:20:28 """ 15:20:28 self.num_requests += 1 15:20:28 15:20:28 timeout_obj = self._get_timeout(timeout) 15:20:28 timeout_obj.start_connect() 15:20:28 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 15:20:28 15:20:28 try: 15:20:28 # Trigger any extra validation we need to do. 15:20:28 try: 15:20:28 self._validate_conn(conn) 15:20:28 except (SocketTimeout, BaseSSLError) as e: 15:20:28 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 15:20:28 raise 15:20:28 15:20:28 # _validate_conn() starts the connection to an HTTPS proxy 15:20:28 # so we need to wrap errors with 'ProxyError' here too. 15:20:28 except ( 15:20:28 OSError, 15:20:28 NewConnectionError, 15:20:28 TimeoutError, 15:20:28 BaseSSLError, 15:20:28 CertificateError, 15:20:28 SSLError, 15:20:28 ) as e: 15:20:28 new_e: Exception = e 15:20:28 if isinstance(e, (BaseSSLError, CertificateError)): 15:20:28 new_e = SSLError(e) 15:20:28 # If the connection didn't successfully connect to it's proxy 15:20:28 # then there 15:20:28 if isinstance( 15:20:28 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 15:20:28 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 15:20:28 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 15:20:28 raise new_e 15:20:28 15:20:28 # conn.request() calls http.client.*.request, not the method in 15:20:28 # urllib3.request. It also calls makefile (recv) on the socket. 15:20:28 try: 15:20:28 conn.request( 15:20:28 method, 15:20:28 url, 15:20:28 body=body, 15:20:28 headers=headers, 15:20:28 chunked=chunked, 15:20:28 preload_content=preload_content, 15:20:28 decode_content=decode_content, 15:20:28 enforce_content_length=enforce_content_length, 15:20:28 ) 15:20:28 15:20:28 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 15:20:28 # legitimately able to close the connection after sending a valid response. 15:20:28 # With this behaviour, the received response is still readable. 15:20:28 except BrokenPipeError: 15:20:28 pass 15:20:28 except OSError as e: 15:20:28 # MacOS/Linux 15:20:28 # EPROTOTYPE and ECONNRESET are needed on macOS 15:20:28 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 15:20:28 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 15:20:28 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 15:20:28 raise 15:20:28 15:20:28 # Reset the timeout for the recv() on the socket 15:20:28 read_timeout = timeout_obj.read_timeout 15:20:28 15:20:28 if not conn.is_closed: 15:20:28 # In Python 3 socket.py will catch EAGAIN and return None when you 15:20:28 # try and read into the file pointer created by http.client, which 15:20:28 # instead raises a BadStatusLine exception. Instead of catching 15:20:28 # the exception and assuming all BadStatusLine exceptions are read 15:20:28 # timeouts, check for a zero timeout before making the request. 15:20:28 if read_timeout == 0: 15:20:28 raise ReadTimeoutError( 15:20:28 self, url, f"Read timed out. (read timeout={read_timeout})" 15:20:28 ) 15:20:28 conn.timeout = read_timeout 15:20:28 15:20:28 # Receive the response from the server 15:20:28 try: 15:20:28 > response = conn.getresponse() 15:20:28 ^^^^^^^^^^^^^^^^^^ 15:20:28 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 15:20:28 httplib_response = super().getresponse() 15:20:28 ^^^^^^^^^^^^^^^^^^^^^ 15:20:28 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 15:20:28 response.begin() 15:20:28 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 15:20:28 version, status, reason = self._read_status() 15:20:28 ^^^^^^^^^^^^^^^^^^^ 15:20:28 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 15:20:28 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 15:20:28 self = 15:20:28 b = 15:20:28 15:20:28 def readinto(self, b): 15:20:28 """Read up to len(b) bytes into the writable buffer *b* and return 15:20:28 the number of bytes read. If the socket is non-blocking and no bytes 15:20:28 are available, None is returned. 15:20:28 15:20:28 If *b* is non-empty, a 0 return value indicates that the connection 15:20:28 was shutdown at the other end. 15:20:28 """ 15:20:28 self._checkClosed() 15:20:28 self._checkReadable() 15:20:28 if self._timeout_occurred: 15:20:28 raise OSError("cannot read from timed out object") 15:20:28 while True: 15:20:28 try: 15:20:28 > return self._sock.recv_into(b) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 E TimeoutError: timed out 15:20:28 15:20:28 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 15:20:28 15:20:28 The above exception was the direct cause of the following exception: 15:20:28 15:20:28 self = 15:20:28 request = , stream = False 15:20:28 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 15:20:28 proxies = OrderedDict() 15:20:28 15:20:28 def send( 15:20:28 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 15:20:28 ): 15:20:28 """Sends PreparedRequest object. Returns Response object. 15:20:28 15:20:28 :param request: The :class:`PreparedRequest ` being sent. 15:20:28 :param stream: (optional) Whether to stream the request content. 15:20:28 :param timeout: (optional) How long to wait for the server to send 15:20:28 data before giving up, as a float, or a :ref:`(connect timeout, 15:20:28 read timeout) ` tuple. 15:20:28 :type timeout: float or tuple or urllib3 Timeout object 15:20:28 :param verify: (optional) Either a boolean, in which case it controls whether 15:20:28 we verify the server's TLS certificate, or a string, in which case it 15:20:28 must be a path to a CA bundle to use 15:20:28 :param cert: (optional) Any user-provided SSL certificate to be trusted. 15:20:28 :param proxies: (optional) The proxies dictionary to apply to the request. 15:20:28 :rtype: requests.Response 15:20:28 """ 15:20:28 15:20:28 try: 15:20:28 conn = self.get_connection_with_tls_context( 15:20:28 request, verify, proxies=proxies, cert=cert 15:20:28 ) 15:20:28 except LocationValueError as e: 15:20:28 raise InvalidURL(e, request=request) 15:20:28 15:20:28 self.cert_verify(conn, request.url, verify, cert) 15:20:28 url = self.request_url(request, proxies) 15:20:28 self.add_headers( 15:20:28 request, 15:20:28 stream=stream, 15:20:28 timeout=timeout, 15:20:28 verify=verify, 15:20:28 cert=cert, 15:20:28 proxies=proxies, 15:20:28 ) 15:20:28 15:20:28 chunked = not (request.body is None or "Content-Length" in request.headers) 15:20:28 15:20:28 if isinstance(timeout, tuple): 15:20:28 try: 15:20:28 connect, read = timeout 15:20:28 timeout = TimeoutSauce(connect=connect, read=read) 15:20:28 except ValueError: 15:20:28 raise ValueError( 15:20:28 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 15:20:28 f"or a single float to set both timeouts to the same value." 15:20:28 ) 15:20:28 elif isinstance(timeout, TimeoutSauce): 15:20:28 pass 15:20:28 else: 15:20:28 timeout = TimeoutSauce(connect=timeout, read=timeout) 15:20:28 15:20:28 try: 15:20:28 > resp = conn.urlopen( 15:20:28 method=request.method, 15:20:28 url=url, 15:20:28 body=request.body, 15:20:28 headers=request.headers, 15:20:28 redirect=False, 15:20:28 assert_same_host=False, 15:20:28 preload_content=False, 15:20:28 decode_content=False, 15:20:28 retries=self.max_retries, 15:20:28 timeout=timeout, 15:20:28 chunked=chunked, 15:20:28 ) 15:20:28 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:645: 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 15:20:28 retries = retries.increment( 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 15:20:28 raise reraise(type(error), error, _stacktrace) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 15:20:28 raise value 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 15:20:28 response = self._make_request( 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 15:20:28 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 15:20:28 self = 15:20:28 err = TimeoutError('timed out') 15:20:28 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 15:20:28 timeout_value = 30 15:20:28 15:20:28 def _raise_timeout( 15:20:28 self, 15:20:28 err: BaseSSLError | OSError | SocketTimeout, 15:20:28 url: str, 15:20:28 timeout_value: _TYPE_TIMEOUT | None, 15:20:28 ) -> None: 15:20:28 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 15:20:28 15:20:28 if isinstance(err, SocketTimeout): 15:20:28 > raise ReadTimeoutError( 15:20:28 self, url, f"Read timed out. (read timeout={timeout_value})" 15:20:28 ) from err 15:20:28 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 15:20:28 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 15:20:28 15:20:28 During handling of the above exception, another exception occurred: 15:20:28 15:20:28 self = 15:20:28 15:20:28 def test_35_check_uninstall_Tapi_Feature(self): 15:20:28 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 15:20:28 time.sleep(16) 15:20:28 print("Tapi Feature uninstalled") 15:20:28 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 15:20:28 transportpce_tests/tapi/test02_full_topology.py:787: 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 15:20:28 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 transportpce_tests/common/test_utils.py:117: in get_request 15:20:28 return requests.request( 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 15:20:28 return session.request(method=method, url=url, **kwargs) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:592: in request 15:20:28 resp = self.send(prep, **send_kwargs) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:706: in send 15:20:28 r = adapter.send(request, **kwargs) 15:20:28 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 15:20:28 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 15:20:28 15:20:28 self = 15:20:28 request = , stream = False 15:20:28 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 15:20:28 proxies = OrderedDict() 15:20:28 15:20:28 def send( 15:20:28 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 15:20:28 ): 15:20:28 """Sends PreparedRequest object. Returns Response object. 15:20:28 15:20:28 :param request: The :class:`PreparedRequest ` being sent. 15:20:28 :param stream: (optional) Whether to stream the request content. 15:20:28 :param timeout: (optional) How long to wait for the server to send 15:20:28 data before giving up, as a float, or a :ref:`(connect timeout, 15:20:28 read timeout) ` tuple. 15:20:28 :type timeout: float or tuple or urllib3 Timeout object 15:20:28 :param verify: (optional) Either a boolean, in which case it controls whether 15:20:28 we verify the server's TLS certificate, or a string, in which case it 15:20:28 must be a path to a CA bundle to use 15:20:28 :param cert: (optional) Any user-provided SSL certificate to be trusted. 15:20:28 :param proxies: (optional) The proxies dictionary to apply to the request. 15:20:28 :rtype: requests.Response 15:20:28 """ 15:20:28 15:20:28 try: 15:20:28 conn = self.get_connection_with_tls_context( 15:20:28 request, verify, proxies=proxies, cert=cert 15:20:28 ) 15:20:28 except LocationValueError as e: 15:20:28 raise InvalidURL(e, request=request) 15:20:28 15:20:28 self.cert_verify(conn, request.url, verify, cert) 15:20:28 url = self.request_url(request, proxies) 15:20:28 self.add_headers( 15:20:28 request, 15:20:28 stream=stream, 15:20:28 timeout=timeout, 15:20:28 verify=verify, 15:20:28 cert=cert, 15:20:28 proxies=proxies, 15:20:28 ) 15:20:28 15:20:28 chunked = not (request.body is None or "Content-Length" in request.headers) 15:20:28 15:20:28 if isinstance(timeout, tuple): 15:20:28 try: 15:20:28 connect, read = timeout 15:20:28 timeout = TimeoutSauce(connect=connect, read=read) 15:20:28 except ValueError: 15:20:28 raise ValueError( 15:20:28 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 15:20:28 f"or a single float to set both timeouts to the same value." 15:20:28 ) 15:20:28 elif isinstance(timeout, TimeoutSauce): 15:20:28 pass 15:20:28 else: 15:20:28 timeout = TimeoutSauce(connect=timeout, read=timeout) 15:20:28 15:20:28 try: 15:20:28 resp = conn.urlopen( 15:20:28 method=request.method, 15:20:28 url=url, 15:20:28 body=request.body, 15:20:28 headers=request.headers, 15:20:28 redirect=False, 15:20:28 assert_same_host=False, 15:20:28 preload_content=False, 15:20:28 decode_content=False, 15:20:28 retries=self.max_retries, 15:20:28 timeout=timeout, 15:20:28 chunked=chunked, 15:20:28 ) 15:20:28 15:20:28 except (ProtocolError, OSError) as err: 15:20:28 raise ConnectionError(err, request=request) 15:20:28 15:20:28 except MaxRetryError as e: 15:20:28 if isinstance(e.reason, ConnectTimeoutError): 15:20:28 # TODO: Remove this in 3.0.0: see #2811 15:20:28 if not isinstance(e.reason, NewConnectionError): 15:20:28 raise ConnectTimeout(e, request=request) 15:20:28 15:20:28 if isinstance(e.reason, ResponseError): 15:20:28 raise RetryError(e, request=request) 15:20:28 15:20:28 if isinstance(e.reason, _ProxyError): 15:20:28 raise ProxyError(e, request=request) 15:20:28 15:20:28 if isinstance(e.reason, _SSLError): 15:20:28 # This branch is for urllib3 v1.22 and later. 15:20:28 raise SSLError(e, request=request) 15:20:28 15:20:28 raise ConnectionError(e, request=request) 15:20:28 15:20:28 except ClosedPoolError as e: 15:20:28 raise ConnectionError(e, request=request) 15:20:28 15:20:28 except _ProxyError as e: 15:20:28 raise ProxyError(e) 15:20:28 15:20:28 except (_SSLError, _HTTPError) as e: 15:20:28 if isinstance(e, _SSLError): 15:20:28 # This branch is for urllib3 versions earlier than v1.22 15:20:28 raise SSLError(e, request=request) 15:20:28 elif isinstance(e, ReadTimeoutError): 15:20:28 > raise ReadTimeout(e, request=request) 15:20:28 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 15:20:28 15:20:28 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:691: ReadTimeout 15:20:28 ----------------------------- Captured stdout call ----------------------------- 15:20:28 uninstalling feature odl-transportpce-tapi 15:20:28 client: JAVA_HOME not set; results may vary 15:20:28 odl-transportpce-tapi │ 13.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 15:20:28 Tapi Feature uninstalled 15:20:28 --------------------------- Captured stdout teardown --------------------------- 15:20:28 all processes killed 15:20:28 ODL log file stored 15:20:28 =========================== short test summary info ============================ 15:20:28 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_13_get_tapi_topology_details 15:20:28 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_35_check_uninstall_Tapi_Feature 15:20:28 2 failed, 34 passed in 369.54s (0:06:09) 15:20:29 tests71: OK ✔ in 7 minutes 35.94 seconds 15:20:29 tests_tapi: exit 1 (866.34 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7590 15:20:29 tests_tapi: FAIL ✖ in 14 minutes 33.79 seconds 15:20:29 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 15:20:36 tests221: freeze> python -m pip freeze --all 15:20:36 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.4,netconf-client==3.5.0,packaging==26.1,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:36 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 15:20:36 using environment variables from ./karaf221.env 15:20:36 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 15:20:46 ........................................ [100%] 15:21:54 35 passed in 78.09s (0:01:18) 15:21:54 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 15:22:28 ...... [100%] 15:22:42 6 passed in 47.08s 15:22:42 pytest -q transportpce_tests/2.2.1/test03_topology.py 15:23:17 ............................................. [100%] 15:25:01 44 passed in 139.07s (0:02:19) 15:25:01 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 15:25:28 ..... [100%] 15:25:31 54 passed in 538.05s (0:08:58) 15:25:38 ............ [100%] 15:26:02 12 passed in 61.01s (0:01:01) 15:26:03 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 15:26:28 ................ [100%] 15:27:58 16 passed in 114.83s (0:01:54) 15:27:58 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 15:28:29 ............................... [100%] 15:28:35 31 passed in 37.53s 15:28:36 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 15:29:12 .......................... [100%] 15:30:08 26 passed in 91.95s (0:01:31) 15:30:08 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 15:30:48 ...................... [100%] 15:31:52 22 passed in 103.88s (0:01:43) 15:31:52 pytest -q transportpce_tests/2.2.1/test09_olm.py 15:32:36 ........................................ [100%] 15:34:59 40 passed in 186.84s (0:03:06) 15:34:59 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 15:35:48 ........................................................................ [ 74%] 15:41:25 ......................... [100%] 15:43:17 97 passed in 497.41s (0:08:17) 15:43:17 pytest -q transportpce_tests/2.2.1/test12_end2end.py 15:43:58 ...................................................... [100%] 15:50:46 54 passed in 449.07s (0:07:29) 15:50:46 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 15:51:42 ........................................................................ [ 71%] 15:56:50 ............................. [100%] 16:01:59 101 passed in 672.78s (0:11:12) 16:01:59 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 16:02:54 ........................................................................ [ 67%] 16:08:41 ................................... [100%] 16:12:01 107 passed in 601.73s (0:10:01) 16:12:01 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 16:12:45 ............................................. [100%] 16:15:23 45 passed in 201.15s (0:03:21) 16:15:23 tests121: OK ✔ in 19 minutes 36.62 seconds 16:15:23 tests221: OK ✔ in 54 minutes 54.29 seconds 16:15:23 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 16:15:30 tests_hybrid: freeze> python -m pip freeze --all 16:15:30 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.4,netconf-client==3.5.0,packaging==26.1,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 16:15:30 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 16:15:30 using environment variables from ./karaf221.env 16:15:30 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 16:16:11 ................................................... [100%] 16:17:58 51 passed in 147.90s (0:02:27) 16:17:58 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 16:18:41 ........................................................................ [ 66%] 16:23:02 ..................................... [100%] 16:25:09 109 passed in 429.84s (0:07:09) 16:25:09 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 16:25:57 ..................................................... [100%] 16:32:29 53 passed in 440.60s (0:07:20) 16:32:29 buildcontroller: OK (116.02=setup[8.67]+cmd[107.34] seconds) 16:32:29 sims: OK (16.88=setup[12.60]+cmd[4.28] seconds) 16:32:29 build_karaf_tests121: OK (74.21=setup[8.16]+cmd[66.05] seconds) 16:32:29 testsPCE: OK (283.52=setup[50.51]+cmd[233.00] seconds) 16:32:29 tests121: OK (1176.62=setup[7.32]+cmd[1169.30] seconds) 16:32:29 build_karaf_tests221: OK (83.91=setup[8.25]+cmd[75.65] seconds) 16:32:29 tests_tapi: FAIL code 1 (873.79=setup[7.45]+cmd[866.34] seconds) 16:32:29 tests221: OK (3294.29=setup[7.50]+cmd[3286.80] seconds) 16:32:29 build_karaf_tests71: OK (80.07=setup[8.22]+cmd[71.86] seconds) 16:32:29 tests71: OK (455.94=setup[7.39]+cmd[448.54] seconds) 16:32:29 build_karaf_tests190: OK (84.66=setup[8.35]+cmd[76.30] seconds) 16:32:29 tests190: OK (214.01=setup[7.29]+cmd[206.72] seconds) 16:32:29 tests_hybrid: OK (1026.67=setup[7.41]+cmd[1019.26] seconds) 16:32:29 buildlighty: OK (39.22=setup[18.55]+cmd[20.67] seconds) 16:32:29 docs: OK (29.14=setup[26.34]+cmd[2.80] seconds) 16:32:29 docs-linkcheck: OK (31.24=setup[26.82]+cmd[4.42] seconds) 16:32:29 checkbashisms: OK (3.36=setup[2.13]+cmd[0.00,0.04,1.19] seconds) 16:32:29 pre-commit: OK (66.75=setup[2.74]+cmd[0.00,0.00,55.10,8.91] seconds) 16:32:29 pylint: OK (33.96=setup[4.14]+cmd[29.82] seconds) 16:32:29 evaluation failed :( (5679.00 seconds) 16:32:30 + tox_status=1 16:32:30 + echo '---> Completed tox runs' 16:32:30 ---> Completed tox runs 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/build_karaf_tests121/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=build_karaf_tests121 16:32:30 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/build_karaf_tests190/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=build_karaf_tests190 16:32:30 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/build_karaf_tests221/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=build_karaf_tests221 16:32:30 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/build_karaf_tests71/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=build_karaf_tests71 16:32:30 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/buildcontroller/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=buildcontroller 16:32:30 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/buildlighty/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=buildlighty 16:32:30 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/checkbashisms/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=checkbashisms 16:32:30 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/docs-linkcheck/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=docs-linkcheck 16:32:30 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/docs/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=docs 16:32:30 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/pre-commit/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=pre-commit 16:32:30 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/pylint/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=pylint 16:32:30 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/sims/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=sims 16:32:30 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/tests121/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=tests121 16:32:30 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/tests190/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=tests190 16:32:30 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/tests221/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=tests221 16:32:30 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/tests71/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=tests71 16:32:30 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/testsPCE/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=testsPCE 16:32:30 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 16:32:30 + for i in .tox/*/log 16:32:30 ++ echo .tox/tests_hybrid/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 + tox_env=tests_hybrid 16:32:30 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 16:32:30 + for i in .tox/*/log 16:32:30 ++ awk -F/ '{print $2}' 16:32:30 ++ echo .tox/tests_tapi/log 16:32:30 + tox_env=tests_tapi 16:32:30 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 16:32:30 + DOC_DIR=docs/_build/html 16:32:30 + [[ -d docs/_build/html ]] 16:32:30 + echo '---> Archiving generated docs' 16:32:30 ---> Archiving generated docs 16:32:30 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 16:32:30 + echo '---> tox-run.sh ends' 16:32:30 ---> tox-run.sh ends 16:32:30 + test 1 -eq 0 16:32:30 + exit 1 16:32:30 ++ '[' 1 = 1 ']' 16:32:30 ++ '[' -x /usr/bin/clear_console ']' 16:32:30 ++ /usr/bin/clear_console -q 16:32:30 Build step 'Execute shell' marked build as failure 16:32:30 $ ssh-agent -k 16:32:30 unset SSH_AUTH_SOCK; 16:32:30 unset SSH_AGENT_PID; 16:32:30 echo Agent pid 1569 killed; 16:32:30 [ssh-agent] Stopped. 16:32:30 [PostBuildScript] - [INFO] Executing post build scripts. 16:32:30 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12983238535582885469.sh 16:32:30 ---> sysstat.sh 16:32:31 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15096493643409928450.sh 16:32:31 ---> package-listing.sh 16:32:31 ++ facter osfamily 16:32:31 ++ tr '[:upper:]' '[:lower:]' 16:32:31 + OS_FAMILY=debian 16:32:31 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 16:32:31 + START_PACKAGES=/tmp/packages_start.txt 16:32:31 + END_PACKAGES=/tmp/packages_end.txt 16:32:31 + DIFF_PACKAGES=/tmp/packages_diff.txt 16:32:31 + PACKAGES=/tmp/packages_start.txt 16:32:31 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 16:32:31 + PACKAGES=/tmp/packages_end.txt 16:32:31 + case "${OS_FAMILY}" in 16:32:31 + dpkg -l 16:32:31 + grep '^ii' 16:32:31 + '[' -f /tmp/packages_start.txt ']' 16:32:31 + '[' -f /tmp/packages_end.txt ']' 16:32:31 + diff /tmp/packages_start.txt /tmp/packages_end.txt 16:32:31 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 16:32:31 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 16:32:31 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 16:32:31 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7483194602219490993.sh 16:32:31 ---> capture-instance-metadata.sh 16:32:31 Setup pyenv: 16:32:31 system 16:32:31 3.8.20 16:32:31 3.9.20 16:32:31 3.10.15 16:32:31 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 16:32:32 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PzJx from file:/tmp/.os_lf_venv 16:32:32 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 16:32:32 lf-activate-venv(): INFO: Attempting to install with network-safe options... 16:32:34 lf-activate-venv(): INFO: Base packages installed successfully 16:32:34 lf-activate-venv(): INFO: Installing additional packages: lftools 16:32:45 lf-activate-venv(): INFO: Adding /tmp/venv-PzJx/bin to PATH 16:32:45 INFO: Running in OpenStack, capturing instance metadata 16:32:45 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1911809494800847041.sh 16:32:45 provisioning config files... 16:32:45 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #5128 16:32:45 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config11459770377166865227tmp 16:32:45 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 16:32:45 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 16:32:45 provisioning config files... 16:32:45 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 16:32:45 [EnvInject] - Injecting environment variables from a build step. 16:32:46 [EnvInject] - Injecting as environment variables the properties content 16:32:46 SERVER_ID=logs 16:32:46 16:32:46 [EnvInject] - Variables injected successfully. 16:32:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17052367123596585326.sh 16:32:46 ---> create-netrc.sh 16:32:46 WARN: Log server credential not found. 16:32:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2107477867316635454.sh 16:32:46 ---> python-tools-install.sh 16:32:46 Setup pyenv: 16:32:46 system 16:32:46 3.8.20 16:32:46 3.9.20 16:32:46 3.10.15 16:32:46 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 16:32:46 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PzJx from file:/tmp/.os_lf_venv 16:32:46 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 16:32:46 lf-activate-venv(): INFO: Attempting to install with network-safe options... 16:32:48 lf-activate-venv(): INFO: Base packages installed successfully 16:32:48 lf-activate-venv(): INFO: Installing additional packages: lftools 16:32:57 lf-activate-venv(): INFO: Adding /tmp/venv-PzJx/bin to PATH 16:32:57 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins3495146455395169276.sh 16:32:57 ---> uv-install.sh 16:32:57 uv 0.11.6 is already installed 16:32:57 uvx 0.11.6 (x86_64-unknown-linux-gnu) 16:32:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4136334092533060042.sh 16:32:57 ---> sudo-logs.sh 16:32:57 Archiving 'sudo' log.. 16:32:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14526454391185028557.sh 16:32:57 ---> job-cost.sh 16:32:57 INFO: Activating Python virtual environment... 16:32:58 Setup pyenv: 16:32:58 system 16:32:58 3.8.20 16:32:58 3.9.20 16:32:58 3.10.15 16:32:58 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 16:32:58 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PzJx from file:/tmp/.os_lf_venv 16:32:58 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 16:32:58 lf-activate-venv(): INFO: Attempting to install with network-safe options... 16:33:00 lf-activate-venv(): INFO: Base packages installed successfully 16:33:00 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 16:33:05 lf-activate-venv(): INFO: Adding /tmp/venv-PzJx/bin to PATH 16:33:05 INFO: No stack-cost file found 16:33:05 INFO: Instance uptime: 5851s 16:33:05 INFO: Fetching instance metadata (attempt 1 of 3)... 16:33:05 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 16:33:06 INFO: Successfully fetched instance metadata 16:33:06 INFO: Instance type: v3-standard-4 16:33:06 INFO: Retrieving pricing info for: v3-standard-4 16:33:06 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 16:33:06 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=5851 16:33:06 INFO: Successfully fetched Vexxhost pricing API 16:33:06 INFO: Retrieved cost: 0.22 16:33:06 INFO: Retrieved resource: v3-standard-4 16:33:06 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 16:33:06 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 16:33:06 INFO: Successfully archived job cost data 16:33:06 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,5128,2026-04-15 16:33:06,v3-standard-4,5851,0.22,0.00,FAILURE 16:33:06 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins10274115946025783832.sh 16:33:06 ---> logs-deploy.sh 16:33:06 Setup pyenv: 16:33:06 system 16:33:06 3.8.20 16:33:06 3.9.20 16:33:06 3.10.15 16:33:06 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 16:33:06 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PzJx from file:/tmp/.os_lf_venv 16:33:06 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 16:33:06 lf-activate-venv(): INFO: Attempting to install with network-safe options... 16:33:08 lf-activate-venv(): INFO: Base packages installed successfully 16:33:08 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 16:33:17 lf-activate-venv(): INFO: Adding /tmp/venv-PzJx/bin to PATH 16:33:17 WARNING: Nexus logging server not set 16:33:17 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/5128/ 16:33:17 INFO: archiving logs to S3 16:33:19 ---> uname -a: 16:33:19 Linux prd-ubuntu2204-docker-4c-16g-3048 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 16:33:19 16:33:19 16:33:19 ---> lscpu: 16:33:19 Architecture: x86_64 16:33:19 CPU op-mode(s): 32-bit, 64-bit 16:33:19 Address sizes: 40 bits physical, 48 bits virtual 16:33:19 Byte Order: Little Endian 16:33:19 CPU(s): 4 16:33:19 On-line CPU(s) list: 0-3 16:33:19 Vendor ID: AuthenticAMD 16:33:19 Model name: AMD EPYC-Rome Processor 16:33:19 CPU family: 23 16:33:19 Model: 49 16:33:19 Thread(s) per core: 1 16:33:19 Core(s) per socket: 1 16:33:19 Socket(s): 4 16:33:19 Stepping: 0 16:33:19 BogoMIPS: 5599.99 16:33:19 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 16:33:19 Virtualization: AMD-V 16:33:19 Hypervisor vendor: KVM 16:33:19 Virtualization type: full 16:33:19 L1d cache: 128 KiB (4 instances) 16:33:19 L1i cache: 128 KiB (4 instances) 16:33:19 L2 cache: 2 MiB (4 instances) 16:33:19 L3 cache: 64 MiB (4 instances) 16:33:19 NUMA node(s): 1 16:33:19 NUMA node0 CPU(s): 0-3 16:33:19 Vulnerability Gather data sampling: Not affected 16:33:19 Vulnerability Indirect target selection: Not affected 16:33:19 Vulnerability Itlb multihit: Not affected 16:33:19 Vulnerability L1tf: Not affected 16:33:19 Vulnerability Mds: Not affected 16:33:19 Vulnerability Meltdown: Not affected 16:33:19 Vulnerability Mmio stale data: Not affected 16:33:19 Vulnerability Reg file data sampling: Not affected 16:33:19 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 16:33:19 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 16:33:19 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 16:33:19 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 16:33:19 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 16:33:19 Vulnerability Srbds: Not affected 16:33:19 Vulnerability Tsa: Not affected 16:33:19 Vulnerability Tsx async abort: Not affected 16:33:19 Vulnerability Vmscape: Not affected 16:33:19 16:33:19 16:33:19 ---> nproc: 16:33:19 4 16:33:19 16:33:19 16:33:19 ---> df -h: 16:33:19 Filesystem Size Used Avail Use% Mounted on 16:33:19 tmpfs 1.6G 1.1M 1.6G 1% /run 16:33:19 /dev/vda1 78G 18G 61G 23% / 16:33:19 tmpfs 7.9G 0 7.9G 0% /dev/shm 16:33:19 tmpfs 5.0M 0 5.0M 0% /run/lock 16:33:19 /dev/vda15 105M 6.1M 99M 6% /boot/efi 16:33:19 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 16:33:19 16:33:19 16:33:19 ---> free -m: 16:33:19 total used free shared buff/cache available 16:33:19 Mem: 15989 703 11389 4 3896 14943 16:33:19 Swap: 1023 0 1023 16:33:19 16:33:19 16:33:19 ---> ip addr: 16:33:19 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 16:33:19 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 16:33:19 inet 127.0.0.1/8 scope host lo 16:33:19 valid_lft forever preferred_lft forever 16:33:19 inet6 ::1/128 scope host 16:33:19 valid_lft forever preferred_lft forever 16:33:19 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 16:33:19 link/ether fa:16:3e:82:3f:03 brd ff:ff:ff:ff:ff:ff 16:33:19 altname enp0s3 16:33:19 inet 10.30.171.121/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 16:33:19 valid_lft 80543sec preferred_lft 80543sec 16:33:19 inet6 fe80::f816:3eff:fe82:3f03/64 scope link 16:33:19 valid_lft forever preferred_lft forever 16:33:19 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 16:33:19 link/ether 96:c5:74:50:3d:48 brd ff:ff:ff:ff:ff:ff 16:33:19 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 16:33:19 valid_lft forever preferred_lft forever 16:33:19 inet6 fe80::94c5:74ff:fe50:3d48/64 scope link 16:33:19 valid_lft forever preferred_lft forever 16:33:19 16:33:19 16:33:19 ---> sar -b -r -n DEV: 16:33:19 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-3048) 04/15/26 _x86_64_ (4 CPU) 16:33:19 16:33:19 14:55:46 LINUX RESTART (4 CPU) 16:33:19 16:33:19 15:00:25 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 16:33:19 15:10:31 108.86 24.17 80.02 4.67 588.07 26573.48 11300.61 16:33:19 15:20:25 23.74 4.05 18.67 1.01 86.54 514.06 2574.27 16:33:19 15:30:00 20.85 0.16 19.75 0.94 9.17 825.95 1646.73 16:33:19 15:40:25 7.66 0.07 7.32 0.27 2.92 212.29 584.48 16:33:19 15:50:25 4.83 0.02 4.65 0.17 0.69 125.99 49.68 16:33:19 16:00:25 20.29 0.06 4.55 15.68 2.67 128.09 211684.28 16:33:19 16:10:25 17.56 12.00 5.39 0.18 141.32 153.44 299.56 16:33:19 16:20:25 10.92 0.06 10.38 0.49 2.16 616.49 309.25 16:33:19 16:30:19 5.20 0.02 5.00 0.18 0.77 161.59 358.66 16:33:19 Average: 24.50 4.54 17.33 2.62 93.37 3288.31 25456.80 16:33:19 16:33:19 15:00:25 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 16:33:19 15:10:31 161116 3679576 12250416 74.82 270372 3214040 13377504 76.79 2194060 13412264 1980 16:33:19 15:20:25 4034684 6870588 9064616 55.36 272320 2589044 9796384 56.23 2166504 9620796 264 16:33:19 15:30:00 10626300 13589572 2351208 14.36 278084 2710612 3092756 17.75 2224456 3016188 228 16:33:19 15:40:25 8368836 11358660 4580556 27.98 279080 2736168 5362164 30.78 2227240 5264724 412 16:33:19 15:50:25 8421820 11426204 4513116 27.56 279724 2750084 5253500 30.16 2228724 5194212 192 16:33:19 16:00:25 6778380 9802716 6135616 37.47 280588 2769184 6855400 39.35 2236080 6839352 196 16:33:19 16:10:25 6815784 9911172 6026940 36.81 285620 2825016 6842004 39.27 2279152 6745040 140 16:33:19 16:20:25 8154588 11383984 4555076 27.82 289592 2948924 5282676 30.32 2295788 5389684 100 16:33:19 16:30:19 7178656 10431292 5507100 33.64 290236 2971444 6148228 35.29 2306216 6341516 68 16:33:19 Average: 6726685 9828196 6109405 37.31 280624 2834946 6890068 39.55 2239802 6869308 398 16:33:19 16:33:19 15:00:25 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 16:33:19 15:10:31 lo 16.48 16.48 14.87 14.87 0.00 0.00 0.00 0.00 16:33:19 15:10:31 ens3 44.22 33.31 696.83 3.49 0.00 0.00 0.00 0.00 16:33:19 15:10:31 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 15:20:25 lo 42.33 42.33 18.40 18.40 0.00 0.00 0.00 0.00 16:33:19 15:20:25 ens3 1.56 1.52 0.32 0.28 0.00 0.00 0.00 0.00 16:33:19 15:20:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 15:30:00 lo 23.44 23.44 9.80 9.80 0.00 0.00 0.00 0.00 16:33:19 15:30:00 ens3 1.22 1.03 0.32 0.30 0.00 0.00 0.00 0.00 16:33:19 15:30:00 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 15:40:25 lo 19.07 19.07 9.95 9.95 0.00 0.00 0.00 0.00 16:33:19 15:40:25 ens3 1.11 1.41 0.20 1.20 0.00 0.00 0.00 0.00 16:33:19 15:40:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 15:50:25 lo 26.81 26.81 9.63 9.63 0.00 0.00 0.00 0.00 16:33:19 15:50:25 ens3 0.59 0.48 0.14 0.10 0.00 0.00 0.00 0.00 16:33:19 15:50:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 16:00:25 lo 18.75 18.75 9.17 9.17 0.00 0.00 0.00 0.00 16:33:19 16:00:25 ens3 0.78 0.55 0.22 0.16 0.00 0.00 0.00 0.00 16:33:19 16:00:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 16:10:25 lo 14.26 14.26 8.95 8.95 0.00 0.00 0.00 0.00 16:33:19 16:10:25 ens3 0.60 0.46 0.12 0.09 0.00 0.00 0.00 0.00 16:33:19 16:10:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 16:20:25 lo 18.85 18.85 10.29 10.29 0.00 0.00 0.00 0.00 16:33:19 16:20:25 ens3 0.99 0.84 0.28 0.22 0.00 0.00 0.00 0.00 16:33:19 16:20:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 16:30:19 lo 32.40 32.40 12.62 12.62 0.00 0.00 0.00 0.00 16:33:19 16:30:19 ens3 0.65 0.57 0.14 0.11 0.00 0.00 0.00 0.00 16:33:19 16:30:19 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 Average: lo 23.54 23.54 11.52 11.52 0.00 0.00 0.00 0.00 16:33:19 Average: ens3 5.80 4.51 78.53 0.67 0.00 0.00 0.00 0.00 16:33:19 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 16:33:19 16:33:19 16:33:19 ---> sar -P ALL: 16:33:19 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-3048) 04/15/26 _x86_64_ (4 CPU) 16:33:19 16:33:19 14:55:46 LINUX RESTART (4 CPU) 16:33:19 16:33:19 15:00:25 CPU %user %nice %system %iowait %steal %idle 16:33:19 15:10:31 all 53.67 0.00 2.29 3.36 0.11 40.57 16:33:19 15:10:31 0 54.77 0.00 2.34 2.88 0.11 39.90 16:33:19 15:10:31 1 53.11 0.00 2.37 3.01 0.10 41.41 16:33:19 15:10:31 2 55.60 0.00 2.15 2.82 0.11 39.32 16:33:19 15:10:31 3 51.19 0.00 2.32 4.72 0.10 41.67 16:33:19 15:20:25 all 39.19 0.00 1.57 0.10 0.12 59.02 16:33:19 15:20:25 0 39.44 0.00 1.63 0.16 0.12 58.65 16:33:19 15:20:25 1 39.13 0.00 1.51 0.03 0.12 59.22 16:33:19 15:20:25 2 40.08 0.00 1.48 0.09 0.12 58.23 16:33:19 15:20:25 3 38.12 0.00 1.66 0.12 0.12 59.98 16:33:19 15:30:00 all 31.24 0.00 1.08 0.15 0.10 67.42 16:33:19 15:30:00 0 31.18 0.00 1.21 0.09 0.10 67.42 16:33:19 15:30:00 1 31.24 0.00 1.03 0.12 0.11 67.50 16:33:19 15:30:00 2 30.93 0.00 1.02 0.24 0.10 67.71 16:33:19 15:30:00 3 31.61 0.00 1.08 0.15 0.10 67.06 16:33:19 15:40:25 all 17.79 0.00 0.72 0.68 0.08 80.74 16:33:19 15:40:25 0 17.95 0.00 0.65 0.17 0.07 81.15 16:33:19 15:40:25 1 17.28 0.00 0.74 0.66 0.09 81.24 16:33:19 15:40:25 2 17.69 0.00 0.76 0.58 0.08 80.89 16:33:19 15:40:25 3 18.22 0.00 0.72 1.29 0.08 79.68 16:33:19 15:50:25 all 8.43 0.00 0.41 0.03 0.08 91.06 16:33:19 15:50:25 0 8.35 0.00 0.40 0.03 0.07 91.16 16:33:19 15:50:25 1 8.40 0.00 0.43 0.00 0.09 91.09 16:33:19 15:50:25 2 8.97 0.00 0.40 0.03 0.08 90.52 16:33:19 15:50:25 3 8.00 0.00 0.42 0.05 0.07 91.47 16:33:19 16:00:25 all 9.77 0.00 0.47 0.04 0.08 89.64 16:33:19 16:00:25 0 9.87 0.00 0.47 0.04 0.08 89.55 16:33:19 16:00:25 1 9.40 0.00 0.43 0.10 0.08 89.99 16:33:19 16:00:25 2 10.09 0.00 0.55 0.02 0.08 89.26 16:33:19 16:00:25 3 9.71 0.00 0.46 0.01 0.07 89.75 16:33:19 16:10:25 all 9.43 0.07 0.45 0.08 0.08 89.88 16:33:19 16:10:25 0 9.07 0.06 0.43 0.07 0.08 90.29 16:33:19 16:10:25 1 9.67 0.11 0.53 0.10 0.09 89.51 16:33:19 16:10:25 2 9.75 0.05 0.47 0.11 0.08 89.54 16:33:19 16:10:25 3 9.23 0.08 0.37 0.06 0.08 90.18 16:33:19 16:20:25 all 19.52 0.00 0.69 0.06 0.09 79.64 16:33:19 16:20:25 0 18.61 0.00 0.76 0.05 0.09 80.50 16:33:19 16:20:25 1 19.69 0.00 0.61 0.11 0.08 79.51 16:33:19 16:20:25 2 20.21 0.00 0.75 0.04 0.09 78.92 16:33:19 16:20:25 3 19.60 0.00 0.64 0.04 0.08 79.65 16:33:19 16:30:19 all 10.35 0.00 0.53 0.03 0.08 89.01 16:33:19 16:30:19 0 10.38 0.00 0.54 0.02 0.08 88.98 16:33:19 16:30:19 1 9.98 0.00 0.54 0.01 0.08 89.38 16:33:19 16:30:19 2 10.48 0.00 0.50 0.09 0.08 88.85 16:33:19 16:30:19 3 10.54 0.00 0.52 0.01 0.08 88.84 16:33:19 Average: all 22.12 0.01 0.91 0.51 0.09 76.36 16:33:19 Average: 0 22.14 0.01 0.93 0.39 0.09 76.43 16:33:19 Average: 1 21.95 0.01 0.91 0.46 0.09 76.57 16:33:19 Average: 2 22.61 0.01 0.90 0.45 0.09 75.95 16:33:19 Average: 3 21.76 0.01 0.91 0.73 0.09 76.50 16:33:19 16:33:19 16:33:19