12:00:20 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/122294 12:00:20 Running as SYSTEM 12:00:20 [EnvInject] - Loading node environment variables. 12:00:20 Building remotely on prd-ubuntu2204-docker-4c-16g-1788 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 12:00:20 [ssh-agent] Looking for ssh-agent implementation... 12:00:21 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 12:00:21 $ ssh-agent 12:00:21 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXqTToQ3/agent.1564 12:00:21 SSH_AGENT_PID=1566 12:00:21 [ssh-agent] Started. 12:00:21 Running ssh-add (command line suppressed) 12:00:21 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_128344788368139527.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_128344788368139527.key) 12:00:21 [ssh-agent] Using credentials jenkins (jenkins-ssh) 12:00:21 The recommended git tool is: NONE 12:00:23 using credential jenkins-ssh 12:00:23 Wiping out workspace first. 12:00:23 Cloning the remote Git repository 12:00:23 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 12:00:23 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 12:00:23 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 12:00:23 > git --version # timeout=10 12:00:23 > git --version # 'git version 2.34.1' 12:00:23 using GIT_SSH to set credentials jenkins-ssh 12:00:23 Verifying host key using known hosts file, will automatically accept unseen keys 12:00:23 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 12:00:28 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 12:00:28 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 12:00:28 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 12:00:28 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 12:00:28 using GIT_SSH to set credentials jenkins-ssh 12:00:28 Verifying host key using known hosts file, will automatically accept unseen keys 12:00:28 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/94/122294/2 # timeout=10 12:00:29 > git rev-parse 60dd72c0d1fcf487952d8668477395c0ce5c98df^{commit} # timeout=10 12:00:29 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 12:00:29 Checking out Revision 60dd72c0d1fcf487952d8668477395c0ce5c98df (refs/changes/94/122294/2) 12:00:29 > git config core.sparsecheckout # timeout=10 12:00:29 > git checkout -f 60dd72c0d1fcf487952d8668477395c0ce5c98df # timeout=10 12:00:29 Commit message: "Use openroadm-topology in OR link listener" 12:00:29 > git rev-parse FETCH_HEAD^{commit} # timeout=10 12:00:29 > git rev-list --no-walk 541217c18b48b4ba69325c2af08292b4368074f8 # timeout=10 12:00:29 > git remote # timeout=10 12:00:29 > git submodule init # timeout=10 12:00:29 > git submodule sync # timeout=10 12:00:29 > git config --get remote.origin.url # timeout=10 12:00:29 > git submodule init # timeout=10 12:00:29 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 12:00:29 ERROR: No submodules found. 12:00:33 provisioning config files... 12:00:33 copy managed file [npmrc] to file:/home/jenkins/.npmrc 12:00:33 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 12:00:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16873843324423857874.sh 12:00:33 ---> python-tools-install.sh 12:00:33 Setup pyenv: 12:00:33 * system (set by /opt/pyenv/version) 12:00:33 * 3.8.20 (set by /opt/pyenv/version) 12:00:33 * 3.9.20 (set by /opt/pyenv/version) 12:00:33 3.10.15 12:00:33 3.11.10 12:00:38 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-EySj 12:00:38 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 12:00:38 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:00:38 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:00:42 lf-activate-venv(): INFO: Base packages installed successfully 12:00:42 lf-activate-venv(): INFO: Installing additional packages: lftools 12:01:08 lf-activate-venv(): INFO: Adding /tmp/venv-EySj/bin to PATH 12:01:08 Generating Requirements File 12:01:27 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. 12:01:27 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 12:01:27 Python 3.11.10 12:01:28 pip 26.0.1 from /tmp/venv-EySj/lib/python3.11/site-packages/pip (python 3.11) 12:01:28 appdirs==1.4.4 12:01:28 argcomplete==3.6.3 12:01:28 aspy.yaml==1.3.0 12:01:28 attrs==26.1.0 12:01:28 autopage==0.6.0 12:01:28 beautifulsoup4==4.14.3 12:01:28 boto3==1.42.87 12:01:28 botocore==1.42.87 12:01:28 bs4==0.0.2 12:01:28 certifi==2026.2.25 12:01:28 cffi==2.0.0 12:01:28 cfgv==3.5.0 12:01:28 chardet==7.4.1 12:01:28 charset-normalizer==3.4.7 12:01:28 click==8.3.2 12:01:28 cliff==4.13.3 12:01:28 cmd2==3.4.0 12:01:28 cryptography==3.3.2 12:01:28 debtcollector==3.1.0 12:01:28 decorator==5.2.1 12:01:28 defusedxml==0.7.1 12:01:28 Deprecated==1.3.1 12:01:28 distlib==0.4.0 12:01:28 dnspython==2.8.0 12:01:28 docker==7.1.0 12:01:28 dogpile.cache==1.5.0 12:01:28 durationpy==0.10 12:01:28 email-validator==2.3.0 12:01:28 filelock==3.25.2 12:01:28 future==1.0.0 12:01:28 gitdb==4.0.12 12:01:28 GitPython==3.1.46 12:01:28 httplib2==0.30.2 12:01:28 identify==2.6.18 12:01:28 idna==3.11 12:01:28 importlib-resources==1.5.0 12:01:28 iso8601==2.1.0 12:01:28 Jinja2==3.1.6 12:01:28 jmespath==1.1.0 12:01:28 jsonpatch==1.33 12:01:28 jsonpointer==3.1.1 12:01:28 jsonschema==4.26.0 12:01:28 jsonschema-specifications==2025.9.1 12:01:28 keystoneauth1==5.13.1 12:01:28 kubernetes==35.0.0 12:01:28 lftools==0.37.22 12:01:28 lxml==6.0.3 12:01:28 markdown-it-py==4.0.0 12:01:28 MarkupSafe==3.0.3 12:01:28 mdurl==0.1.2 12:01:28 msgpack==1.1.2 12:01:28 multi_key_dict==2.0.3 12:01:28 munch==4.0.0 12:01:28 netaddr==1.3.0 12:01:28 niet==1.4.2 12:01:28 nodeenv==1.10.0 12:01:28 oauth2client==4.1.3 12:01:28 oauthlib==3.3.1 12:01:28 openstacksdk==4.10.0 12:01:28 os-service-types==1.8.2 12:01:28 osc-lib==4.4.0 12:01:28 oslo.config==10.3.0 12:01:28 oslo.context==6.3.0 12:01:28 oslo.i18n==6.7.2 12:01:28 oslo.log==8.1.0 12:01:28 oslo.serialization==5.9.1 12:01:28 oslo.utils==10.0.1 12:01:28 packaging==26.0 12:01:28 pbr==7.0.3 12:01:28 platformdirs==4.9.6 12:01:28 prettytable==3.17.0 12:01:28 psutil==7.2.2 12:01:28 pyasn1==0.6.3 12:01:28 pyasn1_modules==0.4.2 12:01:28 pycparser==3.0 12:01:28 pygerrit2==2.0.15 12:01:28 PyGithub==2.9.0 12:01:28 Pygments==2.20.0 12:01:28 PyJWT==2.12.1 12:01:28 PyNaCl==1.6.2 12:01:28 pyparsing==2.4.7 12:01:28 pyperclip==1.11.0 12:01:28 pyrsistent==0.20.0 12:01:28 python-cinderclient==9.9.0 12:01:28 python-dateutil==2.9.0.post0 12:01:28 python-discovery==1.2.2 12:01:28 python-heatclient==5.1.0 12:01:28 python-jenkins==1.8.3 12:01:28 python-keystoneclient==5.8.0 12:01:28 python-magnumclient==4.10.0 12:01:28 python-openstackclient==9.0.0 12:01:28 python-swiftclient==4.10.0 12:01:28 PyYAML==6.0.3 12:01:28 referencing==0.37.0 12:01:28 requests==2.33.1 12:01:28 requests-oauthlib==2.0.0 12:01:28 requestsexceptions==1.4.0 12:01:28 rfc3986==2.0.0 12:01:28 rich==14.3.3 12:01:28 rich-argparse==1.7.2 12:01:28 rpds-py==0.30.0 12:01:28 rsa==4.9.1 12:01:28 ruamel.yaml==0.19.1 12:01:28 ruamel.yaml.clib==0.2.15 12:01:28 s3transfer==0.16.0 12:01:28 simplejson==3.20.2 12:01:28 six==1.17.0 12:01:28 smmap==5.0.3 12:01:28 soupsieve==2.8.3 12:01:28 stevedore==5.7.0 12:01:28 tabulate==0.10.0 12:01:28 toml==0.10.2 12:01:28 tomlkit==0.14.0 12:01:28 tqdm==4.67.3 12:01:28 typing_extensions==4.15.0 12:01:28 urllib3==1.26.20 12:01:28 virtualenv==21.2.1 12:01:28 wcwidth==0.6.0 12:01:28 websocket-client==1.9.0 12:01:28 wrapt==2.1.2 12:01:28 xdg==6.0.0 12:01:28 xmltodict==1.0.4 12:01:28 yq==3.4.3 12:01:28 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins11368645588864514430.sh 12:01:28 ---> uv-install.sh 12:01:28 Installing uv/uvx (latest) using shell installer 12:01:28 2026-04-10 12:01:28 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-10T12%3A36%3A36Z&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-10T11%3A36%3A15Z&ske=2026-04-10T12%3A36%3A36Z&sks=b&skv=2018-11-09&sig=EJ6t%2BpJmTi7d7YXjNgPBkqfS1K%2Btqs%2Bobna%2F4XMaCCs%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NTgyMjc4MCwibmJmIjoxNzc1ODIyNDgwLCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.kiqTrKe3PcnHVABwfy_Bqt7ttVFOn5rs3bxJOG-CW6E&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [71225/71225] -> "/tmp/uv-install-7CRGGB.sh" [1] 12:01:28 downloading uv 0.11.6 x86_64-unknown-linux-gnu 12:01:29 installing to /home/jenkins/.local/bin 12:01:29 uv 12:01:29 uvx 12:01:29 everything's installed! 12:01:29 12:01:29 To add $HOME/.local/bin to your PATH, either restart your shell or run: 12:01:29 12:01:29 source $HOME/.local/bin/env (sh, bash, zsh) 12:01:29 source $HOME/.local/bin/env.fish (fish) 12:01:29 Adding install location to PATH 12:01:29 ---> Validating uv/uvx install 12:01:29 uvx 0.11.6 (x86_64-unknown-linux-gnu) 12:01:29 [EnvInject] - Injecting environment variables from a build step. 12:01:29 [EnvInject] - Injecting as environment variables the properties content 12:01:29 PYTHON=python3 12:01:29 12:01:29 [EnvInject] - Variables injected successfully. 12:01:29 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins11049431543067193669.sh 12:01:29 ---> tox-install.sh 12:01:29 + source /home/jenkins/lf-env.sh 12:01:29 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 12:01:29 ++ mktemp -d /tmp/venv-XXXX 12:01:29 + lf_venv=/tmp/venv-BApA 12:01:29 + local venv_file=/tmp/.os_lf_venv 12:01:29 + local python=python3 12:01:29 + local options 12:01:29 + local set_path=true 12:01:29 + local install_args= 12:01:29 ++ 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 12:01:29 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:01:29 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:01:29 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 12:01:29 + true 12:01:29 + case $1 in 12:01:29 + venv_file=/tmp/.toxenv 12:01:29 + shift 2 12:01:29 + true 12:01:29 + case $1 in 12:01:29 + shift 12:01:29 + break 12:01:29 + case $python in 12:01:29 + local pkg_list= 12:01:29 + [[ -d /opt/pyenv ]] 12:01:29 + echo 'Setup pyenv:' 12:01:29 Setup pyenv: 12:01:29 + export PYENV_ROOT=/opt/pyenv 12:01:29 + PYENV_ROOT=/opt/pyenv 12:01:29 + 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 12:01:29 + 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 12:01:29 + pyenv versions 12:01:29 system 12:01:29 3.8.20 12:01:29 3.9.20 12:01:29 3.10.15 12:01:29 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:01:29 + command -v pyenv 12:01:29 ++ pyenv init - --no-rehash 12:01:29 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 12:01:29 for i in ${!paths[@]}; do 12:01:29 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 12:01:29 fi; done; 12:01:29 echo "${paths[*]}"'\'')" 12:01:29 export PATH="/opt/pyenv/shims:${PATH}" 12:01:29 export PYENV_SHELL=bash 12:01:29 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 12:01:29 pyenv() { 12:01:29 local command 12:01:29 command="${1:-}" 12:01:29 if [ "$#" -gt 0 ]; then 12:01:29 shift 12:01:29 fi 12:01:29 12:01:29 case "$command" in 12:01:29 rehash|shell) 12:01:29 eval "$(pyenv "sh-$command" "$@")" 12:01:29 ;; 12:01:29 *) 12:01:29 command pyenv "$command" "$@" 12:01:29 ;; 12:01:29 esac 12:01:29 }' 12:01:29 +++ bash --norc -ec 'IFS=:; paths=($PATH); 12:01:29 for i in ${!paths[@]}; do 12:01:29 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 12:01:29 fi; done; 12:01:29 echo "${paths[*]}"' 12:01:29 ++ 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 12:01:29 ++ 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 12:01:29 ++ 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 12:01:29 ++ export PYENV_SHELL=bash 12:01:29 ++ PYENV_SHELL=bash 12:01:29 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 12:01:29 +++ complete -F _pyenv pyenv 12:01:29 ++ lf-pyver python3 12:01:29 ++ local py_version_xy=python3 12:01:29 ++ local py_version_xyz= 12:01:29 ++ pyenv versions 12:01:29 ++ local command 12:01:29 ++ command=versions 12:01:29 ++ '[' 1 -gt 0 ']' 12:01:29 ++ shift 12:01:29 ++ grep -E '^[0-9.]*[0-9]$' 12:01:29 ++ case "$command" in 12:01:29 ++ command pyenv versions 12:01:29 ++ sed 's/^[ *]* //' 12:01:29 ++ awk '{ print $1 }' 12:01:29 ++ [[ ! -s /tmp/.pyenv_versions ]] 12:01:29 +++ grep '^3' /tmp/.pyenv_versions 12:01:29 +++ sort -V 12:01:29 +++ tail -n 1 12:01:29 ++ py_version_xyz=3.11.10 12:01:29 ++ [[ -z 3.11.10 ]] 12:01:29 ++ echo 3.11.10 12:01:29 ++ return 0 12:01:29 + pyenv local 3.11.10 12:01:29 + local command 12:01:29 + command=local 12:01:29 + '[' 2 -gt 0 ']' 12:01:29 + shift 12:01:29 + case "$command" in 12:01:29 + command pyenv local 3.11.10 12:01:30 + for arg in "$@" 12:01:30 + case $arg in 12:01:30 + pkg_list+='tox ' 12:01:30 + for arg in "$@" 12:01:30 + case $arg in 12:01:30 + pkg_list+='virtualenv ' 12:01:30 + for arg in "$@" 12:01:30 + case $arg in 12:01:30 + pkg_list+='urllib3~=1.26.15 ' 12:01:30 + [[ -f /tmp/.toxenv ]] 12:01:30 + [[ ! -f /tmp/.toxenv ]] 12:01:30 + [[ -n '' ]] 12:01:30 + python3 -m venv /tmp/venv-BApA 12:01:34 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-BApA' 12:01:34 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-BApA 12:01:34 + echo /tmp/venv-BApA 12:01:34 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 12:01:34 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 12:01:34 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 12:01:34 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:01:34 + local 'pip_opts=--upgrade --quiet' 12:01:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 12:01:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 12:01:34 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 12:01:34 + [[ -n '' ]] 12:01:34 + [[ -n '' ]] 12:01:34 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 12:01:34 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:01:34 + /tmp/venv-BApA/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 12:01:37 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 12:01:37 lf-activate-venv(): INFO: Base packages installed successfully 12:01:37 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 12:01:37 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 12:01:37 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 12:01:37 + /tmp/venv-BApA/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 12:01:39 + type python3 12:01:39 + true 12:01:39 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-BApA/bin to PATH' 12:01:39 lf-activate-venv(): INFO: Adding /tmp/venv-BApA/bin to PATH 12:01:39 + PATH=/tmp/venv-BApA/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 12:01:39 + return 0 12:01:39 + python3 --version 12:01:39 Python 3.11.10 12:01:39 + python3 -m pip --version 12:01:39 pip 26.0.1 from /tmp/venv-BApA/lib/python3.11/site-packages/pip (python 3.11) 12:01:40 + python3 -m pip freeze 12:01:40 cachetools==7.0.5 12:01:40 colorama==0.4.6 12:01:40 distlib==0.4.0 12:01:40 filelock==3.25.2 12:01:40 packaging==26.0 12:01:40 platformdirs==4.9.6 12:01:40 pluggy==1.6.0 12:01:40 pyproject-api==1.10.0 12:01:40 python-discovery==1.2.2 12:01:40 tomli_w==1.2.0 12:01:40 tox==4.52.1 12:01:40 urllib3==1.26.20 12:01:40 virtualenv==21.2.1 12:01:40 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins45568512317016832.sh 12:01:40 [EnvInject] - Injecting environment variables from a build step. 12:01:40 [EnvInject] - Injecting as environment variables the properties content 12:01:40 PARALLEL=True 12:01:40 12:01:40 [EnvInject] - Variables injected successfully. 12:01:40 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins16233122278859346937.sh 12:01:40 ---> tox-run.sh 12:01:40 + 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 12:01:40 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 12:01:40 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 12:01:40 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 12:01:40 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 12:01:40 + source /home/jenkins/lf-env.sh 12:01:40 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 12:01:40 ++ mktemp -d /tmp/venv-XXXX 12:01:40 + lf_venv=/tmp/venv-IWq0 12:01:40 + local venv_file=/tmp/.os_lf_venv 12:01:40 + local python=python3 12:01:40 + local options 12:01:40 + local set_path=true 12:01:40 + local install_args= 12:01:40 ++ 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 12:01:40 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:01:40 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:01:40 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 12:01:40 + true 12:01:40 + case $1 in 12:01:40 + venv_file=/tmp/.toxenv 12:01:40 + shift 2 12:01:40 + true 12:01:40 + case $1 in 12:01:40 + shift 12:01:40 + break 12:01:40 + case $python in 12:01:40 + local pkg_list= 12:01:40 + [[ -d /opt/pyenv ]] 12:01:40 + echo 'Setup pyenv:' 12:01:40 Setup pyenv: 12:01:40 + export PYENV_ROOT=/opt/pyenv 12:01:40 + PYENV_ROOT=/opt/pyenv 12:01:40 + 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 12:01:40 + 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 12:01:40 + pyenv versions 12:01:40 system 12:01:40 3.8.20 12:01:40 3.9.20 12:01:40 3.10.15 12:01:40 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:01:40 + command -v pyenv 12:01:40 ++ pyenv init - --no-rehash 12:01:40 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 12:01:40 for i in ${!paths[@]}; do 12:01:40 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 12:01:40 fi; done; 12:01:40 echo "${paths[*]}"'\'')" 12:01:40 export PATH="/opt/pyenv/shims:${PATH}" 12:01:40 export PYENV_SHELL=bash 12:01:40 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 12:01:40 pyenv() { 12:01:40 local command 12:01:40 command="${1:-}" 12:01:40 if [ "$#" -gt 0 ]; then 12:01:40 shift 12:01:40 fi 12:01:40 12:01:40 case "$command" in 12:01:40 rehash|shell) 12:01:40 eval "$(pyenv "sh-$command" "$@")" 12:01:40 ;; 12:01:40 *) 12:01:40 command pyenv "$command" "$@" 12:01:40 ;; 12:01:40 esac 12:01:40 }' 12:01:40 +++ bash --norc -ec 'IFS=:; paths=($PATH); 12:01:40 for i in ${!paths[@]}; do 12:01:40 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 12:01:40 fi; done; 12:01:40 echo "${paths[*]}"' 12:01:40 ++ 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 12:01:40 ++ 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 12:01:40 ++ 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 12:01:40 ++ export PYENV_SHELL=bash 12:01:40 ++ PYENV_SHELL=bash 12:01:40 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 12:01:40 +++ complete -F _pyenv pyenv 12:01:40 ++ lf-pyver python3 12:01:40 ++ local py_version_xy=python3 12:01:40 ++ local py_version_xyz= 12:01:40 ++ pyenv versions 12:01:40 ++ sed 's/^[ *]* //' 12:01:40 ++ grep -E '^[0-9.]*[0-9]$' 12:01:40 ++ local command 12:01:40 ++ command=versions 12:01:40 ++ '[' 1 -gt 0 ']' 12:01:40 ++ shift 12:01:40 ++ case "$command" in 12:01:40 ++ command pyenv versions 12:01:40 ++ awk '{ print $1 }' 12:01:40 ++ [[ ! -s /tmp/.pyenv_versions ]] 12:01:40 +++ sort -V 12:01:40 +++ tail -n 1 12:01:40 +++ grep '^3' /tmp/.pyenv_versions 12:01:40 ++ py_version_xyz=3.11.10 12:01:40 ++ [[ -z 3.11.10 ]] 12:01:40 ++ echo 3.11.10 12:01:40 ++ return 0 12:01:40 + pyenv local 3.11.10 12:01:40 + local command 12:01:40 + command=local 12:01:40 + '[' 2 -gt 0 ']' 12:01:40 + shift 12:01:40 + case "$command" in 12:01:40 + command pyenv local 3.11.10 12:01:40 + for arg in "$@" 12:01:40 + case $arg in 12:01:40 + pkg_list+='tox ' 12:01:40 + for arg in "$@" 12:01:40 + case $arg in 12:01:40 + pkg_list+='virtualenv ' 12:01:40 + for arg in "$@" 12:01:40 + case $arg in 12:01:40 + pkg_list+='urllib3~=1.26.15 ' 12:01:40 + [[ -f /tmp/.toxenv ]] 12:01:40 ++ cat /tmp/.toxenv 12:01:40 + lf_venv=/tmp/venv-BApA 12:01:40 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BApA from' file:/tmp/.toxenv 12:01:40 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BApA from file:/tmp/.toxenv 12:01:40 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 12:01:40 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:01:40 + local 'pip_opts=--upgrade --quiet' 12:01:40 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 12:01:40 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 12:01:40 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 12:01:40 + [[ -n '' ]] 12:01:40 + [[ -n '' ]] 12:01:40 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 12:01:40 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:01:40 + /tmp/venv-BApA/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 12:01:41 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 12:01:41 lf-activate-venv(): INFO: Base packages installed successfully 12:01:41 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 12:01:41 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 12:01:41 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 12:01:41 + /tmp/venv-BApA/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 12:01:42 + type python3 12:01:42 + true 12:01:42 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-BApA/bin to PATH' 12:01:42 lf-activate-venv(): INFO: Adding /tmp/venv-BApA/bin to PATH 12:01:42 + PATH=/tmp/venv-BApA/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 12:01:42 + return 0 12:01:42 + [[ -d /opt/pyenv ]] 12:01:42 + echo '---> Setting up pyenv' 12:01:42 ---> Setting up pyenv 12:01:42 + export PYENV_ROOT=/opt/pyenv 12:01:42 + PYENV_ROOT=/opt/pyenv 12:01:42 + export PATH=/opt/pyenv/bin:/tmp/venv-BApA/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 12:01:42 + PATH=/opt/pyenv/bin:/tmp/venv-BApA/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 12:01:42 ++ pwd 12:01:42 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 12:01:42 + export PYTHONPATH 12:01:42 + export TOX_TESTENV_PASSENV=PYTHONPATH 12:01:42 + TOX_TESTENV_PASSENV=PYTHONPATH 12:01:42 + tox --version 12:01:42 4.52.1 from /tmp/venv-BApA/lib/python3.11/site-packages/tox/__init__.py 12:01:42 + PARALLEL=True 12:01:42 + TOX_OPTIONS_LIST= 12:01:42 + [[ -n '' ]] 12:01:42 + case ${PARALLEL,,} in 12:01:42 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 12:01:42 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 12:01:42 + tox --parallel auto --parallel-live 12:01:44 checkbashisms: freeze> python -m pip freeze --all 12:01:44 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 12:01:44 docs: install_deps> python -I -m pip install -r docs/requirements.txt 12:01:44 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 12:01:45 checkbashisms: pip==26.0.1,setuptools==82.0.1 12:01:45 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 12:01:45 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)' 12:01:45 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 12:01:46 checkbashisms: OK ✔ in 3.19 seconds 12:01:46 pre-commit: install_deps> python -I -m pip install pre-commit 12:01:48 pre-commit: freeze> python -m pip freeze --all 12:01:49 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.25.2,identify==2.6.18,nodeenv==1.10.0,pip==26.0.1,platformdirs==4.9.6,pre_commit==4.5.1,python-discovery==1.2.2,PyYAML==6.0.3,setuptools==82.0.1,virtualenv==21.2.1 12:01:49 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 12:01:49 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)' 12:01:49 /usr/bin/cpan 12:01:49 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 12:01:49 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 12:01:49 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 12:01:50 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 12:01:50 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 12:01:50 [INFO] Initializing environment for https://github.com/hhatto/autopep8. 12:01:51 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 12:01:51 buildcontroller: freeze> python -m pip freeze --all 12:01:51 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:01:51 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 12:01:51 + update-java-alternatives -l 12:01:51 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 12:01:51 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 12:01:51 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 12:01:51 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 12:01:51 update-alternatives: error: no alternatives for jaotc 12:01:51 update-alternatives: error: no alternatives for rmic 12:01:51 + java -version 12:01:51 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 12:01:51 + JAVA_VER=21 12:01:51 + echo 21 12:01:51 21 12:01:51 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 12:01:51 + javac -version 12:01:51 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 12:01:51 + JAVAC_VER=21 12:01:51 + echo 21 12:01:51 + [ 21 -ge 21 ] 12:01:51 + [ 21 -ge 21 ] 12:01:51 + echo ok, java is 21 or newer 12:01:51 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 12:01:51 21 12:01:51 ok, java is 21 or newer 12:01:51 2026-04-10 12:01:51 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] 12:01:51 + sudo mkdir -p /opt 12:01:52 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 12:01:52 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 12:01:52 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 12:01:52 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 12:01:52 + mvn --version 12:01:52 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 12:01:52 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 12:01:52 Maven home: /opt/maven 12:01:52 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 12:01:52 Default locale: en, platform encoding: UTF-8 12:01:52 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 12:01:52 NOTE: Picked up JDK_JAVA_OPTIONS: 12:01:52 --add-opens=java.base/java.io=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.lang=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.net=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.nio=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.util=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:01:52 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:01:52 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:01:52 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:01:52 -Xlog:disable 12:01:52 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 12:01:53 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 12:01:53 [INFO] Once installed this environment will be reused. 12:01:53 [INFO] This may take a few minutes... 12:01:58 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 12:01:58 [INFO] Once installed this environment will be reused. 12:01:58 [INFO] This may take a few minutes... 12:02:06 [INFO] Installing environment for https://github.com/hhatto/autopep8. 12:02:06 [INFO] Once installed this environment will be reused. 12:02:06 [INFO] This may take a few minutes... 12:02:11 docs: freeze> python -m pip freeze --all 12:02:12 docs: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.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 12:02:12 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 12:02:12 [INFO] Installing environment for https://github.com/perltidy/perltidy. 12:02:12 [INFO] Once installed this environment will be reused. 12:02:12 [INFO] This may take a few minutes... 12:02:14 docs-linkcheck: freeze> python -m pip freeze --all 12:02:15 docs-linkcheck: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.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 12:02:15 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 12:02:16 docs: OK ✔ in 33.12 seconds 12:02:16 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 12:02:20 pylint: freeze> python -m pip freeze --all 12:02:20 docs-linkcheck: OK ✔ in 37.36 seconds 12:02:20 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 12:02:20 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}$' '{}' + 12:02:25 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 12:02:25 [INFO] Once installed this environment will be reused. 12:02:25 [INFO] This may take a few minutes... 12:02:29 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 12:02:29 [INFO] Once installed this environment will be reused. 12:02:29 [INFO] This may take a few minutes... 12:02:33 trim trailing whitespace.................................................Passed 12:02:34 fix end of files.........................................................Passed 12:02:34 check for added large files..............................................Passed 12:02:34 check for merge conflicts................................................Passed 12:02:35 check for case conflicts.................................................Passed 12:02:35 check json...............................................................Passed 12:02:35 mixed line ending........................................................Passed 12:02:35 Tabs remover.............................................................Passed 12:02:36 autopep8.................................................................Passed 12:02:39 perltidy.................................................................Passed 12:02:40 ShellCheck v0.11.0.......................................................Passed 12:02:45 prettier.................................................................Passed 12:02:47 yamllint.................................................................Passed 12:02:48 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 12:02:48 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 12:02:48 [INFO] Once installed this environment will be reused. 12:02:48 [INFO] This may take a few minutes... 12:02:48 12:02:48 ------------------------------------ 12:02:48 Your code has been rated at 10.00/10 12:02:48 12:02:57 gitlint..................................................................Passed 12:03:38 pylint: OK ✔ in 34.58 seconds 12:03:38 pre-commit: OK ✔ in 1 minute 11.02 seconds 12:03:38 buildcontroller: OK ✔ in 1 minute 54.09 seconds 12:03:38 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 12:03:38 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 12:03:38 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 12:03:38 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 12:03:45 build_karaf_tests190: freeze> python -m pip freeze --all 12:03:45 build_karaf_tests221: freeze> python -m pip freeze --all 12:03:45 build_karaf_tests121: freeze> python -m pip freeze --all 12:03:45 build_karaf_tests71: freeze> python -m pip freeze --all 12:03:45 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:03:45 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:03:45 build karaf in karafoc with ./karafoc.env 12:03:45 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:03:45 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:03:45 build karaf in karaf221 with ./karaf221.env 12:03:45 NOTE: Picked up JDK_JAVA_OPTIONS: 12:03:45 --add-opens=java.base/java.io=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.net=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:03:45 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:03:45 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:03:45 -Xlog:disable 12:03:45 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:03:45 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:03:45 build karaf in karaf121 with ./karaf121.env 12:03:45 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:03:45 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:03:45 build karaf in karaf71 with ./karaf71.env 12:03:45 NOTE: Picked up JDK_JAVA_OPTIONS: 12:03:45 --add-opens=java.base/java.io=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.net=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:03:45 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:03:45 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:03:45 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:03:45 -Xlog:disable 12:03:46 NOTE: Picked up JDK_JAVA_OPTIONS: 12:03:46 --add-opens=java.base/java.io=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.net=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:03:46 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:03:46 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:03:46 -Xlog:disable 12:03:46 NOTE: Picked up JDK_JAVA_OPTIONS: 12:03:46 --add-opens=java.base/java.io=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.net=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:03:46 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:03:46 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:03:46 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:03:46 -Xlog:disable 12:04:44 build_karaf_tests71: OK ✔ in 1 minute 7.64 seconds 12:04:44 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 12:04:46 build_karaf_tests221: OK ✔ in 1 minute 8.76 seconds 12:04:46 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 12:04:47 build_karaf_tests190: OK ✔ in 1 minute 10.08 seconds 12:04:47 build_karaf_tests121: OK ✔ in 1 minute 10.13 seconds 12:04:47 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 12:04:53 sims: freeze> python -m pip freeze --all 12:04:53 buildlighty: freeze> python -m pip freeze --all 12:04:54 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:04:54 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 12:04:54 Using lighynode version 22.1.0.6 12:04:54 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 12:04:54 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:04:54 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 12:04:54 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 12:05:35 sims: OK ✔ in 10.66 seconds 12:05:35 buildlighty: OK ✔ in 39.23 seconds 12:05:35 testsPCE: freeze> python -m pip freeze --all 12:05:36 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.3,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.2.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.3,python-dateutil==2.9.0.post0,pytz==2026.1.post1,requests==2.33.1,scipy==1.17.1,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 12:05:36 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 12:05:36 pytest -q transportpce_tests/pce/test01_pce.py 12:06:22 .................... [100%] 12:07:26 20 passed in 110.32s (0:01:50) 12:07:26 pytest -q transportpce_tests/pce/test02_pce_400G.py 12:07:43 ............ [100%] 12:08:14 12 passed in 47.06s 12:08:14 pytest -q transportpce_tests/pce/test03_gnpy.py 12:08:30 ........ [100%] 12:08:52 8 passed in 37.82s 12:08:52 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 12:09:24 ... [100%] 12:09:29 3 passed in 36.61s 12:09:29 testsPCE: OK ✔ in 4 minutes 41.87 seconds 12:09:29 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 12:09:29 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 12:09:29 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 12:09:38 tests_tapi: freeze> python -m pip freeze --all 12:09:38 tests190: freeze> python -m pip freeze --all 12:09:38 tests121: freeze> python -m pip freeze --all 12:09:38 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:09:38 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 12:09:38 using environment variables from ./karaf221.env 12:09:38 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 12:09:38 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:09:38 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 12:09:38 using environment variables from ./karafoc.env 12:09:38 pytest -q transportpce_tests/oc/test01_portmapping.py 12:09:38 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:09:38 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 12:09:38 using environment variables from ./karaf121.env 12:09:38 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 12:10:41 ........... [100%] 12:10:58 10 passed in 79.26s (0:01:19) 12:10:58 pytest -q transportpce_tests/oc/test02_topology.py 12:11:05 ................................ [100%] 12:11:44 21 passed in 125.93s (0:02:05) 12:11:45 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 12:11:46 ......................... [100%] 12:12:04 14 passed in 66.11s (0:01:06) 12:12:04 pytest -q transportpce_tests/oc/test03_renderer.py 12:12:05 ..................... [100%] 12:12:50 6 passed in 65.54s (0:01:05) 12:12:51 pytest -q transportpce_tests/1.2.1/test03_topology.py 12:12:51 .................. [100%] 12:13:07 19 passed in 61.94s (0:01:01) 12:13:07 tests190: OK ✔ in 3 minutes 38.13 seconds 12:13:07 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 12:13:15 .tests71: freeze> python -m pip freeze --all 12:13:16 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:13:16 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 12:13:16 using environment variables from ./karaf71.env 12:13:16 pytest -q transportpce_tests/7.1/test01_portmapping.py 12:13:36 ............................. [100%] 12:14:15 12 passed in 58.72s 12:14:15 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 12:14:16 .................................................... [100%] 12:15:25 44 passed in 154.18s (0:02:34) 12:15:25 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 12:15:25 .................................................................. [100%] 12:16:51 24 passed in 85.93s (0:01:25) 12:16:51 pytest -q transportpce_tests/1.2.1/test05_olm.py 12:16:51 . [100%] 12:16:53 62 passed in 158.04s (0:02:38) 12:16:54 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 12:17:43 ............................................................................. [100%] 12:19:29 48 passed in 154.81s (0:02:34) 12:19:29 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 12:19:36 ....................... [100%] 12:20:16 40 passed in 204.54s (0:03:24) 12:20:16 pytest -q transportpce_tests/1.2.1/test06_end2end.py 12:20:17 .............. [100%] 12:20:45 22 passed in 76.04s (0:01:16) 12:20:59 .......................................... [100%] 12:23:55 51 passed in 856.71s (0:14:16) 12:23:55 pytest -q transportpce_tests/tapi/test02_full_topology.py 12:24:04 .....................F............................ [100%] 12:29:15 54 passed in 538.94s (0:08:58) 12:29:55 F [100%] 12:29:58 =================================== FAILURES =================================== 12:29:58 ________ TestTransportPCEFullTopology.test_13_get_tapi_topology_details ________ 12:29:58 12:29:58 self = 12:29:58 12:29:58 def test_13_get_tapi_topology_details(self): 12:29:58 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 12:29:58 response = test_utils.transportpce_api_rpc_request( 12:29:58 'tapi-topology', 'get-topology-details', self.tapi_topo) 12:29:58 time.sleep(2) 12:29:58 self.assertEqual(response['status_code'], requests.codes.ok) 12:29:58 self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 12:29:58 > self.assertEqual(len(response['output']['topology']['link']), 3, 'There should be 3 TAPI links') 12:29:58 E AssertionError: 1 != 3 : There should be 3 TAPI links 12:29:58 12:29:58 transportpce_tests/tapi/test02_full_topology.py:307: AssertionError 12:29:58 ______ TestTransportPCEFullTopology.test_35_check_uninstall_Tapi_Feature _______ 12:29:58 12:29:58 self = 12:29:58 conn = 12:29:58 method = 'GET' 12:29:58 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 12:29:58 body = None 12:29:58 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='} 12:29:58 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 12:29:58 timeout = Timeout(connect=30, read=30, total=None), chunked = False 12:29:58 response_conn = 12:29:58 preload_content = False, decode_content = False, enforce_content_length = True 12:29:58 12:29:58 def _make_request( 12:29:58 self, 12:29:58 conn: BaseHTTPConnection, 12:29:58 method: str, 12:29:58 url: str, 12:29:58 body: _TYPE_BODY | None = None, 12:29:58 headers: typing.Mapping[str, str] | None = None, 12:29:58 retries: Retry | None = None, 12:29:58 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 12:29:58 chunked: bool = False, 12:29:58 response_conn: BaseHTTPConnection | None = None, 12:29:58 preload_content: bool = True, 12:29:58 decode_content: bool = True, 12:29:58 enforce_content_length: bool = True, 12:29:58 ) -> BaseHTTPResponse: 12:29:58 """ 12:29:58 Perform a request on a given urllib connection object taken from our 12:29:58 pool. 12:29:58 12:29:58 :param conn: 12:29:58 a connection from one of our connection pools 12:29:58 12:29:58 :param method: 12:29:58 HTTP request method (such as GET, POST, PUT, etc.) 12:29:58 12:29:58 :param url: 12:29:58 The URL to perform the request on. 12:29:58 12:29:58 :param body: 12:29:58 Data to send in the request body, either :class:`str`, :class:`bytes`, 12:29:58 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 12:29:58 12:29:58 :param headers: 12:29:58 Dictionary of custom headers to send, such as User-Agent, 12:29:58 If-None-Match, etc. If None, pool headers are used. If provided, 12:29:58 these headers completely replace any pool-specific headers. 12:29:58 12:29:58 :param retries: 12:29:58 Configure the number of retries to allow before raising a 12:29:58 :class:`~urllib3.exceptions.MaxRetryError` exception. 12:29:58 12:29:58 Pass ``None`` to retry until you receive a response. Pass a 12:29:58 :class:`~urllib3.util.retry.Retry` object for fine-grained control 12:29:58 over different types of retries. 12:29:58 Pass an integer number to retry connection errors that many times, 12:29:58 but no other types of errors. Pass zero to never retry. 12:29:58 12:29:58 If ``False``, then retries are disabled and any exception is raised 12:29:58 immediately. Also, instead of raising a MaxRetryError on redirects, 12:29:58 the redirect response will be returned. 12:29:58 12:29:58 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 12:29:58 12:29:58 :param timeout: 12:29:58 If specified, overrides the default timeout for this one 12:29:58 request. It may be a float (in seconds) or an instance of 12:29:58 :class:`urllib3.util.Timeout`. 12:29:58 12:29:58 :param chunked: 12:29:58 If True, urllib3 will send the body using chunked transfer 12:29:58 encoding. Otherwise, urllib3 will send the body using the standard 12:29:58 content-length form. Defaults to False. 12:29:58 12:29:58 :param response_conn: 12:29:58 Set this to ``None`` if you will handle releasing the connection or 12:29:58 set the connection to have the response release it. 12:29:58 12:29:58 :param preload_content: 12:29:58 If True, the response's body will be preloaded during construction. 12:29:58 12:29:58 :param decode_content: 12:29:58 If True, will attempt to decode the body based on the 12:29:58 'content-encoding' header. 12:29:58 12:29:58 :param enforce_content_length: 12:29:58 Enforce content length checking. Body returned by server must match 12:29:58 value of Content-Length header, if present. Otherwise, raise error. 12:29:58 """ 12:29:58 self.num_requests += 1 12:29:58 12:29:58 timeout_obj = self._get_timeout(timeout) 12:29:58 timeout_obj.start_connect() 12:29:58 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 12:29:58 12:29:58 try: 12:29:58 # Trigger any extra validation we need to do. 12:29:58 try: 12:29:58 self._validate_conn(conn) 12:29:58 except (SocketTimeout, BaseSSLError) as e: 12:29:58 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 12:29:58 raise 12:29:58 12:29:58 # _validate_conn() starts the connection to an HTTPS proxy 12:29:58 # so we need to wrap errors with 'ProxyError' here too. 12:29:58 except ( 12:29:58 OSError, 12:29:58 NewConnectionError, 12:29:58 TimeoutError, 12:29:58 BaseSSLError, 12:29:58 CertificateError, 12:29:58 SSLError, 12:29:58 ) as e: 12:29:58 new_e: Exception = e 12:29:58 if isinstance(e, (BaseSSLError, CertificateError)): 12:29:58 new_e = SSLError(e) 12:29:58 # If the connection didn't successfully connect to it's proxy 12:29:58 # then there 12:29:58 if isinstance( 12:29:58 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 12:29:58 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 12:29:58 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 12:29:58 raise new_e 12:29:58 12:29:58 # conn.request() calls http.client.*.request, not the method in 12:29:58 # urllib3.request. It also calls makefile (recv) on the socket. 12:29:58 try: 12:29:58 conn.request( 12:29:58 method, 12:29:58 url, 12:29:58 body=body, 12:29:58 headers=headers, 12:29:58 chunked=chunked, 12:29:58 preload_content=preload_content, 12:29:58 decode_content=decode_content, 12:29:58 enforce_content_length=enforce_content_length, 12:29:58 ) 12:29:58 12:29:58 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 12:29:58 # legitimately able to close the connection after sending a valid response. 12:29:58 # With this behaviour, the received response is still readable. 12:29:58 except BrokenPipeError: 12:29:58 pass 12:29:58 except OSError as e: 12:29:58 # MacOS/Linux 12:29:58 # EPROTOTYPE and ECONNRESET are needed on macOS 12:29:58 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 12:29:58 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 12:29:58 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 12:29:58 raise 12:29:58 12:29:58 # Reset the timeout for the recv() on the socket 12:29:58 read_timeout = timeout_obj.read_timeout 12:29:58 12:29:58 if not conn.is_closed: 12:29:58 # In Python 3 socket.py will catch EAGAIN and return None when you 12:29:58 # try and read into the file pointer created by http.client, which 12:29:58 # instead raises a BadStatusLine exception. Instead of catching 12:29:58 # the exception and assuming all BadStatusLine exceptions are read 12:29:58 # timeouts, check for a zero timeout before making the request. 12:29:58 if read_timeout == 0: 12:29:58 raise ReadTimeoutError( 12:29:58 self, url, f"Read timed out. (read timeout={read_timeout})" 12:29:58 ) 12:29:58 conn.timeout = read_timeout 12:29:58 12:29:58 # Receive the response from the server 12:29:58 try: 12:29:58 > response = conn.getresponse() 12:29:58 ^^^^^^^^^^^^^^^^^^ 12:29:58 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 12:29:58 httplib_response = super().getresponse() 12:29:58 ^^^^^^^^^^^^^^^^^^^^^ 12:29:58 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 12:29:58 response.begin() 12:29:58 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 12:29:58 version, status, reason = self._read_status() 12:29:58 ^^^^^^^^^^^^^^^^^^^ 12:29:58 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 12:29:58 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 12:29:58 self = 12:29:58 b = 12:29:58 12:29:58 def readinto(self, b): 12:29:58 """Read up to len(b) bytes into the writable buffer *b* and return 12:29:58 the number of bytes read. If the socket is non-blocking and no bytes 12:29:58 are available, None is returned. 12:29:58 12:29:58 If *b* is non-empty, a 0 return value indicates that the connection 12:29:58 was shutdown at the other end. 12:29:58 """ 12:29:58 self._checkClosed() 12:29:58 self._checkReadable() 12:29:58 if self._timeout_occurred: 12:29:58 raise OSError("cannot read from timed out object") 12:29:58 while True: 12:29:58 try: 12:29:58 > return self._sock.recv_into(b) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 E TimeoutError: timed out 12:29:58 12:29:58 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 12:29:58 12:29:58 The above exception was the direct cause of the following exception: 12:29:58 12:29:58 self = 12:29:58 request = , stream = False 12:29:58 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 12:29:58 proxies = OrderedDict() 12:29:58 12:29:58 def send( 12:29:58 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:29:58 ): 12:29:58 """Sends PreparedRequest object. Returns Response object. 12:29:58 12:29:58 :param request: The :class:`PreparedRequest ` being sent. 12:29:58 :param stream: (optional) Whether to stream the request content. 12:29:58 :param timeout: (optional) How long to wait for the server to send 12:29:58 data before giving up, as a float, or a :ref:`(connect timeout, 12:29:58 read timeout) ` tuple. 12:29:58 :type timeout: float or tuple or urllib3 Timeout object 12:29:58 :param verify: (optional) Either a boolean, in which case it controls whether 12:29:58 we verify the server's TLS certificate, or a string, in which case it 12:29:58 must be a path to a CA bundle to use 12:29:58 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:29:58 :param proxies: (optional) The proxies dictionary to apply to the request. 12:29:58 :rtype: requests.Response 12:29:58 """ 12:29:58 12:29:58 try: 12:29:58 conn = self.get_connection_with_tls_context( 12:29:58 request, verify, proxies=proxies, cert=cert 12:29:58 ) 12:29:58 except LocationValueError as e: 12:29:58 raise InvalidURL(e, request=request) 12:29:58 12:29:58 self.cert_verify(conn, request.url, verify, cert) 12:29:58 url = self.request_url(request, proxies) 12:29:58 self.add_headers( 12:29:58 request, 12:29:58 stream=stream, 12:29:58 timeout=timeout, 12:29:58 verify=verify, 12:29:58 cert=cert, 12:29:58 proxies=proxies, 12:29:58 ) 12:29:58 12:29:58 chunked = not (request.body is None or "Content-Length" in request.headers) 12:29:58 12:29:58 if isinstance(timeout, tuple): 12:29:58 try: 12:29:58 connect, read = timeout 12:29:58 timeout = TimeoutSauce(connect=connect, read=read) 12:29:58 except ValueError: 12:29:58 raise ValueError( 12:29:58 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:29:58 f"or a single float to set both timeouts to the same value." 12:29:58 ) 12:29:58 elif isinstance(timeout, TimeoutSauce): 12:29:58 pass 12:29:58 else: 12:29:58 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:29:58 12:29:58 try: 12:29:58 > resp = conn.urlopen( 12:29:58 method=request.method, 12:29:58 url=url, 12:29:58 body=request.body, 12:29:58 headers=request.headers, 12:29:58 redirect=False, 12:29:58 assert_same_host=False, 12:29:58 preload_content=False, 12:29:58 decode_content=False, 12:29:58 retries=self.max_retries, 12:29:58 timeout=timeout, 12:29:58 chunked=chunked, 12:29:58 ) 12:29:58 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:645: 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 12:29:58 retries = retries.increment( 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 12:29:58 raise reraise(type(error), error, _stacktrace) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 12:29:58 raise value 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 12:29:58 response = self._make_request( 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 12:29:58 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 12:29:58 self = 12:29:58 err = TimeoutError('timed out') 12:29:58 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 12:29:58 timeout_value = 30 12:29:58 12:29:58 def _raise_timeout( 12:29:58 self, 12:29:58 err: BaseSSLError | OSError | SocketTimeout, 12:29:58 url: str, 12:29:58 timeout_value: _TYPE_TIMEOUT | None, 12:29:58 ) -> None: 12:29:58 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 12:29:58 12:29:58 if isinstance(err, SocketTimeout): 12:29:58 > raise ReadTimeoutError( 12:29:58 self, url, f"Read timed out. (read timeout={timeout_value})" 12:29:58 ) from err 12:29:58 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 12:29:58 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 12:29:58 12:29:58 During handling of the above exception, another exception occurred: 12:29:58 12:29:58 self = 12:29:58 12:29:58 def test_35_check_uninstall_Tapi_Feature(self): 12:29:58 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 12:29:58 time.sleep(16) 12:29:58 print("Tapi Feature uninstalled") 12:29:58 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 12:29:58 transportpce_tests/tapi/test02_full_topology.py:787: 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 12:29:58 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 transportpce_tests/common/test_utils.py:117: in get_request 12:29:58 return requests.request( 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 12:29:58 return session.request(method=method, url=url, **kwargs) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:592: in request 12:29:58 resp = self.send(prep, **send_kwargs) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:706: in send 12:29:58 r = adapter.send(request, **kwargs) 12:29:58 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 12:29:58 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 12:29:58 12:29:58 self = 12:29:58 request = , stream = False 12:29:58 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 12:29:58 proxies = OrderedDict() 12:29:58 12:29:58 def send( 12:29:58 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 12:29:58 ): 12:29:58 """Sends PreparedRequest object. Returns Response object. 12:29:58 12:29:58 :param request: The :class:`PreparedRequest ` being sent. 12:29:58 :param stream: (optional) Whether to stream the request content. 12:29:58 :param timeout: (optional) How long to wait for the server to send 12:29:58 data before giving up, as a float, or a :ref:`(connect timeout, 12:29:58 read timeout) ` tuple. 12:29:58 :type timeout: float or tuple or urllib3 Timeout object 12:29:58 :param verify: (optional) Either a boolean, in which case it controls whether 12:29:58 we verify the server's TLS certificate, or a string, in which case it 12:29:58 must be a path to a CA bundle to use 12:29:58 :param cert: (optional) Any user-provided SSL certificate to be trusted. 12:29:58 :param proxies: (optional) The proxies dictionary to apply to the request. 12:29:58 :rtype: requests.Response 12:29:58 """ 12:29:58 12:29:58 try: 12:29:58 conn = self.get_connection_with_tls_context( 12:29:58 request, verify, proxies=proxies, cert=cert 12:29:58 ) 12:29:58 except LocationValueError as e: 12:29:58 raise InvalidURL(e, request=request) 12:29:58 12:29:58 self.cert_verify(conn, request.url, verify, cert) 12:29:58 url = self.request_url(request, proxies) 12:29:58 self.add_headers( 12:29:58 request, 12:29:58 stream=stream, 12:29:58 timeout=timeout, 12:29:58 verify=verify, 12:29:58 cert=cert, 12:29:58 proxies=proxies, 12:29:58 ) 12:29:58 12:29:58 chunked = not (request.body is None or "Content-Length" in request.headers) 12:29:58 12:29:58 if isinstance(timeout, tuple): 12:29:58 try: 12:29:58 connect, read = timeout 12:29:58 timeout = TimeoutSauce(connect=connect, read=read) 12:29:58 except ValueError: 12:29:58 raise ValueError( 12:29:58 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 12:29:58 f"or a single float to set both timeouts to the same value." 12:29:58 ) 12:29:58 elif isinstance(timeout, TimeoutSauce): 12:29:58 pass 12:29:58 else: 12:29:58 timeout = TimeoutSauce(connect=timeout, read=timeout) 12:29:58 12:29:58 try: 12:29:58 resp = conn.urlopen( 12:29:58 method=request.method, 12:29:58 url=url, 12:29:58 body=request.body, 12:29:58 headers=request.headers, 12:29:58 redirect=False, 12:29:58 assert_same_host=False, 12:29:58 preload_content=False, 12:29:58 decode_content=False, 12:29:58 retries=self.max_retries, 12:29:58 timeout=timeout, 12:29:58 chunked=chunked, 12:29:58 ) 12:29:58 12:29:58 except (ProtocolError, OSError) as err: 12:29:58 raise ConnectionError(err, request=request) 12:29:58 12:29:58 except MaxRetryError as e: 12:29:58 if isinstance(e.reason, ConnectTimeoutError): 12:29:58 # TODO: Remove this in 3.0.0: see #2811 12:29:58 if not isinstance(e.reason, NewConnectionError): 12:29:58 raise ConnectTimeout(e, request=request) 12:29:58 12:29:58 if isinstance(e.reason, ResponseError): 12:29:58 raise RetryError(e, request=request) 12:29:58 12:29:58 if isinstance(e.reason, _ProxyError): 12:29:58 raise ProxyError(e, request=request) 12:29:58 12:29:58 if isinstance(e.reason, _SSLError): 12:29:58 # This branch is for urllib3 v1.22 and later. 12:29:58 raise SSLError(e, request=request) 12:29:58 12:29:58 raise ConnectionError(e, request=request) 12:29:58 12:29:58 except ClosedPoolError as e: 12:29:58 raise ConnectionError(e, request=request) 12:29:58 12:29:58 except _ProxyError as e: 12:29:58 raise ProxyError(e) 12:29:58 12:29:58 except (_SSLError, _HTTPError) as e: 12:29:58 if isinstance(e, _SSLError): 12:29:58 # This branch is for urllib3 versions earlier than v1.22 12:29:58 raise SSLError(e, request=request) 12:29:58 elif isinstance(e, ReadTimeoutError): 12:29:58 > raise ReadTimeout(e, request=request) 12:29:58 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 12:29:58 12:29:58 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:691: ReadTimeout 12:29:58 ----------------------------- Captured stdout call ----------------------------- 12:29:58 uninstalling feature odl-transportpce-tapi 12:29:58 client: JAVA_HOME not set; results may vary 12:29:58 odl-transportpce-tapi │ 13.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 12:29:58 Tapi Feature uninstalled 12:29:58 --------------------------- Captured stdout teardown --------------------------- 12:29:58 all processes killed 12:29:58 ODL log file stored 12:29:58 =========================== short test summary info ============================ 12:29:58 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_13_get_tapi_topology_details 12:29:58 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_35_check_uninstall_Tapi_Feature 12:29:58 2 failed, 34 passed in 362.81s (0:06:02) 12:29:58 tests71: OK ✔ in 7 minutes 38.2 seconds 12:29:58 tests121: OK ✔ in 19 minutes 46.77 seconds 12:29:58 tests_tapi: exit 1 (1220.35 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7530 12:29:58 tests_tapi: FAIL ✖ in 20 minutes 29.54 seconds 12:29:58 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 12:30:05 tests221: freeze> python -m pip freeze --all 12:30:06 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.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:30:06 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 12:30:06 using environment variables from ./karaf221.env 12:30:06 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 12:30:44 ................................... [100%] 12:31:24 35 passed in 77.62s (0:01:17) 12:31:24 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 12:31:56 ...... [100%] 12:32:10 6 passed in 45.67s 12:32:10 pytest -q transportpce_tests/2.2.1/test03_topology.py 12:32:53 ............................................ [100%] 12:37:28 44 passed in 318.08s (0:05:18) 12:37:28 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 12:38:04 ............ [100%] 12:38:28 12 passed in 59.63s 12:38:28 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 12:38:53 ................ [100%] 12:40:23 16 passed in 114.37s (0:01:54) 12:40:23 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 12:40:55 ............................... [100%] 12:41:03 31 passed in 39.55s 12:41:03 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 12:41:40 .......................... [100%] 12:42:37 26 passed in 93.91s (0:01:33) 12:42:37 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 12:43:16 ...................... [100%] 12:44:21 22 passed in 103.99s (0:01:43) 12:44:21 pytest -q transportpce_tests/2.2.1/test09_olm.py 12:45:07 ........................................ [100%] 12:50:31 40 passed in 369.43s (0:06:09) 12:50:31 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 12:51:18 ........................................................................ [ 74%] 12:56:56 ......................... [100%] 12:58:49 97 passed in 497.29s (0:08:17) 12:58:49 pytest -q transportpce_tests/2.2.1/test12_end2end.py 12:59:32 ...................................................... [100%] 13:09:21 54 passed in 631.67s (0:10:31) 13:09:21 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 13:10:18 ........................................................................ [ 71%] 13:15:27 ............................. [100%] 13:20:36 101 passed in 674.87s (0:11:14) 13:20:36 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 13:21:33 ........................................................................ [ 67%] 13:27:20 ................................... [100%] 13:30:41 107 passed in 604.89s (0:10:04) 13:30:41 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 13:31:28 ............................................. [100%] 13:34:06 45 passed in 204.92s (0:03:24) 13:34:06 tests221: OK ✔ in 1 hour 4 minutes 8.04 seconds 13:34:06 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 13:34:13 tests_hybrid: freeze> python -m pip freeze --all 13:34:14 tests_hybrid: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.3,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 13:34:14 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 13:34:14 using environment variables from ./karaf221.env 13:34:14 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 13:34:58 ................................................... [100%] 13:36:45 51 passed in 151.59s (0:02:31) 13:36:46 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 13:37:32 ........................................................................ [ 66%] 13:41:54 ..................................... [100%] 13:44:00 109 passed in 434.50s (0:07:14) 13:44:00 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 13:44:54 ..................................................... [100%] 13:48:28 53 passed in 267.20s (0:04:27) 13:48:28 buildcontroller: OK (114.09=setup[8.28]+cmd[105.81] seconds) 13:48:28 sims: OK (10.66=setup[8.03]+cmd[2.63] seconds) 13:48:28 build_karaf_tests121: OK (70.13=setup[8.66]+cmd[61.47] seconds) 13:48:28 testsPCE: OK (281.87=setup[48.79]+cmd[233.08] seconds) 13:48:28 tests121: OK (1186.77=setup[9.41]+cmd[1177.37] seconds) 13:48:28 build_karaf_tests221: OK (68.76=setup[8.60]+cmd[60.17] seconds) 13:48:28 tests_tapi: FAIL code 1 (1229.54=setup[9.19]+cmd[1220.35] seconds) 13:48:28 tests221: OK (3848.04=setup[7.40]+cmd[3840.64] seconds) 13:48:28 build_karaf_tests71: OK (67.63=setup[8.70]+cmd[58.93] seconds) 13:48:28 tests71: OK (458.20=setup[9.05]+cmd[449.15] seconds) 13:48:28 build_karaf_tests190: OK (70.07=setup[8.53]+cmd[61.54] seconds) 13:48:28 tests190: OK (218.13=setup[9.32]+cmd[208.81] seconds) 13:48:28 tests_hybrid: OK (861.53=setup[7.26]+cmd[854.27] seconds) 13:48:28 buildlighty: OK (39.23=setup[9.21]+cmd[30.02] seconds) 13:48:28 docs: OK (33.12=setup[29.02]+cmd[4.10] seconds) 13:48:28 docs-linkcheck: OK (37.36=setup[31.88]+cmd[5.49] seconds) 13:48:28 checkbashisms: OK (3.19=setup[1.89]+cmd[0.01,0.04,1.25] seconds) 13:48:28 pre-commit: OK (71.02=setup[2.82]+cmd[0.01,0.01,58.89,9.30] seconds) 13:48:28 pylint: OK (34.58=setup[4.39]+cmd[30.18] seconds) 13:48:28 evaluation failed :( (6405.26 seconds) 13:48:28 + tox_status=1 13:48:28 + echo '---> Completed tox runs' 13:48:28 ---> Completed tox runs 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/build_karaf_tests121/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=build_karaf_tests121 13:48:28 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/build_karaf_tests190/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=build_karaf_tests190 13:48:28 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/build_karaf_tests221/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=build_karaf_tests221 13:48:28 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/build_karaf_tests71/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=build_karaf_tests71 13:48:28 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/buildcontroller/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=buildcontroller 13:48:28 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/buildlighty/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=buildlighty 13:48:28 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/checkbashisms/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=checkbashisms 13:48:28 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/docs-linkcheck/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=docs-linkcheck 13:48:28 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/docs/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=docs 13:48:28 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/pre-commit/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=pre-commit 13:48:28 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/pylint/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=pylint 13:48:28 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/sims/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=sims 13:48:28 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests121/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests121 13:48:28 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests190/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests190 13:48:28 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests221/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests221 13:48:28 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests71/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests71 13:48:28 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/testsPCE/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=testsPCE 13:48:28 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests_hybrid/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests_hybrid 13:48:28 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 13:48:28 + for i in .tox/*/log 13:48:28 ++ echo .tox/tests_tapi/log 13:48:28 ++ awk -F/ '{print $2}' 13:48:28 + tox_env=tests_tapi 13:48:28 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 13:48:28 + DOC_DIR=docs/_build/html 13:48:28 + [[ -d docs/_build/html ]] 13:48:28 + echo '---> Archiving generated docs' 13:48:28 ---> Archiving generated docs 13:48:28 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:48:28 + echo '---> tox-run.sh ends' 13:48:28 ---> tox-run.sh ends 13:48:28 + test 1 -eq 0 13:48:28 + exit 1 13:48:28 ++ '[' 1 = 1 ']' 13:48:28 ++ '[' -x /usr/bin/clear_console ']' 13:48:28 ++ /usr/bin/clear_console -q 13:48:28 Build step 'Execute shell' marked build as failure 13:48:28 $ ssh-agent -k 13:48:28 unset SSH_AUTH_SOCK; 13:48:28 unset SSH_AGENT_PID; 13:48:28 echo Agent pid 1566 killed; 13:48:28 [ssh-agent] Stopped. 13:48:28 [PostBuildScript] - [INFO] Executing post build scripts. 13:48:28 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7895042623268311726.sh 13:48:28 ---> sysstat.sh 13:48:29 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4890003332840974126.sh 13:48:29 ---> package-listing.sh 13:48:29 ++ facter osfamily 13:48:29 ++ tr '[:upper:]' '[:lower:]' 13:48:29 + OS_FAMILY=debian 13:48:29 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 13:48:29 + START_PACKAGES=/tmp/packages_start.txt 13:48:29 + END_PACKAGES=/tmp/packages_end.txt 13:48:29 + DIFF_PACKAGES=/tmp/packages_diff.txt 13:48:29 + PACKAGES=/tmp/packages_start.txt 13:48:29 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:48:29 + PACKAGES=/tmp/packages_end.txt 13:48:29 + case "${OS_FAMILY}" in 13:48:29 + dpkg -l 13:48:29 + grep '^ii' 13:48:29 + '[' -f /tmp/packages_start.txt ']' 13:48:29 + '[' -f /tmp/packages_end.txt ']' 13:48:29 + diff /tmp/packages_start.txt /tmp/packages_end.txt 13:48:29 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:48:29 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:48:29 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:48:29 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16967016133609617930.sh 13:48:29 ---> capture-instance-metadata.sh 13:48:29 Setup pyenv: 13:48:30 system 13:48:30 3.8.20 13:48:30 3.9.20 13:48:30 3.10.15 13:48:30 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:48:30 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-EySj from file:/tmp/.os_lf_venv 13:48:30 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:48:30 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:48:32 lf-activate-venv(): INFO: Base packages installed successfully 13:48:32 lf-activate-venv(): INFO: Installing additional packages: lftools 13:48:46 lf-activate-venv(): INFO: Adding /tmp/venv-EySj/bin to PATH 13:48:46 INFO: Running in OpenStack, capturing instance metadata 13:48:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10038648003263200160.sh 13:48:47 provisioning config files... 13:48:47 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #5101 13:48:47 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config2342250431473268121tmp 13:48:47 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 13:48:47 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 13:48:47 provisioning config files... 13:48:47 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 13:48:47 [EnvInject] - Injecting environment variables from a build step. 13:48:47 [EnvInject] - Injecting as environment variables the properties content 13:48:47 SERVER_ID=logs 13:48:47 13:48:47 [EnvInject] - Variables injected successfully. 13:48:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15521923305790860860.sh 13:48:47 ---> create-netrc.sh 13:48:47 WARN: Log server credential not found. 13:48:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10566974974013617950.sh 13:48:47 ---> python-tools-install.sh 13:48:47 Setup pyenv: 13:48:47 system 13:48:47 3.8.20 13:48:47 3.9.20 13:48:47 3.10.15 13:48:47 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:48:48 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-EySj from file:/tmp/.os_lf_venv 13:48:48 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:48:48 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:48:49 lf-activate-venv(): INFO: Base packages installed successfully 13:48:49 lf-activate-venv(): INFO: Installing additional packages: lftools 13:48:59 lf-activate-venv(): INFO: Adding /tmp/venv-EySj/bin to PATH 13:48:59 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins10031445151691007344.sh 13:48:59 ---> uv-install.sh 13:48:59 uv 0.11.6 is already installed 13:48:59 uvx 0.11.6 (x86_64-unknown-linux-gnu) 13:48:59 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14298299848107628045.sh 13:48:59 ---> sudo-logs.sh 13:48:59 Archiving 'sudo' log.. 13:49:00 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4462946878515840431.sh 13:49:00 ---> job-cost.sh 13:49:00 INFO: Activating Python virtual environment... 13:49:00 Setup pyenv: 13:49:00 system 13:49:00 3.8.20 13:49:00 3.9.20 13:49:00 3.10.15 13:49:00 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:49:00 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-EySj from file:/tmp/.os_lf_venv 13:49:00 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:49:00 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:49:02 lf-activate-venv(): INFO: Base packages installed successfully 13:49:02 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 13:49:09 lf-activate-venv(): INFO: Adding /tmp/venv-EySj/bin to PATH 13:49:09 INFO: No stack-cost file found 13:49:09 INFO: Instance uptime: 6570s 13:49:09 INFO: Fetching instance metadata (attempt 1 of 3)... 13:49:09 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 13:49:09 INFO: Successfully fetched instance metadata 13:49:09 INFO: Instance type: v3-standard-4 13:49:09 INFO: Retrieving pricing info for: v3-standard-4 13:49:09 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 13:49:09 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=6570 13:49:09 INFO: Successfully fetched Vexxhost pricing API 13:49:09 INFO: Retrieved cost: 0.22 13:49:09 INFO: Retrieved resource: v3-standard-4 13:49:09 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 13:49:09 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 13:49:09 INFO: Successfully archived job cost data 13:49:09 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,5101,2026-04-10 13:49:09,v3-standard-4,6570,0.22,0.00,FAILURE 13:49:09 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins2982941639755136274.sh 13:49:09 ---> logs-deploy.sh 13:49:09 Setup pyenv: 13:49:10 system 13:49:10 3.8.20 13:49:10 3.9.20 13:49:10 3.10.15 13:49:10 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:49:10 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-EySj from file:/tmp/.os_lf_venv 13:49:10 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:49:10 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:49:12 lf-activate-venv(): INFO: Base packages installed successfully 13:49:12 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 13:49:21 lf-activate-venv(): INFO: Adding /tmp/venv-EySj/bin to PATH 13:49:21 WARNING: Nexus logging server not set 13:49:21 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/5101/ 13:49:21 INFO: archiving logs to S3 13:49:23 ---> uname -a: 13:49:23 Linux prd-ubuntu2204-docker-4c-16g-1788 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 13:49:23 13:49:23 13:49:23 ---> lscpu: 13:49:23 Architecture: x86_64 13:49:23 CPU op-mode(s): 32-bit, 64-bit 13:49:23 Address sizes: 40 bits physical, 48 bits virtual 13:49:23 Byte Order: Little Endian 13:49:23 CPU(s): 4 13:49:23 On-line CPU(s) list: 0-3 13:49:23 Vendor ID: AuthenticAMD 13:49:23 Model name: AMD EPYC-Rome Processor 13:49:23 CPU family: 23 13:49:23 Model: 49 13:49:23 Thread(s) per core: 1 13:49:23 Core(s) per socket: 1 13:49:23 Socket(s): 4 13:49:23 Stepping: 0 13:49:23 BogoMIPS: 5599.99 13:49:23 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 13:49:23 Virtualization: AMD-V 13:49:23 Hypervisor vendor: KVM 13:49:23 Virtualization type: full 13:49:23 L1d cache: 128 KiB (4 instances) 13:49:23 L1i cache: 128 KiB (4 instances) 13:49:23 L2 cache: 2 MiB (4 instances) 13:49:23 L3 cache: 64 MiB (4 instances) 13:49:23 NUMA node(s): 1 13:49:23 NUMA node0 CPU(s): 0-3 13:49:23 Vulnerability Gather data sampling: Not affected 13:49:23 Vulnerability Indirect target selection: Not affected 13:49:23 Vulnerability Itlb multihit: Not affected 13:49:23 Vulnerability L1tf: Not affected 13:49:23 Vulnerability Mds: Not affected 13:49:23 Vulnerability Meltdown: Not affected 13:49:23 Vulnerability Mmio stale data: Not affected 13:49:23 Vulnerability Reg file data sampling: Not affected 13:49:23 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 13:49:23 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 13:49:23 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 13:49:23 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 13:49:23 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 13:49:23 Vulnerability Srbds: Not affected 13:49:23 Vulnerability Tsa: Not affected 13:49:23 Vulnerability Tsx async abort: Not affected 13:49:23 Vulnerability Vmscape: Not affected 13:49:23 13:49:23 13:49:23 ---> nproc: 13:49:23 4 13:49:23 13:49:23 13:49:23 ---> df -h: 13:49:23 Filesystem Size Used Avail Use% Mounted on 13:49:23 tmpfs 1.6G 1.1M 1.6G 1% /run 13:49:23 /dev/vda1 78G 18G 61G 23% / 13:49:23 tmpfs 7.9G 0 7.9G 0% /dev/shm 13:49:23 tmpfs 5.0M 0 5.0M 0% /run/lock 13:49:23 /dev/vda15 105M 6.1M 99M 6% /boot/efi 13:49:23 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 13:49:23 13:49:23 13:49:23 ---> free -m: 13:49:23 total used free shared buff/cache available 13:49:23 Mem: 15989 694 11742 3 3553 14952 13:49:23 Swap: 1023 1 1022 13:49:23 13:49:23 13:49:24 ---> ip addr: 13:49:24 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 13:49:24 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 13:49:24 inet 127.0.0.1/8 scope host lo 13:49:24 valid_lft forever preferred_lft forever 13:49:24 inet6 ::1/128 scope host 13:49:24 valid_lft forever preferred_lft forever 13:49:24 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 13:49:24 link/ether fa:16:3e:ff:27:a8 brd ff:ff:ff:ff:ff:ff 13:49:24 altname enp0s3 13:49:24 inet 10.30.170.49/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 13:49:24 valid_lft 79823sec preferred_lft 79823sec 13:49:24 inet6 fe80::f816:3eff:feff:27a8/64 scope link 13:49:24 valid_lft forever preferred_lft forever 13:49:24 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 13:49:24 link/ether 92:0b:96:f5:f7:68 brd ff:ff:ff:ff:ff:ff 13:49:24 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 13:49:24 valid_lft forever preferred_lft forever 13:49:24 inet6 fe80::900b:96ff:fef5:f768/64 scope link 13:49:24 valid_lft forever preferred_lft forever 13:49:24 13:49:24 13:49:24 ---> sar -b -r -n DEV: 13:49:24 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1788) 04/10/26 _x86_64_ (4 CPU) 13:49:24 13:49:24 11:59:49 LINUX RESTART (4 CPU) 13:49:24 13:49:24 12:00:00 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 13:49:24 12:10:06 156.69 16.55 135.09 5.05 2124.16 40006.49 12128.55 13:49:24 12:20:06 67.49 21.62 43.66 2.21 314.34 4467.23 3505.25 13:49:24 12:30:00 13.99 5.48 7.97 0.53 106.05 310.30 1012.73 13:49:24 12:40:06 29.49 0.19 13.61 15.69 9.65 560.95 209247.96 13:49:24 12:50:06 11.04 0.02 10.55 0.47 0.83 268.56 198.87 13:49:24 13:00:06 7.16 0.01 6.86 0.30 0.44 178.00 78.12 13:49:24 13:10:06 3.69 0.01 3.56 0.11 1.16 123.89 84.96 13:49:24 13:20:03 3.81 0.01 3.72 0.07 0.74 63.19 13.20 13:49:24 13:30:06 6.14 0.00 5.93 0.21 0.30 148.04 163.48 13:49:24 13:40:06 10.55 0.04 10.03 0.48 1.04 602.12 458.00 13:49:24 Average: 31.13 4.40 24.20 2.53 257.35 4703.08 22890.75 13:49:24 13:49:24 12:00:00 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 13:49:24 12:10:06 2112800 13520736 2399968 14.66 259604 10886644 3211924 18.44 2101912 11338908 676688 13:49:24 12:20:06 911148 3453948 12481160 76.23 265220 2327180 13404040 76.94 1963936 12976516 652 13:49:24 12:30:00 12716232 15329388 614056 3.75 267672 2395028 1366368 7.84 2020104 1145476 19776 13:49:24 12:40:06 11007852 13706172 2236672 13.66 272468 2475292 3009176 17.27 2064644 2814164 308 13:49:24 12:50:06 8695504 11420812 4520788 27.61 274424 2500316 5290588 30.37 2068336 5121264 344 13:49:24 13:00:06 8770372 11514372 4427236 27.04 275408 2518040 5215724 29.94 2070444 5042564 260 13:49:24 13:10:06 8656444 11415748 4526056 27.64 275752 2533016 5635816 32.35 2072288 5160304 328 13:49:24 13:20:03 7022224 9783964 6156596 37.60 276220 2534988 6916676 39.70 2073084 6783012 352 13:49:24 13:30:06 7004560 9782136 6158348 37.61 276872 2550168 6935784 39.81 2076504 6782764 80 13:49:24 13:40:06 8430232 11331680 4609720 28.15 280612 2670248 5302044 30.43 2092444 5356664 176 13:49:24 Average: 7532737 11125896 4813060 29.40 272425 3339092 5628814 32.31 2060370 6252164 69896 13:49:24 13:49:24 12:00:00 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 13:49:24 12:10:06 lo 3.37 3.37 2.39 2.39 0.00 0.00 0.00 0.00 13:49:24 12:10:06 ens3 168.07 127.23 2056.60 17.68 0.00 0.00 0.00 0.00 13:49:24 12:10:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 12:20:06 lo 38.36 38.36 22.76 22.76 0.00 0.00 0.00 0.00 13:49:24 12:20:06 ens3 2.01 1.84 0.46 0.40 0.00 0.00 0.00 0.00 13:49:24 12:20:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 12:30:00 lo 28.99 28.99 11.51 11.51 0.00 0.00 0.00 0.00 13:49:24 12:30:00 ens3 1.72 0.75 0.21 0.18 0.00 0.00 0.00 0.00 13:49:24 12:30:00 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 12:40:06 lo 7.33 7.33 3.85 3.85 0.00 0.00 0.00 0.00 13:49:24 12:40:06 ens3 1.30 1.41 0.29 1.28 0.00 0.00 0.00 0.00 13:49:24 12:40:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 12:50:06 lo 15.55 15.55 7.35 7.35 0.00 0.00 0.00 0.00 13:49:24 12:50:06 ens3 0.71 0.57 0.17 0.13 0.00 0.00 0.00 0.00 13:49:24 12:50:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:00:06 lo 17.01 17.01 8.64 8.64 0.00 0.00 0.00 0.00 13:49:24 13:00:06 ens3 0.73 0.57 0.17 0.13 0.00 0.00 0.00 0.00 13:49:24 13:00:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:10:06 lo 21.39 21.39 6.93 6.93 0.00 0.00 0.00 0.00 13:49:24 13:10:06 ens3 0.45 0.29 0.11 0.07 0.00 0.00 0.00 0.00 13:49:24 13:10:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:20:03 lo 16.82 16.82 8.66 8.66 0.00 0.00 0.00 0.00 13:49:24 13:20:03 ens3 0.54 0.41 0.12 0.09 0.00 0.00 0.00 0.00 13:49:24 13:20:03 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:30:06 lo 17.37 17.37 10.21 10.21 0.00 0.00 0.00 0.00 13:49:24 13:30:06 ens3 0.58 0.56 0.12 0.10 0.00 0.00 0.00 0.00 13:49:24 13:30:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:40:06 lo 17.21 17.21 9.70 9.70 0.00 0.00 0.00 0.00 13:49:24 13:40:06 ens3 1.03 0.86 0.28 0.23 0.00 0.00 0.00 0.00 13:49:24 13:40:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 Average: lo 18.30 18.30 9.19 9.19 0.00 0.00 0.00 0.00 13:49:24 Average: ens3 17.84 13.55 207.42 2.04 0.00 0.00 0.00 0.00 13:49:24 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:49:24 13:49:24 13:49:24 ---> sar -P ALL: 13:49:24 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1788) 04/10/26 _x86_64_ (4 CPU) 13:49:24 13:49:24 11:59:49 LINUX RESTART (4 CPU) 13:49:24 13:49:24 12:00:00 CPU %user %nice %system %iowait %steal %idle 13:49:24 12:10:06 all 44.30 0.00 2.73 1.95 0.09 50.93 13:49:24 12:10:06 0 43.72 0.00 2.85 1.60 0.09 51.74 13:49:24 12:10:06 1 43.47 0.00 2.68 2.33 0.09 51.43 13:49:24 12:10:06 2 42.09 0.00 2.81 1.69 0.09 53.32 13:49:24 12:10:06 3 47.92 0.00 2.60 2.17 0.09 47.22 13:49:24 12:20:06 all 56.75 0.00 2.10 0.14 0.12 40.89 13:49:24 12:20:06 0 56.70 0.00 2.00 0.07 0.12 41.11 13:49:24 12:20:06 1 57.74 0.00 1.93 0.12 0.12 40.10 13:49:24 12:20:06 2 55.38 0.00 2.36 0.19 0.12 41.94 13:49:24 12:20:06 3 57.17 0.00 2.09 0.19 0.12 40.43 13:49:24 12:30:00 all 17.78 0.00 0.83 0.12 0.09 81.19 13:49:24 12:30:00 0 18.20 0.00 0.80 0.11 0.09 80.79 13:49:24 12:30:00 1 17.91 0.00 0.85 0.13 0.09 81.01 13:49:24 12:30:00 2 17.08 0.00 0.88 0.07 0.10 81.87 13:49:24 12:30:00 3 17.90 0.00 0.77 0.15 0.09 81.08 13:49:24 12:40:06 all 20.59 0.00 0.74 0.07 0.07 78.53 13:49:24 12:40:06 0 20.25 0.00 0.79 0.05 0.07 78.85 13:49:24 12:40:06 1 20.78 0.00 0.74 0.13 0.07 78.28 13:49:24 12:40:06 2 20.81 0.00 0.76 0.02 0.08 78.33 13:49:24 12:40:06 3 20.51 0.00 0.69 0.07 0.07 78.66 13:49:24 12:50:06 all 20.91 0.00 0.78 0.04 0.07 78.20 13:49:24 12:50:06 0 20.86 0.00 0.89 0.03 0.07 78.15 13:49:24 12:50:06 1 21.22 0.00 0.84 0.07 0.08 77.80 13:49:24 12:50:06 2 20.93 0.00 0.67 0.03 0.08 78.30 13:49:24 12:50:06 3 20.62 0.00 0.71 0.04 0.07 78.56 13:49:24 13:00:06 all 14.73 0.00 0.59 0.04 0.07 84.57 13:49:24 13:00:06 0 14.52 0.00 0.60 0.03 0.07 84.78 13:49:24 13:00:06 1 15.13 0.00 0.69 0.09 0.08 84.01 13:49:24 13:00:06 2 15.17 0.00 0.56 0.03 0.07 84.17 13:49:24 13:00:06 3 14.10 0.00 0.50 0.00 0.07 85.33 13:49:24 13:10:06 all 7.76 0.00 0.39 0.09 0.05 91.70 13:49:24 13:10:06 0 8.19 0.00 0.44 0.07 0.05 91.25 13:49:24 13:10:06 1 8.01 0.00 0.39 0.06 0.06 91.47 13:49:24 13:10:06 2 7.67 0.00 0.32 0.01 0.06 91.93 13:49:24 13:10:06 3 7.15 0.00 0.41 0.23 0.05 92.16 13:49:24 13:20:03 all 5.48 0.00 0.34 0.09 0.06 94.03 13:49:24 13:20:03 0 5.68 0.00 0.31 0.07 0.05 93.89 13:49:24 13:20:03 1 5.34 0.00 0.37 0.23 0.06 94.00 13:49:24 13:20:03 2 5.50 0.00 0.38 0.03 0.06 94.02 13:49:24 13:20:03 3 5.40 0.00 0.32 0.03 0.06 94.19 13:49:24 13:30:06 all 10.01 0.00 0.40 0.46 0.06 89.07 13:49:24 13:30:06 0 9.74 0.00 0.41 0.66 0.06 89.14 13:49:24 13:30:06 1 10.38 0.00 0.38 0.16 0.06 89.02 13:49:24 13:30:06 2 10.05 0.00 0.45 0.79 0.06 88.66 13:49:24 13:30:06 3 9.87 0.00 0.38 0.24 0.06 89.46 13:49:24 13:40:06 all 21.31 0.00 0.87 0.18 0.08 77.56 13:49:24 13:40:06 0 21.45 0.00 0.83 0.52 0.08 77.12 13:49:24 13:40:06 1 21.06 0.00 0.87 0.06 0.08 77.94 13:49:24 13:40:06 2 20.75 0.00 0.91 0.06 0.08 78.20 13:49:24 13:40:06 3 21.98 0.00 0.88 0.07 0.08 77.00 13:49:24 Average: all 21.98 0.00 0.98 0.32 0.08 76.65 13:49:24 Average: 0 21.95 0.00 0.99 0.32 0.07 76.67 13:49:24 Average: 1 22.12 0.00 0.97 0.34 0.08 76.49 13:49:24 Average: 2 21.57 0.00 1.01 0.29 0.08 77.05 13:49:24 Average: 3 22.28 0.00 0.94 0.32 0.08 76.39 13:49:24 13:49:24 13:49:24