06:12:22 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/122259 06:12:22 Running as SYSTEM 06:12:22 [EnvInject] - Loading node environment variables. 06:12:22 Building remotely on prd-ubuntu2204-docker-4c-16g-1433 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 06:12:23 [ssh-agent] Looking for ssh-agent implementation... 06:12:23 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 06:12:23 $ ssh-agent 06:12:23 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXR4aZXL/agent.1566 06:12:23 SSH_AGENT_PID=1568 06:12:23 [ssh-agent] Started. 06:12:23 Running ssh-add (command line suppressed) 06:12:23 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4773411890621163594.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_4773411890621163594.key) 06:12:23 [ssh-agent] Using credentials jenkins (jenkins-ssh) 06:12:23 The recommended git tool is: NONE 06:12:26 using credential jenkins-ssh 06:12:26 Wiping out workspace first. 06:12:26 Cloning the remote Git repository 06:12:26 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 06:12:26 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 06:12:26 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 06:12:26 > git --version # timeout=10 06:12:26 > git --version # 'git version 2.34.1' 06:12:26 using GIT_SSH to set credentials jenkins-ssh 06:12:26 Verifying host key using known hosts file, will automatically accept unseen keys 06:12:26 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 06:12:31 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 06:12:31 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 06:12:32 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 06:12:32 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 06:12:32 using GIT_SSH to set credentials jenkins-ssh 06:12:32 Verifying host key using known hosts file, will automatically accept unseen keys 06:12:32 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/59/122259/2 # timeout=10 06:12:32 > git rev-parse 4ebcec314ed10b40929847ad23386ba2fcdc2905^{commit} # timeout=10 06:12:32 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 06:12:32 Checking out Revision 4ebcec314ed10b40929847ad23386ba2fcdc2905 (refs/changes/59/122259/2) 06:12:32 > git config core.sparsecheckout # timeout=10 06:12:32 > git checkout -f 4ebcec314ed10b40929847ad23386ba2fcdc2905 # timeout=10 06:12:32 Commit message: "Resolve TAPI links from OpenROADM topology" 06:12:32 > git rev-parse FETCH_HEAD^{commit} # timeout=10 06:12:32 > git rev-list --no-walk 52ba4e431f49c30d45227f4953ec762ffde1f542 # timeout=10 06:12:33 > git remote # timeout=10 06:12:33 > git submodule init # timeout=10 06:12:33 > git submodule sync # timeout=10 06:12:33 > git config --get remote.origin.url # timeout=10 06:12:33 > git submodule init # timeout=10 06:12:33 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 06:12:33 ERROR: No submodules found. 06:12:36 provisioning config files... 06:12:36 copy managed file [npmrc] to file:/home/jenkins/.npmrc 06:12:36 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 06:12:36 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins2314085981654222742.sh 06:12:36 ---> python-tools-install.sh 06:12:36 Setup pyenv: 06:12:36 * system (set by /opt/pyenv/version) 06:12:36 * 3.8.20 (set by /opt/pyenv/version) 06:12:36 * 3.9.20 (set by /opt/pyenv/version) 06:12:36 3.10.15 06:12:36 3.11.10 06:12:41 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-H388 06:12:41 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 06:12:41 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 06:12:41 lf-activate-venv(): INFO: Attempting to install with network-safe options... 06:12:45 lf-activate-venv(): INFO: Base packages installed successfully 06:12:45 lf-activate-venv(): INFO: Installing additional packages: lftools 06:13:08 lf-activate-venv(): INFO: Adding /tmp/venv-H388/bin to PATH 06:13:08 Generating Requirements File 06:13:25 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. 06:13:25 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 06:13:26 Python 3.11.10 06:13:26 pip 26.0.1 from /tmp/venv-H388/lib/python3.11/site-packages/pip (python 3.11) 06:13:26 appdirs==1.4.4 06:13:26 argcomplete==3.6.3 06:13:26 aspy.yaml==1.3.0 06:13:26 attrs==26.1.0 06:13:26 autopage==0.6.0 06:13:26 beautifulsoup4==4.14.3 06:13:26 boto3==1.42.86 06:13:26 botocore==1.42.86 06:13:26 bs4==0.0.2 06:13:26 certifi==2026.2.25 06:13:26 cffi==2.0.0 06:13:26 cfgv==3.5.0 06:13:26 chardet==7.4.1 06:13:26 charset-normalizer==3.4.7 06:13:26 click==8.3.2 06:13:26 cliff==4.13.3 06:13:26 cmd2==3.4.0 06:13:26 cryptography==3.3.2 06:13:26 debtcollector==3.1.0 06:13:26 decorator==5.2.1 06:13:26 defusedxml==0.7.1 06:13:26 Deprecated==1.3.1 06:13:26 distlib==0.4.0 06:13:26 dnspython==2.8.0 06:13:26 docker==7.1.0 06:13:26 dogpile.cache==1.5.0 06:13:26 durationpy==0.10 06:13:26 email-validator==2.3.0 06:13:26 filelock==3.25.2 06:13:26 future==1.0.0 06:13:26 gitdb==4.0.12 06:13:26 GitPython==3.1.46 06:13:26 httplib2==0.30.2 06:13:26 identify==2.6.18 06:13:26 idna==3.11 06:13:26 importlib-resources==1.5.0 06:13:26 iso8601==2.1.0 06:13:26 Jinja2==3.1.6 06:13:26 jmespath==1.1.0 06:13:26 jsonpatch==1.33 06:13:26 jsonpointer==3.1.1 06:13:26 jsonschema==4.26.0 06:13:26 jsonschema-specifications==2025.9.1 06:13:26 keystoneauth1==5.13.1 06:13:26 kubernetes==35.0.0 06:13:26 lftools==0.37.22 06:13:26 lxml==6.0.2 06:13:26 markdown-it-py==4.0.0 06:13:26 MarkupSafe==3.0.3 06:13:26 mdurl==0.1.2 06:13:26 msgpack==1.1.2 06:13:26 multi_key_dict==2.0.3 06:13:26 munch==4.0.0 06:13:26 netaddr==1.3.0 06:13:26 niet==1.4.2 06:13:26 nodeenv==1.10.0 06:13:26 oauth2client==4.1.3 06:13:26 oauthlib==3.3.1 06:13:26 openstacksdk==4.10.0 06:13:26 os-service-types==1.8.2 06:13:26 osc-lib==4.4.0 06:13:26 oslo.config==10.3.0 06:13:26 oslo.context==6.3.0 06:13:26 oslo.i18n==6.7.2 06:13:26 oslo.log==8.1.0 06:13:26 oslo.serialization==5.9.1 06:13:26 oslo.utils==10.0.1 06:13:26 packaging==26.0 06:13:26 pbr==7.0.3 06:13:26 platformdirs==4.9.6 06:13:26 prettytable==3.17.0 06:13:26 psutil==7.2.2 06:13:26 pyasn1==0.6.3 06:13:26 pyasn1_modules==0.4.2 06:13:26 pycparser==3.0 06:13:26 pygerrit2==2.0.15 06:13:26 PyGithub==2.9.0 06:13:26 Pygments==2.20.0 06:13:26 PyJWT==2.12.1 06:13:26 PyNaCl==1.6.2 06:13:26 pyparsing==2.4.7 06:13:26 pyperclip==1.11.0 06:13:26 pyrsistent==0.20.0 06:13:26 python-cinderclient==9.9.0 06:13:26 python-dateutil==2.9.0.post0 06:13:26 python-discovery==1.2.2 06:13:26 python-heatclient==5.1.0 06:13:26 python-jenkins==1.8.3 06:13:26 python-keystoneclient==5.8.0 06:13:26 python-magnumclient==4.10.0 06:13:26 python-openstackclient==9.0.0 06:13:26 python-swiftclient==4.10.0 06:13:26 PyYAML==6.0.3 06:13:26 referencing==0.37.0 06:13:26 requests==2.33.1 06:13:26 requests-oauthlib==2.0.0 06:13:26 requestsexceptions==1.4.0 06:13:26 rfc3986==2.0.0 06:13:26 rich==14.3.3 06:13:26 rich-argparse==1.7.2 06:13:26 rpds-py==0.30.0 06:13:26 rsa==4.9.1 06:13:26 ruamel.yaml==0.19.1 06:13:26 ruamel.yaml.clib==0.2.15 06:13:26 s3transfer==0.16.0 06:13:26 simplejson==3.20.2 06:13:26 six==1.17.0 06:13:26 smmap==5.0.3 06:13:26 soupsieve==2.8.3 06:13:26 stevedore==5.7.0 06:13:26 tabulate==0.10.0 06:13:26 toml==0.10.2 06:13:26 tomlkit==0.14.0 06:13:26 tqdm==4.67.3 06:13:26 typing_extensions==4.15.0 06:13:26 urllib3==1.26.20 06:13:26 virtualenv==21.2.0 06:13:26 wcwidth==0.6.0 06:13:26 websocket-client==1.9.0 06:13:26 wrapt==2.1.2 06:13:26 xdg==6.0.0 06:13:26 xmltodict==1.0.4 06:13:26 yq==3.4.3 06:13:26 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins2931318948655530471.sh 06:13:26 ---> uv-install.sh 06:13:26 Installing uv/uvx (latest) using shell installer 06:13:27 2026-04-09 06:13:27 URL:https://release-assets.githubusercontent.com/github-production-release-asset/699532645/0fbdbc27-66c6-43a7-a4cb-366b07980aba?sp=r&sv=2018-11-09&sr=b&spr=https&se=2026-04-09T06%3A55%3A19Z&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-09T05%3A54%3A52Z&ske=2026-04-09T06%3A55%3A19Z&sks=b&skv=2018-11-09&sig=6Pp9DL%2FKbN83bgYyOW9AHzw1jDdGolCPiB2%2FwdB3tKM%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NTcxNTQyMSwibmJmIjoxNzc1NzE1MTIxLCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.kQmWZtJn2IBvxvwAp3l4POH_czWFx02u9moXTFam3r8&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [71225/71225] -> "/tmp/uv-install-Vash4M.sh" [1] 06:13:27 downloading uv 0.11.5 x86_64-unknown-linux-gnu 06:13:27 installing to /home/jenkins/.local/bin 06:13:27 uv 06:13:27 uvx 06:13:27 everything's installed! 06:13:28 06:13:28 To add $HOME/.local/bin to your PATH, either restart your shell or run: 06:13:28 06:13:28 source $HOME/.local/bin/env (sh, bash, zsh) 06:13:28 source $HOME/.local/bin/env.fish (fish) 06:13:28 Adding install location to PATH 06:13:28 ---> Validating uv/uvx install 06:13:28 uvx 0.11.5 (x86_64-unknown-linux-gnu) 06:13:28 [EnvInject] - Injecting environment variables from a build step. 06:13:28 [EnvInject] - Injecting as environment variables the properties content 06:13:28 PYTHON=python3 06:13:28 06:13:28 [EnvInject] - Variables injected successfully. 06:13:28 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins3463064317556964879.sh 06:13:28 ---> tox-install.sh 06:13:28 + source /home/jenkins/lf-env.sh 06:13:28 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 06:13:28 ++ mktemp -d /tmp/venv-XXXX 06:13:28 + lf_venv=/tmp/venv-mQ41 06:13:28 + local venv_file=/tmp/.os_lf_venv 06:13:28 + local python=python3 06:13:28 + local options 06:13:28 + local set_path=true 06:13:28 + local install_args= 06:13:28 ++ getopt -o np:v: -l no-path,system-site-packages,python:,venv-file: -n lf-activate-venv -- --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 06:13:28 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 06:13:28 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 06:13:28 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 06:13:28 + true 06:13:28 + case $1 in 06:13:28 + venv_file=/tmp/.toxenv 06:13:28 + shift 2 06:13:28 + true 06:13:28 + case $1 in 06:13:28 + shift 06:13:28 + break 06:13:28 + case $python in 06:13:28 + local pkg_list= 06:13:28 + [[ -d /opt/pyenv ]] 06:13:28 + echo 'Setup pyenv:' 06:13:28 Setup pyenv: 06:13:28 + export PYENV_ROOT=/opt/pyenv 06:13:28 + PYENV_ROOT=/opt/pyenv 06:13:28 + 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 06:13:28 + 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 06:13:28 + pyenv versions 06:13:28 system 06:13:28 3.8.20 06:13:28 3.9.20 06:13:28 3.10.15 06:13:28 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 06:13:28 + command -v pyenv 06:13:28 ++ pyenv init - --no-rehash 06:13:28 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 06:13:28 for i in ${!paths[@]}; do 06:13:28 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 06:13:28 fi; done; 06:13:28 echo "${paths[*]}"'\'')" 06:13:28 export PATH="/opt/pyenv/shims:${PATH}" 06:13:28 export PYENV_SHELL=bash 06:13:28 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 06:13:28 pyenv() { 06:13:28 local command 06:13:28 command="${1:-}" 06:13:28 if [ "$#" -gt 0 ]; then 06:13:28 shift 06:13:28 fi 06:13:28 06:13:28 case "$command" in 06:13:28 rehash|shell) 06:13:28 eval "$(pyenv "sh-$command" "$@")" 06:13:28 ;; 06:13:28 *) 06:13:28 command pyenv "$command" "$@" 06:13:28 ;; 06:13:28 esac 06:13:28 }' 06:13:28 +++ bash --norc -ec 'IFS=:; paths=($PATH); 06:13:28 for i in ${!paths[@]}; do 06:13:28 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 06:13:28 fi; done; 06:13:28 echo "${paths[*]}"' 06:13:28 ++ 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 06:13:28 ++ 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 06:13:28 ++ 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 06:13:28 ++ export PYENV_SHELL=bash 06:13:28 ++ PYENV_SHELL=bash 06:13:28 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 06:13:28 +++ complete -F _pyenv pyenv 06:13:28 ++ lf-pyver python3 06:13:28 ++ local py_version_xy=python3 06:13:28 ++ local py_version_xyz= 06:13:28 ++ pyenv versions 06:13:28 ++ local command 06:13:28 ++ command=versions 06:13:28 ++ '[' 1 -gt 0 ']' 06:13:28 ++ shift 06:13:28 ++ case "$command" in 06:13:28 ++ command pyenv versions 06:13:28 ++ grep -E '^[0-9.]*[0-9]$' 06:13:28 ++ awk '{ print $1 }' 06:13:28 ++ sed 's/^[ *]* //' 06:13:28 ++ [[ ! -s /tmp/.pyenv_versions ]] 06:13:28 +++ grep '^3' /tmp/.pyenv_versions 06:13:28 +++ sort -V 06:13:28 +++ tail -n 1 06:13:28 ++ py_version_xyz=3.11.10 06:13:28 ++ [[ -z 3.11.10 ]] 06:13:28 ++ echo 3.11.10 06:13:28 ++ return 0 06:13:28 + pyenv local 3.11.10 06:13:28 + local command 06:13:28 + command=local 06:13:28 + '[' 2 -gt 0 ']' 06:13:28 + shift 06:13:28 + case "$command" in 06:13:28 + command pyenv local 3.11.10 06:13:28 + for arg in "$@" 06:13:28 + case $arg in 06:13:28 + pkg_list+='tox ' 06:13:28 + for arg in "$@" 06:13:28 + case $arg in 06:13:28 + pkg_list+='virtualenv ' 06:13:28 + for arg in "$@" 06:13:28 + case $arg in 06:13:28 + pkg_list+='urllib3~=1.26.15 ' 06:13:28 + [[ -f /tmp/.toxenv ]] 06:13:28 + [[ ! -f /tmp/.toxenv ]] 06:13:28 + [[ -n '' ]] 06:13:28 + python3 -m venv /tmp/venv-mQ41 06:13:32 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-mQ41' 06:13:32 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-mQ41 06:13:32 + echo /tmp/venv-mQ41 06:13:32 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 06:13:32 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 06:13:32 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 06:13:32 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 06:13:32 + local 'pip_opts=--upgrade --quiet' 06:13:32 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 06:13:32 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 06:13:32 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 06:13:32 + [[ -n '' ]] 06:13:32 + [[ -n '' ]] 06:13:32 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 06:13:32 lf-activate-venv(): INFO: Attempting to install with network-safe options... 06:13:32 + /tmp/venv-mQ41/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 06:13:36 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 06:13:36 lf-activate-venv(): INFO: Base packages installed successfully 06:13:36 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 06:13:36 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 06:13:36 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 06:13:36 + /tmp/venv-mQ41/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 06:13:37 + type python3 06:13:37 + true 06:13:37 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-mQ41/bin to PATH' 06:13:37 lf-activate-venv(): INFO: Adding /tmp/venv-mQ41/bin to PATH 06:13:37 + PATH=/tmp/venv-mQ41/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 06:13:37 + return 0 06:13:37 + python3 --version 06:13:37 Python 3.11.10 06:13:37 + python3 -m pip --version 06:13:37 pip 26.0.1 from /tmp/venv-mQ41/lib/python3.11/site-packages/pip (python 3.11) 06:13:37 + python3 -m pip freeze 06:13:38 cachetools==7.0.5 06:13:38 colorama==0.4.6 06:13:38 distlib==0.4.0 06:13:38 filelock==3.25.2 06:13:38 packaging==26.0 06:13:38 platformdirs==4.9.6 06:13:38 pluggy==1.6.0 06:13:38 pyproject-api==1.10.0 06:13:38 python-discovery==1.2.2 06:13:38 tomli_w==1.2.0 06:13:38 tox==4.52.0 06:13:38 urllib3==1.26.20 06:13:38 virtualenv==21.2.0 06:13:38 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins8596911176318701484.sh 06:13:38 [EnvInject] - Injecting environment variables from a build step. 06:13:38 [EnvInject] - Injecting as environment variables the properties content 06:13:38 PARALLEL=True 06:13:38 06:13:38 [EnvInject] - Variables injected successfully. 06:13:38 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins10846573357521434614.sh 06:13:38 ---> tox-run.sh 06:13:38 + 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 06:13:38 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 06:13:38 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 06:13:38 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 06:13:38 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 06:13:38 + source /home/jenkins/lf-env.sh 06:13:38 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 06:13:38 ++ mktemp -d /tmp/venv-XXXX 06:13:38 + lf_venv=/tmp/venv-7uom 06:13:38 + local venv_file=/tmp/.os_lf_venv 06:13:38 + local python=python3 06:13:38 + local options 06:13:38 + local set_path=true 06:13:38 + local install_args= 06:13:38 ++ 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 06:13:38 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 06:13:38 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 06:13:38 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 06:13:38 + true 06:13:38 + case $1 in 06:13:38 + venv_file=/tmp/.toxenv 06:13:38 + shift 2 06:13:38 + true 06:13:38 + case $1 in 06:13:38 + shift 06:13:38 + break 06:13:38 + case $python in 06:13:38 + local pkg_list= 06:13:38 + [[ -d /opt/pyenv ]] 06:13:38 + echo 'Setup pyenv:' 06:13:38 Setup pyenv: 06:13:38 + export PYENV_ROOT=/opt/pyenv 06:13:38 + PYENV_ROOT=/opt/pyenv 06:13:38 + 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 06:13:38 + 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 06:13:38 + pyenv versions 06:13:38 system 06:13:38 3.8.20 06:13:38 3.9.20 06:13:38 3.10.15 06:13:38 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 06:13:38 + command -v pyenv 06:13:38 ++ pyenv init - --no-rehash 06:13:38 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 06:13:38 for i in ${!paths[@]}; do 06:13:38 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 06:13:38 fi; done; 06:13:38 echo "${paths[*]}"'\'')" 06:13:38 export PATH="/opt/pyenv/shims:${PATH}" 06:13:38 export PYENV_SHELL=bash 06:13:38 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 06:13:38 pyenv() { 06:13:38 local command 06:13:38 command="${1:-}" 06:13:38 if [ "$#" -gt 0 ]; then 06:13:38 shift 06:13:38 fi 06:13:38 06:13:38 case "$command" in 06:13:38 rehash|shell) 06:13:38 eval "$(pyenv "sh-$command" "$@")" 06:13:38 ;; 06:13:38 *) 06:13:38 command pyenv "$command" "$@" 06:13:38 ;; 06:13:38 esac 06:13:38 }' 06:13:38 +++ bash --norc -ec 'IFS=:; paths=($PATH); 06:13:38 for i in ${!paths[@]}; do 06:13:38 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 06:13:38 fi; done; 06:13:38 echo "${paths[*]}"' 06:13:38 ++ 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 06:13:38 ++ 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 06:13:38 ++ 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 06:13:38 ++ export PYENV_SHELL=bash 06:13:38 ++ PYENV_SHELL=bash 06:13:38 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 06:13:38 +++ complete -F _pyenv pyenv 06:13:38 ++ lf-pyver python3 06:13:38 ++ local py_version_xy=python3 06:13:38 ++ local py_version_xyz= 06:13:38 ++ pyenv versions 06:13:38 ++ local command 06:13:38 ++ command=versions 06:13:38 ++ '[' 1 -gt 0 ']' 06:13:38 ++ shift 06:13:38 ++ case "$command" in 06:13:38 ++ command pyenv versions 06:13:38 ++ sed 's/^[ *]* //' 06:13:38 ++ grep -E '^[0-9.]*[0-9]$' 06:13:38 ++ awk '{ print $1 }' 06:13:38 ++ [[ ! -s /tmp/.pyenv_versions ]] 06:13:38 +++ grep '^3' /tmp/.pyenv_versions 06:13:38 +++ sort -V 06:13:38 +++ tail -n 1 06:13:38 ++ py_version_xyz=3.11.10 06:13:38 ++ [[ -z 3.11.10 ]] 06:13:38 ++ echo 3.11.10 06:13:38 ++ return 0 06:13:38 + pyenv local 3.11.10 06:13:38 + local command 06:13:38 + command=local 06:13:38 + '[' 2 -gt 0 ']' 06:13:38 + shift 06:13:38 + case "$command" in 06:13:38 + command pyenv local 3.11.10 06:13:38 + for arg in "$@" 06:13:38 + case $arg in 06:13:38 + pkg_list+='tox ' 06:13:38 + for arg in "$@" 06:13:38 + case $arg in 06:13:38 + pkg_list+='virtualenv ' 06:13:38 + for arg in "$@" 06:13:38 + case $arg in 06:13:38 + pkg_list+='urllib3~=1.26.15 ' 06:13:38 + [[ -f /tmp/.toxenv ]] 06:13:38 ++ cat /tmp/.toxenv 06:13:38 + lf_venv=/tmp/venv-mQ41 06:13:38 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mQ41 from' file:/tmp/.toxenv 06:13:38 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-mQ41 from file:/tmp/.toxenv 06:13:38 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 06:13:38 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 06:13:38 + local 'pip_opts=--upgrade --quiet' 06:13:38 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 06:13:38 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 06:13:38 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 06:13:38 + [[ -n '' ]] 06:13:38 + [[ -n '' ]] 06:13:38 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 06:13:38 lf-activate-venv(): INFO: Attempting to install with network-safe options... 06:13:38 + /tmp/venv-mQ41/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 06:13:39 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 06:13:39 lf-activate-venv(): INFO: Base packages installed successfully 06:13:39 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 06:13:39 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 06:13:39 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 06:13:39 + /tmp/venv-mQ41/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 06:13:40 + type python3 06:13:40 + true 06:13:40 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-mQ41/bin to PATH' 06:13:40 lf-activate-venv(): INFO: Adding /tmp/venv-mQ41/bin to PATH 06:13:40 + PATH=/tmp/venv-mQ41/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 06:13:40 + return 0 06:13:40 + [[ -d /opt/pyenv ]] 06:13:40 + echo '---> Setting up pyenv' 06:13:40 ---> Setting up pyenv 06:13:40 + export PYENV_ROOT=/opt/pyenv 06:13:40 + PYENV_ROOT=/opt/pyenv 06:13:40 + export PATH=/opt/pyenv/bin:/tmp/venv-mQ41/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 06:13:40 + PATH=/opt/pyenv/bin:/tmp/venv-mQ41/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 06:13:40 ++ pwd 06:13:40 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 06:13:40 + export PYTHONPATH 06:13:40 + export TOX_TESTENV_PASSENV=PYTHONPATH 06:13:40 + TOX_TESTENV_PASSENV=PYTHONPATH 06:13:40 + tox --version 06:13:40 4.52.0 from /tmp/venv-mQ41/lib/python3.11/site-packages/tox/__init__.py 06:13:40 + PARALLEL=True 06:13:40 + TOX_OPTIONS_LIST= 06:13:40 + [[ -n '' ]] 06:13:40 + case ${PARALLEL,,} in 06:13:40 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 06:13:40 + tox --parallel auto --parallel-live 06:13:40 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 06:13:42 checkbashisms: freeze> python -m pip freeze --all 06:13:42 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 06:13:42 docs: install_deps> python -I -m pip install -r docs/requirements.txt 06:13:42 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 06:13:42 checkbashisms: pip==26.0.1,setuptools==82.0.0 06:13:42 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 06:13:42 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)' 06:13:42 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 06:13:44 checkbashisms: OK ✔ in 2.99 seconds 06:13:44 pre-commit: install_deps> python -I -m pip install pre-commit 06:13:46 pre-commit: freeze> python -m pip freeze --all 06:13:46 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.25.2,identify==2.6.18,nodeenv==1.10.0,pip==26.0.1,platformdirs==4.9.6,pre_commit==4.5.1,python-discovery==1.2.2,PyYAML==6.0.3,setuptools==82.0.0,virtualenv==21.2.0 06:13:46 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 06:13:46 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)' 06:13:46 /usr/bin/cpan 06:13:46 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 06:13:46 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 06:13:47 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 06:13:47 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 06:13:48 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 06:13:48 [INFO] Initializing environment for https://github.com/hhatto/autopep8. 06:13:48 buildcontroller: freeze> python -m pip freeze --all 06:13:48 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 06:13:48 buildcontroller: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:13:48 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 06:13:48 + update-java-alternatives -l 06:13:48 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 06:13:48 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 06:13:48 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 06:13:48 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 06:13:48 update-alternatives: error: no alternatives for jaotc 06:13:49 update-alternatives: error: no alternatives for rmic 06:13:49 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 06:13:49 + java -version 06:13:49 + JAVA_VER=21 06:13:49 + echo 21 06:13:49 21 06:13:49 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 06:13:49 + javac -version 06:13:49 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 06:13:49 + JAVAC_VER=21 06:13:49 + echo 21 06:13:49 21 06:13:49 ok, java is 21 or newer 06:13:49 + [ 21 -ge 21 ] 06:13:49 + [ 21 -ge 21 ] 06:13:49 + echo ok, java is 21 or newer 06:13:49 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 06:13:49 2026-04-09 06:13:49 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] 06:13:49 + sudo mkdir -p /opt 06:13:49 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 06:13:49 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 06:13:49 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 06:13:49 + mvn --version 06:13:49 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 06:13:49 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 06:13:49 Maven home: /opt/maven 06:13:49 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 06:13:49 Default locale: en, platform encoding: UTF-8 06:13:49 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 06:13:50 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 06:13:50 NOTE: Picked up JDK_JAVA_OPTIONS: 06:13:50 --add-opens=java.base/java.io=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.lang=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.net=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.nio=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.nio.file=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.util=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.util.jar=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.util.stream=ALL-UNNAMED 06:13:50 --add-opens=java.base/java.util.zip=ALL-UNNAMED 06:13:50 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 06:13:50 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 06:13:50 -Xlog:disable 06:13:50 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 06:13:50 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 06:13:50 [INFO] Once installed this environment will be reused. 06:13:50 [INFO] This may take a few minutes... 06:13:56 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 06:13:56 [INFO] Once installed this environment will be reused. 06:13:56 [INFO] This may take a few minutes... 06:14:03 [INFO] Installing environment for https://github.com/hhatto/autopep8. 06:14:03 [INFO] Once installed this environment will be reused. 06:14:03 [INFO] This may take a few minutes... 06:14:06 docs: freeze> python -m pip freeze --all 06:14:07 docs-linkcheck: freeze> python -m pip freeze --all 06:14:07 docs: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.5.0,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 06:14:07 docs: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> sphinx-build -q -W --keep-going -b html -n -d /w/workspace/transportpce-tox-verify-transportpce-master/.tox/docs/tmp/doctrees ../docs/ /w/workspace/transportpce-tox-verify-transportpce-master/docs/_build/html 06:14:07 [INFO] Installing environment for https://github.com/perltidy/perltidy. 06:14:07 [INFO] Once installed this environment will be reused. 06:14:07 [INFO] This may take a few minutes... 06:14:07 docs-linkcheck: alabaster==1.0.0,attrs==26.1.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.2.25,charset-normalizer==3.4.7,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.62.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==2.0.0,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.5.0,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.4,nwdiag==3.0.0,packaging==26.0,pillow==12.2.0,pip==26.0.1,Pygments==2.20.0,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.33.1,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.5.0,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 06:14:07 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 06:14:11 docs: OK ✔ in 29.84 seconds 06:14:11 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 06:14:15 docs-linkcheck: OK ✔ in 31.33 seconds 06:14:15 pylint: freeze> python -m pip freeze --all 06:14:16 pylint: astroid==4.0.4,dill==0.4.1,isort==8.0.1,mccabe==0.7.0,pip==26.0.1,platformdirs==4.9.6,pylint==4.0.5,setuptools==82.0.0,tomlkit==0.14.0 06:14:16 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}$' '{}' + 06:14:19 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 06:14:19 [INFO] Once installed this environment will be reused. 06:14:19 [INFO] This may take a few minutes... 06:14:23 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 06:14:23 [INFO] Once installed this environment will be reused. 06:14:23 [INFO] This may take a few minutes... 06:14:27 trim trailing whitespace.................................................Passed 06:14:27 fix end of files.........................................................Passed 06:14:28 check for added large files..............................................Passed 06:14:28 check for merge conflicts................................................Passed 06:14:28 check for case conflicts.................................................Passed 06:14:28 check json...............................................................Passed 06:14:29 mixed line ending........................................................Passed 06:14:29 Tabs remover.............................................................Passed 06:14:29 autopep8.................................................................Passed 06:14:33 perltidy.................................................................Passed 06:14:34 ShellCheck v0.11.0.......................................................Passed 06:14:37 prettier.................................................................Passed 06:14:39 yamllint.................................................................Passed 06:14:39 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 06:14:40 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 06:14:40 [INFO] Once installed this environment will be reused. 06:14:40 [INFO] This may take a few minutes... 06:14:42 06:14:42 ------------------------------------ 06:14:42 Your code has been rated at 10.00/10 06:14:42 06:14:48 gitlint..................................................................Passed 06:15:30 pylint: OK ✔ in 34.11 seconds 06:15:30 pre-commit: OK ✔ in 1 minute 4.87 seconds 06:15:30 buildcontroller: OK ✔ in 1 minute 48.61 seconds 06:15:30 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 06:15:30 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 06:15:30 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 06:15:30 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 06:15:37 build_karaf_tests121: freeze> python -m pip freeze --all 06:15:37 build_karaf_tests190: freeze> python -m pip freeze --all 06:15:37 build_karaf_tests71: freeze> python -m pip freeze --all 06:15:37 build_karaf_tests221: freeze> python -m pip freeze --all 06:15:37 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:15:37 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 06:15:37 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:15:37 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 06:15:37 build karaf in karafoc with ./karafoc.env 06:15:37 build karaf in karaf71 with ./karaf71.env 06:15:37 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:15:37 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 06:15:37 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:15:37 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 06:15:37 build karaf in karaf221 with ./karaf221.env 06:15:37 build karaf in karaf121 with ./karaf121.env 06:15:37 NOTE: Picked up JDK_JAVA_OPTIONS: 06:15:37 --add-opens=java.base/java.io=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.net=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.file=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.jar=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.stream=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.zip=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 06:15:37 -Xlog:disable 06:15:37 NOTE: Picked up JDK_JAVA_OPTIONS: 06:15:37 --add-opens=java.base/java.io=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.net=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.file=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.jar=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.stream=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.zip=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 06:15:37 -Xlog:disable 06:15:37 NOTE: Picked up JDK_JAVA_OPTIONS: 06:15:37 --add-opens=java.base/java.io=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.net=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.file=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.jar=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.stream=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.zip=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 06:15:37 -Xlog:disable 06:15:37 NOTE: Picked up JDK_JAVA_OPTIONS: 06:15:37 --add-opens=java.base/java.io=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.net=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.nio.file=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.jar=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.stream=ALL-UNNAMED 06:15:37 --add-opens=java.base/java.util.zip=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 06:15:37 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 06:15:37 -Xlog:disable 06:16:29 build_karaf_tests121: OK ✔ in 59.77 seconds 06:16:29 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 06:16:30 build_karaf_tests190: OK ✔ in 1 minute 0.78 seconds 06:16:30 build_karaf_tests221: OK ✔ in 1 minute 0.92 seconds 06:16:30 build_karaf_tests71: OK ✔ in 1 minute 0.92 seconds 06:16:30 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 06:16:30 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 06:16:35 buildlighty: freeze> python -m pip freeze --all 06:16: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.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:16:35 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 06:16:35 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 06:16:36 sims: freeze> python -m pip freeze --all 06:16:37 sims: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:16:37 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 06:16:37 Using lighynode version 22.1.0.6 06:16:37 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 06:17:14 sims: OK ✔ in 8.81 seconds 06:17:14 buildlighty: OK ✔ in 26.78 seconds 06:17:14 testsPCE: freeze> python -m pip freeze --all 06:17:14 testsPCE: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,click==8.3.2,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.8,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.62.1,gnpy4tpce==2.4.7,idna==3.11,iniconfig==2.3.0,injector==0.24.0,invoke==3.0.3,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.5.0,lxml==6.0.2,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.2.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.3,python-dateutil==2.9.0.post0,pytz==2026.1.post1,requests==2.33.1,scipy==1.17.1,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 06:17:14 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 06:17:14 pytest -q transportpce_tests/pce/test01_pce.py 06:18:01 .................... [100%] 06:19:05 20 passed in 110.09s (0:01:50) 06:19:05 pytest -q transportpce_tests/pce/test02_pce_400G.py 06:19:22 ............ [100%] 06:19:52 12 passed in 46.81s 06:19:52 pytest -q transportpce_tests/pce/test03_gnpy.py 06:20:08 ........ [100%] 06:20:29 8 passed in 36.98s 06:20:29 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 06:21:01 ... [100%] 06:21:05 3 passed in 36.06s 06:21:06 testsPCE: OK ✔ in 4 minutes 35.44 seconds 06:21:06 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 06:21:06 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 06:21:06 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 06:21:12 tests190: freeze> python -m pip freeze --all 06:21:12 tests_tapi: freeze> python -m pip freeze --all 06:21:12 tests121: freeze> python -m pip freeze --all 06:21:12 tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:21:12 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 06:21:12 using environment variables from ./karafoc.env 06:21:12 pytest -q transportpce_tests/oc/test01_portmapping.py 06:21:12 tests_tapi: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:21:12 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 06:21:12 using environment variables from ./karaf221.env 06:21:12 tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:21:12 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 06:21:12 using environment variables from ./karaf121.env 06:21:12 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 06:21:12 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 06:22:14 ........... [100%] 06:22:31 10 passed in 78.21s (0:01:18) 06:22:31 pytest -q transportpce_tests/oc/test02_topology.py 06:22:38 .................................. [100%] 06:23:18 21 passed in 124.91s (0:02:04) 06:23:18 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 06:23:18 .......................... [100%] 06:23:38 14 passed in 66.73s (0:01:06) 06:23:38 pytest -q transportpce_tests/oc/test03_renderer.py 06:23:38 ................ [100%] 06:24:17 6 passed in 58.81s 06:24:17 pytest -q transportpce_tests/1.2.1/test03_topology.py 06:24:17 .................... [100%] 06:24:36 19 passed in 57.38s 06:24:36 tests190: OK ✔ in 3 minutes 30.16 seconds 06:24:36 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 06:24:42 tests71: freeze> python -m pip freeze --all 06:24:43 tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:24:43 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 06:24:43 using environment variables from ./karaf71.env 06:24:43 .pytest -q transportpce_tests/7.1/test01_portmapping.py 06:25:03 ............................. [100%] 06:25:38 12 passed in 54.42s 06:25:38 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 06:25:40 ..................................................... [100%] 06:26:48 44 passed in 151.43s (0:02:31) 06:26:48 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 06:26:50 .................................................................... [100%] 06:28:13 24 passed in 84.35s (0:01:24) 06:28:13 pytest -q transportpce_tests/1.2.1/test05_olm.py 06:28:14 . [100%] 06:28:15 62 passed in 157.57s (0:02:37) 06:28:16 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 06:29:01 ............................................................................. [100%] 06:30:46 48 passed in 149.61s (0:02:29) 06:30:46 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 06:30:50 ..................... [100%] 06:31:30 40 passed in 196.66s (0:03:16) 06:31:30 pytest -q transportpce_tests/1.2.1/test06_end2end.py 06:31:31 .............. [100%] 06:31:59 22 passed in 73.53s (0:01:13) 06:32:10 ............................................. [100%] 06:35:22 51 passed in 849.23s (0:14:09) 06:35:22 pytest -q transportpce_tests/tapi/test02_full_topology.py 06:35:40 .................F........................... [100%] 06:40:25 54 passed in 535.11s (0:08:55) 06:40:26 .F [100%] 06:41:23 =================================== FAILURES =================================== 06:41:23 ________ TestTransportPCEFullTopology.test_13_get_tapi_topology_details ________ 06:41:23 06:41:23 self = 06:41:23 06:41:23 def test_13_get_tapi_topology_details(self): 06:41:23 self.tapi_topo["topology-id"] = test_utils.T0_FULL_MULTILAYER_TOPO_UUID 06:41:23 response = test_utils.transportpce_api_rpc_request( 06:41:23 'tapi-topology', 'get-topology-details', self.tapi_topo) 06:41:23 time.sleep(2) 06:41:23 self.assertEqual(response['status_code'], requests.codes.ok) 06:41:23 self.assertEqual(len(response['output']['topology']['node']), 8, 'There should be 8 TAPI nodes') 06:41:23 > self.assertEqual(len(response['output']['topology']['link']), 3, 'There should be 3 TAPI links') 06:41:23 E AssertionError: 2 != 3 : There should be 3 TAPI links 06:41:23 06:41:23 transportpce_tests/tapi/test02_full_topology.py:307: AssertionError 06:41:23 ______ TestTransportPCEFullTopology.test_35_check_uninstall_Tapi_Feature _______ 06:41:23 06:41:23 self = 06:41:23 conn = 06:41:23 method = 'GET' 06:41:23 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 06:41:23 body = None 06:41:23 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='} 06:41:23 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 06:41:23 timeout = Timeout(connect=30, read=30, total=None), chunked = False 06:41:23 response_conn = 06:41:23 preload_content = False, decode_content = False, enforce_content_length = True 06:41:23 06:41:23 def _make_request( 06:41:23 self, 06:41:23 conn: BaseHTTPConnection, 06:41:23 method: str, 06:41:23 url: str, 06:41:23 body: _TYPE_BODY | None = None, 06:41:23 headers: typing.Mapping[str, str] | None = None, 06:41:23 retries: Retry | None = None, 06:41:23 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 06:41:23 chunked: bool = False, 06:41:23 response_conn: BaseHTTPConnection | None = None, 06:41:23 preload_content: bool = True, 06:41:23 decode_content: bool = True, 06:41:23 enforce_content_length: bool = True, 06:41:23 ) -> BaseHTTPResponse: 06:41:23 """ 06:41:23 Perform a request on a given urllib connection object taken from our 06:41:23 pool. 06:41:23 06:41:23 :param conn: 06:41:23 a connection from one of our connection pools 06:41:23 06:41:23 :param method: 06:41:23 HTTP request method (such as GET, POST, PUT, etc.) 06:41:23 06:41:23 :param url: 06:41:23 The URL to perform the request on. 06:41:23 06:41:23 :param body: 06:41:23 Data to send in the request body, either :class:`str`, :class:`bytes`, 06:41:23 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 06:41:23 06:41:23 :param headers: 06:41:23 Dictionary of custom headers to send, such as User-Agent, 06:41:23 If-None-Match, etc. If None, pool headers are used. If provided, 06:41:23 these headers completely replace any pool-specific headers. 06:41:23 06:41:23 :param retries: 06:41:23 Configure the number of retries to allow before raising a 06:41:23 :class:`~urllib3.exceptions.MaxRetryError` exception. 06:41:23 06:41:23 Pass ``None`` to retry until you receive a response. Pass a 06:41:23 :class:`~urllib3.util.retry.Retry` object for fine-grained control 06:41:23 over different types of retries. 06:41:23 Pass an integer number to retry connection errors that many times, 06:41:23 but no other types of errors. Pass zero to never retry. 06:41:23 06:41:23 If ``False``, then retries are disabled and any exception is raised 06:41:23 immediately. Also, instead of raising a MaxRetryError on redirects, 06:41:23 the redirect response will be returned. 06:41:23 06:41:23 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 06:41:23 06:41:23 :param timeout: 06:41:23 If specified, overrides the default timeout for this one 06:41:23 request. It may be a float (in seconds) or an instance of 06:41:23 :class:`urllib3.util.Timeout`. 06:41:23 06:41:23 :param chunked: 06:41:23 If True, urllib3 will send the body using chunked transfer 06:41:23 encoding. Otherwise, urllib3 will send the body using the standard 06:41:23 content-length form. Defaults to False. 06:41:23 06:41:23 :param response_conn: 06:41:23 Set this to ``None`` if you will handle releasing the connection or 06:41:23 set the connection to have the response release it. 06:41:23 06:41:23 :param preload_content: 06:41:23 If True, the response's body will be preloaded during construction. 06:41:23 06:41:23 :param decode_content: 06:41:23 If True, will attempt to decode the body based on the 06:41:23 'content-encoding' header. 06:41:23 06:41:23 :param enforce_content_length: 06:41:23 Enforce content length checking. Body returned by server must match 06:41:23 value of Content-Length header, if present. Otherwise, raise error. 06:41:23 """ 06:41:23 self.num_requests += 1 06:41:23 06:41:23 timeout_obj = self._get_timeout(timeout) 06:41:23 timeout_obj.start_connect() 06:41:23 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 06:41:23 06:41:23 try: 06:41:23 # Trigger any extra validation we need to do. 06:41:23 try: 06:41:23 self._validate_conn(conn) 06:41:23 except (SocketTimeout, BaseSSLError) as e: 06:41:23 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 06:41:23 raise 06:41:23 06:41:23 # _validate_conn() starts the connection to an HTTPS proxy 06:41:23 # so we need to wrap errors with 'ProxyError' here too. 06:41:23 except ( 06:41:23 OSError, 06:41:23 NewConnectionError, 06:41:23 TimeoutError, 06:41:23 BaseSSLError, 06:41:23 CertificateError, 06:41:23 SSLError, 06:41:23 ) as e: 06:41:23 new_e: Exception = e 06:41:23 if isinstance(e, (BaseSSLError, CertificateError)): 06:41:23 new_e = SSLError(e) 06:41:23 # If the connection didn't successfully connect to it's proxy 06:41:23 # then there 06:41:23 if isinstance( 06:41:23 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 06:41:23 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 06:41:23 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 06:41:23 raise new_e 06:41:23 06:41:23 # conn.request() calls http.client.*.request, not the method in 06:41:23 # urllib3.request. It also calls makefile (recv) on the socket. 06:41:23 try: 06:41:23 conn.request( 06:41:23 method, 06:41:23 url, 06:41:23 body=body, 06:41:23 headers=headers, 06:41:23 chunked=chunked, 06:41:23 preload_content=preload_content, 06:41:23 decode_content=decode_content, 06:41:23 enforce_content_length=enforce_content_length, 06:41:23 ) 06:41:23 06:41:23 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 06:41:23 # legitimately able to close the connection after sending a valid response. 06:41:23 # With this behaviour, the received response is still readable. 06:41:23 except BrokenPipeError: 06:41:23 pass 06:41:23 except OSError as e: 06:41:23 # MacOS/Linux 06:41:23 # EPROTOTYPE and ECONNRESET are needed on macOS 06:41:23 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 06:41:23 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 06:41:23 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 06:41:23 raise 06:41:23 06:41:23 # Reset the timeout for the recv() on the socket 06:41:23 read_timeout = timeout_obj.read_timeout 06:41:23 06:41:23 if not conn.is_closed: 06:41:23 # In Python 3 socket.py will catch EAGAIN and return None when you 06:41:23 # try and read into the file pointer created by http.client, which 06:41:23 # instead raises a BadStatusLine exception. Instead of catching 06:41:23 # the exception and assuming all BadStatusLine exceptions are read 06:41:23 # timeouts, check for a zero timeout before making the request. 06:41:23 if read_timeout == 0: 06:41:23 raise ReadTimeoutError( 06:41:23 self, url, f"Read timed out. (read timeout={read_timeout})" 06:41:23 ) 06:41:23 conn.timeout = read_timeout 06:41:23 06:41:23 # Receive the response from the server 06:41:23 try: 06:41:23 > response = conn.getresponse() 06:41:23 ^^^^^^^^^^^^^^^^^^ 06:41:23 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 06:41:23 httplib_response = super().getresponse() 06:41:23 ^^^^^^^^^^^^^^^^^^^^^ 06:41:23 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 06:41:23 response.begin() 06:41:23 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 06:41:23 version, status, reason = self._read_status() 06:41:23 ^^^^^^^^^^^^^^^^^^^ 06:41:23 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 06:41:23 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 06:41:23 self = 06:41:23 b = 06:41:23 06:41:23 def readinto(self, b): 06:41:23 """Read up to len(b) bytes into the writable buffer *b* and return 06:41:23 the number of bytes read. If the socket is non-blocking and no bytes 06:41:23 are available, None is returned. 06:41:23 06:41:23 If *b* is non-empty, a 0 return value indicates that the connection 06:41:23 was shutdown at the other end. 06:41:23 """ 06:41:23 self._checkClosed() 06:41:23 self._checkReadable() 06:41:23 if self._timeout_occurred: 06:41:23 raise OSError("cannot read from timed out object") 06:41:23 while True: 06:41:23 try: 06:41:23 > return self._sock.recv_into(b) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 E TimeoutError: timed out 06:41:23 06:41:23 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 06:41:23 06:41:23 The above exception was the direct cause of the following exception: 06:41:23 06:41:23 self = 06:41:23 request = , stream = False 06:41:23 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 06:41:23 proxies = OrderedDict() 06:41:23 06:41:23 def send( 06:41:23 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 06:41:23 ): 06:41:23 """Sends PreparedRequest object. Returns Response object. 06:41:23 06:41:23 :param request: The :class:`PreparedRequest ` being sent. 06:41:23 :param stream: (optional) Whether to stream the request content. 06:41:23 :param timeout: (optional) How long to wait for the server to send 06:41:23 data before giving up, as a float, or a :ref:`(connect timeout, 06:41:23 read timeout) ` tuple. 06:41:23 :type timeout: float or tuple or urllib3 Timeout object 06:41:23 :param verify: (optional) Either a boolean, in which case it controls whether 06:41:23 we verify the server's TLS certificate, or a string, in which case it 06:41:23 must be a path to a CA bundle to use 06:41:23 :param cert: (optional) Any user-provided SSL certificate to be trusted. 06:41:23 :param proxies: (optional) The proxies dictionary to apply to the request. 06:41:23 :rtype: requests.Response 06:41:23 """ 06:41:23 06:41:23 try: 06:41:23 conn = self.get_connection_with_tls_context( 06:41:23 request, verify, proxies=proxies, cert=cert 06:41:23 ) 06:41:23 except LocationValueError as e: 06:41:23 raise InvalidURL(e, request=request) 06:41:23 06:41:23 self.cert_verify(conn, request.url, verify, cert) 06:41:23 url = self.request_url(request, proxies) 06:41:23 self.add_headers( 06:41:23 request, 06:41:23 stream=stream, 06:41:23 timeout=timeout, 06:41:23 verify=verify, 06:41:23 cert=cert, 06:41:23 proxies=proxies, 06:41:23 ) 06:41:23 06:41:23 chunked = not (request.body is None or "Content-Length" in request.headers) 06:41:23 06:41:23 if isinstance(timeout, tuple): 06:41:23 try: 06:41:23 connect, read = timeout 06:41:23 timeout = TimeoutSauce(connect=connect, read=read) 06:41:23 except ValueError: 06:41:23 raise ValueError( 06:41:23 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 06:41:23 f"or a single float to set both timeouts to the same value." 06:41:23 ) 06:41:23 elif isinstance(timeout, TimeoutSauce): 06:41:23 pass 06:41:23 else: 06:41:23 timeout = TimeoutSauce(connect=timeout, read=timeout) 06:41:23 06:41:23 try: 06:41:23 > resp = conn.urlopen( 06:41:23 method=request.method, 06:41:23 url=url, 06:41:23 body=request.body, 06:41:23 headers=request.headers, 06:41:23 redirect=False, 06:41:23 assert_same_host=False, 06:41:23 preload_content=False, 06:41:23 decode_content=False, 06:41:23 retries=self.max_retries, 06:41:23 timeout=timeout, 06:41:23 chunked=chunked, 06:41:23 ) 06:41:23 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:645: 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 06:41:23 retries = retries.increment( 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 06:41:23 raise reraise(type(error), error, _stacktrace) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 06:41:23 raise value 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 06:41:23 response = self._make_request( 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 06:41:23 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 06:41:23 self = 06:41:23 err = TimeoutError('timed out') 06:41:23 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 06:41:23 timeout_value = 30 06:41:23 06:41:23 def _raise_timeout( 06:41:23 self, 06:41:23 err: BaseSSLError | OSError | SocketTimeout, 06:41:23 url: str, 06:41:23 timeout_value: _TYPE_TIMEOUT | None, 06:41:23 ) -> None: 06:41:23 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 06:41:23 06:41:23 if isinstance(err, SocketTimeout): 06:41:23 > raise ReadTimeoutError( 06:41:23 self, url, f"Read timed out. (read timeout={timeout_value})" 06:41:23 ) from err 06:41:23 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 06:41:23 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 06:41:23 06:41:23 During handling of the above exception, another exception occurred: 06:41:23 06:41:23 self = 06:41:23 06:41:23 def test_35_check_uninstall_Tapi_Feature(self): 06:41:23 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 06:41:23 time.sleep(16) 06:41:23 print("Tapi Feature uninstalled") 06:41:23 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 06:41:23 transportpce_tests/tapi/test02_full_topology.py:787: 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 transportpce_tests/common/test_utils.py:562: in get_ietf_network_request 06:41:23 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 transportpce_tests/common/test_utils.py:117: in get_request 06:41:23 return requests.request( 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 06:41:23 return session.request(method=method, url=url, **kwargs) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:592: in request 06:41:23 resp = self.send(prep, **send_kwargs) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:706: in send 06:41:23 r = adapter.send(request, **kwargs) 06:41:23 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 06:41:23 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 06:41:23 06:41:23 self = 06:41:23 request = , stream = False 06:41:23 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 06:41:23 proxies = OrderedDict() 06:41:23 06:41:23 def send( 06:41:23 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 06:41:23 ): 06:41:23 """Sends PreparedRequest object. Returns Response object. 06:41:23 06:41:23 :param request: The :class:`PreparedRequest ` being sent. 06:41:23 :param stream: (optional) Whether to stream the request content. 06:41:23 :param timeout: (optional) How long to wait for the server to send 06:41:23 data before giving up, as a float, or a :ref:`(connect timeout, 06:41:23 read timeout) ` tuple. 06:41:23 :type timeout: float or tuple or urllib3 Timeout object 06:41:23 :param verify: (optional) Either a boolean, in which case it controls whether 06:41:23 we verify the server's TLS certificate, or a string, in which case it 06:41:23 must be a path to a CA bundle to use 06:41:23 :param cert: (optional) Any user-provided SSL certificate to be trusted. 06:41:23 :param proxies: (optional) The proxies dictionary to apply to the request. 06:41:23 :rtype: requests.Response 06:41:23 """ 06:41:23 06:41:23 try: 06:41:23 conn = self.get_connection_with_tls_context( 06:41:23 request, verify, proxies=proxies, cert=cert 06:41:23 ) 06:41:23 except LocationValueError as e: 06:41:23 raise InvalidURL(e, request=request) 06:41:23 06:41:23 self.cert_verify(conn, request.url, verify, cert) 06:41:23 url = self.request_url(request, proxies) 06:41:23 self.add_headers( 06:41:23 request, 06:41:23 stream=stream, 06:41:23 timeout=timeout, 06:41:23 verify=verify, 06:41:23 cert=cert, 06:41:23 proxies=proxies, 06:41:23 ) 06:41:23 06:41:23 chunked = not (request.body is None or "Content-Length" in request.headers) 06:41:23 06:41:23 if isinstance(timeout, tuple): 06:41:23 try: 06:41:23 connect, read = timeout 06:41:23 timeout = TimeoutSauce(connect=connect, read=read) 06:41:23 except ValueError: 06:41:23 raise ValueError( 06:41:23 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 06:41:23 f"or a single float to set both timeouts to the same value." 06:41:23 ) 06:41:23 elif isinstance(timeout, TimeoutSauce): 06:41:23 pass 06:41:23 else: 06:41:23 timeout = TimeoutSauce(connect=timeout, read=timeout) 06:41:23 06:41:23 try: 06:41:23 resp = conn.urlopen( 06:41:23 method=request.method, 06:41:23 url=url, 06:41:23 body=request.body, 06:41:23 headers=request.headers, 06:41:23 redirect=False, 06:41:23 assert_same_host=False, 06:41:23 preload_content=False, 06:41:23 decode_content=False, 06:41:23 retries=self.max_retries, 06:41:23 timeout=timeout, 06:41:23 chunked=chunked, 06:41:23 ) 06:41:23 06:41:23 except (ProtocolError, OSError) as err: 06:41:23 raise ConnectionError(err, request=request) 06:41:23 06:41:23 except MaxRetryError as e: 06:41:23 if isinstance(e.reason, ConnectTimeoutError): 06:41:23 # TODO: Remove this in 3.0.0: see #2811 06:41:23 if not isinstance(e.reason, NewConnectionError): 06:41:23 raise ConnectTimeout(e, request=request) 06:41:23 06:41:23 if isinstance(e.reason, ResponseError): 06:41:23 raise RetryError(e, request=request) 06:41:23 06:41:23 if isinstance(e.reason, _ProxyError): 06:41:23 raise ProxyError(e, request=request) 06:41:23 06:41:23 if isinstance(e.reason, _SSLError): 06:41:23 # This branch is for urllib3 v1.22 and later. 06:41:23 raise SSLError(e, request=request) 06:41:23 06:41:23 raise ConnectionError(e, request=request) 06:41:23 06:41:23 except ClosedPoolError as e: 06:41:23 raise ConnectionError(e, request=request) 06:41:23 06:41:23 except _ProxyError as e: 06:41:23 raise ProxyError(e) 06:41:23 06:41:23 except (_SSLError, _HTTPError) as e: 06:41:23 if isinstance(e, _SSLError): 06:41:23 # This branch is for urllib3 versions earlier than v1.22 06:41:23 raise SSLError(e, request=request) 06:41:23 elif isinstance(e, ReadTimeoutError): 06:41:23 > raise ReadTimeout(e, request=request) 06:41:23 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 06:41:23 06:41:23 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:691: ReadTimeout 06:41:23 ----------------------------- Captured stdout call ----------------------------- 06:41:23 uninstalling feature odl-transportpce-tapi 06:41:23 client: JAVA_HOME not set; results may vary 06:41:23 odl-transportpce-tapi │ 13.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 06:41:23 Tapi Feature uninstalled 06:41:23 --------------------------- Captured stdout teardown --------------------------- 06:41:23 all processes killed 06:41:23 ODL log file stored 06:41:23 =========================== short test summary info ============================ 06:41:23 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_13_get_tapi_topology_details 06:41:23 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_35_check_uninstall_Tapi_Feature 06:41:23 2 failed, 34 passed in 361.05s (0:06:01) 06:41:23 tests71: OK ✔ in 7 minutes 23.62 seconds 06:41:23 tests121: OK ✔ in 19 minutes 19.96 seconds 06:41:23 tests_tapi: exit 1 (1210.97 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7544 06:41:24 tests_tapi: FAIL ✖ in 20 minutes 17.85 seconds 06:41:24 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 06:41:30 tests221: freeze> python -m pip freeze --all 06:41:31 tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.7,cryptography==46.0.7,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==3.0.3,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.0,urllib3==2.6.3 06:41:31 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 06:41:31 using environment variables from ./karaf221.env 06:41:31 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 06:42:06 ................................... [100%] 06:42:47 35 passed in 75.61s (0:01:15) 06:42:47 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 06:43:18 ...... [100%] 06:43:32 6 passed in 45.41s 06:43:32 pytest -q transportpce_tests/2.2.1/test03_topology.py 06:44:15 ............................................ [100%] 06:48:50 44 passed in 317.72s (0:05:17) 06:48:50 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 06:49:25 ............ [100%] 06:49:50 12 passed in 59.05s 06:49:50 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 06:50:16 ................ [100%] 06:51:45 16 passed in 114.79s (0:01:54) 06:51:45 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 06:52:14 ............................... [100%] 06:52:21 31 passed in 35.99s 06:52:21 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 06:52:56 .......................... [100%] 06:53:51 26 passed in 90.05s (0:01:30) 06:53:51 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 06:54:27 ...................... [100%] 06:55:30 22 passed in 98.35s (0:01:38) 06:55:30 pytest -q transportpce_tests/2.2.1/test09_olm.py 06:56:10 ........................................ [100%] 06:58:32 40 passed in 182.02s (0:03:02) 06:58:32 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 06:59:18 ........................................................................ [ 74%] 07:04:55 ......................... [100%] 07:06:47 97 passed in 494.30s (0:08:14) 07:06:47 pytest -q transportpce_tests/2.2.1/test12_end2end.py 07:07:27 ...................................................... [100%] 07:14:14 54 passed in 447.08s (0:07:27) 07:14:14 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 07:15:09 ........................................................................ [ 71%] 07:20:17 ............................. [100%] 07:22:26 101 passed in 491.69s (0:08:11) 07:22:26 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 07:23:20 ........................................................................ [ 67%] 07:29:07 ................................... [100%] 07:32:27 107 passed in 600.98s (0:10:00) 07:32:28 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 07:33:10 ............................................. [100%] 07:35:48 45 passed in 199.71s (0:03:19) 07:35:48 tests221: OK ✔ in 54 minutes 24.17 seconds 07:35:48 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 07:35:54 tests_hybrid: freeze> python -m pip freeze --all 07:35:54 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.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.20.0,PyNaCl==1.6.2,pytest==9.0.3,requests==2.33.1,setuptools==82.0.1,urllib3==2.6.3 07:35:54 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 07:35:54 using environment variables from ./karaf221.env 07:35:54 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 07:36:35 ................................................... [100%] 07:41:22 51 passed in 327.44s (0:05:27) 07:41:22 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 07:42:04 ........................................................................ [ 66%] 07:46:25 ..................................... [100%] 07:48:31 109 passed in 428.92s (0:07:08) 07:48:31 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 07:49:19 ..................................................... [100%] 07:52:51 53 passed in 259.74s (0:04:19) 07:52:51 buildcontroller: OK (108.61=setup[7.85]+cmd[100.75] seconds) 07:52:51 sims: OK (8.81=setup[6.58]+cmd[2.24] seconds) 07:52:51 build_karaf_tests121: OK (59.77=setup[7.78]+cmd[51.99] seconds) 07:52:51 testsPCE: OK (275.44=setup[44.29]+cmd[231.15] seconds) 07:52:51 tests121: OK (1159.96=setup[6.88]+cmd[1153.08] seconds) 07:52:51 build_karaf_tests221: OK (60.92=setup[7.78]+cmd[53.13] seconds) 07:52:51 tests_tapi: FAIL code 1 (1217.85=setup[6.88]+cmd[1210.97] seconds) 07:52:51 tests221: OK (3264.17=setup[7.28]+cmd[3256.88] seconds) 07:52:51 build_karaf_tests71: OK (60.92=setup[7.77]+cmd[53.15] seconds) 07:52:51 tests71: OK (443.62=setup[7.08]+cmd[436.54] seconds) 07:52:51 build_karaf_tests190: OK (60.78=setup[7.77]+cmd[53.02] seconds) 07:52:51 tests190: OK (210.16=setup[6.82]+cmd[203.34] seconds) 07:52:51 tests_hybrid: OK (1023.57=setup[6.56]+cmd[1017.00] seconds) 07:52:51 buildlighty: OK (26.78=setup[6.36]+cmd[20.42] seconds) 07:52:51 docs: OK (29.84=setup[26.49]+cmd[3.35] seconds) 07:52:51 docs-linkcheck: OK (31.33=setup[26.90]+cmd[4.42] seconds) 07:52:51 checkbashisms: OK (2.99=setup[1.75]+cmd[0.01,0.05,1.19] seconds) 07:52:51 pre-commit: OK (64.87=setup[2.69]+cmd[0.00,0.00,53.21,8.97] seconds) 07:52:51 pylint: OK (34.11=setup[5.24]+cmd[28.87] seconds) 07:52:51 evaluation failed :( (5950.61 seconds) 07:52:51 + tox_status=1 07:52:51 + echo '---> Completed tox runs' 07:52:51 ---> Completed tox runs 07:52:51 + for i in .tox/*/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 ++ echo .tox/build_karaf_tests121/log 07:52:51 + tox_env=build_karaf_tests121 07:52:51 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/build_karaf_tests190/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=build_karaf_tests190 07:52:51 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/build_karaf_tests221/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=build_karaf_tests221 07:52:51 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/build_karaf_tests71/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=build_karaf_tests71 07:52:51 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/buildcontroller/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=buildcontroller 07:52:51 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/buildlighty/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=buildlighty 07:52:51 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/checkbashisms/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=checkbashisms 07:52:51 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/docs-linkcheck/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=docs-linkcheck 07:52:51 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/docs/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=docs 07:52:51 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/pre-commit/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=pre-commit 07:52:51 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/pylint/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=pylint 07:52:51 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/sims/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=sims 07:52:51 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/tests121/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=tests121 07:52:51 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/tests190/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=tests190 07:52:51 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/tests221/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=tests221 07:52:51 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/tests71/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=tests71 07:52:51 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 07:52:51 + for i in .tox/*/log 07:52:51 ++ echo .tox/testsPCE/log 07:52:51 ++ awk -F/ '{print $2}' 07:52:51 + tox_env=testsPCE 07:52:51 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 07:52:52 + for i in .tox/*/log 07:52:52 ++ echo .tox/tests_hybrid/log 07:52:52 ++ awk -F/ '{print $2}' 07:52:52 + tox_env=tests_hybrid 07:52:52 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 07:52:52 + for i in .tox/*/log 07:52:52 ++ echo .tox/tests_tapi/log 07:52:52 ++ awk -F/ '{print $2}' 07:52:52 + tox_env=tests_tapi 07:52:52 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 07:52:52 + DOC_DIR=docs/_build/html 07:52:52 + [[ -d docs/_build/html ]] 07:52:52 + echo '---> Archiving generated docs' 07:52:52 ---> Archiving generated docs 07:52:52 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 07:52:52 + echo '---> tox-run.sh ends' 07:52:52 ---> tox-run.sh ends 07:52:52 + test 1 -eq 0 07:52:52 + exit 1 07:52:52 ++ '[' 1 = 1 ']' 07:52:52 ++ '[' -x /usr/bin/clear_console ']' 07:52:52 ++ /usr/bin/clear_console -q 07:52:52 Build step 'Execute shell' marked build as failure 07:52:52 $ ssh-agent -k 07:52:52 unset SSH_AUTH_SOCK; 07:52:52 unset SSH_AGENT_PID; 07:52:52 echo Agent pid 1568 killed; 07:52:52 [ssh-agent] Stopped. 07:52:52 [PostBuildScript] - [INFO] Executing post build scripts. 07:52:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11388844701236358035.sh 07:52:52 ---> sysstat.sh 07:52:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17544304046712141608.sh 07:52:52 ---> package-listing.sh 07:52:52 ++ facter osfamily 07:52:52 ++ tr '[:upper:]' '[:lower:]' 07:52:53 + OS_FAMILY=debian 07:52:53 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 07:52:53 + START_PACKAGES=/tmp/packages_start.txt 07:52:53 + END_PACKAGES=/tmp/packages_end.txt 07:52:53 + DIFF_PACKAGES=/tmp/packages_diff.txt 07:52:53 + PACKAGES=/tmp/packages_start.txt 07:52:53 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 07:52:53 + PACKAGES=/tmp/packages_end.txt 07:52:53 + case "${OS_FAMILY}" in 07:52:53 + dpkg -l 07:52:53 + grep '^ii' 07:52:53 + '[' -f /tmp/packages_start.txt ']' 07:52:53 + '[' -f /tmp/packages_end.txt ']' 07:52:53 + diff /tmp/packages_start.txt /tmp/packages_end.txt 07:52:53 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 07:52:53 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 07:52:53 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 07:52:53 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13525344269392071312.sh 07:52:53 ---> capture-instance-metadata.sh 07:52:53 Setup pyenv: 07:52:53 system 07:52:53 3.8.20 07:52:53 3.9.20 07:52:53 3.10.15 07:52:53 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:52:53 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-H388 from file:/tmp/.os_lf_venv 07:52:53 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:52:53 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:52:55 lf-activate-venv(): INFO: Base packages installed successfully 07:52:55 lf-activate-venv(): INFO: Installing additional packages: lftools 07:53:08 lf-activate-venv(): INFO: Adding /tmp/venv-H388/bin to PATH 07:53:08 INFO: Running in OpenStack, capturing instance metadata 07:53:08 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17759500236034904622.sh 07:53:08 provisioning config files... 07:53:09 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #5084 07:53:09 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config874800892356367463tmp 07:53:09 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 07:53:09 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 07:53:09 provisioning config files... 07:53:09 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 07:53:09 [EnvInject] - Injecting environment variables from a build step. 07:53:09 [EnvInject] - Injecting as environment variables the properties content 07:53:09 SERVER_ID=logs 07:53:09 07:53:09 [EnvInject] - Variables injected successfully. 07:53:09 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1096494675025888237.sh 07:53:09 ---> create-netrc.sh 07:53:09 WARN: Log server credential not found. 07:53:09 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15725155392218630389.sh 07:53:09 ---> python-tools-install.sh 07:53:09 Setup pyenv: 07:53:09 system 07:53:09 3.8.20 07:53:09 3.9.20 07:53:09 3.10.15 07:53:09 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:53:09 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-H388 from file:/tmp/.os_lf_venv 07:53:09 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:53:09 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:53:11 lf-activate-venv(): INFO: Base packages installed successfully 07:53:11 lf-activate-venv(): INFO: Installing additional packages: lftools 07:53:20 lf-activate-venv(): INFO: Adding /tmp/venv-H388/bin to PATH 07:53:20 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins2753829171147053593.sh 07:53:20 ---> uv-install.sh 07:53:20 uv 0.11.5 is already installed 07:53:20 uvx 0.11.5 (x86_64-unknown-linux-gnu) 07:53:20 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4733448630212370107.sh 07:53:20 ---> sudo-logs.sh 07:53:20 Archiving 'sudo' log.. 07:53:21 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16747802333703569723.sh 07:53:21 ---> job-cost.sh 07:53:21 INFO: Activating Python virtual environment... 07:53:21 Setup pyenv: 07:53:21 system 07:53:21 3.8.20 07:53:21 3.9.20 07:53:21 3.10.15 07:53:21 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:53:21 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-H388 from file:/tmp/.os_lf_venv 07:53:21 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:53:21 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:53:23 lf-activate-venv(): INFO: Base packages installed successfully 07:53:23 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 07:53:29 lf-activate-venv(): INFO: Adding /tmp/venv-H388/bin to PATH 07:53:29 INFO: No stack-cost file found 07:53:29 INFO: Instance uptime: 6110s 07:53:29 INFO: Fetching instance metadata (attempt 1 of 3)... 07:53:29 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 07:53:29 INFO: Successfully fetched instance metadata 07:53:29 INFO: Instance type: v3-standard-4 07:53:29 INFO: Retrieving pricing info for: v3-standard-4 07:53:29 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 07:53:29 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=6110 07:53:30 INFO: Successfully fetched Vexxhost pricing API 07:53:30 INFO: Retrieved cost: 0.22 07:53:30 INFO: Retrieved resource: v3-standard-4 07:53:30 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 07:53:30 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 07:53:30 INFO: Successfully archived job cost data 07:53:30 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,5084,2026-04-09 07:53:30,v3-standard-4,6110,0.22,0.00,FAILURE 07:53:30 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins15140700912051894914.sh 07:53:30 ---> logs-deploy.sh 07:53:30 Setup pyenv: 07:53:30 system 07:53:30 3.8.20 07:53:30 3.9.20 07:53:30 3.10.15 07:53:30 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:53:30 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-H388 from file:/tmp/.os_lf_venv 07:53:30 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:53:30 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:53:32 lf-activate-venv(): INFO: Base packages installed successfully 07:53:32 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 07:53:41 lf-activate-venv(): INFO: Adding /tmp/venv-H388/bin to PATH 07:53:41 WARNING: Nexus logging server not set 07:53:41 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/5084/ 07:53:41 INFO: archiving logs to S3 07:53:43 ---> uname -a: 07:53:43 Linux prd-ubuntu2204-docker-4c-16g-1433 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 07:53:43 07:53:43 07:53:43 ---> lscpu: 07:53:43 Architecture: x86_64 07:53:43 CPU op-mode(s): 32-bit, 64-bit 07:53:43 Address sizes: 40 bits physical, 48 bits virtual 07:53:43 Byte Order: Little Endian 07:53:43 CPU(s): 4 07:53:43 On-line CPU(s) list: 0-3 07:53:43 Vendor ID: AuthenticAMD 07:53:43 Model name: AMD EPYC-Rome Processor 07:53:43 CPU family: 23 07:53:43 Model: 49 07:53:43 Thread(s) per core: 1 07:53:43 Core(s) per socket: 1 07:53:43 Socket(s): 4 07:53:43 Stepping: 0 07:53:43 BogoMIPS: 5599.86 07:53:43 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 07:53:43 Virtualization: AMD-V 07:53:43 Hypervisor vendor: KVM 07:53:43 Virtualization type: full 07:53:43 L1d cache: 128 KiB (4 instances) 07:53:43 L1i cache: 128 KiB (4 instances) 07:53:43 L2 cache: 2 MiB (4 instances) 07:53:43 L3 cache: 64 MiB (4 instances) 07:53:43 NUMA node(s): 1 07:53:43 NUMA node0 CPU(s): 0-3 07:53:43 Vulnerability Gather data sampling: Not affected 07:53:43 Vulnerability Indirect target selection: Not affected 07:53:43 Vulnerability Itlb multihit: Not affected 07:53:43 Vulnerability L1tf: Not affected 07:53:43 Vulnerability Mds: Not affected 07:53:43 Vulnerability Meltdown: Not affected 07:53:43 Vulnerability Mmio stale data: Not affected 07:53:43 Vulnerability Reg file data sampling: Not affected 07:53:43 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 07:53:43 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 07:53:43 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 07:53:43 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 07:53:43 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 07:53:43 Vulnerability Srbds: Not affected 07:53:43 Vulnerability Tsa: Not affected 07:53:43 Vulnerability Tsx async abort: Not affected 07:53:43 Vulnerability Vmscape: Not affected 07:53:43 07:53:43 07:53:43 ---> nproc: 07:53:43 4 07:53:43 07:53:43 07:53:43 ---> df -h: 07:53:43 Filesystem Size Used Avail Use% Mounted on 07:53:43 tmpfs 1.6G 1.1M 1.6G 1% /run 07:53:43 /dev/vda1 78G 18G 61G 23% / 07:53:43 tmpfs 7.9G 0 7.9G 0% /dev/shm 07:53:43 tmpfs 5.0M 0 5.0M 0% /run/lock 07:53:43 /dev/vda15 105M 6.1M 99M 6% /boot/efi 07:53:43 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 07:53:43 07:53:43 07:53:43 ---> free -m: 07:53:43 total used free shared buff/cache available 07:53:43 Mem: 15989 701 11844 3 3443 14945 07:53:43 Swap: 1023 3 1020 07:53:43 07:53:43 07:53:43 ---> ip addr: 07:53:43 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 07:53:43 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 07:53:43 inet 127.0.0.1/8 scope host lo 07:53:43 valid_lft forever preferred_lft forever 07:53:43 inet6 ::1/128 scope host 07:53:43 valid_lft forever preferred_lft forever 07:53:43 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 07:53:43 link/ether fa:16:3e:e3:df:9c brd ff:ff:ff:ff:ff:ff 07:53:43 altname enp0s3 07:53:43 inet 10.30.171.21/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 07:53:43 valid_lft 80284sec preferred_lft 80284sec 07:53:43 inet6 fe80::f816:3eff:fee3:df9c/64 scope link 07:53:43 valid_lft forever preferred_lft forever 07:53:43 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 07:53:43 link/ether e6:4c:c3:f5:26:e1 brd ff:ff:ff:ff:ff:ff 07:53:43 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 07:53:43 valid_lft forever preferred_lft forever 07:53:43 inet6 fe80::e44c:c3ff:fef5:26e1/64 scope link 07:53:43 valid_lft forever preferred_lft forever 07:53:43 07:53:43 07:53:43 ---> sar -b -r -n DEV: 07:53:43 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1433) 04/09/26 _x86_64_ (4 CPU) 07:53:43 07:53:43 06:11:49 LINUX RESTART (4 CPU) 07:53:43 07:53:43 06:20:16 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 07:53:43 06:30:16 72.25 22.41 47.15 2.68 332.50 5235.19 3546.18 07:53:43 06:40:16 14.15 4.33 9.31 0.51 86.24 288.47 345.53 07:53:43 06:50:11 15.75 0.30 14.78 0.68 15.44 614.17 728.43 07:53:43 07:00:03 14.65 0.04 13.87 0.75 2.35 373.45 226.56 07:53:43 07:10:16 4.63 0.02 4.45 0.16 0.73 113.12 39.66 07:53:43 07:20:16 5.56 0.03 5.34 0.18 1.65 140.12 61.11 07:53:43 07:30:16 21.02 0.08 5.38 15.55 2.27 139.76 208638.07 07:53:43 07:40:16 8.67 0.07 8.22 0.39 5.19 532.24 136.52 07:53:43 07:50:14 7.07 0.02 6.75 0.30 0.92 241.62 276.67 07:53:43 Average: 18.17 3.03 12.78 2.35 49.71 852.52 23787.32 07:53:43 07:53:43 06:20:16 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 07:53:43 06:30:16 170952 2674672 13239020 80.86 264256 2312884 14249132 81.79 1925128 13744540 288 07:53:43 06:40:16 4785264 7241176 8696480 53.11 265808 2246228 9532904 54.72 1869980 9219472 460 07:53:43 06:50:11 11392120 13955544 1987204 12.14 270672 2348956 2834852 16.27 1916620 2595680 5572 07:53:43 07:00:03 8806928 11406556 4534796 27.70 273272 2382564 5331188 30.60 1922212 5157028 712 07:53:43 07:10:16 8874000 11486180 4455172 27.21 273916 2394472 5221636 29.97 1923644 5095124 432 07:53:43 07:20:16 7350492 9978504 5961896 36.41 274708 2409512 6747652 38.73 1926200 6606884 104 07:53:43 07:30:16 7106244 9756592 6183744 37.77 277424 2429132 6908468 39.65 1936636 6845060 80 07:53:43 07:40:16 8646924 11412080 4529128 27.66 281584 2539376 5264904 30.22 1945532 5300476 56 07:53:43 07:50:14 7957884 10761240 5179576 31.63 282656 2576452 5965840 34.24 1964908 5967532 68 07:53:43 Average: 7232312 9852505 6085224 37.17 273811 2404397 6895175 39.58 1925651 6725755 864 07:53:43 07:53:43 06:20:16 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 07:53:43 06:30:16 lo 33.35 33.35 21.01 21.01 0.00 0.00 0.00 0.00 07:53:43 06:30:16 ens3 2.14 2.11 0.64 0.56 0.00 0.00 0.00 0.00 07:53:43 06:30:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 06:40:16 lo 33.91 33.91 13.37 13.37 0.00 0.00 0.00 0.00 07:53:43 06:40:16 ens3 1.14 0.97 0.24 1.15 0.00 0.00 0.00 0.00 07:53:43 06:40:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 06:50:11 lo 6.88 6.88 3.62 3.62 0.00 0.00 0.00 0.00 07:53:43 06:50:11 ens3 0.95 0.77 0.26 0.24 0.00 0.00 0.00 0.00 07:53:43 06:50:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:00:03 lo 19.75 19.75 10.13 10.13 0.00 0.00 0.00 0.00 07:53:43 07:00:03 ens3 1.37 0.84 0.43 0.31 0.00 0.00 0.00 0.00 07:53:43 07:00:03 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:10:16 lo 20.84 20.84 8.68 8.68 0.00 0.00 0.00 0.00 07:53:43 07:10:16 ens3 0.74 0.55 0.17 0.13 0.00 0.00 0.00 0.00 07:53:43 07:10:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:20:16 lo 26.31 26.31 11.04 11.04 0.00 0.00 0.00 0.00 07:53:43 07:20:16 ens3 0.92 0.53 0.26 0.18 0.00 0.00 0.00 0.00 07:53:43 07:20:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:30:16 lo 17.44 17.44 10.35 10.35 0.00 0.00 0.00 0.00 07:53:43 07:30:16 ens3 0.66 0.52 0.14 0.11 0.00 0.00 0.00 0.00 07:53:43 07:30:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:40:16 lo 15.23 15.23 8.59 8.59 0.00 0.00 0.00 0.00 07:53:43 07:40:16 ens3 0.78 0.70 0.21 0.17 0.00 0.00 0.00 0.00 07:53:43 07:40:16 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:50:14 lo 21.32 21.32 9.21 9.21 0.00 0.00 0.00 0.00 07:53:43 07:50:14 ens3 0.87 0.66 0.21 0.16 0.00 0.00 0.00 0.00 07:53:43 07:50:14 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 Average: lo 21.68 21.68 10.67 10.67 0.00 0.00 0.00 0.00 07:53:43 Average: ens3 1.06 0.85 0.28 0.33 0.00 0.00 0.00 0.00 07:53:43 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 07:53:43 07:53:43 07:53:43 ---> sar -P ALL: 07:53:43 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-1433) 04/09/26 _x86_64_ (4 CPU) 07:53:43 07:53:43 06:11:49 LINUX RESTART (4 CPU) 07:53:43 07:53:43 06:20:16 CPU %user %nice %system %iowait %steal %idle 07:53:43 06:30:16 all 56.53 0.00 2.07 0.10 0.10 41.21 07:53:43 06:30:16 0 56.40 0.00 2.09 0.13 0.10 41.28 07:53:43 06:30:16 1 56.89 0.00 2.05 0.07 0.10 40.90 07:53:43 06:30:16 2 56.13 0.00 1.90 0.05 0.10 41.83 07:53:43 06:30:16 3 56.70 0.00 2.23 0.14 0.10 40.84 07:53:43 06:40:16 all 19.57 0.00 0.83 0.06 0.10 79.44 07:53:43 06:40:16 0 19.09 0.00 0.87 0.05 0.10 79.89 07:53:43 06:40:16 1 20.33 0.00 0.80 0.04 0.10 78.72 07:53:43 06:40:16 2 19.32 0.00 0.84 0.04 0.10 79.71 07:53:43 06:40:16 3 19.55 0.00 0.82 0.10 0.10 79.43 07:53:43 06:50:11 all 20.53 0.00 0.81 0.04 0.09 78.53 07:53:43 06:50:11 0 19.84 0.00 0.75 0.04 0.08 79.29 07:53:43 06:50:11 1 19.68 0.00 0.81 0.01 0.09 79.41 07:53:43 06:50:11 2 21.26 0.00 0.90 0.05 0.10 77.68 07:53:43 06:50:11 3 21.34 0.00 0.77 0.07 0.09 77.73 07:53:43 07:00:03 all 25.32 0.00 0.86 0.05 0.09 73.68 07:53:43 07:00:03 0 25.40 0.00 1.09 0.08 0.08 73.35 07:53:43 07:00:03 1 25.52 0.00 0.77 0.02 0.09 73.60 07:53:43 07:00:03 2 24.55 0.00 0.78 0.04 0.09 74.53 07:53:43 07:00:03 3 25.82 0.00 0.78 0.06 0.09 73.25 07:53:43 07:10:16 all 8.02 0.00 0.37 0.02 0.09 91.50 07:53:43 07:10:16 0 8.07 0.00 0.35 0.02 0.08 91.48 07:53:43 07:10:16 1 7.89 0.00 0.37 0.03 0.09 91.62 07:53:43 07:10:16 2 8.32 0.00 0.41 0.01 0.09 91.16 07:53:43 07:10:16 3 7.80 0.00 0.37 0.02 0.09 91.73 07:53:43 07:20:16 all 10.02 0.00 0.47 0.02 0.10 89.40 07:53:43 07:20:16 0 9.49 0.00 0.45 0.01 0.10 89.95 07:53:43 07:20:16 1 10.08 0.00 0.50 0.01 0.10 89.32 07:53:43 07:20:16 2 10.41 0.00 0.47 0.01 0.10 89.01 07:53:43 07:20:16 3 10.09 0.00 0.46 0.04 0.10 89.31 07:53:43 07:30:16 all 9.58 0.00 0.49 0.04 0.09 89.80 07:53:43 07:30:16 0 9.66 0.00 0.48 0.05 0.09 89.72 07:53:43 07:30:16 1 9.92 0.00 0.49 0.05 0.10 89.45 07:53:43 07:30:16 2 9.21 0.00 0.52 0.02 0.10 90.14 07:53:43 07:30:16 3 9.52 0.00 0.46 0.05 0.09 89.89 07:53:43 07:40:16 all 13.17 0.00 0.50 0.05 0.09 86.20 07:53:43 07:40:16 0 12.96 0.00 0.53 0.07 0.08 86.36 07:53:43 07:40:16 1 13.68 0.00 0.61 0.06 0.09 85.56 07:53:43 07:40:16 2 12.69 0.00 0.42 0.01 0.09 86.78 07:53:43 07:40:16 3 13.35 0.00 0.44 0.04 0.09 86.09 07:53:43 07:50:14 all 14.42 0.00 0.56 0.02 0.09 84.90 07:53:43 07:50:14 0 14.18 0.00 0.59 0.03 0.09 85.12 07:53:43 07:50:14 1 14.51 0.00 0.56 0.01 0.09 84.83 07:53:43 07:50:14 2 14.34 0.00 0.52 0.04 0.10 85.00 07:53:43 07:50:14 3 14.64 0.00 0.59 0.01 0.10 84.66 07:53:43 Average: all 19.64 0.00 0.77 0.04 0.09 79.45 07:53:43 Average: 0 19.41 0.00 0.80 0.05 0.09 79.65 07:53:43 Average: 1 19.79 0.00 0.77 0.03 0.09 79.32 07:53:43 Average: 2 19.53 0.00 0.75 0.03 0.10 79.59 07:53:43 Average: 3 19.82 0.00 0.77 0.06 0.09 79.26 07:53:43 07:53:43 07:53:43