21:38:13 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/120310 21:38:13 Running as SYSTEM 21:38:13 [EnvInject] - Loading node environment variables. 21:38:13 Building remotely on prd-ubuntu2204-docker-4c-16g-5101 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 21:38:13 [ssh-agent] Looking for ssh-agent implementation... 21:38:13 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 21:38:13 $ ssh-agent 21:38:13 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXQtttxT/agent.1564 21:38:13 SSH_AGENT_PID=1566 21:38:13 [ssh-agent] Started. 21:38:13 Running ssh-add (command line suppressed) 21:38:13 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_12940925880476841299.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_12940925880476841299.key) 21:38:13 [ssh-agent] Using credentials jenkins (jenkins-ssh) 21:38:13 The recommended git tool is: NONE 21:38:16 using credential jenkins-ssh 21:38:16 Wiping out workspace first. 21:38:16 Cloning the remote Git repository 21:38:16 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 21:38:16 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 21:38:16 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 21:38:16 > git --version # timeout=10 21:38:16 > git --version # 'git version 2.34.1' 21:38:16 using GIT_SSH to set credentials jenkins-ssh 21:38:16 Verifying host key using known hosts file 21:38:16 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:16 > 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/10/120310/2 # timeout=10 21:38:37 > git rev-parse 7a7cc6e07326cf9053a3ce89e8e0f80996e28f7b^{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 7a7cc6e07326cf9053a3ce89e8e0f80996e28f7b (refs/changes/10/120310/2) 21:38:37 > git config core.sparsecheckout # timeout=10 21:38:37 > git checkout -f 7a7cc6e07326cf9053a3ce89e8e0f80996e28f7b # timeout=10 21:38:38 Commit message: "TAPI add SpectrumRanges-based spectrum extraction" 21:38:38 > git rev-parse FETCH_HEAD^{commit} # timeout=10 21:38:38 > git rev-list --no-walk 84a516773589de626a8f936f0265872575785573 # 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/jenkins12051339589271781050.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-wFKf 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-wFKf/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-wFKf/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/jenkins5821060335373700976.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-7wcf 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 ++ sed 's/^[ *]* //' 21:39:52 ++ command=versions 21:39:52 ++ awk '{ print $1 }' 21:39:52 ++ grep -E '^[0-9.]*[0-9]$' 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 ++ [[ ! -s /tmp/.pyenv_versions ]] 21:39:52 +++ grep '^3' /tmp/.pyenv_versions 21:39:52 +++ sort -V 21:39:52 +++ tail -n 1 21:39:52 ++ py_version_xyz=3.11.10 21:39:52 ++ [[ -z 3.11.10 ]] 21:39:52 ++ echo 3.11.10 21:39:52 ++ return 0 21:39:52 + pyenv local 3.11.10 21:39:52 + local command 21:39:52 + command=local 21:39:52 + '[' 2 -gt 0 ']' 21:39:52 + shift 21:39:52 + case "$command" in 21:39:52 + command pyenv local 3.11.10 21:39:52 + for arg in "$@" 21:39:52 + case $arg in 21:39:52 + pkg_list+='tox ' 21:39:52 + for arg in "$@" 21:39:52 + case $arg in 21:39:52 + pkg_list+='virtualenv ' 21:39:52 + for arg in "$@" 21:39:52 + case $arg in 21:39:52 + pkg_list+='urllib3~=1.26.15 ' 21:39:52 + [[ -f /tmp/.toxenv ]] 21:39:52 + [[ ! -f /tmp/.toxenv ]] 21:39:52 + [[ -n '' ]] 21:39:52 + python3 -m venv /tmp/venv-7wcf 21:39:57 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-7wcf' 21:39:57 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-7wcf 21:39:57 + echo /tmp/venv-7wcf 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-7wcf/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-7wcf/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-7wcf/bin to PATH' 21:40:03 lf-activate-venv(): INFO: Adding /tmp/venv-7wcf/bin to PATH 21:40:03 + PATH=/tmp/venv-7wcf/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-7wcf/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/jenkins11953169594196090559.sh 21:40:03 [EnvInject] - Injecting environment variables from a build step. 21:40:03 [EnvInject] - Injecting as environment variables the properties content 21:40:03 PARALLEL=True 21:40:03 21:40:03 [EnvInject] - Variables injected successfully. 21:40:04 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins6368985506154936444.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-wH8w 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 ++ awk '{ print $1 }' 21:40:04 ++ local command 21:40:04 ++ grep -E '^[0-9.]*[0-9]$' 21:40:04 ++ command=versions 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 ++ sed 's/^[ *]* //' 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-7wcf 21:40:04 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-7wcf from' file:/tmp/.toxenv 21:40:04 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-7wcf 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-7wcf/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-7wcf/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-7wcf/bin to PATH' 21:40:06 lf-activate-venv(): INFO: Adding /tmp/venv-7wcf/bin to PATH 21:40:06 + PATH=/tmp/venv-7wcf/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-7wcf/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-7wcf/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-7wcf/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 checkbashisms: freeze> python -m pip freeze --all 21:40:08 docs: install_deps> python -I -m pip install -r docs/requirements.txt 21:40:08 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 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 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.16 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 buildcontroller: freeze> python -m pip freeze --all 21:40:15 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 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 + sudo update-java-alternatives -s java-1.21.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 update-alternatives: error: no alternatives for jaotc 21:40:16 update-alternatives: error: no alternatives for rmic 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 + 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:20 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 21:40:20 [INFO] Once installed this environment will be reused. 21:40:20 [INFO] This may take a few minutes... 21:40:52 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 21:40:52 [INFO] Once installed this environment will be reused. 21:40:52 [INFO] This may take a few minutes... 21:41:12 [INFO] Installing environment for https://github.com/perltidy/perltidy. 21:41:12 [INFO] Once installed this environment will be reused. 21:41:12 [INFO] This may take a few minutes... 21:41:19 docs: freeze> python -m pip freeze --all 21:41:20 docs-linkcheck: 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:20 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:20 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:23 docs: OK ✔ in 1 minute 16.64 seconds 21:41:23 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 21:41:26 trim trailing whitespace.................................................Passed 21:41:26 Tabs remover.............................................................Passed 21:41:27 autopep8.................................................................docs-linkcheck: OK ✔ in 1 minute 17.96 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:32 Passed 21:41:32 perltidy.................................................................Passed 21:41:33 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 21:41:33 [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:33 [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:33 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 21:41:33 [INFO] Once installed this environment will be reused. 21:41:33 [INFO] This may take a few minutes... 21:41:42 gitlint..................................................................Passed 21:41:54 21:41:54 ------------------------------------ 21:41:54 Your code has been rated at 10.00/10 21:41:54 21:42:44 pre-commit: OK ✔ in 1 minute 32.33 seconds 21:42:44 pylint: OK ✔ in 32.56 seconds 21:42:44 buildcontroller: OK ✔ in 2 minutes 36.02 seconds 21:42:44 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:44 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:44 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:44 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:43:24 build_karaf_tests121: freeze> python -m pip freeze --all 21:43:25 build_karaf_tests221: freeze> python -m pip freeze --all 21:43:25 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:43:25 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:43:25 build karaf in karaf121 with ./karaf121.env 21:43:25 build_karaf_tests190: freeze> python -m pip freeze --all 21:43:25 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:43:25 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:43:25 build karaf in karaf221 with ./karaf221.env 21:43:25 NOTE: Picked up JDK_JAVA_OPTIONS: 21:43:25 --add-opens=java.base/java.io=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.net=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:43:25 -Xlog:disable 21:43:25 NOTE: Picked up JDK_JAVA_OPTIONS: 21:43:25 --add-opens=java.base/java.io=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.net=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:43:25 -Xlog:disable 21:43:25 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:43:25 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:43:25 build karaf in karafoc with ./karafoc.env 21:43:25 NOTE: Picked up JDK_JAVA_OPTIONS: 21:43:25 --add-opens=java.base/java.io=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.net=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:43:25 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:43:25 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:43:25 -Xlog:disable 21:43:25 build_karaf_tests71: freeze> python -m pip freeze --all 21:43:26 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:43:26 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 21:43:26 build karaf in karaf71 with ./karaf71.env 21:43:27 NOTE: Picked up JDK_JAVA_OPTIONS: 21:43:27 --add-opens=java.base/java.io=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.lang=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.net=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.nio=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.nio.file=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.util=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.util.jar=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.util.stream=ALL-UNNAMED 21:43:27 --add-opens=java.base/java.util.zip=ALL-UNNAMED 21:43:27 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 21:43:27 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 21:43:27 -Xlog:disable 21:44:55 build_karaf_tests121: OK ✔ in 2 minutes 11.23 seconds 21:44:55 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:45:22 build_karaf_tests221: OK ✔ in 2 minutes 38.72 seconds 21:45:22 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:45:29 build_karaf_tests71: OK ✔ in 2 minutes 46.59 seconds 21:45:29 build_karaf_tests190: OK ✔ in 2 minutes 46.61 seconds 21:45:29 testsPCE: install_deps> python -I -m pip install gnpy4tpce==2.4.7 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 21:45:46 buildlighty: freeze> python -m pip freeze --all 21:45:46 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:46 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 21:45:46 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 21:45:49 sims: freeze> python -m pip freeze --all 21:45:49 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:49 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 21:45:49 Using lighynode version 20.1.0.5 21:45:49 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 21:47:25 sims: OK ✔ in 31.78 seconds 21:47:25 buildlighty: OK ✔ in 1 minute 17.6 seconds 21:47:25 testsPCE: freeze> python -m pip freeze --all 21:47:25 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:25 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 21:47:25 pytest -q transportpce_tests/pce/test01_pce.py 21:48:29 FFFFFFFFFFFFFFFFFFFF [100%] 21:48:53 =================================== FAILURES =================================== 21:48:53 ________________ TestTransportPCEPce.test_01_load_port_mapping _________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_01_load_port_mapping(self): 21:48:53 response = test_utils.post_portmapping(self.port_mapping_data) 21:48:53 > self.assertIn(response['status_code'], (requests.codes.created, requests.codes.no_content)) 21:48:53 E AssertionError: 401 not found in (201, 204) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:113: AssertionError 21:48:53 ---------------------------- Captured stdout setup ----------------------------- 21:48:53 sample files content loaded 21:48:53 starting OpenDaylight... 21:48:53 starting KARAF (karaf) TransportPCE build... 21:48:53 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 21:48:53 _____________ TestTransportPCEPce.test_02_load_simple_topology_bi ______________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_02_load_simple_topology_bi(self): 21:48:53 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_bi_dir_data) 21:48:53 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 21:48:53 E AssertionError: 401 not found in (200, 204) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:119: AssertionError 21:48:53 ____________________ TestTransportPCEPce.test_03_get_nodeId ____________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_03_get_nodeId(self): 21:48:53 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'ROADMA01-SRG1', 'config') 21:48:53 > self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 E AssertionError: 401 != 200 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:125: AssertionError 21:48:53 ____________________ TestTransportPCEPce.test_04_get_linkId ____________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_04_get_linkId(self): 21:48:53 > response = test_utils.get_ietf_network_link_request( 21:48:53 'openroadm-topology', 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX', 'config') 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:131: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 network = 'openroadm-topology' 21:48:53 link = 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX' 21:48:53 content = 'config' 21:48:53 21:48:53 def get_ietf_network_link_request(network: str, link: str, content: str): 21:48:53 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 21:48:53 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 21:48:53 if RESTCONF_VERSION in ('rfc8040'): 21:48:53 format_args = ('{}', network, link, content) 21:48:53 elif content == 'config': 21:48:53 format_args = ('{}', content, network, link) 21:48:53 else: 21:48:53 format_args = ('{}', 'operational', network, link) 21:48:53 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': 'ietf-network-topology:link', 21:48:53 'draft-bierman02': 'ietf-network-topology:link'} 21:48:53 > link = res[return_key[RESTCONF_VERSION]][0] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'ietf-network-topology:link' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:602: KeyError 21:48:53 _____________ TestTransportPCEPce.test_05_path_computation_xpdr_bi _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_05_path_computation_xpdr_bi(self): 21:48:53 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:139: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:53 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:53 21:48:53 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:53 # pylint: disable=consider-using-f-string 21:48:53 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:53 if payload is None: 21:48:53 data = None 21:48:53 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:53 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:53 else: 21:48:53 data = {'input': payload} 21:48:53 response = post_request(url, data) 21:48:53 if response.status_code == requests.codes.no_content: 21:48:53 return_output = None 21:48:53 else: 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': api_module + ':output', 21:48:53 'draft-bierman02': 'output'} 21:48:53 if response.status_code == requests.codes.internal_server_error: 21:48:53 return_output = res 21:48:53 else: 21:48:53 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'transportpce-pce:output' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:761: KeyError 21:48:53 _____________ TestTransportPCEPce.test_06_path_computation_rdm_bi ______________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_06_path_computation_rdm_bi(self): 21:48:53 self.path_computation_input_data["service-a-end"]["node-id"] = "ROADMA01" 21:48:53 self.path_computation_input_data["service-z-end"]["node-id"] = "ROADMC01" 21:48:53 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:151: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:53 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:53 21:48:53 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:53 # pylint: disable=consider-using-f-string 21:48:53 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:53 if payload is None: 21:48:53 data = None 21:48:53 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:53 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:53 else: 21:48:53 data = {'input': payload} 21:48:53 response = post_request(url, data) 21:48:53 if response.status_code == requests.codes.no_content: 21:48:53 return_output = None 21:48:53 else: 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': api_module + ':output', 21:48:53 'draft-bierman02': 'output'} 21:48:53 if response.status_code == requests.codes.internal_server_error: 21:48:53 return_output = res 21:48:53 else: 21:48:53 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'transportpce-pce:output' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:761: KeyError 21:48:53 _____________ TestTransportPCEPce.test_07_load_simple_topology_uni _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_07_load_simple_topology_uni(self): 21:48:53 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_uni_dir_data) 21:48:53 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 21:48:53 E AssertionError: 401 not found in (200, 204) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:162: AssertionError 21:48:53 ____________________ TestTransportPCEPce.test_08_get_nodeId ____________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_08_get_nodeId(self): 21:48:53 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-1-2', 'config') 21:48:53 > self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 E AssertionError: 401 != 200 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:168: AssertionError 21:48:53 ____________________ TestTransportPCEPce.test_09_get_linkId ____________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_09_get_linkId(self): 21:48:53 > response = test_utils.get_ietf_network_link_request( 21:48:53 'openroadm-topology', 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX', 'config') 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:174: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 network = 'openroadm-topology' 21:48:53 link = 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX' 21:48:53 content = 'config' 21:48:53 21:48:53 def get_ietf_network_link_request(network: str, link: str, content: str): 21:48:53 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 21:48:53 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 21:48:53 if RESTCONF_VERSION in ('rfc8040'): 21:48:53 format_args = ('{}', network, link, content) 21:48:53 elif content == 'config': 21:48:53 format_args = ('{}', content, network, link) 21:48:53 else: 21:48:53 format_args = ('{}', 'operational', network, link) 21:48:53 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': 'ietf-network-topology:link', 21:48:53 'draft-bierman02': 'ietf-network-topology:link'} 21:48:53 > link = res[return_key[RESTCONF_VERSION]][0] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'ietf-network-topology:link' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:602: KeyError 21:48:53 ____________ TestTransportPCEPce.test_10_path_computation_xpdr_uni _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_10_path_computation_xpdr_uni(self): 21:48:53 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 21:48:53 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 21:48:53 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 21:48:53 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 21:48:53 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:186: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:53 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:53 21:48:53 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:53 # pylint: disable=consider-using-f-string 21:48:53 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:53 if payload is None: 21:48:53 data = None 21:48:53 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:53 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:53 else: 21:48:53 data = {'input': payload} 21:48:53 response = post_request(url, data) 21:48:53 if response.status_code == requests.codes.no_content: 21:48:53 return_output = None 21:48:53 else: 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': api_module + ':output', 21:48:53 'draft-bierman02': 'output'} 21:48:53 if response.status_code == requests.codes.internal_server_error: 21:48:53 return_output = res 21:48:53 else: 21:48:53 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'transportpce-pce:output' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:761: KeyError 21:48:53 _____________ TestTransportPCEPce.test_11_path_computation_rdm_uni _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_11_path_computation_rdm_uni(self): 21:48:53 self.path_computation_input_data["service-a-end"]["node-id"] = "OpenROADM-2-1" 21:48:53 self.path_computation_input_data["service-a-end"]["clli"] = "cll21" 21:48:53 self.path_computation_input_data["service-z-end"]["node-id"] = "OpenROADM-2-2" 21:48:53 self.path_computation_input_data["service-z-end"]["clli"] = "ncli22" 21:48:53 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:200: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:53 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:53 21:48:53 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:53 # pylint: disable=consider-using-f-string 21:48:53 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:53 if payload is None: 21:48:53 data = None 21:48:53 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:53 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:53 else: 21:48:53 data = {'input': payload} 21:48:53 response = post_request(url, data) 21:48:53 if response.status_code == requests.codes.no_content: 21:48:53 return_output = None 21:48:53 else: 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': api_module + ':output', 21:48:53 'draft-bierman02': 'output'} 21:48:53 if response.status_code == requests.codes.internal_server_error: 21:48:53 return_output = res 21:48:53 else: 21:48:53 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'transportpce-pce:output' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:761: KeyError 21:48:53 ______________ TestTransportPCEPce.test_12_load_complex_topology _______________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_12_load_complex_topology(self): 21:48:53 response = test_utils.put_ietf_network('openroadm-topology', self.complex_topo_uni_dir_data) 21:48:53 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 21:48:53 E AssertionError: 401 not found in (200, 204) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:223: AssertionError 21:48:53 ____________________ TestTransportPCEPce.test_13_get_nodeId ____________________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_13_get_nodeId(self): 21:48:53 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-3-2', 'config') 21:48:53 > self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 E AssertionError: 401 != 200 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:229: AssertionError 21:48:53 ______________ TestTransportPCEPce.test_14_fail_path_computation _______________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_14_fail_path_computation(self): 21:48:53 del self.path_computation_input_data["service-name"] 21:48:53 del self.path_computation_input_data["service-a-end"] 21:48:53 del self.path_computation_input_data["service-z-end"] 21:48:53 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:238: 21:48:53 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 21:48:53 21:48:53 api_module = 'transportpce-pce', rpc = 'path-computation-request' 21:48:53 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-handler-header': {'request-id': 'request1'}} 21:48:53 21:48:53 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 21:48:53 # pylint: disable=consider-using-f-string 21:48:53 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 21:48:53 if payload is None: 21:48:53 data = None 21:48:53 elif RESTCONF_VERSION == 'draft-bierman02': 21:48:53 data = prepend_dict_keys({'input': payload}, api_module + ':') 21:48:53 else: 21:48:53 data = {'input': payload} 21:48:53 response = post_request(url, data) 21:48:53 if response.status_code == requests.codes.no_content: 21:48:53 return_output = None 21:48:53 else: 21:48:53 res = response.json() 21:48:53 return_key = {'rfc8040': api_module + ':output', 21:48:53 'draft-bierman02': 'output'} 21:48:53 if response.status_code == requests.codes.internal_server_error: 21:48:53 return_output = res 21:48:53 else: 21:48:53 > return_output = res[return_key[RESTCONF_VERSION]] 21:48:53 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 21:48:53 E KeyError: 'transportpce-pce:output' 21:48:53 21:48:53 transportpce_tests/common/test_utils.py:761: KeyError 21:48:53 ____________ TestTransportPCEPce.test_15_success1_path_computation _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_15_success1_path_computation(self): 21:48:53 self.path_computation_input_data["service-name"] = "service 1" 21:48:53 self.path_computation_input_data["service-a-end"] = {"service-format": "Ethernet", "service-rate": "100", 21:48:53 "clli": "ORANGE2", "node-id": "XPONDER-2-2"} 21:48:53 self.path_computation_input_data["service-z-end"] = {"service-format": "Ethernet", "service-rate": "100", 21:48:53 "clli": "ORANGE1", "node-id": "XPONDER-1-2"} 21:48:53 self.path_computation_input_data["hard-constraints"] = {"customer-code": ["Some customer-code"], 21:48:53 "co-routing": { 21:48:53 "service-identifier-list": [{ 21:48:53 "service-identifier": "Some existing-service"}] 21:48:53 }} 21:48:53 self.path_computation_input_data["soft-constraints"] = {"customer-code": ["Some customer-code"], 21:48:53 "co-routing": { 21:48:53 "service-identifier-list": [{ 21:48:53 "service-identifier": "Some existing-service"}] 21:48:53 }} 21:48:53 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 > self.assertIn('Path is calculated', 21:48:53 response['output']['configuration-response-common']['response-message']) 21:48:53 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:267: AssertionError 21:48:53 ____________ TestTransportPCEPce.test_16_success2_path_computation _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_16_success2_path_computation(self): 21:48:53 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 21:48:53 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 21:48:53 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 21:48:53 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 21:48:53 del self.path_computation_input_data["hard-constraints"] 21:48:53 del self.path_computation_input_data["soft-constraints"] 21:48:53 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 > self.assertIn('Path is calculated', 21:48:53 response['output']['configuration-response-common']['response-message']) 21:48:53 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:284: AssertionError 21:48:53 ____________ TestTransportPCEPce.test_17_success3_path_computation _____________ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_17_success3_path_computation(self): 21:48:53 self.path_computation_input_data["hard-constraints"] = {"exclude": 21:48:53 {"node-id": ["OpenROADM-2-1", "OpenROADM-2-2"]}} 21:48:53 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 > self.assertIn('Path is calculated', 21:48:53 response['output']['configuration-response-common']['response-message']) 21:48:53 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:300: AssertionError 21:48:53 __ TestTransportPCEPce.test_18_path_computation_before_oms_attribute_deletion __ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_18_path_computation_before_oms_attribute_deletion(self): 21:48:53 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-2-2" 21:48:53 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE2" 21:48:53 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-1-2" 21:48:53 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE1" 21:48:53 del self.path_computation_input_data["hard-constraints"] 21:48:53 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 > self.assertIn('Path is calculated', 21:48:53 response['output']['configuration-response-common']['response-message']) 21:48:53 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:319: AssertionError 21:48:53 _ TestTransportPCEPce.test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link _ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link(self): 21:48:53 response = test_utils.del_oms_attr_request("OpenROADM-1-3-DEG2-to-OpenROADM-1-2-DEG2") 21:48:53 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 21:48:53 E AssertionError: 409 not found in (200, 204) 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:337: AssertionError 21:48:53 __ TestTransportPCEPce.test_20_path_computation_after_oms_attribute_deletion ___ 21:48:53 21:48:53 self = 21:48:53 21:48:53 def test_20_path_computation_after_oms_attribute_deletion(self): 21:48:53 response = test_utils.transportpce_api_rpc_request('transportpce-pce', 21:48:53 'path-computation-request', 21:48:53 self.path_computation_input_data) 21:48:53 self.assertEqual(response['status_code'], requests.codes.ok) 21:48:53 > self.assertIn('Path is calculated', 21:48:53 response['output']['configuration-response-common']['response-message']) 21:48:53 E AssertionError: 'Path is calculated' not found in 'No nodes found in network' 21:48:53 21:48:53 transportpce_tests/pce/test01_pce.py:346: AssertionError 21:48:53 --------------------------- Captured stdout teardown --------------------------- 21:48:53 all processes killed 21:48:53 ODL log file stored 21:48:53 =========================== short test summary info ============================ 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_01_load_port_mapping 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_02_load_simple_topology_bi 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_03_get_nodeId 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_04_get_linkId 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_05_path_computation_xpdr_bi 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_06_path_computation_rdm_bi 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_07_load_simple_topology_uni 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_08_get_nodeId 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_09_get_linkId 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_10_path_computation_xpdr_uni 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_11_path_computation_rdm_uni 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_12_load_complex_topology 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_13_get_nodeId 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_14_fail_path_computation 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_15_success1_path_computation 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_16_success2_path_computation 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_17_success3_path_computation 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_18_path_computation_before_oms_attribute_deletion 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link 21:48:53 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_20_path_computation_after_oms_attribute_deletion 21:48:53 20 failed in 87.48s (0:01:27) 21:48:53 testsPCE: exit 1 (87.79 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce pid=5193 21:48:54 testsPCE: FAIL ✖ in 3 minutes 24.07 seconds 21:48:54 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:54 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:54 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:11 tests_tapi: freeze> python -m pip freeze --all 21:49:11 tests190: freeze> python -m pip freeze --all 21:49:11 tests121: freeze> python -m pip freeze --all 21:49:11 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:11 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 21:49:11 using environment variables from ./karaf221.env 21:49:11 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 21:49:11 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:11 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 21:49:11 using environment variables from ./karafoc.env 21:49:11 pytest -q transportpce_tests/oc/test01_portmapping.py 21:49:11 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:11 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 21:49:11 using environment variables from ./karaf121.env 21:49:11 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 21:50:09 FF................................ [100%] 21:51:15 21 passed in 123.70s (0:02:03) 21:51:15 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 21:51:16 ........................................FFFFFFF. [100%] 21:55:06 6 passed in 230.54s (0:03:50) 21:55:06 pytest -q transportpce_tests/1.2.1/test03_topology.py 21:55:49 ..................F. [100%] 21:56:21 =================================== FAILURES =================================== 21:56:21 ___________ TestTransportPCEPortmapping.test_01_meta_data_insertion ____________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_01_meta_data_insertion(self): 21:56:21 response = test_utils_oc.metadata_input() 21:56:21 > self.assertEqual(response.status_code, requests.codes.created, 21:56:21 test_utils.CODE_SHOULD_BE_201) 21:56:21 E AssertionError: 401 != 201 : Http status code should be 201 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:48: AssertionError 21:56:21 ---------------------------- Captured stdout setup ----------------------------- 21:56:21 starting OpenDaylight... 21:56:21 starting KARAF (karafoc) TransportPCE build... 21:56:21 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 21:56:21 starting simulator oc-mpdr in OpenROADM device version oc... 21:56:21 Searching for patterns in sample-openconfig-mpdr.log... Pattern found! simulator for oc-mpdr started 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_01_meta_data_insertion 21:56:21 __________ TestTransportPCEPortmapping.test_02_catlog_input_insertion __________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_02_catlog_input_insertion(self): 21:56:21 response = test_utils_oc.catlog_input() 21:56:21 > self.assertEqual(response.status_code, requests.codes.ok, 21:56:21 test_utils.CODE_SHOULD_BE_200) 21:56:21 E AssertionError: 401 != 200 : Http status code should be 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:53: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_02_catlog_input_insertion 21:56:21 __________ TestTransportPCEPortmapping.test_03_xpdr_device_connection __________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_03_xpdr_device_connection(self): 21:56:21 response = test_utils.mount_device("XPDR-OC", 21:56:21 ('oc-mpdr', self.NODE_VERSION)) 21:56:21 > self.assertEqual(response.status_code, requests.codes.created, 21:56:21 test_utils.CODE_SHOULD_BE_201) 21:56:21 E AssertionError: 401 != 201 : Http status code should be 201 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:59: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_03_xpdr_device_connection 21:56:21 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not added to tpce topology... 21:56:21 __________ TestTransportPCEPortmapping.test_04_xpdr_device_connected ___________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_04_xpdr_device_connected(self): 21:56:21 response = test_utils.check_device_connection("XPDR-OC") 21:56:21 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:64: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_04_xpdr_device_connected 21:56:21 __________ TestTransportPCEPortmapping.test_05_xpdr_portmapping_info ___________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_05_xpdr_portmapping_info(self): 21:56:21 response = test_utils.get_portmapping_node_attr("XPDR-OC", "node-info", None) 21:56:21 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:69: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_05_xpdr_portmapping_info 21:56:21 ________ TestTransportPCEPortmapping.test_06_mpdr_portmapping_NETWORK5 _________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_06_mpdr_portmapping_NETWORK5(self): 21:56:21 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-NETWORK5") 21:56:21 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:82: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_06_mpdr_portmapping_NETWORK5 21:56:21 _________ TestTransportPCEPortmapping.test_07_mpdr_portmapping_CLIENT1 _________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_07_mpdr_portmapping_CLIENT1(self): 21:56:21 response = test_utils.get_portmapping_node_attr("XPDR-OC", "mapping", "XPDR1-CLIENT1") 21:56:21 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:104: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_07_mpdr_portmapping_CLIENT1 21:56:21 ___________ TestTransportPCEPortmapping.test_08_mpdr_switching_pool ____________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_08_mpdr_switching_pool(self): 21:56:21 response = test_utils.get_portmapping_node_attr("XPDR-OC", "switching-pool-lcp", "1") 21:56:21 > self.assertEqual(response['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:130: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_08_mpdr_switching_pool 21:56:21 ____________ TestTransportPCEPortmapping.test_09_check_mccapprofile ____________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_09_check_mccapprofile(self): 21:56:21 res = test_utils.get_portmapping_node_attr("XPDR-OC", "mc-capabilities", "XPDR-mcprofile") 21:56:21 > self.assertEqual(res['status_code'], requests.codes.ok) 21:56:21 E AssertionError: 409 != 200 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:143: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_09_check_mccapprofile 21:56:21 ________ TestTransportPCEPortmapping.test_10_xpdr_device_disconnection _________ 21:56:21 21:56:21 self = 21:56:21 21:56:21 def test_10_xpdr_device_disconnection(self): 21:56:21 response = test_utils.unmount_device("XPDR-OC") 21:56:21 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 21:56:21 E AssertionError: 409 not found in (200, 204) 21:56:21 21:56:21 transportpce_tests/oc/test01_portmapping.py:150: AssertionError 21:56:21 ----------------------------- Captured stdout call ----------------------------- 21:56:21 execution of test_10_xpdr_device_disconnection 21:56:21 Searching for patterns in karaf.log... Pattern not found after 180 seconds! Node XPDR-OC still not deleted from tpce topology... 21:56:21 --------------------------- Captured stdout teardown --------------------------- 21:56:21 all processes killed 21:56:21 ODL log file stored 21:56:21 =========================== short test summary info ============================ 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_01_meta_data_insertion 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_02_catlog_input_insertion 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_03_xpdr_device_connection 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_04_xpdr_device_connected 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_05_xpdr_portmapping_info 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_06_mpdr_portmapping_NETWORK5 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_07_mpdr_portmapping_CLIENT1 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_08_mpdr_switching_pool 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_09_check_mccapprofile 21:56:21 FAILED transportpce_tests/oc/test01_portmapping.py::TestTransportPCEPortmapping::test_10_xpdr_device_disconnection 21:56:21 10 failed in 429.57s (0:07:09) 21:56:21 tests190: exit 1 (429.91 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc pid=6019 21:56:21 tests190: FAIL ✖ in 7 minutes 27.79 seconds 21:56:21 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:22 ...tests71: freeze> python -m pip freeze --all 21:56:28 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:28 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 21:56:28 using environment variables from ./karaf71.env 21:56:28 pytest -q transportpce_tests/7.1/test01_portmapping.py 21:56:28 .................................... [100%] 21:57:16 12 passed in 47.44s 21:57:16 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 21:57:17 [100%] 21:57:17 51 passed in 485.85s (0:08:05) 21:57:17 pytest -q transportpce_tests/tapi/test02_full_topology.py 21:57:18 ... [100%] 21:57:27 44 passed in 139.01s (0:02:19) 21:57:27 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 21:58:08 .................................................................. [100%] 21:59:20 24 passed in 114.45s (0:01:54) 21:59:20 pytest -q transportpce_tests/1.2.1/test05_olm.py 21:59:21 ................................F...F.. [100%] 22:00:21 62 passed in 184.48s (0:03:04) 22:00:21 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 22:00:26 ........F...............F....F....................................................................... [100%] 22:02:46 48 passed in 144.99s (0:02:24) 22:02:46 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 22:02:47 ... [100%] 22:02:52 40 passed in 211.75s (0:03:31) 22:02:52 pytest -q transportpce_tests/1.2.1/test06_end2end.py 22:03:04 . [100%] 22:03:08 =================================== FAILURES =================================== 22:03:08 _ TestTransportPCEFullTopology.test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation _ 22:03:08 22:03:08 self = 22:03:08 22:03:08 def test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation(self): 22:03:08 response = test_utils.get_tapi_topology_node( 22:03:08 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1OTS, "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertEqual(response['status_code'], requests.codes.ok) 22:03:08 input_dict_1 = {"spectrum-capability-pac": {"occupied-spectrum": [{"upper-frequency": "196125000000000", 22:03:08 "lower-frequency": "196075000000000"}], 22:03:08 "supportable-spectrum": [{"upper-frequency": "196125000000000", 22:03:08 "lower-frequency": "191325000000000"}]} 22:03:08 } 22:03:08 22:03:08 self.assertDictEqual(dict(input_dict_1, 22:03:08 **response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']), 22:03:08 response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'eNodeEdgePoint') 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+PHOTONIC_MEDIA_OTS+XPDR1-NETWORK1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:03:08 ['client-node-edge-point'][0]['node-edge-point-uuid'], 'f32f5e9e-d167-31ba-a9e4-8f1efdb8786d') 22:03:08 self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:03:08 ['parent-node-edge-point']['node-edge-point-uuid'], '21efd6a4-2d81-3cdb-aabb-b983fb61904e') 22:03:08 22:03:08 response = test_utils.get_tapi_topology_node( 22:03:08 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1OTSi, "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertDictEqual(dict(input_dict_1, 22:03:08 **response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']), 22:03:08 response['onep'][0]['tapi-photonic-media:photonic-media-node-edge-point-spec']) 22:03:08 self.assertEqual(response['status_code'], requests.codes.ok) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'PhotMedNodeEdgePoint') 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+OTSi_MEDIA_CHANNEL+XPDR1-NETWORK1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:03:08 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:03:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:03:08 ['client-node-edge-point'][0]['node-edge-point-uuid'], '7d2a0549-63e3-3c7f-b4dc-5653e8a81dbe') 22:03:08 E KeyError: 'tapi-connectivity:cep-list' 22:03:08 22:03:08 transportpce_tests/tapi/test02_full_topology.py:428: KeyError 22:03:08 _ TestTransportPCEFullTopology.test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation _ 22:03:08 22:03:08 self = 22:03:08 22:03:08 def test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation(self): 22:03:08 response = test_utils.get_tapi_topology_node( 22:03:08 test_utils.T0_FULL_MULTILAYER_TOPO_UUID, self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1iODU, "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'iNodeEdgePoint_N') 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+iODU+XPDR1-NETWORK1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '100.0') 22:03:08 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '100.0') 22:03:08 22:03:08 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:03:08 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:03:08 "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value-name'], 'eNodeEdgePoint_N') 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '10.0') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '10.0') 22:03:08 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '10.0') 22:03:08 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:03:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:03:08 ['parent-node-edge-point']['node-edge-point-uuid'], '72c6b97a-3944-3d88-9882-b7e688bb2772') 22:03:08 E KeyError: 'tapi-connectivity:cep-list' 22:03:08 22:03:08 transportpce_tests/tapi/test02_full_topology.py:478: KeyError 22:03:08 _ TestTransportPCEFullTopology.test_20_get_tapi_node_details_at_ODU_Service_creation _ 22:03:08 22:03:08 self = 22:03:08 22:03:08 def test_20_get_tapi_node_details_at_ODU_Service_creation(self): 22:03:08 # ODU service creation correspond to the creation of HO-ODU between 2 Network ports and is associated an 22:03:08 # iODU4 top connection which uses 100% of underlying OTU4 22:03:08 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:03:08 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:03:08 "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['available-payload-structure'][0]['capacity']['value'], '10.0') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['number-of-cep-instances'], '1') 22:03:08 self.assertEqual(response['onep'][0]['supported-payload-structure'][0]['capacity']['value'], '10.0') 22:03:08 self.assertEqual(response['onep'][0]['available-capacity']['total-size']['value'], '10.0') 22:03:08 > self.assertEqual(response['onep'][0]['tapi-connectivity:cep-list']['connection-end-point'][0] 22:03:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 22:03:08 ['client-node-edge-point'][0]['node-edge-point-uuid'], 'c6cd334c-51a1-3995-bed3-5cf2b7445c04') 22:03:08 E KeyError: 'tapi-connectivity:cep-list' 22:03:08 22:03:08 transportpce_tests/tapi/test02_full_topology.py:545: KeyError 22:03:08 _ TestTransportPCEFullTopology.test_23_get_tapi_node_details_at_DSR_Service_creation _ 22:03:08 22:03:08 self = 22:03:08 22:03:08 def test_23_get_tapi_node_details_at_DSR_Service_creation(self): 22:03:08 22:03:08 response = test_utils.get_tapi_topology_node(test_utils.T0_FULL_MULTILAYER_TOPO_UUID, 22:03:08 self.uuidSpdrSA1xpdr1, self.uuidOnepSpdrSA1xpdr1eODUC1, 22:03:08 "nonconfig") 22:03:08 time.sleep(2) 22:03:08 self.assertEqual(response['onep'][0]['name'][0]['value'], 'SPDR-SA1-XPDR1+eODU+XPDR1-CLIENT1') 22:03:08 self.assertEqual(response['onep'][0]['administrative-state'], 'UNLOCKED') 22:03:08 self.assertEqual(response['onep'][0]['operational-state'], 'ENABLED') 22:03:08 > self.assertEqual(response['onep'][0]['available-payload-structure'][0]['number-of-cep-instances'], '0') 22:03:08 E AssertionError: '1' != '0' 22:03:08 E - 1 22:03:08 E + 0 22:03:08 22:03:08 transportpce_tests/tapi/test02_full_topology.py:663: AssertionError 22:03:08 ______ TestTransportPCEFullTopology.test_25_get_connectivity_service_list ______ 22:03:08 22:03:08 self = 22:03:08 22:03:08 def test_25_get_connectivity_service_list(self): 22:03:08 response = test_utils.transportpce_api_rpc_request( 22:03:08 'tapi-connectivity', 'get-connectivity-service-list', None) 22:03:08 self.assertEqual(response['status_code'], requests.codes.ok) 22:03:08 liste_service = response['output']['service'] 22:03:08 for ele in liste_service: 22:03:08 if ele['uuid'] == self.uuid_services.pm: 22:03:08 self.assertEqual(ele['operational-state'], 'ENABLED') 22:03:08 # self.assertEqual(ele['service-layer'], 'PHOTONIC_MEDIA') 22:03:08 self.assertEqual(ele['layer-protocol-name'], 'PHOTONIC_MEDIA') 22:03:08 nbconnection = len(ele['connection']) 22:03:08 self.assertEqual(nbconnection, 4, 'There should be 4 connections') 22:03:08 elif ele['uuid'] == self.uuid_services.odu: 22:03:08 > self.assertEqual(ele['operational-state'], 'ENABLED') 22:03:08 E AssertionError: 'DISABLED' != 'ENABLED' 22:03:08 E - DISABLED 22:03:08 E + ENABLED 22:03:08 22:03:08 transportpce_tests/tapi/test02_full_topology.py:714: AssertionError 22:03:08 =========================== short test summary info ============================ 22:03:08 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_18a_get_tapi_Pht_node_details_at_Pht_Service_creation 22:03:08 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_18b_get_tapi_OTN_node_details_at_Pht_Service_creation 22:03:08 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_20_get_tapi_node_details_at_ODU_Service_creation 22:03:08 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_23_get_tapi_node_details_at_DSR_Service_creation 22:03:08 FAILED transportpce_tests/tapi/test02_full_topology.py::TestTransportPCEFullTopology::test_25_get_connectivity_service_list 22:03:08 5 failed, 31 passed in 350.72s (0:05:50) 22:03:08 tests_tapi: exit 1 (837.45 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=6008 22:03:09 tests_tapi: FAIL ✖ in 14 minutes 15.2 seconds 22:03:09 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:03:22 tests221: freeze> python -m pip freeze --all 22:03:22 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:03:22 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 22:03:23 using environment variables from ./karaf221.env 22:03:23 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 22:03:25 ................................ [100%] 22:04:15 22 passed in 88.74s (0:01:28) 22:04:24 .............................................. [100%] 22:05:04 35 passed in 100.62s (0:01:40) 22:05:04 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 22:05:08 .............. [100%] 22:05:51 6 passed in 46.88s 22:05:51 pytest -q transportpce_tests/2.2.1/test03_topology.py 22:05:57 ............................................................... [100%] 22:08:10 44 passed in 138.80s (0:02:18) 22:08:10 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 22:08:47 ............ [100%] 22:09:11 12 passed in 60.49s (0:01:00) 22:09:11 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 22:09:37 ................. [100%] 22:11:06 16 passed in 114.99s (0:01:54) 22:11:06 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 22:11:40 .................................. [100%] 22:12:16 54 passed in 563.43s (0:09:23) 22:14:44 .. [100%] 22:14:47 31 passed in 220.43s (0:03:40) 22:14:47 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 22:15:24 .......................... [100%] 22:16:20 26 passed in 92.77s (0:01:32) 22:16:20 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 22:17:02 ...................... [100%] 22:18:06 22 passed in 105.60s (0:01:45) 22:18:06 pytest -q transportpce_tests/2.2.1/test09_olm.py 22:18:49 ........................................ [100%] 22:21:12 40 passed in 186.13s (0:03:06) 22:21:12 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 22:21:59 ........................................................................ [ 74%] 22:27:37 ......................... [100%] 22:32:29 97 passed in 676.46s (0:11:16) 22:32:29 pytest -q transportpce_tests/2.2.1/test12_end2end.py 22:33:12 ...................................................... [100%] 22:39:59 54 passed in 449.83s (0:07:29) 22:39:59 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 22:40:57 ........................................................................ [ 71%] 22:46:07 ............................. [100%] 22:48:16 101 passed in 496.43s (0:08:16) 22:48:16 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 22:49:13 ........................................................................ [ 67%] 22:55:00 ................................... [100%] 22:58:21 107 passed in 604.22s (0:10:04) 22:58:21 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 22:59:07 ............................................. [100%] 23:04:44 45 passed in 383.23s (0:06:23) 23:04:44 tests71: OK ✔ in 7 minutes 54.85 seconds 23:04:44 tests121: OK ✔ in 23 minutes 22.99 seconds 23:04:44 tests221: OK ✔ in 1 hour 1 minute 35.91 seconds 23:04:44 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:04:53 tests_hybrid: freeze> python -m pip freeze --all 23:04:53 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:04:53 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 23:04:53 using environment variables from ./karaf221.env 23:04:53 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 23:05:37 ................................................... [100%] 23:13:25 51 passed in 511.34s (0:08:31) 23:13:25 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 23:14:12 ........................................................................ [ 66%] 23:18:34 ..................................... [100%] 23:20:40 109 passed in 435.09s (0:07:15) 23:20:40 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 23:21:31 ..................................................... [100%] 23:25:03 53 passed in 263.09s (0:04:23) 23:25:03 buildcontroller: OK (156.02=setup[8.92]+cmd[147.09] seconds) 23:25:03 sims: OK (31.78=setup[28.13]+cmd[3.65] seconds) 23:25:03 build_karaf_tests121: OK (131.23=setup[42.35]+cmd[88.88] seconds) 23:25:03 testsPCE: FAIL code 1 (204.07=setup[116.28]+cmd[87.79] seconds) 23:25:03 tests121: OK (1402.99=setup[17.96]+cmd[1385.03] seconds) 23:25:03 build_karaf_tests221: OK (158.72=setup[42.57]+cmd[116.15] seconds) 23:25:03 tests_tapi: FAIL code 1 (855.20=setup[17.75]+cmd[837.45] seconds) 23:25:03 tests221: OK (3695.91=setup[14.17]+cmd[3681.74] seconds) 23:25:03 build_karaf_tests71: OK (166.59=setup[43.65]+cmd[122.94] seconds) 23:25:03 tests71: OK (474.85=setup[7.29]+cmd[467.56] seconds) 23:25:03 build_karaf_tests190: OK (166.61=setup[42.70]+cmd[123.92] seconds) 23:25:03 tests190: FAIL code 1 (447.79=setup[17.88]+cmd[429.91] seconds) 23:25:03 tests_hybrid: OK (1219.26=setup[8.68]+cmd[1210.58] seconds) 23:25:03 buildlighty: OK (77.60=setup[52.65]+cmd[24.95] seconds) 23:25:03 docs: OK (76.64=setup[73.63]+cmd[3.00] seconds) 23:25:03 docs-linkcheck: OK (77.96=setup[74.10]+cmd[3.86] seconds) 23:25:03 checkbashisms: OK (3.16=setup[1.91]+cmd[0.01,0.05,1.18] seconds) 23:25:03 pre-commit: OK (92.33=setup[3.47]+cmd[0.00,0.00,79.92,8.93] seconds) 23:25:03 pylint: OK (32.56=setup[6.69]+cmd[25.86] seconds) 23:25:03 evaluation failed :( (6297.13 seconds) 23:25:04 + tox_status=255 23:25:04 + echo '---> Completed tox runs' 23:25:04 ---> Completed tox runs 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/build_karaf_tests121/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=build_karaf_tests121 23:25:04 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/build_karaf_tests190/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=build_karaf_tests190 23:25:04 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/build_karaf_tests221/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=build_karaf_tests221 23:25:04 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/build_karaf_tests71/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=build_karaf_tests71 23:25:04 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/buildcontroller/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=buildcontroller 23:25:04 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/buildlighty/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=buildlighty 23:25:04 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/checkbashisms/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=checkbashisms 23:25:04 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/docs-linkcheck/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=docs-linkcheck 23:25:04 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/docs/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=docs 23:25:04 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/pre-commit/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=pre-commit 23:25:04 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/pylint/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=pylint 23:25:04 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/sims/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=sims 23:25:04 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/tests121/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=tests121 23:25:04 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/tests190/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=tests190 23:25:04 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 23:25:04 + for i in .tox/*/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 ++ echo .tox/tests221/log 23:25:04 + tox_env=tests221 23:25:04 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/tests71/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=tests71 23:25:04 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/testsPCE/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=testsPCE 23:25:04 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/tests_hybrid/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=tests_hybrid 23:25:04 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 23:25:04 + for i in .tox/*/log 23:25:04 ++ echo .tox/tests_tapi/log 23:25:04 ++ awk -F/ '{print $2}' 23:25:04 + tox_env=tests_tapi 23:25:04 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 23:25:04 + DOC_DIR=docs/_build/html 23:25:04 + [[ -d docs/_build/html ]] 23:25:04 + echo '---> Archiving generated docs' 23:25:04 ---> Archiving generated docs 23:25:04 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 23:25:04 + echo '---> tox-run.sh ends' 23:25:04 ---> tox-run.sh ends 23:25:04 + test 255 -eq 0 23:25:04 + exit 255 23:25:04 ++ '[' 1 = 1 ']' 23:25:04 ++ '[' -x /usr/bin/clear_console ']' 23:25:04 ++ /usr/bin/clear_console -q 23:25:04 Build step 'Execute shell' marked build as failure 23:25:04 $ ssh-agent -k 23:25:04 unset SSH_AUTH_SOCK; 23:25:04 unset SSH_AGENT_PID; 23:25:04 echo Agent pid 1566 killed; 23:25:04 [ssh-agent] Stopped. 23:25:04 [PostBuildScript] - [INFO] Executing post build scripts. 23:25:04 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13520895715046069339.sh 23:25:04 ---> sysstat.sh 23:25:05 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13988840669438233804.sh 23:25:05 ---> package-listing.sh 23:25:05 ++ facter osfamily 23:25:05 ++ tr '[:upper:]' '[:lower:]' 23:25:05 + OS_FAMILY=debian 23:25:05 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 23:25:05 + START_PACKAGES=/tmp/packages_start.txt 23:25:05 + END_PACKAGES=/tmp/packages_end.txt 23:25:05 + DIFF_PACKAGES=/tmp/packages_diff.txt 23:25:05 + PACKAGES=/tmp/packages_start.txt 23:25:05 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 23:25:05 + PACKAGES=/tmp/packages_end.txt 23:25:05 + case "${OS_FAMILY}" in 23:25:05 + dpkg -l 23:25:05 + grep '^ii' 23:25:05 + '[' -f /tmp/packages_start.txt ']' 23:25:05 + '[' -f /tmp/packages_end.txt ']' 23:25:05 + diff /tmp/packages_start.txt /tmp/packages_end.txt 23:25:05 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 23:25:05 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 23:25:05 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 23:25:05 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins18281087688722572587.sh 23:25:05 ---> capture-instance-metadata.sh 23:25:05 Setup pyenv: 23:25:05 system 23:25:05 3.8.20 23:25:05 3.9.20 23:25:05 3.10.15 23:25:05 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:25:05 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wFKf from file:/tmp/.os_lf_venv 23:25:05 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:25:05 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:25:08 lf-activate-venv(): INFO: Base packages installed successfully 23:25:08 lf-activate-venv(): INFO: Installing additional packages: lftools 23:25:24 lf-activate-venv(): INFO: Adding /tmp/venv-wFKf/bin to PATH 23:25:24 INFO: Running in OpenStack, capturing instance metadata 23:25:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8653148407296869501.sh 23:25:24 provisioning config files... 23:25:25 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #4247 23:25:25 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config15075099939717485584tmp 23:25:25 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 23:25:25 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 23:25:25 provisioning config files... 23:25:25 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 23:25:25 [EnvInject] - Injecting environment variables from a build step. 23:25:25 [EnvInject] - Injecting as environment variables the properties content 23:25:25 SERVER_ID=logs 23:25:25 23:25:25 [EnvInject] - Variables injected successfully. 23:25:25 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5860480370524788369.sh 23:25:25 ---> create-netrc.sh 23:25:25 WARN: Log server credential not found. 23:25:25 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16387548320094355304.sh 23:25:25 ---> python-tools-install.sh 23:25:25 Setup pyenv: 23:25:25 system 23:25:25 3.8.20 23:25:25 3.9.20 23:25:25 3.10.15 23:25:25 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:25:25 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wFKf from file:/tmp/.os_lf_venv 23:25:25 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:25:25 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:25:27 lf-activate-venv(): INFO: Base packages installed successfully 23:25:27 lf-activate-venv(): INFO: Installing additional packages: lftools 23:25:40 lf-activate-venv(): INFO: Adding /tmp/venv-wFKf/bin to PATH 23:25:40 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12698696271393988552.sh 23:25:40 ---> sudo-logs.sh 23:25:40 Archiving 'sudo' log.. 23:25:41 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17322619579021824858.sh 23:25:41 ---> job-cost.sh 23:25:41 Setup pyenv: 23:25:41 system 23:25:41 3.8.20 23:25:41 3.9.20 23:25:41 3.10.15 23:25:41 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:25:41 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wFKf from file:/tmp/.os_lf_venv 23:25:41 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:25:41 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:25:44 lf-activate-venv(): INFO: Base packages installed successfully 23:25:44 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 23:25:51 lf-activate-venv(): INFO: Adding /tmp/venv-wFKf/bin to PATH 23:25:51 INFO: No Stack... 23:25:51 INFO: Retrieving Pricing Info for: v3-standard-4 23:25:52 INFO: Archiving Costs 23:25:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins11915357600856641761.sh 23:25:52 ---> logs-deploy.sh 23:25:52 Setup pyenv: 23:25:52 system 23:25:52 3.8.20 23:25:52 3.9.20 23:25:52 3.10.15 23:25:52 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 23:25:52 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wFKf from file:/tmp/.os_lf_venv 23:25:52 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 23:25:52 lf-activate-venv(): INFO: Attempting to install with network-safe options... 23:25:54 lf-activate-venv(): INFO: Base packages installed successfully 23:25:54 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 23:26:06 lf-activate-venv(): INFO: Adding /tmp/venv-wFKf/bin to PATH 23:26:06 WARNING: Nexus logging server not set 23:26:06 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/4247/ 23:26:06 INFO: archiving logs to S3 23:26:10 ---> uname -a: 23:26:10 Linux prd-ubuntu2204-docker-4c-16g-5101 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:26:10 23:26:10 23:26:10 ---> lscpu: 23:26:10 Architecture: x86_64 23:26:10 CPU op-mode(s): 32-bit, 64-bit 23:26:10 Address sizes: 40 bits physical, 48 bits virtual 23:26:10 Byte Order: Little Endian 23:26:10 CPU(s): 4 23:26:10 On-line CPU(s) list: 0-3 23:26:10 Vendor ID: AuthenticAMD 23:26:10 Model name: AMD EPYC-Rome Processor 23:26:10 CPU family: 23 23:26:10 Model: 49 23:26:10 Thread(s) per core: 1 23:26:10 Core(s) per socket: 1 23:26:10 Socket(s): 4 23:26:10 Stepping: 0 23:26:10 BogoMIPS: 5600.00 23:26:10 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:26:10 Virtualization: AMD-V 23:26:10 Hypervisor vendor: KVM 23:26:10 Virtualization type: full 23:26:10 L1d cache: 128 KiB (4 instances) 23:26:10 L1i cache: 128 KiB (4 instances) 23:26:10 L2 cache: 2 MiB (4 instances) 23:26:10 L3 cache: 64 MiB (4 instances) 23:26:10 NUMA node(s): 1 23:26:10 NUMA node0 CPU(s): 0-3 23:26:10 Vulnerability Gather data sampling: Not affected 23:26:10 Vulnerability Indirect target selection: Not affected 23:26:10 Vulnerability Itlb multihit: Not affected 23:26:10 Vulnerability L1tf: Not affected 23:26:10 Vulnerability Mds: Not affected 23:26:10 Vulnerability Meltdown: Not affected 23:26:10 Vulnerability Mmio stale data: Not affected 23:26:10 Vulnerability Reg file data sampling: Not affected 23:26:10 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 23:26:10 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 23:26:10 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 23:26:10 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 23:26:10 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 23:26:10 Vulnerability Srbds: Not affected 23:26:10 Vulnerability Tsa: Not affected 23:26:10 Vulnerability Tsx async abort: Not affected 23:26:10 Vulnerability Vmscape: Not affected 23:26:10 23:26:10 23:26:10 ---> nproc: 23:26:10 4 23:26:10 23:26:10 23:26:10 ---> df -h: 23:26:10 Filesystem Size Used Avail Use% Mounted on 23:26:10 tmpfs 1.6G 1.1M 1.6G 1% /run 23:26:10 /dev/vda1 78G 18G 61G 23% / 23:26:10 tmpfs 7.9G 0 7.9G 0% /dev/shm 23:26:10 tmpfs 5.0M 0 5.0M 0% /run/lock 23:26:10 /dev/vda15 105M 6.1M 99M 6% /boot/efi 23:26:10 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 23:26:10 23:26:10 23:26:10 ---> free -m: 23:26:10 total used free shared buff/cache available 23:26:10 Mem: 15989 707 10871 3 4409 14939 23:26:10 Swap: 1023 1 1022 23:26:10 23:26:10 23:26:10 ---> ip addr: 23:26:10 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 23:26:10 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 23:26:10 inet 127.0.0.1/8 scope host lo 23:26:10 valid_lft forever preferred_lft forever 23:26:10 inet6 ::1/128 scope host 23:26:10 valid_lft forever preferred_lft forever 23:26:10 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 23:26:10 link/ether fa:16:3e:f0:66:4c brd ff:ff:ff:ff:ff:ff 23:26:10 altname enp0s3 23:26:10 inet 10.30.170.145/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 23:26:10 valid_lft 79881sec preferred_lft 79881sec 23:26:10 inet6 fe80::f816:3eff:fef0:664c/64 scope link 23:26:10 valid_lft forever preferred_lft forever 23:26:10 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 23:26:10 link/ether da:75:24:3c:7c:63 brd ff:ff:ff:ff:ff:ff 23:26:10 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 23:26:10 valid_lft forever preferred_lft forever 23:26:10 23:26:10 23:26:10 ---> sar -b -r -n DEV: 23:26:10 Linux 5.15.0-164-generic (prd-ubuntu2204-docker-4c-16g-5101) 01/27/26 _x86_64_ (4 CPU) 23:26:10 23:26:10 21:37:34 LINUX RESTART (4 CPU) 23:26:10 23:26:10 21:40:06 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 23:26:10 21:50:02 122.79 16.31 85.52 20.95 910.81 37536.06 254964.29 23:26:10 22:00:01 55.41 24.35 29.16 1.90 370.83 2853.23 1578.30 23:26:10 22:10:21 22.38 0.21 21.12 1.06 7.67 768.17 1550.62 23:26:10 22:20:21 10.97 0.02 10.52 0.43 0.61 283.55 416.67 23:26:10 22:30:01 4.57 0.04 4.42 0.11 2.03 102.84 53.62 23:26:10 22:40:00 4.83 0.01 4.71 0.12 0.59 115.94 53.37 23:26:10 22:50:21 7.60 0.03 7.28 0.30 2.20 205.66 134.59 23:26:10 23:00:01 5.64 0.01 5.46 0.17 0.77 146.25 403.41 23:26:10 23:10:21 6.92 0.07 6.62 0.23 1.98 399.36 59.45 23:26:10 23:20:21 3.99 0.00 3.90 0.09 0.33 120.85 48.27 23:26:10 Average: 24.46 4.08 17.85 2.52 128.90 4222.98 25709.41 23:26:10 23:26:10 21:40:06 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 23:26:10 21:50:02 551484 12130208 3787892 23.13 259636 11047464 4657456 26.73 2262176 12708300 318292 23:26:10 22:00:01 3132496 6656200 9274756 56.65 259888 3221620 11226064 64.44 2124416 10505404 472 23:26:10 22:10:21 6051472 9693436 6237968 38.10 266584 3329396 6924696 39.75 2205424 7501960 124 23:26:10 22:20:21 7775136 11448576 4485284 27.39 268272 3359196 5216288 29.94 2209848 5788084 360 23:26:10 22:30:01 7646428 11329336 4604400 28.12 268960 3367980 5296972 30.40 2211368 5914988 248 23:26:10 22:40:00 11606052 15311148 624336 3.81 269376 3389756 1329476 7.63 2213400 1953320 10620 23:26:10 22:50:21 6272932 9993412 5939916 36.28 270452 3404056 6643076 38.13 2217776 7260980 144 23:26:10 23:00:01 7834276 11571868 4362128 26.64 271336 3420260 5087680 29.20 2220280 5717164 508 23:26:10 23:10:21 7472224 11306368 4627232 28.26 274596 3508572 5299360 30.42 2227368 6067532 144 23:26:10 23:20:21 7425288 11276928 4656532 28.44 274968 3525636 5292564 30.38 2235492 6108688 408 23:26:10 Average: 6576779 11071748 4860044 29.68 268407 4157394 5697363 32.70 2212755 6952642 33132 23:26:10 23:26:10 21:40:06 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 23:26:10 21:50:02 lo 1.94 1.94 1.48 1.48 0.00 0.00 0.00 0.00 23:26:10 21:50:02 ens3 133.15 100.47 2063.21 10.46 0.00 0.00 0.00 0.00 23:26:10 21:50:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:00:01 lo 24.65 24.65 15.59 15.59 0.00 0.00 0.00 0.00 23:26:10 22:00:01 ens3 1.53 1.38 0.34 0.31 0.00 0.00 0.00 0.00 23:26:10 22:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:10:21 lo 41.83 41.83 16.90 16.90 0.00 0.00 0.00 0.00 23:26:10 22:10:21 ens3 1.66 1.68 0.40 0.38 0.00 0.00 0.00 0.00 23:26:10 22:10:21 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:20:21 lo 17.51 17.51 7.96 7.96 0.00 0.00 0.00 0.00 23:26:10 22:20:21 ens3 0.78 0.59 0.17 0.13 0.00 0.00 0.00 0.00 23:26:10 22:20:21 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:30:01 lo 16.09 16.09 8.23 8.23 0.00 0.00 0.00 0.00 23:26:10 22:30:01 ens3 0.72 0.63 0.18 0.14 0.00 0.00 0.00 0.00 23:26:10 22:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:40:00 lo 24.46 24.46 8.22 8.22 0.00 0.00 0.00 0.00 23:26:10 22:40:00 ens3 0.60 0.37 0.16 0.11 0.00 0.00 0.00 0.00 23:26:10 22:40:00 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 22:50:21 lo 19.23 19.23 10.75 10.75 0.00 0.00 0.00 0.00 23:26:10 22:50:21 ens3 0.79 0.59 0.17 0.13 0.00 0.00 0.00 0.00 23:26:10 22:50:21 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 23:00:01 lo 17.62 17.62 10.14 10.14 0.00 0.00 0.00 0.00 23:26:10 23:00:01 ens3 0.77 0.72 0.14 1.34 0.00 0.00 0.00 0.00 23:26:10 23:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 23:10:21 lo 8.41 8.41 4.53 4.53 0.00 0.00 0.00 0.00 23:26:10 23:10:21 ens3 0.70 0.63 0.24 0.19 0.00 0.00 0.00 0.00 23:26:10 23:10:21 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 23:20:21 lo 16.46 16.46 6.79 6.79 0.00 0.00 0.00 0.00 23:26:10 23:20:21 ens3 0.61 0.57 0.13 0.10 0.00 0.00 0.00 0.00 23:26:10 23:20:21 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 Average: lo 18.88 18.88 9.08 9.08 0.00 0.00 0.00 0.00 23:26:10 Average: ens3 14.02 10.68 204.74 1.32 0.00 0.00 0.00 0.00 23:26:10 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 23:26:10 23:26:10 23:26:10 ---> sar -P ALL: 23:26:10 Linux 5.15.0-164-generic (prd-ubuntu2204-docker-4c-16g-5101) 01/27/26 _x86_64_ (4 CPU) 23:26:10 23:26:10 21:37:34 LINUX RESTART (4 CPU) 23:26:10 23:26:10 21:40:06 CPU %user %nice %system %iowait %steal %idle 23:26:10 21:50:02 all 39.84 0.11 2.59 24.22 0.10 33.14 23:26:10 21:50:02 0 37.74 0.13 2.32 28.64 0.09 31.08 23:26:10 21:50:02 1 37.68 0.03 2.37 23.82 0.10 35.98 23:26:10 21:50:02 2 42.91 0.11 3.01 20.99 0.10 32.89 23:26:10 21:50:02 3 41.04 0.15 2.66 23.44 0.10 32.60 23:26:10 22:00:01 all 39.32 0.00 1.78 2.54 0.11 56.25 23:26:10 22:00:01 0 38.98 0.00 1.80 3.57 0.11 55.54 23:26:10 22:00:01 1 38.43 0.00 1.77 3.09 0.11 56.61 23:26:10 22:00:01 2 40.71 0.00 1.73 0.53 0.11 56.92 23:26:10 22:00:01 3 39.16 0.00 1.81 2.98 0.10 55.94 23:26:10 22:10:21 all 38.97 0.00 1.54 0.77 0.11 58.60 23:26:10 22:10:21 0 39.26 0.00 1.53 0.98 0.11 58.13 23:26:10 22:10:21 1 39.65 0.00 1.60 0.61 0.12 58.03 23:26:10 22:10:21 2 39.30 0.00 1.64 0.63 0.12 58.32 23:26:10 22:10:21 3 37.67 0.00 1.41 0.88 0.11 59.93 23:26:10 22:20:21 all 19.79 0.00 0.85 1.45 0.09 77.82 23:26:10 22:20:21 0 19.68 0.00 0.88 1.74 0.08 77.62 23:26:10 22:20:21 1 20.29 0.00 0.89 1.12 0.09 77.61 23:26:10 22:20:21 2 19.68 0.00 0.70 0.56 0.10 78.96 23:26:10 22:20:21 3 19.50 0.00 0.94 2.40 0.09 77.07 23:26:10 22:30:01 all 8.42 0.00 0.43 0.85 0.06 90.23 23:26:10 22:30:01 0 8.59 0.00 0.45 1.80 0.06 89.10 23:26:10 22:30:01 1 8.78 0.00 0.44 0.88 0.07 89.83 23:26:10 22:30:01 2 8.38 0.00 0.46 0.41 0.06 90.68 23:26:10 22:30:01 3 7.94 0.00 0.38 0.30 0.06 91.32 23:26:10 22:40:00 all 8.22 0.00 0.41 0.52 0.06 90.78 23:26:10 22:40:00 0 7.98 0.00 0.44 0.65 0.07 90.85 23:26:10 22:40:00 1 8.42 0.00 0.39 0.76 0.07 90.36 23:26:10 22:40:00 2 8.17 0.00 0.42 0.52 0.07 90.82 23:26:10 22:40:00 3 8.32 0.00 0.39 0.13 0.06 91.10 23:26:10 22:50:21 all 16.76 0.00 0.72 0.20 0.08 82.24 23:26:10 22:50:21 0 16.82 0.00 0.68 0.13 0.08 82.29 23:26:10 22:50:21 1 16.64 0.00 0.69 0.17 0.08 82.41 23:26:10 22:50:21 2 16.73 0.00 0.74 0.40 0.08 82.05 23:26:10 22:50:21 3 16.86 0.00 0.75 0.08 0.08 82.23 23:26:10 23:00:01 all 8.99 0.00 0.39 0.16 0.07 90.39 23:26:10 23:00:01 0 8.41 0.00 0.40 0.10 0.07 91.02 23:26:10 23:00:01 1 8.82 0.00 0.38 0.05 0.07 90.67 23:26:10 23:00:01 2 9.48 0.00 0.41 0.46 0.07 89.58 23:26:10 23:00:01 3 9.25 0.00 0.37 0.02 0.07 90.28 23:26:10 23:10:21 all 7.69 0.00 0.45 0.52 0.09 91.25 23:26:10 23:10:21 0 7.67 0.00 0.42 0.15 0.09 91.68 23:26:10 23:10:21 1 7.14 0.00 0.52 1.17 0.08 91.08 23:26:10 23:10:21 2 7.25 0.00 0.47 0.46 0.09 91.73 23:26:10 23:10:21 3 8.70 0.00 0.40 0.31 0.08 90.51 23:26:10 23:20:21 all 8.59 0.00 0.55 0.35 0.06 90.44 23:26:10 23:20:21 0 8.27 0.00 0.56 0.10 0.06 91.00 23:26:10 23:20:21 1 8.49 0.00 0.53 0.14 0.06 90.78 23:26:10 23:20:21 2 8.72 0.00 0.55 0.34 0.07 90.33 23:26:10 23:20:21 3 8.88 0.00 0.55 0.83 0.06 89.67 23:26:10 Average: all 19.73 0.01 0.97 3.14 0.08 76.07 23:26:10 Average: 0 19.42 0.01 0.95 3.76 0.08 75.78 23:26:10 Average: 1 19.50 0.00 0.96 3.16 0.08 76.29 23:26:10 Average: 2 20.20 0.01 1.01 2.51 0.09 76.18 23:26:10 Average: 3 19.80 0.02 0.97 3.12 0.08 76.03 23:26:10 23:26:10 23:26:10