21:38:11 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/120307 21:38:11 Running as SYSTEM 21:38:11 [EnvInject] - Loading node environment variables. 21:38:11 Building remotely on prd-ubuntu2204-docker-4c-16g-5100 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 21:38:11 [ssh-agent] Looking for ssh-agent implementation... 21:38:11 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 21:38:11 $ ssh-agent 21:38:11 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXEvlDUP/agent.1559 21:38:11 SSH_AGENT_PID=1561 21:38:11 [ssh-agent] Started. 21:38:11 Running ssh-add (command line suppressed) 21:38:11 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_9821502448731905961.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_9821502448731905961.key) 21:38:11 [ssh-agent] Using credentials jenkins (jenkins-ssh) 21:38:11 The recommended git tool is: NONE 21:38:14 using credential jenkins-ssh 21:38:14 Wiping out workspace first. 21:38:14 Cloning the remote Git repository 21:38:14 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 21:38:14 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 21:38:14 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 21:38:14 > git --version # timeout=10 21:38:14 > git --version # 'git version 2.34.1' 21:38:14 using GIT_SSH to set credentials jenkins-ssh 21:38:14 Verifying host key using known hosts file 21:38:14 You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. 21:38:14 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 21:38:36 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 21:38:36 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 21:38:37 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 21:38:37 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 21:38:37 using GIT_SSH to set credentials jenkins-ssh 21:38:37 Verifying host key using known hosts file 21:38:37 You're using 'Known hosts file' strategy to verify ssh host keys, but your known_hosts file does not exist, please go to 'Manage Jenkins' -> 'Security' -> 'Git Host Key Verification Configuration' and configure host key verification. 21:38:37 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/07/120307/2 # timeout=10 21:38:37 > git rev-parse a9b37d262a9dcb514875a80df7ad40cdb3f80932^{commit} # timeout=10 21:38:37 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 21:38:37 Checking out Revision a9b37d262a9dcb514875a80df7ad40cdb3f80932 (refs/changes/07/120307/2) 21:38:37 > git config core.sparsecheckout # timeout=10 21:38:37 > git checkout -f a9b37d262a9dcb514875a80df7ad40cdb3f80932 # timeout=10 21:38:38 Commit message: "TAPI - Normalize SortedRange by merging intervals" 21:38:38 > git rev-parse FETCH_HEAD^{commit} # timeout=10 21:38:38 > git rev-list --no-walk acff7da01588930e68a18586af358bceb8dc09b9 # timeout=10 21:38:38 > git remote # timeout=10 21:38:38 > git submodule init # timeout=10 21:38:38 > git submodule sync # timeout=10 21:38:38 > git config --get remote.origin.url # timeout=10 21:38:38 > git submodule init # timeout=10 21:38:38 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 21:38:38 ERROR: No submodules found. 21:38:41 provisioning config files... 21:38:41 copy managed file [npmrc] to file:/home/jenkins/.npmrc 21:38:41 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 21:38:41 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6404968864015107844.sh 21:38:41 ---> python-tools-install.sh 21:38:41 Setup pyenv: 21:38:41 * system (set by /opt/pyenv/version) 21:38:41 * 3.8.20 (set by /opt/pyenv/version) 21:38:41 * 3.9.20 (set by /opt/pyenv/version) 21:38:41 3.10.15 21:38:41 3.11.10 21:38:47 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-1ER1 21:38:47 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 21:38:47 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 21:38:47 lf-activate-venv(): INFO: Attempting to install with network-safe options... 21:38:51 lf-activate-venv(): INFO: Base packages installed successfully 21:38:51 lf-activate-venv(): INFO: Installing additional packages: lftools 21:39:28 lf-activate-venv(): INFO: Adding /tmp/venv-1ER1/bin to PATH 21:39:28 Generating Requirements File 21:39:51 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. 21:39:51 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 21:39:52 Python 3.11.10 21:39:52 pip 25.3 from /tmp/venv-1ER1/lib/python3.11/site-packages/pip (python 3.11) 21:39:52 appdirs==1.4.4 21:39:52 argcomplete==3.6.3 21:39:52 aspy.yaml==1.3.0 21:39:52 attrs==25.4.0 21:39:52 autopage==0.5.2 21:39:52 beautifulsoup4==4.14.3 21:39:52 boto3==1.42.36 21:39:52 botocore==1.42.36 21:39:52 bs4==0.0.2 21:39:52 certifi==2026.1.4 21:39:52 cffi==2.0.0 21:39:52 cfgv==3.5.0 21:39:52 chardet==5.2.0 21:39:52 charset-normalizer==3.4.4 21:39:52 click==8.3.1 21:39:52 cliff==4.13.1 21:39:52 cmd2==3.1.2 21:39:52 cryptography==3.3.2 21:39:52 debtcollector==3.0.0 21:39:52 decorator==5.2.1 21:39:52 defusedxml==0.7.1 21:39:52 Deprecated==1.3.1 21:39:52 distlib==0.4.0 21:39:52 dnspython==2.8.0 21:39:52 docker==7.1.0 21:39:52 dogpile.cache==1.5.0 21:39:52 durationpy==0.10 21:39:52 email-validator==2.3.0 21:39:52 filelock==3.20.3 21:39:52 future==1.0.0 21:39:52 gitdb==4.0.12 21:39:52 GitPython==3.1.46 21:39:52 httplib2==0.30.2 21:39:52 identify==2.6.16 21:39:52 idna==3.11 21:39:52 importlib-resources==1.5.0 21:39:52 iso8601==2.1.0 21:39:52 Jinja2==3.1.6 21:39:52 jmespath==1.1.0 21:39:52 jsonpatch==1.33 21:39:52 jsonpointer==3.0.0 21:39:52 jsonschema==4.26.0 21:39:52 jsonschema-specifications==2025.9.1 21:39:52 keystoneauth1==5.13.0 21:39:52 kubernetes==35.0.0 21:39:52 lftools==0.37.21 21:39:52 lxml==6.0.2 21:39:52 markdown-it-py==4.0.0 21:39:52 MarkupSafe==3.0.3 21:39:52 mdurl==0.1.2 21:39:52 msgpack==1.1.2 21:39:52 multi_key_dict==2.0.3 21:39:52 munch==4.0.0 21:39:52 netaddr==1.3.0 21:39:52 niet==1.4.2 21:39:52 nodeenv==1.10.0 21:39:52 oauth2client==4.1.3 21:39:52 oauthlib==3.3.1 21:39:52 openstacksdk==4.9.0 21:39:52 os-service-types==1.8.2 21:39:52 osc-lib==4.3.0 21:39:52 oslo.config==10.2.0 21:39:52 oslo.context==6.2.0 21:39:52 oslo.i18n==6.7.1 21:39:52 oslo.log==8.0.0 21:39:52 oslo.serialization==5.9.0 21:39:52 oslo.utils==9.2.0 21:39:52 packaging==26.0 21:39:52 pbr==7.0.3 21:39:52 platformdirs==4.5.1 21:39:52 prettytable==3.17.0 21:39:52 psutil==7.2.1 21:39:52 pyasn1==0.6.2 21:39:52 pyasn1_modules==0.4.2 21:39:52 pycparser==3.0 21:39:52 pygerrit2==2.0.15 21:39:52 PyGithub==2.8.1 21:39:52 Pygments==2.19.2 21:39:52 PyJWT==2.10.1 21:39:52 PyNaCl==1.6.2 21:39:52 pyparsing==2.4.7 21:39:52 pyperclip==1.11.0 21:39:52 pyrsistent==0.20.0 21:39:52 python-cinderclient==9.8.0 21:39:52 python-dateutil==2.9.0.post0 21:39:52 python-heatclient==5.0.0 21:39:52 python-jenkins==1.8.3 21:39:52 python-keystoneclient==5.7.0 21:39:52 python-magnumclient==4.9.0 21:39:52 python-openstackclient==8.3.0 21:39:52 python-swiftclient==4.9.0 21:39:52 PyYAML==6.0.3 21:39:52 referencing==0.37.0 21:39:52 requests==2.32.5 21:39:52 requests-oauthlib==2.0.0 21:39:52 requestsexceptions==1.4.0 21:39:52 rfc3986==2.0.0 21:39:52 rich==14.3.1 21:39:52 rich-argparse==1.7.2 21:39:52 rpds-py==0.30.0 21:39:52 rsa==4.9.1 21:39:52 ruamel.yaml==0.19.1 21:39:52 ruamel.yaml.clib==0.2.15 21:39:52 s3transfer==0.16.0 21:39:52 simplejson==3.20.2 21:39:52 six==1.17.0 21:39:52 smmap==5.0.2 21:39:52 soupsieve==2.8.3 21:39:52 stevedore==5.6.0 21:39:52 tabulate==0.9.0 21:39:52 toml==0.10.2 21:39:52 tomlkit==0.14.0 21:39:52 tqdm==4.67.1 21:39:52 typing_extensions==4.15.0 21:39:52 tzdata==2025.3 21:39:52 urllib3==1.26.20 21:39:52 virtualenv==20.36.1 21:39:52 wcwidth==0.5.0 21:39:52 websocket-client==1.9.0 21:39:52 wrapt==2.0.1 21:39:52 xdg==6.0.0 21:39:52 xmltodict==1.0.2 21:39:52 yq==3.4.3 21:39:52 [EnvInject] - Injecting environment variables from a build step. 21:39:52 [EnvInject] - Injecting as environment variables the properties content 21:39:52 PYTHON=python3 21:39:52 21:39:52 [EnvInject] - Variables injected successfully. 21:39:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins10243501300138213653.sh 21:39:52 ---> tox-install.sh 21:39:52 + source /home/jenkins/lf-env.sh 21:39:52 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 21:39:52 ++ mktemp -d /tmp/venv-XXXX 21:39:52 + lf_venv=/tmp/venv-DLiZ 21:39:52 + local venv_file=/tmp/.os_lf_venv 21:39:52 + local python=python3 21:39:52 + local options 21:39:52 + local set_path=true 21:39:52 + local install_args= 21:39:52 ++ 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 21:39:52 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 21:39:52 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 21:39:52 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 21:39:52 + true 21:39:52 + case $1 in 21:39:52 + venv_file=/tmp/.toxenv 21:39:52 + shift 2 21:39:52 + true 21:39:52 + case $1 in 21:39:52 + shift 21:39:52 + break 21:39:52 + case $python in 21:39:52 + local pkg_list= 21:39:52 + [[ -d /opt/pyenv ]] 21:39:52 + echo 'Setup pyenv:' 21:39:52 Setup pyenv: 21:39:52 + export PYENV_ROOT=/opt/pyenv 21:39:52 + PYENV_ROOT=/opt/pyenv 21:39:52 + export PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:39:52 + PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:39:52 + pyenv versions 21:39:52 system 21:39:52 3.8.20 21:39:52 3.9.20 21:39:52 3.10.15 21:39:52 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 21:39:52 + command -v pyenv 21:39:52 ++ pyenv init - --no-rehash 21:39:52 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 21:39:52 for i in ${!paths[@]}; do 21:39:52 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 21:39:52 fi; done; 21:39:52 echo "${paths[*]}"'\'')" 21:39:52 export PATH="/opt/pyenv/shims:${PATH}" 21:39:52 export PYENV_SHELL=bash 21:39:52 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 21:39:52 pyenv() { 21:39:52 local command 21:39:52 command="${1:-}" 21:39:52 if [ "$#" -gt 0 ]; then 21:39:52 shift 21:39:52 fi 21:39:52 21:39:52 case "$command" in 21:39:52 rehash|shell) 21:39:52 eval "$(pyenv "sh-$command" "$@")" 21:39:52 ;; 21:39:52 *) 21:39:52 command pyenv "$command" "$@" 21:39:52 ;; 21:39:52 esac 21:39:52 }' 21:39:52 +++ bash --norc -ec 'IFS=:; paths=($PATH); 21:39:52 for i in ${!paths[@]}; do 21:39:52 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 21:39:52 fi; done; 21:39:52 echo "${paths[*]}"' 21:39:52 ++ PATH=/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:39:52 ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:39:52 ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:39:52 ++ export PYENV_SHELL=bash 21:39:52 ++ PYENV_SHELL=bash 21:39:52 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 21:39:52 +++ complete -F _pyenv pyenv 21:39:52 ++ lf-pyver python3 21:39:52 ++ local py_version_xy=python3 21:39:52 ++ local py_version_xyz= 21:39:52 ++ pyenv versions 21:39:52 ++ local command 21:39:52 ++ command=versions 21:39:52 ++ '[' 1 -gt 0 ']' 21:39:52 ++ shift 21:39:52 ++ case "$command" in 21:39:52 ++ command pyenv versions 21:39:52 ++ awk '{ print $1 }' 21:39:52 ++ sed 's/^[ *]* //' 21:39:52 ++ grep -E '^[0-9.]*[0-9]$' 21:39:53 ++ [[ ! -s /tmp/.pyenv_versions ]] 21:39:53 +++ grep '^3' /tmp/.pyenv_versions 21:39:53 +++ tail -n 1 21:39:53 +++ sort -V 21:39:53 ++ py_version_xyz=3.11.10 21:39:53 ++ [[ -z 3.11.10 ]] 21:39:53 ++ echo 3.11.10 21:39:53 ++ return 0 21:39:53 + pyenv local 3.11.10 21:39:53 + local command 21:39:53 + command=local 21:39:53 + '[' 2 -gt 0 ']' 21:39:53 + shift 21:39:53 + case "$command" in 21:39:53 + command pyenv local 3.11.10 21:39:53 + for arg in "$@" 21:39:53 + case $arg in 21:39:53 + pkg_list+='tox ' 21:39:53 + for arg in "$@" 21:39:53 + case $arg in 21:39:53 + pkg_list+='virtualenv ' 21:39:53 + for arg in "$@" 21:39:53 + case $arg in 21:39:53 + pkg_list+='urllib3~=1.26.15 ' 21:39:53 + [[ -f /tmp/.toxenv ]] 21:39:53 + [[ ! -f /tmp/.toxenv ]] 21:39:53 + [[ -n '' ]] 21:39:53 + python3 -m venv /tmp/venv-DLiZ 21:39:57 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-DLiZ' 21:39:57 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-DLiZ 21:39:57 + echo /tmp/venv-DLiZ 21:39:57 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 21:39:57 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 21:39:57 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 21:39:57 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 21:39:57 + local 'pip_opts=--upgrade --quiet' 21:39:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 21:39:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 21:39:57 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 21:39:57 + [[ -n '' ]] 21:39:57 + [[ -n '' ]] 21:39:57 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 21:39:57 lf-activate-venv(): INFO: Attempting to install with network-safe options... 21:39:57 + /tmp/venv-DLiZ/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 21:40:01 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 21:40:01 lf-activate-venv(): INFO: Base packages installed successfully 21:40:01 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 21:40:01 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 21:40:01 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 21:40:01 + /tmp/venv-DLiZ/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 21:40:03 + type python3 21:40:03 + true 21:40:03 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-DLiZ/bin to PATH' 21:40:03 lf-activate-venv(): INFO: Adding /tmp/venv-DLiZ/bin to PATH 21:40:03 + PATH=/tmp/venv-DLiZ/bin:/opt/pyenv/shims:/opt/pyenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/opt/puppetlabs/bin 21:40:03 + return 0 21:40:03 + python3 --version 21:40:03 Python 3.11.10 21:40:03 + python3 -m pip --version 21:40:03 pip 25.3 from /tmp/venv-DLiZ/lib/python3.11/site-packages/pip (python 3.11) 21:40:03 + python3 -m pip freeze 21:40:03 cachetools==6.2.6 21:40:03 chardet==5.2.0 21:40:03 colorama==0.4.6 21:40:03 distlib==0.4.0 21:40:03 filelock==3.20.3 21:40:03 packaging==26.0 21:40:03 platformdirs==4.5.1 21:40:03 pluggy==1.6.0 21:40:03 pyproject-api==1.10.0 21:40:03 tox==4.34.1 21:40:03 urllib3==1.26.20 21:40:03 virtualenv==20.36.1 21:40:03 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins3047283680330035061.sh 21:40:04 [EnvInject] - Injecting environment variables from a build step. 21:40:04 [EnvInject] - Injecting as environment variables the properties content 21:40:04 PARALLEL=True 21:40:04 21:40:04 [EnvInject] - Variables injected successfully. 21:40:04 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins16110096064802143789.sh 21:40:04 ---> tox-run.sh 21:40:04 + PATH=/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 21:40:04 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 21:40:04 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 21:40:04 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 21:40:04 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 21:40:04 + source /home/jenkins/lf-env.sh 21:40:04 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 21:40:04 ++ mktemp -d /tmp/venv-XXXX 21:40:04 + lf_venv=/tmp/venv-OkcM 21:40:04 + local venv_file=/tmp/.os_lf_venv 21:40:04 + local python=python3 21:40:04 + local options 21:40:04 + local set_path=true 21:40:04 + local install_args= 21:40:04 ++ 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 21:40:04 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 21:40:04 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 21:40:04 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 21:40:04 + true 21:40:04 + case $1 in 21:40:04 + venv_file=/tmp/.toxenv 21:40:04 + shift 2 21:40:04 + true 21:40:04 + case $1 in 21:40:04 + shift 21:40:04 + break 21:40:04 + case $python in 21:40:04 + local pkg_list= 21:40:04 + [[ -d /opt/pyenv ]] 21:40:04 + echo 'Setup pyenv:' 21:40:04 Setup pyenv: 21:40:04 + export PYENV_ROOT=/opt/pyenv 21:40:04 + PYENV_ROOT=/opt/pyenv 21:40:04 + 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 21:40:04 + 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 21:40:04 + pyenv versions 21:40:04 system 21:40:04 3.8.20 21:40:04 3.9.20 21:40:04 3.10.15 21:40:04 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 21:40:04 + command -v pyenv 21:40:04 ++ pyenv init - --no-rehash 21:40:04 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 21:40:04 for i in ${!paths[@]}; do 21:40:04 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 21:40:04 fi; done; 21:40:04 echo "${paths[*]}"'\'')" 21:40:04 export PATH="/opt/pyenv/shims:${PATH}" 21:40:04 export PYENV_SHELL=bash 21:40:04 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 21:40:04 pyenv() { 21:40:04 local command 21:40:04 command="${1:-}" 21:40:04 if [ "$#" -gt 0 ]; then 21:40:04 shift 21:40:04 fi 21:40:04 21:40:04 case "$command" in 21:40:04 rehash|shell) 21:40:04 eval "$(pyenv "sh-$command" "$@")" 21:40:04 ;; 21:40:04 *) 21:40:04 command pyenv "$command" "$@" 21:40:04 ;; 21:40:04 esac 21:40:04 }' 21:40:04 +++ bash --norc -ec 'IFS=:; paths=($PATH); 21:40:04 for i in ${!paths[@]}; do 21:40:04 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 21:40:04 fi; done; 21:40:04 echo "${paths[*]}"' 21:40:04 ++ 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 21:40:04 ++ 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 21:40:04 ++ 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 21:40:04 ++ export PYENV_SHELL=bash 21:40:04 ++ PYENV_SHELL=bash 21:40:04 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 21:40:04 +++ complete -F _pyenv pyenv 21:40:04 ++ lf-pyver python3 21:40:04 ++ local py_version_xy=python3 21:40:04 ++ local py_version_xyz= 21:40:04 ++ pyenv versions 21:40:04 ++ local command 21:40:04 ++ command=versions 21:40:04 ++ sed 's/^[ *]* //' 21:40:04 ++ '[' 1 -gt 0 ']' 21:40:04 ++ shift 21:40:04 ++ case "$command" in 21:40:04 ++ command pyenv versions 21:40:04 ++ grep -E '^[0-9.]*[0-9]$' 21:40:04 ++ awk '{ print $1 }' 21:40:04 ++ [[ ! -s /tmp/.pyenv_versions ]] 21:40:04 +++ grep '^3' /tmp/.pyenv_versions 21:40:04 +++ sort -V 21:40:04 +++ tail -n 1 21:40:04 ++ py_version_xyz=3.11.10 21:40:04 ++ [[ -z 3.11.10 ]] 21:40:04 ++ echo 3.11.10 21:40:04 ++ return 0 21:40:04 + pyenv local 3.11.10 21:40:04 + local command 21:40:04 + command=local 21:40:04 + '[' 2 -gt 0 ']' 21:40:04 + shift 21:40:04 + case "$command" in 21:40:04 + command pyenv local 3.11.10 21:40:04 + for arg in "$@" 21:40:04 + case $arg in 21:40:04 + pkg_list+='tox ' 21:40:04 + for arg in "$@" 21:40:04 + case $arg in 21:40:04 + pkg_list+='virtualenv ' 21:40:04 + for arg in "$@" 21:40:04 + case $arg in 21:40:04 + pkg_list+='urllib3~=1.26.15 ' 21:40:04 + [[ -f /tmp/.toxenv ]] 21:40:04 ++ cat /tmp/.toxenv 21:40:04 + lf_venv=/tmp/venv-DLiZ 21:40:04 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-DLiZ from' file:/tmp/.toxenv 21:40:04 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-DLiZ from file:/tmp/.toxenv 21:40:04 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 21:40:04 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 21:40:04 + local 'pip_opts=--upgrade --quiet' 21:40:04 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 21:40:04 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 21:40:04 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 21:40:04 + [[ -n '' ]] 21:40:04 + [[ -n '' ]] 21:40:04 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 21:40:04 lf-activate-venv(): INFO: Attempting to install with network-safe options... 21:40:04 + /tmp/venv-DLiZ/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 21:40:05 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 21:40:05 lf-activate-venv(): INFO: Base packages installed successfully 21:40:05 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 21:40:05 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 21:40:05 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 21:40:05 + /tmp/venv-DLiZ/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 21:40:06 + type python3 21:40:06 + true 21:40:06 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-DLiZ/bin to PATH' 21:40:06 lf-activate-venv(): INFO: Adding /tmp/venv-DLiZ/bin to PATH 21:40:06 + PATH=/tmp/venv-DLiZ/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 21:40:06 + return 0 21:40:06 + [[ -d /opt/pyenv ]] 21:40:06 + echo '---> Setting up pyenv' 21:40:06 ---> Setting up pyenv 21:40:06 + export PYENV_ROOT=/opt/pyenv 21:40:06 + PYENV_ROOT=/opt/pyenv 21:40:06 + export PATH=/opt/pyenv/bin:/tmp/venv-DLiZ/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 21:40:06 + PATH=/opt/pyenv/bin:/tmp/venv-DLiZ/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 21:40:06 ++ pwd 21:40:06 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 21:40:06 + export PYTHONPATH 21:40:06 + export TOX_TESTENV_PASSENV=PYTHONPATH 21:40:06 + TOX_TESTENV_PASSENV=PYTHONPATH 21:40:06 + tox --version 21:40:06 4.34.1 from /tmp/venv-DLiZ/lib/python3.11/site-packages/tox/__init__.py 21:40:06 + PARALLEL=True 21:40:06 + TOX_OPTIONS_LIST= 21:40:06 + [[ -n '' ]] 21:40:06 + case ${PARALLEL,,} in 21:40:06 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 21:40:06 + tox --parallel auto --parallel-live 21:40:06 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 21:40:08 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 21:40:08 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 21:40:08 docs: install_deps> python -I -m pip install -r docs/requirements.txt 21:40:08 checkbashisms: freeze> python -m pip freeze --all 21:40:08 checkbashisms: pip==25.3,setuptools==80.9.0 21:40:08 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 21:40:08 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)' 21:40:08 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 21:40:10 checkbashisms: OK ✔ in 3.22 seconds 21:40:10 pre-commit: install_deps> python -I -m pip install pre-commit 21:40:13 pre-commit: freeze> python -m pip freeze --all 21:40:13 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.20.3,identify==2.6.16,nodeenv==1.10.0,pip==25.3,platformdirs==4.5.1,pre_commit==4.5.1,PyYAML==6.0.3,setuptools==80.9.0,virtualenv==20.36.1 21:40:13 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 21:40:13 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)' 21:40:13 /usr/bin/cpan 21:40:13 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 21:40:13 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 21:40:13 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 21:40:13 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 21:40:14 [WARNING] repo `https://github.com/pre-commit/pre-commit-hooks` uses deprecated stage names (commit, push) which will be removed in a future version. Hint: often `pre-commit autoupdate --repo https://github.com/pre-commit/pre-commit-hooks` will fix this. if it does not -- consider reporting an issue to that repo. 21:40:14 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 21:40:14 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 21:40:15 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 21:40:15 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 21:40:15 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 21:40:15 buildcontroller: freeze> python -m pip freeze --all 21:40:15 buildcontroller: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:40:15 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 21:40:15 + update-java-alternatives -l 21:40:15 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 21:40:15 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 21:40:15 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 21:40:15 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 21:40:15 update-alternatives: error: no alternatives for jaotc 21:40:16 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 21:40:16 [INFO] Once installed this environment will be reused. 21:40:16 [INFO] This may take a few minutes... 21:40:16 update-alternatives: error: no alternatives for rmic 21:40:16 + java -version 21:40:16 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 21:40:16 + JAVA_VER=21 21:40:16 + echo 21 21:40:16 21 21:40:16 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 21:40:16 + javac -version 21:40:17 + JAVAC_VER=21 21:40:17 + echo 21 21:40:17 21 21:40:17 ok, java is 21 or newer 21:40:17 + [ 21 -ge 21 ] 21:40:17 + [ 21 -ge 21 ] 21:40:17 + echo ok, java is 21 or newer 21:40:17 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.12/binaries/apache-maven-3.9.12-bin.tar.gz -P /tmp 21:40:17 2026-01-27 21:40:17 URL:https://dlcdn.apache.org/maven/maven-3/3.9.12/binaries/apache-maven-3.9.12-bin.tar.gz [9233336/9233336] -> "/tmp/apache-maven-3.9.12-bin.tar.gz" [1] 21:40:17 + sudo mkdir -p /opt 21:40:17 + sudo tar xf /tmp/apache-maven-3.9.12-bin.tar.gz -C /opt 21:40:17 + sudo ln -s /opt/apache-maven-3.9.12 /opt/maven 21:40:17 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 21:40:17 + mvn --version 21:40:18 Apache Maven 3.9.12 (848fbb4bf2d427b72bdb2471c22fced7ebd9a7a1) 21:40:18 Maven home: /opt/maven 21:40:18 Java version: 21.0.9, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 21:40:18 Default locale: en, platform encoding: UTF-8 21:40:18 OS name: "linux", version: "5.15.0-164-generic", arch: "amd64", family: "unix" 21:40:18 NOTE: Picked up JDK_JAVA_OPTIONS: 21:40:18 --add-opens=java.base/java.io=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.lang=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.net=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.nio=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.util=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:40:18 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:40:18 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:40:18 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:40:18 -Xlog:disable 21:40:26 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 21:40:26 [INFO] Once installed this environment will be reused. 21:40:26 [INFO] This may take a few minutes... 21:40:54 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 21:40:54 [INFO] Once installed this environment will be reused. 21:40:54 [INFO] This may take a few minutes... 21:41:11 [INFO] Installing environment for https://github.com/perltidy/perltidy. 21:41:11 [INFO] Once installed this environment will be reused. 21:41:11 [INFO] This may take a few minutes... 21:41:18 docs-linkcheck: freeze> python -m pip freeze --all 21:41:19 docs-linkcheck: alabaster==1.0.0,attrs==25.4.0,babel==2.17.0,blockdiag==3.0.0,certifi==2026.1.4,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.61.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.1,nwdiag==3.0.0,packaging==26.0,pillow==12.1.0,pip==25.3,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==80.9.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.4.7,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 21:41:19 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 21:41:19 docs: freeze> python -m pip freeze --all 21:41:20 docs: alabaster==1.0.0,attrs==25.4.0,babel==2.17.0,blockdiag==3.0.0,certifi==2026.1.4,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.61.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.1,nwdiag==3.0.0,packaging==26.0,pillow==12.1.0,pip==25.3,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==80.9.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.4.7,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 21:41:20 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 21:41:23 docs: OK ✔ in 1 minute 16.11 seconds 21:41:23 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 21:41:24 trim trailing whitespace.................................................Passed 21:41:25 Tabs remover.............................................................Passed 21:41:25 autopep8.................................................................docs-linkcheck: OK ✔ in 1 minute 17.73 seconds 21:41:29 pylint: freeze> python -m pip freeze --all 21:41:30 pylint: astroid==4.0.3,dill==0.4.1,isort==7.0.0,mccabe==0.7.0,pip==25.3,platformdirs==4.5.1,pylint==4.0.4,setuptools==80.9.0,tomlkit==0.14.0 21:41:30 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}$' '{}' + 21:41:30 Passed 21:41:30 perltidy.................................................................Passed 21:41:31 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 21:41:31 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 21:41:31 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 21:41:31 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 21:41:31 [INFO] Once installed this environment will be reused. 21:41:31 [INFO] This may take a few minutes... 21:41:41 gitlint..................................................................Passed 21:41:52 21:41:52 ------------------------------------ 21:41:52 Your code has been rated at 10.00/10 21:41:52 21:42:25 pre-commit: OK ✔ in 1 minute 31.75 seconds 21:42:25 pylint: OK ✔ in 31.31 seconds 21:42:25 buildcontroller: OK ✔ in 2 minutes 17.72 seconds 21:42:25 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 21:42:25 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 21:42:25 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 21:42:25 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 21:42:34 build_karaf_tests190: freeze> python -m pip freeze --all 21:42:34 build_karaf_tests221: freeze> python -m pip freeze --all 21:42:34 build_karaf_tests121: freeze> python -m pip freeze --all 21:42:34 build_karaf_tests71: freeze> python -m pip freeze --all 21:42:35 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:42:35 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:42:35 build karaf in karafoc with ./karafoc.env 21:42:35 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:42:35 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:42:35 build karaf in karaf221 with ./karaf221.env 21:42:35 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:42:35 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:42:35 NOTE: Picked up JDK_JAVA_OPTIONS: 21:42:35 --add-opens=java.base/java.io=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.net=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:42:35 -Xlog:disable 21:42:35 build karaf in karaf121 with ./karaf121.env 21:42:35 NOTE: Picked up JDK_JAVA_OPTIONS: 21:42:35 --add-opens=java.base/java.io=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.net=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:42:35 -Xlog:disable 21:42:35 NOTE: Picked up JDK_JAVA_OPTIONS: 21:42:35 --add-opens=java.base/java.io=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.net=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:42:35 -Xlog:disable 21:42:35 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:42:35 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:42:35 build karaf in karaf71 with ./karaf71.env 21:42:35 NOTE: Picked up JDK_JAVA_OPTIONS: 21:42:35 --add-opens=java.base/java.io=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.net=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:42:35 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:42:35 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:42:35 -Xlog:disable 21:44:26 build_karaf_tests190: OK ✔ in 2 minutes 1.6 seconds 21:44:26 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 21:44:46 build_karaf_tests71: OK ✔ in 2 minutes 21.32 seconds 21:44:46 sims: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 21:44:49 build_karaf_tests221: OK ✔ in 2 minutes 21.84 seconds 21:44:49 build_karaf_tests121: OK ✔ in 2 minutes 23.35 seconds 21:44:49 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 21:45:37 buildlighty: freeze> python -m pip freeze --all 21:45:37 sims: freeze> python -m pip freeze --all 21:45:37 buildlighty: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:45:37 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 21:45:37 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 21:45:38 sims: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:45:38 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 21:45:38 Using lighynode version 20.1.0.5 21:45:38 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 21:47:16 sims: OK ✔ in 55.17 seconds 21:47:16 buildlighty: OK ✔ in 1 minute 34.87 seconds 21:47:16 testsPCE: freeze> python -m pip freeze --all 21:47:16 testsPCE: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,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.61.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.4.9,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.0,pip==25.3,pluggy==1.6.0,psutil==7.2.1,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==2025.2,requests==2.32.5,scipy==1.17.0,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 21:47:16 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 21:47:16 pytest -q transportpce_tests/pce/test01_pce.py 21:48:18 FFFFFFFFFFF...FFFF.F [100%] 21:48:50 =================================== FAILURES =================================== 21:48:50 ________________ TestTransportPCEPce.test_01_load_port_mapping _________________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_01_load_port_mapping(self): 21:48:50 response = test_utils.post_portmapping(self.port_mapping_data) 21:48:50 > self.assertIn(response['status_code'], (requests.codes.created, requests.codes.no_content)) 21:48:50 E AssertionError: 401 not found in (201, 204) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:113: AssertionError 21:48:50 ---------------------------- Captured stdout setup ----------------------------- 21:48:50 sample files content loaded 21:48:50 starting OpenDaylight... 21:48:50 starting KARAF (karaf) TransportPCE build... 21:48:50 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 21:48:50 _____________ TestTransportPCEPce.test_02_load_simple_topology_bi ______________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_02_load_simple_topology_bi(self): 21:48:50 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_bi_dir_data) 21:48:50 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 21:48:50 E AssertionError: 401 not found in (200, 204) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:119: AssertionError 21:48:50 ____________________ TestTransportPCEPce.test_03_get_nodeId ____________________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_03_get_nodeId(self): 21:48:50 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'ROADMA01-SRG1', 'config') 21:48:50 > self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 E AssertionError: 401 != 200 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:125: AssertionError 21:48:50 ____________________ TestTransportPCEPce.test_04_get_linkId ____________________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_04_get_linkId(self): 21:48:50 > response = test_utils.get_ietf_network_link_request( 21:48:50 'openroadm-topology', 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX', 'config') 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:131: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 network = 'openroadm-topology' 21:48:50 link = 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX' 21:48:50 content = 'config' 21:48:50 21:48:50 def get_ietf_network_link_request(network: str, link: str, content: str): 21:48:50 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 21:48:50 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 21:48:50 if RESTCONF_VERSION in ('rfc8040'): 21:48:50 format_args = ('{}', network, link, content) 21:48:50 elif content == 'config': 21:48:50 format_args = ('{}', content, network, link) 21:48:50 else: 21:48:50 format_args = ('{}', 'operational', network, link) 21:48:50 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': 'ietf-network-topology:link', 21:48:50 'draft-bierman02': 'ietf-network-topology:link'} 21:48:50 > link = res[return_key[RESTCONF_VERSION]][0] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'ietf-network-topology:link' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:602: KeyError 21:48:50 _____________ TestTransportPCEPce.test_05_path_computation_xpdr_bi _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_05_path_computation_xpdr_bi(self): 21:48:50 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:139: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:50 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'}, ...} 21:48:50 21:48:50 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:50 # pylint: disable=consider-using-f-string 21:48:50 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:50 if payload is None: 21:48:50 data = None 21:48:50 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:50 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:50 else: 21:48:50 data = {'input': payload} 21:48:50 response = post_request(url, data) 21:48:50 if response.status_code == requests.codes.no_content: 21:48:50 return_output = None 21:48:50 else: 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': api_module + ':output', 21:48:50 'draft-bierman02': 'output'} 21:48:50 if response.status_code == requests.codes.internal_server_error: 21:48:50 return_output = res 21:48:50 else: 21:48:50 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'transportpce-pce:output' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:761: KeyError 21:48:50 _____________ TestTransportPCEPce.test_06_path_computation_rdm_bi ______________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_06_path_computation_rdm_bi(self): 21:48:50 self.path_computation_input_data["service-a-end"]["node-id"] = "ROADMA01" 21:48:50 self.path_computation_input_data["service-z-end"]["node-id"] = "ROADMC01" 21:48:50 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:151: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:50 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'}, ...} 21:48:50 21:48:50 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:50 # pylint: disable=consider-using-f-string 21:48:50 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:50 if payload is None: 21:48:50 data = None 21:48:50 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:50 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:50 else: 21:48:50 data = {'input': payload} 21:48:50 response = post_request(url, data) 21:48:50 if response.status_code == requests.codes.no_content: 21:48:50 return_output = None 21:48:50 else: 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': api_module + ':output', 21:48:50 'draft-bierman02': 'output'} 21:48:50 if response.status_code == requests.codes.internal_server_error: 21:48:50 return_output = res 21:48:50 else: 21:48:50 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'transportpce-pce:output' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:761: KeyError 21:48:50 _____________ TestTransportPCEPce.test_07_load_simple_topology_uni _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_07_load_simple_topology_uni(self): 21:48:50 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_uni_dir_data) 21:48:50 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 21:48:50 E AssertionError: 401 not found in (200, 204) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:162: AssertionError 21:48:50 ____________________ TestTransportPCEPce.test_08_get_nodeId ____________________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_08_get_nodeId(self): 21:48:50 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-1-2', 'config') 21:48:50 > self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 E AssertionError: 401 != 200 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:168: AssertionError 21:48:50 ____________________ TestTransportPCEPce.test_09_get_linkId ____________________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_09_get_linkId(self): 21:48:50 > response = test_utils.get_ietf_network_link_request( 21:48:50 'openroadm-topology', 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX', 'config') 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:174: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 network = 'openroadm-topology' 21:48:50 link = 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX' 21:48:50 content = 'config' 21:48:50 21:48:50 def get_ietf_network_link_request(network: str, link: str, content: str): 21:48:50 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 21:48:50 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 21:48:50 if RESTCONF_VERSION in ('rfc8040'): 21:48:50 format_args = ('{}', network, link, content) 21:48:50 elif content == 'config': 21:48:50 format_args = ('{}', content, network, link) 21:48:50 else: 21:48:50 format_args = ('{}', 'operational', network, link) 21:48:50 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': 'ietf-network-topology:link', 21:48:50 'draft-bierman02': 'ietf-network-topology:link'} 21:48:50 > link = res[return_key[RESTCONF_VERSION]][0] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'ietf-network-topology:link' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:602: KeyError 21:48:50 ____________ TestTransportPCEPce.test_10_path_computation_xpdr_uni _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_10_path_computation_xpdr_uni(self): 21:48:50 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 21:48:50 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 21:48:50 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 21:48:50 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 21:48:50 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:186: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:50 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'}, ...} 21:48:50 21:48:50 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:50 # pylint: disable=consider-using-f-string 21:48:50 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:50 if payload is None: 21:48:50 data = None 21:48:50 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:50 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:50 else: 21:48:50 data = {'input': payload} 21:48:50 response = post_request(url, data) 21:48:50 if response.status_code == requests.codes.no_content: 21:48:50 return_output = None 21:48:50 else: 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': api_module + ':output', 21:48:50 'draft-bierman02': 'output'} 21:48:50 if response.status_code == requests.codes.internal_server_error: 21:48:50 return_output = res 21:48:50 else: 21:48:50 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'transportpce-pce:output' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:761: KeyError 21:48:50 _____________ TestTransportPCEPce.test_11_path_computation_rdm_uni _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_11_path_computation_rdm_uni(self): 21:48:50 self.path_computation_input_data["service-a-end"]["node-id"] = "OpenROADM-2-1" 21:48:50 self.path_computation_input_data["service-a-end"]["clli"] = "cll21" 21:48:50 self.path_computation_input_data["service-z-end"]["node-id"] = "OpenROADM-2-2" 21:48:50 self.path_computation_input_data["service-z-end"]["clli"] = "ncli22" 21:48:50 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:200: 21:48:50 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:50 21:48:50 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:50 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'cll21', 'node-id': 'OpenROADM-2-1', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 21:48:50 21:48:50 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:50 # pylint: disable=consider-using-f-string 21:48:50 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:50 if payload is None: 21:48:50 data = None 21:48:50 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:50 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:50 else: 21:48:50 data = {'input': payload} 21:48:50 response = post_request(url, data) 21:48:50 if response.status_code == requests.codes.no_content: 21:48:50 return_output = None 21:48:50 else: 21:48:50 res = response.json() 21:48:50 return_key = {'rfc8040': api_module + ':output', 21:48:50 'draft-bierman02': 'output'} 21:48:50 if response.status_code == requests.codes.internal_server_error: 21:48:50 return_output = res 21:48:50 else: 21:48:50 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:50 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:50 E KeyError: 'transportpce-pce:output' 21:48:50 21:48:50 transportpce_tests/common/test_utils.py:761: KeyError 21:48:50 ____________ TestTransportPCEPce.test_15_success1_path_computation _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_15_success1_path_computation(self): 21:48:50 self.path_computation_input_data["service-name"] = "service 1" 21:48:50 self.path_computation_input_data["service-a-end"] = {"service-format": "Ethernet", "service-rate": "100", 21:48:50 "clli": "ORANGE2", "node-id": "XPONDER-2-2"} 21:48:50 self.path_computation_input_data["service-z-end"] = {"service-format": "Ethernet", "service-rate": "100", 21:48:50 "clli": "ORANGE1", "node-id": "XPONDER-1-2"} 21:48:50 self.path_computation_input_data["hard-constraints"] = {"customer-code": ["Some customer-code"], 21:48:50 "co-routing": { 21:48:50 "service-identifier-list": [{ 21:48:50 "service-identifier": "Some existing-service"}] 21:48:50 }} 21:48:50 self.path_computation_input_data["soft-constraints"] = {"customer-code": ["Some customer-code"], 21:48:50 "co-routing": { 21:48:50 "service-identifier-list": [{ 21:48:50 "service-identifier": "Some existing-service"}] 21:48:50 }} 21:48:50 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 > self.assertIn('Path is calculated', 21:48:50 response['output']['configuration-response-common']['response-message']) 21:48:50 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:267: AssertionError 21:48:50 ____________ TestTransportPCEPce.test_16_success2_path_computation _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_16_success2_path_computation(self): 21:48:50 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 21:48:50 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 21:48:50 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 21:48:50 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 21:48:50 del self.path_computation_input_data["hard-constraints"] 21:48:50 del self.path_computation_input_data["soft-constraints"] 21:48:50 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 > self.assertIn('Path is calculated', 21:48:50 response['output']['configuration-response-common']['response-message']) 21:48:50 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:284: AssertionError 21:48:50 ____________ TestTransportPCEPce.test_17_success3_path_computation _____________ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_17_success3_path_computation(self): 21:48:50 self.path_computation_input_data["hard-constraints"] = {"exclude": 21:48:50 {"node-id": ["OpenROADM-2-1", "OpenROADM-2-2"]}} 21:48:50 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 > self.assertIn('Path is calculated', 21:48:50 response['output']['configuration-response-common']['response-message']) 21:48:50 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:300: AssertionError 21:48:50 __ TestTransportPCEPce.test_18_path_computation_before_oms_attribute_deletion __ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_18_path_computation_before_oms_attribute_deletion(self): 21:48:50 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-2-2" 21:48:50 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE2" 21:48:50 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-1-2" 21:48:50 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE1" 21:48:50 del self.path_computation_input_data["hard-constraints"] 21:48:50 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 > self.assertIn('Path is calculated', 21:48:50 response['output']['configuration-response-common']['response-message']) 21:48:50 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:319: AssertionError 21:48:50 __ TestTransportPCEPce.test_20_path_computation_after_oms_attribute_deletion ___ 21:48:50 21:48:50 self = 21:48:50 21:48:50 def test_20_path_computation_after_oms_attribute_deletion(self): 21:48:50 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:50 'path-computation-request', 21:48:50 self.path_computation_input_data) 21:48:50 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:50 > self.assertIn('Path is calculated', 21:48:50 response['output']['configuration-response-common']['response-message']) 21:48:50 E AssertionError: 'Path is calculated' not found in 'Error during reading nodes: A is not present in the network' 21:48:50 21:48:50 transportpce_tests/pce/test01_pce.py:346: AssertionError 21:48:50 --------------------------- Captured stdout teardown --------------------------- 21:48:50 all processes killed 21:48:50 ODL log file stored 21:48:50 =========================== short test summary info ============================ 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_01_load_port_mapping 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_02_load_simple_topology_bi 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_03_get_nodeId 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_04_get_linkId 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_05_path_computation_xpdr_bi 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_06_path_computation_rdm_bi 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_07_load_simple_topology_uni 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_08_get_nodeId 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_09_get_linkId 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_10_path_computation_xpdr_uni 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_11_path_computation_rdm_uni 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_15_success1_path_computation 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_16_success2_path_computation 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_17_success3_path_computation 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_18_path_computation_before_oms_attribute_deletion 21:48:50 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_20_path_computation_after_oms_attribute_deletion 21:48:50 16 failed, 4 passed in 93.20s (0:01:33) 21:48:50 testsPCE: exit 1 (93.52 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce pid=5180 21:48:51 testsPCE: FAIL ✖ in 4 minutes 2.53 seconds 21:48:51 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 21:48:51 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 21:48:51 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 21:49:02 tests121: freeze> python -m pip freeze --all 21:49:02 tests_tapi: freeze> python -m pip freeze --all 21:49:03 tests_tapi: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:49:03 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 21:49:03 tests121: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:49:03 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 21:49:03 using environment variables from ./karaf121.env 21:49:03 using environment variables from ./karaf221.env 21:49:03 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 21:49:03 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 21:49:03 tests190: freeze> python -m pip freeze --all 21:49:03 tests190: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:49:03 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 21:49:03 using environment variables from ./karafoc.env 21:49:03 pytest -q transportpce_tests/oc/test01_portmapping.py 21:49:57 FF..............................................FFFFFFFFFFFFF................F [100%] 21:56:09 =================================== FAILURES =================================== 21:56:09 ___________ TestTransportPCEPortmapping.test_01_meta_data_insertion ____________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_01_meta_data_insertion(self): 21:56:09 response = test_utils_oc.metadata_input() 21:56:09 > self.assertEqual(response.status_code, requests.codes.created, 21:56:09 test_utils.CODE_SHOULD_BE_201) 21:56:09 E AssertionError: 401 != 201 : Http status code should be 201 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:48: AssertionError 21:56:09 ---------------------------- Captured stdout setup ----------------------------- 21:56:09 starting OpenDaylight... 21:56:09 starting KARAF (karafoc) TransportPCE build... 21:56:09 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 21:56:09 starting simulator oc-mpdr in OpenROADM device version oc... 21:56:09 Searching for patterns in sample-openconfig-mpdr.log... Pattern found! simulator for oc-mpdr started 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_01_meta_data_insertion 21:56:09 __________ TestTransportPCEPortmapping.test_02_catlog_input_insertion __________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_02_catlog_input_insertion(self): 21:56:09 response = test_utils_oc.catlog_input() 21:56:09 > self.assertEqual(response.status_code, requests.codes.ok, 21:56:09 test_utils.CODE_SHOULD_BE_200) 21:56:09 E AssertionError: 401 != 200 : Http status code should be 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:53: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_02_catlog_input_insertion 21:56:09 __________ TestTransportPCEPortmapping.test_03_xpdr_device_connection __________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_03_xpdr_device_connection(self): 21:56:09 response = test_utils.mount_device("XPDR-OC", 21:56:09 ('oc-mpdr', self.NODE_VERSION)) 21:56:09 > self.assertEqual(response.status_code, requests.codes.created, 21:56:09 test_utils.CODE_SHOULD_BE_201) 21:56:09 E AssertionError: 401 != 201 : Http status code should be 201 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:59: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_03_xpdr_device_connection 21:56:09 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not added to tpce topology... 21:56:09 __________ TestTransportPCEPortmapping.test_04_xpdr_device_connected ___________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_04_xpdr_device_connected(self): 21:56:09 response = test_utils.check_device_connection("XPDR-OC") 21:56:09 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:64: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_04_xpdr_device_connected 21:56:09 __________ TestTransportPCEPortmapping.test_05_xpdr_portmapping_info ___________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_05_xpdr_portmapping_info(self): 21:56:09 response = test_utils.get_portmapping_node_attr("XPDR-OC", "node-info", None) 21:56:09 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:69: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_05_xpdr_portmapping_info 21:56:09 ________ TestTransportPCEPortmapping.test_06_mpdr_portmapping_NETWORK5 _________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_06_mpdr_portmapping_NETWORK5(self): 21:56:09 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-NETWORK5") 21:56:09 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:82: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_06_mpdr_portmapping_NETWORK5 21:56:09 _________ TestTransportPCEPortmapping.test_07_mpdr_portmapping_CLIENT1 _________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_07_mpdr_portmapping_CLIENT1(self): 21:56:09 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-CLIENT1") 21:56:09 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:104: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_07_mpdr_portmapping_CLIENT1 21:56:09 ___________ TestTransportPCEPortmapping.test_08_mpdr_switching_pool ____________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_08_mpdr_switching_pool(self): 21:56:09 response = test_utils.get_portmapping_node_attr("XPDR-OC", "switching-pool-lcp", "1") 21:56:09 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:130: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_08_mpdr_switching_pool 21:56:09 ____________ TestTransportPCEPortmapping.test_09_check_mccapprofile ____________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_09_check_mccapprofile(self): 21:56:09 res = test_utils.get_portmapping_node_attr("XPDR-OC", "mc-capabilities", "XPDR-mcprofile") 21:56:09 > self.assertEqual(res['status_code'], requests.codes.ok) 21:56:09 E AssertionError: 409 != 200 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:143: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_09_check_mccapprofile 21:56:09 ________ TestTransportPCEPortmapping.test_10_xpdr_device_disconnection _________ 21:56:09 21:56:09 self = 21:56:09 21:56:09 def test_10_xpdr_device_disconnection(self): 21:56:09 response = test_utils.unmount_device("XPDR-OC") 21:56:09 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 21:56:09 E AssertionError: 409 not found in (200, 204) 21:56:09 21:56:09 transportpce_tests/oc/test01_portmapping.py:150: AssertionError 21:56:09 ----------------------------- Captured stdout call ----------------------------- 21:56:09 execution of test_10_xpdr_device_disconnection 21:56:09 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not deleted from tpce topology... 21:56:09 --------------------------- Captured stdout teardown --------------------------- 21:56:09 all processes killed 21:56:09 ODL log file stored 21:56:09 =========================== short test summary info ============================ 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_01_meta_data_insertion 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_02_catlog_input_insertion 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_03_xpdr_device_connection 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_04_xpdr_device_connected 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_05_xpdr_portmapping_info 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_06_mpdr_portmapping_NETWORK5 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_07_mpdr_portmapping_CLIENT1 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_08_mpdr_switching_pool 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_09_check_mccapprofile 21:56:09 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_10_xpdr_device_disconnection 21:56:09 10 failed in 425.33s (0:07:05) 21:56:09 tests190: exit 1 (425.63 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc pid=6240 21:56:09 tests190: FAIL ✖ in 7 minutes 19.14 seconds 21:56:09 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 21:56:16 tests71: freeze> python -m pip freeze --all 21:56:16 tests71: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 21:56:16 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 21:56:16 using environment variables from ./karaf71.env 21:56:16 pytest -q transportpce_tests/7.1/test01_portmapping.py 21:56:45 F... [100%] 21:56:49 =================================== FAILURES =================================== 21:56:49 __________ TestTransportPCEPortmapping.test_01_rdm_device_connection ___________ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_01_rdm_device_connection(self): 21:56:49 response = test_utils.mount_device("ROADMA01", ('roadma', self.NODE_VERSION)) 21:56:49 > self.assertEqual(response.status_code, requests.codes.created, test_utils.CODE_SHOULD_BE_201) 21:56:49 E AssertionError: 401 != 201 : Http status code should be 201 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:51: AssertionError 21:56:49 ---------------------------- Captured stdout setup ----------------------------- 21:56:49 starting OpenDaylight... 21:56:49 starting KARAF (karaf121) TransportPCE build... 21:56:49 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 21:56:49 starting simulator xpdra in OpenROADM device version 1.2.1... 21:56:49 Searching for patterns in xpdra-121.log... Pattern found! simulator for xpdra started 21:56:49 starting simulator roadma in OpenROADM device version 1.2.1... 21:56:49 Searching for patterns in roadma-121.log... Pattern found! simulator for roadma started 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_01_rdm_device_connection 21:56:49 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not added to tpce topology... 21:56:49 ___________ TestTransportPCEPortmapping.test_02_rdm_device_connected ___________ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_02_rdm_device_connected(self): 21:56:49 response = test_utils.check_device_connection("ROADMA01") 21:56:49 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:49 E AssertionError: 409 != 200 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:55: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_02_rdm_device_connected 21:56:49 ___________ TestTransportPCEPortmapping.test_03_rdm_portmapping_info ___________ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_03_rdm_portmapping_info(self): 21:56:49 response = test_utils.get_portmapping_node_attr("ROADMA01", "node-info", None) 21:56:49 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:49 E AssertionError: 409 != 200 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:61: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_03_rdm_portmapping_info 21:56:49 ______ TestTransportPCEPortmapping.test_04_rdm_portmapping_DEG1_TTP_TXRX _______ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_04_rdm_portmapping_DEG1_TTP_TXRX(self): 21:56:49 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "DEG1-TTP-TXRX") 21:56:49 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:49 E AssertionError: 409 != 200 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:74: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_04_rdm_portmapping_DEG1_TTP_TXRX 21:56:49 ______ TestTransportPCEPortmapping.test_05_rdm_portmapping_SRG1_PP7_TXRX _______ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_05_rdm_portmapping_SRG1_PP7_TXRX(self): 21:56:49 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG1-PP7-TXRX") 21:56:49 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:49 E AssertionError: 409 != 200 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:83: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_05_rdm_portmapping_SRG1_PP7_TXRX 21:56:49 ______ TestTransportPCEPortmapping.test_06_rdm_portmapping_SRG3_PP1_TXRX _______ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_06_rdm_portmapping_SRG3_PP1_TXRX(self): 21:56:49 response = test_utils.get_portmapping_node_attr("ROADMA01", "mapping", "SRG3-PP1-TXRX") 21:56:49 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:49 E AssertionError: 409 != 200 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:92: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_06_rdm_portmapping_SRG3_PP1_TXRX 21:56:49 _________ TestTransportPCEPortmapping.test_19_rdm_device_disconnection _________ 21:56:49 21:56:49 self = 21:56:49 21:56:49 def test_19_rdm_device_disconnection(self): 21:56:49 response = test_utils.unmount_device("ROADMA01") 21:56:49 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 21:56:49 E AssertionError: 409 not found in (200, 204) 21:56:49 21:56:49 transportpce_tests/1.2.1/test01_portmapping.py:214: AssertionError 21:56:49 ----------------------------- Captured stdout call ----------------------------- 21:56:49 execution of test_19_rdm_device_disconnection 21:56:49 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node ROADMA01 still not deleted from tpce topology... 21:56:49 =========================== short test summary info ============================ 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_01_rdm_device_connection 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_02_rdm_device_connected 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_03_rdm_portmapping_info 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_04_rdm_portmapping_DEG1_TTP_TXRX 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_05_rdm_portmapping_SRG1_PP7_TXRX 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_06_rdm_portmapping_SRG3_PP1_TXRX 21:56:49 FAILED transportpce_tests/1.2.1/test01_portmapping.py::TestTransportPCEPortmapping::test_19_rdm_device_disconnection 21:56:49 7 failed, 14 passed in 466.10s (0:07:46) 21:56:49 tests121: exit 1 (466.39 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=5966 21:56:50 ........... [100%] 21:57:02 12 passed in 45.49s 21:57:02 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 21:57:07 . [100%] 21:57:11 51 passed in 487.88s (0:08:07) 21:57:11 pytest -q transportpce_tests/tapi/test02_full_topology.py 21:57:38 ...........................................................................F...F. [100%] 21:59:49 62 passed in 166.25s (0:02:46) 21:59:49 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 22:00:07 .F.......F...F.................................................. [100%] 22:02:12 48 passed in 143.12s (0:02:23) 22:02:12 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 22:02:36 . [100%] 22:02:39 =================================== FAILURES =================================== 22:02:39 _ TestTransportPCEFullTopology.test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation _ 22:02:39 22:02:39 self = 22:02:39 22:02:39 def test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation(self): 22:02:39 response = test_utils.get_tapi_topology_node( 22:02:39 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1OTS, "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertEqual(response['status_code'], requests.codes.ok) 22:02:39 input_dict_1 = {"spectrum-capability-pac": {"occupied-spectrum": [{"upper-frequency": "196125000000000", 22:02:39 "lower-frequency": "196075000000000"}], 22:02:39 "supportable-spectrum": [{"upper-frequency": "196125000000000", 22:02:39 "lower-frequency": "191325000000000"}]} 22:02:39 } 22:02:39 22:02:39 self.assertDictEqual(dict(input_dict_1, 22:02:39 **response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']), 22:02:39 response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'eNodeEdgePoint') 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+PHOTONIC_MEDIA_OTS+XPDR1-NETWORK1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:02:39 ['client-node-edge-point'][0]['node-edge-point-uuid'], 'f32f5e9e-d167-31ba-a9e4-8f1efdb8786d') 22:02:39 self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:02:39 ['parent-node-edge-point']['node-edge-point-uuid'], '21efd6a4-2d81-3cdb-aabb-b983fb61904e') 22:02:39 22:02:39 response = test_utils.get_tapi_topology_node( 22:02:39 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1OTSi, "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertDictEqual(dict(input_dict_1, 22:02:39 **response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']), 22:02:39 response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']) 22:02:39 self.assertEqual(response['status_code'], requests.codes.ok) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'PhotMedNodeEdgePoint') 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+OTSi_MEDIA_CHANNEL+XPDR1-NETWORK1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:02:39 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:02:39 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:02:39 ['client-node-edge-point'][0]['node-edge-point-uuid'], '7d2a0549-63e3-3c7f-b4dc-5653e8a81dbe') 22:02:39 E KeyError: 'tapi-connectivity:cep-list' 22:02:39 22:02:39 transportpce_tests/tapi/test02_full_topology.py:428: KeyError 22:02:39 _ TestTransportPCEFullTopology.test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation _ 22:02:39 22:02:39 self = 22:02:39 22:02:39 def test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation(self): 22:02:39 response = test_utils.get_tapi_topology_node( 22:02:39 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1iODU, "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'iNodeEdgePoint_N') 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+iODU+XPDR1-NETWORK1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:02:39 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:02:39 22:02:39 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:02:39 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:02:39 "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'eNodeEdgePoint_N') 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '10.0') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '10.0') 22:02:39 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '10.0') 22:02:39 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:02:39 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:02:39 ['parent-node-edge-point']['node-edge-point-uuid'], '72c6b97a-3944-3d88-9882-b7e688bb2772') 22:02:39 E KeyError: 'tapi-connectivity:cep-list' 22:02:39 22:02:39 transportpce_tests/tapi/test02_full_topology.py:478: KeyError 22:02:39 _ TestTransportPCEFullTopology.test_20_get_tapi_node_details_at_ODU_Service_creation _ 22:02:39 22:02:39 self = 22:02:39 22:02:39 def test_20_get_tapi_node_details_at_ODU_Service_creation(self): 22:02:39 # ODU service creation correspond to the creation of HO-ODU between 2 Network ports and is associated an 22:02:39 # iODU4 top connection which uses 100% of underlying OTU4 22:02:39 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:02:39 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:02:39 "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '10.0') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:02:39 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '10.0') 22:02:39 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '10.0') 22:02:39 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:02:39 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:02:39 ['client-node-edge-point'][0]['node-edge-point-uuid'], 'c6cd334c-51a1-3995-bed3-5cf2b7445c04') 22:02:39 E KeyError: 'tapi-connectivity:cep-list' 22:02:39 22:02:39 transportpce_tests/tapi/test02_full_topology.py:545: KeyError 22:02:39 _ TestTransportPCEFullTopology.test_23_get_tapi_node_details_at_DSR_Service_creation _ 22:02:39 22:02:39 self = 22:02:39 22:02:39 def test_23_get_tapi_node_details_at_DSR_Service_creation(self): 22:02:39 22:02:39 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:02:39 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:02:39 "nonconfig") 22:02:39 time.sleep(2) 22:02:39 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:02:39 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:02:39 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:02:39 > self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '0') 22:02:39 E AssertionError: '1' != '0' 22:02:39 E - 1 22:02:39 E + 0 22:02:39 22:02:39 transportpce_tests/tapi/test02_full_topology.py:663: AssertionError 22:02:39 ______ TestTransportPCEFullTopology.test_25_get_connectivity_service_list ______ 22:02:39 22:02:39 self = 22:02:39 22:02:39 def test_25_get_connectivity_service_list(self): 22:02:39 response = test_utils.transportpce_api_rpc_request( 22:02:39 'tapi-connectivity', 'get-connectivity-service-list', None) 22:02:39 self.assertEqual(response['status_code'], requests.codes.ok) 22:02:39 liste_service = response['output']['service'] 22:02:39 for ele in liste_service: 22:02:39 if ele['uuid'] == self.uuid_services.pm: 22:02:39 self.assertEqual(ele['operational-state'], 'ENABLED') 22:02:39 # self.assertEqual(ele['service-layer'], 'PHOTONIC_MEDIA') 22:02:39 self.assertEqual(ele['layer-protocol-name'], 'PHOTONIC_MEDIA') 22:02:39 nbconnection = len(ele['connection']) 22:02:39 self.assertEqual(nbconnection, 4, 'There should be 4 connections') 22:02:39 elif ele['uuid'] == self.uuid_services.odu: 22:02:39 > self.assertEqual(ele['operational-state'], 'ENABLED') 22:02:39 E AssertionError: 'DISABLED' != 'ENABLED' 22:02:39 E - DISABLED 22:02:39 E + ENABLED 22:02:39 22:02:39 transportpce_tests/tapi/test02_full_topology.py:714: AssertionError 22:02:39 =========================== short test summary info ============================ 22:02:39 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation 22:02:39 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation 22:02:39 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_20_get_tapi_node_details_at_ODU_Service_creation 22:02:39 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_23_get_tapi_node_details_at_DSR_Service_creation 22:02:39 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_25_get_connectivity_service_list 22:02:39 5 failed, 31 passed in 327.76s (0:05:27) 22:02:39 tests121: FAIL ✖ in 7 minutes 59.29 seconds 22:02:39 tests_tapi: exit 1 (816.51 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=5967 22:02:40 tests_tapi: FAIL ✖ in 13 minutes 49.41 seconds 22:02:40 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 22:02:41 ...tests221: freeze> python -m pip freeze --all 22:02:48 tests221: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 22:02:48 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 22:02:48 using environment variables from ./karaf221.env 22:02:48 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 22:02:49 ...................... [100%] 22:03:29 22 passed in 76.80s (0:01:16) 22:03:29 ................................ [100%] 22:04:06 35 passed in 78.20s (0:01:18) 22:04:06 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 22:04:44 ...... [100%] 22:04:58 6 passed in 51.75s 22:04:58 pytest -q transportpce_tests/2.2.1/test03_topology.py 22:05:42 ............................................ [100%] 22:07:16 44 passed in 137.47s (0:02:17) 22:07:16 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 22:07:52 ............ [100%] 22:08:16 12 passed in 59.95s 22:08:16 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 22:08:43 ................ [100%] 22:10:12 16 passed in 115.57s (0:01:55) 22:10:12 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 22:10:43 ............................... [100%] 22:10:49 31 passed in 36.79s 22:10:49 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 22:11:26 .......................... [100%] 22:12:21 26 passed in 91.64s (0:01:31) 22:12:21 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 22:13:02 ...................... [100%] 22:14:06 22 passed in 104.52s (0:01:44) 22:14:06 pytest -q transportpce_tests/2.2.1/test09_olm.py 22:14:54 ........................................ [100%] 22:17:17 40 passed in 190.53s (0:03:10) 22:17:17 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 22:18:05 ........................................................................ [ 74%] 22:23:43 ......................... [100%] 22:25:35 97 passed in 497.80s (0:08:17) 22:25:35 pytest -q transportpce_tests/2.2.1/test12_end2end.py 22:26:19 ...................................................... [100%] 22:33:07 54 passed in 451.67s (0:07:31) 22:33:07 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 22:34:05 ........................................................................ [ 71%] 22:39:14 ............................. [100%] 22:41:23 101 passed in 495.64s (0:08:15) 22:41:23 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 22:42:20 ........................................................................ [ 67%] 22:48:07 ................................... [100%] 22:54:28 107 passed in 784.16s (0:13:04) 22:54:28 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 22:55:13 ............................................. [100%] 23:00:50 45 passed in 381.75s (0:06:21) 23:00:50 tests71: OK ✔ in 7 minutes 20.24 seconds 23:00:50 tests221: OK ✔ in 58 minutes 10.33 seconds 23:00:50 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 23:00:57 tests_hybrid: freeze> python -m pip freeze --all 23:00:57 tests_hybrid: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.3,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==25.3,pluggy==1.6.0,psutil==7.2.1,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.6.3 23:00:57 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 23:00:57 using environment variables from ./karaf221.env 23:00:57 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 23:01:43 ................................................... [100%] 23:03:32 51 passed in 155.19s (0:02:35) 23:03:32 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 23:04:20 ........................................................................ [ 66%] 23:08:41 ..................................... [100%] 23:10:47 109 passed in 434.66s (0:07:14) 23:10:47 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 23:11:38 ..................................................... [100%] 23:18:11 53 passed in 443.29s (0:07:23) 23:18:11 buildcontroller: OK (137.72=setup[8.96]+cmd[128.75] seconds) 23:18:11 sims: OK (55.17=setup[52.09]+cmd[3.09] seconds) 23:18:11 build_karaf_tests121: OK (143.35=setup[10.54]+cmd[132.81] seconds) 23:18:11 testsPCE: FAIL code 1 (242.53=setup[149.01]+cmd[93.52] seconds) 23:18:11 tests121: FAIL code 1 (479.29=setup[12.90]+cmd[466.39] seconds) 23:18:11 build_karaf_tests221: OK (141.84=setup[10.54]+cmd[131.31] seconds) 23:18:11 tests_tapi: FAIL code 1 (829.41=setup[12.90]+cmd[816.51] seconds) 23:18:11 tests221: OK (3490.33=setup[8.14]+cmd[3482.19] seconds) 23:18:11 build_karaf_tests71: OK (141.32=setup[10.69]+cmd[130.63] seconds) 23:18:11 tests71: OK (440.24=setup[7.29]+cmd[432.95] seconds) 23:18:11 build_karaf_tests190: OK (121.60=setup[10.47]+cmd[111.13] seconds) 23:18:11 tests190: FAIL code 1 (439.14=setup[13.50]+cmd[425.63] seconds) 23:18:11 tests_hybrid: OK (1041.33=setup[7.16]+cmd[1034.16] seconds) 23:18:11 buildlighty: OK (94.87=setup[71.68]+cmd[23.19] seconds) 23:18:11 docs: OK (76.11=setup[73.47]+cmd[2.63] seconds) 23:18:11 docs-linkcheck: OK (77.73=setup[72.48]+cmd[5.25] seconds) 23:18:11 checkbashisms: OK (3.22=setup[1.93]+cmd[0.01,0.05,1.23] seconds) 23:18:11 pre-commit: OK (91.75=setup[3.39]+cmd[0.01,0.01,78.04,10.31] seconds) 23:18:11 pylint: OK (31.31=setup[7.28]+cmd[24.03] seconds) 23:18:11 evaluation failed :( (5884.71 seconds) 23:18:11 + tox_status=255 23:18:11 + echo '---> Completed tox runs' 23:18:11 ---> Completed tox runs 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/build_karaf_tests121/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=build_karaf_tests121 23:18:11 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/build_karaf_tests190/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=build_karaf_tests190 23:18:11 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/build_karaf_tests221/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=build_karaf_tests221 23:18:11 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/build_karaf_tests71/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=build_karaf_tests71 23:18:11 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/buildcontroller/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=buildcontroller 23:18:11 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/buildlighty/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=buildlighty 23:18:11 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/checkbashisms/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=checkbashisms 23:18:11 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/docs-linkcheck/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=docs-linkcheck 23:18:11 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/docs/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=docs 23:18:11 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/pre-commit/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=pre-commit 23:18:11 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/pylint/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=pylint 23:18:11 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/sims/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=sims 23:18:11 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests121/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests121 23:18:11 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests190/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests190 23:18:11 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests221/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests221 23:18:11 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests71/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests71 23:18:11 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/testsPCE/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=testsPCE 23:18:11 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests_hybrid/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests_hybrid 23:18:11 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 23:18:11 + for i in .tox/*/log 23:18:11 ++ echo .tox/tests_tapi/log 23:18:11 ++ awk -F/ '{print $2}' 23:18:11 + tox_env=tests_tapi 23:18:11 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 23:18:11 + DOC_DIR=docs/_build/html 23:18:11 + [[ -d docs/_build/html ]] 23:18:11 + echo '---> Archiving generated docs' 23:18:11 ---> Archiving generated docs 23:18:11 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 23:18:11 + echo '---> tox-run.sh ends' 23:18:11 ---> tox-run.sh ends 23:18:11 + test 255 -eq 0 23:18:11 + exit 255 23:18:11 ++ '[' 1 = 1 ']' 23:18:11 ++ '[' -x /usr/bin/clear_console ']' 23:18:11 ++ /usr/bin/clear_console -q 23:18:11 Build step 'Execute shell' marked build as failure 23:18:11 $ ssh-agent -k 23:18:11 unset SSH_AUTH_SOCK; 23:18:11 unset SSH_AGENT_PID; 23:18:11 echo Agent pid 1561 killed; 23:18:11 [ssh-agent] Stopped. 23:18:12 [PostBuildScript] - [INFO] Executing post build scripts. 23:18:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1848661626495759375.sh 23:18:12 ---> sysstat.sh 23:18:12 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11351898891787646471.sh 23:18:12 ---> package-listing.sh 23:18:12 ++ facter osfamily 23:18:12 ++ tr '[:upper:]' '[:lower:]' 23:18:13 + OS_FAMILY=debian 23:18:13 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 23:18:13 + START_PACKAGES=/tmp/packages_start.txt 23:18:13 + END_PACKAGES=/tmp/packages_end.txt 23:18:13 + DIFF_PACKAGES=/tmp/packages_diff.txt 23:18:13 + PACKAGES=/tmp/packages_start.txt 23:18:13 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 23:18:13 + PACKAGES=/tmp/packages_end.txt 23:18:13 + case "${OS_FAMILY}" in 23:18:13 + dpkg -l 23:18:13 + grep '^ii' 23:18:13 + '[' -f /tmp/packages_start.txt ']' 23:18:13 + '[' -f /tmp/packages_end.txt ']' 23:18:13 + diff /tmp/packages_start.txt /tmp/packages_end.txt 23:18:13 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 23:18:13 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 23:18:13 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 23:18:13 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4081172816173444630.sh 23:18:13 ---> capture-instance-metadata.sh 23:18:13 Setup pyenv: 23:18:13 system 23:18:13 3.8.20 23:18:13 3.9.20 23:18:13 3.10.15 23:18:13 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:18:13 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-1ER1 from file:/tmp/.os_lf_venv 23:18:13 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:18:13 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:18:15 lf-activate-venv(): INFO: Base packages installed successfully 23:18:15 lf-activate-venv(): INFO: Installing additional packages: lftools 23:18:33 lf-activate-venv(): INFO: Adding /tmp/venv-1ER1/bin to PATH 23:18:33 INFO: Running in OpenStack, capturing instance metadata 23:18:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3380614826737700740.sh 23:18:33 provisioning config files... 23:18:34 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #4246 23:18:34 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config14205250347526945155tmp 23:18:34 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 23:18:34 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 23:18:34 provisioning config files... 23:18:34 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 23:18:34 [EnvInject] - Injecting environment variables from a build step. 23:18:34 [EnvInject] - Injecting as environment variables the properties content 23:18:34 SERVER_ID=logs 23:18:34 23:18:34 [EnvInject] - Variables injected successfully. 23:18:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins11814875648345608899.sh 23:18:34 ---> create-netrc.sh 23:18:34 WARN: Log server credential not found. 23:18:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8212503540004110936.sh 23:18:34 ---> python-tools-install.sh 23:18:34 Setup pyenv: 23:18:34 system 23:18:34 3.8.20 23:18:34 3.9.20 23:18:34 3.10.15 23:18:34 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:18:34 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-1ER1 from file:/tmp/.os_lf_venv 23:18:34 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:18:34 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:18:36 lf-activate-venv(): INFO: Base packages installed successfully 23:18:36 lf-activate-venv(): INFO: Installing additional packages: lftools 23:18:48 lf-activate-venv(): INFO: Adding /tmp/venv-1ER1/bin to PATH 23:18:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16311297467843461126.sh 23:18:48 ---> sudo-logs.sh 23:18:48 Archiving 'sudo' log.. 23:18:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins10487548800096034679.sh 23:18:48 ---> job-cost.sh 23:18:48 Setup pyenv: 23:18:48 system 23:18:48 3.8.20 23:18:48 3.9.20 23:18:48 3.10.15 23:18:48 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:18:48 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-1ER1 from file:/tmp/.os_lf_venv 23:18:48 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:18:48 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:18:50 lf-activate-venv(): INFO: Base packages installed successfully 23:18:50 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 23:18:59 lf-activate-venv(): INFO: Adding /tmp/venv-1ER1/bin to PATH 23:18:59 INFO: No Stack... 23:18:59 INFO: Retrieving Pricing Info for: v3-standard-4 23:19:00 INFO: Archiving Costs 23:19:00 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins2845722879352092053.sh 23:19:00 ---> logs-deploy.sh 23:19:00 Setup pyenv: 23:19:00 system 23:19:00 3.8.20 23:19:00 3.9.20 23:19:00 3.10.15 23:19:00 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:19:00 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-1ER1 from file:/tmp/.os_lf_venv 23:19:00 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:19:00 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:19:04 lf-activate-venv(): INFO: Base packages installed successfully 23:19:04 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 23:19:18 lf-activate-venv(): INFO: Adding /tmp/venv-1ER1/bin to PATH 23:19:18 WARNING: Nexus logging server not set 23:19:18 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/4246/ 23:19:18 INFO: archiving logs to S3 23:19:20 ---> uname -a: 23:19:20 Linux prd-ubuntu2204-docker-4c-16g-5100 5.15.0-164-generic #174-Ubuntu SMP Fri Nov 14 20:25:16 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux 23:19:20 23:19:20 23:19:20 ---> lscpu: 23:19:20 Architecture: x86_64 23:19:20 CPU op-mode(s): 32-bit, 64-bit 23:19:20 Address sizes: 40 bits physical, 48 bits virtual 23:19:20 Byte Order: Little Endian 23:19:20 CPU(s): 4 23:19:20 On-line CPU(s) list: 0-3 23:19:20 Vendor ID: AuthenticAMD 23:19:20 Model name: AMD EPYC-Rome Processor 23:19:20 CPU family: 23 23:19:20 Model: 49 23:19:20 Thread(s) per core: 1 23:19:20 Core(s) per socket: 1 23:19:20 Socket(s): 4 23:19:20 Stepping: 0 23:19:20 BogoMIPS: 5600.00 23:19:20 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 23:19:20 Virtualization: AMD-V 23:19:20 Hypervisor vendor: KVM 23:19:20 Virtualization type: full 23:19:20 L1d cache: 128 KiB (4 instances) 23:19:20 L1i cache: 128 KiB (4 instances) 23:19:20 L2 cache: 2 MiB (4 instances) 23:19:20 L3 cache: 64 MiB (4 instances) 23:19:20 NUMA node(s): 1 23:19:20 NUMA node0 CPU(s): 0-3 23:19:20 Vulnerability Gather data sampling: Not affected 23:19:20 Vulnerability Indirect target selection: Not affected 23:19:20 Vulnerability Itlb multihit: Not affected 23:19:20 Vulnerability L1tf: Not affected 23:19:20 Vulnerability Mds: Not affected 23:19:20 Vulnerability Meltdown: Not affected 23:19:20 Vulnerability Mmio stale data: Not affected 23:19:20 Vulnerability Reg file data sampling: Not affected 23:19:20 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 23:19:20 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 23:19:20 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 23:19:20 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 23:19:20 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 23:19:20 Vulnerability Srbds: Not affected 23:19:20 Vulnerability Tsa: Not affected 23:19:20 Vulnerability Tsx async abort: Not affected 23:19:20 Vulnerability Vmscape: Not affected 23:19:20 23:19:20 23:19:20 ---> nproc: 23:19:20 4 23:19:20 23:19:20 23:19:20 ---> df -h: 23:19:20 Filesystem Size Used Avail Use% Mounted on 23:19:20 tmpfs 1.6G 1.1M 1.6G 1% /run 23:19:20 /dev/vda1 78G 18G 61G 23% / 23:19:20 tmpfs 7.9G 0 7.9G 0% /dev/shm 23:19:20 tmpfs 5.0M 0 5.0M 0% /run/lock 23:19:20 /dev/vda15 105M 6.1M 99M 6% /boot/efi 23:19:20 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 23:19:20 23:19:20 23:19:20 ---> free -m: 23:19:20 total used free shared buff/cache available 23:19:20 Mem: 15989 745 9406 4 5837 14901 23:19:20 Swap: 1023 0 1023 23:19:20 23:19:20 23:19:20 ---> ip addr: 23:19:20 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 23:19:20 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 23:19:20 inet 127.0.0.1/8 scope host lo 23:19:20 valid_lft forever preferred_lft forever 23:19:20 inet6 ::1/128 scope host 23:19:20 valid_lft forever preferred_lft forever 23:19:20 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 23:19:20 link/ether fa:16:3e:be:b0:1a brd ff:ff:ff:ff:ff:ff 23:19:20 altname enp0s3 23:19:20 inet 10.30.170.102/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 23:19:20 valid_lft 80288sec preferred_lft 80288sec 23:19:20 inet6 fe80::f816:3eff:febe:b01a/64 scope link 23:19:20 valid_lft forever preferred_lft forever 23:19:20 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 23:19:20 link/ether da:a4:7f:06:9b:48 brd ff:ff:ff:ff:ff:ff 23:19:20 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 23:19:20 valid_lft forever preferred_lft forever 23:19:20 23:19:20 23:19:20 ---> sar -b -r -n DEV: 23:19:20 Linux 5.15.0-164-generic (prd-ubuntu2204-docker-4c-16g-5100) 01/27/26 _x86_64_ (4 CPU) 23:19:20 23:19:20 21:37:32 LINUX RESTART (4 CPU) 23:19:20 23:19:20 21:40:02 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 23:19:20 21:50:03 113.74 4.65 89.31 19.78 816.87 37545.94 258861.90 23:19:20 22:00:01 45.46 21.71 22.36 1.38 208.23 1948.05 1165.89 23:19:20 22:10:11 19.25 0.00 18.41 0.83 0.03 665.03 936.44 23:19:20 22:20:11 11.85 0.01 11.34 0.50 0.11 317.99 255.96 23:19:20 22:30:01 3.90 0.00 3.79 0.11 0.01 101.57 58.16 23:19:20 22:40:11 4.47 0.00 4.34 0.13 0.00 120.25 3754.90 23:19:20 22:50:11 5.06 0.00 4.91 0.15 0.01 127.52 68.28 23:19:20 23:00:01 4.95 0.00 4.81 0.13 0.00 124.72 54.50 23:19:20 23:10:11 9.25 0.12 8.85 0.27 3.04 502.47 222.30 23:19:20 Average: 24.22 2.93 18.70 2.59 114.14 4606.21 29491.78 23:19:20 23:19:20 21:40:02 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 23:19:20 21:50:03 164452 11338336 4579784 27.97 258432 10658256 5941356 34.10 2227048 13164948 138036 23:19:20 22:00:01 4191000 9238716 6688624 40.85 269352 4649992 8196748 47.05 2267840 9223096 1588 23:19:20 22:10:11 8444456 13599368 2330220 14.23 275344 4747732 3036172 17.43 2308300 4940652 96 23:19:20 22:20:11 6219704 11405800 4522688 27.62 276856 4777308 5215804 29.94 2311784 7151948 204 23:19:20 22:30:01 6204548 11401724 4526612 27.65 277440 4787788 5206516 29.89 2312908 7171112 272 23:19:20 22:40:11 4636716 9847712 6079836 37.13 278000 4801016 6810560 39.09 2314744 8731388 168 23:19:20 22:50:11 4676228 9901236 6026280 36.81 278664 4814364 6728372 38.62 2317796 8689756 76 23:19:20 23:00:01 6150276 11390200 4538304 27.72 279208 4828724 5267912 30.24 2319844 7218160 244 23:19:20 23:10:11 6021048 11375592 4552244 27.80 283152 4933640 5215656 29.94 2334364 7328312 64 23:19:20 Average: 5189825 11055409 4871621 29.75 275161 5444313 5735455 32.92 2301625 8179930 15639 23:19:20 23:19:20 21:40:02 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 23:19:20 21:50:03 lo 1.98 1.98 1.51 1.51 0.00 0.00 0.00 0.00 23:19:20 21:50:03 ens3 139.12 101.88 2029.90 10.61 0.00 0.00 0.00 0.00 23:19:20 21:50:03 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:00:01 lo 18.24 18.24 12.52 12.52 0.00 0.00 0.00 0.00 23:19:20 22:00:01 ens3 1.22 1.01 0.28 0.25 0.00 0.00 0.00 0.00 23:19:20 22:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:10:11 lo 19.31 19.31 8.88 8.88 0.00 0.00 0.00 0.00 23:19:20 22:10:11 ens3 1.32 1.15 0.33 0.30 0.00 0.00 0.00 0.00 23:19:20 22:10:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:20:11 lo 19.66 19.66 10.44 10.44 0.00 0.00 0.00 0.00 23:19:20 22:20:11 ens3 0.90 0.67 0.19 0.15 0.00 0.00 0.00 0.00 23:19:20 22:20:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:30:01 lo 22.76 22.76 8.94 8.94 0.00 0.00 0.00 0.00 23:19:20 22:30:01 ens3 0.72 0.68 0.18 0.14 0.00 0.00 0.00 0.00 23:19:20 22:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:40:11 lo 25.83 25.83 11.34 11.34 0.00 0.00 0.00 0.00 23:19:20 22:40:11 ens3 0.74 0.55 0.19 0.14 0.00 0.00 0.00 0.00 23:19:20 22:40:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 22:50:11 lo 16.07 16.07 9.85 9.85 0.00 0.00 0.00 0.00 23:19:20 22:50:11 ens3 0.72 0.65 0.16 0.13 0.00 0.00 0.00 0.00 23:19:20 22:50:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 23:00:01 lo 8.32 8.32 4.08 4.08 0.00 0.00 0.00 0.00 23:19:20 23:00:01 ens3 0.43 0.31 0.09 0.06 0.00 0.00 0.00 0.00 23:19:20 23:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 23:10:11 lo 19.71 19.71 9.69 9.69 0.00 0.00 0.00 0.00 23:19:20 23:10:11 ens3 1.34 1.54 0.33 1.58 0.00 0.00 0.00 0.00 23:19:20 23:10:11 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 Average: lo 16.90 16.90 8.60 8.60 0.00 0.00 0.00 0.00 23:19:20 Average: ens3 16.28 12.05 225.73 1.49 0.00 0.00 0.00 0.00 23:19:20 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:19:20 23:19:20 23:19:20 ---> sar -P ALL: 23:19:20 Linux 5.15.0-164-generic (prd-ubuntu2204-docker-4c-16g-5100) 01/27/26 _x86_64_ (4 CPU) 23:19:20 23:19:20 21:37:32 LINUX RESTART (4 CPU) 23:19:20 23:19:20 21:40:02 CPU %user %nice %system %iowait %steal %idle 23:19:20 21:50:03 all 40.61 0.00 2.56 20.80 0.10 35.94 23:19:20 21:50:03 0 38.58 0.00 2.45 22.72 0.10 36.15 23:19:20 21:50:03 1 45.75 0.00 2.63 21.37 0.10 30.15 23:19:20 21:50:03 2 38.41 0.00 2.54 21.11 0.10 37.84 23:19:20 21:50:03 3 39.68 0.00 2.61 18.00 0.10 39.61 23:19:20 22:00:01 all 24.72 0.00 1.30 1.31 0.11 72.55 23:19:20 22:00:01 0 23.36 0.00 1.35 0.51 0.11 74.68 23:19:20 22:00:01 1 25.00 0.00 1.28 0.42 0.11 73.19 23:19:20 22:00:01 2 25.00 0.00 1.38 1.71 0.11 71.80 23:19:20 22:00:01 3 25.54 0.00 1.21 2.62 0.11 70.53 23:19:20 22:10:11 all 28.17 0.00 1.04 0.78 0.09 69.92 23:19:20 22:10:11 0 28.29 0.00 0.91 0.20 0.09 70.51 23:19:20 22:10:11 1 28.47 0.00 1.02 0.90 0.10 69.51 23:19:20 22:10:11 2 27.39 0.00 1.10 0.29 0.10 71.12 23:19:20 22:10:11 3 28.54 0.00 1.14 1.72 0.10 68.52 23:19:20 22:20:11 all 25.24 0.00 0.83 1.50 0.09 72.34 23:19:20 22:20:11 0 25.22 0.00 0.86 3.13 0.09 70.71 23:19:20 22:20:11 1 25.91 0.00 0.82 0.76 0.09 72.42 23:19:20 22:20:11 2 24.68 0.00 0.83 1.63 0.09 72.77 23:19:20 22:20:11 3 25.14 0.00 0.82 0.47 0.09 73.47 23:19:20 22:30:01 all 8.68 0.00 0.44 0.98 0.06 89.83 23:19:20 22:30:01 0 8.65 0.00 0.43 0.41 0.06 90.45 23:19:20 22:30:01 1 9.13 0.00 0.43 0.59 0.07 89.78 23:19:20 22:30:01 2 8.10 0.00 0.50 2.51 0.07 88.82 23:19:20 22:30:01 3 8.85 0.00 0.40 0.42 0.06 90.27 23:19:20 22:40:11 all 10.41 0.00 0.50 0.56 0.07 88.47 23:19:20 22:40:11 0 10.65 0.00 0.54 0.61 0.07 88.13 23:19:20 22:40:11 1 10.21 0.00 0.49 0.57 0.07 88.65 23:19:20 22:40:11 2 10.36 0.00 0.47 0.49 0.07 88.61 23:19:20 22:40:11 3 10.41 0.00 0.49 0.56 0.07 88.47 23:19:20 22:50:11 all 10.12 0.00 0.59 0.14 0.07 89.07 23:19:20 22:50:11 0 10.32 0.00 0.52 0.08 0.07 89.02 23:19:20 22:50:11 1 10.37 0.00 0.66 0.28 0.07 88.62 23:19:20 22:50:11 2 10.76 0.00 0.66 0.12 0.07 88.38 23:19:20 22:50:11 3 9.05 0.00 0.53 0.09 0.07 90.26 23:19:20 23:00:01 all 7.20 0.00 0.43 0.10 0.06 92.21 23:19:20 23:00:01 0 6.70 0.00 0.35 0.10 0.05 92.80 23:19:20 23:00:01 1 7.26 0.00 0.53 0.11 0.07 92.04 23:19:20 23:00:01 2 7.57 0.00 0.47 0.09 0.06 91.81 23:19:20 23:00:01 3 7.27 0.00 0.38 0.12 0.06 92.18 23:19:20 23:10:11 all 15.08 0.00 0.69 0.78 0.11 83.34 23:19:20 23:10:11 0 14.99 0.00 0.60 0.36 0.11 83.95 23:19:20 23:10:11 1 16.16 0.00 0.92 0.73 0.10 82.09 23:19:20 23:10:11 2 15.00 0.00 0.65 0.83 0.10 83.42 23:19:20 23:10:11 3 14.18 0.00 0.57 1.22 0.13 83.90 23:19:20 Average: all 18.95 0.00 0.93 2.99 0.08 77.04 23:19:20 Average: 0 18.56 0.00 0.89 3.12 0.08 77.35 23:19:20 Average: 1 19.84 0.00 0.98 2.86 0.09 76.24 23:19:20 Average: 2 18.62 0.00 0.96 3.19 0.09 77.15 23:19:20 Average: 3 18.77 0.00 0.91 2.80 0.09 77.43 23:19:20 23:19:20 23:19:20