13:17:47 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/117038 13:17:47 Running as SYSTEM 13:17:47 [EnvInject] - Loading node environment variables. 13:17:47 Building remotely on prd-ubuntu2204-docker-4c-16g-49184 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 13:17:48 [ssh-agent] Looking for ssh-agent implementation... 13:17:48 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 13:17:48 $ ssh-agent 13:17:48 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXnxYeXZ/agent.1574 13:17:48 SSH_AGENT_PID=1576 13:17:48 [ssh-agent] Started. 13:17:48 Running ssh-add (command line suppressed) 13:17:48 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_11123230688589987635.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_11123230688589987635.key) 13:17:48 [ssh-agent] Using credentials jenkins (jenkins-ssh) 13:17:48 The recommended git tool is: NONE 13:17:50 using credential jenkins-ssh 13:17:50 Wiping out workspace first. 13:17:50 Cloning the remote Git repository 13:17:50 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 13:17:50 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 13:17:50 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:17:50 > git --version # timeout=10 13:17:50 > git --version # 'git version 2.34.1' 13:17:50 using GIT_SSH to set credentials jenkins-ssh 13:17:50 Verifying host key using known hosts file 13:17:51 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. 13:17:51 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 13:17:54 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:17:54 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 13:17:55 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 13:17:55 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 13:17:55 using GIT_SSH to set credentials jenkins-ssh 13:17:55 Verifying host key using known hosts file 13:17:55 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. 13:17:55 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/38/117038/15 # timeout=10 13:17:56 > git rev-parse 80dd4bbf9186475e03225825693839a565c33245^{commit} # timeout=10 13:17:56 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 13:17:56 Checking out Revision 80dd4bbf9186475e03225825693839a565c33245 (refs/changes/38/117038/15) 13:17:56 > git config core.sparsecheckout # timeout=10 13:17:56 > git checkout -f 80dd4bbf9186475e03225825693839a565c33245 # timeout=10 13:17:56 Commit message: "Add wavelength duplication to TPCE portmapping" 13:17:56 > git rev-parse FETCH_HEAD^{commit} # timeout=10 13:17:56 > git rev-list --no-walk edf26e334e77188a63de8806063485e8ca7c800e # timeout=10 13:17:56 > git remote # timeout=10 13:17:56 > git submodule init # timeout=10 13:17:56 > git submodule sync # timeout=10 13:17:56 > git config --get remote.origin.url # timeout=10 13:17:56 > git submodule init # timeout=10 13:17:56 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 13:17:56 ERROR: No submodules found. 13:17:59 provisioning config files... 13:17:59 copy managed file [npmrc] to file:/home/jenkins/.npmrc 13:17:59 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 13:17:59 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13415504976005144568.sh 13:17:59 ---> python-tools-install.sh 13:17:59 Setup pyenv: 13:18:00 * system (set by /opt/pyenv/version) 13:18:00 * 3.8.20 (set by /opt/pyenv/version) 13:18:00 * 3.9.20 (set by /opt/pyenv/version) 13:18:00 * 3.10.15 (set by /opt/pyenv/version) 13:18:00 * 3.11.10 (set by /opt/pyenv/version) 13:18:05 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-BJis 13:18:05 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 13:18:09 lf-activate-venv(): INFO: Installing: lftools 13:18:35 lf-activate-venv(): INFO: Adding /tmp/venv-BJis/bin to PATH 13:18:35 Generating Requirements File 13:19:02 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. 13:19:02 httplib2 0.30.0 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 13:19:02 Python 3.11.10 13:19:02 pip 25.2 from /tmp/venv-BJis/lib/python3.11/site-packages/pip (python 3.11) 13:19:03 appdirs==1.4.4 13:19:03 argcomplete==3.6.2 13:19:03 aspy.yaml==1.3.0 13:19:03 attrs==25.3.0 13:19:03 autopage==0.5.2 13:19:03 beautifulsoup4==4.13.5 13:19:03 boto3==1.40.24 13:19:03 botocore==1.40.24 13:19:03 bs4==0.0.2 13:19:03 cachetools==5.5.2 13:19:03 certifi==2025.8.3 13:19:03 cffi==1.17.1 13:19:03 cfgv==3.4.0 13:19:03 chardet==5.2.0 13:19:03 charset-normalizer==3.4.3 13:19:03 click==8.2.1 13:19:03 cliff==4.11.0 13:19:03 cmd2==2.7.0 13:19:03 cryptography==3.3.2 13:19:03 debtcollector==3.0.0 13:19:03 decorator==5.2.1 13:19:03 defusedxml==0.7.1 13:19:03 Deprecated==1.2.18 13:19:03 distlib==0.4.0 13:19:03 dnspython==2.7.0 13:19:03 docker==7.1.0 13:19:03 dogpile.cache==1.4.0 13:19:03 durationpy==0.10 13:19:03 email-validator==2.3.0 13:19:03 filelock==3.19.1 13:19:03 future==1.0.0 13:19:03 gitdb==4.0.12 13:19:03 GitPython==3.1.45 13:19:03 google-auth==2.40.3 13:19:03 httplib2==0.30.0 13:19:03 identify==2.6.13 13:19:03 idna==3.10 13:19:03 importlib-resources==1.5.0 13:19:03 iso8601==2.1.0 13:19:03 Jinja2==3.1.6 13:19:03 jmespath==1.0.1 13:19:03 jsonpatch==1.33 13:19:03 jsonpointer==3.0.0 13:19:03 jsonschema==4.25.1 13:19:03 jsonschema-specifications==2025.4.1 13:19:03 keystoneauth1==5.12.0 13:19:03 kubernetes==33.1.0 13:19:03 lftools==0.37.13 13:19:03 lxml==6.0.1 13:19:03 markdown-it-py==4.0.0 13:19:03 MarkupSafe==3.0.2 13:19:03 mdurl==0.1.2 13:19:03 msgpack==1.1.1 13:19:03 multi_key_dict==2.0.3 13:19:03 munch==4.0.0 13:19:03 netaddr==1.3.0 13:19:03 niet==1.4.2 13:19:03 nodeenv==1.9.1 13:19:03 oauth2client==4.1.3 13:19:03 oauthlib==3.3.1 13:19:03 openstacksdk==4.7.0 13:19:03 os-service-types==1.8.0 13:19:03 osc-lib==4.2.0 13:19:03 oslo.config==10.0.0 13:19:03 oslo.context==6.1.0 13:19:03 oslo.i18n==6.6.0 13:19:03 oslo.log==7.2.1 13:19:03 oslo.serialization==5.8.0 13:19:03 oslo.utils==9.1.0 13:19:03 packaging==25.0 13:19:03 pbr==7.0.1 13:19:03 platformdirs==4.4.0 13:19:03 prettytable==3.16.0 13:19:03 psutil==7.0.0 13:19:03 pyasn1==0.6.1 13:19:03 pyasn1_modules==0.4.2 13:19:03 pycparser==2.22 13:19:03 pygerrit2==2.0.15 13:19:03 PyGithub==2.8.1 13:19:03 Pygments==2.19.2 13:19:03 PyJWT==2.10.1 13:19:03 PyNaCl==1.5.0 13:19:03 pyparsing==2.4.7 13:19:03 pyperclip==1.9.0 13:19:03 pyrsistent==0.20.0 13:19:03 python-cinderclient==9.8.0 13:19:03 python-dateutil==2.9.0.post0 13:19:03 python-heatclient==4.3.0 13:19:03 python-jenkins==1.8.3 13:19:03 python-keystoneclient==5.7.0 13:19:03 python-magnumclient==4.9.0 13:19:03 python-openstackclient==8.2.0 13:19:03 python-swiftclient==4.8.0 13:19:03 PyYAML==6.0.2 13:19:03 referencing==0.36.2 13:19:03 requests==2.32.5 13:19:03 requests-oauthlib==2.0.0 13:19:03 requestsexceptions==1.4.0 13:19:03 rfc3986==2.0.0 13:19:03 rich==14.1.0 13:19:03 rich-argparse==1.7.1 13:19:03 rpds-py==0.27.1 13:19:03 rsa==4.9.1 13:19:03 ruamel.yaml==0.18.15 13:19:03 ruamel.yaml.clib==0.2.12 13:19:03 s3transfer==0.13.1 13:19:03 simplejson==3.20.1 13:19:03 six==1.17.0 13:19:03 smmap==5.0.2 13:19:03 soupsieve==2.8 13:19:03 stevedore==5.5.0 13:19:03 tabulate==0.9.0 13:19:03 toml==0.10.2 13:19:03 tomlkit==0.13.3 13:19:03 tqdm==4.67.1 13:19:03 typing_extensions==4.15.0 13:19:03 tzdata==2025.2 13:19:03 urllib3==1.26.20 13:19:03 virtualenv==20.34.0 13:19:03 wcwidth==0.2.13 13:19:03 websocket-client==1.8.0 13:19:03 wrapt==1.17.3 13:19:03 xdg==6.0.0 13:19:03 xmltodict==0.15.0 13:19:03 yq==3.4.3 13:19:03 [EnvInject] - Injecting environment variables from a build step. 13:19:03 [EnvInject] - Injecting as environment variables the properties content 13:19:03 PYTHON=python3 13:19:03 13:19:03 [EnvInject] - Variables injected successfully. 13:19:03 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins9508174632016556701.sh 13:19:03 ---> tox-install.sh 13:19:03 + source /home/jenkins/lf-env.sh 13:19:03 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:19:03 ++ mktemp -d /tmp/venv-XXXX 13:19:03 + lf_venv=/tmp/venv-Z44T 13:19:03 + local venv_file=/tmp/.os_lf_venv 13:19:03 + local python=python3 13:19:03 + local options 13:19:03 + local set_path=true 13:19:03 + local install_args= 13:19:03 ++ 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 13:19:03 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:19:03 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:19:03 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:19:03 + true 13:19:03 + case $1 in 13:19:03 + venv_file=/tmp/.toxenv 13:19:03 + shift 2 13:19:03 + true 13:19:03 + case $1 in 13:19:03 + shift 13:19:03 + break 13:19:03 + case $python in 13:19:03 + local pkg_list= 13:19:03 + [[ -d /opt/pyenv ]] 13:19:03 + echo 'Setup pyenv:' 13:19:03 Setup pyenv: 13:19:03 + export PYENV_ROOT=/opt/pyenv 13:19:03 + PYENV_ROOT=/opt/pyenv 13:19:03 + 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 13:19:03 + 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 13:19:03 + pyenv versions 13:19:03 system 13:19:03 3.8.20 13:19:03 3.9.20 13:19:03 3.10.15 13:19:03 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:19:03 + command -v pyenv 13:19:03 ++ pyenv init - --no-rehash 13:19:03 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:19:03 for i in ${!paths[@]}; do 13:19:03 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:19:03 fi; done; 13:19:03 echo "${paths[*]}"'\'')" 13:19:03 export PATH="/opt/pyenv/shims:${PATH}" 13:19:03 export PYENV_SHELL=bash 13:19:03 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:19:03 pyenv() { 13:19:03 local command 13:19:03 command="${1:-}" 13:19:03 if [ "$#" -gt 0 ]; then 13:19:03 shift 13:19:03 fi 13:19:03 13:19:03 case "$command" in 13:19:03 rehash|shell) 13:19:03 eval "$(pyenv "sh-$command" "$@")" 13:19:03 ;; 13:19:03 *) 13:19:03 command pyenv "$command" "$@" 13:19:03 ;; 13:19:03 esac 13:19:03 }' 13:19:03 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:19:03 for i in ${!paths[@]}; do 13:19:03 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:19:03 fi; done; 13:19:03 echo "${paths[*]}"' 13:19:03 ++ 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 13:19:03 ++ 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 13:19:03 ++ 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 13:19:03 ++ export PYENV_SHELL=bash 13:19:03 ++ PYENV_SHELL=bash 13:19:03 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:19:03 +++ complete -F _pyenv pyenv 13:19:03 ++ lf-pyver python3 13:19:03 ++ local py_version_xy=python3 13:19:03 ++ local py_version_xyz= 13:19:03 ++ pyenv versions 13:19:03 ++ sed 's/^[ *]* //' 13:19:03 ++ local command 13:19:03 ++ command=versions 13:19:03 ++ '[' 1 -gt 0 ']' 13:19:03 ++ shift 13:19:03 ++ case "$command" in 13:19:03 ++ command pyenv versions 13:19:03 ++ awk '{ print $1 }' 13:19:03 ++ grep -E '^[0-9.]*[0-9]$' 13:19:03 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:19:03 +++ grep '^3' /tmp/.pyenv_versions 13:19:03 +++ sort -V 13:19:03 +++ tail -n 1 13:19:03 ++ py_version_xyz=3.11.10 13:19:03 ++ [[ -z 3.11.10 ]] 13:19:03 ++ echo 3.11.10 13:19:03 ++ return 0 13:19:03 + pyenv local 3.11.10 13:19:03 + local command 13:19:03 + command=local 13:19:03 + '[' 2 -gt 0 ']' 13:19:03 + shift 13:19:03 + case "$command" in 13:19:03 + command pyenv local 3.11.10 13:19:03 + for arg in "$@" 13:19:03 + case $arg in 13:19:03 + pkg_list+='tox ' 13:19:03 + for arg in "$@" 13:19:03 + case $arg in 13:19:03 + pkg_list+='virtualenv ' 13:19:03 + for arg in "$@" 13:19:03 + case $arg in 13:19:03 + pkg_list+='urllib3~=1.26.15 ' 13:19:03 + [[ -f /tmp/.toxenv ]] 13:19:03 + [[ ! -f /tmp/.toxenv ]] 13:19:03 + [[ -n '' ]] 13:19:03 + python3 -m venv /tmp/venv-Z44T 13:19:07 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-Z44T' 13:19:07 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-Z44T 13:19:07 + echo /tmp/venv-Z44T 13:19:07 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 13:19:07 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 13:19:07 + /tmp/venv-Z44T/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 13:19:12 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:19:12 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 13:19:12 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 13:19:12 + /tmp/venv-Z44T/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 13:19:14 + type python3 13:19:14 + true 13:19:14 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-Z44T/bin to PATH' 13:19:14 lf-activate-venv(): INFO: Adding /tmp/venv-Z44T/bin to PATH 13:19:14 + PATH=/tmp/venv-Z44T/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 13:19:14 + return 0 13:19:14 + python3 --version 13:19:14 Python 3.11.10 13:19:14 + python3 -m pip --version 13:19:14 pip 25.2 from /tmp/venv-Z44T/lib/python3.11/site-packages/pip (python 3.11) 13:19:14 + python3 -m pip freeze 13:19:14 cachetools==6.2.0 13:19:14 chardet==5.2.0 13:19:14 colorama==0.4.6 13:19:14 distlib==0.4.0 13:19:14 filelock==3.19.1 13:19:14 packaging==25.0 13:19:14 platformdirs==4.4.0 13:19:14 pluggy==1.6.0 13:19:14 pyproject-api==1.9.1 13:19:14 tox==4.30.2 13:19:14 urllib3==1.26.20 13:19:14 virtualenv==20.34.0 13:19:14 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins1020021200102034588.sh 13:19:14 [EnvInject] - Injecting environment variables from a build step. 13:19:14 [EnvInject] - Injecting as environment variables the properties content 13:19:14 PARALLEL=True 13:19:14 13:19:14 [EnvInject] - Variables injected successfully. 13:19:14 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins6208029460893524849.sh 13:19:14 ---> tox-run.sh 13:19:14 + 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 13:19:14 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:19:14 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:19:14 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 13:19:14 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 13:19:14 + source /home/jenkins/lf-env.sh 13:19:14 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 13:19:14 ++ mktemp -d /tmp/venv-XXXX 13:19:14 + lf_venv=/tmp/venv-pqrW 13:19:14 + local venv_file=/tmp/.os_lf_venv 13:19:14 + local python=python3 13:19:14 + local options 13:19:14 + local set_path=true 13:19:14 + local install_args= 13:19:14 ++ 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 13:19:14 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:19:14 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 13:19:14 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 13:19:14 + true 13:19:14 + case $1 in 13:19:14 + venv_file=/tmp/.toxenv 13:19:14 + shift 2 13:19:14 + true 13:19:14 + case $1 in 13:19:14 + shift 13:19:14 + break 13:19:14 + case $python in 13:19:14 + local pkg_list= 13:19:14 + [[ -d /opt/pyenv ]] 13:19:14 + echo 'Setup pyenv:' 13:19:14 Setup pyenv: 13:19:14 + export PYENV_ROOT=/opt/pyenv 13:19:14 + PYENV_ROOT=/opt/pyenv 13:19:14 + 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 13:19:14 + 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 13:19:14 + pyenv versions 13:19:15 system 13:19:15 3.8.20 13:19:15 3.9.20 13:19:15 3.10.15 13:19:15 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:19:15 + command -v pyenv 13:19:15 ++ pyenv init - --no-rehash 13:19:15 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 13:19:15 for i in ${!paths[@]}; do 13:19:15 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 13:19:15 fi; done; 13:19:15 echo "${paths[*]}"'\'')" 13:19:15 export PATH="/opt/pyenv/shims:${PATH}" 13:19:15 export PYENV_SHELL=bash 13:19:15 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 13:19:15 pyenv() { 13:19:15 local command 13:19:15 command="${1:-}" 13:19:15 if [ "$#" -gt 0 ]; then 13:19:15 shift 13:19:15 fi 13:19:15 13:19:15 case "$command" in 13:19:15 rehash|shell) 13:19:15 eval "$(pyenv "sh-$command" "$@")" 13:19:15 ;; 13:19:15 *) 13:19:15 command pyenv "$command" "$@" 13:19:15 ;; 13:19:15 esac 13:19:15 }' 13:19:15 +++ bash --norc -ec 'IFS=:; paths=($PATH); 13:19:15 for i in ${!paths[@]}; do 13:19:15 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 13:19:15 fi; done; 13:19:15 echo "${paths[*]}"' 13:19:15 ++ 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 13:19:15 ++ 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 13:19:15 ++ 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 13:19:15 ++ export PYENV_SHELL=bash 13:19:15 ++ PYENV_SHELL=bash 13:19:15 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 13:19:15 +++ complete -F _pyenv pyenv 13:19:15 ++ lf-pyver python3 13:19:15 ++ local py_version_xy=python3 13:19:15 ++ local py_version_xyz= 13:19:15 ++ pyenv versions 13:19:15 ++ local command 13:19:15 ++ command=versions 13:19:15 ++ '[' 1 -gt 0 ']' 13:19:15 ++ shift 13:19:15 ++ case "$command" in 13:19:15 ++ command pyenv versions 13:19:15 ++ sed 's/^[ *]* //' 13:19:15 ++ awk '{ print $1 }' 13:19:15 ++ grep -E '^[0-9.]*[0-9]$' 13:19:15 ++ [[ ! -s /tmp/.pyenv_versions ]] 13:19:15 +++ grep '^3' /tmp/.pyenv_versions 13:19:15 +++ sort -V 13:19:15 +++ tail -n 1 13:19:15 ++ py_version_xyz=3.11.10 13:19:15 ++ [[ -z 3.11.10 ]] 13:19:15 ++ echo 3.11.10 13:19:15 ++ return 0 13:19:15 + pyenv local 3.11.10 13:19:15 + local command 13:19:15 + command=local 13:19:15 + '[' 2 -gt 0 ']' 13:19:15 + shift 13:19:15 + case "$command" in 13:19:15 + command pyenv local 3.11.10 13:19:15 + for arg in "$@" 13:19:15 + case $arg in 13:19:15 + pkg_list+='tox ' 13:19:15 + for arg in "$@" 13:19:15 + case $arg in 13:19:15 + pkg_list+='virtualenv ' 13:19:15 + for arg in "$@" 13:19:15 + case $arg in 13:19:15 + pkg_list+='urllib3~=1.26.15 ' 13:19:15 + [[ -f /tmp/.toxenv ]] 13:19:15 ++ cat /tmp/.toxenv 13:19:15 + lf_venv=/tmp/venv-Z44T 13:19:15 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-Z44T from' file:/tmp/.toxenv 13:19:15 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-Z44T from file:/tmp/.toxenv 13:19:15 + /tmp/venv-Z44T/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 13:19:16 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 13:19:16 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 13:19:16 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 13:19:16 + /tmp/venv-Z44T/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 13:19:18 + type python3 13:19:18 + true 13:19:18 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-Z44T/bin to PATH' 13:19:18 lf-activate-venv(): INFO: Adding /tmp/venv-Z44T/bin to PATH 13:19:18 + PATH=/tmp/venv-Z44T/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 13:19:18 + return 0 13:19:18 + [[ -d /opt/pyenv ]] 13:19:18 + echo '---> Setting up pyenv' 13:19:18 ---> Setting up pyenv 13:19:18 + export PYENV_ROOT=/opt/pyenv 13:19:18 + PYENV_ROOT=/opt/pyenv 13:19:18 + export PATH=/opt/pyenv/bin:/tmp/venv-Z44T/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 13:19:18 + PATH=/opt/pyenv/bin:/tmp/venv-Z44T/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 13:19:18 ++ pwd 13:19:18 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 13:19:18 + export PYTHONPATH 13:19:18 + export TOX_TESTENV_PASSENV=PYTHONPATH 13:19:18 + TOX_TESTENV_PASSENV=PYTHONPATH 13:19:18 + tox --version 13:19:18 4.30.2 from /tmp/venv-Z44T/lib/python3.11/site-packages/tox/__init__.py 13:19:18 + PARALLEL=True 13:19:18 + TOX_OPTIONS_LIST= 13:19:18 + [[ -n '' ]] 13:19:18 + case ${PARALLEL,,} in 13:19:18 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 13:19:18 + tox --parallel auto --parallel-live 13:19:18 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 13:19:19 docs: install_deps> python -I -m pip install -r docs/requirements.txt 13:19:19 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 13:19:19 checkbashisms: freeze> python -m pip freeze --all 13:19:19 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 13:19:20 checkbashisms: pip==25.2,setuptools==80.9.0 13:19:20 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:19:20 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)' 13:19:20 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 13:19:22 checkbashisms: OK ✔ in 3.34 seconds 13:19:22 pre-commit: install_deps> python -I -m pip install pre-commit 13:19:24 pre-commit: freeze> python -m pip freeze --all 13:19:24 pre-commit: cfgv==3.4.0,distlib==0.4.0,filelock==3.19.1,identify==2.6.13,nodeenv==1.9.1,pip==25.2,platformdirs==4.4.0,pre_commit==4.3.0,PyYAML==6.0.2,setuptools==80.9.0,virtualenv==20.34.0 13:19:24 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 13:19:24 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)' 13:19:24 /usr/bin/cpan 13:19:24 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 13:19:25 [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. 13:19:25 [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. 13:19:25 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 13:19:25 [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. 13:19:25 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 13:19:25 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 13:19:26 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:19:26 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 13:19:27 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 13:19:27 buildcontroller: freeze> python -m pip freeze --all 13:19:27 buildcontroller: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:19:27 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 13:19:27 + update-java-alternatives -l 13:19:27 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 13:19:27 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 13:19:27 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 13:19:27 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 13:19:27 update-alternatives: error: no alternatives for jaotc 13:19:27 update-alternatives: error: no alternatives for rmic 13:19:27 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 13:19:27 [INFO] Once installed this environment will be reused. 13:19:27 [INFO] This may take a few minutes... 13:19:27 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 13:19:27 + java -version 13:19:28 + JAVA_VER=21 13:19:28 + echo 21 13:19:28 21 13:19:28 + javac -version 13:19:28 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 13:19:28 + JAVAC_VER=21 13:19:28 + echo 21 13:19:28 21 13:19:28 ok, java is 21 or newer 13:19:28 + [ 21 -ge 21 ] 13:19:28 + [ 21 -ge 21 ] 13:19:28 + echo ok, java is 21 or newer 13:19:28 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz -P /tmp 13:19:29 2025-09-05 13:19:29 URL:https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz [9160848/9160848] -> "/tmp/apache-maven-3.9.11-bin.tar.gz" [1] 13:19:29 + sudo mkdir -p /opt 13:19:29 + sudo tar xf /tmp/apache-maven-3.9.11-bin.tar.gz -C /opt 13:19:29 + sudo ln -s /opt/apache-maven-3.9.11 /opt/maven 13:19:29 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 13:19:29 + mvn --version 13:19:30 Apache Maven 3.9.11 (3e54c93a704957b63ee3494413a2b544fd3d825b) 13:19:30 Maven home: /opt/maven 13:19:30 Java version: 21.0.5, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 13:19:30 Default locale: en, platform encoding: UTF-8 13:19:30 OS name: "linux", version: "5.15.0-131-generic", arch: "amd64", family: "unix" 13:19:30 NOTE: Picked up JDK_JAVA_OPTIONS: 13:19:30 --add-opens=java.base/java.io=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.lang=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.net=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.nio=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.util=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:19:30 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:19:30 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:19:30 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:19:30 -Xlog:disable 13:19:32 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 13:19:32 [INFO] Once installed this environment will be reused. 13:19:32 [INFO] This may take a few minutes... 13:19:41 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 13:19:41 [INFO] Once installed this environment will be reused. 13:19:41 [INFO] This may take a few minutes... 13:19:47 [INFO] Installing environment for https://github.com/perltidy/perltidy. 13:19:47 [INFO] Once installed this environment will be reused. 13:19:47 [INFO] This may take a few minutes... 13:19:48 docs: freeze> python -m pip freeze --all 13:19:48 docs: alabaster==1.0.0,attrs==25.3.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.8.3,charset-normalizer==3.4.3,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.59.2,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.10.6,numpy==2.3.2,nwdiag==3.0.0,packaging==25.0,pillow==11.3.0,pip==25.2,Pygments==2.19.2,pyparsing==3.2.3,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.5,requests-file==1.5.1,roman-numerals-py==3.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-rtd-theme==3.0.2,sphinx-tabs==3.4.7,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.5.0,webcolors==24.11.1 13:19:48 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 13:19:49 docs-linkcheck: freeze> python -m pip freeze --all 13:19:49 docs-linkcheck: alabaster==1.0.0,attrs==25.3.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.8.3,charset-normalizer==3.4.3,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.59.2,funcparserlib==2.0.0a0,future==1.0.0,idna==3.10,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.10.6,numpy==2.3.2,nwdiag==3.0.0,packaging==25.0,pillow==11.3.0,pip==25.2,Pygments==2.19.2,pyparsing==3.2.3,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.2,requests==2.32.5,requests-file==1.5.1,roman-numerals-py==3.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-rtd-theme==3.0.2,sphinx-tabs==3.4.7,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.5.0,webcolors==24.11.1 13:19:49 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 13:19:51 docs: OK ✔ in 32.4 seconds 13:19:51 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 13:19:55 docs-linkcheck: OK ✔ in 35.27 seconds 13:19:55 pylint: freeze> python -m pip freeze --all 13:19:55 pylint: astroid==3.3.11,dill==0.4.0,isort==6.0.1,mccabe==0.7.0,pip==25.2,platformdirs==4.4.0,pylint==3.3.8,setuptools==80.9.0,tomlkit==0.13.3 13:19:55 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}$' '{}' + 13:19:57 trim trailing whitespace.................................................Passed 13:19:57 Tabs remover.............................................................Passed 13:19:57 autopep8.................................................................Passed 13:20:04 perltidy.................................................................Passed 13:20:05 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 13:20:05 [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. 13:20:05 [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. 13:20:05 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 13:20:05 [INFO] Once installed this environment will be reused. 13:20:05 [INFO] This may take a few minutes... 13:20:14 gitlint..................................................................Passed 13:20:20 13:20:20 ------------------------------------ 13:20:20 Your code has been rated at 10.00/10 13:20:20 13:21:24 pre-commit: OK ✔ in 52.4 seconds 13:21:24 pylint: OK ✔ in 31.17 seconds 13:21:24 buildcontroller: OK ✔ in 2 minutes 4.61 seconds 13:21:24 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 13:21:24 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 13:21:24 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 13:21:24 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 13:21:31 build_karaf_tests121: freeze> python -m pip freeze --all 13:21:31 build_karaf_tests221: freeze> python -m pip freeze --all 13:21:32 build_karaf_tests71: freeze> python -m pip freeze --all 13:21:32 build_karaf_tests190: freeze> python -m pip freeze --all 13:21:32 build_karaf_tests221: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:21:32 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:21:32 build karaf in karaf221 with ./karaf221.env 13:21:32 build_karaf_tests121: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:21:32 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:21:32 build karaf in karaf121 with ./karaf121.env 13:21:32 build_karaf_tests71: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:21:32 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:21:32 build_karaf_tests190: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:21:32 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 13:21:32 build karaf in karafoc with ./karafoc.env 13:21:32 build karaf in karaf71 with ./karaf71.env 13:21:32 NOTE: Picked up JDK_JAVA_OPTIONS: 13:21:32 --add-opens=java.base/java.io=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.net=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:21:32 -Xlog:disable 13:21:32 NOTE: Picked up JDK_JAVA_OPTIONS: 13:21:32 --add-opens=java.base/java.io=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.net=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:21:32 -Xlog:disable 13:21:32 NOTE: Picked up JDK_JAVA_OPTIONS: 13:21:32 --add-opens=java.base/java.io=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.net=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:21:32 -Xlog:disable 13:21:32 NOTE: Picked up JDK_JAVA_OPTIONS: 13:21:32 --add-opens=java.base/java.io=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.net=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.nio.file=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.jar=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.stream=ALL-UNNAMED 13:21:32 --add-opens=java.base/java.util.zip=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 13:21:32 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 13:21:32 -Xlog:disable 13:22:38 build_karaf_tests221: OK ✔ in 1 minute 14.06 seconds 13:22:38 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 13:22:43 build_karaf_tests121: OK ✔ in 1 minute 19.24 seconds 13:22:43 build_karaf_tests71: OK ✔ in 1 minute 19.28 seconds 13:22:43 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 13:22:44 build_karaf_tests190: OK ✔ in 1 minute 20.99 seconds 13:22:44 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 13:22:51 buildlighty: freeze> python -m pip freeze --all 13:22:51 buildlighty: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:22:51 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 13:22:51 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 13:22:51 sims: freeze> python -m pip freeze --all 13:22:51 sims: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:22:51 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 13:22:51 Using lighynode version 20.1.0.5 13:22:51 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 13:23:38 sims: OK ✔ in 13.63 seconds 13:23:38 buildlighty: OK ✔ in 42.39 seconds 13:23:38 testsPCE: freeze> python -m pip freeze --all 13:23:38 testsPCE: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,click==8.2.1,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.7,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.59.2,gnpy4tpce==2.4.7,idna==3.10,iniconfig==2.1.0,injector==0.22.0,invoke==2.2.0,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.4.9,lxml==6.0.1,MarkupSafe==3.0.2,matplotlib==3.10.6,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==25.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==11.3.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pyparsing==3.2.3,pytest==8.4.2,python-dateutil==2.9.0.post0,pytz==2025.2,requests==2.32.5,scipy==1.16.1,setuptools==50.3.2,six==1.17.0,urllib3==2.5.0,Werkzeug==2.0.3,xlrd==1.2.0 13:23:38 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 13:23:38 pytest -q transportpce_tests/pce/test01_pce.py 13:25:43 FFFFFFFFFFFFFFFFFFFF [100%] 13:26:10 =================================== FAILURES =================================== 13:26:10 ________________ TestTransportPCEPce.test_01_load_port_mapping _________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_01_load_port_mapping(self): 13:26:10 response = test_utils.post_portmapping(self.port_mapping_data) 13:26:10 > self.assertIn(response['status_code'], (requests.codes.created, requests.codes.no_content)) 13:26:10 E AssertionError: 401 not found in (201, 204) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:113: AssertionError 13:26:10 ---------------------------- Captured stdout setup ----------------------------- 13:26:10 sample files content loaded 13:26:10 starting OpenDaylight... 13:26:10 starting KARAF (karaf) TransportPCE build... 13:26:10 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 13:26:10 _____________ TestTransportPCEPce.test_02_load_simple_topology_bi ______________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_02_load_simple_topology_bi(self): 13:26:10 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_bi_dir_data) 13:26:10 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 13:26:10 E AssertionError: 401 not found in (200, 204) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:119: AssertionError 13:26:10 ____________________ TestTransportPCEPce.test_03_get_nodeId ____________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_03_get_nodeId(self): 13:26:10 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'ROADMA01-SRG1', 'config') 13:26:10 > self.assertEqual(response['status_code'], requests.codes.ok) 13:26:10 E AssertionError: 401 != 200 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:125: AssertionError 13:26:10 ____________________ TestTransportPCEPce.test_04_get_linkId ____________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_04_get_linkId(self): 13:26:10 > response = test_utils.get_ietf_network_link_request( 13:26:10 'openroadm-topology', 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX', 'config') 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:131: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 network = 'openroadm-topology' 13:26:10 link = 'XPDRA01-XPDR1-XPDR1-NETWORK1toROADMA01-SRG1-SRG1-PP1-TXRX' 13:26:10 content = 'config' 13:26:10 13:26:10 def get_ietf_network_link_request(network: str, link: str, content: str): 13:26:10 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 13:26:10 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 13:26:10 if RESTCONF_VERSION in ('rfc8040'): 13:26:10 format_args = ('{}', network, link, content) 13:26:10 elif content == 'config': 13:26:10 format_args = ('{}', content, network, link) 13:26:10 else: 13:26:10 format_args = ('{}', 'operational', network, link) 13:26:10 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': 'ietf-network-topology:link', 13:26:10 'draft-bierman02': 'ietf-network-topology:link'} 13:26:10 > link = res[return_key[RESTCONF_VERSION]][0] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'ietf-network-topology:link' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:602: KeyError 13:26:10 _____________ TestTransportPCEPce.test_05_path_computation_xpdr_bi _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_05_path_computation_xpdr_bi(self): 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:139: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 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'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 _____________ TestTransportPCEPce.test_06_path_computation_rdm_bi ______________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_06_path_computation_rdm_bi(self): 13:26:10 self.path_computation_input_data["service-a-end"]["node-id"] = "ROADMA01" 13:26:10 self.path_computation_input_data["service-z-end"]["node-id"] = "ROADMC01" 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:151: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 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'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 _____________ TestTransportPCEPce.test_07_load_simple_topology_uni _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_07_load_simple_topology_uni(self): 13:26:10 response = test_utils.put_ietf_network('openroadm-topology', self.simple_topo_uni_dir_data) 13:26:10 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 13:26:10 E AssertionError: 401 not found in (200, 204) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:162: AssertionError 13:26:10 ____________________ TestTransportPCEPce.test_08_get_nodeId ____________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_08_get_nodeId(self): 13:26:10 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-1-2', 'config') 13:26:10 > self.assertEqual(response['status_code'], requests.codes.ok) 13:26:10 E AssertionError: 401 != 200 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:168: AssertionError 13:26:10 ____________________ TestTransportPCEPce.test_09_get_linkId ____________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_09_get_linkId(self): 13:26:10 > response = test_utils.get_ietf_network_link_request( 13:26:10 'openroadm-topology', 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX', 'config') 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:174: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 network = 'openroadm-topology' 13:26:10 link = 'XPONDER-1-2XPDR-NW1-TX-toOpenROADM-1-2-SRG1-SRG1-PP1-RX' 13:26:10 content = 'config' 13:26:10 13:26:10 def get_ietf_network_link_request(network: str, link: str, content: str): 13:26:10 url = {'rfc8040': '{}/data/ietf-network:networks/network={}/ietf-network-topology:link={}?content={}', 13:26:10 'draft-bierman02': '{}/{}/ietf-network:networks/network/{}/ietf-network-topology:link/{}'} 13:26:10 if RESTCONF_VERSION in ('rfc8040'): 13:26:10 format_args = ('{}', network, link, content) 13:26:10 elif content == 'config': 13:26:10 format_args = ('{}', content, network, link) 13:26:10 else: 13:26:10 format_args = ('{}', 'operational', network, link) 13:26:10 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': 'ietf-network-topology:link', 13:26:10 'draft-bierman02': 'ietf-network-topology:link'} 13:26:10 > link = res[return_key[RESTCONF_VERSION]][0] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'ietf-network-topology:link' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:602: KeyError 13:26:10 ____________ TestTransportPCEPce.test_10_path_computation_xpdr_uni _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_10_path_computation_xpdr_uni(self): 13:26:10 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 13:26:10 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 13:26:10 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 13:26:10 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:186: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 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'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 _____________ TestTransportPCEPce.test_11_path_computation_rdm_uni _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_11_path_computation_rdm_uni(self): 13:26:10 self.path_computation_input_data["service-a-end"]["node-id"] = "OpenROADM-2-1" 13:26:10 self.path_computation_input_data["service-a-end"]["clli"] = "cll21" 13:26:10 self.path_computation_input_data["service-z-end"]["node-id"] = "OpenROADM-2-2" 13:26:10 self.path_computation_input_data["service-z-end"]["clli"] = "ncli22" 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:200: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 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'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 ______________ TestTransportPCEPce.test_12_load_complex_topology _______________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_12_load_complex_topology(self): 13:26:10 response = test_utils.put_ietf_network('openroadm-topology', self.complex_topo_uni_dir_data) 13:26:10 > self.assertIn(response['status_code'], (requests.codes.ok, requests.codes.no_content)) 13:26:10 E AssertionError: 401 not found in (200, 204) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:223: AssertionError 13:26:10 ____________________ TestTransportPCEPce.test_13_get_nodeId ____________________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_13_get_nodeId(self): 13:26:10 response = test_utils.get_ietf_network_node_request('openroadm-topology', 'XPONDER-3-2', 'config') 13:26:10 > self.assertEqual(response['status_code'], requests.codes.ok) 13:26:10 E AssertionError: 401 != 200 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:229: AssertionError 13:26:10 ______________ TestTransportPCEPce.test_14_fail_path_computation _______________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_14_fail_path_computation(self): 13:26:10 del self.path_computation_input_data["service-name"] 13:26:10 del self.path_computation_input_data["service-a-end"] 13:26:10 del self.path_computation_input_data["service-z-end"] 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:238: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-handler-header': {'request-id': 'request1'}} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 ____________ TestTransportPCEPce.test_15_success1_path_computation _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_15_success1_path_computation(self): 13:26:10 self.path_computation_input_data["service-name"] = "service 1" 13:26:10 self.path_computation_input_data["service-a-end"] = {"service-format": "Ethernet", "service-rate": "100", 13:26:10 "clli": "ORANGE2", "node-id": "XPONDER-2-2"} 13:26:10 self.path_computation_input_data["service-z-end"] = {"service-format": "Ethernet", "service-rate": "100", 13:26:10 "clli": "ORANGE1", "node-id": "XPONDER-1-2"} 13:26:10 self.path_computation_input_data["hard-constraints"] = {"customer-code": ["Some customer-code"], 13:26:10 "co-routing": { 13:26:10 "service-identifier-list": [{ 13:26:10 "service-identifier": "Some existing-service"}] 13:26:10 }} 13:26:10 self.path_computation_input_data["soft-constraints"] = {"customer-code": ["Some customer-code"], 13:26:10 "co-routing": { 13:26:10 "service-identifier-list": [{ 13:26:10 "service-identifier": "Some existing-service"}] 13:26:10 }} 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:263: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 payload = {'hard-constraints': {'co-routing': {'service-identifier-list': [{'service-identifier': 'Some existing-service'}]}, 'c...ervice-a-end': {'clli': 'ORANGE2', 'node-id': 'XPONDER-2-2', 'service-format': 'Ethernet', 'service-rate': '100'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 ____________ TestTransportPCEPce.test_16_success2_path_computation _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_16_success2_path_computation(self): 13:26:10 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-1-2" 13:26:10 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE1" 13:26:10 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-3-2" 13:26:10 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE3" 13:26:10 del self.path_computation_input_data["hard-constraints"] 13:26:10 del self.path_computation_input_data["soft-constraints"] 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:280: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 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'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 ____________ TestTransportPCEPce.test_17_success3_path_computation _____________ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_17_success3_path_computation(self): 13:26:10 self.path_computation_input_data["hard-constraints"] = {"exclude": 13:26:10 {"node-id": ["OpenROADM-2-1", "OpenROADM-2-2"]}} 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:296: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 payload = {'hard-constraints': {'exclude': {'node-id': ['OpenROADM-2-1', 'OpenROADM-2-2']}}, 'pce-routing-metric': 'hop-count', ...ervice-a-end': {'clli': 'ORANGE1', 'node-id': 'XPONDER-1-2', 'service-format': 'Ethernet', 'service-rate': '100'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 __ TestTransportPCEPce.test_18_path_computation_before_oms_attribute_deletion __ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_18_path_computation_before_oms_attribute_deletion(self): 13:26:10 self.path_computation_input_data["service-a-end"]["node-id"] = "XPONDER-2-2" 13:26:10 self.path_computation_input_data["service-a-end"]["clli"] = "ORANGE2" 13:26:10 self.path_computation_input_data["service-z-end"]["node-id"] = "XPONDER-1-2" 13:26:10 self.path_computation_input_data["service-z-end"]["clli"] = "ORANGE1" 13:26:10 del self.path_computation_input_data["hard-constraints"] 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:315: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'ORANGE2', 'node-id': 'XPONDER-2-2', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 _ TestTransportPCEPce.test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link _ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link(self): 13:26:10 response = test_utils.del_oms_attr_request("OpenROADM-1-3-DEG2-to-OpenROADM-1-2-DEG2") 13:26:10 > self.assertIn(response.status_code, (requests.codes.ok, requests.codes.no_content)) 13:26:10 E AssertionError: 401 not found in (200, 204) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:337: AssertionError 13:26:10 __ TestTransportPCEPce.test_20_path_computation_after_oms_attribute_deletion ___ 13:26:10 13:26:10 self = 13:26:10 13:26:10 def test_20_path_computation_after_oms_attribute_deletion(self): 13:26:10 > response = test_utils.transportpce_api_rpc_request('transportpce-pce', 13:26:10 'path-computation-request', 13:26:10 self.path_computation_input_data) 13:26:10 13:26:10 transportpce_tests/pce/test01_pce.py:342: 13:26:10 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:26:10 13:26:10 api_module = 'transportpce-pce', rpc = 'path-computation-request' 13:26:10 payload = {'pce-routing-metric': 'hop-count', 'resource-reserve': 'true', 'service-a-end': {'clli': 'ORANGE2', 'node-id': 'XPONDER-2-2', 'service-format': 'Ethernet', 'service-rate': '100'}, 'service-handler-header': {'request-id': 'request1'}, ...} 13:26:10 13:26:10 def transportpce_api_rpc_request(api_module: str, rpc: str, payload: dict): 13:26:10 # pylint: disable=consider-using-f-string 13:26:10 url = "{}/operations/{}:{}".format('{}', api_module, rpc) 13:26:10 if payload is None: 13:26:10 data = None 13:26:10 elif RESTCONF_VERSION == 'draft-bierman02': 13:26:10 data = prepend_dict_keys({'input': payload}, api_module + ':') 13:26:10 else: 13:26:10 data = {'input': payload} 13:26:10 response = post_request(url, data) 13:26:10 if response.status_code == requests.codes.no_content: 13:26:10 return_output = None 13:26:10 else: 13:26:10 res = response.json() 13:26:10 return_key = {'rfc8040': api_module + ':output', 13:26:10 'draft-bierman02': 'output'} 13:26:10 if response.status_code == requests.codes.internal_server_error: 13:26:10 return_output = res 13:26:10 else: 13:26:10 > return_output = res[return_key[RESTCONF_VERSION]] 13:26:10 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:26:10 E KeyError: 'transportpce-pce:output' 13:26:10 13:26:10 transportpce_tests/common/test_utils.py:761: KeyError 13:26:10 --------------------------- Captured stdout teardown --------------------------- 13:26:10 all processes killed 13:26:10 ODL log file stored 13:26:10 =========================== short test summary info ============================ 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_01_load_port_mapping 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_02_load_simple_topology_bi 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_03_get_nodeId 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_04_get_linkId 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_05_path_computation_xpdr_bi 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_06_path_computation_rdm_bi 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_07_load_simple_topology_uni 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_08_get_nodeId 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_09_get_linkId 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_10_path_computation_xpdr_uni 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_11_path_computation_rdm_uni 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_12_load_complex_topology 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_13_get_nodeId 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_14_fail_path_computation 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_15_success1_path_computation 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_16_success2_path_computation 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_17_success3_path_computation 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_18_path_computation_before_oms_attribute_deletion 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_19_delete_oms_attribute_in_openroadm13toopenroadm12_link 13:26:10 FAILED transportpce_tests/pce/test01_pce.py::TestTransportPCEPce::test_20_path_computation_after_oms_attribute_deletion 13:26:10 20 failed in 152.07s (0:02:32) 13:26:10 testsPCE: exit 1 (152.46 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce pid=5156 13:26:11 testsPCE: FAIL ✖ in 3 minutes 26.79 seconds 13:26:11 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 13:26:11 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 13:26:11 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 13:26:22 tests190: freeze> python -m pip freeze --all 13:26:22 tests121: freeze> python -m pip freeze --all 13:26:22 tests_tapi: freeze> python -m pip freeze --all 13:26:22 tests190: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:26:22 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 13:26:22 using environment variables from ./karafoc.env 13:26:22 pytest -q transportpce_tests/oc/test01_portmapping.py 13:26:22 tests_tapi: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:26:22 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 13:26:22 tests121: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:26:22 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 13:26:22 using environment variables from ./karaf121.env 13:26:22 using environment variables from ./karaf221.env 13:26:22 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 13:26:22 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 13:27:35 ........... [100%] 13:27:51 10 passed in 89.04s (0:01:29) 13:27:51 pytest -q transportpce_tests/oc/test02_topology.py 13:27:59 ................................ [100%] 13:28:38 21 passed in 136.04s (0:02:16) 13:28:38 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 13:28:40 ............................ [100%] 13:29:00 14 passed in 68.63s (0:01:08) 13:29:00 pytest -q transportpce_tests/oc/test03_renderer.py 13:29:02 ................. [100%] 13:29:44 6 passed in 65.04s (0:01:05) 13:29:44 pytest -q transportpce_tests/1.2.1/test03_topology.py 13:29:44 ................... [100%] 13:30:05 19 passed in 64.47s (0:01:04) 13:30:05 tests190: OK ✔ in 3 minutes 54.78 seconds 13:30:05 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 13:30:06 .tests71: freeze> python -m pip freeze --all 13:30:14 tests71: bcrypt==4.3.0,certifi==2025.8.3,cffi==1.17.1,charset-normalizer==3.4.3,cryptography==45.0.7,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,invoke==2.2.0,lxml==6.0.1,netconf-client==3.5.0,packaging==25.0,paramiko==4.0.0,pip==25.2,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.2,requests==2.32.5,setuptools==80.9.0,urllib3==2.5.0 13:30:14 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 13:30:14 using environment variables from ./karaf71.env 13:30:14 pytest -q transportpce_tests/7.1/test01_portmapping.py 13:30:27 .............................. [100%] 13:31:08 12 passed in 53.95s 13:31:08 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 13:31:10 .................................................. [100%] 13:32:17 44 passed in 152.76s (0:02:32) 13:32:17 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 13:32:17 ........................................................................ [100%] 13:33:43 24 passed in 86.25s (0:01:26) 13:33:43 pytest -q transportpce_tests/1.2.1/test05_olm.py 13:33:45 . [100%] 13:33:47 62 passed in 158.66s (0:02:38) 13:33:48 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 13:34:41 ............................................................................. [100%] 13:36:26 48 passed in 158.18s (0:02:38) 13:36:26 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 13:36:28 .................. [100%] 13:37:09 40 passed in 204.78s (0:03:24) 13:37:09 pytest -q transportpce_tests/1.2.1/test06_end2end.py 13:37:10 ................. [100%] 13:37:44 22 passed in 77.83s (0:01:17) 13:37:45 [100%] 13:37:45 51 passed in 683.15s (0:11:23) 13:37:45 pytest -q transportpce_tests/tapi/test02_full_topology.py 13:37:55 ......................$ ssh-agent -k 13:38:57 unset SSH_AUTH_SOCK; 13:38:57 unset SSH_AGENT_PID; 13:38:57 echo Agent pid 1576 killed; 13:38:57 [ssh-agent] Stopped. 13:38:57 Build was aborted 13:38:57 Aborted by new patch set. 13:38:57 [PostBuildScript] - [INFO] Executing post build scripts. 13:38:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1030296629352844773.sh 13:38:57 ---> sysstat.sh 13:38:58 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17305309461113277415.sh 13:38:58 ---> package-listing.sh 13:38:58 ++ facter osfamily 13:38:58 ++ tr '[:upper:]' '[:lower:]' 13:38:58 .+ OS_FAMILY=debian 13:38:58 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 13:38:58 + START_PACKAGES=/tmp/packages_start.txt 13:38:58 + END_PACKAGES=/tmp/packages_end.txt 13:38:58 + DIFF_PACKAGES=/tmp/packages_diff.txt 13:38:58 + PACKAGES=/tmp/packages_start.txt 13:38:58 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:38:58 + PACKAGES=/tmp/packages_end.txt 13:38:58 + case "${OS_FAMILY}" in 13:38:58 + dpkg -l 13:38:58 + grep '^ii' 13:38:58 + '[' -f /tmp/packages_start.txt ']' 13:38:58 + '[' -f /tmp/packages_end.txt ']' 13:38:58 + diff /tmp/packages_start.txt /tmp/packages_end.txt 13:38:58 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:38:58 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:38:58 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:38:58 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins5673341420146837173.sh 13:38:58 ---> capture-instance-metadata.sh 13:38:59 Setup pyenv: 13:38:59 system 13:38:59 3.8.20 13:38:59 3.9.20 13:38:59 3.10.15 13:38:59 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:38:59 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BJis from file:/tmp/.os_lf_venv 13:39:02 lf-activate-venv(): INFO: Installing: lftools 13:39:03 Terminated 13:39:03 tests71: OK ✔ in 7 minutes 39.06 seconds 13:39:03 tests_tapi: exit 1 (761.46 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=5895 13:39:04 Terminated 13:39:04 + tox_status=143 13:39:04 + echo '---> Completed tox runs' 13:39:04 ---> Completed tox runs 13:39:04 + for i in .tox/*/log 13:39:04 ++ echo .tox/build_karaf_tests121/log 13:39:04 ++ awk -F/ '{print $2}' 13:39:16 lf-activate-venv(): INFO: Adding /tmp/venv-BJis/bin to PATH 13:39:16 INFO: Running in OpenStack, capturing instance metadata 13:39:16 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins4643981312853572774.sh 13:39:16 provisioning config files... 13:39:18 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #3560 13:39:18 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config16501471111679737410tmp 13:39:18 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 13:39:18 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 13:39:18 provisioning config files... 13:39:18 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 13:39:18 [EnvInject] - Injecting environment variables from a build step. 13:39:18 [EnvInject] - Injecting as environment variables the properties content 13:39:18 SERVER_ID=logs 13:39:18 13:39:18 [EnvInject] - Variables injected successfully. 13:39:18 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15549275851315520342.sh 13:39:18 ---> create-netrc.sh 13:39:19 WARN: Log server credential not found. 13:39:19 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8658865157554777509.sh 13:39:19 ---> python-tools-install.sh 13:39:19 Setup pyenv: 13:39:19 system 13:39:19 3.8.20 13:39:19 3.9.20 13:39:19 3.10.15 13:39:19 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:39:19 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BJis from file:/tmp/.os_lf_venv 13:39:21 lf-activate-venv(): INFO: Installing: lftools 13:39:33 lf-activate-venv(): INFO: Adding /tmp/venv-BJis/bin to PATH 13:39:33 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3508120106789597121.sh 13:39:33 ---> sudo-logs.sh 13:39:33 Archiving 'sudo' log.. 13:39:34 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins15600481100799864567.sh 13:39:34 ---> job-cost.sh 13:39:34 Setup pyenv: 13:39:34 system 13:39:34 3.8.20 13:39:34 3.9.20 13:39:34 3.10.15 13:39:34 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:39:34 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BJis from file:/tmp/.os_lf_venv 13:39:38 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 13:39:48 lf-activate-venv(): INFO: Adding /tmp/venv-BJis/bin to PATH 13:39:48 INFO: No Stack... 13:39:49 INFO: Retrieving Pricing Info for: v3-standard-4 13:39:49 INFO: Archiving Costs 13:39:49 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins3489440792087061657.sh 13:39:49 ---> logs-deploy.sh 13:39:49 Setup pyenv: 13:39:49 system 13:39:49 3.8.20 13:39:49 3.9.20 13:39:49 3.10.15 13:39:49 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:39:49 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-BJis from file:/tmp/.os_lf_venv 13:39:51 lf-activate-venv(): INFO: Installing: lftools 13:40:02 lf-activate-venv(): INFO: Adding /tmp/venv-BJis/bin to PATH 13:40:02 WARNING: Nexus logging server not set 13:40:02 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/3560/ 13:40:02 INFO: archiving logs to S3 13:40:04 ---> uname -a: 13:40:04 Linux prd-ubuntu2204-docker-4c-16g-49184 5.15.0-131-generic #141-Ubuntu SMP Fri Jan 10 21:18:28 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux 13:40:04 13:40:04 13:40:04 ---> lscpu: 13:40:04 Architecture: x86_64 13:40:04 CPU op-mode(s): 32-bit, 64-bit 13:40:04 Address sizes: 40 bits physical, 48 bits virtual 13:40:04 Byte Order: Little Endian 13:40:04 CPU(s): 4 13:40:04 On-line CPU(s) list: 0-3 13:40:04 Vendor ID: AuthenticAMD 13:40:04 Model name: AMD EPYC-Rome Processor 13:40:04 CPU family: 23 13:40:04 Model: 49 13:40:04 Thread(s) per core: 1 13:40:04 Core(s) per socket: 1 13:40:04 Socket(s): 4 13:40:04 Stepping: 0 13:40:04 BogoMIPS: 5600.00 13:40:04 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 13:40:04 Virtualization: AMD-V 13:40:04 Hypervisor vendor: KVM 13:40:04 Virtualization type: full 13:40:04 L1d cache: 128 KiB (4 instances) 13:40:04 L1i cache: 128 KiB (4 instances) 13:40:04 L2 cache: 2 MiB (4 instances) 13:40:04 L3 cache: 64 MiB (4 instances) 13:40:04 NUMA node(s): 1 13:40:04 NUMA node0 CPU(s): 0-3 13:40:04 Vulnerability Gather data sampling: Not affected 13:40:04 Vulnerability Itlb multihit: Not affected 13:40:04 Vulnerability L1tf: Not affected 13:40:04 Vulnerability Mds: Not affected 13:40:04 Vulnerability Meltdown: Not affected 13:40:04 Vulnerability Mmio stale data: Not affected 13:40:04 Vulnerability Reg file data sampling: Not affected 13:40:04 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 13:40:04 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 13:40:04 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 13:40:04 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 13:40:04 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 13:40:04 Vulnerability Srbds: Not affected 13:40:04 Vulnerability Tsx async abort: Not affected 13:40:04 13:40:04 13:40:04 ---> nproc: 13:40:04 4 13:40:04 13:40:04 13:40:04 ---> df -h: 13:40:04 Filesystem Size Used Avail Use% Mounted on 13:40:04 tmpfs 1.6G 1.1M 1.6G 1% /run 13:40:04 /dev/vda1 78G 17G 61G 22% / 13:40:04 tmpfs 7.9G 0 7.9G 0% /dev/shm 13:40:04 tmpfs 5.0M 0 5.0M 0% /run/lock 13:40:04 /dev/vda15 105M 6.1M 99M 6% /boot/efi 13:40:04 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 13:40:04 13:40:04 13:40:04 ---> free -m: 13:40:04 total used free shared buff/cache available 13:40:04 Mem: 15989 670 12193 3 3125 14976 13:40:04 Swap: 1023 1 1022 13:40:04 13:40:04 13:40:04 ---> ip addr: 13:40:04 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 13:40:04 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 13:40:04 inet 127.0.0.1/8 scope host lo 13:40:04 valid_lft forever preferred_lft forever 13:40:04 inet6 ::1/128 scope host 13:40:04 valid_lft forever preferred_lft forever 13:40:04 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 13:40:04 link/ether fa:16:3e:4f:44:bb brd ff:ff:ff:ff:ff:ff 13:40:04 altname enp0s3 13:40:04 inet 10.30.171.10/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 13:40:04 valid_lft 85019sec preferred_lft 85019sec 13:40:04 inet6 fe80::f816:3eff:fe4f:44bb/64 scope link 13:40:04 valid_lft forever preferred_lft forever 13:40:04 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 13:40:04 link/ether 02:42:e3:30:27:26 brd ff:ff:ff:ff:ff:ff 13:40:04 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 13:40:04 valid_lft forever preferred_lft forever 13:40:04 13:40:04 13:40:04 ---> sar -b -r -n DEV: 13:40:04 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-49184) 09/05/25 _x86_64_ (4 CPU) 13:40:04 13:40:04 13:17:07 LINUX RESTART (4 CPU) 13:40:04 13:40:04 13:20:01 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 13:40:04 13:30:15 80.83 4.98 71.18 4.67 812.09 34458.47 22725.58 13:40:04 Average: 80.83 4.98 71.18 4.67 812.09 34458.47 22725.58 13:40:04 13:40:04 13:20:01 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 13:40:04 13:30:15 1961544 6297468 9629620 58.81 238728 4003004 11325948 65.01 2178276 11567788 77772 13:40:04 Average: 1961544 6297468 9629620 58.81 238728 4003004 11325948 65.01 2178276 11567788 77772 13:40:04 13:40:04 13:20:01 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 13:40:04 13:30:15 lo 13.45 13.45 11.50 11.50 0.00 0.00 0.00 0.00 13:40:04 13:30:15 ens3 81.68 59.14 1309.21 6.41 0.00 0.00 0.00 0.00 13:40:04 13:30:15 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:40:04 Average: lo 13.45 13.45 11.50 11.50 0.00 0.00 0.00 0.00 13:40:04 Average: ens3 81.68 59.14 1309.21 6.41 0.00 0.00 0.00 0.00 13:40:04 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:40:04 13:40:04 13:40:04 ---> sar -P ALL: 13:40:04 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-49184) 09/05/25 _x86_64_ (4 CPU) 13:40:04 13:40:04 13:17:07 LINUX RESTART (4 CPU) 13:40:04 13:40:04 13:20:01 CPU %user %nice %system %iowait %steal %idle 13:40:04 13:30:15 all 55.91 0.00 2.96 13.69 0.17 27.27 13:40:04 13:30:15 0 58.17 0.00 3.03 14.01 0.13 24.66 13:40:04 13:30:15 1 54.40 0.00 3.23 12.10 0.13 30.13 13:40:04 13:30:15 2 56.95 0.00 2.85 16.57 0.14 23.49 13:40:04 13:30:15 3 54.13 0.00 2.74 12.07 0.28 30.77 13:40:04 Average: all 55.91 0.00 2.96 13.69 0.17 27.27 13:40:04 Average: 0 58.17 0.00 3.03 14.01 0.13 24.66 13:40:04 Average: 1 54.40 0.00 3.23 12.10 0.13 30.13 13:40:04 Average: 2 56.95 0.00 2.85 16.57 0.14 23.49 13:40:04 Average: 3 54.13 0.00 2.74 12.07 0.28 30.77 13:40:04 13:40:04 13:40:04