07:03:10 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/121843 07:03:10 Running as SYSTEM 07:03:10 [EnvInject] - Loading node environment variables. 07:03:10 Building remotely on prd-ubuntu2204-docker-4c-16g-30007 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 07:03:15 [ssh-agent] Looking for ssh-agent implementation... 07:03:16 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 07:03:16 $ ssh-agent 07:03:16 SSH_AUTH_SOCK=/tmp/ssh-XXXXXX3f2D3X/agent.1553 07:03:16 SSH_AGENT_PID=1555 07:03:16 [ssh-agent] Started. 07:03:16 Running ssh-add (command line suppressed) 07:03:16 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_6617578361851450912.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_6617578361851450912.key) 07:03:16 [ssh-agent] Using credentials jenkins (jenkins-ssh) 07:03:16 The recommended git tool is: NONE 07:03:22 using credential jenkins-ssh 07:03:22 Wiping out workspace first. 07:03:22 Cloning the remote Git repository 07:03:22 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 07:03:22 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 07:03:22 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 07:03:22 > git --version # timeout=10 07:03:22 > git --version # 'git version 2.34.1' 07:03:22 using GIT_SSH to set credentials jenkins-ssh 07:03:22 Verifying host key using known hosts file, will automatically accept unseen keys 07:03:22 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 07:03:51 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 07:03:51 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 07:03:51 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 07:03:51 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 07:03:51 using GIT_SSH to set credentials jenkins-ssh 07:03:51 Verifying host key using known hosts file, will automatically accept unseen keys 07:03:51 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/43/121843/4 # timeout=10 07:03:52 > git rev-parse 9c369214f537531a24ea0ae5dc4529f40c503f25^{commit} # timeout=10 07:03:52 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 07:03:52 Checking out Revision 9c369214f537531a24ea0ae5dc4529f40c503f25 (refs/changes/43/121843/4) 07:03:52 > git config core.sparsecheckout # timeout=10 07:03:52 > git checkout -f 9c369214f537531a24ea0ae5dc4529f40c503f25 # timeout=10 07:03:53 Commit message: "TAPI - remove ietfNodeId as an instance variable" 07:03:53 > git rev-parse FETCH_HEAD^{commit} # timeout=10 07:03:53 > git rev-list --no-walk f1118538a571bbe37aa70b9b6a7e8544c1d87fd6 # timeout=10 07:03:53 > git remote # timeout=10 07:03:53 > git submodule init # timeout=10 07:03:53 > git submodule sync # timeout=10 07:03:53 > git config --get remote.origin.url # timeout=10 07:03:53 > git submodule init # timeout=10 07:03:53 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 07:03:53 ERROR: No submodules found. 07:03:56 provisioning config files... 07:03:56 copy managed file [npmrc] to file:/home/jenkins/.npmrc 07:03:56 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 07:03:56 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14007593570310050763.sh 07:03:56 ---> python-tools-install.sh 07:03:56 Setup pyenv: 07:03:56 * system (set by /opt/pyenv/version) 07:03:56 * 3.8.20 (set by /opt/pyenv/version) 07:03:56 * 3.9.20 (set by /opt/pyenv/version) 07:03:56 3.10.15 07:03:56 3.11.10 07:04:02 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-5jM9 07:04:02 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 07:04:02 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:04:02 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:04:06 lf-activate-venv(): INFO: Base packages installed successfully 07:04:06 lf-activate-venv(): INFO: Installing additional packages: lftools 07:04:39 lf-activate-venv(): INFO: Adding /tmp/venv-5jM9/bin to PATH 07:04:39 Generating Requirements File 07:05:04 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. 07:05:04 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 07:05:05 Python 3.11.10 07:05:05 pip 26.0.1 from /tmp/venv-5jM9/lib/python3.11/site-packages/pip (python 3.11) 07:05:05 appdirs==1.4.4 07:05:05 argcomplete==3.6.3 07:05:05 aspy.yaml==1.3.0 07:05:05 attrs==26.1.0 07:05:05 autopage==0.6.0 07:05:05 beautifulsoup4==4.14.3 07:05:05 boto3==1.42.75 07:05:05 botocore==1.42.75 07:05:05 bs4==0.0.2 07:05:05 certifi==2026.2.25 07:05:05 cffi==2.0.0 07:05:05 cfgv==3.5.0 07:05:05 chardet==7.3.0 07:05:05 charset-normalizer==3.4.6 07:05:05 click==8.3.1 07:05:05 cliff==4.13.2 07:05:05 cmd2==3.4.0 07:05:05 cryptography==3.3.2 07:05:05 debtcollector==3.1.0 07:05:05 decorator==5.2.1 07:05:05 defusedxml==0.7.1 07:05:05 Deprecated==1.3.1 07:05:05 distlib==0.4.0 07:05:05 dnspython==2.8.0 07:05:05 docker==7.1.0 07:05:05 dogpile.cache==1.5.0 07:05:05 durationpy==0.10 07:05:05 email-validator==2.3.0 07:05:05 filelock==3.25.2 07:05:05 future==1.0.0 07:05:05 gitdb==4.0.12 07:05:05 GitPython==3.1.46 07:05:05 httplib2==0.30.2 07:05:05 identify==2.6.18 07:05:05 idna==3.11 07:05:05 importlib-resources==1.5.0 07:05:05 iso8601==2.1.0 07:05:05 Jinja2==3.1.6 07:05:05 jmespath==1.1.0 07:05:05 jsonpatch==1.33 07:05:05 jsonpointer==3.1.1 07:05:05 jsonschema==4.26.0 07:05:05 jsonschema-specifications==2025.9.1 07:05:05 keystoneauth1==5.13.1 07:05:05 kubernetes==35.0.0 07:05:05 lftools==0.37.22 07:05:05 lxml==6.0.2 07:05:05 markdown-it-py==4.0.0 07:05:05 MarkupSafe==3.0.3 07:05:05 mdurl==0.1.2 07:05:05 msgpack==1.1.2 07:05:05 multi_key_dict==2.0.3 07:05:05 munch==4.0.0 07:05:05 netaddr==1.3.0 07:05:05 niet==1.4.2 07:05:05 nodeenv==1.10.0 07:05:05 oauth2client==4.1.3 07:05:05 oauthlib==3.3.1 07:05:05 openstacksdk==4.10.0 07:05:05 os-service-types==1.8.2 07:05:05 osc-lib==4.4.0 07:05:05 oslo.config==10.3.0 07:05:05 oslo.context==6.3.0 07:05:05 oslo.i18n==6.7.2 07:05:05 oslo.log==8.1.0 07:05:05 oslo.serialization==5.9.1 07:05:05 oslo.utils==10.0.0 07:05:05 packaging==26.0 07:05:05 pbr==7.0.3 07:05:05 platformdirs==4.9.4 07:05:05 prettytable==3.17.0 07:05:05 psutil==7.2.2 07:05:05 pyasn1==0.6.3 07:05:05 pyasn1_modules==0.4.2 07:05:05 pycparser==3.0 07:05:05 pygerrit2==2.0.15 07:05:05 PyGithub==2.9.0 07:05:05 Pygments==2.19.2 07:05:05 PyJWT==2.12.1 07:05:05 PyNaCl==1.6.2 07:05:05 pyparsing==2.4.7 07:05:05 pyperclip==1.11.0 07:05:05 pyrsistent==0.20.0 07:05:05 python-cinderclient==9.9.0 07:05:05 python-dateutil==2.9.0.post0 07:05:05 python-discovery==1.2.0 07:05:05 python-heatclient==5.1.0 07:05:05 python-jenkins==1.8.3 07:05:05 python-keystoneclient==5.8.0 07:05:05 python-magnumclient==4.10.0 07:05:05 python-openstackclient==9.0.0 07:05:05 python-swiftclient==4.10.0 07:05:05 PyYAML==6.0.3 07:05:05 referencing==0.37.0 07:05:05 requests==2.32.5 07:05:05 requests-oauthlib==2.0.0 07:05:05 requestsexceptions==1.4.0 07:05:05 rfc3986==2.0.0 07:05:05 rich==14.3.3 07:05:05 rich-argparse==1.7.2 07:05:05 rpds-py==0.30.0 07:05:05 rsa==4.9.1 07:05:05 ruamel.yaml==0.19.1 07:05:05 ruamel.yaml.clib==0.2.15 07:05:05 s3transfer==0.16.0 07:05:05 simplejson==3.20.2 07:05:05 six==1.17.0 07:05:05 smmap==5.0.3 07:05:05 soupsieve==2.8.3 07:05:05 stevedore==5.7.0 07:05:05 tabulate==0.10.0 07:05:05 toml==0.10.2 07:05:05 tomlkit==0.14.0 07:05:05 tqdm==4.67.3 07:05:05 typing_extensions==4.15.0 07:05:05 urllib3==1.26.20 07:05:05 virtualenv==21.2.0 07:05:05 wcwidth==0.6.0 07:05:05 websocket-client==1.9.0 07:05:05 wrapt==2.1.2 07:05:05 xdg==6.0.0 07:05:05 xmltodict==1.0.4 07:05:05 yq==3.4.3 07:05:05 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins147456535154014332.sh 07:05:05 ---> uv-install.sh 07:05:05 Installing uv/uvx (latest) using shell installer 07:05:06 2026-03-25 07:05:06 URL:https://release-assets.githubusercontent.com/github-production-release-asset/699532645/8526d680-25b4-4fe7-8df2-386b1bc03575?sp=r&sv=2018-11-09&sr=b&spr=https&se=2026-03-25T07%3A44%3A59Z&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-03-25T06%3A44%3A42Z&ske=2026-03-25T07%3A44%3A59Z&sks=b&skv=2018-11-09&sig=g7AP%2F8SzPLpd3IF%2B3ELUFJTp0%2B8EF%2BakAxzDPtQ29pQ%3D&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmVsZWFzZS1hc3NldHMuZ2l0aHVidXNlcmNvbnRlbnQuY29tIiwia2V5Ijoia2V5MSIsImV4cCI6MTc3NDQyMjU4NywibmJmIjoxNzc0NDIyMjg3LCJwYXRoIjoicmVsZWFzZWFzc2V0cHJvZHVjdGlvbi5ibG9iLmNvcmUud2luZG93cy5uZXQifQ.4RsDRi4OSUM1MvzvbVLmjp8h1M1Djg0xLOpj4da4SKY&response-content-disposition=attachment%3B%20filename%3Duv-installer.sh&response-content-type=application%2Foctet-stream [72114/72114] -> "/tmp/uv-install-OG4NgQ.sh" [1] 07:05:07 downloading uv 0.11.1 x86_64-unknown-linux-gnu 07:05:07 installing to /home/jenkins/.local/bin 07:05:07 uv 07:05:07 uvx 07:05:07 everything's installed! 07:05:07 07:05:07 To add $HOME/.local/bin to your PATH, either restart your shell or run: 07:05:07 07:05:07 source $HOME/.local/bin/env (sh, bash, zsh) 07:05:07 source $HOME/.local/bin/env.fish (fish) 07:05:07 Adding install location to PATH 07:05:07 ---> Validating uv/uvx install 07:05:07 uvx 0.11.1 (x86_64-unknown-linux-gnu) 07:05:07 [EnvInject] - Injecting environment variables from a build step. 07:05:07 [EnvInject] - Injecting as environment variables the properties content 07:05:07 PYTHON=python3 07:05:07 07:05:07 [EnvInject] - Variables injected successfully. 07:05:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins6259741523154852635.sh 07:05:08 ---> tox-install.sh 07:05:08 + source /home/jenkins/lf-env.sh 07:05:08 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 07:05:08 ++ mktemp -d /tmp/venv-XXXX 07:05:08 + lf_venv=/tmp/venv-0lFB 07:05:08 + local venv_file=/tmp/.os_lf_venv 07:05:08 + local python=python3 07:05:08 + local options 07:05:08 + local set_path=true 07:05:08 + local install_args= 07:05:08 ++ 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 07:05:08 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:05:08 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:05:08 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 07:05:08 + true 07:05:08 + case $1 in 07:05:08 + venv_file=/tmp/.toxenv 07:05:08 + shift 2 07:05:08 + true 07:05:08 + case $1 in 07:05:08 + shift 07:05:08 + break 07:05:08 + case $python in 07:05:08 + local pkg_list= 07:05:08 + [[ -d /opt/pyenv ]] 07:05:08 + echo 'Setup pyenv:' 07:05:08 Setup pyenv: 07:05:08 + export PYENV_ROOT=/opt/pyenv 07:05:08 + PYENV_ROOT=/opt/pyenv 07:05:08 + 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 07:05:08 + 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 07:05:08 + pyenv versions 07:05:08 system 07:05:08 3.8.20 07:05:08 3.9.20 07:05:08 3.10.15 07:05:08 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:05:08 + command -v pyenv 07:05:08 ++ pyenv init - --no-rehash 07:05:08 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 07:05:08 for i in ${!paths[@]}; do 07:05:08 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 07:05:08 fi; done; 07:05:08 echo "${paths[*]}"'\'')" 07:05:08 export PATH="/opt/pyenv/shims:${PATH}" 07:05:08 export PYENV_SHELL=bash 07:05:08 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 07:05:08 pyenv() { 07:05:08 local command 07:05:08 command="${1:-}" 07:05:08 if [ "$#" -gt 0 ]; then 07:05:08 shift 07:05:08 fi 07:05:08 07:05:08 case "$command" in 07:05:08 rehash|shell) 07:05:08 eval "$(pyenv "sh-$command" "$@")" 07:05:08 ;; 07:05:08 *) 07:05:08 command pyenv "$command" "$@" 07:05:08 ;; 07:05:08 esac 07:05:08 }' 07:05:08 +++ bash --norc -ec 'IFS=:; paths=($PATH); 07:05:08 for i in ${!paths[@]}; do 07:05:08 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 07:05:08 fi; done; 07:05:08 echo "${paths[*]}"' 07:05:08 ++ 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 07:05:08 ++ 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 07:05:08 ++ 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 07:05:08 ++ export PYENV_SHELL=bash 07:05:08 ++ PYENV_SHELL=bash 07:05:08 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 07:05:08 +++ complete -F _pyenv pyenv 07:05:08 ++ lf-pyver python3 07:05:08 ++ local py_version_xy=python3 07:05:08 ++ local py_version_xyz= 07:05:08 ++ pyenv versions 07:05:08 ++ local command 07:05:08 ++ awk '{ print $1 }' 07:05:08 ++ command=versions 07:05:08 ++ sed 's/^[ *]* //' 07:05:08 ++ grep -E '^[0-9.]*[0-9]$' 07:05:08 ++ '[' 1 -gt 0 ']' 07:05:08 ++ shift 07:05:08 ++ case "$command" in 07:05:08 ++ command pyenv versions 07:05:08 ++ [[ ! -s /tmp/.pyenv_versions ]] 07:05:08 +++ grep '^3' /tmp/.pyenv_versions 07:05:08 +++ sort -V 07:05:08 +++ tail -n 1 07:05:08 ++ py_version_xyz=3.11.10 07:05:08 ++ [[ -z 3.11.10 ]] 07:05:08 ++ echo 3.11.10 07:05:08 ++ return 0 07:05:08 + pyenv local 3.11.10 07:05:08 + local command 07:05:08 + command=local 07:05:08 + '[' 2 -gt 0 ']' 07:05:08 + shift 07:05:08 + case "$command" in 07:05:08 + command pyenv local 3.11.10 07:05:08 + for arg in "$@" 07:05:08 + case $arg in 07:05:08 + pkg_list+='tox ' 07:05:08 + for arg in "$@" 07:05:08 + case $arg in 07:05:08 + pkg_list+='virtualenv ' 07:05:08 + for arg in "$@" 07:05:08 + case $arg in 07:05:08 + pkg_list+='urllib3~=1.26.15 ' 07:05:08 + [[ -f /tmp/.toxenv ]] 07:05:08 + [[ ! -f /tmp/.toxenv ]] 07:05:08 + [[ -n '' ]] 07:05:08 + python3 -m venv /tmp/venv-0lFB 07:05:12 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-0lFB' 07:05:12 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-0lFB 07:05:12 + echo /tmp/venv-0lFB 07:05:12 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 07:05:12 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 07:05:12 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 07:05:12 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:05:12 + local 'pip_opts=--upgrade --quiet' 07:05:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 07:05:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 07:05:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 07:05:12 + [[ -n '' ]] 07:05:12 + [[ -n '' ]] 07:05:12 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 07:05:12 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:05:12 + /tmp/venv-0lFB/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 07:05:17 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 07:05:17 lf-activate-venv(): INFO: Base packages installed successfully 07:05:17 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 07:05:17 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 07:05:17 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 07:05:17 + /tmp/venv-0lFB/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 07:05:19 + type python3 07:05:19 + true 07:05:19 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-0lFB/bin to PATH' 07:05:19 lf-activate-venv(): INFO: Adding /tmp/venv-0lFB/bin to PATH 07:05:19 + PATH=/tmp/venv-0lFB/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 07:05:19 + return 0 07:05:19 + python3 --version 07:05:19 Python 3.11.10 07:05:19 + python3 -m pip --version 07:05:19 pip 26.0.1 from /tmp/venv-0lFB/lib/python3.11/site-packages/pip (python 3.11) 07:05:19 + python3 -m pip freeze 07:05:19 cachetools==7.0.5 07:05:19 colorama==0.4.6 07:05:19 distlib==0.4.0 07:05:19 filelock==3.25.2 07:05:19 packaging==26.0 07:05:19 platformdirs==4.9.4 07:05:19 pluggy==1.6.0 07:05:19 pyproject-api==1.10.0 07:05:19 python-discovery==1.2.0 07:05:19 tomli_w==1.2.0 07:05:19 tox==4.50.3 07:05:19 urllib3==1.26.20 07:05:19 virtualenv==21.2.0 07:05:19 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins10745549410457983454.sh 07:05:19 [EnvInject] - Injecting environment variables from a build step. 07:05:19 [EnvInject] - Injecting as environment variables the properties content 07:05:19 PARALLEL=True 07:05:19 07:05:19 [EnvInject] - Variables injected successfully. 07:05:19 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins13999189804753436453.sh 07:05:19 ---> tox-run.sh 07:05:19 + 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 07:05:19 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 07:05:19 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 07:05:19 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 07:05:19 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 07:05:19 + source /home/jenkins/lf-env.sh 07:05:19 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 07:05:19 ++ mktemp -d /tmp/venv-XXXX 07:05:19 + lf_venv=/tmp/venv-Q1ko 07:05:19 + local venv_file=/tmp/.os_lf_venv 07:05:19 + local python=python3 07:05:19 + local options 07:05:19 + local set_path=true 07:05:19 + local install_args= 07:05:19 ++ 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 07:05:19 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:05:19 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 07:05:19 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 07:05:19 + true 07:05:19 + case $1 in 07:05:19 + venv_file=/tmp/.toxenv 07:05:19 + shift 2 07:05:19 + true 07:05:19 + case $1 in 07:05:19 + shift 07:05:19 + break 07:05:19 + case $python in 07:05:19 + local pkg_list= 07:05:19 + [[ -d /opt/pyenv ]] 07:05:19 + echo 'Setup pyenv:' 07:05:19 Setup pyenv: 07:05:19 + export PYENV_ROOT=/opt/pyenv 07:05:19 + PYENV_ROOT=/opt/pyenv 07:05:19 + 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 07:05:19 + 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 07:05:19 + pyenv versions 07:05:20 system 07:05:20 3.8.20 07:05:20 3.9.20 07:05:20 3.10.15 07:05:20 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 07:05:20 + command -v pyenv 07:05:20 ++ pyenv init - --no-rehash 07:05:20 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 07:05:20 for i in ${!paths[@]}; do 07:05:20 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 07:05:20 fi; done; 07:05:20 echo "${paths[*]}"'\'')" 07:05:20 export PATH="/opt/pyenv/shims:${PATH}" 07:05:20 export PYENV_SHELL=bash 07:05:20 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 07:05:20 pyenv() { 07:05:20 local command 07:05:20 command="${1:-}" 07:05:20 if [ "$#" -gt 0 ]; then 07:05:20 shift 07:05:20 fi 07:05:20 07:05:20 case "$command" in 07:05:20 rehash|shell) 07:05:20 eval "$(pyenv "sh-$command" "$@")" 07:05:20 ;; 07:05:20 *) 07:05:20 command pyenv "$command" "$@" 07:05:20 ;; 07:05:20 esac 07:05:20 }' 07:05:20 +++ bash --norc -ec 'IFS=:; paths=($PATH); 07:05:20 for i in ${!paths[@]}; do 07:05:20 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 07:05:20 fi; done; 07:05:20 echo "${paths[*]}"' 07:05:20 ++ 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 07:05:20 ++ 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 07:05:20 ++ 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 07:05:20 ++ export PYENV_SHELL=bash 07:05:20 ++ PYENV_SHELL=bash 07:05:20 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 07:05:20 +++ complete -F _pyenv pyenv 07:05:20 ++ lf-pyver python3 07:05:20 ++ local py_version_xy=python3 07:05:20 ++ local py_version_xyz= 07:05:20 ++ pyenv versions 07:05:20 ++ local command 07:05:20 ++ command=versions 07:05:20 ++ '[' 1 -gt 0 ']' 07:05:20 ++ shift 07:05:20 ++ case "$command" in 07:05:20 ++ command pyenv versions 07:05:20 ++ sed 's/^[ *]* //' 07:05:20 ++ awk '{ print $1 }' 07:05:20 ++ grep -E '^[0-9.]*[0-9]$' 07:05:20 ++ [[ ! -s /tmp/.pyenv_versions ]] 07:05:20 +++ grep '^3' /tmp/.pyenv_versions 07:05:20 +++ tail -n 1 07:05:20 +++ sort -V 07:05:20 ++ py_version_xyz=3.11.10 07:05:20 ++ [[ -z 3.11.10 ]] 07:05:20 ++ echo 3.11.10 07:05:20 ++ return 0 07:05:20 + pyenv local 3.11.10 07:05:20 + local command 07:05:20 + command=local 07:05:20 + '[' 2 -gt 0 ']' 07:05:20 + shift 07:05:20 + case "$command" in 07:05:20 + command pyenv local 3.11.10 07:05:20 + for arg in "$@" 07:05:20 + case $arg in 07:05:20 + pkg_list+='tox ' 07:05:20 + for arg in "$@" 07:05:20 + case $arg in 07:05:20 + pkg_list+='virtualenv ' 07:05:20 + for arg in "$@" 07:05:20 + case $arg in 07:05:20 + pkg_list+='urllib3~=1.26.15 ' 07:05:20 + [[ -f /tmp/.toxenv ]] 07:05:20 ++ cat /tmp/.toxenv 07:05:20 + lf_venv=/tmp/venv-0lFB 07:05:20 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-0lFB from' file:/tmp/.toxenv 07:05:20 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-0lFB from file:/tmp/.toxenv 07:05:20 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 07:05:20 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 07:05:20 + local 'pip_opts=--upgrade --quiet' 07:05:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 07:05:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 07:05:20 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 07:05:20 + [[ -n '' ]] 07:05:20 + [[ -n '' ]] 07:05:20 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 07:05:20 lf-activate-venv(): INFO: Attempting to install with network-safe options... 07:05:20 + /tmp/venv-0lFB/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 07:05:21 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 07:05:21 lf-activate-venv(): INFO: Base packages installed successfully 07:05:21 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 07:05:21 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 07:05:21 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 07:05:21 + /tmp/venv-0lFB/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 07:05:22 + type python3 07:05:22 + true 07:05:22 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-0lFB/bin to PATH' 07:05:22 lf-activate-venv(): INFO: Adding /tmp/venv-0lFB/bin to PATH 07:05:22 + PATH=/tmp/venv-0lFB/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 07:05:22 + return 0 07:05:22 + [[ -d /opt/pyenv ]] 07:05:22 + echo '---> Setting up pyenv' 07:05:22 ---> Setting up pyenv 07:05:22 + export PYENV_ROOT=/opt/pyenv 07:05:22 + PYENV_ROOT=/opt/pyenv 07:05:22 + export PATH=/opt/pyenv/bin:/tmp/venv-0lFB/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 07:05:22 + PATH=/opt/pyenv/bin:/tmp/venv-0lFB/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 07:05:22 ++ pwd 07:05:22 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 07:05:22 + export PYTHONPATH 07:05:22 + export TOX_TESTENV_PASSENV=PYTHONPATH 07:05:22 + TOX_TESTENV_PASSENV=PYTHONPATH 07:05:22 + tox --version 07:05:22 4.50.3 from /tmp/venv-0lFB/lib/python3.11/site-packages/tox/__init__.py 07:05:22 + PARALLEL=True 07:05:22 + TOX_OPTIONS_LIST= 07:05:22 + [[ -n '' ]] 07:05:22 + case ${PARALLEL,,} in 07:05:22 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 07:05:22 + tox --parallel auto --parallel-live 07:05:22 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 07:05:24 checkbashisms: freeze> python -m pip freeze --all 07:05:24 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 07:05:24 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 07:05:24 docs: install_deps> python -I -m pip install -r docs/requirements.txt 07:05:24 checkbashisms: pip==26.0.1,setuptools==82.0.0 07:05:24 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 07:05:24 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)' 07:05:25 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 07:05:26 checkbashisms: OK ✔ in 3.19 seconds 07:05:26 pre-commit: install_deps> python -I -m pip install pre-commit 07:05:29 pre-commit: freeze> python -m pip freeze --all 07:05:30 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.4,pre_commit==4.5.1,python-discovery==1.2.0,PyYAML==6.0.3,setuptools==82.0.0,virtualenv==21.2.0 07:05:30 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 07:05:30 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)' 07:05:30 /usr/bin/cpan 07:05:30 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 07:05:30 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 07:05:34 buildcontroller: freeze> python -m pip freeze --all 07:05:34 buildcontroller: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:05:34 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 07:05:34 + update-java-alternatives -l 07:05:34 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 07:05:34 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 07:05:34 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 07:05:34 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 07:05:34 update-alternatives: error: no alternatives for jaotc 07:05:34 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 07:05:34 update-alternatives: error: no alternatives for rmic 07:05:35 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 07:05:36 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 07:05:36 + java -version 07:05:36 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 07:05:36 + JAVA_VER=21 07:05:36 + echo 21 07:05:36 21 07:05:36 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 07:05:36 + javac -version 07:05:36 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 07:05:37 + JAVAC_VER=21 07:05:37 + echo 21 07:05:37 + [ 21 -ge 21 ] 07:05:37 + [ 21 -ge 21 ] 07:05:37 + echo ok, java is 21 or newer 07:05:37 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.14/binaries/apache-maven-3.9.14-bin.tar.gz -P /tmp 07:05:37 21 07:05:37 ok, java is 21 or newer 07:05:37 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 07:05:37 2026-03-25 07:05:37 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] 07:05:37 + sudo mkdir -p /opt 07:05:37 + sudo tar xf /tmp/apache-maven-3.9.14-bin.tar.gz -C /opt 07:05:38 + sudo ln -s /opt/apache-maven-3.9.14 /opt/maven 07:05:38 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 07:05:38 + mvn --version 07:05:38 Apache Maven 3.9.14 (996c630dbc656c76214ce58821dcc58be960875b) 07:05:38 Maven home: /opt/maven 07:05:38 Java version: 21.0.10, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 07:05:38 Default locale: en, platform encoding: UTF-8 07:05:38 OS name: "linux", version: "5.15.0-171-generic", arch: "amd64", family: "unix" 07:05:38 NOTE: Picked up JDK_JAVA_OPTIONS: 07:05:38 --add-opens=java.base/java.io=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.lang=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.net=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.nio=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.util=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:05:38 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:05:38 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:05:38 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:05:38 -Xlog:disable 07:05:40 [INFO] Initializing environment for https://github.com/koalaman/shellcheck-precommit. 07:05:40 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier. 07:05:41 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-prettier:prettier@4.0.0-alpha.8. 07:05:42 [INFO] Initializing environment for https://github.com/adrienverge/yamllint. 07:05:45 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 07:05:45 [INFO] Once installed this environment will be reused. 07:05:45 [INFO] This may take a few minutes... 07:06:01 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 07:06:01 [INFO] Once installed this environment will be reused. 07:06:01 [INFO] This may take a few minutes... 07:06:29 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 07:06:29 [INFO] Once installed this environment will be reused. 07:06:29 [INFO] This may take a few minutes... 07:07:03 [INFO] Installing environment for https://github.com/perltidy/perltidy. 07:07:03 [INFO] Once installed this environment will be reused. 07:07:03 [INFO] This may take a few minutes... 07:07:24 [INFO] Installing environment for https://github.com/pre-commit/mirrors-prettier. 07:07:24 [INFO] Once installed this environment will be reused. 07:07:24 [INFO] This may take a few minutes... 07:07:40 [INFO] Installing environment for https://github.com/adrienverge/yamllint. 07:07:40 [INFO] Once installed this environment will be reused. 07:07:40 [INFO] This may take a few minutes... 07:07:51 trim trailing whitespace.................................................Passed 07:07:52 fix end of files.........................................................Passed 07:07:52 check for added large files..............................................Passed 07:07:53 check for merge conflicts................................................Passed 07:07:53 check for case conflicts.................................................Passed 07:07:54 check json...............................................................Passed 07:07:54 mixed line ending........................................................Passed 07:07:55 Tabs remover.............................................................Passed 07:07:55 autopep8.................................................................Passed 07:07:58 perltidy.................................................................Passed 07:08:00 ShellCheck v0.10.0.......................................................docs: freeze> python -m pip freeze --all 07:08:22 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.6,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.3,nwdiag==3.0.0,packaging==26.0,pillow==12.1.1,pip==26.0.1,Pygments==2.19.2,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,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 07:08:22 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 07:08:25 docs-linkcheck: freeze> python -m pip freeze --all 07:08:25 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.6,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.3,nwdiag==3.0.0,packaging==26.0,pillow==12.1.1,pip==26.0.1,Pygments==2.19.2,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,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 07:08:25 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 07:08:32 docs: OK ✔ in 3 minutes 8.56 seconds 07:08:32 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 07:08:59 docs-linkcheck: OK ✔ in 3 minutes 12.04 seconds 07:08:59 pylint: freeze> python -m pip freeze --all 07:08:59 pylint: astroid==4.0.4,dill==0.4.1,isort==8.0.1,mccabe==0.7.0,pip==26.0.1,platformdirs==4.9.4,pylint==4.0.5,setuptools==82.0.0,tomlkit==0.14.0 07:08:59 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}$' '{}' + 07:09:26 07:09:26 ------------------------------------ 07:09:26 Your code has been rated at 10.00/10 07:09:26 07:09:43 Passed 07:09:43 prettier.................................................................Passed 07:09:45 yamllint.................................................................Passed 07:09:45 pylint: OK ✔ in 56.95 seconds 07:09:45 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 07:09:45 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 07:09:45 [INFO] Once installed this environment will be reused. 07:09:45 [INFO] This may take a few minutes... 07:10:03 buildcontroller: OK ✔ in 4 minutes 39.58 seconds 07:10:03 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 07:10:03 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 07:10:03 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 07:10:07 gitlint..................................................................Passed 07:10:07 pre-commit: OK ✔ in 4 minutes 41.28 seconds 07:10:07 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 07:10:33 build_karaf_tests121: freeze> python -m pip freeze --all 07:10:35 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:10:35 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:10:35 build karaf in karaf121 with ./karaf121.env 07:10:35 NOTE: Picked up JDK_JAVA_OPTIONS: 07:10:35 --add-opens=java.base/java.io=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.lang=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.net=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.nio=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.util=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:10:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:10:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:10:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:10:35 -Xlog:disable 07:10:38 build_karaf_tests71: freeze> python -m pip freeze --all 07:10:39 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:10:39 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:10:39 build karaf in karaf71 with ./karaf71.env 07:10:39 build_karaf_tests221: freeze> python -m pip freeze --all 07:10:39 NOTE: Picked up JDK_JAVA_OPTIONS: 07:10:39 --add-opens=java.base/java.io=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.lang=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.net=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.nio=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.util=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:10:39 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:10:39 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:10:39 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:10:39 -Xlog:disable 07:10:40 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:10:40 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:10:40 build karaf in karaf221 with ./karaf221.env 07:10:42 NOTE: Picked up JDK_JAVA_OPTIONS: 07:10:42 --add-opens=java.base/java.io=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.lang=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.net=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.nio=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.util=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:10:42 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:10:42 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:10:42 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:10:42 -Xlog:disable 07:11:04 build_karaf_tests190: freeze> python -m pip freeze --all 07:11:04 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:11:04 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 07:11:04 build karaf in karafoc with ./karafoc.env 07:11:04 NOTE: Picked up JDK_JAVA_OPTIONS: 07:11:04 --add-opens=java.base/java.io=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.lang=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.net=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.nio=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.nio.file=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.util=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.util.jar=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.util.stream=ALL-UNNAMED 07:11:04 --add-opens=java.base/java.util.zip=ALL-UNNAMED 07:11:04 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 07:11:04 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 07:11:04 -Xlog:disable 07:12:22 build_karaf_tests121: OK ✔ in 2 minutes 18.68 seconds 07:12:22 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 07:12:38 build_karaf_tests71: OK ✔ in 2 minutes 32.42 seconds 07:12:38 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 07:13:03 build_karaf_tests221: OK ✔ in 2 minutes 45.93 seconds 07:13:03 build_karaf_tests190: OK ✔ in 2 minutes 54.9 seconds 07:13:03 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 07:14:39 buildlighty: freeze> python -m pip freeze --all 07:14:39 sims: freeze> python -m pip freeze --all 07:14:39 buildlighty: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:14:39 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 07:14:40 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 07:14:40 sims: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:14:40 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 07:14:40 Using lighynode version 22.1.0.6 07:14:40 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 07:18:15 sims: OK ✔ in 2 minutes 7.48 seconds 07:18:15 buildlighty: OK ✔ in 2 minutes 47.19 seconds 07:18:15 testsPCE: freeze> python -m pip freeze --all 07:18:15 testsPCE: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,click==8.3.1,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==2.2.1,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.1.1,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.2,python-dateutil==2.9.0.post0,pytz==2026.1.post1,requests==2.32.5,scipy==1.17.1,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 07:18:15 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 07:18:15 pytest -q transportpce_tests/pce/test01_pce.py 07:19:24 FFFFFFFFFFF...FFFF.F [100%] 07:20:02 =================================== FAILURES =================================== 07:20:02 ________________ TestTransportPCEPce.test_01_load_port_mapping _________________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_01_load_port_mapping(self): 07:20:02 response = test_utils.post_portmapping(self.port_mapping_data) 07:20:02 > self.assertIn(response['status_code'], (requests.codes.created, requests.codes.no_content)) 07:20:02 E AssertionError: 401 not found in (201, 204) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:113: AssertionError 07:20:02 ---------------------------- Captured stdout setup ----------------------------- 07:20:02 sample files content loaded 07:20:02 starting OpenDaylight... 07:20:02 starting KARAF (karaf) TransportPCE build... 07:20:02 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 07:20:02 _____________ TestTransportPCEPce.test_02_load_simple_topology_bi ______________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_02_load_simple_topology_bi(self): 07:20:02 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_bi_dir_data) 07:20:02 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 07:20:02 E AssertionError: 401 not found in (200, 204) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:119: AssertionError 07:20:02 ____________________ TestTransportPCEPce.test_03_get_nodeId ____________________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_03_get_nodeId(self): 07:20:02 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'ROADMA01-SRG1', 'config') 07:20:02 > self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 E AssertionError: 401 != 200 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:125: AssertionError 07:20:02 ____________________ TestTransportPCEPce.test_04_get_linkId ____________________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_04_get_linkId(self): 07:20:02 > response = test_utils.get_ietf_network_link_request( 07:20:02 'openroadm-topology', 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX', 'config') 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:131: 07:20:02 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:20:02 07:20:02 network = 'openroadm-topology' 07:20:02 link = 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX' 07:20:02 content = 'config' 07:20:02 07:20:02 def get_ietf_network_link_request(network: str, link: str, content: str): 07:20:02 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 07:20:02 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 07:20:02 if RESTCONF_VERSION in ('rfc8040'): 07:20:02 format_args = ('{}', network, link, content) 07:20:02 elif content == 'config': 07:20:02 format_args = ('{}', content, network, link) 07:20:02 else: 07:20:02 format_args = ('{}', 'operational', network, link) 07:20:02 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 07:20:02 res = response.json() 07:20:02 return_key = {'rfc8040': 'ietf-network-topology:link', 07:20:02 'draft-bierman02': 'ietf-network-topology:link'} 07:20:02 > link = res[return_key[RESTCONF_VERSION]][0] 07:20:02 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 07:20:02 E KeyError: 'ietf-network-topology:link' 07:20:02 07:20:02 transportpce_tests/common/test_utils.py:602: KeyError 07:20:02 _____________ TestTransportPCEPce.test_05_path_computation_xpdr_bi _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_05_path_computation_xpdr_bi(self): 07:20:02 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:139: 07:20:02 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:20:02 07:20:02 api_module = 'transportpce-pce', rpc = 'path-computation-request' 07:20:02 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'NodeA', 'node-id': 'XPDRA01', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 07:20:02 07:20:02 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 07:20:02 # pylint: disable=consider-using-f-string 07:20:02 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 07:20:02 if payload is None: 07:20:02 data = None 07:20:02 elif RESTCONF_VERSION == 'draft-bierman02': 07:20:02 data = prepend_dict_keys({'input': payload}, api_module + ':') 07:20:02 else: 07:20:02 data = {'input': payload} 07:20:02 response = post_request(url, data) 07:20:02 if response.status_code == requests.codes.no_content: 07:20:02 return_output = None 07:20:02 else: 07:20:02 res = response.json() 07:20:02 return_key = {'rfc8040': api_module + ':output', 07:20:02 'draft-bierman02': 'output'} 07:20:02 if response.status_code == requests.codes.internal_server_error: 07:20:02 return_output = res 07:20:02 else: 07:20:02 > return_output = res[return_key[RESTCONF_VERSION]] 07:20:02 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 07:20:02 E KeyError: 'transportpce-pce:output' 07:20:02 07:20:02 transportpce_tests/common/test_utils.py:761: KeyError 07:20:02 _____________ TestTransportPCEPce.test_06_path_computation_rdm_bi ______________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_06_path_computation_rdm_bi(self): 07:20:02 self.path_computation_input_data["service-a-end"]["node-id"] = "ROADMA01" 07:20:02 self.path_computation_input_data["service-z-end"]["node-id"] = "ROADMC01" 07:20:02 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:151: 07:20:02 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:20:02 07:20:02 api_module = 'transportpce-pce', rpc = 'path-computation-request' 07:20:02 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'NodeA', 'node-id': 'ROADMA01', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 07:20:02 07:20:02 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 07:20:02 # pylint: disable=consider-using-f-string 07:20:02 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 07:20:02 if payload is None: 07:20:02 data = None 07:20:02 elif RESTCONF_VERSION == 'draft-bierman02': 07:20:02 data = prepend_dict_keys({'input': payload}, api_module + ':') 07:20:02 else: 07:20:02 data = {'input': payload} 07:20:02 response = post_request(url, data) 07:20:02 if response.status_code == requests.codes.no_content: 07:20:02 return_output = None 07:20:02 else: 07:20:02 res = response.json() 07:20:02 return_key = {'rfc8040': api_module + ':output', 07:20:02 'draft-bierman02': 'output'} 07:20:02 if response.status_code == requests.codes.internal_server_error: 07:20:02 return_output = res 07:20:02 else: 07:20:02 > return_output = res[return_key[RESTCONF_VERSION]] 07:20:02 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 07:20:02 E KeyError: 'transportpce-pce:output' 07:20:02 07:20:02 transportpce_tests/common/test_utils.py:761: KeyError 07:20:02 _____________ TestTransportPCEPce.test_07_load_simple_topology_uni _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_07_load_simple_topology_uni(self): 07:20:02 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_uni_dir_data) 07:20:02 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 07:20:02 E AssertionError: 401 not found in (200, 204) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:162: AssertionError 07:20:02 ____________________ TestTransportPCEPce.test_08_get_nodeId ____________________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_08_get_nodeId(self): 07:20:02 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-1-2', 'config') 07:20:02 > self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 E AssertionError: 401 != 200 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:168: AssertionError 07:20:02 ____________________ TestTransportPCEPce.test_09_get_linkId ____________________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_09_get_linkId(self): 07:20:02 > response = test_utils.get_ietf_network_link_request( 07:20:02 'openroadm-topology', 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX', 'config') 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:174: 07:20:02 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:20:02 07:20:02 network = 'openroadm-topology' 07:20:02 link = 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX' 07:20:02 content = 'config' 07:20:02 07:20:02 def get_ietf_network_link_request(network: str, link: str, content: str): 07:20:02 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 07:20:02 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 07:20:02 if RESTCONF_VERSION in ('rfc8040'): 07:20:02 format_args = ('{}', network, link, content) 07:20:02 elif content == 'config': 07:20:02 format_args = ('{}', content, network, link) 07:20:02 else: 07:20:02 format_args = ('{}', 'operational', network, link) 07:20:02 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 07:20:02 res = response.json() 07:20:02 return_key = {'rfc8040': 'ietf-network-topology:link', 07:20:02 'draft-bierman02': 'ietf-network-topology:link'} 07:20:02 > link = res[return_key[RESTCONF_VERSION]][0] 07:20:02 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 07:20:02 E KeyError: 'ietf-network-topology:link' 07:20:02 07:20:02 transportpce_tests/common/test_utils.py:602: KeyError 07:20:02 ____________ TestTransportPCEPce.test_10_path_computation_xpdr_uni _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_10_path_computation_xpdr_uni(self): 07:20:02 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 07:20:02 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 07:20:02 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 07:20:02 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 07:20:02 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:186: 07:20:02 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 07:20:02 07:20:02 api_module = 'transportpce-pce', rpc = 'path-computation-request' 07:20:02 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'ORANGE1', 'node-id': 'XPONDER-1-2', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 07:20:02 07:20:02 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 07:20:02 # pylint: disable=consider-using-f-string 07:20:02 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 07:20:02 if payload is None: 07:20:02 data = None 07:20:02 elif RESTCONF_VERSION == 'draft-bierman02': 07:20:02 data = prepend_dict_keys({'input': payload}, api_module + ':') 07:20:02 else: 07:20:02 data = {'input': payload} 07:20:02 response = post_request(url, data) 07:20:02 if response.status_code == requests.codes.no_content: 07:20:02 return_output = None 07:20:02 else: 07:20:02 res = response.json() 07:20:02 return_key = {'rfc8040': api_module + ':output', 07:20:02 'draft-bierman02': 'output'} 07:20:02 if response.status_code == requests.codes.internal_server_error: 07:20:02 return_output = res 07:20:02 else: 07:20:02 > return_output = res[return_key[RESTCONF_VERSION]] 07:20:02 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 07:20:02 E KeyError: 'transportpce-pce:output' 07:20:02 07:20:02 transportpce_tests/common/test_utils.py:761: KeyError 07:20:02 _____________ TestTransportPCEPce.test_11_path_computation_rdm_uni _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_11_path_computation_rdm_uni(self): 07:20:02 self.path_computation_input_data["service-a-end"]["node-id"] = "OpenROADM-2-1" 07:20:02 self.path_computation_input_data["service-a-end"]["clli"] = "cll21" 07:20:02 self.path_computation_input_data["service-z-end"]["node-id"] = "OpenROADM-2-2" 07:20:02 self.path_computation_input_data["service-z-end"]["clli"] = "ncli22" 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:204: AssertionError 07:20:02 ____________ TestTransportPCEPce.test_15_success1_path_computation _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_15_success1_path_computation(self): 07:20:02 self.path_computation_input_data["service-name"] = "service 1" 07:20:02 self.path_computation_input_data["service-a-end"] = {"service-format": "Ethernet", "service-rate": "100", 07:20:02 "clli": "ORANGE2", "node-id": "XPONDER-2-2"} 07:20:02 self.path_computation_input_data["service-z-end"] = {"service-format": "Ethernet", "service-rate": "100", 07:20:02 "clli": "ORANGE1", "node-id": "XPONDER-1-2"} 07:20:02 self.path_computation_input_data["hard-constraints"] = {"customer-code": ["Some customer-code"], 07:20:02 "co-routing": { 07:20:02 "service-identifier-list": [{ 07:20:02 "service-identifier": "Some existing-service"}] 07:20:02 }} 07:20:02 self.path_computation_input_data["soft-constraints"] = {"customer-code": ["Some customer-code"], 07:20:02 "co-routing": { 07:20:02 "service-identifier-list": [{ 07:20:02 "service-identifier": "Some existing-service"}] 07:20:02 }} 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:267: AssertionError 07:20:02 ____________ TestTransportPCEPce.test_16_success2_path_computation _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_16_success2_path_computation(self): 07:20:02 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 07:20:02 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 07:20:02 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 07:20:02 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 07:20:02 del self.path_computation_input_data["hard-constraints"] 07:20:02 del self.path_computation_input_data["soft-constraints"] 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:284: AssertionError 07:20:02 ____________ TestTransportPCEPce.test_17_success3_path_computation _____________ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_17_success3_path_computation(self): 07:20:02 self.path_computation_input_data["hard-constraints"] = {"exclude": 07:20:02 {"node-id": ["OpenROADM-2-1", "OpenROADM-2-2"]}} 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:300: AssertionError 07:20:02 __ TestTransportPCEPce.test_18_path_computation_before_oms_attribute_deletion __ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_18_path_computation_before_oms_attribute_deletion(self): 07:20:02 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-2-2" 07:20:02 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE2" 07:20:02 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-1-2" 07:20:02 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE1" 07:20:02 del self.path_computation_input_data["hard-constraints"] 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:319: AssertionError 07:20:02 __ TestTransportPCEPce.test_20_path_computation_after_oms_attribute_deletion ___ 07:20:02 07:20:02 self = 07:20:02 07:20:02 def test_20_path_computation_after_oms_attribute_deletion(self): 07:20:02 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 07:20:02 'path-computation-request', 07:20:02 self.path_computation_input_data) 07:20:02 self.assertEqual(response['status_code'], requests.codes.ok) 07:20:02 > self.assertIn('Path is calculated', 07:20:02 response['output']['configuration-response-common']['response-message']) 07:20:02 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 07:20:02 07:20:02 transportpce_tests/pce/test01_pce.py:346: AssertionError 07:20:02 --------------------------- Captured stdout teardown --------------------------- 07:20:02 all processes killed 07:20:02 ODL log file stored 07:20:02 =========================== short test summary info ============================ 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_01_load_port_mapping 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_02_load_simple_topology_bi 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_03_get_nodeId 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_04_get_linkId 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_05_path_computation_xpdr_bi 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_06_path_computation_rdm_bi 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_07_load_simple_topology_uni 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_08_get_nodeId 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_09_get_linkId 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_10_path_computation_xpdr_uni 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_11_path_computation_rdm_uni 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_15_success1_path_computation 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_16_success2_path_computation 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_17_success3_path_computation 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_18_path_computation_before_oms_attribute_deletion 07:20:02 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_20_path_computation_after_oms_attribute_deletion 07:20:02 16 failed, 4 passed in 106.06s (0:01:46) 07:20:02 testsPCE: exit 1 (106.50 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce pid=5014 07:20:02 testsPCE: FAIL ✖ in 6 minutes 59.69 seconds 07:20:02 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 07:20:03 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 07:20:03 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 07:20:09 tests190: freeze> python -m pip freeze --all 07:20:09 tests121: freeze> python -m pip freeze --all 07:20:10 tests121: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:20:10 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 07:20:10 using environment variables from ./karaf121.env 07:20:10 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 07:20:10 tests_tapi: freeze> python -m pip freeze --all 07:20:10 tests190: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:20:10 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 07:20:10 using environment variables from ./karafoc.env 07:20:10 pytest -q transportpce_tests/oc/test01_portmapping.py 07:20:10 tests_tapi: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:20:10 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 07:20:10 using environment variables from ./karaf221.env 07:20:10 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 07:21:39 FF................................FFFFFFFFFFFFF............................... [100%] 07:26:56 51 passed in 405.91s (0:06:45) 07:26:56 pytest -q transportpce_tests/tapi/test02_full_topology.py 07:27:53 F [100%] 07:27:55 =================================== FAILURES =================================== 07:27:55 ___________ TestTransportPCEPortmapping.test_01_meta_data_insertion ____________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_01_meta_data_insertion(self): 07:27:55 response = test_utils_oc.metadata_input() 07:27:55 > self.assertEqual(response.status_code, requests.codes.created, 07:27:55 test_utils.CODE_SHOULD_BE_201) 07:27:55 E AssertionError: 401 != 201 : Http status code should be 201 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:48: AssertionError 07:27:55 ---------------------------- Captured stdout setup ----------------------------- 07:27:55 starting OpenDaylight... 07:27:55 starting KARAF (karafoc) TransportPCE build... 07:27:55 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 07:27:55 starting simulator oc-mpdr in OpenROADM device version oc... 07:27:55 Searching for patterns in sample-openconfig-mpdr.log... Pattern found! simulator for oc-mpdr started 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_01_meta_data_insertion 07:27:55 __________ TestTransportPCEPortmapping.test_02_catlog_input_insertion __________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_02_catlog_input_insertion(self): 07:27:55 response = test_utils_oc.catlog_input() 07:27:55 > self.assertEqual(response.status_code, requests.codes.ok, 07:27:55 test_utils.CODE_SHOULD_BE_200) 07:27:55 E AssertionError: 401 != 200 : Http status code should be 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:53: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_02_catlog_input_insertion 07:27:55 __________ TestTransportPCEPortmapping.test_03_xpdr_device_connection __________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_03_xpdr_device_connection(self): 07:27:55 response = test_utils.mount_device("XPDR-OC", 07:27:55 ('oc-mpdr', self.NODE_VERSION)) 07:27:55 > self.assertEqual(response.status_code, requests.codes.created, 07:27:55 test_utils.CODE_SHOULD_BE_201) 07:27:55 E AssertionError: 401 != 201 : Http status code should be 201 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:59: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_03_xpdr_device_connection 07:27:55 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not added to tpce topology... 07:27:55 __________ TestTransportPCEPortmapping.test_04_xpdr_device_connected ___________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_04_xpdr_device_connected(self): 07:27:55 response = test_utils.check_device_connection("XPDR-OC") 07:27:55 > self.assertEqual(response['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:64: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_04_xpdr_device_connected 07:27:55 __________ TestTransportPCEPortmapping.test_05_xpdr_portmapping_info ___________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_05_xpdr_portmapping_info(self): 07:27:55 response = test_utils.get_portmapping_node_attr("XPDR-OC", "node-info", None) 07:27:55 > self.assertEqual(response['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:69: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_05_xpdr_portmapping_info 07:27:55 ________ TestTransportPCEPortmapping.test_06_mpdr_portmapping_NETWORK5 _________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_06_mpdr_portmapping_NETWORK5(self): 07:27:55 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-NETWORK5") 07:27:55 > self.assertEqual(response['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:82: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_06_mpdr_portmapping_NETWORK5 07:27:55 _________ TestTransportPCEPortmapping.test_07_mpdr_portmapping_CLIENT1 _________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_07_mpdr_portmapping_CLIENT1(self): 07:27:55 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-CLIENT1") 07:27:55 > self.assertEqual(response['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:105: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_07_mpdr_portmapping_CLIENT1 07:27:55 ___________ TestTransportPCEPortmapping.test_08_mpdr_switching_pool ____________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_08_mpdr_switching_pool(self): 07:27:55 response = test_utils.get_portmapping_node_attr("XPDR-OC", "switching-pool-lcp", "1") 07:27:55 > self.assertEqual(response['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:132: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_08_mpdr_switching_pool 07:27:55 ____________ TestTransportPCEPortmapping.test_09_check_mccapprofile ____________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_09_check_mccapprofile(self): 07:27:55 res = test_utils.get_portmapping_node_attr("XPDR-OC", "mc-capabilities", "XPDR-mcprofile") 07:27:55 > self.assertEqual(res['status_code'], requests.codes.ok) 07:27:55 E AssertionError: 409 != 200 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:149: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_09_check_mccapprofile 07:27:55 ________ TestTransportPCEPortmapping.test_10_xpdr_device_disconnection _________ 07:27:55 07:27:55 self = 07:27:55 07:27:55 def test_10_xpdr_device_disconnection(self): 07:27:55 response = test_utils.unmount_device("XPDR-OC") 07:27:55 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 07:27:55 E AssertionError: 409 not found in (200, 204) 07:27:55 07:27:55 transportpce_tests/oc/test01_portmapping.py:156: AssertionError 07:27:55 ----------------------------- Captured stdout call ----------------------------- 07:27:55 execution of test_10_xpdr_device_disconnection 07:27:55 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not deleted from tpce topology... 07:27:55 --------------------------- Captured stdout teardown --------------------------- 07:27:55 all processes killed 07:27:55 ODL log file stored 07:27:55 =========================== short test summary info ============================ 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_01_meta_data_insertion 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_02_catlog_input_insertion 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_03_xpdr_device_connection 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_04_xpdr_device_connected 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_05_xpdr_portmapping_info 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_06_mpdr_portmapping_NETWORK5 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_07_mpdr_portmapping_CLIENT1 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_08_mpdr_switching_pool 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_09_check_mccapprofile 07:27:55 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_10_xpdr_device_disconnection 07:27:55 10 failed in 465.20s (0:07:45) 07:27:55 tests190: exit 1 (465.66 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc pid=5796 07:27:58 .tests190: FAIL ✖ in 7 minutes 53.55 seconds 07:27:58 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 07:28:03 ..tests71: freeze> python -m pip freeze --all 07:28:16 tests71: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:28:16 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 07:28:16 using environment variables from ./karaf71.env 07:28:16 pytest -q transportpce_tests/7.1/test01_portmapping.py 07:28:16 ..F... [100%] 07:28:27 =================================== FAILURES =================================== 07:28:27 __________ TestTransportPCEPortmapping.test_01_rdm_device_connection ___________ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_01_rdm_device_connection(self): 07:28:27 response = test_utils.mount_device("ROADMA01", ('roadma', self.NODE_VERSION)) 07:28:27 > self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) 07:28:27 E AssertionError: 401 != 201 : Http status code should be 201 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:51: AssertionError 07:28:27 ---------------------------- Captured stdout setup ----------------------------- 07:28:27 starting OpenDaylight... 07:28:27 starting KARAF (karaf121) TransportPCE build... 07:28:27 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 07:28:27 starting simulator xpdra in OpenROADM device version 1.2.1... 07:28:27 Searching for patterns in xpdra-121.log... Pattern found! simulator for xpdra started 07:28:27 starting simulator roadma in OpenROADM device version 1.2.1... 07:28:27 Searching for patterns in roadma-121.log... Pattern found! simulator for roadma started 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_01_rdm_device_connection 07:28:27 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not added to tpce topology... 07:28:27 ___________ TestTransportPCEPortmapping.test_02_rdm_device_connected ___________ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_02_rdm_device_connected(self): 07:28:27 response = test_utils.check_device_connection("ROADMA01") 07:28:27 > self.assertEqual(response['status_code'], requests.codes.ok) 07:28:27 E AssertionError: 409 != 200 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:55: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_02_rdm_device_connected 07:28:27 ___________ TestTransportPCEPortmapping.test_03_rdm_portmapping_info ___________ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_03_rdm_portmapping_info(self): 07:28:27 response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) 07:28:27 > self.assertEqual(response['status_code'], requests.codes.ok) 07:28:27 E AssertionError: 409 != 200 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:61: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_03_rdm_portmapping_info 07:28:27 ______ TestTransportPCEPortmapping.test_04_rdm_portmapping_DEG1_TTP_TXRX _______ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_04_rdm_portmapping_DEG1_TTP_TXRX(self): 07:28:27 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "DEG1-TTP-TXRX") 07:28:27 > self.assertEqual(response['status_code'], requests.codes.ok) 07:28:27 E AssertionError: 409 != 200 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:74: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_04_rdm_portmapping_DEG1_TTP_TXRX 07:28:27 ______ TestTransportPCEPortmapping.test_05_rdm_portmapping_SRG1_PP7_TXRX _______ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_05_rdm_portmapping_SRG1_PP7_TXRX(self): 07:28:27 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG1-PP7-TXRX") 07:28:27 > self.assertEqual(response['status_code'], requests.codes.ok) 07:28:27 E AssertionError: 409 != 200 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:83: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_05_rdm_portmapping_SRG1_PP7_TXRX 07:28:27 ______ TestTransportPCEPortmapping.test_06_rdm_portmapping_SRG3_PP1_TXRX _______ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_06_rdm_portmapping_SRG3_PP1_TXRX(self): 07:28:27 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG3-PP1-TXRX") 07:28:27 > self.assertEqual(response['status_code'], requests.codes.ok) 07:28:27 E AssertionError: 409 != 200 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:92: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_06_rdm_portmapping_SRG3_PP1_TXRX 07:28:27 _________ TestTransportPCEPortmapping.test_19_rdm_device_disconnection _________ 07:28:27 07:28:27 self = 07:28:27 07:28:27 def test_19_rdm_device_disconnection(self): 07:28:27 response = test_utils.unmount_device("ROADMA01") 07:28:27 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 07:28:27 E AssertionError: 409 not found in (200, 204) 07:28:27 07:28:27 transportpce_tests/1.2.1/test01_portmapping.py:214: AssertionError 07:28:27 ----------------------------- Captured stdout call ----------------------------- 07:28:27 execution of test_19_rdm_device_disconnection 07:28:27 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not deleted from tpce topology... 07:28:27 =========================== short test summary info ============================ 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_01_rdm_device_connection 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_02_rdm_device_connected 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_03_rdm_portmapping_info 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_04_rdm_portmapping_DEG1_TTP_TXRX 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_05_rdm_portmapping_SRG1_PP7_TXRX 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_06_rdm_portmapping_SRG3_PP1_TXRX 07:28:27 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_19_rdm_device_disconnection 07:28:27 7 failed, 14 passed in 497.05s (0:08:17) 07:28:27 tests121: exit 1 (497.49 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=5782 07:28:28 ..........................F.FFFF.FFFF.. [100%] 07:32:37 36 passed in 340.33s (0:05:40) 07:32:37 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 07:33:34 ..........................F.. [100%] 07:35:15 =================================== FAILURES =================================== 07:35:15 __________ TestTransportPCEPortmapping.test_01_xpdr_device_connection __________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_01_xpdr_device_connection(self): 07:35:15 response = test_utils.mount_device("XPDR-A2", 07:35:15 ('xpdra2', self.NODE_VERSION)) 07:35:15 > self.assertEqual(response.status_code, requests.codes.created, 07:35:15 test_utils.CODE_SHOULD_BE_201) 07:35:15 E AssertionError: 401 != 201 : Http status code should be 201 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:51: AssertionError 07:35:15 ---------------------------- Captured stdout setup ----------------------------- 07:35:15 starting OpenDaylight... 07:35:15 starting KARAF (karaf71) TransportPCE build... 07:35:15 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 07:35:15 starting simulator xpdra2 in OpenROADM device version 7.1... 07:35:15 Searching for patterns in xpdra2-71.log... Pattern found! simulator for xpdra2 started 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_01_xpdr_device_connection 07:35:15 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-A2 still not added to tpce topology... 07:35:15 __________ TestTransportPCEPortmapping.test_02_xpdr_device_connected ___________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_02_xpdr_device_connected(self): 07:35:15 response = test_utils.check_device_connection("XPDR-A2") 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:57: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_02_xpdr_device_connected 07:35:15 __________ TestTransportPCEPortmapping.test_03_xpdr_portmapping_info ___________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_03_xpdr_portmapping_info(self): 07:35:15 response = test_utils.get_portmapping_node_attr("XPDR-A2", "node-info", None) 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:63: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_03_xpdr_portmapping_info 07:35:15 ________ TestTransportPCEPortmapping.test_04_tpdr_portmapping_NETWORK1 _________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_04_tpdr_portmapping_NETWORK1(self): 07:35:15 response = test_utils.get_portmapping_node_attr("XPDR-A2", "mapping", "XPDR1-NETWORK1") 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:76: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_04_tpdr_portmapping_NETWORK1 07:35:15 _________ TestTransportPCEPortmapping.test_05_tpdr_portmapping_CLIENT1 _________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_05_tpdr_portmapping_CLIENT1(self): 07:35:15 response = test_utils.get_portmapping_node_attr("XPDR-A2", "mapping", "XPDR1-CLIENT1") 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:100: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_05_tpdr_portmapping_CLIENT1 07:35:15 ________ TestTransportPCEPortmapping.test_06_mpdr_portmapping_NETWORK1 _________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_06_mpdr_portmapping_NETWORK1(self): 07:35:15 response = test_utils.get_portmapping_node_attr("XPDR-A2", "mapping", "XPDR2-NETWORK1") 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:120: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_06_mpdr_portmapping_NETWORK1 07:35:15 _________ TestTransportPCEPortmapping.test_07_mpdr_portmapping_CLIENT1 _________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_07_mpdr_portmapping_CLIENT1(self): 07:35:15 res = test_utils.get_portmapping_node_attr("XPDR-A2", "mapping", "XPDR2-CLIENT1") 07:35:15 > self.assertEqual(res['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:143: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_07_mpdr_portmapping_CLIENT1 07:35:15 ____________ TestTransportPCEPortmapping.test_08_check_mccapprofile ____________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_08_check_mccapprofile(self): 07:35:15 res = test_utils.get_portmapping_node_attr("XPDR-A2", "mc-capabilities", "XPDR-mcprofile") 07:35:15 > self.assertEqual(res['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:163: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_08_check_mccapprofile 07:35:15 ___________ TestTransportPCEPortmapping.test_09_mpdr_switching_pool ____________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_09_mpdr_switching_pool(self): 07:35:15 response = test_utils.get_portmapping_node_attr("XPDR-A2", "switching-pool-lcp", "1") 07:35:15 > self.assertEqual(response['status_code'], requests.codes.ok) 07:35:15 E AssertionError: 409 != 200 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:170: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_09_mpdr_switching_pool 07:35:15 ________ TestTransportPCEPortmapping.test_10_xpdr_device_disconnection _________ 07:35:15 07:35:15 self = 07:35:15 07:35:15 def test_10_xpdr_device_disconnection(self): 07:35:15 response = test_utils.unmount_device("XPDR-A2") 07:35:15 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 07:35:15 E AssertionError: 409 not found in (200, 204) 07:35:15 07:35:15 transportpce_tests/7.1/test01_portmapping.py:186: AssertionError 07:35:15 ----------------------------- Captured stdout call ----------------------------- 07:35:15 execution of test_10_xpdr_device_disconnection 07:35:15 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-A2 still not deleted from tpce topology... 07:35:15 =========================== short test summary info ============================ 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_01_xpdr_device_connection 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_02_xpdr_device_connected 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_03_xpdr_portmapping_info 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_04_tpdr_portmapping_NETWORK1 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_05_tpdr_portmapping_CLIENT1 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_06_mpdr_portmapping_NETWORK1 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_07_mpdr_portmapping_CLIENT1 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_08_check_mccapprofile 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_09_mpdr_switching_pool 07:35:15 FAILED transportpce_tests/7.1/test01_portmapping.py::TestTransportPCEPortmapping::test_10_xpdr_device_disconnection 07:35:15 10 failed, 2 passed in 419.48s (0:06:59) 07:35:15 tests121: FAIL ✖ in 8 minutes 25.3 seconds 07:35:15 tests71: exit 1 (419.87 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 pid=9986 07:35:18 ............................................. [100%] 07:41:06 71 passed in 508.14s (0:08:28) 07:41:06 pytest -q transportpce_tests/tapi/test04_topo_extension.py 07:42:02 ................... [100%] 07:43:33 19 passed in 146.84s (0:02:26) 07:43:33 pytest -q transportpce_tests/tapi/test05_pce_tapi.py 07:45:41 ...................... [100%] 07:51:18 22 passed in 465.12s (0:07:45) 07:51:19 tests71: FAIL ✖ in 7 minutes 20.09 seconds 07:51:19 tests_tapi: OK ✔ in 31 minutes 16.59 seconds 07:51:19 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 07:51:30 tests221: freeze> python -m pip freeze --all 07:51:30 tests221: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 07:51:30 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 07:51:30 using environment variables from ./karaf221.env 07:51:30 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 07:52:13 ................................... [100%] 07:52:54 35 passed in 83.80s (0:01:23) 07:52:54 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 07:53:29 ...... [100%] 07:53:43 6 passed in 48.50s 07:53:43 pytest -q transportpce_tests/2.2.1/test03_topology.py 07:54:30 ............................................ [100%] 07:56:06 44 passed in 142.80s (0:02:22) 07:56:06 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 07:56:46 ............ [100%] 07:57:10 12 passed in 63.85s (0:01:03) 07:57:10 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 07:57:40 ................ [100%] 07:59:09 16 passed in 118.30s (0:01:58) 07:59:09 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 07:59:44 ............................... [100%] 07:59:52 31 passed in 42.55s 07:59:52 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 08:00:32 .......................... [100%] 08:01:29 26 passed in 96.08s (0:01:36) 08:01:29 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 08:02:10 ...................... [100%] 08:03:14 22 passed in 105.29s (0:01:45) 08:03:14 pytest -q transportpce_tests/2.2.1/test09_olm.py 08:04:00 ........................................ [100%] 08:06:24 40 passed in 189.46s (0:03:09) 08:06:24 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 08:07:12 ........................................................................ [ 74%] 08:12:50 ......................... [100%] 08:14:42 97 passed in 497.55s (0:08:17) 08:14:42 pytest -q transportpce_tests/2.2.1/test12_end2end.py 08:15:28 ...................................................... [100%] 08:22:16 54 passed in 453.11s (0:07:33) 08:22:16 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 08:23:12 ........................................................................ [ 71%] 08:28:21 ............................. [100%] 08:33:30 101 passed in 674.36s (0:11:14) 08:33:30 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 08:34:41 ........................................................................ [ 67%] 08:40:30 ................................... [100%] 08:43:51 107 passed in 620.54s (0:10:20) 08:43:51 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 08:44:38 ............................................. [100%] 08:47:17 45 passed in 205.34s (0:03:25) 08:47:17 tests221: OK ✔ in 55 minutes 58.66 seconds 08:47:17 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 08:47:24 tests_hybrid: freeze> python -m pip freeze --all 08:47:24 tests_hybrid: bcrypt==5.0.0,certifi==2026.2.25,cffi==2.0.0,charset-normalizer==3.4.6,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,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.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.1,urllib3==2.6.3 08:47:24 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 08:47:24 using environment variables from ./karaf221.env 08:47:24 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 08:48:08 ................................................... [100%] 08:49:56 51 passed in 151.48s (0:02:31) 08:49:56 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 08:50:40 ........................................................................ [ 66%] 08:55:01 ..................................... [100%] 08:57:07 109 passed in 431.03s (0:07:11) 08:57:08 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 08:57:59 ..................................................... [100%] 09:01:32 53 passed in 264.53s (0:04:24) 09:01:32 buildcontroller: OK (279.58=setup[10.20]+cmd[269.38] seconds) 09:01:32 sims: OK (127.48=setup[125.08]+cmd[2.39] seconds) 09:01:32 build_karaf_tests121: OK (138.68=setup[32.75]+cmd[105.93] seconds) 09:01:32 testsPCE: FAIL code 1 (419.69=setup[313.18]+cmd[106.50] seconds) 09:01:32 tests121: FAIL code 1 (505.30=setup[7.81]+cmd[497.49] seconds) 09:01:32 build_karaf_tests221: OK (165.93=setup[37.27]+cmd[128.66] seconds) 09:01:32 tests_tapi: OK (1876.59=setup[8.11]+cmd[1868.48] seconds) 09:01:32 tests221: OK (3358.66=setup[11.53]+cmd[3347.13] seconds) 09:01:32 build_karaf_tests71: OK (152.41=setup[36.65]+cmd[115.76] seconds) 09:01:32 tests71: FAIL code 1 (440.09=setup[20.22]+cmd[419.87] seconds) 09:01:32 build_karaf_tests190: OK (174.90=setup[56.73]+cmd[118.17] seconds) 09:01:32 tests190: FAIL code 1 (473.55=setup[7.89]+cmd[465.66] seconds) 09:01:32 tests_hybrid: OK (855.45=setup[7.17]+cmd[848.28] seconds) 09:01:32 buildlighty: OK (167.19=setup[138.45]+cmd[28.74] seconds) 09:01:32 docs: OK (188.56=setup[179.22]+cmd[9.34] seconds) 09:01:32 docs-linkcheck: OK (192.04=setup[182.32]+cmd[9.72] seconds) 09:01:32 checkbashisms: OK (3.19=setup[1.78]+cmd[0.00,0.08,1.33] seconds) 09:01:32 pre-commit: OK (281.28=setup[3.56]+cmd[0.01,0.00,255.67,22.04] seconds) 09:01:32 pylint: OK (56.95=setup[27.98]+cmd[28.97] seconds) 09:01:32 evaluation failed :( (6969.82 seconds) 09:01:33 + tox_status=1 09:01:33 + echo '---> Completed tox runs' 09:01:33 ---> Completed tox runs 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/build_karaf_tests121/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=build_karaf_tests121 09:01:33 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/build_karaf_tests190/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=build_karaf_tests190 09:01:33 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/build_karaf_tests221/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=build_karaf_tests221 09:01:33 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/build_karaf_tests71/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=build_karaf_tests71 09:01:33 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/buildcontroller/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=buildcontroller 09:01:33 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/buildlighty/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=buildlighty 09:01:33 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/checkbashisms/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=checkbashisms 09:01:33 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/docs-linkcheck/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=docs-linkcheck 09:01:33 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/docs/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=docs 09:01:33 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/pre-commit/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=pre-commit 09:01:33 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/pylint/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=pylint 09:01:33 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/sims/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=sims 09:01:33 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/tests121/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=tests121 09:01:33 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/tests190/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=tests190 09:01:33 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/tests221/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=tests221 09:01:33 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 09:01:33 + for i in .tox/*/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 ++ echo .tox/tests71/log 09:01:33 + tox_env=tests71 09:01:33 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/testsPCE/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=testsPCE 09:01:33 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/tests_hybrid/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=tests_hybrid 09:01:33 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 09:01:33 + for i in .tox/*/log 09:01:33 ++ echo .tox/tests_tapi/log 09:01:33 ++ awk -F/ '{print $2}' 09:01:33 + tox_env=tests_tapi 09:01:33 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 09:01:33 + DOC_DIR=docs/_build/html 09:01:33 + [[ -d docs/_build/html ]] 09:01:33 + echo '---> Archiving generated docs' 09:01:33 ---> Archiving generated docs 09:01:33 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 09:01:33 + echo '---> tox-run.sh ends' 09:01:33 ---> tox-run.sh ends 09:01:33 + test 1 -eq 0 09:01:33 + exit 1 09:01:33 ++ '[' 1 = 1 ']' 09:01:33 ++ '[' -x /usr/bin/clear_console ']' 09:01:33 ++ /usr/bin/clear_console -q 09:01:33 Build step 'Execute shell' marked build as failure 09:01:33 $ ssh-agent -k 09:01:33 unset SSH_AUTH_SOCK; 09:01:33 unset SSH_AGENT_PID; 09:01:33 echo Agent pid 1555 killed; 09:01:33 [ssh-agent] Stopped. 09:01:33 [PostBuildScript] - [INFO] Executing post build scripts. 09:01:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7095743520641335041.sh 09:01:33 ---> sysstat.sh 09:01:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12430038986935194123.sh 09:01:34 ---> package-listing.sh 09:01:34 ++ facter osfamily 09:01:34 ++ tr '[:upper:]' '[:lower:]' 09:01:34 + OS_FAMILY=debian 09:01:34 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 09:01:34 + START_PACKAGES=/tmp/packages_start.txt 09:01:34 + END_PACKAGES=/tmp/packages_end.txt 09:01:34 + DIFF_PACKAGES=/tmp/packages_diff.txt 09:01:34 + PACKAGES=/tmp/packages_start.txt 09:01:34 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:01:34 + PACKAGES=/tmp/packages_end.txt 09:01:34 + case "${OS_FAMILY}" in 09:01:34 + dpkg -l 09:01:34 + grep '^ii' 09:01:34 + '[' -f /tmp/packages_start.txt ']' 09:01:34 + '[' -f /tmp/packages_end.txt ']' 09:01:34 + diff /tmp/packages_start.txt /tmp/packages_end.txt 09:01:34 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 09:01:34 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:01:34 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 09:01:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11143029259698732701.sh 09:01:34 ---> capture-instance-metadata.sh 09:01:34 Setup pyenv: 09:01:34 system 09:01:34 3.8.20 09:01:34 3.9.20 09:01:34 3.10.15 09:01:34 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:01:35 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5jM9 from file:/tmp/.os_lf_venv 09:01:35 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:01:35 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:01:37 lf-activate-venv(): INFO: Base packages installed successfully 09:01:37 lf-activate-venv(): INFO: Installing additional packages: lftools 09:01:47 lf-activate-venv(): INFO: Adding /tmp/venv-5jM9/bin to PATH 09:01:47 INFO: Running in OpenStack, capturing instance metadata 09:01:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11267529177112046230.sh 09:01:48 provisioning config files... 09:01:48 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #4862 09:01:48 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config15293269152965891860tmp 09:01:48 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 09:01:48 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 09:01:48 provisioning config files... 09:01:48 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 09:01:48 [EnvInject] - Injecting environment variables from a build step. 09:01:48 [EnvInject] - Injecting as environment variables the properties content 09:01:48 SERVER_ID=logs 09:01:48 09:01:48 [EnvInject] - Variables injected successfully. 09:01:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5947662863301899359.sh 09:01:48 ---> create-netrc.sh 09:01:48 WARN: Log server credential not found. 09:01:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15120823404292950853.sh 09:01:48 ---> python-tools-install.sh 09:01:48 Setup pyenv: 09:01:48 system 09:01:48 3.8.20 09:01:48 3.9.20 09:01:48 3.10.15 09:01:48 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:01:48 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5jM9 from file:/tmp/.os_lf_venv 09:01:48 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:01:48 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:01:50 lf-activate-venv(): INFO: Base packages installed successfully 09:01:50 lf-activate-venv(): INFO: Installing additional packages: lftools 09:02:02 lf-activate-venv(): INFO: Adding /tmp/venv-5jM9/bin to PATH 09:02:02 [transportpce-tox-verify-transportpce-master] $ /bin/sh /tmp/jenkins17248807514152143291.sh 09:02:02 ---> uv-install.sh 09:02:02 uv 0.11.1 is already installed 09:02:02 uvx 0.11.1 (x86_64-unknown-linux-gnu) 09:02:02 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11904801715448361142.sh 09:02:02 ---> sudo-logs.sh 09:02:02 Archiving 'sudo' log.. 09:02:03 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16788182523629718877.sh 09:02:03 ---> job-cost.sh 09:02:03 INFO: Activating Python virtual environment... 09:02:03 Setup pyenv: 09:02:03 system 09:02:03 3.8.20 09:02:03 3.9.20 09:02:03 3.10.15 09:02:03 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:02:03 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5jM9 from file:/tmp/.os_lf_venv 09:02:03 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:02:03 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:02:06 lf-activate-venv(): INFO: Base packages installed successfully 09:02:06 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 09:02:15 lf-activate-venv(): INFO: Adding /tmp/venv-5jM9/bin to PATH 09:02:15 INFO: No stack-cost file found 09:02:15 INFO: Instance uptime: 7262s 09:02:15 INFO: Fetching instance metadata (attempt 1 of 3)... 09:02:15 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 09:02:15 INFO: Successfully fetched instance metadata 09:02:15 INFO: Instance type: v3-standard-4 09:02:15 INFO: Retrieving pricing info for: v3-standard-4 09:02:15 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 09:02:15 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=7262 09:02:16 INFO: Successfully fetched Vexxhost pricing API 09:02:16 INFO: Retrieved cost: 0.33 09:02:16 INFO: Retrieved resource: v3-standard-4 09:02:16 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 09:02:16 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 09:02:16 INFO: Successfully archived job cost data 09:02:16 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,4862,2026-03-25 09:02:16,v3-standard-4,7262,0.33,0.00,FAILURE 09:02:16 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins9611000844838587987.sh 09:02:16 ---> logs-deploy.sh 09:02:16 Setup pyenv: 09:02:16 system 09:02:16 3.8.20 09:02:16 3.9.20 09:02:16 3.10.15 09:02:16 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:02:16 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5jM9 from file:/tmp/.os_lf_venv 09:02:16 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 09:02:16 lf-activate-venv(): INFO: Attempting to install with network-safe options... 09:02:18 lf-activate-venv(): INFO: Base packages installed successfully 09:02:18 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 09:02:29 lf-activate-venv(): INFO: Adding /tmp/venv-5jM9/bin to PATH 09:02:29 WARNING: Nexus logging server not set 09:02:29 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/4862/ 09:02:29 INFO: archiving logs to S3 09:02:29 /tmp/venv-5jM9/lib/python3.11/site-packages/requests/__init__.py:113: RequestsDependencyWarning: urllib3 (1.26.20) or chardet (7.3.0)/charset_normalizer (3.4.6) doesn't match a supported version! 09:02:29 warnings.warn( 09:02:38 ---> uname -a: 09:02:38 Linux prd-ubuntu2204-docker-4c-16g-30007 5.15.0-171-generic #181-Ubuntu SMP Fri Feb 6 22:44:50 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 09:02:38 09:02:38 09:02:38 ---> lscpu: 09:02:38 Architecture: x86_64 09:02:38 CPU op-mode(s): 32-bit, 64-bit 09:02:38 Address sizes: 40 bits physical, 48 bits virtual 09:02:38 Byte Order: Little Endian 09:02:38 CPU(s): 4 09:02:38 On-line CPU(s) list: 0-3 09:02:38 Vendor ID: AuthenticAMD 09:02:38 Model name: AMD EPYC-Rome Processor 09:02:38 CPU family: 23 09:02:38 Model: 49 09:02:38 Thread(s) per core: 1 09:02:38 Core(s) per socket: 1 09:02:38 Socket(s): 4 09:02:38 Stepping: 0 09:02:38 BogoMIPS: 5600.00 09:02:38 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 09:02:38 Virtualization: AMD-V 09:02:38 Hypervisor vendor: KVM 09:02:38 Virtualization type: full 09:02:38 L1d cache: 128 KiB (4 instances) 09:02:38 L1i cache: 128 KiB (4 instances) 09:02:38 L2 cache: 2 MiB (4 instances) 09:02:38 L3 cache: 64 MiB (4 instances) 09:02:38 NUMA node(s): 1 09:02:38 NUMA node0 CPU(s): 0-3 09:02:38 Vulnerability Gather data sampling: Not affected 09:02:38 Vulnerability Indirect target selection: Not affected 09:02:38 Vulnerability Itlb multihit: Not affected 09:02:38 Vulnerability L1tf: Not affected 09:02:38 Vulnerability Mds: Not affected 09:02:38 Vulnerability Meltdown: Not affected 09:02:38 Vulnerability Mmio stale data: Not affected 09:02:38 Vulnerability Reg file data sampling: Not affected 09:02:38 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 09:02:38 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 09:02:38 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 09:02:38 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 09:02:38 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 09:02:38 Vulnerability Srbds: Not affected 09:02:38 Vulnerability Tsa: Not affected 09:02:38 Vulnerability Tsx async abort: Not affected 09:02:38 Vulnerability Vmscape: Not affected 09:02:38 09:02:38 09:02:38 ---> nproc: 09:02:38 4 09:02:38 09:02:38 09:02:38 ---> df -h: 09:02:38 Filesystem Size Used Avail Use% Mounted on 09:02:38 tmpfs 1.6G 1.1M 1.6G 1% /run 09:02:38 /dev/vda1 78G 18G 61G 23% / 09:02:38 tmpfs 7.9G 0 7.9G 0% /dev/shm 09:02:38 tmpfs 5.0M 0 5.0M 0% /run/lock 09:02:38 /dev/vda15 105M 6.1M 99M 6% /boot/efi 09:02:38 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 09:02:38 09:02:38 09:02:38 ---> free -m: 09:02:38 total used free shared buff/cache available 09:02:38 Mem: 15989 727 10517 4 4745 14919 09:02:38 Swap: 1023 1 1022 09:02:38 09:02:38 09:02:38 ---> ip addr: 09:02:38 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 09:02:38 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 09:02:38 inet 127.0.0.1/8 scope host lo 09:02:38 valid_lft forever preferred_lft forever 09:02:38 inet6 ::1/128 scope host 09:02:38 valid_lft forever preferred_lft forever 09:02:38 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 09:02:38 link/ether fa:16:3e:5f:32:61 brd ff:ff:ff:ff:ff:ff 09:02:38 altname enp0s3 09:02:38 inet 10.30.171.85/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 09:02:38 valid_lft 79127sec preferred_lft 79127sec 09:02:38 inet6 fe80::f816:3eff:fe5f:3261/64 scope link 09:02:38 valid_lft forever preferred_lft forever 09:02:38 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 09:02:38 link/ether 7e:88:51:a4:75:d1 brd ff:ff:ff:ff:ff:ff 09:02:38 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 09:02:38 valid_lft forever preferred_lft forever 09:02:38 inet6 fe80::7c88:51ff:fea4:75d1/64 scope link 09:02:38 valid_lft forever preferred_lft forever 09:02:38 09:02:38 09:02:38 ---> sar -b -r -n DEV: 09:02:38 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-30007) 03/25/26 _x86_64_ (4 CPU) 09:02:38 09:02:38 07:01:28 LINUX RESTART (4 CPU) 09:02:38 09:02:38 07:10:20 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 09:02:38 07:20:10 44.75 1.17 41.46 2.12 43.42 24374.84 7413.85 09:02:38 07:30:01 46.58 24.24 20.62 1.72 381.68 4674.73 3789.05 09:02:38 07:40:10 5.89 0.17 5.47 0.25 8.12 165.94 324.82 09:02:38 07:50:20 7.65 0.01 7.24 0.40 0.41 230.27 457.41 09:02:38 08:00:01 20.05 0.02 19.26 0.77 0.69 812.31 570.93 09:02:38 08:10:20 9.68 0.01 9.27 0.39 0.58 310.44 510.78 09:02:38 08:20:20 5.62 0.01 5.46 0.16 0.25 143.75 266.29 09:02:38 08:30:01 4.75 0.01 4.58 0.17 1.10 142.10 291.40 09:02:38 08:40:20 20.37 0.05 4.78 15.54 0.90 141.10 205191.64 09:02:38 08:50:11 10.96 0.09 10.46 0.40 5.83 597.26 535.08 09:02:38 09:00:01 5.43 0.10 5.14 0.20 3.48 244.85 521.75 09:02:38 Average: 16.45 2.32 12.07 2.06 40.12 2857.87 20623.60 09:02:38 09:02:38 07:10:20 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 09:02:38 07:20:10 4458292 15242280 682924 4.17 245752 10303172 1462944 8.40 1942672 9196688 215568 09:02:38 07:30:01 5734660 9382704 6550740 40.01 263664 3344252 7257684 41.66 1833296 8207676 312 09:02:38 07:40:10 7407864 11066228 4868080 29.73 265000 3353136 5592356 32.10 1853604 6510052 60 09:02:38 07:50:20 5978156 9652284 6282360 38.37 266812 3367080 7008096 40.23 1859508 7927408 148 09:02:38 08:00:01 10967040 14791136 1146552 7.00 272524 3506476 1907188 10.95 1909704 2927932 11164 09:02:38 08:10:20 7491120 11353444 4582220 27.99 274448 3542704 5321760 30.55 1912960 6388864 72 09:02:38 08:20:20 7512464 11392744 4542772 27.75 275192 3559832 5296020 30.40 1914364 6345740 48 09:02:38 08:30:01 5966248 9865944 6068636 37.06 275840 3578568 6717296 38.56 1916536 7889732 320 09:02:38 08:40:20 5999336 9923860 6010952 36.71 276512 3602636 6736720 38.67 1924560 7856456 84 09:02:38 08:50:11 10337820 14414376 1522668 9.30 281032 3743828 2801700 16.08 1940468 3518980 21752 09:02:38 09:00:01 6455984 10560556 5374080 32.82 281644 3771104 6009840 34.50 1953540 7370832 932 09:02:38 Average: 7118999 11604141 4330180 26.45 270765 4152072 5101055 29.28 1905565 6740033 22769 09:02:38 09:02:38 07:10:20 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 09:02:38 07:20:10 lo 1.05 1.05 1.41 1.41 0.00 0.00 0.00 0.00 09:02:38 07:20:10 ens3 38.81 28.81 655.62 3.23 0.00 0.00 0.00 0.00 09:02:38 07:20:10 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 07:30:01 lo 12.77 12.77 9.17 9.17 0.00 0.00 0.00 0.00 09:02:38 07:30:01 ens3 1.15 0.77 0.29 0.24 0.00 0.00 0.00 0.00 09:02:38 07:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 07:40:10 lo 11.60 11.60 5.16 5.16 0.00 0.00 0.00 0.00 09:02:38 07:40:10 ens3 1.58 0.59 0.34 0.21 0.00 0.00 0.00 0.00 09:02:38 07:40:10 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 07:50:20 lo 9.79 9.79 6.04 6.04 0.00 0.00 0.00 0.00 09:02:38 07:50:20 ens3 0.97 0.35 0.17 0.09 0.00 0.00 0.00 0.00 09:02:38 07:50:20 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:00:01 lo 12.73 12.73 5.85 5.85 0.00 0.00 0.00 0.00 09:02:38 08:00:01 ens3 1.45 1.21 0.36 1.62 0.00 0.00 0.00 0.00 09:02:38 08:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:10:20 lo 18.34 18.34 10.14 10.14 0.00 0.00 0.00 0.00 09:02:38 08:10:20 ens3 1.08 0.69 0.24 0.17 0.00 0.00 0.00 0.00 09:02:38 08:10:20 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:20:20 lo 23.39 23.39 8.74 8.74 0.00 0.00 0.00 0.00 09:02:38 08:20:20 ens3 0.84 0.47 0.17 0.11 0.00 0.00 0.00 0.00 09:02:38 08:20:20 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:30:01 lo 22.48 22.48 10.00 10.00 0.00 0.00 0.00 0.00 09:02:38 08:30:01 ens3 0.78 0.49 0.18 0.13 0.00 0.00 0.00 0.00 09:02:38 08:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:40:20 lo 14.41 14.41 8.51 8.51 0.00 0.00 0.00 0.00 09:02:38 08:40:20 ens3 0.71 0.52 0.16 0.12 0.00 0.00 0.00 0.00 09:02:38 08:40:20 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 08:50:11 lo 18.10 18.10 10.10 10.10 0.00 0.00 0.00 0.00 09:02:38 08:50:11 ens3 1.33 0.81 0.35 0.25 0.00 0.00 0.00 0.00 09:02:38 08:50:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 09:00:01 lo 29.83 29.83 12.39 12.39 0.00 0.00 0.00 0.00 09:02:38 09:00:01 ens3 1.26 0.76 0.34 0.25 0.00 0.00 0.00 0.00 09:02:38 09:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 Average: lo 15.84 15.84 7.96 7.96 0.00 0.00 0.00 0.00 09:02:38 Average: ens3 4.49 3.19 59.03 0.58 0.00 0.00 0.00 0.00 09:02:38 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 09:02:38 09:02:38 09:02:38 ---> sar -P ALL: 09:02:38 Linux 5.15.0-171-generic (prd-ubuntu2204-docker-4c-16g-30007) 03/25/26 _x86_64_ (4 CPU) 09:02:38 09:02:38 07:01:28 LINUX RESTART (4 CPU) 09:02:38 09:02:38 07:10:20 CPU %user %nice %system %iowait %steal %idle 09:02:38 07:20:10 all 18.64 0.00 1.21 27.88 0.11 52.16 09:02:38 07:20:10 0 18.24 0.00 1.23 22.00 0.10 58.43 09:02:38 07:20:10 1 21.58 0.00 1.27 18.87 0.11 58.17 09:02:38 07:20:10 2 15.79 0.00 1.21 27.24 0.13 55.63 09:02:38 07:20:10 3 18.93 0.00 1.12 43.41 0.12 36.42 09:02:38 07:30:01 all 32.81 0.00 1.82 12.68 0.18 52.50 09:02:38 07:30:01 0 33.89 0.00 1.89 15.69 0.18 48.34 09:02:38 07:30:01 1 31.83 0.00 1.71 9.60 0.19 56.67 09:02:38 07:30:01 2 32.07 0.00 1.84 12.67 0.18 53.24 09:02:38 07:30:01 3 33.44 0.00 1.86 12.76 0.18 51.76 09:02:38 07:40:10 all 10.05 0.00 0.63 0.21 0.09 89.03 09:02:38 07:40:10 0 9.93 0.00 0.74 0.53 0.08 88.72 09:02:38 07:40:10 1 10.24 0.00 0.57 0.06 0.10 89.03 09:02:38 07:40:10 2 9.89 0.00 0.65 0.13 0.09 89.24 09:02:38 07:40:10 3 10.13 0.00 0.55 0.13 0.07 89.11 09:02:38 07:50:20 all 17.64 0.00 0.79 0.06 0.08 81.43 09:02:38 07:50:20 0 18.22 0.00 0.74 0.07 0.07 80.90 09:02:38 07:50:20 1 17.14 0.00 0.83 0.03 0.08 81.92 09:02:38 07:50:20 2 18.19 0.00 0.82 0.03 0.08 80.87 09:02:38 07:50:20 3 17.00 0.00 0.78 0.09 0.08 82.05 09:02:38 08:00:01 all 30.58 0.00 1.20 0.44 0.11 67.66 09:02:38 08:00:01 0 31.76 0.00 1.28 1.11 0.11 65.73 09:02:38 08:00:01 1 30.96 0.00 1.29 0.11 0.12 67.53 09:02:38 08:00:01 2 30.30 0.00 1.13 0.16 0.12 68.29 09:02:38 08:00:01 3 29.31 0.00 1.10 0.37 0.11 69.11 09:02:38 08:10:20 all 21.98 0.00 0.79 0.13 0.08 77.01 09:02:38 08:10:20 0 21.87 0.00 0.79 0.05 0.08 77.22 09:02:38 08:10:20 1 21.54 0.00 0.78 0.21 0.09 77.38 09:02:38 08:10:20 2 22.28 0.00 0.79 0.13 0.08 76.72 09:02:38 08:10:20 3 22.23 0.00 0.81 0.13 0.08 76.74 09:02:38 08:20:20 all 9.34 0.00 0.49 0.02 0.06 90.09 09:02:38 08:20:20 0 9.28 0.00 0.52 0.01 0.06 90.12 09:02:38 08:20:20 1 9.79 0.00 0.56 0.01 0.07 89.57 09:02:38 08:20:20 2 9.16 0.00 0.47 0.02 0.07 90.28 09:02:38 08:20:20 3 9.13 0.00 0.41 0.03 0.06 90.37 09:02:38 08:30:01 all 10.42 0.00 0.45 0.13 0.07 88.93 09:02:38 08:30:01 0 10.66 0.00 0.51 0.02 0.07 88.74 09:02:38 08:30:01 1 10.73 0.00 0.41 0.07 0.07 88.73 09:02:38 08:30:01 2 10.07 0.00 0.45 0.26 0.07 89.14 09:02:38 08:30:01 3 10.21 0.00 0.42 0.17 0.07 89.12 09:02:38 08:40:20 all 10.02 0.00 0.54 1.66 0.09 87.68 09:02:38 08:40:20 0 9.96 0.00 0.47 1.01 0.08 88.48 09:02:38 08:40:20 1 10.03 0.00 0.59 1.41 0.11 87.86 09:02:38 08:40:20 2 10.06 0.00 0.54 1.96 0.10 87.33 09:02:38 08:40:20 3 10.04 0.00 0.54 2.27 0.08 87.06 09:02:38 08:50:11 all 17.11 0.00 0.80 0.36 0.08 81.66 09:02:38 08:50:11 0 16.67 0.00 0.79 0.42 0.08 82.05 09:02:38 08:50:11 1 18.26 0.00 0.85 0.38 0.08 80.43 09:02:38 08:50:11 2 16.90 0.00 0.90 0.37 0.07 81.75 09:02:38 08:50:11 3 16.62 0.00 0.65 0.26 0.07 82.41 09:02:38 09:00:01 all 15.25 0.00 0.68 0.08 0.08 83.92 09:02:38 09:00:01 0 15.15 0.00 0.69 0.05 0.07 84.04 09:02:38 09:00:01 1 15.07 0.00 0.70 0.04 0.07 84.11 09:02:38 09:00:01 2 15.84 0.00 0.66 0.06 0.09 83.34 09:02:38 09:00:01 3 14.92 0.00 0.65 0.17 0.08 84.18 09:02:38 09:02:38 Average: CPU %user %nice %system %iowait %steal %idle 09:02:38 Average: all 17.56 0.00 0.85 3.91 0.09 77.59 09:02:38 Average: 0 17.71 0.00 0.87 3.66 0.09 77.66 09:02:38 Average: 1 17.85 0.00 0.86 2.76 0.10 78.42 09:02:38 Average: 2 17.27 0.00 0.86 3.85 0.10 77.92 09:02:38 Average: 3 17.39 0.00 0.81 5.35 0.09 76.36 09:02:38 09:02:38 09:02:38