10:50:31 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/122294 10:50:31 Running as SYSTEM 10:50:31 [EnvInject] - Loading node environment variables. 10:50:31 Building remotely on prd-ubuntu2204-docker-4c-16g-2981 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 10:50:35 [ssh-agent] Looking for ssh-agent implementation... 10:50:35 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 10:50:35 $ ssh-agent 10:50:35 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXFPzVfu/agent.1561 10:50:35 SSH_AGENT_PID=1563 10:50:35 [ssh-agent] Started. 10:50:35 Running ssh-add (command line suppressed) 10:50:35 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4225869540114234621.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4225869540114234621.key) 10:50:35 [ssh-agent] Using credentials jenkins (jenkins-ssh) 10:50:35 The recommended git tool is: NONE 10:50:39 using credential jenkins-ssh 10:50:39 Wiping out workspace first. 10:50:39 Cloning the remote Git repository 10:50:39 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 10:50:39 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 10:50:39 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 10:50:39 > git --version # timeout=10 10:50:39 > git --version # 'git version 2.34.1' 10:50:39 using GIT_SSH to set credentials jenkins-ssh 10:50:39 Verifying host key using known hosts file, will automatically accept unseen keys 10:50:39 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 10:50:43 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 10:50:43 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 10:50:43 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 10:50:43 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 10:50:43 using GIT_SSH to set credentials jenkins-ssh 10:50:43 Verifying host key using known hosts file, will automatically accept unseen keys 10:50:43 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/94/122294/3 # timeout=10 10:50:44 > git rev-parse ad2cbfe2c7304edd60dfd674ef85138cd3c11471^{commit} # timeout=10 10:50:44 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 10:50:44 Checking out Revision ad2cbfe2c7304edd60dfd674ef85138cd3c11471 (refs/changes/94/122294/3) 10:50:44 > git config core.sparsecheckout # timeout=10 10:50:44 > git checkout -f ad2cbfe2c7304edd60dfd674ef85138cd3c11471 # timeout=10 10:50:44 Commit message: "Use openroadm-topology in OR link listener" 10:50:44 > git rev-parse FETCH_HEAD^{commit} # timeout=10 10:50:44 > git rev-list --no-walk 4cb3c1898b4ab0ee0ed3c6f2f54e556efda19316 # timeout=10 10:50:44 > git remote # timeout=10 10:50:44 > git submodule init # timeout=10 10:50:44 > git submodule sync # timeout=10 10:50:44 > git config --get remote.origin.url # timeout=10 10:50:44 > git submodule init # timeout=10 10:50:44 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 10:50:44 ERROR: No submodules found. 10:50:48 provisioning config files... 10:50:48 copy managed file [npmrc] to file:/home/jenkins/.npmrc 10:50:48 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 10:50:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16492942407421390002.sh 10:50:48 ---> python-tools-install.sh 10:50:48 Setup pyenv: 10:50:48 * system (set by /opt/pyenv/version) 10:50:48 * 3.8.20 (set by /opt/pyenv/version) 10:50:48 * 3.9.20 (set by /opt/pyenv/version) 10:50:48 3.10.15 10:50:48 3.11.10 10:50:53 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-PRgb 10:50:53 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 10:50:53 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 10:50:53 lf-activate-venv(): INFO: Attempting to install with network-safe options... 10:50:57 lf-activate-venv(): INFO: Base packages installed successfully 10:50:57 lf-activate-venv(): INFO: Installing additional packages: lftools 10:51:24 lf-activate-venv(): INFO: Adding /tmp/venv-PRgb/bin to PATH 10:51:24 Generating Requirements File 10:51:43 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. 10:51:43 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 10:51:43 Python 3.11.10 10:51:43 pip 26.0.1 from /tmp/venv-PRgb/lib/python3.11/site-packages/pip (python 3.11) 10:51:44 appdirs==1.4.4 10:51:44 argcomplete==3.6.3 10:51:44 aspy.yaml==1.3.0 10:51:44 attrs==26.1.0 10:51:44 autopage==0.6.0 10:51:44 beautifulsoup4==4.14.3 10:51:44 boto3==1.42.89 10:51:44 botocore==1.42.89 10:51:44 bs4==0.0.2 10:51:44 certifi==2026.2.25 10:51:44 cffi==2.0.0 10:51:44 cfgv==3.5.0 10:51:44 chardet==7.4.3 10:51:44 charset-normalizer==3.4.7 10:51:44 click==8.3.2 10:51:44 cliff==4.13.3 10:51:44 cmd2==3.5.0 10:51:44 cryptography==3.3.2 10:51:44 debtcollector==3.1.0 10:51:44 decorator==5.2.1 10:51:44 defusedxml==0.7.1 10:51:44 Deprecated==1.3.1 10:51:44 distlib==0.4.0 10:51:44 dnspython==2.8.0 10:51:44 docker==7.1.0 10:51:44 dogpile.cache==1.5.0 10:51:44 durationpy==0.10 10:51:44 email-validator==2.3.0 10:51:44 filelock==3.28.0 10:51:44 future==1.0.0 10:51:44 gitdb==4.0.12 10:51:44 GitPython==3.1.46 10:51:44 httplib2==0.30.2 10:51:44 identify==2.6.18 10:51:44 idna==3.11 10:51:44 importlib-resources==1.5.0 10:51:44 iso8601==2.1.0 10:51:44 Jinja2==3.1.6 10:51:44 jmespath==1.1.0 10:51:44 jsonpatch==1.33 10:51:44 jsonpointer==3.1.1 10:51:44 jsonschema==4.26.0 10:51:44 jsonschema-specifications==2025.9.1 10:51:44 keystoneauth1==5.13.1 10:51:44 kubernetes==35.0.0 10:51:44 lftools==0.37.22 10:51:44 lxml==6.0.4 10:51:44 markdown-it-py==4.0.0 10:51:44 MarkupSafe==3.0.3 10:51:44 mdurl==0.1.2 10:51:44 msgpack==1.1.2 10:51:44 multi_key_dict==2.0.3 10:51:44 munch==4.0.0 10:51:44 netaddr==1.3.0 10:51:44 niet==1.4.2 10:51:44 nodeenv==1.10.0 10:51:44 oauth2client==4.1.3 10:51:44 oauthlib==3.3.1 10:51:44 openstacksdk==4.11.0 10:51:44 os-service-types==1.8.2 10:51:44 osc-lib==4.5.0 10:51:44 oslo.config==10.3.0 10:51:44 oslo.context==6.3.0 10:51:44 oslo.i18n==6.7.2 10:51:44 oslo.log==8.1.0 10:51:44 oslo.serialization==5.9.1 10:51:44 oslo.utils==10.0.1 10:51:44 packaging==26.1 10:51:44 pbr==7.0.3 10:51:44 platformdirs==4.9.6 10:51:44 prettytable==3.17.0 10:51:44 psutil==7.2.2 10:51:44 pyasn1==0.6.3 10:51:44 pyasn1_modules==0.4.2 10:51:44 pycparser==3.0 10:51:44 pygerrit2==2.0.15 10:51:44 PyGithub==2.9.1 10:51:44 Pygments==2.20.0 10:51:44 PyJWT==2.12.1 10:51:44 PyNaCl==1.6.2 10:51:44 pyparsing==2.4.7 10:51:44 pyperclip==1.11.0 10:51:44 pyrsistent==0.20.0 10:51:44 python-cinderclient==9.9.0 10:51:44 python-dateutil==2.9.0.post0 10:51:44 python-discovery==1.2.2 10:51:44 python-heatclient==5.1.0 10:51:44 python-jenkins==1.8.3 10:51:44 python-keystoneclient==5.8.0 10:51:44 python-magnumclient==4.10.0 10:51:44 python-openstackclient==9.0.0 10:51:44 python-swiftclient==4.10.0 10:51:44 PyYAML==6.0.3 10:51:44 referencing==0.37.0 10:51:44 requests==2.33.1 10:51:44 requests-oauthlib==2.0.0 10:51:44 rfc3986==2.0.0 10:51:44 rich==15.0.0 10:51:44 rich-argparse==1.7.2 10:51:44 rpds-py==0.30.0 10:51:44 rsa==4.9.1 10:51:44 ruamel.yaml==0.19.1 10:51:44 ruamel.yaml.clib==0.2.15 10:51:44 s3transfer==0.16.0 10:51:44 simplejson==3.20.2 10:51:44 six==1.17.0 10:51:44 smmap==5.0.3 10:51:44 soupsieve==2.8.3 10:51:44 stevedore==5.7.0 10:51:44 tabulate==0.10.0 10:51:44 toml==0.10.2 10:51:44 tomlkit==0.14.0 10:51:44 tqdm==4.67.3 10:51:44 typing_extensions==4.15.0 10:51:44 urllib3==1.26.20 10:51:44 virtualenv==21.2.4 10:51:44 wcwidth==0.6.0 10:51:44 websocket-client==1.9.0 10:51:44 wrapt==2.1.2 10:51:44 xdg==6.0.0 10:51:44 xmltodict==1.0.4 10:51:44 yq==3.4.3 10:51:44 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins16222528596592044352.sh 10:51:44 ---> uv-install.sh 10:51:44 Installing uv/uvx (latest) using shell installer 10:51:44 2026-04-15 10:51:44 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-15T11%3A48%3A35Z&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-15T10%3A48%3A08Z&ske=2026-04-15T11%3A48%3A35Z&sks=b&skv=2018-11-09&sig=dCMNpm9Aww%2BFpx0oH2eGOSg6gDNnAPmQoEl0iNLaDGE%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NjI1MDUyOCwibmJmIjoxNzc2MjUwMjI4LCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.kvniqTy-Pk3VFtol-gmoGzSwe6wdPUWpmPhe1yymwdE&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [71225/71225] -> "/tmp/uv-install-e7UMhm.sh" [1] 10:51:44 downloading uv 0.11.6 x86_64-unknown-linux-gnu 10:51:45 installing to /home/jenkins/.local/bin 10:51:45 uv 10:51:45 uvx 10:51:45 everything's installed! 10:51:45 10:51:45 To add $HOME/.local/bin to your PATH, either restart your shell or run: 10:51:45 10:51:45 source $HOME/.local/bin/env (sh, bash, zsh) 10:51:45 source $HOME/.local/bin/env.fish (fish) 10:51:45 Adding install location to PATH 10:51:45 ---> Validating uv/uvx install 10:51:45 uvx 0.11.6 (x86_64-unknown-linux-gnu) 10:51:45 [EnvInject] - Injecting environment variables from a build step. 10:51:45 [EnvInject] - Injecting as environment variables the properties content 10:51:45 PYTHON=python3 10:51:45 10:51:45 [EnvInject] - Variables injected successfully. 10:51:45 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins9461776396612923819.sh 10:51:45 ---> tox-install.sh 10:51:45 + source /home/jenkins/lf-env.sh 10:51:45 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 10:51:45 ++ mktemp -d /tmp/venv-XXXX 10:51:45 + lf_venv=/tmp/venv-ARM7 10:51:45 + local venv_file=/tmp/.os_lf_venv 10:51:45 + local python=python3 10:51:45 + local options 10:51:45 + local set_path=true 10:51:45 + local install_args= 10:51:45 ++ getopt -o np:v: -l no-path,system-site-packages,python:,venv-file: -n lf-activate-venv -- --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 10:51:45 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:45 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:45 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 10:51:45 + true 10:51:45 + case $1 in 10:51:45 + venv_file=/tmp/.toxenv 10:51:45 + shift 2 10:51:45 + true 10:51:45 + case $1 in 10:51:45 + shift 10:51:45 + break 10:51:45 + case $python in 10:51:45 + local pkg_list= 10:51:45 + [[ -d /opt/pyenv ]] 10:51:45 + echo 'Setup pyenv:' 10:51:45 Setup pyenv: 10:51:45 + export PYENV_ROOT=/opt/pyenv 10:51:45 + PYENV_ROOT=/opt/pyenv 10:51:45 + 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 10:51:45 + 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 10:51:45 + pyenv versions 10:51:45 system 10:51:45 3.8.20 10:51:45 3.9.20 10:51:45 3.10.15 10:51:45 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:51:45 + command -v pyenv 10:51:45 ++ pyenv init - --no-rehash 10:51:45 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 10:51:45 for i in ${!paths[@]}; do 10:51:45 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 10:51:45 fi; done; 10:51:45 echo "${paths[*]}"'\'')" 10:51:45 export PATH="/opt/pyenv/shims:${PATH}" 10:51:45 export PYENV_SHELL=bash 10:51:45 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 10:51:45 pyenv() { 10:51:45 local command 10:51:45 command="${1:-}" 10:51:45 if [ "$#" -gt 0 ]; then 10:51:45 shift 10:51:45 fi 10:51:45 10:51:45 case "$command" in 10:51:45 rehash|shell) 10:51:45 eval "$(pyenv "sh-$command" "$@")" 10:51:45 ;; 10:51:45 *) 10:51:45 command pyenv "$command" "$@" 10:51:45 ;; 10:51:45 esac 10:51:45 }' 10:51:45 +++ bash --norc -ec 'IFS=:; paths=($PATH); 10:51:45 for i in ${!paths[@]}; do 10:51:45 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 10:51:45 fi; done; 10:51:45 echo "${paths[*]}"' 10:51:45 ++ 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 10:51:45 ++ 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 10:51:45 ++ 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 10:51:45 ++ export PYENV_SHELL=bash 10:51:45 ++ PYENV_SHELL=bash 10:51:45 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 10:51:45 +++ complete -F _pyenv pyenv 10:51:45 ++ lf-pyver python3 10:51:45 ++ local py_version_xy=python3 10:51:45 ++ local py_version_xyz= 10:51:45 ++ pyenv versions 10:51:45 ++ sed 's/^[ *]* //' 10:51:45 ++ awk '{ print $1 }' 10:51:45 ++ grep -E '^[0-9.]*[0-9]$' 10:51:45 ++ local command 10:51:45 ++ command=versions 10:51:45 ++ '[' 1 -gt 0 ']' 10:51:45 ++ shift 10:51:45 ++ case "$command" in 10:51:45 ++ command pyenv versions 10:51:45 ++ [[ ! -s /tmp/.pyenv_versions ]] 10:51:45 +++ grep '^3' /tmp/.pyenv_versions 10:51:45 +++ sort -V 10:51:45 +++ tail -n 1 10:51:45 ++ py_version_xyz=3.11.10 10:51:45 ++ [[ -z 3.11.10 ]] 10:51:45 ++ echo 3.11.10 10:51:45 ++ return 0 10:51:45 + pyenv local 3.11.10 10:51:45 + local command 10:51:45 + command=local 10:51:45 + '[' 2 -gt 0 ']' 10:51:45 + shift 10:51:45 + case "$command" in 10:51:45 + command pyenv local 3.11.10 10:51:45 + for arg in "$@" 10:51:45 + case $arg in 10:51:45 + pkg_list+='tox ' 10:51:45 + for arg in "$@" 10:51:45 + case $arg in 10:51:45 + pkg_list+='virtualenv ' 10:51:45 + for arg in "$@" 10:51:45 + case $arg in 10:51:45 + pkg_list+='urllib3~=1.26.15 ' 10:51:45 + [[ -f /tmp/.toxenv ]] 10:51:45 + [[ ! -f /tmp/.toxenv ]] 10:51:45 + [[ -n '' ]] 10:51:45 + python3 -m venv /tmp/venv-ARM7 10:51:50 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-ARM7' 10:51:50 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-ARM7 10:51:50 + echo /tmp/venv-ARM7 10:51:50 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 10:51:50 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 10:51:50 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 10:51:50 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 10:51:50 + local 'pip_opts=--upgrade --quiet' 10:51:50 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 10:51:50 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 10:51:50 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 10:51:50 + [[ -n '' ]] 10:51:50 + [[ -n '' ]] 10:51:50 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 10:51:50 lf-activate-venv(): INFO: Attempting to install with network-safe options... 10:51:50 + /tmp/venv-ARM7/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 10:51:54 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 10:51:54 lf-activate-venv(): INFO: Base packages installed successfully 10:51:54 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 10:51:54 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 10:51:54 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 10:51:54 + /tmp/venv-ARM7/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 10:51:56 + type python3 10:51:56 + true 10:51:56 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-ARM7/bin to PATH' 10:51:56 lf-activate-venv(): INFO: Adding /tmp/venv-ARM7/bin to PATH 10:51:56 + PATH=/tmp/venv-ARM7/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 10:51:56 + return 0 10:51:56 + python3 --version 10:51:56 Python 3.11.10 10:51:56 + python3 -m pip --version 10:51:56 pip 26.0.1 from /tmp/venv-ARM7/lib/python3.11/site-packages/pip (python 3.11) 10:51:56 + python3 -m pip freeze 10:51:56 cachetools==7.0.5 10:51:56 colorama==0.4.6 10:51:56 distlib==0.4.0 10:51:56 filelock==3.28.0 10:51:56 packaging==26.1 10:51:56 platformdirs==4.9.6 10:51:56 pluggy==1.6.0 10:51:56 pyproject-api==1.10.0 10:51:56 python-discovery==1.2.2 10:51:56 tomli_w==1.2.0 10:51:56 tox==4.53.0 10:51:56 urllib3==1.26.20 10:51:56 virtualenv==21.2.4 10:51:56 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins14232735598051027351.sh 10:51:56 [EnvInject] - Injecting environment variables from a build step. 10:51:56 [EnvInject] - Injecting as environment variables the properties content 10:51:56 PARALLEL=True 10:51:56 10:51:56 [EnvInject] - Variables injected successfully. 10:51:56 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins4326955859710043751.sh 10:51:56 ---> tox-run.sh 10:51:56 + 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 10:51:56 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 10:51:56 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 10:51:56 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 10:51:56 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 10:51:56 + source /home/jenkins/lf-env.sh 10:51:56 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 10:51:56 ++ mktemp -d /tmp/venv-XXXX 10:51:56 + lf_venv=/tmp/venv-alK9 10:51:56 + local venv_file=/tmp/.os_lf_venv 10:51:56 + local python=python3 10:51:56 + local options 10:51:56 + local set_path=true 10:51:56 + local install_args= 10:51:56 ++ 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 10:51:56 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:56 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 10:51:56 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 10:51:56 + true 10:51:56 + case $1 in 10:51:56 + venv_file=/tmp/.toxenv 10:51:56 + shift 2 10:51:56 + true 10:51:56 + case $1 in 10:51:56 + shift 10:51:56 + break 10:51:56 + case $python in 10:51:56 + local pkg_list= 10:51:56 + [[ -d /opt/pyenv ]] 10:51:56 + echo 'Setup pyenv:' 10:51:56 Setup pyenv: 10:51:56 + export PYENV_ROOT=/opt/pyenv 10:51:56 + PYENV_ROOT=/opt/pyenv 10:51:56 + 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 10:51:56 + 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 10:51:56 + pyenv versions 10:51:56 system 10:51:56 3.8.20 10:51:56 3.9.20 10:51:56 3.10.15 10:51:56 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:51:56 + command -v pyenv 10:51:56 ++ pyenv init - --no-rehash 10:51:56 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 10:51:56 for i in ${!paths[@]}; do 10:51:56 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 10:51:56 fi; done; 10:51:56 echo "${paths[*]}"'\'')" 10:51:56 export PATH="/opt/pyenv/shims:${PATH}" 10:51:56 export PYENV_SHELL=bash 10:51:56 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 10:51:56 pyenv() { 10:51:56 local command 10:51:56 command="${1:-}" 10:51:56 if [ "$#" -gt 0 ]; then 10:51:56 shift 10:51:56 fi 10:51:56 10:51:56 case "$command" in 10:51:56 rehash|shell) 10:51:56 eval "$(pyenv "sh-$command" "$@")" 10:51:56 ;; 10:51:56 *) 10:51:56 command pyenv "$command" "$@" 10:51:56 ;; 10:51:56 esac 10:51:56 }' 10:51:56 +++ bash --norc -ec 'IFS=:; paths=($PATH); 10:51:56 for i in ${!paths[@]}; do 10:51:56 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 10:51:56 fi; done; 10:51:56 echo "${paths[*]}"' 10:51:56 ++ 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 10:51:56 ++ 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 10:51:56 ++ 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 10:51:56 ++ export PYENV_SHELL=bash 10:51:56 ++ PYENV_SHELL=bash 10:51:56 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 10:51:56 +++ complete -F _pyenv pyenv 10:51:56 ++ lf-pyver python3 10:51:56 ++ local py_version_xy=python3 10:51:56 ++ local py_version_xyz= 10:51:56 ++ pyenv versions 10:51:56 ++ local command 10:51:56 ++ command=versions 10:51:56 ++ '[' 1 -gt 0 ']' 10:51:56 ++ shift 10:51:56 ++ case "$command" in 10:51:56 ++ command pyenv versions 10:51:56 ++ sed 's/^[ *]* //' 10:51:56 ++ grep -E '^[0-9.]*[0-9]$' 10:51:56 ++ awk '{ print $1 }' 10:51:57 ++ [[ ! -s /tmp/.pyenv_versions ]] 10:51:57 +++ grep '^3' /tmp/.pyenv_versions 10:51:57 +++ sort -V 10:51:57 +++ tail -n 1 10:51:57 ++ py_version_xyz=3.11.10 10:51:57 ++ [[ -z 3.11.10 ]] 10:51:57 ++ echo 3.11.10 10:51:57 ++ return 0 10:51:57 + pyenv local 3.11.10 10:51:57 + local command 10:51:57 + command=local 10:51:57 + '[' 2 -gt 0 ']' 10:51:57 + shift 10:51:57 + case "$command" in 10:51:57 + command pyenv local 3.11.10 10:51:57 + for arg in "$@" 10:51:57 + case $arg in 10:51:57 + pkg_list+='tox ' 10:51:57 + for arg in "$@" 10:51:57 + case $arg in 10:51:57 + pkg_list+='virtualenv ' 10:51:57 + for arg in "$@" 10:51:57 + case $arg in 10:51:57 + pkg_list+='urllib3~=1.26.15 ' 10:51:57 + [[ -f /tmp/.toxenv ]] 10:51:57 ++ cat /tmp/.toxenv 10:51:57 + lf_venv=/tmp/venv-ARM7 10:51:57 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-ARM7 from' file:/tmp/.toxenv 10:51:57 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-ARM7 from file:/tmp/.toxenv 10:51:57 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 10:51:57 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 10:51:57 + local 'pip_opts=--upgrade --quiet' 10:51:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 10:51:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 10:51:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 10:51:57 + [[ -n '' ]] 10:51:57 + [[ -n '' ]] 10:51:57 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 10:51:57 lf-activate-venv(): INFO: Attempting to install with network-safe options... 10:51:57 + /tmp/venv-ARM7/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 10:51:58 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 10:51:58 lf-activate-venv(): INFO: Base packages installed successfully 10:51:58 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 10:51:58 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 10:51:58 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 10:51:58 + /tmp/venv-ARM7/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 10:51:59 + type python3 10:51:59 + true 10:51:59 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-ARM7/bin to PATH' 10:51:59 lf-activate-venv(): INFO: Adding /tmp/venv-ARM7/bin to PATH 10:51:59 + PATH=/tmp/venv-ARM7/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 10:51:59 + return 0 10:51:59 + [[ -d /opt/pyenv ]] 10:51:59 + echo '---> Setting up pyenv' 10:51:59 ---> Setting up pyenv 10:51:59 + export PYENV_ROOT=/opt/pyenv 10:51:59 + PYENV_ROOT=/opt/pyenv 10:51:59 + export PATH=/opt/pyenv/bin:/tmp/venv-ARM7/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 10:51:59 + PATH=/opt/pyenv/bin:/tmp/venv-ARM7/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 10:51:59 ++ pwd 10:51:59 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 10:51:59 + export PYTHONPATH 10:51:59 + export TOX_TESTENV_PASSENV=PYTHONPATH 10:51:59 + TOX_TESTENV_PASSENV=PYTHONPATH 10:51:59 + tox --version 10:51:59 4.53.0 from /tmp/venv-ARM7/lib/python3.11/site-packages/tox/__init__.py 10:51:59 + PARALLEL=True 10:51:59 + TOX_OPTIONS_LIST= 10:51:59 + [[ -n '' ]] 10:51:59 + case ${PARALLEL,,} in 10:51:59 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 10:51:59 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 10:51:59 + tox --parallel auto --parallel-live 10:52:01 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 10:52:01 checkbashisms: freeze> python -m pip freeze --all 10:52:01 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 10:52:01 docs: install_deps> python -I -m pip install -r docs/requirements.txt 10:52:02 checkbashisms: pip==26.0.1,setuptools==82.0.1 10:52:02 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 10:52:02 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)' 10:52:02 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 10:52:03 checkbashisms: OK ✔ in 3.64 seconds 10:52:03 pre-commit: install_deps> python -I -m pip install pre-commit 10:52:06 pre-commit: freeze> python -m pip freeze --all 10:52:06 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.28.0,identify==2.6.18,nodeenv==1.10.0,pip==26.0.1,platformdirs==4.9.6,pre_commit==4.5.1,python-discovery==1.2.2,PyYAML==6.0.3,setuptools==82.0.1,virtualenv==21.2.4 10:52:06 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 10:52:06 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)' 10:52:06 /usr/bin/cpan 10:52:06 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 10:52:07 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 10:52:07 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 10:52:07 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 10:52:08 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 10:52:08 [INFO] Initializing environment for https://github.com/hhatto/autopep8. 10:52:08 buildcontroller: freeze> python -m pip freeze --all 10:52:09 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 10:52:09 buildcontroller: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:52:09 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 10:52:09 + update-java-alternatives -l 10:52:09 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 10:52:09 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 10:52:09 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 10:52:09 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 10:52:09 update-alternatives: error: no alternatives for jaotc 10:52:09 update-alternatives: error: no alternatives for rmic 10:52:09 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 10:52:09 + java -version 10:52:09 21 10:52:09 + JAVA_VER=21 10:52:09 + echo 21 10:52:09 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 10:52:09 + javac -version 10:52:09 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 10:52:09 21 10:52:09 ok, java is 21 or newer 10:52:09 + JAVAC_VER=21 10:52:09 + echo 21 10:52:09 + [ 21 -ge 21 ] 10:52:09 + [ 21 -ge 21 ] 10:52:09 + echo ok, java is 21 or newer 10:52:09 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 10:52:09 2026-04-15 10:52:09 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] 10:52:09 + sudo mkdir -p /opt 10:52:10 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 10:52:10 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 10:52:10 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 10:52:10 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 10:52:10 + mvn --version 10:52:10 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 10:52:10 Maven home: /opt/maven 10:52:10 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 10:52:10 Default locale: en, platform encoding: UTF-8 10:52:10 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 10:52:10 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 10:52:10 NOTE: Picked up JDK_JAVA_OPTIONS: 10:52:10 --add-opens=java.base/java.io=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.lang=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.net=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.nio=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.util=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:52:10 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:52:10 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:52:10 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:52:10 -Xlog:disable 10:52:10 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 10:52:11 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 10:52:11 [INFO] Once installed this environment will be reused. 10:52:11 [INFO] This may take a few minutes... 10:52:17 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 10:52:17 [INFO] Once installed this environment will be reused. 10:52:17 [INFO] This may take a few minutes... 10:52:25 [INFO] Installing environment for https://github.com/hhatto/autopep8. 10:52:25 [INFO] Once installed this environment will be reused. 10:52:25 [INFO] This may take a few minutes... 10:52:29 docs-linkcheck: freeze> python -m pip freeze --all 10:52:29 docs: freeze> python -m pip freeze --all 10:52:30 docs-linkcheck: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.1,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.1,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.5.0,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 10:52:30 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 10:52:30 docs: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.1,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.1,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.5.0,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 10:52:30 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 10:52:31 [INFO] Installing environment for https://github.com/perltidy/perltidy. 10:52:31 [INFO] Once installed this environment will be reused. 10:52:31 [INFO] This may take a few minutes... 10:52:33 docs: OK ✔ in 33.4 seconds 10:52:33 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 10:52:37 docs-linkcheck: OK ✔ in 35.58 seconds 10:52:37 pylint: freeze> python -m pip freeze --all 10:52:38 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 10:52:38 pylint: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find transportpce_tests/ -name '*.py' -exec pylint --fail-under=10 --max-line-length=120 --disable=missing-docstring,import-error --disable=fixme --disable=duplicate-code '--module-rgx=([a-z0-9_]+$)|([0-9.]{1,30}$)' '--method-rgx=(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$' '--variable-rgx=[a-zA-Z_][a-zA-Z0-9_]{1,30}$' '{}' + 10:52:43 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 10:52:43 [INFO] Once installed this environment will be reused. 10:52:43 [INFO] This may take a few minutes... 10:52:47 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 10:52:47 [INFO] Once installed this environment will be reused. 10:52:47 [INFO] This may take a few minutes... 10:52:52 trim trailing whitespace.................................................Passed 10:52:52 fix end of files.........................................................Passed 10:52:53 check for added large files..............................................Passed 10:52:53 check for merge conflicts................................................Passed 10:52:53 check for case conflicts.................................................Passed 10:52:53 check json...............................................................Passed 10:52:53 mixed line ending........................................................Passed 10:52:54 Tabs remover.............................................................Passed 10:52:54 autopep8.................................................................Passed 10:52:56 perltidy.................................................................Passed 10:52:57 ShellCheck v0.11.0.......................................................Passed 10:53:02 prettier.................................................................Passed 10:53:04 yamllint.................................................................Passed 10:53:04 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 10:53:04 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 10:53:04 [INFO] Once installed this environment will be reused. 10:53:04 [INFO] This may take a few minutes... 10:53:05 10:53:05 ------------------------------------ 10:53:05 Your code has been rated at 10.00/10 10:53:05 10:53:14 gitlint..................................................................Passed 10:54:21 pylint: OK ✔ in 34.92 seconds 10:54:21 pre-commit: OK ✔ in 1 minute 10.96 seconds 10:54:21 buildcontroller: OK ✔ in 2 minutes 20.39 seconds 10:54:21 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 10:54:21 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 10:54:21 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 10:54:21 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 10:54:28 build_karaf_tests71: freeze> python -m pip freeze --all 10:54:28 build_karaf_tests190: freeze> python -m pip freeze --all 10:54:28 build_karaf_tests121: freeze> python -m pip freeze --all 10:54:28 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:54:28 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:28 build karaf in karafoc with ./karafoc.env 10:54:28 build_karaf_tests221: freeze> python -m pip freeze --all 10:54:28 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:54:28 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:28 build karaf in karaf71 with ./karaf71.env 10:54:28 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:28 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:28 -Xlog:disable 10:54:28 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:54:28 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:28 build karaf in karaf121 with ./karaf121.env 10:54:28 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:28 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:28 -Xlog:disable 10:54:28 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:28 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:28 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:28 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:28 -Xlog:disable 10:54:28 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:54:28 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 10:54:28 build karaf in karaf221 with ./karaf221.env 10:54:29 NOTE: Picked up JDK_JAVA_OPTIONS: 10:54:29 --add-opens=java.base/java.io=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.lang=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.net=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.nio=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.nio.file=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.util=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.util.jar=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.util.stream=ALL-UNNAMED 10:54:29 --add-opens=java.base/java.util.zip=ALL-UNNAMED 10:54:29 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 10:54:29 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 10:54:29 -Xlog:disable 10:55:27 build_karaf_tests190: OK ✔ in 1 minute 7.22 seconds 10:55:27 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 10:55:28 build_karaf_tests121: OK ✔ in 1 minute 8.21 seconds 10:55:28 build_karaf_tests71: OK ✔ in 1 minute 8.29 seconds 10:55:28 build_karaf_tests221: OK ✔ in 1 minute 8.3 seconds 10:55:28 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 10:55:29 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 10:55:35 buildlighty: freeze> python -m pip freeze --all 10:55:35 buildlighty: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:55:35 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 10:55:35 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 10:55:35 sims: freeze> python -m pip freeze --all 10:55:36 sims: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 10:55:36 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 10:55:36 Using lighynode version 22.1.0.6 10:55:36 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 10:56:17 sims: OK ✔ in 10.07 seconds 10:56:17 buildlighty: OK ✔ in 39.92 seconds 10:56:17 testsPCE: freeze> python -m pip freeze --all 10:56:18 testsPCE: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,click==8.3.2,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.8,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.62.1,gnpy4tpce==2.4.7,idna==3.11,iniconfig==2.3.0,injector==0.24.0,invoke==3.0.3,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.5.0,lxml==6.0.4,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.1,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.2.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.3,python-dateutil==2.9.0.post0,pytz==2026.1.post1,requests==2.33.1,scipy==1.17.1,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 10:56:18 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 10:56:18 pytest -q transportpce_tests/pce/test01_pce.py 10:57:08 .................... [100%] 10:58:12 20 passed in 114.40s (0:01:54) 10:58:12 pytest -q transportpce_tests/pce/test02_pce_400G.py 10:58:31 ............ [100%] 10:59:02 12 passed in 48.73s 10:59:02 pytest -q transportpce_tests/pce/test03_gnpy.py 10:59:20 ........ [100%] 10:59:41 8 passed in 39.23s 10:59:41 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 11:00:14 ... [100%] 11:00:19 3 passed in 37.23s 11:00:20 testsPCE: OK ✔ in 4 minutes 50.64 seconds 11:00:20 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 11:00:20 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 11:00:20 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 11:00:26 tests190: freeze> python -m pip freeze --all 11:00:26 tests121: freeze> python -m pip freeze --all 11:00:26 tests_tapi: freeze> python -m pip freeze --all 11:00:26 tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 11:00:26 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 11:00:26 using environment variables from ./karafoc.env 11:00:26 pytest -q transportpce_tests/oc/test01_portmapping.py 11:00:27 tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 11:00:27 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 11:00:27 using environment variables from ./karaf121.env 11:00:27 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 11:00:27 tests_tapi: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 11:00:27 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 11:00:27 using environment variables from ./karaf221.env 11:00:27 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 11:01:32 ........... [100%] 11:01:49 10 passed in 81.90s (0:01:21) 11:01:49 pytest -q transportpce_tests/oc/test02_topology.py 11:01:58 .................................. [100%] 11:02:38 21 passed in 131.29s (0:02:11) 11:02:38 .pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 11:02:40 ........................ [100%] 11:02:58 14 passed in 68.98s (0:01:08) 11:02:58 pytest -q transportpce_tests/oc/test03_renderer.py 11:02:58 .................... [100%] 11:03:41 6 passed in 62.96s (0:01:02) 11:03:41 pytest -q transportpce_tests/1.2.1/test03_topology.py 11:03:42 ................. [100%] 11:04:00 19 passed in 60.97s (0:01:00) 11:04:00 tests190: OK ✔ in 3 minutes 40.92 seconds 11:04:00 tests71: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 11:04:05 .tests71: freeze> python -m pip freeze --all 11:04:08 tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 11:04:08 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 11:04:08 using environment variables from ./karaf71.env 11:04:08 pytest -q transportpce_tests/7.1/test01_portmapping.py 11:04:25 ............................ [100%] 11:05:04 12 passed in 54.94s 11:05:04 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 11:05:05 ....................................................... [100%] 11:06:18 44 passed in 156.69s (0:02:36) 11:06:18 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 11:06:20 ....................................................................... [100%] 11:07:43 62 passed in 158.96s (0:02:38) 11:07:43 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 11:07:44 [100%] 11:07:44 24 passed in 85.23s (0:01:25) 11:07:44 pytest -q transportpce_tests/1.2.1/test05_olm.py 11:08:30 ........ [100%] 11:08:45 51 passed in 498.65s (0:08:18) 11:08:46 pytest -q transportpce_tests/tapi/test02_full_topology.py 11:08:47 ........................................................................... [100%] 11:10:16 48 passed in 152.57s (0:02:32) 11:10:16 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 11:10:18 ..........F....................... [100%] 11:11:11 40 passed in 206.80s (0:03:26) 11:11:11 pytest -q transportpce_tests/1.2.1/test06_end2end.py 11:11:13 ............. [100%] 11:11:35 22 passed in 78.65s (0:01:18) 11:11:42 .................................................................F [100%] 11:17:59 =================================== FAILURES =================================== 11:17:59 ________ TestTransportPCEFullTopology.test_13_get_tapi_topology_details ________ 11:17:59 11:17:59 self = 11:17:59 11:17:59 def test_13_get_tapi_topology_details(self): 11:17:59 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 11:17:59 response = test_utils.transportpce_api_rpc_request( 11:17:59 'tapi-topology', 'get-topology-details', self.tapi_topo) 11:17:59 time.sleep(2) 11:17:59 self.assertEqual(response['status_code'], requests.codes.ok) 11:17:59 self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 11:17:59 > self.assertEqual(len(response['output']['topology']['link']), 3, 'There should be 3 TAPI links') 11:17:59 E AssertionError: 1 != 3 : There should be 3 TAPI links 11:17:59 11:17:59 transportpce_tests/tapi/test02_full_topology.py:307: AssertionError 11:17:59 ______ TestTransportPCEFullTopology.test_35_check_uninstall_Tapi_Feature _______ 11:17:59 11:17:59 self = 11:17:59 conn = 11:17:59 method = 'GET' 11:17:59 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 11:17:59 body = None 11:17:59 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='} 11:17:59 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 11:17:59 timeout = Timeout(connect=30, read=30, total=None), chunked = False 11:17:59 response_conn = 11:17:59 preload_content = False, decode_content = False, enforce_content_length = True 11:17:59 11:17:59 def _make_request( 11:17:59 self, 11:17:59 conn: BaseHTTPConnection, 11:17:59 method: str, 11:17:59 url: str, 11:17:59 body: _TYPE_BODY | None = None, 11:17:59 headers: typing.Mapping[str, str] | None = None, 11:17:59 retries: Retry | None = None, 11:17:59 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 11:17:59 chunked: bool = False, 11:17:59 response_conn: BaseHTTPConnection | None = None, 11:17:59 preload_content: bool = True, 11:17:59 decode_content: bool = True, 11:17:59 enforce_content_length: bool = True, 11:17:59 ) -> BaseHTTPResponse: 11:17:59 """ 11:17:59 Perform a request on a given urllib connection object taken from our 11:17:59 pool. 11:17:59 11:17:59 :param conn: 11:17:59 a connection from one of our connection pools 11:17:59 11:17:59 :param method: 11:17:59 HTTP request method (such as GET, POST, PUT, etc.) 11:17:59 11:17:59 :param url: 11:17:59 The URL to perform the request on. 11:17:59 11:17:59 :param body: 11:17:59 Data to send in the request body, either :class:`str`, :class:`bytes`, 11:17:59 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 11:17:59 11:17:59 :param headers: 11:17:59 Dictionary of custom headers to send, such as User-Agent, 11:17:59 If-None-Match, etc. If None, pool headers are used. If provided, 11:17:59 these headers completely replace any pool-specific headers. 11:17:59 11:17:59 :param retries: 11:17:59 Configure the number of retries to allow before raising a 11:17:59 :class:`~urllib3.exceptions.MaxRetryError` exception. 11:17:59 11:17:59 Pass ``None`` to retry until you receive a response. Pass a 11:17:59 :class:`~urllib3.util.retry.Retry` object for fine-grained control 11:17:59 over different types of retries. 11:17:59 Pass an integer number to retry connection errors that many times, 11:17:59 but no other types of errors. Pass zero to never retry. 11:17:59 11:17:59 If ``False``, then retries are disabled and any exception is raised 11:17:59 immediately. Also, instead of raising a MaxRetryError on redirects, 11:17:59 the redirect response will be returned. 11:17:59 11:17:59 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 11:17:59 11:17:59 :param timeout: 11:17:59 If specified, overrides the default timeout for this one 11:17:59 request. It may be a float (in seconds) or an instance of 11:17:59 :class:`urllib3.util.Timeout`. 11:17:59 11:17:59 :param chunked: 11:17:59 If True, urllib3 will send the body using chunked transfer 11:17:59 encoding. Otherwise, urllib3 will send the body using the standard 11:17:59 content-length form. Defaults to False. 11:17:59 11:17:59 :param response_conn: 11:17:59 Set this to ``None`` if you will handle releasing the connection or 11:17:59 set the connection to have the response release it. 11:17:59 11:17:59 :param preload_content: 11:17:59 If True, the response's body will be preloaded during construction. 11:17:59 11:17:59 :param decode_content: 11:17:59 If True, will attempt to decode the body based on the 11:17:59 'content-encoding' header. 11:17:59 11:17:59 :param enforce_content_length: 11:17:59 Enforce content length checking. Body returned by server must match 11:17:59 value of Content-Length header, if present. Otherwise, raise error. 11:17:59 """ 11:17:59 self.num_requests += 1 11:17:59 11:17:59 timeout_obj = self._get_timeout(timeout) 11:17:59 timeout_obj.start_connect() 11:17:59 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 11:17:59 11:17:59 try: 11:17:59 # Trigger any extra validation we need to do. 11:17:59 try: 11:17:59 self._validate_conn(conn) 11:17:59 except (SocketTimeout, BaseSSLError) as e: 11:17:59 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 11:17:59 raise 11:17:59 11:17:59 # _validate_conn() starts the connection to an HTTPS proxy 11:17:59 # so we need to wrap errors with 'ProxyError' here too. 11:17:59 except ( 11:17:59 OSError, 11:17:59 NewConnectionError, 11:17:59 TimeoutError, 11:17:59 BaseSSLError, 11:17:59 CertificateError, 11:17:59 SSLError, 11:17:59 ) as e: 11:17:59 new_e: Exception = e 11:17:59 if isinstance(e, (BaseSSLError, CertificateError)): 11:17:59 new_e = SSLError(e) 11:17:59 # If the connection didn't successfully connect to it's proxy 11:17:59 # then there 11:17:59 if isinstance( 11:17:59 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 11:17:59 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 11:17:59 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 11:17:59 raise new_e 11:17:59 11:17:59 # conn.request() calls http.client.*.request, not the method in 11:17:59 # urllib3.request. It also calls makefile (recv) on the socket. 11:17:59 try: 11:17:59 conn.request( 11:17:59 method, 11:17:59 url, 11:17:59 body=body, 11:17:59 headers=headers, 11:17:59 chunked=chunked, 11:17:59 preload_content=preload_content, 11:17:59 decode_content=decode_content, 11:17:59 enforce_content_length=enforce_content_length, 11:17:59 ) 11:17:59 11:17:59 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 11:17:59 # legitimately able to close the connection after sending a valid response. 11:17:59 # With this behaviour, the received response is still readable. 11:17:59 except BrokenPipeError: 11:17:59 pass 11:17:59 except OSError as e: 11:17:59 # MacOS/Linux 11:17:59 # EPROTOTYPE and ECONNRESET are needed on macOS 11:17:59 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 11:17:59 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 11:17:59 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 11:17:59 raise 11:17:59 11:17:59 # Reset the timeout for the recv() on the socket 11:17:59 read_timeout = timeout_obj.read_timeout 11:17:59 11:17:59 if not conn.is_closed: 11:17:59 # In Python 3 socket.py will catch EAGAIN and return None when you 11:17:59 # try and read into the file pointer created by http.client, which 11:17:59 # instead raises a BadStatusLine exception. Instead of catching 11:17:59 # the exception and assuming all BadStatusLine exceptions are read 11:17:59 # timeouts, check for a zero timeout before making the request. 11:17:59 if read_timeout == 0: 11:17:59 raise ReadTimeoutError( 11:17:59 self, url, f"Read timed out. (read timeout={read_timeout})" 11:17:59 ) 11:17:59 conn.timeout = read_timeout 11:17:59 11:17:59 # Receive the response from the server 11:17:59 try: 11:17:59 > response = conn.getresponse() 11:17:59 ^^^^^^^^^^^^^^^^^^ 11:17:59 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 11:17:59 httplib_response = super().getresponse() 11:17:59 ^^^^^^^^^^^^^^^^^^^^^ 11:17:59 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 11:17:59 response.begin() 11:17:59 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 11:17:59 version, status, reason = self._read_status() 11:17:59 ^^^^^^^^^^^^^^^^^^^ 11:17:59 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 11:17:59 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 11:17:59 self = 11:17:59 b = 11:17:59 11:17:59 def readinto(self, b): 11:17:59 """Read up to len(b) bytes into the writable buffer *b* and return 11:17:59 the number of bytes read. If the socket is non-blocking and no bytes 11:17:59 are available, None is returned. 11:17:59 11:17:59 If *b* is non-empty, a 0 return value indicates that the connection 11:17:59 was shutdown at the other end. 11:17:59 """ 11:17:59 self._checkClosed() 11:17:59 self._checkReadable() 11:17:59 if self._timeout_occurred: 11:17:59 raise OSError("cannot read from timed out object") 11:17:59 while True: 11:17:59 try: 11:17:59 > return self._sock.recv_into(b) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 E TimeoutError: timed out 11:17:59 11:17:59 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 11:17:59 11:17:59 The above exception was the direct cause of the following exception: 11:17:59 11:17:59 self = 11:17:59 request = , stream = False 11:17:59 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 11:17:59 proxies = OrderedDict() 11:17:59 11:17:59 def send( 11:17:59 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:17:59 ): 11:17:59 """Sends PreparedRequest object. Returns Response object. 11:17:59 11:17:59 :param request: The :class:`PreparedRequest ` being sent. 11:17:59 :param stream: (optional) Whether to stream the request content. 11:17:59 :param timeout: (optional) How long to wait for the server to send 11:17:59 data before giving up, as a float, or a :ref:`(connect timeout, 11:17:59 read timeout) ` tuple. 11:17:59 :type timeout: float or tuple or urllib3 Timeout object 11:17:59 :param verify: (optional) Either a boolean, in which case it controls whether 11:17:59 we verify the server's TLS certificate, or a string, in which case it 11:17:59 must be a path to a CA bundle to use 11:17:59 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:17:59 :param proxies: (optional) The proxies dictionary to apply to the request. 11:17:59 :rtype: requests.Response 11:17:59 """ 11:17:59 11:17:59 try: 11:17:59 conn = self.get_connection_with_tls_context( 11:17:59 request, verify, proxies=proxies, cert=cert 11:17:59 ) 11:17:59 except LocationValueError as e: 11:17:59 raise InvalidURL(e, request=request) 11:17:59 11:17:59 self.cert_verify(conn, request.url, verify, cert) 11:17:59 url = self.request_url(request, proxies) 11:17:59 self.add_headers( 11:17:59 request, 11:17:59 stream=stream, 11:17:59 timeout=timeout, 11:17:59 verify=verify, 11:17:59 cert=cert, 11:17:59 proxies=proxies, 11:17:59 ) 11:17:59 11:17:59 chunked = not (request.body is None or "Content-Length" in request.headers) 11:17:59 11:17:59 if isinstance(timeout, tuple): 11:17:59 try: 11:17:59 connect, read = timeout 11:17:59 timeout = TimeoutSauce(connect=connect, read=read) 11:17:59 except ValueError: 11:17:59 raise ValueError( 11:17:59 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:17:59 f"or a single float to set both timeouts to the same value." 11:17:59 ) 11:17:59 elif isinstance(timeout, TimeoutSauce): 11:17:59 pass 11:17:59 else: 11:17:59 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:17:59 11:17:59 try: 11:17:59 > resp = conn.urlopen( 11:17:59 method=request.method, 11:17:59 url=url, 11:17:59 body=request.body, 11:17:59 headers=request.headers, 11:17:59 redirect=False, 11:17:59 assert_same_host=False, 11:17:59 preload_content=False, 11:17:59 decode_content=False, 11:17:59 retries=self.max_retries, 11:17:59 timeout=timeout, 11:17:59 chunked=chunked, 11:17:59 ) 11:17:59 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:645: 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 11:17:59 retries = retries.increment( 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 11:17:59 raise reraise(type(error), error, _stacktrace) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 11:17:59 raise value 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 11:17:59 response = self._make_request( 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 11:17:59 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 11:17:59 self = 11:17:59 err = TimeoutError('timed out') 11:17:59 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 11:17:59 timeout_value = 30 11:17:59 11:17:59 def _raise_timeout( 11:17:59 self, 11:17:59 err: BaseSSLError | OSError | SocketTimeout, 11:17:59 url: str, 11:17:59 timeout_value: _TYPE_TIMEOUT | None, 11:17:59 ) -> None: 11:17:59 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 11:17:59 11:17:59 if isinstance(err, SocketTimeout): 11:17:59 > raise ReadTimeoutError( 11:17:59 self, url, f"Read timed out. (read timeout={timeout_value})" 11:17:59 ) from err 11:17:59 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 11:17:59 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 11:17:59 11:17:59 During handling of the above exception, another exception occurred: 11:17:59 11:17:59 self = 11:17:59 11:17:59 def test_35_check_uninstall_Tapi_Feature(self): 11:17:59 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 11:17:59 time.sleep(16) 11:17:59 print("Tapi Feature uninstalled") 11:17:59 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 11:17:59 transportpce_tests/tapi/test02_full_topology.py:787: 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 11:17:59 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 transportpce_tests/common/test_utils.py:117: in get_request 11:17:59 return requests.request( 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 11:17:59 return session.request(method=method, url=url, **kwargs) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:592: in request 11:17:59 resp = self.send(prep, **send_kwargs) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:706: in send 11:17:59 r = adapter.send(request, **kwargs) 11:17:59 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 11:17:59 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 11:17:59 11:17:59 self = 11:17:59 request = , stream = False 11:17:59 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 11:17:59 proxies = OrderedDict() 11:17:59 11:17:59 def send( 11:17:59 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 11:17:59 ): 11:17:59 """Sends PreparedRequest object. Returns Response object. 11:17:59 11:17:59 :param request: The :class:`PreparedRequest ` being sent. 11:17:59 :param stream: (optional) Whether to stream the request content. 11:17:59 :param timeout: (optional) How long to wait for the server to send 11:17:59 data before giving up, as a float, or a :ref:`(connect timeout, 11:17:59 read timeout) ` tuple. 11:17:59 :type timeout: float or tuple or urllib3 Timeout object 11:17:59 :param verify: (optional) Either a boolean, in which case it controls whether 11:17:59 we verify the server's TLS certificate, or a string, in which case it 11:17:59 must be a path to a CA bundle to use 11:17:59 :param cert: (optional) Any user-provided SSL certificate to be trusted. 11:17:59 :param proxies: (optional) The proxies dictionary to apply to the request. 11:17:59 :rtype: requests.Response 11:17:59 """ 11:17:59 11:17:59 try: 11:17:59 conn = self.get_connection_with_tls_context( 11:17:59 request, verify, proxies=proxies, cert=cert 11:17:59 ) 11:17:59 except LocationValueError as e: 11:17:59 raise InvalidURL(e, request=request) 11:17:59 11:17:59 self.cert_verify(conn, request.url, verify, cert) 11:17:59 url = self.request_url(request, proxies) 11:17:59 self.add_headers( 11:17:59 request, 11:17:59 stream=stream, 11:17:59 timeout=timeout, 11:17:59 verify=verify, 11:17:59 cert=cert, 11:17:59 proxies=proxies, 11:17:59 ) 11:17:59 11:17:59 chunked = not (request.body is None or "Content-Length" in request.headers) 11:17:59 11:17:59 if isinstance(timeout, tuple): 11:17:59 try: 11:17:59 connect, read = timeout 11:17:59 timeout = TimeoutSauce(connect=connect, read=read) 11:17:59 except ValueError: 11:17:59 raise ValueError( 11:17:59 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 11:17:59 f"or a single float to set both timeouts to the same value." 11:17:59 ) 11:17:59 elif isinstance(timeout, TimeoutSauce): 11:17:59 pass 11:17:59 else: 11:17:59 timeout = TimeoutSauce(connect=timeout, read=timeout) 11:17:59 11:17:59 try: 11:17:59 resp = conn.urlopen( 11:17:59 method=request.method, 11:17:59 url=url, 11:17:59 body=request.body, 11:17:59 headers=request.headers, 11:17:59 redirect=False, 11:17:59 assert_same_host=False, 11:17:59 preload_content=False, 11:17:59 decode_content=False, 11:17:59 retries=self.max_retries, 11:17:59 timeout=timeout, 11:17:59 chunked=chunked, 11:17:59 ) 11:17:59 11:17:59 except (ProtocolError, OSError) as err: 11:17:59 raise ConnectionError(err, request=request) 11:17:59 11:17:59 except MaxRetryError as e: 11:17:59 if isinstance(e.reason, ConnectTimeoutError): 11:17:59 # TODO: Remove this in 3.0.0: see #2811 11:17:59 if not isinstance(e.reason, NewConnectionError): 11:17:59 raise ConnectTimeout(e, request=request) 11:17:59 11:17:59 if isinstance(e.reason, ResponseError): 11:17:59 raise RetryError(e, request=request) 11:17:59 11:17:59 if isinstance(e.reason, _ProxyError): 11:17:59 raise ProxyError(e, request=request) 11:17:59 11:17:59 if isinstance(e.reason, _SSLError): 11:17:59 # This branch is for urllib3 v1.22 and later. 11:17:59 raise SSLError(e, request=request) 11:17:59 11:17:59 raise ConnectionError(e, request=request) 11:17:59 11:17:59 except ClosedPoolError as e: 11:17:59 raise ConnectionError(e, request=request) 11:17:59 11:17:59 except _ProxyError as e: 11:17:59 raise ProxyError(e) 11:17:59 11:17:59 except (_SSLError, _HTTPError) as e: 11:17:59 if isinstance(e, _SSLError): 11:17:59 # This branch is for urllib3 versions earlier than v1.22 11:17:59 raise SSLError(e, request=request) 11:17:59 elif isinstance(e, ReadTimeoutError): 11:17:59 > raise ReadTimeout(e, request=request) 11:17:59 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 11:17:59 11:17:59 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:691: ReadTimeout 11:17:59 ----------------------------- Captured stdout call ----------------------------- 11:17:59 uninstalling feature odl-transportpce-tapi 11:17:59 client: JAVA_HOME not set; results may vary 11:17:59 odl-transportpce-tapi │ 13.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 11:17:59 Tapi Feature uninstalled 11:17:59 --------------------------- Captured stdout teardown --------------------------- 11:17:59 all processes killed 11:17:59 ODL log file stored 11:17:59 =========================== short test summary info ============================ 11:17:59 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_13_get_tapi_topology_details 11:17:59 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_35_check_uninstall_Tapi_Feature 11:17:59 2 failed, 34 passed in 552.63s (0:09:12) 11:17:59 tests71: OK ✔ in 7 minutes 35.18 seconds 11:17:59 tests_tapi: exit 1 (1052.14 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7390 11:17:59 tests_tapi: FAIL ✖ in 17 minutes 39.79 seconds 11:17:59 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 11:18:06 tests221: freeze> python -m pip freeze --all 11:18: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.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 11:18:06 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 11:18:06 using environment variables from ./karaf221.env 11:18:06 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 11:18:43 ................................... [100%] 11:19:23 35 passed in 77.16s (0:01:17) 11:19:23 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 11:19:56 ........... [100%] 11:20:10 6 passed in 46.11s 11:20:10 [100%] 11:20:10 54 passed in 538.48s (0:08:58) 11:20:10 pytest -q transportpce_tests/2.2.1/test03_topology.py 11:20:54 ............................................ [100%] 11:22:29 44 passed in 138.90s (0:02:18) 11:22:29 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 11:23:05 ............ [100%] 11:23:30 12 passed in 60.16s (0:01:00) 11:23:30 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 11:23:56 ................ [100%] 11:25:25 16 passed in 115.35s (0:01:55) 11:25:25 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 11:25:54 ............................... [100%] 11:26:01 31 passed in 35.39s 11:26:01 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 11:26:36 .......................... [100%] 11:27:32 26 passed in 90.85s (0:01:30) 11:27:32 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 11:28:09 ...................... [100%] 11:29:12 22 passed in 99.64s (0:01:39) 11:29:12 pytest -q transportpce_tests/2.2.1/test09_olm.py 11:29:54 ........................................ [100%] 11:32:15 40 passed in 182.99s (0:03:02) 11:32:15 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 11:32:59 ........................................................................ [ 74%] 11:38:36 ......................... [100%] 11:40:28 97 passed in 492.93s (0:08:12) 11:40:29 pytest -q transportpce_tests/2.2.1/test12_end2end.py 11:41:13 ...................................................... [100%] 11:48:01 54 passed in 452.60s (0:07:32) 11:48:02 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 11:49:01 ........................................................................ [ 71%] 11:54:10 ............................. [100%] 11:56:20 101 passed in 497.94s (0:08:17) 11:56:20 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 11:57:19 ........................................................................ [ 67%] 12:03:07 ................................... [100%] 12:06:28 107 passed in 608.04s (0:10:08) 12:06:28 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 12:07:15 ............................................. [100%] 12:09:53 45 passed in 204.50s (0:03:24) 12:09:53 tests121: OK ✔ in 19 minutes 51.07 seconds 12:09:53 tests221: OK ✔ in 51 minutes 54.39 seconds 12:09:53 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 12:10:00 tests_hybrid: freeze> python -m pip freeze --all 12:10:00 tests_hybrid: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.4,netconf-client==3.5.0,packaging==26.1,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 12:10:00 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 12:10:00 using environment variables from ./karaf221.env 12:10:00 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 12:10:45 ................................................... [100%] 12:12:33 51 passed in 152.65s (0:02:32) 12:12:33 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 12:13:20 ........................................................................ [ 66%] 12:17:43 ..................................... [100%] 12:19:49 109 passed in 435.67s (0:07:15) 12:19:49 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 12:20:42 ..................................................... [100%] 12:24:16 53 passed in 266.94s (0:04:26) 12:24:16 buildcontroller: OK (140.39=setup[9.22]+cmd[131.17] seconds) 12:24:16 sims: OK (10.07=setup[7.51]+cmd[2.56] seconds) 12:24:16 build_karaf_tests121: OK (68.20=setup[8.17]+cmd[60.03] seconds) 12:24:16 testsPCE: OK (290.64=setup[49.40]+cmd[241.24] seconds) 12:24:16 tests121: OK (1191.07=setup[7.62]+cmd[1183.45] seconds) 12:24:16 build_karaf_tests221: OK (68.30=setup[8.46]+cmd[59.84] seconds) 12:24:16 tests_tapi: FAIL code 1 (1059.79=setup[7.64]+cmd[1052.14] seconds) 12:24:16 tests221: OK (3114.39=setup[7.30]+cmd[3107.08] seconds) 12:24:16 build_karaf_tests71: OK (68.29=setup[8.10]+cmd[60.19] seconds) 12:24:16 tests71: OK (455.18=setup[8.27]+cmd[446.91] seconds) 12:24:16 build_karaf_tests190: OK (67.22=setup[8.07]+cmd[59.16] seconds) 12:24:16 tests190: OK (220.92=setup[7.53]+cmd[213.39] seconds) 12:24:16 tests_hybrid: OK (863.31=setup[6.89]+cmd[856.42] seconds) 12:24:16 buildlighty: OK (39.92=setup[7.89]+cmd[32.03] seconds) 12:24:16 docs: OK (33.40=setup[30.27]+cmd[3.13] seconds) 12:24:16 docs-linkcheck: OK (35.58=setup[30.02]+cmd[5.56] seconds) 12:24:16 checkbashisms: OK (3.64=setup[2.18]+cmd[0.01,0.06,1.39] seconds) 12:24:16 pre-commit: OK (70.96=setup[3.24]+cmd[0.01,0.01,57.42,10.27] seconds) 12:24:16 pylint: OK (34.92=setup[4.85]+cmd[30.07] seconds) 12:24:16 evaluation failed :( (5536.89 seconds) 12:24:16 + tox_status=1 12:24:16 + echo '---> Completed tox runs' 12:24:16 ---> Completed tox runs 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/build_karaf_tests121/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=build_karaf_tests121 12:24:16 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/build_karaf_tests190/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=build_karaf_tests190 12:24:16 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 12:24:16 + for i in .tox/*/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 ++ echo .tox/build_karaf_tests221/log 12:24:16 + tox_env=build_karaf_tests221 12:24:16 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/build_karaf_tests71/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=build_karaf_tests71 12:24:16 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/buildcontroller/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=buildcontroller 12:24:16 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/buildlighty/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=buildlighty 12:24:16 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/checkbashisms/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=checkbashisms 12:24:16 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 12:24:16 + for i in .tox/*/log 12:24:16 ++ echo .tox/docs-linkcheck/log 12:24:16 ++ awk -F/ '{print $2}' 12:24:16 + tox_env=docs-linkcheck 12:24:16 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/docs/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=docs 12:24:17 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/pre-commit/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=pre-commit 12:24:17 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 12:24:17 + for i in .tox/*/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 ++ echo .tox/pylint/log 12:24:17 + tox_env=pylint 12:24:17 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/sims/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=sims 12:24:17 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 12:24:17 + for i in .tox/*/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 ++ echo .tox/tests121/log 12:24:17 + tox_env=tests121 12:24:17 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/tests190/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=tests190 12:24:17 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/tests221/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=tests221 12:24:17 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/tests71/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=tests71 12:24:17 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/testsPCE/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=testsPCE 12:24:17 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/tests_hybrid/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=tests_hybrid 12:24:17 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 12:24:17 + for i in .tox/*/log 12:24:17 ++ echo .tox/tests_tapi/log 12:24:17 ++ awk -F/ '{print $2}' 12:24:17 + tox_env=tests_tapi 12:24:17 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 12:24:17 + DOC_DIR=docs/_build/html 12:24:17 + [[ -d docs/_build/html ]] 12:24:17 + echo '---> Archiving generated docs' 12:24:17 ---> Archiving generated docs 12:24:17 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 12:24:17 + echo '---> tox-run.sh ends' 12:24:17 ---> tox-run.sh ends 12:24:17 + test 1 -eq 0 12:24:17 + exit 1 12:24:17 ++ '[' 1 = 1 ']' 12:24:17 ++ '[' -x /usr/bin/clear_console ']' 12:24:17 ++ /usr/bin/clear_console -q 12:24:17 Build step 'Execute shell' marked build as failure 12:24:17 $ ssh-agent -k 12:24:17 unset SSH_AUTH_SOCK; 12:24:17 unset SSH_AGENT_PID; 12:24:17 echo Agent pid 1563 killed; 12:24:17 [ssh-agent] Stopped. 12:24:17 [PostBuildScript] - [INFO] Executing post build scripts. 12:24:17 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9428732877017032532.sh 12:24:17 ---> sysstat.sh 12:24:18 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16305877922701763060.sh 12:24:18 ---> package-listing.sh 12:24:18 ++ facter osfamily 12:24:18 ++ tr '[:upper:]' '[:lower:]' 12:24:18 + OS_FAMILY=debian 12:24:18 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 12:24:18 + START_PACKAGES=/tmp/packages_start.txt 12:24:18 + END_PACKAGES=/tmp/packages_end.txt 12:24:18 + DIFF_PACKAGES=/tmp/packages_diff.txt 12:24:18 + PACKAGES=/tmp/packages_start.txt 12:24:18 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 12:24:18 + PACKAGES=/tmp/packages_end.txt 12:24:18 + case "${OS_FAMILY}" in 12:24:18 + dpkg -l 12:24:18 + grep '^ii' 12:24:18 + '[' -f /tmp/packages_start.txt ']' 12:24:18 + '[' -f /tmp/packages_end.txt ']' 12:24:18 + diff /tmp/packages_start.txt /tmp/packages_end.txt 12:24:18 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 12:24:18 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 12:24:18 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 12:24:18 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2278185964770531245.sh 12:24:18 ---> capture-instance-metadata.sh 12:24:18 Setup pyenv: 12:24:18 system 12:24:18 3.8.20 12:24:18 3.9.20 12:24:18 3.10.15 12:24:18 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:24:18 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PRgb from file:/tmp/.os_lf_venv 12:24:18 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:24:18 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:24:21 lf-activate-venv(): INFO: Base packages installed successfully 12:24:21 lf-activate-venv(): INFO: Installing additional packages: lftools 12:24:36 lf-activate-venv(): INFO: Adding /tmp/venv-PRgb/bin to PATH 12:24:36 INFO: Running in OpenStack, capturing instance metadata 12:24:37 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins18028278230384861589.sh 12:24:37 provisioning config files... 12:24:38 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #5115 12:24:38 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config1206402581699326350tmp 12:24:38 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 12:24:38 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 12:24:38 provisioning config files... 12:24:38 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 12:24:38 [EnvInject] - Injecting environment variables from a build step. 12:24:38 [EnvInject] - Injecting as environment variables the properties content 12:24:38 SERVER_ID=logs 12:24:38 12:24:38 [EnvInject] - Variables injected successfully. 12:24:38 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1309354310081271319.sh 12:24:38 ---> create-netrc.sh 12:24:38 WARN: Log server credential not found. 12:24:38 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15732345405949696910.sh 12:24:38 ---> python-tools-install.sh 12:24:38 Setup pyenv: 12:24:38 system 12:24:38 3.8.20 12:24:38 3.9.20 12:24:38 3.10.15 12:24:38 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:24:38 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PRgb from file:/tmp/.os_lf_venv 12:24:38 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:24:38 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:24:40 lf-activate-venv(): INFO: Base packages installed successfully 12:24:40 lf-activate-venv(): INFO: Installing additional packages: lftools 12:24:51 lf-activate-venv(): INFO: Adding /tmp/venv-PRgb/bin to PATH 12:24:51 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins1758844306634042664.sh 12:24:51 ---> uv-install.sh 12:24:52 uv 0.11.6 is already installed 12:24:52 uvx 0.11.6 (x86_64-unknown-linux-gnu) 12:24:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13685748903920669340.sh 12:24:52 ---> sudo-logs.sh 12:24:52 Archiving 'sudo' log.. 12:24:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11002340794879797931.sh 12:24:52 ---> job-cost.sh 12:24:52 INFO: Activating Python virtual environment... 12:24:52 Setup pyenv: 12:24:52 system 12:24:52 3.8.20 12:24:52 3.9.20 12:24:52 3.10.15 12:24:52 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:24:52 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PRgb from file:/tmp/.os_lf_venv 12:24:52 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:24:52 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:24:54 lf-activate-venv(): INFO: Base packages installed successfully 12:24:54 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 12:25:02 lf-activate-venv(): INFO: Adding /tmp/venv-PRgb/bin to PATH 12:25:02 INFO: No stack-cost file found 12:25:02 INFO: Instance uptime: 5717s 12:25:02 INFO: Fetching instance metadata (attempt 1 of 3)... 12:25:02 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 12:25:03 INFO: Successfully fetched instance metadata 12:25:03 INFO: Instance type: v3-standard-4 12:25:03 INFO: Retrieving pricing info for: v3-standard-4 12:25:03 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 12:25:03 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=5717 12:25:03 INFO: Successfully fetched Vexxhost pricing API 12:25:03 INFO: Retrieved cost: 0.22 12:25:03 INFO: Retrieved resource: v3-standard-4 12:25:03 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 12:25:03 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 12:25:03 INFO: Successfully archived job cost data 12:25:03 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,5115,2026-04-15 12:25:03,v3-standard-4,5717,0.22,0.00,FAILURE 12:25:03 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins3835696642928773903.sh 12:25:03 ---> logs-deploy.sh 12:25:03 Setup pyenv: 12:25:03 system 12:25:03 3.8.20 12:25:03 3.9.20 12:25:03 3.10.15 12:25:03 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:25:04 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-PRgb from file:/tmp/.os_lf_venv 12:25:04 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:25:04 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:25:06 lf-activate-venv(): INFO: Base packages installed successfully 12:25:06 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 12:25:16 lf-activate-venv(): INFO: Adding /tmp/venv-PRgb/bin to PATH 12:25:16 WARNING: Nexus logging server not set 12:25:16 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/5115/ 12:25:16 INFO: archiving logs to S3 12:25:18 ---> uname -a: 12:25:18 Linux prd-ubuntu2204-docker-4c-16g-2981 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 12:25:18 12:25:18 12:25:18 ---> lscpu: 12:25:18 Architecture: x86_64 12:25:18 CPU op-mode(s): 32-bit, 64-bit 12:25:18 Address sizes: 40 bits physical, 48 bits virtual 12:25:18 Byte Order: Little Endian 12:25:18 CPU(s): 4 12:25:18 On-line CPU(s) list: 0-3 12:25:18 Vendor ID: AuthenticAMD 12:25:18 Model name: AMD EPYC-Rome Processor 12:25:18 CPU family: 23 12:25:18 Model: 49 12:25:18 Thread(s) per core: 1 12:25:18 Core(s) per socket: 1 12:25:18 Socket(s): 4 12:25:18 Stepping: 0 12:25:18 BogoMIPS: 5599.99 12:25:18 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 12:25:18 Virtualization: AMD-V 12:25:18 Hypervisor vendor: KVM 12:25:18 Virtualization type: full 12:25:18 L1d cache: 128 KiB (4 instances) 12:25:18 L1i cache: 128 KiB (4 instances) 12:25:18 L2 cache: 2 MiB (4 instances) 12:25:18 L3 cache: 64 MiB (4 instances) 12:25:18 NUMA node(s): 1 12:25:18 NUMA node0 CPU(s): 0-3 12:25:18 Vulnerability Gather data sampling: Not affected 12:25:18 Vulnerability Indirect target selection: Not affected 12:25:18 Vulnerability Itlb multihit: Not affected 12:25:18 Vulnerability L1tf: Not affected 12:25:18 Vulnerability Mds: Not affected 12:25:18 Vulnerability Meltdown: Not affected 12:25:18 Vulnerability Mmio stale data: Not affected 12:25:18 Vulnerability Reg file data sampling: Not affected 12:25:18 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 12:25:18 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 12:25:18 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 12:25:18 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 12:25:18 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 12:25:18 Vulnerability Srbds: Not affected 12:25:18 Vulnerability Tsa: Not affected 12:25:18 Vulnerability Tsx async abort: Not affected 12:25:18 Vulnerability Vmscape: Not affected 12:25:18 12:25:18 12:25:18 ---> nproc: 12:25:18 4 12:25:18 12:25:18 12:25:18 ---> df -h: 12:25:18 Filesystem Size Used Avail Use% Mounted on 12:25:18 tmpfs 1.6G 1.1M 1.6G 1% /run 12:25:18 /dev/vda1 78G 18G 61G 23% / 12:25:18 tmpfs 7.9G 0 7.9G 0% /dev/shm 12:25:18 tmpfs 5.0M 0 5.0M 0% /run/lock 12:25:18 /dev/vda15 105M 6.1M 99M 6% /boot/efi 12:25:18 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 12:25:18 12:25:18 12:25:18 ---> free -m: 12:25:18 total used free shared buff/cache available 12:25:18 Mem: 15989 684 11309 3 3995 14962 12:25:18 Swap: 1023 0 1023 12:25:18 12:25:18 12:25:18 ---> ip addr: 12:25:18 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 12:25:18 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 12:25:18 inet 127.0.0.1/8 scope host lo 12:25:18 valid_lft forever preferred_lft forever 12:25:18 inet6 ::1/128 scope host 12:25:18 valid_lft forever preferred_lft forever 12:25:18 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 12:25:18 link/ether fa:16:3e:94:fb:48 brd ff:ff:ff:ff:ff:ff 12:25:18 altname enp0s3 12:25:18 inet 10.30.171.194/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 12:25:18 valid_lft 80675sec preferred_lft 80675sec 12:25:18 inet6 fe80::f816:3eff:fe94:fb48/64 scope link 12:25:18 valid_lft forever preferred_lft forever 12:25:18 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 12:25:18 link/ether b2:19:6c:6d:4c:63 brd ff:ff:ff:ff:ff:ff 12:25:18 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 12:25:18 valid_lft forever preferred_lft forever 12:25:18 inet6 fe80::b019:6cff:fe6d:4c63/64 scope link 12:25:18 valid_lft forever preferred_lft forever 12:25:18 12:25:18 12:25:18 ---> sar -b -r -n DEV: 12:25:18 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-2981) 04/15/26 _x86_64_ (4 CPU) 12:25:18 12:25:18 10:49:57 LINUX RESTART (4 CPU) 12:25:18 12:25:18 10:50:00 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 12:25:18 11:00:23 141.87 18.25 119.50 4.12 2128.51 44268.30 11704.80 12:25:18 11:10:09 72.14 24.23 45.08 2.83 366.23 5411.44 2820.52 12:25:18 11:20:01 14.06 0.21 13.21 0.64 10.22 598.46 533.25 12:25:18 11:30:03 18.27 0.07 17.41 0.79 4.55 458.20 360.58 12:25:18 11:40:04 5.27 0.01 5.08 0.18 0.48 118.93 262.89 12:25:18 11:50:01 7.84 0.02 7.48 0.34 1.39 212.63 366.83 12:25:18 12:00:05 5.36 0.00 5.18 0.18 0.30 145.48 910.26 12:25:18 12:10:00 4.94 0.01 4.70 0.23 0.51 157.55 76.34 12:25:18 12:20:01 25.37 0.11 9.55 15.71 1.74 583.25 207963.85 12:25:18 Average: 33.20 4.78 25.62 2.79 287.36 5944.68 25066.38 12:25:18 12:25:18 10:50:00 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 12:25:18 11:00:23 4532500 15212372 713524 4.36 245940 10212072 1529200 8.78 2005432 9076684 95224 12:25:18 11:10:09 751724 3764284 12169404 74.33 265624 2757328 13453456 77.22 2167208 12898828 520 12:25:18 11:20:01 5968024 9077960 6858304 41.89 270168 2850128 7717492 44.30 2206064 7648556 620 12:25:18 11:30:03 8423220 11582792 4356400 26.61 273584 2896344 5250148 30.14 2223836 5187612 536 12:25:18 11:40:04 8097624 11267412 4671556 28.53 274224 2905920 5416988 31.09 2225060 5511520 384 12:25:18 11:50:01 6883792 10078376 5860112 35.79 275216 2929728 6720932 38.58 2228196 6725928 80 12:25:18 12:00:05 6724728 9936024 6002288 36.66 275732 2945924 6879656 39.49 2231384 6886052 392 12:25:18 12:10:00 12010120 15328584 612660 3.74 279268 3048432 1382124 7.93 2238804 1587816 88928 12:25:18 12:20:01 11353724 14718212 1222884 7.47 282276 3091376 2012392 11.55 2264292 2240920 440 12:25:18 Average: 7193940 11218446 4718570 28.82 271337 3737472 5595821 32.12 2198920 6418213 20792 12:25:18 12:25:18 10:50:00 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 12:25:18 11:00:23 lo 3.11 3.11 2.27 2.27 0.00 0.00 0.00 0.00 12:25:18 11:00:23 ens3 163.72 123.45 1973.16 17.17 0.00 0.00 0.00 0.00 12:25:18 11:00:23 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 11:10:09 lo 38.08 38.08 23.65 23.65 0.00 0.00 0.00 0.00 12:25:18 11:10:09 ens3 2.30 2.05 0.61 0.52 0.00 0.00 0.00 0.00 12:25:18 11:10:09 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 11:20:01 lo 32.78 32.78 12.59 12.59 0.00 0.00 0.00 0.00 12:25:18 11:20:01 ens3 1.30 1.30 0.28 1.30 0.00 0.00 0.00 0.00 12:25:18 11:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 11:30:03 lo 13.40 13.40 7.52 7.52 0.00 0.00 0.00 0.00 12:25:18 11:30:03 ens3 0.95 0.75 0.18 0.14 0.00 0.00 0.00 0.00 12:25:18 11:30:03 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 11:40:04 lo 20.34 20.34 9.54 9.54 0.00 0.00 0.00 0.00 12:25:18 11:40:04 ens3 0.76 0.61 0.17 0.14 0.00 0.00 0.00 0.00 12:25:18 11:40:04 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 11:50:01 lo 27.31 27.31 10.69 10.69 0.00 0.00 0.00 0.00 12:25:18 11:50:01 ens3 0.54 0.57 0.11 0.09 0.00 0.00 0.00 0.00 12:25:18 11:50:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 12:00:05 lo 21.18 21.18 10.70 10.70 0.00 0.00 0.00 0.00 12:25:18 12:00:05 ens3 0.88 0.64 0.24 0.18 0.00 0.00 0.00 0.00 12:25:18 12:00:05 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 12:10:00 lo 15.22 15.22 8.47 8.47 0.00 0.00 0.00 0.00 12:25:18 12:10:00 ens3 0.79 0.65 0.22 0.18 0.00 0.00 0.00 0.00 12:25:18 12:10:00 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 12:20:01 lo 23.36 23.36 10.94 10.94 0.00 0.00 0.00 0.00 12:25:18 12:20:01 ens3 1.48 0.71 0.29 0.16 0.00 0.00 0.00 0.00 12:25:18 12:20:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 Average: lo 21.50 21.50 10.64 10.64 0.00 0.00 0.00 0.00 12:25:18 Average: ens3 19.87 15.04 227.77 2.28 0.00 0.00 0.00 0.00 12:25:18 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12:25:18 12:25:18 12:25:18 ---> sar -P ALL: 12:25:18 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-2981) 04/15/26 _x86_64_ (4 CPU) 12:25:18 12:25:18 10:49:57 LINUX RESTART (4 CPU) 12:25:18 12:25:18 10:50:00 CPU %user %nice %system %iowait %steal %idle 12:25:18 11:00:23 all 41.75 0.00 3.10 0.72 0.11 54.32 12:25:18 11:00:23 0 45.05 0.00 3.19 0.87 0.11 50.78 12:25:18 11:00:23 1 39.56 0.00 3.25 0.77 0.11 56.31 12:25:18 11:00:23 2 40.55 0.00 3.03 0.62 0.10 55.69 12:25:18 11:00:23 3 41.84 0.00 2.94 0.61 0.11 54.49 12:25:18 11:10:09 all 66.22 0.00 2.45 0.14 0.13 31.06 12:25:18 11:10:09 0 67.02 0.00 2.60 0.26 0.13 30.00 12:25:18 11:10:09 1 65.62 0.00 2.50 0.18 0.13 31.57 12:25:18 11:10:09 2 65.31 0.00 2.46 0.06 0.12 32.04 12:25:18 11:10:09 3 66.95 0.00 2.22 0.08 0.13 30.62 12:25:18 11:20:01 all 23.28 0.00 1.02 0.06 0.09 75.55 12:25:18 11:20:01 0 23.04 0.00 0.97 0.05 0.08 75.85 12:25:18 11:20:01 1 23.19 0.00 1.11 0.12 0.09 75.50 12:25:18 11:20:01 2 23.71 0.00 1.04 0.02 0.09 75.14 12:25:18 11:20:01 3 23.17 0.00 0.97 0.04 0.09 75.73 12:25:18 11:30:03 all 29.48 0.00 0.95 0.05 0.08 69.45 12:25:18 11:30:03 0 28.77 0.00 0.90 0.02 0.08 70.24 12:25:18 11:30:03 1 29.20 0.00 1.01 0.07 0.08 69.64 12:25:18 11:30:03 2 29.61 0.00 0.86 0.07 0.08 69.38 12:25:18 11:30:03 3 30.35 0.00 1.01 0.03 0.08 68.53 12:25:18 11:40:04 all 8.91 0.00 0.37 0.02 0.06 90.64 12:25:18 11:40:04 0 8.84 0.00 0.36 0.02 0.05 90.74 12:25:18 11:40:04 1 8.95 0.00 0.43 0.04 0.06 90.52 12:25:18 11:40:04 2 8.78 0.00 0.34 0.01 0.05 90.82 12:25:18 11:40:04 3 9.06 0.00 0.36 0.03 0.06 90.50 12:25:18 11:50:01 all 16.83 0.00 0.75 0.06 0.07 82.29 12:25:18 11:50:01 0 16.94 0.00 0.67 0.08 0.07 82.23 12:25:18 11:50:01 1 16.53 0.00 0.77 0.09 0.07 82.54 12:25:18 11:50:01 2 16.92 0.00 0.81 0.08 0.07 82.13 12:25:18 11:50:01 3 16.91 0.00 0.74 0.01 0.07 82.27 12:25:18 12:00:05 all 11.99 0.00 0.59 0.02 0.07 87.33 12:25:18 12:00:05 0 12.17 0.00 0.54 0.01 0.06 87.21 12:25:18 12:00:05 1 12.35 0.00 0.69 0.03 0.07 86.86 12:25:18 12:00:05 2 11.40 0.00 0.60 0.02 0.07 87.91 12:25:18 12:00:05 3 12.06 0.00 0.51 0.02 0.07 87.33 12:25:18 12:10:00 all 9.08 0.00 0.63 0.03 0.06 90.20 12:25:18 12:10:00 0 8.46 0.00 0.48 0.01 0.06 90.99 12:25:18 12:10:00 1 9.01 0.00 0.61 0.04 0.06 90.28 12:25:18 12:10:00 2 9.64 0.00 0.82 0.02 0.07 89.46 12:25:18 12:10:00 3 9.24 0.00 0.61 0.03 0.06 90.06 12:25:18 12:20:01 all 17.35 0.00 0.67 0.07 0.08 81.83 12:25:18 12:20:01 0 17.31 0.00 0.58 0.09 0.08 81.95 12:25:18 12:20:01 1 17.16 0.00 0.60 0.05 0.08 82.11 12:25:18 12:20:01 2 17.40 0.00 0.73 0.11 0.08 81.68 12:25:18 12:20:01 3 17.53 0.00 0.77 0.03 0.08 81.60 12:25:18 Average: all 24.96 0.00 1.17 0.13 0.08 73.65 12:25:18 Average: 0 25.27 0.00 1.15 0.16 0.08 73.34 12:25:18 Average: 1 24.58 0.00 1.23 0.16 0.08 73.95 12:25:18 Average: 2 24.77 0.00 1.19 0.11 0.08 73.84 12:25:18 Average: 3 25.20 0.00 1.13 0.10 0.08 73.49 12:25:18 12:25:18 12:25:18