11:56:24 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/116914 11:56:24 Running as SYSTEM 11:56:24 [EnvInject] - Loading node environment variables. 11:56:25 Building remotely on prd-ubuntu2204-docker-4c-16g-43768 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 11:56:25 [ssh-agent] Looking for ssh-agent implementation... 11:56:25 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 11:56:25 $ ssh-agent 11:56:25 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXaVjFsG/agent.1571 11:56:25 SSH_AGENT_PID=1573 11:56:25 [ssh-agent] Started. 11:56:25 Running ssh-add (command line suppressed) 11:56:25 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_6981819377377740896.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_6981819377377740896.key) 11:56:25 [ssh-agent] Using credentials jenkins (jenkins-ssh) 11:56:25 The recommended git tool is: NONE 11:56:27 using credential jenkins-ssh 11:56:27 Wiping out workspace first. 11:56:27 Cloning the remote Git repository 11:56:27 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 11:56:27 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 11:56:27 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 11:56:27 > git --version # timeout=10 11:56:27 > git --version # 'git version 2.34.1' 11:56:27 using GIT_SSH to set credentials jenkins-ssh 11:56:27 Verifying host key using known hosts file 11:56:27 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. 11:56:27 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 11:56:30 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 11:56:30 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 11:56:31 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 11:56:31 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 11:56:31 using GIT_SSH to set credentials jenkins-ssh 11:56:31 Verifying host key using known hosts file 11:56:31 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. 11:56:31 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/14/116914/7 # timeout=10 11:56:31 > git rev-parse 3a7ef488e5605f28a575f3c80f08a4ecc832ce34^{commit} # timeout=10 11:56:31 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 11:56:31 Checking out Revision 3a7ef488e5605f28a575f3c80f08a4ecc832ce34 (refs/changes/14/116914/7) 11:56:31 > git config core.sparsecheckout # timeout=10 11:56:31 > git checkout -f 3a7ef488e5605f28a575f3c80f08a4ecc832ce34 # timeout=10 11:56:34 Commit message: "Added available frequencies" 11:56:34 > git rev-parse FETCH_HEAD^{commit} # timeout=10 11:56:35 > git rev-list --no-walk f2033df0fefd53a428e413af0b21ee532cff38d1 # timeout=10 11:56:35 > git remote # timeout=10 11:56:35 > git submodule init # timeout=10 11:56:35 > git submodule sync # timeout=10 11:56:35 > git config --get remote.origin.url # timeout=10 11:56:35 > git submodule init # timeout=10 11:56:35 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 11:56:35 ERROR: No submodules found. 11:56:35 provisioning config files... 11:56:35 copy managed file [npmrc] to file:/home/jenkins/.npmrc 11:56:35 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 11:56:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14182154222838590543.sh 11:56:35 ---> python-tools-install.sh 11:56:35 Setup pyenv: 11:56:35 * system (set by /opt/pyenv/version) 11:56:35 * 3.8.20 (set by /opt/pyenv/version) 11:56:35 * 3.9.20 (set by /opt/pyenv/version) 11:56:35 * 3.10.15 (set by /opt/pyenv/version) 11:56:35 * 3.11.10 (set by /opt/pyenv/version) 11:56:40 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-z8bK 11:56:40 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 11:56:44 lf-activate-venv(): INFO: Installing: lftools 11:57:17 lf-activate-venv(): INFO: Adding /tmp/venv-z8bK/bin to PATH 11:57:17 Generating Requirements File 11:57:40 Python 3.11.10 11:57:40 pip 25.1.1 from /tmp/venv-z8bK/lib/python3.11/site-packages/pip (python 3.11) 11:57:40 appdirs==1.4.4 11:57:40 argcomplete==3.6.2 11:57:40 aspy.yaml==1.3.0 11:57:40 attrs==25.3.0 11:57:40 autopage==0.5.2 11:57:40 beautifulsoup4==4.13.4 11:57:40 boto3==1.39.8 11:57:40 botocore==1.39.8 11:57:40 bs4==0.0.2 11:57:40 cachetools==5.5.2 11:57:40 certifi==2025.7.14 11:57:40 cffi==1.17.1 11:57:40 cfgv==3.4.0 11:57:40 chardet==5.2.0 11:57:40 charset-normalizer==3.4.2 11:57:40 click==8.2.1 11:57:40 cliff==4.10.0 11:57:40 cmd2==2.7.0 11:57:40 cryptography==3.3.2 11:57:40 debtcollector==3.0.0 11:57:40 decorator==5.2.1 11:57:40 defusedxml==0.7.1 11:57:40 Deprecated==1.2.18 11:57:40 distlib==0.4.0 11:57:40 dnspython==2.7.0 11:57:40 docker==7.1.0 11:57:40 dogpile.cache==1.4.0 11:57:40 durationpy==0.10 11:57:40 email_validator==2.2.0 11:57:40 filelock==3.18.0 11:57:40 future==1.0.0 11:57:40 gitdb==4.0.12 11:57:40 GitPython==3.1.44 11:57:40 google-auth==2.40.3 11:57:40 httplib2==0.22.0 11:57:40 identify==2.6.12 11:57:40 idna==3.10 11:57:40 importlib-resources==1.5.0 11:57:40 iso8601==2.1.0 11:57:40 Jinja2==3.1.6 11:57:40 jmespath==1.0.1 11:57:40 jsonpatch==1.33 11:57:40 jsonpointer==3.0.0 11:57:40 jsonschema==4.24.1 11:57:40 jsonschema-specifications==2025.4.1 11:57:40 keystoneauth1==5.11.1 11:57:40 kubernetes==33.1.0 11:57:40 lftools==0.37.13 11:57:40 lxml==6.0.0 11:57:40 markdown-it-py==3.0.0 11:57:40 MarkupSafe==3.0.2 11:57:40 mdurl==0.1.2 11:57:40 msgpack==1.1.1 11:57:40 multi_key_dict==2.0.3 11:57:40 munch==4.0.0 11:57:40 netaddr==1.3.0 11:57:40 niet==1.4.2 11:57:40 nodeenv==1.9.1 11:57:40 oauth2client==4.1.3 11:57:40 oauthlib==3.3.1 11:57:40 openstacksdk==4.6.0 11:57:40 os-client-config==2.3.0 11:57:40 os-service-types==1.8.0 11:57:40 osc-lib==4.1.0 11:57:40 oslo.config==10.0.0 11:57:40 oslo.context==6.0.0 11:57:40 oslo.i18n==6.5.1 11:57:40 oslo.log==7.2.0 11:57:40 oslo.serialization==5.7.0 11:57:40 oslo.utils==9.0.0 11:57:40 packaging==25.0 11:57:40 pbr==6.1.1 11:57:40 platformdirs==4.3.8 11:57:40 prettytable==3.16.0 11:57:40 psutil==7.0.0 11:57:40 pyasn1==0.6.1 11:57:40 pyasn1_modules==0.4.2 11:57:40 pycparser==2.22 11:57:40 pygerrit2==2.0.15 11:57:40 PyGithub==2.6.1 11:57:40 Pygments==2.19.2 11:57:40 PyJWT==2.10.1 11:57:40 PyNaCl==1.5.0 11:57:40 pyparsing==2.4.7 11:57:40 pyperclip==1.9.0 11:57:40 pyrsistent==0.20.0 11:57:40 python-cinderclient==9.7.0 11:57:40 python-dateutil==2.9.0.post0 11:57:40 python-heatclient==4.3.0 11:57:40 python-jenkins==1.8.2 11:57:40 python-keystoneclient==5.6.0 11:57:40 python-magnumclient==4.8.1 11:57:40 python-openstackclient==8.1.0 11:57:40 python-swiftclient==4.8.0 11:57:40 PyYAML==6.0.2 11:57:40 referencing==0.36.2 11:57:40 requests==2.32.4 11:57:40 requests-oauthlib==2.0.0 11:57:40 requestsexceptions==1.4.0 11:57:40 rfc3986==2.0.0 11:57:40 rich==14.0.0 11:57:40 rich-argparse==1.7.1 11:57:40 rpds-py==0.26.0 11:57:40 rsa==4.9.1 11:57:40 ruamel.yaml==0.18.14 11:57:40 ruamel.yaml.clib==0.2.12 11:57:40 s3transfer==0.13.0 11:57:40 simplejson==3.20.1 11:57:40 six==1.17.0 11:57:40 smmap==5.0.2 11:57:40 soupsieve==2.7 11:57:40 stevedore==5.4.1 11:57:40 tabulate==0.9.0 11:57:40 toml==0.10.2 11:57:40 tomlkit==0.13.3 11:57:40 tqdm==4.67.1 11:57:40 typing_extensions==4.14.1 11:57:40 tzdata==2025.2 11:57:40 urllib3==1.26.20 11:57:40 virtualenv==20.31.2 11:57:40 wcwidth==0.2.13 11:57:40 websocket-client==1.8.0 11:57:40 wrapt==1.17.2 11:57:40 xdg==6.0.0 11:57:40 xmltodict==0.14.2 11:57:40 yq==3.4.3 11:57:40 [EnvInject] - Injecting environment variables from a build step. 11:57:40 [EnvInject] - Injecting as environment variables the properties content 11:57:40 PYTHON=python3 11:57:40 11:57:40 [EnvInject] - Variables injected successfully. 11:57:40 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins1479442030085713117.sh 11:57:40 ---> tox-install.sh 11:57:40 + source /home/jenkins/lf-env.sh 11:57:40 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 11:57:40 ++ mktemp -d /tmp/venv-XXXX 11:57:40 + lf_venv=/tmp/venv-JbYz 11:57:40 + local venv_file=/tmp/.os_lf_venv 11:57:40 + local python=python3 11:57:40 + local options 11:57:40 + local set_path=true 11:57:40 + local install_args= 11:57:40 ++ 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 11:57:40 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:57:40 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:57:40 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 11:57:40 + true 11:57:40 + case $1 in 11:57:40 + venv_file=/tmp/.toxenv 11:57:40 + shift 2 11:57:40 + true 11:57:40 + case $1 in 11:57:40 + shift 11:57:40 + break 11:57:40 + case $python in 11:57:40 + local pkg_list= 11:57:40 + [[ -d /opt/pyenv ]] 11:57:40 + echo 'Setup pyenv:' 11:57:40 Setup pyenv: 11:57:40 + export PYENV_ROOT=/opt/pyenv 11:57:40 + PYENV_ROOT=/opt/pyenv 11:57:40 + 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 11:57:40 + 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 11:57:40 + pyenv versions 11:57:40 system 11:57:40 3.8.20 11:57:40 3.9.20 11:57:40 3.10.15 11:57:40 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:57:40 + command -v pyenv 11:57:40 ++ pyenv init - --no-rehash 11:57:40 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 11:57:40 for i in ${!paths[@]}; do 11:57:40 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 11:57:40 fi; done; 11:57:40 echo "${paths[*]}"'\'')" 11:57:40 export PATH="/opt/pyenv/shims:${PATH}" 11:57:40 export PYENV_SHELL=bash 11:57:40 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 11:57:40 pyenv() { 11:57:40 local command 11:57:40 command="${1:-}" 11:57:40 if [ "$#" -gt 0 ]; then 11:57:40 shift 11:57:40 fi 11:57:40 11:57:40 case "$command" in 11:57:40 rehash|shell) 11:57:40 eval "$(pyenv "sh-$command" "$@")" 11:57:40 ;; 11:57:40 *) 11:57:40 command pyenv "$command" "$@" 11:57:40 ;; 11:57:40 esac 11:57:40 }' 11:57:40 +++ bash --norc -ec 'IFS=:; paths=($PATH); 11:57:40 for i in ${!paths[@]}; do 11:57:40 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 11:57:40 fi; done; 11:57:40 echo "${paths[*]}"' 11:57:40 ++ 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 11:57:40 ++ 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 11:57:40 ++ 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 11:57:40 ++ export PYENV_SHELL=bash 11:57:40 ++ PYENV_SHELL=bash 11:57:40 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 11:57:40 +++ complete -F _pyenv pyenv 11:57:40 ++ lf-pyver python3 11:57:40 ++ local py_version_xy=python3 11:57:40 ++ local py_version_xyz= 11:57:40 ++ pyenv versions 11:57:40 ++ local command 11:57:40 ++ command=versions 11:57:40 ++ '[' 1 -gt 0 ']' 11:57:40 ++ shift 11:57:40 ++ case "$command" in 11:57:40 ++ command pyenv versions 11:57:40 ++ sed 's/^[ *]* //' 11:57:40 ++ awk '{ print $1 }' 11:57:40 ++ grep -E '^[0-9.]*[0-9]$' 11:57:40 ++ [[ ! -s /tmp/.pyenv_versions ]] 11:57:40 +++ grep '^3' /tmp/.pyenv_versions 11:57:40 +++ sort -V 11:57:40 +++ tail -n 1 11:57:40 ++ py_version_xyz=3.11.10 11:57:40 ++ [[ -z 3.11.10 ]] 11:57:40 ++ echo 3.11.10 11:57:40 ++ return 0 11:57:40 + pyenv local 3.11.10 11:57:40 + local command 11:57:40 + command=local 11:57:40 + '[' 2 -gt 0 ']' 11:57:40 + shift 11:57:40 + case "$command" in 11:57:40 + command pyenv local 3.11.10 11:57:40 + for arg in "$@" 11:57:40 + case $arg in 11:57:40 + pkg_list+='tox ' 11:57:40 + for arg in "$@" 11:57:40 + case $arg in 11:57:40 + pkg_list+='virtualenv ' 11:57:40 + for arg in "$@" 11:57:40 + case $arg in 11:57:40 + pkg_list+='urllib3~=1.26.15 ' 11:57:40 + [[ -f /tmp/.toxenv ]] 11:57:40 + [[ ! -f /tmp/.toxenv ]] 11:57:40 + [[ -n '' ]] 11:57:40 + python3 -m venv /tmp/venv-JbYz 11:57:44 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-JbYz' 11:57:44 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-JbYz 11:57:44 + echo /tmp/venv-JbYz 11:57:44 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 11:57:44 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 11:57:44 + /tmp/venv-JbYz/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 11:57:48 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 11:57:48 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 11:57:48 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 11:57:48 + /tmp/venv-JbYz/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 11:57:50 + type python3 11:57:50 + true 11:57:50 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-JbYz/bin to PATH' 11:57:50 lf-activate-venv(): INFO: Adding /tmp/venv-JbYz/bin to PATH 11:57:50 + PATH=/tmp/venv-JbYz/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 11:57:50 + return 0 11:57:50 + python3 --version 11:57:50 Python 3.11.10 11:57:50 + python3 -m pip --version 11:57:50 pip 25.1.1 from /tmp/venv-JbYz/lib/python3.11/site-packages/pip (python 3.11) 11:57:50 + python3 -m pip freeze 11:57:51 cachetools==6.1.0 11:57:51 chardet==5.2.0 11:57:51 colorama==0.4.6 11:57:51 distlib==0.4.0 11:57:51 filelock==3.18.0 11:57:51 packaging==25.0 11:57:51 platformdirs==4.3.8 11:57:51 pluggy==1.6.0 11:57:51 pyproject-api==1.9.1 11:57:51 tox==4.27.0 11:57:51 urllib3==1.26.20 11:57:51 virtualenv==20.31.2 11:57:51 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins5382627660709852287.sh 11:57:51 [EnvInject] - Injecting environment variables from a build step. 11:57:51 [EnvInject] - Injecting as environment variables the properties content 11:57:51 PARALLEL=True 11:57:51 11:57:51 [EnvInject] - Variables injected successfully. 11:57:51 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins7711543975599432429.sh 11:57:51 ---> tox-run.sh 11:57:51 + 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 11:57:51 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 11:57:51 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 11:57:51 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 11:57:51 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 11:57:51 + source /home/jenkins/lf-env.sh 11:57:51 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 11:57:51 ++ mktemp -d /tmp/venv-XXXX 11:57:51 + lf_venv=/tmp/venv-hp00 11:57:51 + local venv_file=/tmp/.os_lf_venv 11:57:51 + local python=python3 11:57:51 + local options 11:57:51 + local set_path=true 11:57:51 + local install_args= 11:57:51 ++ 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 11:57:51 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:57:51 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 11:57:51 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 11:57:51 + true 11:57:51 + case $1 in 11:57:51 + venv_file=/tmp/.toxenv 11:57:51 + shift 2 11:57:51 + true 11:57:51 + case $1 in 11:57:51 + shift 11:57:51 + break 11:57:51 + case $python in 11:57:51 + local pkg_list= 11:57:51 + [[ -d /opt/pyenv ]] 11:57:51 + echo 'Setup pyenv:' 11:57:51 Setup pyenv: 11:57:51 + export PYENV_ROOT=/opt/pyenv 11:57:51 + PYENV_ROOT=/opt/pyenv 11:57:51 + 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 11:57:51 + 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 11:57:51 + pyenv versions 11:57:51 system 11:57:51 3.8.20 11:57:51 3.9.20 11:57:51 3.10.15 11:57:51 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 11:57:51 + command -v pyenv 11:57:51 ++ pyenv init - --no-rehash 11:57:51 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 11:57:51 for i in ${!paths[@]}; do 11:57:51 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 11:57:51 fi; done; 11:57:51 echo "${paths[*]}"'\'')" 11:57:51 export PATH="/opt/pyenv/shims:${PATH}" 11:57:51 export PYENV_SHELL=bash 11:57:51 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 11:57:51 pyenv() { 11:57:51 local command 11:57:51 command="${1:-}" 11:57:51 if [ "$#" -gt 0 ]; then 11:57:51 shift 11:57:51 fi 11:57:51 11:57:51 case "$command" in 11:57:51 rehash|shell) 11:57:51 eval "$(pyenv "sh-$command" "$@")" 11:57:51 ;; 11:57:51 *) 11:57:51 command pyenv "$command" "$@" 11:57:51 ;; 11:57:51 esac 11:57:51 }' 11:57:51 +++ bash --norc -ec 'IFS=:; paths=($PATH); 11:57:51 for i in ${!paths[@]}; do 11:57:51 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 11:57:51 fi; done; 11:57:51 echo "${paths[*]}"' 11:57:51 ++ 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 11:57:51 ++ 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 11:57:51 ++ 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 11:57:51 ++ export PYENV_SHELL=bash 11:57:51 ++ PYENV_SHELL=bash 11:57:51 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 11:57:51 +++ complete -F _pyenv pyenv 11:57:51 ++ lf-pyver python3 11:57:51 ++ local py_version_xy=python3 11:57:51 ++ local py_version_xyz= 11:57:51 ++ pyenv versions 11:57:51 ++ local command 11:57:51 ++ command=versions 11:57:51 ++ '[' 1 -gt 0 ']' 11:57:51 ++ shift 11:57:51 ++ case "$command" in 11:57:51 ++ command pyenv versions 11:57:51 ++ sed 's/^[ *]* //' 11:57:51 ++ awk '{ print $1 }' 11:57:51 ++ grep -E '^[0-9.]*[0-9]$' 11:57:51 ++ [[ ! -s /tmp/.pyenv_versions ]] 11:57:51 +++ grep '^3' /tmp/.pyenv_versions 11:57:51 +++ tail -n 1 11:57:51 +++ sort -V 11:57:51 ++ py_version_xyz=3.11.10 11:57:51 ++ [[ -z 3.11.10 ]] 11:57:51 ++ echo 3.11.10 11:57:51 ++ return 0 11:57:51 + pyenv local 3.11.10 11:57:51 + local command 11:57:51 + command=local 11:57:51 + '[' 2 -gt 0 ']' 11:57:51 + shift 11:57:51 + case "$command" in 11:57:51 + command pyenv local 3.11.10 11:57:51 + for arg in "$@" 11:57:51 + case $arg in 11:57:51 + pkg_list+='tox ' 11:57:51 + for arg in "$@" 11:57:51 + case $arg in 11:57:51 + pkg_list+='virtualenv ' 11:57:51 + for arg in "$@" 11:57:51 + case $arg in 11:57:51 + pkg_list+='urllib3~=1.26.15 ' 11:57:51 + [[ -f /tmp/.toxenv ]] 11:57:51 ++ cat /tmp/.toxenv 11:57:51 + lf_venv=/tmp/venv-JbYz 11:57:51 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-JbYz from' file:/tmp/.toxenv 11:57:51 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-JbYz from file:/tmp/.toxenv 11:57:51 + /tmp/venv-JbYz/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 11:57:52 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 11:57:52 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 11:57:52 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 11:57:52 + /tmp/venv-JbYz/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 11:57:55 + type python3 11:57:55 + true 11:57:55 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-JbYz/bin to PATH' 11:57:55 lf-activate-venv(): INFO: Adding /tmp/venv-JbYz/bin to PATH 11:57:55 + PATH=/tmp/venv-JbYz/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 11:57:55 + return 0 11:57:55 + [[ -d /opt/pyenv ]] 11:57:55 + echo '---> Setting up pyenv' 11:57:55 ---> Setting up pyenv 11:57:55 + export PYENV_ROOT=/opt/pyenv 11:57:55 + PYENV_ROOT=/opt/pyenv 11:57:55 + export PATH=/opt/pyenv/bin:/tmp/venv-JbYz/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 11:57:55 + PATH=/opt/pyenv/bin:/tmp/venv-JbYz/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 11:57:55 ++ pwd 11:57:55 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 11:57:55 + export PYTHONPATH 11:57:55 + export TOX_TESTENV_PASSENV=PYTHONPATH 11:57:55 + TOX_TESTENV_PASSENV=PYTHONPATH 11:57:55 + tox --version 11:57:55 4.27.0 from /tmp/venv-JbYz/lib/python3.11/site-packages/tox/__init__.py 11:57:55 + PARALLEL=True 11:57:55 + TOX_OPTIONS_LIST= 11:57:55 + [[ -n '' ]] 11:57:55 + case ${PARALLEL,,} in 11:57:55 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 11:57:55 + tox --parallel auto --parallel-live 11:57:55 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 11:57:57 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 11:57:57 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 11:57:57 checkbashisms: freeze> python -m pip freeze --all 11:57:57 docs: install_deps> python -I -m pip install -r docs/requirements.txt 11:57:57 checkbashisms: pip==25.1.1,setuptools==80.3.1 11:57:57 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 11:57:57 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)' 11:57:57 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 11:57:59 script ./reflectwarn.sh does not appear to have a #! interpreter line; 11:57:59 you may get strange results 11:58:00 checkbashisms: OK ✔ in 3.97 seconds 11:58:00 pre-commit: install_deps> python -I -m pip install pre-commit 11:58:07 pre-commit: freeze> python -m pip freeze --all 11:58:07 pre-commit: cfgv==3.4.0,distlib==0.4.0,filelock==3.18.0,identify==2.6.12,nodeenv==1.9.1,pip==25.1.1,platformdirs==4.3.8,pre_commit==4.2.0,PyYAML==6.0.2,setuptools==80.3.1,virtualenv==20.31.2 11:58:07 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 11:58:07 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)' 11:58:07 /usr/bin/cpan 11:58:07 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 11:58:07 [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. 11:58:07 [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. 11:58:07 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 11:58:07 [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. 11:58:07 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 11:58:08 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 11:58:08 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 11:58:09 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 11:58:09 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 11:58:10 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 11:58:10 [INFO] Once installed this environment will be reused. 11:58:10 [INFO] This may take a few minutes... 11:58:13 buildcontroller: freeze> python -m pip freeze --all 11:58:13 buildcontroller: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 11:58:13 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 11:58:13 + update-java-alternatives -l 11:58:13 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 11:58:13 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 11:58:13 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 11:58:13 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 11:58:13 update-alternatives: error: no alternatives for jaotc 11:58:13 update-alternatives: error: no alternatives for rmic 11:58:15 + java -version 11:58:15 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 11:58:15 + JAVA_VER=21 11:58:15 + echo 21 11:58:15 21 11:58:15 + javac -version 11:58:15 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 11:58:15 + JAVAC_VER=21 11:58:15 + echo 21 11:58:15 + [ 21 -ge 21 ] 11:58:15 + [ 21 -ge 21 ] 11:58:15 + echo ok, java is 21 or newer 11:58:15 21 11:58:15 ok, java is 21 or newer 11:58:15 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz -P /tmp 11:58:15 2025-07-18 11:58:15 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] 11:58:15 + sudo mkdir -p /opt 11:58:15 + sudo tar xf /tmp/apache-maven-3.9.11-bin.tar.gz -C /opt 11:58:15 + sudo ln -s /opt/apache-maven-3.9.11 /opt/maven 11:58:15 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 11:58:15 + mvn --version 11:58:15 Apache Maven 3.9.11 (3e54c93a704957b63ee3494413a2b544fd3d825b) 11:58:15 Maven home: /opt/maven 11:58:15 Java version: 21.0.5, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 11:58:15 Default locale: en, platform encoding: UTF-8 11:58:15 OS name: "linux", version: "5.15.0-131-generic", arch: "amd64", family: "unix" 11:58:16 NOTE: Picked up JDK_JAVA_OPTIONS: 11:58:16 --add-opens=java.base/java.io=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.lang=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.net=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.nio=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.nio.file=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.util=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.util.jar=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.util.stream=ALL-UNNAMED 11:58:16 --add-opens=java.base/java.util.zip=ALL-UNNAMED 11:58:16 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 11:58:16 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 11:58:16 -Xlog:disable 11:58:17 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 11:58:17 [INFO] Once installed this environment will be reused. 11:58:17 [INFO] This may take a few minutes... 11:58:25 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 11:58:25 [INFO] Once installed this environment will be reused. 11:58:25 [INFO] This may take a few minutes... 11:58:30 [INFO] Installing environment for https://github.com/perltidy/perltidy. 11:58:30 [INFO] Once installed this environment will be reused. 11:58:30 [INFO] This may take a few minutes... 11:58:34 docs-linkcheck: freeze> python -m pip freeze --all 11:58:34 docs: freeze> python -m pip freeze --all 11:58:34 docs-linkcheck: alabaster==1.0.0,attrs==25.3.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.7.14,charset-normalizer==3.4.2,contourpy==1.3.2,cycler==0.12.1,docutils==0.21.2,fonttools==4.59.0,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.8,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.10.3,numpy==2.3.1,nwdiag==3.0.0,packaging==25.0,pillow==11.3.0,pip==25.1.1,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.4,requests-file==1.5.1,roman-numerals-py==3.1.0,seqdiag==3.0.0,setuptools==80.3.1,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.30,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 11:58:34 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 11:58:35 docs: alabaster==1.0.0,attrs==25.3.0,babel==2.17.0,blockdiag==3.0.0,certifi==2025.7.14,charset-normalizer==3.4.2,contourpy==1.3.2,cycler==0.12.1,docutils==0.21.2,fonttools==4.59.0,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.8,lfdocs-conf==0.9.0,MarkupSafe==3.0.2,matplotlib==3.10.3,numpy==2.3.1,nwdiag==3.0.0,packaging==25.0,pillow==11.3.0,pip==25.1.1,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.4,requests-file==1.5.1,roman-numerals-py==3.1.0,seqdiag==3.0.0,setuptools==80.3.1,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.30,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 11:58:35 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 11:58:37 docs: OK ✔ in 41.82 seconds 11:58:37 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 11:58:41 docs-linkcheck: OK ✔ in 42.72 seconds 11:58:41 pylint: freeze> python -m pip freeze --all 11:58:41 trim trailing whitespace.................................................pylint: astroid==3.3.11,dill==0.4.0,isort==6.0.1,mccabe==0.7.0,pip==25.1.1,platformdirs==4.3.8,pylint==3.3.7,setuptools==80.3.1,tomlkit==0.13.3 11:58:41 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}$' '{}' + 11:58:41 Passed 11:58:41 Tabs remover.............................................................Passed 11:58:42 autopep8.................................................................Passed 11:58:48 perltidy.................................................................Passed 11:58:49 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 11:58:49 [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. 11:58:49 [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. 11:58:49 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 11:58:49 [INFO] Once installed this environment will be reused. 11:58:49 [INFO] This may take a few minutes... 11:59:00 gitlint..................................................................Passed 11:59:04 11:59:04 ------------------------------------ 11:59:04 Your code has been rated at 10.00/10 11:59:04 12:00:01 pre-commit: OK ✔ in 1 minute 1.42 seconds 12:00:01 pylint: OK ✔ in 28.8 seconds 12:00:01 buildcontroller: OK ✔ in 2 minutes 4.52 seconds 12:00:01 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 12:00:01 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 12:00:01 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 12:00:01 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 12:00:09 build_karaf_tests221: freeze> python -m pip freeze --all 12:00:09 sims: freeze> python -m pip freeze --all 12:00:09 build_karaf_tests121: freeze> python -m pip freeze --all 12:00:09 build_karaf_tests221: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:00:09 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:00:09 sims: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:00:09 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 12:00:09 Using lighynode version 20.1.0.5 12:00:09 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 12:00:09 NOTE: Picked up JDK_JAVA_OPTIONS: 12:00:09 --add-opens=java.base/java.io=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.net=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:00:09 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:00:09 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:00:09 -Xlog:disable 12:00:09 build_karaf_tests121: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:00:09 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:00:09 NOTE: Picked up JDK_JAVA_OPTIONS: 12:00:09 --add-opens=java.base/java.io=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.net=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:00:09 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:00:09 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:00:09 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:00:09 -Xlog:disable 12:00:14 sims: OK ✔ in 14.11 seconds 12:00:14 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 12:00:28 build_karaf_tests71: freeze> python -m pip freeze --all 12:00:28 build_karaf_tests71: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:00:28 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:00:28 NOTE: Picked up JDK_JAVA_OPTIONS: 12:00:28 --add-opens=java.base/java.io=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.lang=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.net=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.nio=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.util=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:00:28 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:00:28 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:00:28 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:00:28 -Xlog:disable 12:00:56 build_karaf_tests121: OK ✔ in 55.61 seconds 12:00:56 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 12:01:00 build_karaf_tests221: OK ✔ in 59.72 seconds 12:01:00 build_karaf_tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 12:01:25 build_karaf_tests71: OK ✔ in 1 minute 7.42 seconds 12:01:25 build_karaf_tests190: freeze> python -m pip freeze --all 12:01:26 build_karaf_tests190: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:01:26 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:01:26 NOTE: Picked up JDK_JAVA_OPTIONS: 12:01:26 --add-opens=java.base/java.io=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.lang=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.net=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.nio=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.util=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:01:26 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:01:26 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:01:26 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:01:26 -Xlog:disable 12:01:26 build_karaf_tests_hybrid: freeze> python -m pip freeze --all 12:01:26 build_karaf_tests_hybrid: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:01:26 build_karaf_tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:01:27 NOTE: Picked up JDK_JAVA_OPTIONS: 12:01:27 --add-opens=java.base/java.io=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.lang=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.net=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.nio=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.util=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:01:27 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:01:27 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:01:27 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:01:27 -Xlog:disable 12:01:58 testsPCE: freeze> python -m pip freeze --all 12:01:59 testsPCE: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,click==8.2.1,contourpy==1.3.2,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.7,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.59.0,gnpy4tpce==2.4.7,idna==3.10,iniconfig==2.1.0,injector==0.22.0,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.4.8,lxml==6.0.0,MarkupSafe==3.0.2,matplotlib==3.10.3,netconf-client==3.3.0,networkx==2.8.8,numpy==1.26.4,packaging==25.0,pandas==1.5.3,paramiko==3.5.1,pbr==5.11.1,pillow==11.3.0,pip==25.1.1,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.1,python-dateutil==2.9.0.post0,pytz==2025.2,requests==2.32.4,scipy==1.16.0,setuptools==50.3.2,six==1.17.0,urllib3==2.5.0,Werkzeug==2.0.3,xlrd==1.2.0 12:01:59 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 12:01:59 pytest -q transportpce_tests/pce/test01_pce.py 12:02:23 build_karaf_tests_hybrid: OK ✔ in 1 minute 23.15 seconds 12:02:23 build_karaf_tests190: OK ✔ in 1 minute 27.3 seconds 12:02:23 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 12:02:36 tests190: freeze> python -m pip freeze --all 12:02:36 tests190: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:02:36 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 12:02:36 using environment variables from ./karafoc.env 12:02:36 pytest -q transportpce_tests/oc/test01_portmapping.py 12:03:04 .................... [100%] 12:03:27 10 passed in 50.76s 12:03:27 pytest -q transportpce_tests/oc/test02_topology.py 12:03:29 ............... [100%] 12:04:08 20 passed in 128.79s (0:02:08) 12:04:08 pytest -q transportpce_tests/pce/test02_pce_400G.py 12:04:08 .......... [100%] 12:04:26 14 passed in 58.57s 12:04:26 pytest -q transportpce_tests/oc/test03_renderer.py 12:04:27 ................ [100%] 12:04:56 12 passed in 47.48s 12:04:56 pytest -q transportpce_tests/pce/test03_gnpy.py 12:04:57 .............. [100%] 12:05:14 19 passed in 48.13s 12:05:14 ........ [100%] 12:05:35 8 passed in 39.52s 12:05:35 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 12:06:07 ... [100%] 12:06:12 3 passed in 36.37s 12:06:12 tests190: OK ✔ in 2 minutes 51.6 seconds 12:06:12 testsPCE: OK ✔ in 6 minutes 12.29 seconds 12:06:12 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 12:06:19 tests_tapi: freeze> python -m pip freeze --all 12:06:19 tests_tapi: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:06:19 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 12:06:19 using environment variables from ./karaf221.env 12:06:19 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 12:07:27 ................................................... [100%] 12:13:35 51 passed in 435.33s (0:07:15) 12:13:35 pytest -q transportpce_tests/tapi/test02_full_topology.py 12:14:25 .................................... [100%] 12:22:01 36 passed in 505.29s (0:08:25) 12:22:01 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 12:22:47 ....................................................................... [100%] 12:27:07 71 passed in 305.65s (0:05:05) 12:27:07 pytest -q transportpce_tests/tapi/test04_topo_extension.py 12:27:57 ................... [100%] 12:29:26 19 passed in 139.16s (0:02:19) 12:29:26 tests_tapi: OK ✔ in 23 minutes 13.99 seconds 12:29:26 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 12:29:33 tests71: freeze> python -m pip freeze --all 12:29:34 tests71: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:29:34 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 12:29:34 using environment variables from ./karaf71.env 12:29:34 pytest -q transportpce_tests/7.1/test01_portmapping.py 12:30:03 ............ [100%] 12:30:17 12 passed in 42.83s 12:30:17 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 12:30:42 .............................................................. [100%] 12:32:52 62 passed in 155.22s (0:02:35) 12:32:52 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 12:33:23 ................................................ [100%] 12:35:06 48 passed in 134.12s (0:02:14) 12:35:07 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 12:35:32 ...................... [100%] 12:36:19 22 passed in 72.43s (0:01:12) 12:36:19 tests71: OK ✔ in 6 minutes 53.17 seconds 12:36:19 tests221: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 12:36:26 tests221: freeze> python -m pip freeze --all 12:36:26 tests221: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.3.1,urllib3==2.5.0 12:36:26 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 12:36:26 using environment variables from ./karaf221.env 12:36:26 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 12:37:01 ................................... [100%] 12:37:41 35 passed in 74.35s (0:01:14) 12:37:41 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 12:38:11 ...... [100%] 12:41:25 6 passed in 224.02s (0:03:44) 12:41:25 pytest -q transportpce_tests/2.2.1/test03_topology.py 12:42:07 ............................................ [100%] 12:43:42 44 passed in 136.38s (0:02:16) 12:43:42 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 12:44:17 ............ [100%] 12:44:41 12 passed in 58.80s 12:44:41 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 12:45:05 ................ [100%] 12:46:34 16 passed in 113.18s (0:01:53) 12:46:34 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 12:47:03 ............................... [100%] 12:47:09 31 passed in 34.93s 12:47:09 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 12:47:44 .......................... [100%] 12:48:39 26 passed in 89.67s (0:01:29) 12:48:39 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 12:49:15 ...................... [100%] 12:50:18 22 passed in 98.78s (0:01:38) 12:50:18 pytest -q transportpce_tests/2.2.1/test09_olm.py 12:50:58 ........................................ [100%] 12:53:19 40 passed in 180.29s (0:03:00) 12:53:19 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 12:54:01 ........................................................................ [ 74%] 12:59:37 ......................... [100%] 13:01:29 97 passed in 489.52s (0:08:09) 13:01:29 pytest -q transportpce_tests/2.2.1/test12_end2end.py 13:02:08 ...................................................... [100%] 13:08:55 54 passed in 445.70s (0:07:25) 13:08:55 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 13:09:49 ........................................................................ [ 71%] 13:14:56 ............................. [100%] 13:20:05 101 passed in 670.19s (0:11:10) 13:20:05 pytest -q transportpce_tests/2.2.1/test15_otn_end2end_with_intermediate_switch.py 13:20:58 ........................................................................ [ 67%] 13:26:43 ................................... [100%] 13:30:04 107 passed in 598.51s (0:09:58) 13:30:04 pytest -q transportpce_tests/2.2.1/test16_freq_end2end.py 13:30:45 ............................................. [100%] 13:33:22 45 passed in 197.39s (0:03:17) 13:33:22 tests221: OK ✔ in 57 minutes 2.38 seconds 13:33:22 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:33:28 tests121: freeze> python -m pip freeze --all 13:33:28 tests121: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.9.0,urllib3==2.5.0 13:33:28 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 13:33:28 using environment variables from ./karaf121.env 13:33:28 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 13:34:03 ..................... [100%] 13:34:52 21 passed in 83.80s (0:01:23) 13:34:53 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 13:35:24 ...... [100%] 13:35:38 6 passed in 45.00s 13:35:38 pytest -q transportpce_tests/1.2.1/test03_topology.py 13:36:19 ............................................ [100%] 13:37:54 44 passed in 135.64s (0:02:15) 13:37:54 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 13:38:24 ........................ [100%] 13:39:16 24 passed in 81.98s (0:01:21) 13:39:16 pytest -q transportpce_tests/1.2.1/test05_olm.py 13:39:55 ................F....................... [100%] 13:42:52 =================================== FAILURES =================================== 13:42:52 _____________ TransportOlmTesting.test_17_servicePath_create_AToZ ______________ 13:42:52 13:42:52 self = 13:42:52 conn = 13:42:52 method = 'POST' 13:42:52 url = '/rests/operations/transportpce-device-renderer:service-path' 13:42:52 body = '{"input": {"service-name": "test", "wave-number": "1", "modulation-format": "dp-qpsk", "operation": "create", "nodes"... 40, "min-freq": 196.075, "max-freq": 196.125, "lower-spectral-slot-number": 761, "higher-spectral-slot-number": 768}}' 13:42:52 headers = {'User-Agent': 'python-requests/2.32.4', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '593', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 13:42:52 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:42:52 timeout = Timeout(connect=30, read=30, total=None), chunked = False 13:42:52 response_conn = 13:42:52 preload_content = False, decode_content = False, enforce_content_length = True 13:42:52 13:42:52 def _make_request( 13:42:52 self, 13:42:52 conn: BaseHTTPConnection, 13:42:52 method: str, 13:42:52 url: str, 13:42:52 body: _TYPE_BODY | None = None, 13:42:52 headers: typing.Mapping[str, str] | None = None, 13:42:52 retries: Retry | None = None, 13:42:52 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:42:52 chunked: bool = False, 13:42:52 response_conn: BaseHTTPConnection | None = None, 13:42:52 preload_content: bool = True, 13:42:52 decode_content: bool = True, 13:42:52 enforce_content_length: bool = True, 13:42:52 ) -> BaseHTTPResponse: 13:42:52 """ 13:42:52 Perform a request on a given urllib connection object taken from our 13:42:52 pool. 13:42:52 13:42:52 :param conn: 13:42:52 a connection from one of our connection pools 13:42:52 13:42:52 :param method: 13:42:52 HTTP request method (such as GET, POST, PUT, etc.) 13:42:52 13:42:52 :param url: 13:42:52 The URL to perform the request on. 13:42:52 13:42:52 :param body: 13:42:52 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:42:52 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:42:52 13:42:52 :param headers: 13:42:52 Dictionary of custom headers to send, such as User-Agent, 13:42:52 If-None-Match, etc. If None, pool headers are used. If provided, 13:42:52 these headers completely replace any pool-specific headers. 13:42:52 13:42:52 :param retries: 13:42:52 Configure the number of retries to allow before raising a 13:42:52 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:42:52 13:42:52 Pass ``None`` to retry until you receive a response. Pass a 13:42:52 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:42:52 over different types of retries. 13:42:52 Pass an integer number to retry connection errors that many times, 13:42:52 but no other types of errors. Pass zero to never retry. 13:42:52 13:42:52 If ``False``, then retries are disabled and any exception is raised 13:42:52 immediately. Also, instead of raising a MaxRetryError on redirects, 13:42:52 the redirect response will be returned. 13:42:52 13:42:52 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:42:52 13:42:52 :param timeout: 13:42:52 If specified, overrides the default timeout for this one 13:42:52 request. It may be a float (in seconds) or an instance of 13:42:52 :class:`urllib3.util.Timeout`. 13:42:52 13:42:52 :param chunked: 13:42:52 If True, urllib3 will send the body using chunked transfer 13:42:52 encoding. Otherwise, urllib3 will send the body using the standard 13:42:52 content-length form. Defaults to False. 13:42:52 13:42:52 :param response_conn: 13:42:52 Set this to ``None`` if you will handle releasing the connection or 13:42:52 set the connection to have the response release it. 13:42:52 13:42:52 :param preload_content: 13:42:52 If True, the response's body will be preloaded during construction. 13:42:52 13:42:52 :param decode_content: 13:42:52 If True, will attempt to decode the body based on the 13:42:52 'content-encoding' header. 13:42:52 13:42:52 :param enforce_content_length: 13:42:52 Enforce content length checking. Body returned by server must match 13:42:52 value of Content-Length header, if present. Otherwise, raise error. 13:42:52 """ 13:42:52 self.num_requests += 1 13:42:52 13:42:52 timeout_obj = self._get_timeout(timeout) 13:42:52 timeout_obj.start_connect() 13:42:52 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 13:42:52 13:42:52 try: 13:42:52 # Trigger any extra validation we need to do. 13:42:52 try: 13:42:52 self._validate_conn(conn) 13:42:52 except (SocketTimeout, BaseSSLError) as e: 13:42:52 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 13:42:52 raise 13:42:52 13:42:52 # _validate_conn() starts the connection to an HTTPS proxy 13:42:52 # so we need to wrap errors with 'ProxyError' here too. 13:42:52 except ( 13:42:52 OSError, 13:42:52 NewConnectionError, 13:42:52 TimeoutError, 13:42:52 BaseSSLError, 13:42:52 CertificateError, 13:42:52 SSLError, 13:42:52 ) as e: 13:42:52 new_e: Exception = e 13:42:52 if isinstance(e, (BaseSSLError, CertificateError)): 13:42:52 new_e = SSLError(e) 13:42:52 # If the connection didn't successfully connect to it's proxy 13:42:52 # then there 13:42:52 if isinstance( 13:42:52 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 13:42:52 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 13:42:52 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 13:42:52 raise new_e 13:42:52 13:42:52 # conn.request() calls http.client.*.request, not the method in 13:42:52 # urllib3.request. It also calls makefile (recv) on the socket. 13:42:52 try: 13:42:52 conn.request( 13:42:52 method, 13:42:52 url, 13:42:52 body=body, 13:42:52 headers=headers, 13:42:52 chunked=chunked, 13:42:52 preload_content=preload_content, 13:42:52 decode_content=decode_content, 13:42:52 enforce_content_length=enforce_content_length, 13:42:52 ) 13:42:52 13:42:52 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 13:42:52 # legitimately able to close the connection after sending a valid response. 13:42:52 # With this behaviour, the received response is still readable. 13:42:52 except BrokenPipeError: 13:42:52 pass 13:42:52 except OSError as e: 13:42:52 # MacOS/Linux 13:42:52 # EPROTOTYPE and ECONNRESET are needed on macOS 13:42:52 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 13:42:52 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 13:42:52 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 13:42:52 raise 13:42:52 13:42:52 # Reset the timeout for the recv() on the socket 13:42:52 read_timeout = timeout_obj.read_timeout 13:42:52 13:42:52 if not conn.is_closed: 13:42:52 # In Python 3 socket.py will catch EAGAIN and return None when you 13:42:52 # try and read into the file pointer created by http.client, which 13:42:52 # instead raises a BadStatusLine exception. Instead of catching 13:42:52 # the exception and assuming all BadStatusLine exceptions are read 13:42:52 # timeouts, check for a zero timeout before making the request. 13:42:52 if read_timeout == 0: 13:42:52 raise ReadTimeoutError( 13:42:52 self, url, f"Read timed out. (read timeout={read_timeout})" 13:42:52 ) 13:42:52 conn.timeout = read_timeout 13:42:52 13:42:52 # Receive the response from the server 13:42:52 try: 13:42:52 > response = conn.getresponse() 13:42:52 ^^^^^^^^^^^^^^^^^^ 13:42:52 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connection.py:565: in getresponse 13:42:52 httplib_response = super().getresponse() 13:42:52 ^^^^^^^^^^^^^^^^^^^^^ 13:42:52 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 13:42:52 response.begin() 13:42:52 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 13:42:52 version, status, reason = self._read_status() 13:42:52 ^^^^^^^^^^^^^^^^^^^ 13:42:52 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 13:42:52 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 13:42:52 self = 13:42:52 b = 13:42:52 13:42:52 def readinto(self, b): 13:42:52 """Read up to len(b) bytes into the writable buffer *b* and return 13:42:52 the number of bytes read. If the socket is non-blocking and no bytes 13:42:52 are available, None is returned. 13:42:52 13:42:52 If *b* is non-empty, a 0 return value indicates that the connection 13:42:52 was shutdown at the other end. 13:42:52 """ 13:42:52 self._checkClosed() 13:42:52 self._checkReadable() 13:42:52 if self._timeout_occurred: 13:42:52 raise OSError("cannot read from timed out object") 13:42:52 while True: 13:42:52 try: 13:42:52 > return self._sock.recv_into(b) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 E TimeoutError: timed out 13:42:52 13:42:52 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 13:42:52 13:42:52 The above exception was the direct cause of the following exception: 13:42:52 13:42:52 self = 13:42:52 request = , stream = False 13:42:52 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:42:52 proxies = OrderedDict() 13:42:52 13:42:52 def send( 13:42:52 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:52 ): 13:42:52 """Sends PreparedRequest object. Returns Response object. 13:42:52 13:42:52 :param request: The :class:`PreparedRequest ` being sent. 13:42:52 :param stream: (optional) Whether to stream the request content. 13:42:52 :param timeout: (optional) How long to wait for the server to send 13:42:52 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:52 read timeout) ` tuple. 13:42:52 :type timeout: float or tuple or urllib3 Timeout object 13:42:52 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:52 we verify the server's TLS certificate, or a string, in which case it 13:42:52 must be a path to a CA bundle to use 13:42:52 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:52 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:52 :rtype: requests.Response 13:42:52 """ 13:42:52 13:42:52 try: 13:42:52 conn = self.get_connection_with_tls_context( 13:42:52 request, verify, proxies=proxies, cert=cert 13:42:52 ) 13:42:52 except LocationValueError as e: 13:42:52 raise InvalidURL(e, request=request) 13:42:52 13:42:52 self.cert_verify(conn, request.url, verify, cert) 13:42:52 url = self.request_url(request, proxies) 13:42:52 self.add_headers( 13:42:52 request, 13:42:52 stream=stream, 13:42:52 timeout=timeout, 13:42:52 verify=verify, 13:42:52 cert=cert, 13:42:52 proxies=proxies, 13:42:52 ) 13:42:52 13:42:52 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:52 13:42:52 if isinstance(timeout, tuple): 13:42:52 try: 13:42:52 connect, read = timeout 13:42:52 timeout = TimeoutSauce(connect=connect, read=read) 13:42:52 except ValueError: 13:42:52 raise ValueError( 13:42:52 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:52 f"or a single float to set both timeouts to the same value." 13:42:52 ) 13:42:52 elif isinstance(timeout, TimeoutSauce): 13:42:52 pass 13:42:52 else: 13:42:52 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:52 13:42:52 try: 13:42:52 > resp = conn.urlopen( 13:42:52 method=request.method, 13:42:52 url=url, 13:42:52 body=request.body, 13:42:52 headers=request.headers, 13:42:52 redirect=False, 13:42:52 assert_same_host=False, 13:42:52 preload_content=False, 13:42:52 decode_content=False, 13:42:52 retries=self.max_retries, 13:42:52 timeout=timeout, 13:42:52 chunked=chunked, 13:42:52 ) 13:42:52 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:667: 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 13:42:52 retries = retries.increment( 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/retry.py:474: in increment 13:42:52 raise reraise(type(error), error, _stacktrace) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 13:42:52 raise value 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 13:42:52 response = self._make_request( 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 13:42:52 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 13:42:52 self = 13:42:52 err = TimeoutError('timed out') 13:42:52 url = '/rests/operations/transportpce-device-renderer:service-path' 13:42:52 timeout_value = 30 13:42:52 13:42:52 def _raise_timeout( 13:42:52 self, 13:42:52 err: BaseSSLError | OSError | SocketTimeout, 13:42:52 url: str, 13:42:52 timeout_value: _TYPE_TIMEOUT | None, 13:42:52 ) -> None: 13:42:52 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 13:42:52 13:42:52 if isinstance(err, SocketTimeout): 13:42:52 > raise ReadTimeoutError( 13:42:52 self, url, f"Read timed out. (read timeout={timeout_value})" 13:42:52 ) from err 13:42:52 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8182): Read timed out. (read timeout=30) 13:42:52 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 13:42:52 13:42:52 During handling of the above exception, another exception occurred: 13:42:52 13:42:52 self = 13:42:52 13:42:52 def test_17_servicePath_create_AToZ(self): 13:42:52 > response = test_utils.transportpce_api_rpc_request( 13:42:52 'transportpce-device-renderer', 'service-path', 13:42:52 { 13:42:52 'service-name': 'test', 13:42:52 'wave-number': '1', 13:42:52 'modulation-format': 'dp-qpsk', 13:42:52 'operation': 'create', 13:42:52 'nodes': 13:42:52 [{'node-id': 'XPDRA01', 13:42:52 'dest-tp': 'XPDR1-NETWORK1', 'src-tp': 'XPDR1-CLIENT1'}, 13:42:52 {'node-id': 'ROADMA01', 13:42:52 'dest-tp': 'DEG1-TTP-TXRX', 'src-tp': 'SRG1-PP1-TXRX'}, 13:42:52 {'node-id': 'ROADMC01', 13:42:52 'dest-tp': 'SRG1-PP1-TXRX', 'src-tp': 'DEG2-TTP-TXRX'}, 13:42:52 {'node-id': 'XPDRC01', 13:42:52 'dest-tp': 'XPDR1-CLIENT1', 'src-tp': 'XPDR1-NETWORK1'}], 13:42:52 'center-freq': 196.1, 13:42:52 'nmc-width': 40, 13:42:52 'min-freq': 196.075, 13:42:52 'max-freq': 196.125, 13:42:52 'lower-spectral-slot-number': 761, 13:42:52 'higher-spectral-slot-number': 768 13:42:52 }) 13:42:52 13:42:52 transportpce_tests/1.2.1/test05_olm.py:213: 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 transportpce_tests/common/test_utils.py:729: in transportpce_api_rpc_request 13:42:52 response = post_request(url, data) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 transportpce_tests/common/test_utils.py:142: in post_request 13:42:52 return requests.request( 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/requests/api.py:59: in request 13:42:52 return session.request(method=method, url=url, **kwargs) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:42:52 resp = self.send(prep, **send_kwargs) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:42:52 r = adapter.send(request, **kwargs) 13:42:52 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:42:52 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:42:52 13:42:52 self = 13:42:52 request = , stream = False 13:42:52 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:42:52 proxies = OrderedDict() 13:42:52 13:42:52 def send( 13:42:52 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:42:52 ): 13:42:52 """Sends PreparedRequest object. Returns Response object. 13:42:52 13:42:52 :param request: The :class:`PreparedRequest ` being sent. 13:42:52 :param stream: (optional) Whether to stream the request content. 13:42:52 :param timeout: (optional) How long to wait for the server to send 13:42:52 data before giving up, as a float, or a :ref:`(connect timeout, 13:42:52 read timeout) ` tuple. 13:42:52 :type timeout: float or tuple or urllib3 Timeout object 13:42:52 :param verify: (optional) Either a boolean, in which case it controls whether 13:42:52 we verify the server's TLS certificate, or a string, in which case it 13:42:52 must be a path to a CA bundle to use 13:42:52 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:42:52 :param proxies: (optional) The proxies dictionary to apply to the request. 13:42:52 :rtype: requests.Response 13:42:52 """ 13:42:52 13:42:52 try: 13:42:52 conn = self.get_connection_with_tls_context( 13:42:52 request, verify, proxies=proxies, cert=cert 13:42:52 ) 13:42:52 except LocationValueError as e: 13:42:52 raise InvalidURL(e, request=request) 13:42:52 13:42:52 self.cert_verify(conn, request.url, verify, cert) 13:42:52 url = self.request_url(request, proxies) 13:42:52 self.add_headers( 13:42:52 request, 13:42:52 stream=stream, 13:42:52 timeout=timeout, 13:42:52 verify=verify, 13:42:52 cert=cert, 13:42:52 proxies=proxies, 13:42:52 ) 13:42:52 13:42:52 chunked = not (request.body is None or "Content-Length" in request.headers) 13:42:52 13:42:52 if isinstance(timeout, tuple): 13:42:52 try: 13:42:52 connect, read = timeout 13:42:52 timeout = TimeoutSauce(connect=connect, read=read) 13:42:52 except ValueError: 13:42:52 raise ValueError( 13:42:52 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:42:52 f"or a single float to set both timeouts to the same value." 13:42:52 ) 13:42:52 elif isinstance(timeout, TimeoutSauce): 13:42:52 pass 13:42:52 else: 13:42:52 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:42:52 13:42:52 try: 13:42:52 resp = conn.urlopen( 13:42:52 method=request.method, 13:42:52 url=url, 13:42:52 body=request.body, 13:42:52 headers=request.headers, 13:42:52 redirect=False, 13:42:52 assert_same_host=False, 13:42:52 preload_content=False, 13:42:52 decode_content=False, 13:42:52 retries=self.max_retries, 13:42:52 timeout=timeout, 13:42:52 chunked=chunked, 13:42:52 ) 13:42:52 13:42:52 except (ProtocolError, OSError) as err: 13:42:52 raise ConnectionError(err, request=request) 13:42:52 13:42:52 except MaxRetryError as e: 13:42:52 if isinstance(e.reason, ConnectTimeoutError): 13:42:52 # TODO: Remove this in 3.0.0: see #2811 13:42:52 if not isinstance(e.reason, NewConnectionError): 13:42:52 raise ConnectTimeout(e, request=request) 13:42:52 13:42:52 if isinstance(e.reason, ResponseError): 13:42:52 raise RetryError(e, request=request) 13:42:52 13:42:52 if isinstance(e.reason, _ProxyError): 13:42:52 raise ProxyError(e, request=request) 13:42:52 13:42:52 if isinstance(e.reason, _SSLError): 13:42:52 # This branch is for urllib3 v1.22 and later. 13:42:52 raise SSLError(e, request=request) 13:42:52 13:42:52 raise ConnectionError(e, request=request) 13:42:52 13:42:52 except ClosedPoolError as e: 13:42:52 raise ConnectionError(e, request=request) 13:42:52 13:42:52 except _ProxyError as e: 13:42:52 raise ProxyError(e) 13:42:52 13:42:52 except (_SSLError, _HTTPError) as e: 13:42:52 if isinstance(e, _SSLError): 13:42:52 # This branch is for urllib3 versions earlier than v1.22 13:42:52 raise SSLError(e, request=request) 13:42:52 elif isinstance(e, ReadTimeoutError): 13:42:52 > raise ReadTimeout(e, request=request) 13:42:52 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8182): Read timed out. (read timeout=30) 13:42:52 13:42:52 ../.tox/tests121/lib/python3.11/site-packages/requests/adapters.py:713: ReadTimeout 13:42:52 ----------------------------- Captured stdout call ----------------------------- 13:42:52 execution of test_17_servicePath_create_AToZ 13:42:52 =========================== short test summary info ============================ 13:42:52 FAILED transportpce_tests/1.2.1/test05_olm.py::TransportOlmTesting::test_17_servicePath_create_AToZ 13:42:52 1 failed, 39 passed in 215.57s (0:03:35) 13:42:52 tests121: exit 1 (563.42 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 pid=36182 13:42:52 tests121: FAIL ✖ in 9 minutes 30.18 seconds 13:42:52 tests_hybrid: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 13:42:59 tests_hybrid: freeze> python -m pip freeze --all 13:43:00 tests_hybrid: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.9.0,urllib3==2.5.0 13:43:00 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 13:43:00 using environment variables from ./karaf121.env 13:43:00 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 13:44:15 F.................................................. [100%] 13:49:12 =================================== FAILURES =================================== 13:49:12 ________________ TransportPCEFulltesting.test_01_connect_xpdrA _________________ 13:49:12 13:49:12 self = 13:49:12 conn = 13:49:12 method = 'PUT' 13:49:12 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01' 13:49:12 body = '{"node": [{"node-id": "XPDRA01", "netconf-node-topology:netconf-node": {"netconf-node-topology:host": "127.0.0.1", "n...ff-millis": 1800000, "netconf-node-topology:backoff-multiplier": 1.5, "netconf-node-topology:keepalive-delay": 120}}]}' 13:49:12 headers = {'User-Agent': 'python-requests/2.32.4', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '709', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 13:49:12 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:49:12 timeout = Timeout(connect=30, read=30, total=None), chunked = False 13:49:12 response_conn = 13:49:12 preload_content = False, decode_content = False, enforce_content_length = True 13:49:12 13:49:12 def _make_request( 13:49:12 self, 13:49:12 conn: BaseHTTPConnection, 13:49:12 method: str, 13:49:12 url: str, 13:49:12 body: _TYPE_BODY | None = None, 13:49:12 headers: typing.Mapping[str, str] | None = None, 13:49:12 retries: Retry | None = None, 13:49:12 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:49:12 chunked: bool = False, 13:49:12 response_conn: BaseHTTPConnection | None = None, 13:49:12 preload_content: bool = True, 13:49:12 decode_content: bool = True, 13:49:12 enforce_content_length: bool = True, 13:49:12 ) -> BaseHTTPResponse: 13:49:12 """ 13:49:12 Perform a request on a given urllib connection object taken from our 13:49:12 pool. 13:49:12 13:49:12 :param conn: 13:49:12 a connection from one of our connection pools 13:49:12 13:49:12 :param method: 13:49:12 HTTP request method (such as GET, POST, PUT, etc.) 13:49:12 13:49:12 :param url: 13:49:12 The URL to perform the request on. 13:49:12 13:49:12 :param body: 13:49:12 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:49:12 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:49:12 13:49:12 :param headers: 13:49:12 Dictionary of custom headers to send, such as User-Agent, 13:49:12 If-None-Match, etc. If None, pool headers are used. If provided, 13:49:12 these headers completely replace any pool-specific headers. 13:49:12 13:49:12 :param retries: 13:49:12 Configure the number of retries to allow before raising a 13:49:12 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:49:12 13:49:12 Pass ``None`` to retry until you receive a response. Pass a 13:49:12 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:49:12 over different types of retries. 13:49:12 Pass an integer number to retry connection errors that many times, 13:49:12 but no other types of errors. Pass zero to never retry. 13:49:12 13:49:12 If ``False``, then retries are disabled and any exception is raised 13:49:12 immediately. Also, instead of raising a MaxRetryError on redirects, 13:49:12 the redirect response will be returned. 13:49:12 13:49:12 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:49:12 13:49:12 :param timeout: 13:49:12 If specified, overrides the default timeout for this one 13:49:12 request. It may be a float (in seconds) or an instance of 13:49:12 :class:`urllib3.util.Timeout`. 13:49:12 13:49:12 :param chunked: 13:49:12 If True, urllib3 will send the body using chunked transfer 13:49:12 encoding. Otherwise, urllib3 will send the body using the standard 13:49:12 content-length form. Defaults to False. 13:49:12 13:49:12 :param response_conn: 13:49:12 Set this to ``None`` if you will handle releasing the connection or 13:49:12 set the connection to have the response release it. 13:49:12 13:49:12 :param preload_content: 13:49:12 If True, the response's body will be preloaded during construction. 13:49:12 13:49:12 :param decode_content: 13:49:12 If True, will attempt to decode the body based on the 13:49:12 'content-encoding' header. 13:49:12 13:49:12 :param enforce_content_length: 13:49:12 Enforce content length checking. Body returned by server must match 13:49:12 value of Content-Length header, if present. Otherwise, raise error. 13:49:12 """ 13:49:12 self.num_requests += 1 13:49:12 13:49:12 timeout_obj = self._get_timeout(timeout) 13:49:12 timeout_obj.start_connect() 13:49:12 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 13:49:12 13:49:12 try: 13:49:12 # Trigger any extra validation we need to do. 13:49:12 try: 13:49:12 self._validate_conn(conn) 13:49:12 except (SocketTimeout, BaseSSLError) as e: 13:49:12 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 13:49:12 raise 13:49:12 13:49:12 # _validate_conn() starts the connection to an HTTPS proxy 13:49:12 # so we need to wrap errors with 'ProxyError' here too. 13:49:12 except ( 13:49:12 OSError, 13:49:12 NewConnectionError, 13:49:12 TimeoutError, 13:49:12 BaseSSLError, 13:49:12 CertificateError, 13:49:12 SSLError, 13:49:12 ) as e: 13:49:12 new_e: Exception = e 13:49:12 if isinstance(e, (BaseSSLError, CertificateError)): 13:49:12 new_e = SSLError(e) 13:49:12 # If the connection didn't successfully connect to it's proxy 13:49:12 # then there 13:49:12 if isinstance( 13:49:12 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 13:49:12 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 13:49:12 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 13:49:12 raise new_e 13:49:12 13:49:12 # conn.request() calls http.client.*.request, not the method in 13:49:12 # urllib3.request. It also calls makefile (recv) on the socket. 13:49:12 try: 13:49:12 conn.request( 13:49:12 method, 13:49:12 url, 13:49:12 body=body, 13:49:12 headers=headers, 13:49:12 chunked=chunked, 13:49:12 preload_content=preload_content, 13:49:12 decode_content=decode_content, 13:49:12 enforce_content_length=enforce_content_length, 13:49:12 ) 13:49:12 13:49:12 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 13:49:12 # legitimately able to close the connection after sending a valid response. 13:49:12 # With this behaviour, the received response is still readable. 13:49:12 except BrokenPipeError: 13:49:12 pass 13:49:12 except OSError as e: 13:49:12 # MacOS/Linux 13:49:12 # EPROTOTYPE and ECONNRESET are needed on macOS 13:49:12 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 13:49:12 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 13:49:12 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 13:49:12 raise 13:49:12 13:49:12 # Reset the timeout for the recv() on the socket 13:49:12 read_timeout = timeout_obj.read_timeout 13:49:12 13:49:12 if not conn.is_closed: 13:49:12 # In Python 3 socket.py will catch EAGAIN and return None when you 13:49:12 # try and read into the file pointer created by http.client, which 13:49:12 # instead raises a BadStatusLine exception. Instead of catching 13:49:12 # the exception and assuming all BadStatusLine exceptions are read 13:49:12 # timeouts, check for a zero timeout before making the request. 13:49:12 if read_timeout == 0: 13:49:12 raise ReadTimeoutError( 13:49:12 self, url, f"Read timed out. (read timeout={read_timeout})" 13:49:12 ) 13:49:12 conn.timeout = read_timeout 13:49:12 13:49:12 # Receive the response from the server 13:49:12 try: 13:49:12 > response = conn.getresponse() 13:49:12 ^^^^^^^^^^^^^^^^^^ 13:49:12 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connection.py:565: in getresponse 13:49:12 httplib_response = super().getresponse() 13:49:12 ^^^^^^^^^^^^^^^^^^^^^ 13:49:12 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 13:49:12 response.begin() 13:49:12 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 13:49:12 version, status, reason = self._read_status() 13:49:12 ^^^^^^^^^^^^^^^^^^^ 13:49:12 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 13:49:12 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 13:49:12 self = 13:49:12 b = 13:49:12 13:49:12 def readinto(self, b): 13:49:12 """Read up to len(b) bytes into the writable buffer *b* and return 13:49:12 the number of bytes read. If the socket is non-blocking and no bytes 13:49:12 are available, None is returned. 13:49:12 13:49:12 If *b* is non-empty, a 0 return value indicates that the connection 13:49:12 was shutdown at the other end. 13:49:12 """ 13:49:12 self._checkClosed() 13:49:12 self._checkReadable() 13:49:12 if self._timeout_occurred: 13:49:12 raise OSError("cannot read from timed out object") 13:49:12 while True: 13:49:12 try: 13:49:12 > return self._sock.recv_into(b) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 E TimeoutError: timed out 13:49:12 13:49:12 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 13:49:12 13:49:12 The above exception was the direct cause of the following exception: 13:49:12 13:49:12 self = 13:49:12 request = , stream = False 13:49:12 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:49:12 proxies = OrderedDict() 13:49:12 13:49:12 def send( 13:49:12 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:49:12 ): 13:49:12 """Sends PreparedRequest object. Returns Response object. 13:49:12 13:49:12 :param request: The :class:`PreparedRequest ` being sent. 13:49:12 :param stream: (optional) Whether to stream the request content. 13:49:12 :param timeout: (optional) How long to wait for the server to send 13:49:12 data before giving up, as a float, or a :ref:`(connect timeout, 13:49:12 read timeout) ` tuple. 13:49:12 :type timeout: float or tuple or urllib3 Timeout object 13:49:12 :param verify: (optional) Either a boolean, in which case it controls whether 13:49:12 we verify the server's TLS certificate, or a string, in which case it 13:49:12 must be a path to a CA bundle to use 13:49:12 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:49:12 :param proxies: (optional) The proxies dictionary to apply to the request. 13:49:12 :rtype: requests.Response 13:49:12 """ 13:49:12 13:49:12 try: 13:49:12 conn = self.get_connection_with_tls_context( 13:49:12 request, verify, proxies=proxies, cert=cert 13:49:12 ) 13:49:12 except LocationValueError as e: 13:49:12 raise InvalidURL(e, request=request) 13:49:12 13:49:12 self.cert_verify(conn, request.url, verify, cert) 13:49:12 url = self.request_url(request, proxies) 13:49:12 self.add_headers( 13:49:12 request, 13:49:12 stream=stream, 13:49:12 timeout=timeout, 13:49:12 verify=verify, 13:49:12 cert=cert, 13:49:12 proxies=proxies, 13:49:12 ) 13:49:12 13:49:12 chunked = not (request.body is None or "Content-Length" in request.headers) 13:49:12 13:49:12 if isinstance(timeout, tuple): 13:49:12 try: 13:49:12 connect, read = timeout 13:49:12 timeout = TimeoutSauce(connect=connect, read=read) 13:49:12 except ValueError: 13:49:12 raise ValueError( 13:49:12 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:49:12 f"or a single float to set both timeouts to the same value." 13:49:12 ) 13:49:12 elif isinstance(timeout, TimeoutSauce): 13:49:12 pass 13:49:12 else: 13:49:12 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:49:12 13:49:12 try: 13:49:12 > resp = conn.urlopen( 13:49:12 method=request.method, 13:49:12 url=url, 13:49:12 body=request.body, 13:49:12 headers=request.headers, 13:49:12 redirect=False, 13:49:12 assert_same_host=False, 13:49:12 preload_content=False, 13:49:12 decode_content=False, 13:49:12 retries=self.max_retries, 13:49:12 timeout=timeout, 13:49:12 chunked=chunked, 13:49:12 ) 13:49:12 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/requests/adapters.py:667: 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 13:49:12 retries = retries.increment( 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/util/retry.py:474: in increment 13:49:12 raise reraise(type(error), error, _stacktrace) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 13:49:12 raise value 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 13:49:12 response = self._make_request( 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 13:49:12 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 13:49:12 self = 13:49:12 err = TimeoutError('timed out') 13:49:12 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=XPDRA01' 13:49:12 timeout_value = 30 13:49:12 13:49:12 def _raise_timeout( 13:49:12 self, 13:49:12 err: BaseSSLError | OSError | SocketTimeout, 13:49:12 url: str, 13:49:12 timeout_value: _TYPE_TIMEOUT | None, 13:49:12 ) -> None: 13:49:12 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 13:49:12 13:49:12 if isinstance(err, SocketTimeout): 13:49:12 > raise ReadTimeoutError( 13:49:12 self, url, f"Read timed out. (read timeout={timeout_value})" 13:49:12 ) from err 13:49:12 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8182): Read timed out. (read timeout=30) 13:49:12 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 13:49:12 13:49:12 During handling of the above exception, another exception occurred: 13:49:12 13:49:12 self = 13:49:12 13:49:12 def test_01_connect_xpdrA(self): 13:49:12 > response = test_utils.mount_device("XPDRA01", ('xpdra', self.NODE_VERSION_121)) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 13:49:12 transportpce_tests/hybrid/test01_device_change_notifications.py:96: 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 transportpce_tests/common/test_utils.py:362: in mount_device 13:49:12 response = put_request(url[RESTCONF_VERSION].format('{}', node), body) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 transportpce_tests/common/test_utils.py:124: in put_request 13:49:12 return requests.request( 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/requests/api.py:59: in request 13:49:12 return session.request(method=method, url=url, **kwargs) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:49:12 resp = self.send(prep, **send_kwargs) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:49:12 r = adapter.send(request, **kwargs) 13:49:12 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:49:12 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:49:12 13:49:12 self = 13:49:12 request = , stream = False 13:49:12 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:49:12 proxies = OrderedDict() 13:49:12 13:49:12 def send( 13:49:12 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:49:12 ): 13:49:12 """Sends PreparedRequest object. Returns Response object. 13:49:12 13:49:12 :param request: The :class:`PreparedRequest ` being sent. 13:49:12 :param stream: (optional) Whether to stream the request content. 13:49:12 :param timeout: (optional) How long to wait for the server to send 13:49:12 data before giving up, as a float, or a :ref:`(connect timeout, 13:49:12 read timeout) ` tuple. 13:49:12 :type timeout: float or tuple or urllib3 Timeout object 13:49:12 :param verify: (optional) Either a boolean, in which case it controls whether 13:49:12 we verify the server's TLS certificate, or a string, in which case it 13:49:12 must be a path to a CA bundle to use 13:49:12 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:49:12 :param proxies: (optional) The proxies dictionary to apply to the request. 13:49:12 :rtype: requests.Response 13:49:12 """ 13:49:12 13:49:12 try: 13:49:12 conn = self.get_connection_with_tls_context( 13:49:12 request, verify, proxies=proxies, cert=cert 13:49:12 ) 13:49:12 except LocationValueError as e: 13:49:12 raise InvalidURL(e, request=request) 13:49:12 13:49:12 self.cert_verify(conn, request.url, verify, cert) 13:49:12 url = self.request_url(request, proxies) 13:49:12 self.add_headers( 13:49:12 request, 13:49:12 stream=stream, 13:49:12 timeout=timeout, 13:49:12 verify=verify, 13:49:12 cert=cert, 13:49:12 proxies=proxies, 13:49:12 ) 13:49:12 13:49:12 chunked = not (request.body is None or "Content-Length" in request.headers) 13:49:12 13:49:12 if isinstance(timeout, tuple): 13:49:12 try: 13:49:12 connect, read = timeout 13:49:12 timeout = TimeoutSauce(connect=connect, read=read) 13:49:12 except ValueError: 13:49:12 raise ValueError( 13:49:12 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:49:12 f"or a single float to set both timeouts to the same value." 13:49:12 ) 13:49:12 elif isinstance(timeout, TimeoutSauce): 13:49:12 pass 13:49:12 else: 13:49:12 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:49:12 13:49:12 try: 13:49:12 resp = conn.urlopen( 13:49:12 method=request.method, 13:49:12 url=url, 13:49:12 body=request.body, 13:49:12 headers=request.headers, 13:49:12 redirect=False, 13:49:12 assert_same_host=False, 13:49:12 preload_content=False, 13:49:12 decode_content=False, 13:49:12 retries=self.max_retries, 13:49:12 timeout=timeout, 13:49:12 chunked=chunked, 13:49:12 ) 13:49:12 13:49:12 except (ProtocolError, OSError) as err: 13:49:12 raise ConnectionError(err, request=request) 13:49:12 13:49:12 except MaxRetryError as e: 13:49:12 if isinstance(e.reason, ConnectTimeoutError): 13:49:12 # TODO: Remove this in 3.0.0: see #2811 13:49:12 if not isinstance(e.reason, NewConnectionError): 13:49:12 raise ConnectTimeout(e, request=request) 13:49:12 13:49:12 if isinstance(e.reason, ResponseError): 13:49:12 raise RetryError(e, request=request) 13:49:12 13:49:12 if isinstance(e.reason, _ProxyError): 13:49:12 raise ProxyError(e, request=request) 13:49:12 13:49:12 if isinstance(e.reason, _SSLError): 13:49:12 # This branch is for urllib3 v1.22 and later. 13:49:12 raise SSLError(e, request=request) 13:49:12 13:49:12 raise ConnectionError(e, request=request) 13:49:12 13:49:12 except ClosedPoolError as e: 13:49:12 raise ConnectionError(e, request=request) 13:49:12 13:49:12 except _ProxyError as e: 13:49:12 raise ProxyError(e) 13:49:12 13:49:12 except (_SSLError, _HTTPError) as e: 13:49:12 if isinstance(e, _SSLError): 13:49:12 # This branch is for urllib3 versions earlier than v1.22 13:49:12 raise SSLError(e, request=request) 13:49:12 elif isinstance(e, ReadTimeoutError): 13:49:12 > raise ReadTimeout(e, request=request) 13:49:12 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8182): Read timed out. (read timeout=30) 13:49:12 13:49:12 ../.tox/tests_hybrid/lib/python3.11/site-packages/requests/adapters.py:713: ReadTimeout 13:49:12 ---------------------------- Captured stdout setup ----------------------------- 13:49:12 starting OpenDaylight... 13:49:12 starting KARAF TransportPCE build... 13:49:12 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 13:49:12 starting simulator xpdra in OpenROADM device version 1.2.1... 13:49:12 Searching for patterns in xpdra-121.log... Pattern found! simulator for xpdra started 13:49:12 starting simulator roadma in OpenROADM device version 2.2.1... 13:49:12 Searching for patterns in roadma-221.log... Pattern found! simulator for roadma started 13:49:12 starting simulator roadmc in OpenROADM device version 2.2.1... 13:49:12 Searching for patterns in roadmc-221.log... Pattern found! simulator for roadmc started 13:49:12 starting simulator xpdrc in OpenROADM device version 7.1... 13:49:12 Searching for patterns in xpdrc-71.log... Pattern found! simulator for xpdrc started 13:49:12 ----------------------------- Captured stdout call ----------------------------- 13:49:12 execution of test_01_connect_xpdrA 13:49:12 =========================== short test summary info ============================ 13:49:12 FAILED transportpce_tests/hybrid/test01_device_change_notifications.py::TransportPCEFulltesting::test_01_connect_xpdrA 13:49:12 1 failed, 50 passed in 371.96s (0:06:11) 13:49:12 tests_hybrid: exit 1 (372.27 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid pid=40580 13:49:12 tests_hybrid: FAIL ✖ in 6 minutes 20.22 seconds 13:49:12 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:49:21 buildlighty: freeze> python -m pip freeze --all 13:49:22 buildlighty: bcrypt==4.3.0,certifi==2025.7.14,cffi==1.17.1,charset-normalizer==3.4.2,cryptography==45.0.5,dict2xml==1.7.7,idna==3.10,iniconfig==2.1.0,lxml==6.0.0,netconf-client==3.3.0,packaging==25.0,paramiko==3.5.1,pip==25.1.1,pluggy==1.6.0,psutil==7.0.0,pycparser==2.22,Pygments==2.19.2,PyNaCl==1.5.0,pytest==8.4.1,requests==2.32.4,setuptools==80.9.0,urllib3==2.5.0 13:49:22 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 13:49:22 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 13:49:46 buildcontroller: OK (124.52=setup[17.87]+cmd[106.65] seconds) 13:49:46 testsPCE: OK (372.29=setup[118.82]+cmd[253.47] seconds) 13:49:46 sims: OK (14.11=setup[9.06]+cmd[5.05] seconds) 13:49:46 build_karaf_tests121: OK (55.61=setup[9.21]+cmd[46.41] seconds) 13:49:46 tests121: FAIL code 1 (570.18=setup[6.76]+cmd[563.42] seconds) 13:49:46 build_karaf_tests221: OK (59.72=setup[9.03]+cmd[50.69] seconds) 13:49:46 tests_tapi: OK (1393.99=setup[7.37]+cmd[1386.63] seconds) 13:49:46 tests221: OK (3422.38=setup[6.72]+cmd[3415.66] seconds) 13:49:46 build_karaf_tests71: OK (67.42=setup[14.42]+cmd[53.00] seconds) 13:49:46 tests71: OK (413.17=setup[7.44]+cmd[405.73] seconds) 13:49:46 build_karaf_tests190: OK (87.30=setup[30.34]+cmd[56.96] seconds) 13:49:46 tests190: OK (171.60=setup[13.26]+cmd[158.33] seconds) 13:49:46 build_karaf_tests_hybrid: OK (83.15=setup[27.05]+cmd[56.09] seconds) 13:49:46 tests_hybrid: FAIL code 1 (380.22=setup[7.96]+cmd[372.27] seconds) 13:49:46 buildlighty: OK (33.56=setup[9.73]+cmd[23.83] seconds) 13:49:46 docs: OK (41.81=setup[39.34]+cmd[2.48] seconds) 13:49:46 docs-linkcheck: OK (42.72=setup[38.86]+cmd[3.86] seconds) 13:49:46 checkbashisms: OK (3.97=setup[2.03]+cmd[0.05,0.07,1.83] seconds) 13:49:46 pre-commit: OK (61.42=setup[7.69]+cmd[0.01,0.00,41.60,12.12] seconds) 13:49:46 pylint: OK (28.80=setup[4.22]+cmd[24.59] seconds) 13:49:46 evaluation failed :( (6710.40 seconds) 13:49:46 + tox_status=255 13:49:46 + echo '---> Completed tox runs' 13:49:46 ---> Completed tox runs 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/build_karaf_tests121/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=build_karaf_tests121 13:49:46 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/build_karaf_tests190/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=build_karaf_tests190 13:49:46 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/build_karaf_tests221/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=build_karaf_tests221 13:49:46 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/build_karaf_tests71/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=build_karaf_tests71 13:49:46 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/build_karaf_tests_hybrid/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=build_karaf_tests_hybrid 13:49:46 + cp -r .tox/build_karaf_tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests_hybrid 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/buildcontroller/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=buildcontroller 13:49:46 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/buildlighty/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=buildlighty 13:49:46 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/checkbashisms/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=checkbashisms 13:49:46 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/docs-linkcheck/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=docs-linkcheck 13:49:46 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/docs/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=docs 13:49:46 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/pre-commit/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=pre-commit 13:49:46 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/pylint/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=pylint 13:49:46 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/sims/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=sims 13:49:46 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests121/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests121 13:49:46 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests190/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests190 13:49:46 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests221/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests221 13:49:46 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests71/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests71 13:49:46 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/testsPCE/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=testsPCE 13:49:46 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests_hybrid/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests_hybrid 13:49:46 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 13:49:46 + for i in .tox/*/log 13:49:46 ++ echo .tox/tests_tapi/log 13:49:46 ++ awk -F/ '{print $2}' 13:49:46 + tox_env=tests_tapi 13:49:46 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 13:49:46 + DOC_DIR=docs/_build/html 13:49:46 + [[ -d docs/_build/html ]] 13:49:46 + echo '---> Archiving generated docs' 13:49:46 ---> Archiving generated docs 13:49:46 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:49:46 + echo '---> tox-run.sh ends' 13:49:46 ---> tox-run.sh ends 13:49:46 + test 255 -eq 0 13:49:46 + exit 255 13:49:46 ++ '[' 1 = 1 ']' 13:49:46 ++ '[' -x /usr/bin/clear_console ']' 13:49:46 ++ /usr/bin/clear_console -q 13:49:46 Build step 'Execute shell' marked build as failure 13:49:46 $ ssh-agent -k 13:49:46 unset SSH_AUTH_SOCK; 13:49:46 unset SSH_AGENT_PID; 13:49:46 echo Agent pid 1573 killed; 13:49:46 [ssh-agent] Stopped. 13:49:46 [PostBuildScript] - [INFO] Executing post build scripts. 13:49:46 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9201624490594358244.sh 13:49:46 ---> sysstat.sh 13:49:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7331748156460643715.sh 13:49:47 ---> package-listing.sh 13:49:47 ++ facter osfamily 13:49:47 ++ tr '[:upper:]' '[:lower:]' 13:49:47 + OS_FAMILY=debian 13:49:47 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 13:49:47 + START_PACKAGES=/tmp/packages_start.txt 13:49:47 + END_PACKAGES=/tmp/packages_end.txt 13:49:47 + DIFF_PACKAGES=/tmp/packages_diff.txt 13:49:47 + PACKAGES=/tmp/packages_start.txt 13:49:47 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:49:47 + PACKAGES=/tmp/packages_end.txt 13:49:47 + case "${OS_FAMILY}" in 13:49:47 + dpkg -l 13:49:47 + grep '^ii' 13:49:47 + '[' -f /tmp/packages_start.txt ']' 13:49:47 + '[' -f /tmp/packages_end.txt ']' 13:49:47 + diff /tmp/packages_start.txt /tmp/packages_end.txt 13:49:47 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:49:47 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:49:47 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:49:47 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins17171716314340381751.sh 13:49:47 ---> capture-instance-metadata.sh 13:49:47 Setup pyenv: 13:49:47 system 13:49:47 3.8.20 13:49:47 3.9.20 13:49:47 3.10.15 13:49:47 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:49:47 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-z8bK from file:/tmp/.os_lf_venv 13:49:50 lf-activate-venv(): INFO: Installing: lftools 13:50:05 lf-activate-venv(): INFO: Adding /tmp/venv-z8bK/bin to PATH 13:50:06 INFO: Running in OpenStack, capturing instance metadata 13:50:06 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9686785151591549167.sh 13:50:06 provisioning config files... 13:50:07 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #3468 13:50:07 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config15050211754329452710tmp 13:50:07 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 13:50:07 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 13:50:07 provisioning config files... 13:50:07 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 13:50:07 [EnvInject] - Injecting environment variables from a build step. 13:50:07 [EnvInject] - Injecting as environment variables the properties content 13:50:07 SERVER_ID=logs 13:50:07 13:50:07 [EnvInject] - Variables injected successfully. 13:50:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8738949444120474755.sh 13:50:07 ---> create-netrc.sh 13:50:07 WARN: Log server credential not found. 13:50:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14939702762388532472.sh 13:50:07 ---> python-tools-install.sh 13:50:07 Setup pyenv: 13:50:07 system 13:50:07 3.8.20 13:50:07 3.9.20 13:50:07 3.10.15 13:50:07 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:50:07 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-z8bK from file:/tmp/.os_lf_venv 13:50:09 lf-activate-venv(): INFO: Installing: lftools 13:50:26 lf-activate-venv(): INFO: Adding /tmp/venv-z8bK/bin to PATH 13:50:26 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins14408676216142691734.sh 13:50:26 ---> sudo-logs.sh 13:50:26 Archiving 'sudo' log.. 13:50:26 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6603733563448016009.sh 13:50:26 ---> job-cost.sh 13:50:26 Setup pyenv: 13:50:26 system 13:50:26 3.8.20 13:50:26 3.9.20 13:50:26 3.10.15 13:50:26 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:50:26 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-z8bK from file:/tmp/.os_lf_venv 13:50:28 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 13:50:35 lf-activate-venv(): INFO: Adding /tmp/venv-z8bK/bin to PATH 13:50:35 INFO: No Stack... 13:50:36 INFO: Retrieving Pricing Info for: v3-standard-4 13:50:36 INFO: Archiving Costs 13:50:36 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins5968264842026650152.sh 13:50:36 ---> logs-deploy.sh 13:50:36 Setup pyenv: 13:50:36 system 13:50:36 3.8.20 13:50:36 3.9.20 13:50:36 3.10.15 13:50:36 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:50:36 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-z8bK from file:/tmp/.os_lf_venv 13:50:39 lf-activate-venv(): INFO: Installing: lftools 13:50:51 lf-activate-venv(): INFO: Adding /tmp/venv-z8bK/bin to PATH 13:50:51 WARNING: Nexus logging server not set 13:50:51 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/3468/ 13:50:51 INFO: archiving logs to S3 13:50:55 ---> uname -a: 13:50:55 Linux prd-ubuntu2204-docker-4c-16g-43768 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:50:55 13:50:55 13:50:55 ---> lscpu: 13:50:55 Architecture: x86_64 13:50:55 CPU op-mode(s): 32-bit, 64-bit 13:50:55 Address sizes: 40 bits physical, 48 bits virtual 13:50:55 Byte Order: Little Endian 13:50:55 CPU(s): 4 13:50:55 On-line CPU(s) list: 0-3 13:50:55 Vendor ID: AuthenticAMD 13:50:55 Model name: AMD EPYC-Rome Processor 13:50:55 CPU family: 23 13:50:55 Model: 49 13:50:55 Thread(s) per core: 1 13:50:55 Core(s) per socket: 1 13:50:55 Socket(s): 4 13:50:55 Stepping: 0 13:50:55 BogoMIPS: 5599.99 13:50:55 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:50:55 Virtualization: AMD-V 13:50:55 Hypervisor vendor: KVM 13:50:55 Virtualization type: full 13:50:55 L1d cache: 128 KiB (4 instances) 13:50:55 L1i cache: 128 KiB (4 instances) 13:50:55 L2 cache: 2 MiB (4 instances) 13:50:55 L3 cache: 64 MiB (4 instances) 13:50:55 NUMA node(s): 1 13:50:55 NUMA node0 CPU(s): 0-3 13:50:55 Vulnerability Gather data sampling: Not affected 13:50:55 Vulnerability Itlb multihit: Not affected 13:50:55 Vulnerability L1tf: Not affected 13:50:55 Vulnerability Mds: Not affected 13:50:55 Vulnerability Meltdown: Not affected 13:50:55 Vulnerability Mmio stale data: Not affected 13:50:55 Vulnerability Reg file data sampling: Not affected 13:50:55 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 13:50:55 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 13:50:55 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 13:50:55 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 13:50:55 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 13:50:55 Vulnerability Srbds: Not affected 13:50:55 Vulnerability Tsx async abort: Not affected 13:50:55 13:50:55 13:50:55 ---> nproc: 13:50:55 4 13:50:55 13:50:55 13:50:55 ---> df -h: 13:50:55 Filesystem Size Used Avail Use% Mounted on 13:50:55 tmpfs 1.6G 1.1M 1.6G 1% /run 13:50:55 /dev/vda1 78G 18G 60G 23% / 13:50:55 tmpfs 7.9G 0 7.9G 0% /dev/shm 13:50:55 tmpfs 5.0M 0 5.0M 0% /run/lock 13:50:55 /dev/vda15 105M 6.1M 99M 6% /boot/efi 13:50:55 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 13:50:55 13:50:55 13:50:55 ---> free -m: 13:50:55 total used free shared buff/cache available 13:50:55 Mem: 15989 708 5016 3 10264 14938 13:50:55 Swap: 1023 0 1023 13:50:55 13:50:55 13:50:55 ---> ip addr: 13:50:55 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 13:50:55 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 13:50:55 inet 127.0.0.1/8 scope host lo 13:50:55 valid_lft forever preferred_lft forever 13:50:55 inet6 ::1/128 scope host 13:50:55 valid_lft forever preferred_lft forever 13:50:55 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 13:50:55 link/ether fa:16:3e:f8:8b:47 brd ff:ff:ff:ff:ff:ff 13:50:55 altname enp0s3 13:50:55 inet 10.30.171.213/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 13:50:55 valid_lft 79488sec preferred_lft 79488sec 13:50:55 inet6 fe80::f816:3eff:fef8:8b47/64 scope link 13:50:55 valid_lft forever preferred_lft forever 13:50:55 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 13:50:55 link/ether 02:42:1c:1e:d8:16 brd ff:ff:ff:ff:ff:ff 13:50:55 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 13:50:55 valid_lft forever preferred_lft forever 13:50:55 13:50:55 13:50:55 ---> sar -b -r -n DEV: 13:50:55 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-43768) 07/18/25 _x86_64_ (4 CPU) 13:50:55 13:50:55 11:55:46 LINUX RESTART (4 CPU) 13:50:55 13:50:55 12:00:13 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 13:50:55 12:10:13 75.91 13.93 57.48 4.50 810.97 29226.33 28200.52 13:50:55 12:20:13 5.73 0.41 5.14 0.18 26.69 141.73 1197.91 13:50:55 12:30:13 12.00 0.70 10.59 0.71 8.28 707.41 2052.54 13:50:55 12:40:13 15.71 0.01 15.00 0.70 0.05 1158.41 1104.55 13:50:55 12:50:13 15.71 0.00 15.07 0.64 0.00 263.60 2335.56 13:50:55 13:00:13 7.13 0.00 6.85 0.28 0.00 123.97 303.91 13:50:55 13:10:13 7.27 0.00 6.93 0.34 0.01 157.19 568.80 13:50:55 13:20:06 2.53 0.00 2.52 0.01 0.00 44.21 2.30 13:50:55 13:30:04 21.18 0.06 5.88 15.24 1.10 102.32 214549.95 13:50:55 13:40:13 18.64 0.02 17.68 0.94 3.86 1328.57 2528.12 13:50:55 13:50:06 16.10 5.90 9.47 0.74 137.28 1907.57 849.16 13:50:55 Average: 18.01 1.91 13.90 2.21 89.79 3199.69 23051.11 13:50:55 13:50:55 12:00:13 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 13:50:55 12:10:13 160168 8442712 7479196 45.68 232888 7846520 9072412 52.08 2307660 13139592 136 13:50:55 12:20:13 1917624 10077468 5846180 35.71 232900 7726992 7004924 40.21 2330824 11364420 204 13:50:55 12:30:13 5073156 13514516 2410004 14.72 241072 7991912 3089704 17.73 2407796 8127424 168572 13:50:55 12:40:13 4601368 13127200 2796292 17.08 246008 8065380 3634832 20.86 2462880 8538656 48 13:50:55 12:50:13 4405076 12935232 2988244 18.25 248292 8067264 3721204 21.36 2476008 8719240 224 13:50:55 13:00:13 2697256 11231032 4691480 28.65 249480 8069668 5354888 30.74 2477276 10415248 88 13:50:55 13:10:13 1624824 10162716 5759544 35.18 250536 8072704 6531400 37.49 2478524 11491116 196 13:50:55 13:20:06 6765428 15305072 619192 3.78 250752 8074248 1314724 7.55 2478740 6343544 368 13:50:55 13:30:04 6762320 15309876 614044 3.75 252344 8080524 1315140 7.55 2484984 6344940 248 13:50:55 13:40:13 2886696 11722668 4199292 25.65 261544 8349596 5079576 29.16 2587960 10110828 88 13:50:55 13:50:06 5252784 15377664 543188 3.32 275196 9578448 1171920 6.73 2811952 7477768 775028 13:50:55 Average: 3831518 12473287 3449696 21.07 249183 8174841 4299157 24.68 2482237 9279343 85927 13:50:55 13:50:55 12:00:13 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 13:50:55 12:10:13 lo 11.93 11.93 11.18 11.18 0.00 0.00 0.00 0.00 13:50:55 12:10:13 ens3 32.74 19.96 442.01 1.96 0.00 0.00 0.00 0.00 13:50:55 12:10:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 12:20:13 lo 7.73 7.73 4.42 4.42 0.00 0.00 0.00 0.00 13:50:55 12:20:13 ens3 0.55 0.30 0.10 0.07 0.00 0.00 0.00 0.00 13:50:55 12:20:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 12:30:13 lo 10.94 10.94 7.24 7.24 0.00 0.00 0.00 0.00 13:50:55 12:30:13 ens3 1.13 1.04 0.22 1.30 0.00 0.00 0.00 0.00 13:50:55 12:30:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 12:40:13 lo 16.38 16.38 7.15 7.15 0.00 0.00 0.00 0.00 13:50:55 12:40:13 ens3 1.16 0.93 0.29 0.24 0.00 0.00 0.00 0.00 13:50:55 12:40:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 12:50:13 lo 11.94 11.94 6.91 6.91 0.00 0.00 0.00 0.00 13:50:55 12:50:13 ens3 0.86 0.80 0.16 0.14 0.00 0.00 0.00 0.00 13:50:55 12:50:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:00:13 lo 19.81 19.81 9.28 9.28 0.00 0.00 0.00 0.00 13:50:55 13:00:13 ens3 0.83 0.64 0.18 0.14 0.00 0.00 0.00 0.00 13:50:55 13:00:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:10:13 lo 28.76 28.76 11.48 11.48 0.00 0.00 0.00 0.00 13:50:55 13:10:13 ens3 0.69 0.46 0.14 0.10 0.00 0.00 0.00 0.00 13:50:55 13:10:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:20:06 lo 14.99 14.99 6.43 6.43 0.00 0.00 0.00 0.00 13:50:55 13:20:06 ens3 0.62 0.42 0.14 0.11 0.00 0.00 0.00 0.00 13:50:55 13:20:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:30:04 lo 17.98 17.98 10.27 10.27 0.00 0.00 0.00 0.00 13:50:55 13:30:04 ens3 0.82 0.54 0.19 0.14 0.00 0.00 0.00 0.00 13:50:55 13:30:04 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:40:13 lo 13.98 13.98 7.44 7.44 0.00 0.00 0.00 0.00 13:50:55 13:40:13 ens3 1.14 0.97 0.28 0.24 0.00 0.00 0.00 0.00 13:50:55 13:40:13 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:50:06 lo 12.53 12.53 6.67 6.67 0.00 0.00 0.00 0.00 13:50:55 13:50:06 ens3 14.29 11.24 201.70 1.70 0.00 0.00 0.00 0.00 13:50:55 13:50:06 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 Average: lo 15.18 15.18 8.04 8.04 0.00 0.00 0.00 0.00 13:50:55 Average: ens3 4.97 3.38 58.51 0.56 0.00 0.00 0.00 0.00 13:50:55 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:50:55 13:50:55 13:50:55 ---> sar -P ALL: 13:50:55 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-43768) 07/18/25 _x86_64_ (4 CPU) 13:50:55 13:50:55 11:55:46 LINUX RESTART (4 CPU) 13:50:55 13:50:55 12:00:13 CPU %user %nice %system %iowait %steal %idle 13:50:55 12:10:13 all 41.26 0.07 2.10 6.17 0.10 50.28 13:50:55 12:10:13 0 40.42 0.02 2.33 6.12 0.10 51.01 13:50:55 12:10:13 1 43.05 0.10 2.21 7.30 0.11 47.23 13:50:55 12:10:13 2 40.92 0.15 2.00 6.82 0.11 49.99 13:50:55 12:10:13 3 40.66 0.02 1.87 4.45 0.10 52.89 13:50:55 12:20:13 all 7.73 0.00 0.40 0.06 0.09 91.72 13:50:55 12:20:13 0 7.95 0.00 0.40 0.12 0.08 91.45 13:50:55 12:20:13 1 7.48 0.00 0.44 0.07 0.09 91.92 13:50:55 12:20:13 2 7.51 0.00 0.37 0.02 0.09 92.00 13:50:55 12:20:13 3 7.99 0.00 0.38 0.05 0.09 91.50 13:50:55 12:30:13 all 17.85 0.00 0.72 0.08 0.09 81.25 13:50:55 12:30:13 0 16.67 0.00 0.74 0.06 0.09 82.44 13:50:55 12:30:13 1 19.39 0.00 0.80 0.10 0.09 79.62 13:50:55 12:30:13 2 18.02 0.00 0.62 0.10 0.09 81.16 13:50:55 12:30:13 3 17.34 0.00 0.73 0.07 0.09 81.77 13:50:55 12:40:13 all 19.93 0.00 0.75 0.09 0.09 79.14 13:50:55 12:40:13 0 20.67 0.00 0.79 0.06 0.09 78.39 13:50:55 12:40:13 1 20.18 0.00 0.84 0.05 0.09 78.84 13:50:55 12:40:13 2 19.98 0.00 0.68 0.14 0.10 79.11 13:50:55 12:40:13 3 18.89 0.00 0.69 0.12 0.09 80.20 13:50:55 12:50:13 all 22.85 0.00 0.81 0.05 0.09 76.20 13:50:55 12:50:13 0 23.62 0.00 0.68 0.02 0.08 75.60 13:50:55 12:50:13 1 22.56 0.00 0.75 0.02 0.09 76.59 13:50:55 12:50:13 2 22.78 0.00 1.01 0.10 0.09 76.03 13:50:55 12:50:13 3 22.45 0.00 0.79 0.07 0.10 76.60 13:50:55 13:00:13 all 12.82 0.00 0.61 0.04 0.09 86.45 13:50:55 13:00:13 0 12.81 0.00 0.59 0.10 0.08 86.42 13:50:55 13:00:13 1 12.91 0.00 0.55 0.02 0.09 86.43 13:50:55 13:00:13 2 12.50 0.00 0.66 0.03 0.09 86.72 13:50:55 13:00:13 3 13.05 0.00 0.62 0.02 0.08 86.22 13:50:55 13:10:13 all 14.13 0.00 0.58 0.04 0.09 85.17 13:50:55 13:10:13 0 14.15 0.00 0.47 0.02 0.09 85.26 13:50:55 13:10:13 1 13.89 0.00 0.61 0.03 0.09 85.39 13:50:55 13:10:13 2 14.29 0.00 0.62 0.05 0.10 84.94 13:50:55 13:10:13 3 14.20 0.00 0.60 0.04 0.09 85.07 13:50:55 13:20:06 all 2.94 0.00 0.36 0.02 0.10 96.58 13:50:55 13:20:06 0 2.85 0.00 0.33 0.01 0.10 96.71 13:50:55 13:20:06 1 3.19 0.00 0.38 0.04 0.10 96.29 13:50:55 13:20:06 2 2.72 0.00 0.37 0.01 0.10 96.81 13:50:55 13:20:06 3 3.01 0.00 0.37 0.00 0.10 96.52 13:50:55 13:30:04 all 8.79 0.00 0.41 0.06 0.10 90.64 13:50:55 13:30:04 0 8.72 0.00 0.41 0.07 0.09 90.71 13:50:55 13:30:04 1 8.36 0.00 0.39 0.04 0.10 91.11 13:50:55 13:30:04 2 8.91 0.00 0.39 0.04 0.11 90.55 13:50:55 13:30:04 3 9.18 0.00 0.44 0.10 0.11 90.18 13:50:55 13:40:13 all 26.91 0.00 0.99 0.12 0.10 71.88 13:50:55 13:40:13 0 27.58 0.00 0.96 0.12 0.09 71.26 13:50:55 13:40:13 1 27.35 0.00 1.02 0.06 0.10 71.48 13:50:55 13:40:13 2 25.97 0.00 1.16 0.27 0.10 72.51 13:50:55 13:40:13 3 26.76 0.00 0.80 0.04 0.11 72.29 13:50:55 13:50:06 all 11.89 0.00 0.62 12.55 0.08 74.86 13:50:55 13:50:06 0 13.16 0.00 0.66 9.34 0.07 76.76 13:50:55 13:50:06 1 12.39 0.00 0.60 14.08 0.08 72.84 13:50:55 13:50:06 2 11.52 0.00 0.59 14.05 0.09 73.76 13:50:55 13:50:06 3 10.48 0.00 0.61 12.74 0.08 76.08 13:50:55 13:50:55 Average: CPU %user %nice %system %iowait %steal %idle 13:50:55 Average: all 17.04 0.01 0.76 1.74 0.09 80.36 13:50:55 Average: 0 17.18 0.00 0.76 1.45 0.09 80.52 13:50:55 Average: 1 17.37 0.01 0.78 1.96 0.09 79.78 13:50:55 Average: 2 16.86 0.01 0.77 1.95 0.10 80.30 13:50:55 Average: 3 16.76 0.00 0.72 1.60 0.09 80.83 13:50:55 13:50:55 13:50:55