09:55:18 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/117092 09:55:18 Running as SYSTEM 09:55:18 [EnvInject] - Loading node environment variables. 09:55:18 Building remotely on prd-ubuntu2204-docker-4c-16g-43485 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 09:55:18 [ssh-agent] Looking for ssh-agent implementation... 09:55:18 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 09:55:18 $ ssh-agent 09:55:18 SSH_AUTH_SOCK=/tmp/ssh-XXXXXXnz51zu/agent.1570 09:55:18 SSH_AGENT_PID=1572 09:55:18 [ssh-agent] Started. 09:55:18 Running ssh-add (command line suppressed) 09:55:18 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_17165093958161129313.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_17165093958161129313.key) 09:55:18 [ssh-agent] Using credentials jenkins (jenkins-ssh) 09:55:18 The recommended git tool is: NONE 09:55:20 using credential jenkins-ssh 09:55:20 Wiping out workspace first. 09:55:20 Cloning the remote Git repository 09:55:20 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 09:55:20 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 09:55:20 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 09:55:20 > git --version # timeout=10 09:55:20 > git --version # 'git version 2.34.1' 09:55:20 using GIT_SSH to set credentials jenkins-ssh 09:55:20 Verifying host key using known hosts file 09:55:20 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. 09:55:20 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 09:55:24 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 09:55:24 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 09:55:24 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 09:55:24 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 09:55:24 using GIT_SSH to set credentials jenkins-ssh 09:55:24 Verifying host key using known hosts file 09:55:24 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. 09:55:24 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/92/117092/6 # timeout=10 09:55:24 > git rev-parse 1c9e786f550052fee7f3248a61ca783b957eb45a^{commit} # timeout=10 09:55:24 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 09:55:24 Checking out Revision 1c9e786f550052fee7f3248a61ca783b957eb45a (refs/changes/92/117092/6) 09:55:24 > git config core.sparsecheckout # timeout=10 09:55:24 > git checkout -f 1c9e786f550052fee7f3248a61ca783b957eb45a # timeout=10 09:55:28 Commit message: "Optimize functional test execution" 09:55:28 > git rev-parse FETCH_HEAD^{commit} # timeout=10 09:55:28 > git rev-list --no-walk c620a7a720c446bbc6ee19bfc2622fac5942a85f # timeout=10 09:55:28 > git remote # timeout=10 09:55:28 > git submodule init # timeout=10 09:55:28 > git submodule sync # timeout=10 09:55:28 > git config --get remote.origin.url # timeout=10 09:55:28 > git submodule init # timeout=10 09:55:28 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 09:55:28 ERROR: No submodules found. 09:55:28 provisioning config files... 09:55:28 copy managed file [npmrc] to file:/home/jenkins/.npmrc 09:55:28 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 09:55:28 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1701593488553226374.sh 09:55:28 ---> python-tools-install.sh 09:55:28 Setup pyenv: 09:55:28 * system (set by /opt/pyenv/version) 09:55:28 * 3.8.20 (set by /opt/pyenv/version) 09:55:28 * 3.9.20 (set by /opt/pyenv/version) 09:55:28 * 3.10.15 (set by /opt/pyenv/version) 09:55:28 * 3.11.10 (set by /opt/pyenv/version) 09:55:33 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-5cFN 09:55:33 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 09:55:37 lf-activate-venv(): INFO: Installing: lftools 09:56:02 lf-activate-venv(): INFO: Adding /tmp/venv-5cFN/bin to PATH 09:56:02 Generating Requirements File 09:56:24 Python 3.11.10 09:56:24 pip 25.1.1 from /tmp/venv-5cFN/lib/python3.11/site-packages/pip (python 3.11) 09:56:24 appdirs==1.4.4 09:56:24 argcomplete==3.6.2 09:56:24 aspy.yaml==1.3.0 09:56:24 attrs==25.3.0 09:56:24 autopage==0.5.2 09:56:24 beautifulsoup4==4.13.4 09:56:24 boto3==1.39.7 09:56:24 botocore==1.39.7 09:56:24 bs4==0.0.2 09:56:24 cachetools==5.5.2 09:56:24 certifi==2025.7.14 09:56:24 cffi==1.17.1 09:56:24 cfgv==3.4.0 09:56:24 chardet==5.2.0 09:56:24 charset-normalizer==3.4.2 09:56:24 click==8.2.1 09:56:24 cliff==4.10.0 09:56:24 cmd2==2.7.0 09:56:24 cryptography==3.3.2 09:56:24 debtcollector==3.0.0 09:56:24 decorator==5.2.1 09:56:24 defusedxml==0.7.1 09:56:24 Deprecated==1.2.18 09:56:24 distlib==0.3.9 09:56:24 dnspython==2.7.0 09:56:24 docker==7.1.0 09:56:24 dogpile.cache==1.4.0 09:56:24 durationpy==0.10 09:56:24 email_validator==2.2.0 09:56:24 filelock==3.18.0 09:56:24 future==1.0.0 09:56:24 gitdb==4.0.12 09:56:24 GitPython==3.1.44 09:56:24 google-auth==2.40.3 09:56:24 httplib2==0.22.0 09:56:24 identify==2.6.12 09:56:24 idna==3.10 09:56:24 importlib-resources==1.5.0 09:56:24 iso8601==2.1.0 09:56:24 Jinja2==3.1.6 09:56:24 jmespath==1.0.1 09:56:24 jsonpatch==1.33 09:56:24 jsonpointer==3.0.0 09:56:24 jsonschema==4.24.0 09:56:24 jsonschema-specifications==2025.4.1 09:56:24 keystoneauth1==5.11.1 09:56:24 kubernetes==33.1.0 09:56:24 lftools==0.37.13 09:56:24 lxml==6.0.0 09:56:24 markdown-it-py==3.0.0 09:56:24 MarkupSafe==3.0.2 09:56:24 mdurl==0.1.2 09:56:24 msgpack==1.1.1 09:56:24 multi_key_dict==2.0.3 09:56:24 munch==4.0.0 09:56:24 netaddr==1.3.0 09:56:24 niet==1.4.2 09:56:24 nodeenv==1.9.1 09:56:24 oauth2client==4.1.3 09:56:24 oauthlib==3.3.1 09:56:24 openstacksdk==4.6.0 09:56:24 os-client-config==2.3.0 09:56:24 os-service-types==1.8.0 09:56:24 osc-lib==4.1.0 09:56:24 oslo.config==10.0.0 09:56:24 oslo.context==6.0.0 09:56:24 oslo.i18n==6.5.1 09:56:24 oslo.log==7.2.0 09:56:24 oslo.serialization==5.7.0 09:56:24 oslo.utils==9.0.0 09:56:24 packaging==25.0 09:56:24 pbr==6.1.1 09:56:24 platformdirs==4.3.8 09:56:24 prettytable==3.16.0 09:56:24 psutil==7.0.0 09:56:24 pyasn1==0.6.1 09:56:24 pyasn1_modules==0.4.2 09:56:24 pycparser==2.22 09:56:24 pygerrit2==2.0.15 09:56:24 PyGithub==2.6.1 09:56:24 Pygments==2.19.2 09:56:24 PyJWT==2.10.1 09:56:24 PyNaCl==1.5.0 09:56:24 pyparsing==2.4.7 09:56:24 pyperclip==1.9.0 09:56:24 pyrsistent==0.20.0 09:56:24 python-cinderclient==9.7.0 09:56:24 python-dateutil==2.9.0.post0 09:56:24 python-heatclient==4.3.0 09:56:24 python-jenkins==1.8.2 09:56:24 python-keystoneclient==5.6.0 09:56:24 python-magnumclient==4.8.1 09:56:24 python-openstackclient==8.1.0 09:56:24 python-swiftclient==4.8.0 09:56:24 PyYAML==6.0.2 09:56:24 referencing==0.36.2 09:56:24 requests==2.32.4 09:56:24 requests-oauthlib==2.0.0 09:56:24 requestsexceptions==1.4.0 09:56:24 rfc3986==2.0.0 09:56:24 rich==14.0.0 09:56:24 rich-argparse==1.7.1 09:56:24 rpds-py==0.26.0 09:56:24 rsa==4.9.1 09:56:24 ruamel.yaml==0.18.14 09:56:24 ruamel.yaml.clib==0.2.12 09:56:24 s3transfer==0.13.0 09:56:24 simplejson==3.20.1 09:56:24 six==1.17.0 09:56:24 smmap==5.0.2 09:56:24 soupsieve==2.7 09:56:24 stevedore==5.4.1 09:56:24 tabulate==0.9.0 09:56:24 toml==0.10.2 09:56:24 tomlkit==0.13.3 09:56:24 tqdm==4.67.1 09:56:24 typing_extensions==4.14.1 09:56:24 tzdata==2025.2 09:56:24 urllib3==1.26.20 09:56:24 virtualenv==20.31.2 09:56:24 wcwidth==0.2.13 09:56:24 websocket-client==1.8.0 09:56:24 wrapt==1.17.2 09:56:24 xdg==6.0.0 09:56:24 xmltodict==0.14.2 09:56:24 yq==3.4.3 09:56:24 [EnvInject] - Injecting environment variables from a build step. 09:56:24 [EnvInject] - Injecting as environment variables the properties content 09:56:24 PYTHON=python3 09:56:24 09:56:24 [EnvInject] - Variables injected successfully. 09:56:24 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins8642345378312717095.sh 09:56:24 ---> tox-install.sh 09:56:24 + source /home/jenkins/lf-env.sh 09:56:24 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 09:56:24 ++ mktemp -d /tmp/venv-XXXX 09:56:24 + lf_venv=/tmp/venv-TUqv 09:56:24 + local venv_file=/tmp/.os_lf_venv 09:56:24 + local python=python3 09:56:24 + local options 09:56:24 + local set_path=true 09:56:24 + local install_args= 09:56:24 ++ 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 09:56:24 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 09:56:24 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 09:56:24 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 09:56:24 + true 09:56:24 + case $1 in 09:56:24 + venv_file=/tmp/.toxenv 09:56:24 + shift 2 09:56:24 + true 09:56:24 + case $1 in 09:56:24 + shift 09:56:24 + break 09:56:24 + case $python in 09:56:24 + local pkg_list= 09:56:24 + [[ -d /opt/pyenv ]] 09:56:24 + echo 'Setup pyenv:' 09:56:24 Setup pyenv: 09:56:24 + export PYENV_ROOT=/opt/pyenv 09:56:24 + PYENV_ROOT=/opt/pyenv 09:56:24 + 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 09:56:24 + 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 09:56:24 + pyenv versions 09:56:24 system 09:56:24 3.8.20 09:56:24 3.9.20 09:56:24 3.10.15 09:56:24 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:56:24 + command -v pyenv 09:56:24 ++ pyenv init - --no-rehash 09:56:25 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 09:56:25 for i in ${!paths[@]}; do 09:56:25 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 09:56:25 fi; done; 09:56:25 echo "${paths[*]}"'\'')" 09:56:25 export PATH="/opt/pyenv/shims:${PATH}" 09:56:25 export PYENV_SHELL=bash 09:56:25 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 09:56:25 pyenv() { 09:56:25 local command 09:56:25 command="${1:-}" 09:56:25 if [ "$#" -gt 0 ]; then 09:56:25 shift 09:56:25 fi 09:56:25 09:56:25 case "$command" in 09:56:25 rehash|shell) 09:56:25 eval "$(pyenv "sh-$command" "$@")" 09:56:25 ;; 09:56:25 *) 09:56:25 command pyenv "$command" "$@" 09:56:25 ;; 09:56:25 esac 09:56:25 }' 09:56:25 +++ bash --norc -ec 'IFS=:; paths=($PATH); 09:56:25 for i in ${!paths[@]}; do 09:56:25 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 09:56:25 fi; done; 09:56:25 echo "${paths[*]}"' 09:56:25 ++ 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 09:56:25 ++ 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 09:56:25 ++ 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 09:56:25 ++ export PYENV_SHELL=bash 09:56:25 ++ PYENV_SHELL=bash 09:56:25 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 09:56:25 +++ complete -F _pyenv pyenv 09:56:25 ++ lf-pyver python3 09:56:25 ++ local py_version_xy=python3 09:56:25 ++ local py_version_xyz= 09:56:25 ++ pyenv versions 09:56:25 ++ sed 's/^[ *]* //' 09:56:25 ++ local command 09:56:25 ++ command=versions 09:56:25 ++ '[' 1 -gt 0 ']' 09:56:25 ++ shift 09:56:25 ++ case "$command" in 09:56:25 ++ command pyenv versions 09:56:25 ++ grep -E '^[0-9.]*[0-9]$' 09:56:25 ++ awk '{ print $1 }' 09:56:25 ++ [[ ! -s /tmp/.pyenv_versions ]] 09:56:25 +++ grep '^3' /tmp/.pyenv_versions 09:56:25 +++ sort -V 09:56:25 +++ tail -n 1 09:56:25 ++ py_version_xyz=3.11.10 09:56:25 ++ [[ -z 3.11.10 ]] 09:56:25 ++ echo 3.11.10 09:56:25 ++ return 0 09:56:25 + pyenv local 3.11.10 09:56:25 + local command 09:56:25 + command=local 09:56:25 + '[' 2 -gt 0 ']' 09:56:25 + shift 09:56:25 + case "$command" in 09:56:25 + command pyenv local 3.11.10 09:56:25 + for arg in "$@" 09:56:25 + case $arg in 09:56:25 + pkg_list+='tox ' 09:56:25 + for arg in "$@" 09:56:25 + case $arg in 09:56:25 + pkg_list+='virtualenv ' 09:56:25 + for arg in "$@" 09:56:25 + case $arg in 09:56:25 + pkg_list+='urllib3~=1.26.15 ' 09:56:25 + [[ -f /tmp/.toxenv ]] 09:56:25 + [[ ! -f /tmp/.toxenv ]] 09:56:25 + [[ -n '' ]] 09:56:25 + python3 -m venv /tmp/venv-TUqv 09:56:29 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-TUqv' 09:56:29 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-TUqv 09:56:29 + echo /tmp/venv-TUqv 09:56:29 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 09:56:29 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 09:56:29 + /tmp/venv-TUqv/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 09:56:32 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 09:56:32 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 09:56:32 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 09:56:32 + /tmp/venv-TUqv/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 09:56:34 + type python3 09:56:34 + true 09:56:34 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-TUqv/bin to PATH' 09:56:34 lf-activate-venv(): INFO: Adding /tmp/venv-TUqv/bin to PATH 09:56:34 + PATH=/tmp/venv-TUqv/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 09:56:34 + return 0 09:56:34 + python3 --version 09:56:34 Python 3.11.10 09:56:34 + python3 -m pip --version 09:56:35 pip 25.1.1 from /tmp/venv-TUqv/lib/python3.11/site-packages/pip (python 3.11) 09:56:35 + python3 -m pip freeze 09:56:35 cachetools==6.1.0 09:56:35 chardet==5.2.0 09:56:35 colorama==0.4.6 09:56:35 distlib==0.3.9 09:56:35 filelock==3.18.0 09:56:35 packaging==25.0 09:56:35 platformdirs==4.3.8 09:56:35 pluggy==1.6.0 09:56:35 pyproject-api==1.9.1 09:56:35 tox==4.27.0 09:56:35 urllib3==1.26.20 09:56:35 virtualenv==20.31.2 09:56:35 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins3870836953810366422.sh 09:56:35 [EnvInject] - Injecting environment variables from a build step. 09:56:35 [EnvInject] - Injecting as environment variables the properties content 09:56:35 PARALLEL=True 09:56:35 09:56:35 [EnvInject] - Variables injected successfully. 09:56:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins4315152941108316120.sh 09:56:35 ---> tox-run.sh 09:56:35 + 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 09:56:35 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 09:56:35 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 09:56:35 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 09:56:35 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 09:56:35 + source /home/jenkins/lf-env.sh 09:56:35 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 09:56:35 ++ mktemp -d /tmp/venv-XXXX 09:56:35 + lf_venv=/tmp/venv-MjL1 09:56:35 + local venv_file=/tmp/.os_lf_venv 09:56:35 + local python=python3 09:56:35 + local options 09:56:35 + local set_path=true 09:56:35 + local install_args= 09:56:35 ++ 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 09:56:35 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 09:56:35 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 09:56:35 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 09:56:35 + true 09:56:35 + case $1 in 09:56:35 + venv_file=/tmp/.toxenv 09:56:35 + shift 2 09:56:35 + true 09:56:35 + case $1 in 09:56:35 + shift 09:56:35 + break 09:56:35 + case $python in 09:56:35 + local pkg_list= 09:56:35 + [[ -d /opt/pyenv ]] 09:56:35 + echo 'Setup pyenv:' 09:56:35 Setup pyenv: 09:56:35 + export PYENV_ROOT=/opt/pyenv 09:56:35 + PYENV_ROOT=/opt/pyenv 09:56:35 + 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 09:56:35 + 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 09:56:35 + pyenv versions 09:56:35 system 09:56:35 3.8.20 09:56:35 3.9.20 09:56:35 3.10.15 09:56:35 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 09:56:35 + command -v pyenv 09:56:35 ++ pyenv init - --no-rehash 09:56:35 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 09:56:35 for i in ${!paths[@]}; do 09:56:35 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 09:56:35 fi; done; 09:56:35 echo "${paths[*]}"'\'')" 09:56:35 export PATH="/opt/pyenv/shims:${PATH}" 09:56:35 export PYENV_SHELL=bash 09:56:35 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 09:56:35 pyenv() { 09:56:35 local command 09:56:35 command="${1:-}" 09:56:35 if [ "$#" -gt 0 ]; then 09:56:35 shift 09:56:35 fi 09:56:35 09:56:35 case "$command" in 09:56:35 rehash|shell) 09:56:35 eval "$(pyenv "sh-$command" "$@")" 09:56:35 ;; 09:56:35 *) 09:56:35 command pyenv "$command" "$@" 09:56:35 ;; 09:56:35 esac 09:56:35 }' 09:56:35 +++ bash --norc -ec 'IFS=:; paths=($PATH); 09:56:35 for i in ${!paths[@]}; do 09:56:35 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 09:56:35 fi; done; 09:56:35 echo "${paths[*]}"' 09:56:35 ++ 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 09:56:35 ++ 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 09:56:35 ++ 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 09:56:35 ++ export PYENV_SHELL=bash 09:56:35 ++ PYENV_SHELL=bash 09:56:35 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 09:56:35 +++ complete -F _pyenv pyenv 09:56:35 ++ lf-pyver python3 09:56:35 ++ local py_version_xy=python3 09:56:35 ++ local py_version_xyz= 09:56:35 ++ pyenv versions 09:56:35 ++ local command 09:56:35 ++ command=versions 09:56:35 ++ sed 's/^[ *]* //' 09:56:35 ++ '[' 1 -gt 0 ']' 09:56:35 ++ shift 09:56:35 ++ case "$command" in 09:56:35 ++ command pyenv versions 09:56:35 ++ awk '{ print $1 }' 09:56:35 ++ grep -E '^[0-9.]*[0-9]$' 09:56:35 ++ [[ ! -s /tmp/.pyenv_versions ]] 09:56:35 +++ sort -V 09:56:35 +++ grep '^3' /tmp/.pyenv_versions 09:56:35 +++ tail -n 1 09:56:35 ++ py_version_xyz=3.11.10 09:56:35 ++ [[ -z 3.11.10 ]] 09:56:35 ++ echo 3.11.10 09:56:35 ++ return 0 09:56:35 + pyenv local 3.11.10 09:56:35 + local command 09:56:35 + command=local 09:56:35 + '[' 2 -gt 0 ']' 09:56:35 + shift 09:56:35 + case "$command" in 09:56:35 + command pyenv local 3.11.10 09:56:35 + for arg in "$@" 09:56:35 + case $arg in 09:56:35 + pkg_list+='tox ' 09:56:35 + for arg in "$@" 09:56:35 + case $arg in 09:56:35 + pkg_list+='virtualenv ' 09:56:35 + for arg in "$@" 09:56:35 + case $arg in 09:56:35 + pkg_list+='urllib3~=1.26.15 ' 09:56:35 + [[ -f /tmp/.toxenv ]] 09:56:35 ++ cat /tmp/.toxenv 09:56:35 + lf_venv=/tmp/venv-TUqv 09:56:35 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-TUqv from' file:/tmp/.toxenv 09:56:35 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-TUqv from file:/tmp/.toxenv 09:56:35 + /tmp/venv-TUqv/bin/python3 -m pip install --upgrade --quiet pip 'setuptools<66' virtualenv 09:56:36 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 09:56:36 + echo 'lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 ' 09:56:36 lf-activate-venv(): INFO: Installing: tox virtualenv urllib3~=1.26.15 09:56:36 + /tmp/venv-TUqv/bin/python3 -m pip install --upgrade --quiet --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 09:56:37 + type python3 09:56:37 + true 09:56:37 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-TUqv/bin to PATH' 09:56:37 lf-activate-venv(): INFO: Adding /tmp/venv-TUqv/bin to PATH 09:56:37 + PATH=/tmp/venv-TUqv/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 09:56:37 + return 0 09:56:37 + [[ -d /opt/pyenv ]] 09:56:37 + echo '---> Setting up pyenv' 09:56:37 ---> Setting up pyenv 09:56:37 + export PYENV_ROOT=/opt/pyenv 09:56:37 + PYENV_ROOT=/opt/pyenv 09:56:37 + export PATH=/opt/pyenv/bin:/tmp/venv-TUqv/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 09:56:37 + PATH=/opt/pyenv/bin:/tmp/venv-TUqv/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 09:56:37 ++ pwd 09:56:37 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 09:56:37 + export PYTHONPATH 09:56:37 + export TOX_TESTENV_PASSENV=PYTHONPATH 09:56:37 + TOX_TESTENV_PASSENV=PYTHONPATH 09:56:37 + tox --version 09:56:38 4.27.0 from /tmp/venv-TUqv/lib/python3.11/site-packages/tox/__init__.py 09:56:38 + PARALLEL=True 09:56:38 + TOX_OPTIONS_LIST= 09:56:38 + [[ -n '' ]] 09:56:38 + case ${PARALLEL,,} in 09:56:38 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 09:56:38 + tox --parallel auto --parallel-live 09:56:38 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 09:56:39 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 09:56:39 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 09:56:39 docs: install_deps> python -I -m pip install -r docs/requirements.txt 09:56:39 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 09:56:46 sims: freeze> python -m pip freeze --all 09:56:46 buildcontroller: freeze> python -m pip freeze --all 09:56:46 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 09:56:46 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 09:56:46 Using lighynode version 20.1.0.5 09:56:46 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 09:56:46 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 09:56:46 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 09:56:46 + update-java-alternatives -l 09:56:46 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 09:56:46 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 09:56:46 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 09:56:46 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 09:56:46 update-alternatives: error: no alternatives for jaotc 09:56:46 update-alternatives: error: no alternatives for rmic 09:56:46 + java -version 09:56:46 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 09:56:47 + JAVA_VER=21 09:56:47 + echo 21 09:56:47 21 09:56:47 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 09:56:47 + javac -version 09:56:47 + JAVAC_VER=21 09:56:47 + echo 21 09:56:47 21 09:56:47 ok, java is 21 or newer 09:56:47 + [ 21 -ge 21 ] 09:56:47 + [ 21 -ge 21 ] 09:56:47 + echo ok, java is 21 or newer 09:56:47 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.11/binaries/apache-maven-3.9.11-bin.tar.gz -P /tmp 09:56:47 2025-07-17 09:56:47 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] 09:56:47 + sudo mkdir -p /opt 09:56:47 + sudo tar xf /tmp/apache-maven-3.9.11-bin.tar.gz -C /opt 09:56:47 + sudo ln -s /opt/apache-maven-3.9.11 /opt/maven 09:56:47 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 09:56:47 + mvn --version 09:56:47 Apache Maven 3.9.11 (3e54c93a704957b63ee3494413a2b544fd3d825b) 09:56:47 Maven home: /opt/maven 09:56:47 Java version: 21.0.5, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 09:56:47 Default locale: en, platform encoding: UTF-8 09:56:47 OS name: "linux", version: "5.15.0-131-generic", arch: "amd64", family: "unix" 09:56:48 NOTE: Picked up JDK_JAVA_OPTIONS: 09:56:48 --add-opens=java.base/java.io=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.lang=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.net=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.nio=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.nio.file=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.util=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.util.jar=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.util.stream=ALL-UNNAMED 09:56:48 --add-opens=java.base/java.util.zip=ALL-UNNAMED 09:56:48 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 09:56:48 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 09:56:48 -Xlog:disable 09:56:49 sims: OK ✔ in 11.04 seconds 09:56:49 checkbashisms: freeze> python -m pip freeze --all 09:56:50 checkbashisms: pip==25.1.1,setuptools==80.3.1 09:56:50 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 09:56:50 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)' 09:56:50 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 09:56:51 possible bashism in ./lightynode/lightynode-openroadm-device/start-controller.sh line 16 (exit|return with negative status code): 09:56:51 exit -1 09:56:52 checkbashisms: exit 1 (1.32 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + pid=2805 09:56:52 checkbashisms: FAIL ✖ in 2.62 seconds 09:56:52 pre-commit: install_deps> python -I -m pip install pre-commit 09:56:55 pre-commit: freeze> python -m pip freeze --all 09:56:56 pre-commit: cfgv==3.4.0,distlib==0.3.9,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 09:56:56 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 09:56:56 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)' 09:56:56 /usr/bin/cpan 09:56:56 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 09:56:56 [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. 09:56:56 [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. 09:56:56 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 09:56:57 [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. 09:56:57 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 09:56:57 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 09:56:58 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 09:56:58 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 09:56:59 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 09:56:59 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 09:57:00 [INFO] Once installed this environment will be reused. 09:57:00 [INFO] This may take a few minutes... 09:57:06 docs-linkcheck: freeze> python -m pip freeze --all 09:57:06 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 09:57:06 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 09:57:09 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 09:57:09 [INFO] Once installed this environment will be reused. 09:57:09 [INFO] This may take a few minutes... 09:57:09 docs: freeze> python -m pip freeze --all 09:57:10 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 09:57:10 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 09:57:11 docs-linkcheck: OK ✔ in 32.75 seconds 09:57:11 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 09:57:14 docs: OK ✔ in 33.88 seconds 09:57:14 pylint: freeze> python -m pip freeze --all 09:57:15 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 09:57:15 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}$' '{}' + 09:57:16 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 09:57:16 [INFO] Once installed this environment will be reused. 09:57:16 [INFO] This may take a few minutes... 09:57:20 [INFO] Installing environment for https://github.com/perltidy/perltidy. 09:57:20 [INFO] Once installed this environment will be reused. 09:57:20 [INFO] This may take a few minutes... 09:57:32 trim trailing whitespace.................................................Passed 09:57:32 Tabs remover.............................................................Passed 09:57:32 autopep8.................................................................Passed 09:57:38 perltidy.................................................................Passed 09:57:38 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 09:57:39 [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. 09:57:39 [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. 09:57:39 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 09:57:39 [INFO] Once installed this environment will be reused. 09:57:39 [INFO] This may take a few minutes... 09:57:39 09:57:39 ------------------------------------ 09:57:39 Your code has been rated at 10.00/10 09:57:39 09:57:45 gitlint..................................................................Passed 09:58:27 pylint: OK ✔ in 30.97 seconds 09:58:27 pre-commit: OK ✔ in 53.72 seconds 09:58:27 buildcontroller: OK ✔ in 1 minute 48.07 seconds 09:58:27 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 09:58:27 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 09:58:27 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 09:58:27 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 09:58:33 build_karaf_tests71: freeze> python -m pip freeze --all 09:58:33 build_karaf_tests221: freeze> python -m pip freeze --all 09:58:33 build_karaf_tests121: freeze> python -m pip freeze --all 09:58:33 build_karaf_tests190: freeze> python -m pip freeze --all 09:58:34 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 09:58:34 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 09:58:34 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 09:58:34 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 09:58:34 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 09:58:34 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 09:58:34 build karaf in karaf71 with ./karaf71.env 09:58:34 build karaf in karaf221 with ./karaf221.env 09:58:34 build karaf in karaf121 with ./karaf121.env 09:58:34 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 09:58:34 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 09:58:34 build karaf in karafoc with ./karafoc.env 09:58:34 NOTE: Picked up JDK_JAVA_OPTIONS: 09:58:34 --add-opens=java.base/java.io=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.net=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.file=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.jar=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.stream=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.zip=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 09:58:34 -Xlog:disable 09:58:34 NOTE: Picked up JDK_JAVA_OPTIONS: 09:58:34 --add-opens=java.base/java.io=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.net=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.file=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.jar=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.stream=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.zip=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 09:58:34 -Xlog:disable 09:58:34 NOTE: Picked up JDK_JAVA_OPTIONS: 09:58:34 --add-opens=java.base/java.io=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.net=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.file=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.jar=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.stream=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.zip=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 09:58:34 -Xlog:disable 09:58:34 NOTE: Picked up JDK_JAVA_OPTIONS: 09:58:34 --add-opens=java.base/java.io=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.net=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.nio.file=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.jar=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.stream=ALL-UNNAMED 09:58:34 --add-opens=java.base/java.util.zip=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 09:58:34 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 09:58:34 -Xlog:disable 09:59:27 build_karaf_tests71: OK ✔ in 1 minute 0.55 seconds 09:59:27 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 09:59:29 build_karaf_tests221: OK ✔ in 1 minute 1.05 seconds 09:59:29 build_karaf_tests190: OK ✔ in 1 minute 2.29 seconds 09:59:29 build_karaf_tests121: OK ✔ in 1 minute 2.35 seconds 09:59:29 testsPCE: install_deps> python -I -m pip install gnpy4tpce==2.4.7 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 09:59:34 buildlighty: freeze> python -m pip freeze --all 09:59:34 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.3.1,urllib3==2.5.0 09:59:34 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 09:59:35 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 10:00:18 buildlighty: OK ✔ in 30.7 seconds 10:00:18 testsPCE: freeze> python -m pip freeze --all 10:00:18 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 10:00:18 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 10:00:18 pytest -q transportpce_tests/pce/test01_pce.py 10:01:05 .................... [100%] 10:02:08 20 passed in 109.51s (0:01:49) 10:02:08 pytest -q transportpce_tests/pce/test02_pce_400G.py 10:02:25 ............ [100%] 10:02:55 12 passed in 46.34s 10:02:55 pytest -q transportpce_tests/pce/test03_gnpy.py 10:03:11 ........ [100%] 10:03:32 8 passed in 37.04s 10:03:32 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 10:04:04 ... [100%] 10:04:09 3 passed in 36.17s 10:04:09 testsPCE: OK ✔ in 4 minutes 40.23 seconds 10:04:09 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 10:04:09 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 10:04:09 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 10:04:16 tests_tapi: freeze> python -m pip freeze --all 10:04:16 tests121: freeze> python -m pip freeze --all 10:04:16 tests190: freeze> python -m pip freeze --all 10:04:16 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 10:04:16 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 10:04:16 using environment variables from ./karaf221.env 10:04:16 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 10:04:16 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 10:04:16 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 10:04:16 using environment variables from ./karaf121.env 10:04:16 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 10:04:16 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 10:04:16 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 10:04:16 using environment variables from ./karafoc.env 10:04:16 pytest -q transportpce_tests/oc/test01_portmapping.py 10:05:18 ........... [100%] 10:05:34 10 passed in 77.43s (0:01:17) 10:05:34 pytest -q transportpce_tests/oc/test02_topology.py 10:05:40 ................................... [100%] 10:06:19 21 passed in 122.80s (0:02:02) 10:06:19 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 10:06:20 ............................. [100%] 10:06:42 14 passed in 67.61s (0:01:07) 10:06:43 pytest -q transportpce_tests/oc/test03_renderer.py 10:07:00 .............. [100%] 10:07:21 6 passed in 61.64s (0:01:01) 10:07:21 pytest -q transportpce_tests/1.2.1/test03_topology.py 10:07:22 .................. [100%] 10:07:40 19 passed in 56.87s 10:07:41 tests190: OK ✔ in 3 minutes 31.88 seconds 10:07:41 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 10:07:45 .tests71: freeze> python -m pip freeze --all 10:07:48 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 10:07:48 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 10:07:48 using environment variables from ./karaf71.env 10:07:48 pytest -q transportpce_tests/7.1/test01_portmapping.py 10:08:05 .................................... [100%] 10:08:42 12 passed in 53.99s 10:08:42 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 10:08:43 .................................................... [100%] 10:09:51 44 passed in 149.46s (0:02:29) 10:09:51 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 10:09:52 .F.. [100%] 10:09:57 =================================== FAILURES =================================== 10:09:57 __________ TransportTapitesting.test_51_check_uninstall_Tapi_Feature ___________ 10:09:57 10:09:57 self = 10:09:57 conn = 10:09:57 method = 'GET' 10:09:57 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 10:09:57 body = None 10:09:57 headers = {'User-Agent': 'python-requests/2.32.4', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 10:09:57 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 10:09:57 timeout = Timeout(connect=30, read=30, total=None), chunked = False 10:09:57 response_conn = 10:09:57 preload_content = False, decode_content = False, enforce_content_length = True 10:09:57 10:09:57 def _make_request( 10:09:57 self, 10:09:57 conn: BaseHTTPConnection, 10:09:57 method: str, 10:09:57 url: str, 10:09:57 body: _TYPE_BODY | None = None, 10:09:57 headers: typing.Mapping[str, str] | None = None, 10:09:57 retries: Retry | None = None, 10:09:57 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 10:09:57 chunked: bool = False, 10:09:57 response_conn: BaseHTTPConnection | None = None, 10:09:57 preload_content: bool = True, 10:09:57 decode_content: bool = True, 10:09:57 enforce_content_length: bool = True, 10:09:57 ) -> BaseHTTPResponse: 10:09:57 """ 10:09:57 Perform a request on a given urllib connection object taken from our 10:09:57 pool. 10:09:57 10:09:57 :param conn: 10:09:57 a connection from one of our connection pools 10:09:57 10:09:57 :param method: 10:09:57 HTTP request method (such as GET, POST, PUT, etc.) 10:09:57 10:09:57 :param url: 10:09:57 The URL to perform the request on. 10:09:57 10:09:57 :param body: 10:09:57 Data to send in the request body, either :class:`str`, :class:`bytes`, 10:09:57 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 10:09:57 10:09:57 :param headers: 10:09:57 Dictionary of custom headers to send, such as User-Agent, 10:09:57 If-None-Match, etc. If None, pool headers are used. If provided, 10:09:57 these headers completely replace any pool-specific headers. 10:09:57 10:09:57 :param retries: 10:09:57 Configure the number of retries to allow before raising a 10:09:57 :class:`~urllib3.exceptions.MaxRetryError` exception. 10:09:57 10:09:57 Pass ``None`` to retry until you receive a response. Pass a 10:09:57 :class:`~urllib3.util.retry.Retry` object for fine-grained control 10:09:57 over different types of retries. 10:09:57 Pass an integer number to retry connection errors that many times, 10:09:57 but no other types of errors. Pass zero to never retry. 10:09:57 10:09:57 If ``False``, then retries are disabled and any exception is raised 10:09:57 immediately. Also, instead of raising a MaxRetryError on redirects, 10:09:57 the redirect response will be returned. 10:09:57 10:09:57 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 10:09:57 10:09:57 :param timeout: 10:09:57 If specified, overrides the default timeout for this one 10:09:57 request. It may be a float (in seconds) or an instance of 10:09:57 :class:`urllib3.util.Timeout`. 10:09:57 10:09:57 :param chunked: 10:09:57 If True, urllib3 will send the body using chunked transfer 10:09:57 encoding. Otherwise, urllib3 will send the body using the standard 10:09:57 content-length form. Defaults to False. 10:09:57 10:09:57 :param response_conn: 10:09:57 Set this to ``None`` if you will handle releasing the connection or 10:09:57 set the connection to have the response release it. 10:09:57 10:09:57 :param preload_content: 10:09:57 If True, the response's body will be preloaded during construction. 10:09:57 10:09:57 :param decode_content: 10:09:57 If True, will attempt to decode the body based on the 10:09:57 'content-encoding' header. 10:09:57 10:09:57 :param enforce_content_length: 10:09:57 Enforce content length checking. Body returned by server must match 10:09:57 value of Content-Length header, if present. Otherwise, raise error. 10:09:57 """ 10:09:57 self.num_requests += 1 10:09:57 10:09:57 timeout_obj = self._get_timeout(timeout) 10:09:57 timeout_obj.start_connect() 10:09:57 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 10:09:57 10:09:57 try: 10:09:57 # Trigger any extra validation we need to do. 10:09:57 try: 10:09:57 self._validate_conn(conn) 10:09:57 except (SocketTimeout, BaseSSLError) as e: 10:09:57 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 10:09:57 raise 10:09:57 10:09:57 # _validate_conn() starts the connection to an HTTPS proxy 10:09:57 # so we need to wrap errors with 'ProxyError' here too. 10:09:57 except ( 10:09:57 OSError, 10:09:57 NewConnectionError, 10:09:57 TimeoutError, 10:09:57 BaseSSLError, 10:09:57 CertificateError, 10:09:57 SSLError, 10:09:57 ) as e: 10:09:57 new_e: Exception = e 10:09:57 if isinstance(e, (BaseSSLError, CertificateError)): 10:09:57 new_e = SSLError(e) 10:09:57 # If the connection didn't successfully connect to it's proxy 10:09:57 # then there 10:09:57 if isinstance( 10:09:57 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 10:09:57 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 10:09:57 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 10:09:57 raise new_e 10:09:57 10:09:57 # conn.request() calls http.client.*.request, not the method in 10:09:57 # urllib3.request. It also calls makefile (recv) on the socket. 10:09:57 try: 10:09:57 conn.request( 10:09:57 method, 10:09:57 url, 10:09:57 body=body, 10:09:57 headers=headers, 10:09:57 chunked=chunked, 10:09:57 preload_content=preload_content, 10:09:57 decode_content=decode_content, 10:09:57 enforce_content_length=enforce_content_length, 10:09:57 ) 10:09:57 10:09:57 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 10:09:57 # legitimately able to close the connection after sending a valid response. 10:09:57 # With this behaviour, the received response is still readable. 10:09:57 except BrokenPipeError: 10:09:57 pass 10:09:57 except OSError as e: 10:09:57 # MacOS/Linux 10:09:57 # EPROTOTYPE and ECONNRESET are needed on macOS 10:09:57 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 10:09:57 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 10:09:57 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 10:09:57 raise 10:09:57 10:09:57 # Reset the timeout for the recv() on the socket 10:09:57 read_timeout = timeout_obj.read_timeout 10:09:57 10:09:57 if not conn.is_closed: 10:09:57 # In Python 3 socket.py will catch EAGAIN and return None when you 10:09:57 # try and read into the file pointer created by http.client, which 10:09:57 # instead raises a BadStatusLine exception. Instead of catching 10:09:57 # the exception and assuming all BadStatusLine exceptions are read 10:09:57 # timeouts, check for a zero timeout before making the request. 10:09:57 if read_timeout == 0: 10:09:57 raise ReadTimeoutError( 10:09:57 self, url, f"Read timed out. (read timeout={read_timeout})" 10:09:57 ) 10:09:57 conn.timeout = read_timeout 10:09:57 10:09:57 # Receive the response from the server 10:09:57 try: 10:09:57 > response = conn.getresponse() 10:09:57 ^^^^^^^^^^^^^^^^^^ 10:09:57 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connection.py:565: in getresponse 10:09:57 httplib_response = super().getresponse() 10:09:57 ^^^^^^^^^^^^^^^^^^^^^ 10:09:57 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 10:09:57 response.begin() 10:09:57 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 10:09:57 version, status, reason = self._read_status() 10:09:57 ^^^^^^^^^^^^^^^^^^^ 10:09:57 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 10:09:57 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 10:09:57 self = 10:09:57 b = 10:09:57 10:09:57 def readinto(self, b): 10:09:57 """Read up to len(b) bytes into the writable buffer *b* and return 10:09:57 the number of bytes read. If the socket is non-blocking and no bytes 10:09:57 are available, None is returned. 10:09:57 10:09:57 If *b* is non-empty, a 0 return value indicates that the connection 10:09:57 was shutdown at the other end. 10:09:57 """ 10:09:57 self._checkClosed() 10:09:57 self._checkReadable() 10:09:57 if self._timeout_occurred: 10:09:57 raise OSError("cannot read from timed out object") 10:09:57 while True: 10:09:57 try: 10:09:57 > return self._sock.recv_into(b) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 E TimeoutError: timed out 10:09:57 10:09:57 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 10:09:57 10:09:57 The above exception was the direct cause of the following exception: 10:09:57 10:09:57 self = 10:09:57 request = , stream = False 10:09:57 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 10:09:57 proxies = OrderedDict() 10:09:57 10:09:57 def send( 10:09:57 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 10:09:57 ): 10:09:57 """Sends PreparedRequest object. Returns Response object. 10:09:57 10:09:57 :param request: The :class:`PreparedRequest ` being sent. 10:09:57 :param stream: (optional) Whether to stream the request content. 10:09:57 :param timeout: (optional) How long to wait for the server to send 10:09:57 data before giving up, as a float, or a :ref:`(connect timeout, 10:09:57 read timeout) ` tuple. 10:09:57 :type timeout: float or tuple or urllib3 Timeout object 10:09:57 :param verify: (optional) Either a boolean, in which case it controls whether 10:09:57 we verify the server's TLS certificate, or a string, in which case it 10:09:57 must be a path to a CA bundle to use 10:09:57 :param cert: (optional) Any user-provided SSL certificate to be trusted. 10:09:57 :param proxies: (optional) The proxies dictionary to apply to the request. 10:09:57 :rtype: requests.Response 10:09:57 """ 10:09:57 10:09:57 try: 10:09:57 conn = self.get_connection_with_tls_context( 10:09:57 request, verify, proxies=proxies, cert=cert 10:09:57 ) 10:09:57 except LocationValueError as e: 10:09:57 raise InvalidURL(e, request=request) 10:09:57 10:09:57 self.cert_verify(conn, request.url, verify, cert) 10:09:57 url = self.request_url(request, proxies) 10:09:57 self.add_headers( 10:09:57 request, 10:09:57 stream=stream, 10:09:57 timeout=timeout, 10:09:57 verify=verify, 10:09:57 cert=cert, 10:09:57 proxies=proxies, 10:09:57 ) 10:09:57 10:09:57 chunked = not (request.body is None or "Content-Length" in request.headers) 10:09:57 10:09:57 if isinstance(timeout, tuple): 10:09:57 try: 10:09:57 connect, read = timeout 10:09:57 timeout = TimeoutSauce(connect=connect, read=read) 10:09:57 except ValueError: 10:09:57 raise ValueError( 10:09:57 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 10:09:57 f"or a single float to set both timeouts to the same value." 10:09:57 ) 10:09:57 elif isinstance(timeout, TimeoutSauce): 10:09:57 pass 10:09:57 else: 10:09:57 timeout = TimeoutSauce(connect=timeout, read=timeout) 10:09:57 10:09:57 try: 10:09:57 > resp = conn.urlopen( 10:09:57 method=request.method, 10:09:57 url=url, 10:09:57 body=request.body, 10:09:57 headers=request.headers, 10:09:57 redirect=False, 10:09:57 assert_same_host=False, 10:09:57 preload_content=False, 10:09:57 decode_content=False, 10:09:57 retries=self.max_retries, 10:09:57 timeout=timeout, 10:09:57 chunked=chunked, 10:09:57 ) 10:09:57 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:667: 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 10:09:57 retries = retries.increment( 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/retry.py:474: in increment 10:09:57 raise reraise(type(error), error, _stacktrace) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 10:09:57 raise value 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 10:09:57 response = self._make_request( 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 10:09:57 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 10:09:57 self = 10:09:57 err = TimeoutError('timed out') 10:09:57 url = '/rests/data/ietf-network:networks/network=otn-topology?content=config' 10:09:57 timeout_value = 30 10:09:57 10:09:57 def _raise_timeout( 10:09:57 self, 10:09:57 err: BaseSSLError | OSError | SocketTimeout, 10:09:57 url: str, 10:09:57 timeout_value: _TYPE_TIMEOUT | None, 10:09:57 ) -> None: 10:09:57 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 10:09:57 10:09:57 if isinstance(err, SocketTimeout): 10:09:57 > raise ReadTimeoutError( 10:09:57 self, url, f"Read timed out. (read timeout={timeout_value})" 10:09:57 ) from err 10:09:57 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 10:09:57 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 10:09:57 10:09:57 During handling of the above exception, another exception occurred: 10:09:57 10:09:57 self = 10:09:57 10:09:57 def test_51_check_uninstall_Tapi_Feature(self): 10:09:57 test_utils.uninstall_karaf_feature("odl-transportpce-tapi") 10:09:57 time.sleep(60) 10:09:57 print("Tapi Feature uninstalled") 10:09:57 # Need to disable these checks due to too much read timeout errors on the CI only (not locally). 10:09:57 > response = test_utils.get_ietf_network_request('otn-topology', 'config') 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 10:09:57 transportpce_tests/tapi/test01_abstracted_topology.py:689: 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 transportpce_tests/common/test_utils.py:540: in get_ietf_network_request 10:09:57 response = get_request(url[RESTCONF_VERSION].format(*format_args)) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 transportpce_tests/common/test_utils.py:116: in get_request 10:09:57 return requests.request( 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/api.py:59: in request 10:09:57 return session.request(method=method, url=url, **kwargs) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:589: in request 10:09:57 resp = self.send(prep, **send_kwargs) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/sessions.py:703: in send 10:09:57 r = adapter.send(request, **kwargs) 10:09:57 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 10:09:57 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 10:09:57 10:09:57 self = 10:09:57 request = , stream = False 10:09:57 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 10:09:57 proxies = OrderedDict() 10:09:57 10:09:57 def send( 10:09:57 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 10:09:57 ): 10:09:57 """Sends PreparedRequest object. Returns Response object. 10:09:57 10:09:57 :param request: The :class:`PreparedRequest ` being sent. 10:09:57 :param stream: (optional) Whether to stream the request content. 10:09:57 :param timeout: (optional) How long to wait for the server to send 10:09:57 data before giving up, as a float, or a :ref:`(connect timeout, 10:09:57 read timeout) ` tuple. 10:09:57 :type timeout: float or tuple or urllib3 Timeout object 10:09:57 :param verify: (optional) Either a boolean, in which case it controls whether 10:09:57 we verify the server's TLS certificate, or a string, in which case it 10:09:57 must be a path to a CA bundle to use 10:09:57 :param cert: (optional) Any user-provided SSL certificate to be trusted. 10:09:57 :param proxies: (optional) The proxies dictionary to apply to the request. 10:09:57 :rtype: requests.Response 10:09:57 """ 10:09:57 10:09:57 try: 10:09:57 conn = self.get_connection_with_tls_context( 10:09:57 request, verify, proxies=proxies, cert=cert 10:09:57 ) 10:09:57 except LocationValueError as e: 10:09:57 raise InvalidURL(e, request=request) 10:09:57 10:09:57 self.cert_verify(conn, request.url, verify, cert) 10:09:57 url = self.request_url(request, proxies) 10:09:57 self.add_headers( 10:09:57 request, 10:09:57 stream=stream, 10:09:57 timeout=timeout, 10:09:57 verify=verify, 10:09:57 cert=cert, 10:09:57 proxies=proxies, 10:09:57 ) 10:09:57 10:09:57 chunked = not (request.body is None or "Content-Length" in request.headers) 10:09:57 10:09:57 if isinstance(timeout, tuple): 10:09:57 try: 10:09:57 connect, read = timeout 10:09:57 timeout = TimeoutSauce(connect=connect, read=read) 10:09:57 except ValueError: 10:09:57 raise ValueError( 10:09:57 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 10:09:57 f"or a single float to set both timeouts to the same value." 10:09:57 ) 10:09:57 elif isinstance(timeout, TimeoutSauce): 10:09:57 pass 10:09:57 else: 10:09:57 timeout = TimeoutSauce(connect=timeout, read=timeout) 10:09:57 10:09:57 try: 10:09:57 resp = conn.urlopen( 10:09:57 method=request.method, 10:09:57 url=url, 10:09:57 body=request.body, 10:09:57 headers=request.headers, 10:09:57 redirect=False, 10:09:57 assert_same_host=False, 10:09:57 preload_content=False, 10:09:57 decode_content=False, 10:09:57 retries=self.max_retries, 10:09:57 timeout=timeout, 10:09:57 chunked=chunked, 10:09:57 ) 10:09:57 10:09:57 except (ProtocolError, OSError) as err: 10:09:57 raise ConnectionError(err, request=request) 10:09:57 10:09:57 except MaxRetryError as e: 10:09:57 if isinstance(e.reason, ConnectTimeoutError): 10:09:57 # TODO: Remove this in 3.0.0: see #2811 10:09:57 if not isinstance(e.reason, NewConnectionError): 10:09:57 raise ConnectTimeout(e, request=request) 10:09:57 10:09:57 if isinstance(e.reason, ResponseError): 10:09:57 raise RetryError(e, request=request) 10:09:57 10:09:57 if isinstance(e.reason, _ProxyError): 10:09:57 raise ProxyError(e, request=request) 10:09:57 10:09:57 if isinstance(e.reason, _SSLError): 10:09:57 # This branch is for urllib3 v1.22 and later. 10:09:57 raise SSLError(e, request=request) 10:09:57 10:09:57 raise ConnectionError(e, request=request) 10:09:57 10:09:57 except ClosedPoolError as e: 10:09:57 raise ConnectionError(e, request=request) 10:09:57 10:09:57 except _ProxyError as e: 10:09:57 raise ProxyError(e) 10:09:57 10:09:57 except (_SSLError, _HTTPError) as e: 10:09:57 if isinstance(e, _SSLError): 10:09:57 # This branch is for urllib3 versions earlier than v1.22 10:09:57 raise SSLError(e, request=request) 10:09:57 elif isinstance(e, ReadTimeoutError): 10:09:57 > raise ReadTimeout(e, request=request) 10:09:57 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 10:09:57 10:09:57 ../.tox/tests_tapi/lib/python3.11/site-packages/requests/adapters.py:713: ReadTimeout 10:09:57 ----------------------------- Captured stdout call ----------------------------- 10:09:57 execution of test_51_check_uninstall_Tapi_Feature 10:09:57 uninstalling feature odl-transportpce-tapi 10:09:57 client: JAVA_HOME not set; results may vary 10:09:57 odl-transportpce-tapi │ 11.0.0.SNAPSHOT │ │ Uninstalled │ odl-transportpce-tapi │ OpenDaylight :: transportpce :: tapi 10:09:57 Tapi Feature uninstalled 10:09:57 --------------------------- Captured stdout teardown --------------------------- 10:09:57 all processes killed 10:09:57 =========================== short test summary info ============================ 10:09:57 FAILED transportpce_tests/tapi/test01_abstracted_topology.py::TransportTapitesting::test_51_check_uninstall_Tapi_Feature 10:09:57 1 failed, 50 passed in 340.76s (0:05:40) 10:09:57 tests_tapi: exit 1 (341.15 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi pid=7805 10:09:58 tests_tapi: FAIL ✖ in 5 minutes 48.87 seconds 10:09:58 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 10:09:58 ....tests221: freeze> python -m pip freeze --all 10:10:05 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 10:10:05 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 10:10:05 using environment variables from ./karaf221.env 10:10:05 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 10:10:07 ................................................................................... [100%] 10:11:20 62 passed in 156.72s (0:02:36) 10:11:20 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 10:11:20 ....... [100%] 10:11:24 24 passed in 92.86s (0:01:32) 10:11:24 pytest -q transportpce_tests/1.2.1/test05_olm.py 10:11:25 .... [100%] 10:11:31 35 passed in 85.71s (0:01:25) 10:11:31 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 10:12:15 ....................... [100%] 10:12:45 6 passed in 73.93s (0:01:13) 10:12:46 pytest -q transportpce_tests/2.2.1/test03_topology.py 10:12:46 ......................................................................... [100%] 10:14:03 48 passed in 162.87s (0:02:42) 10:14:03 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 10:14:03 ..................................................... [100%] 10:15:00 40 passed in 215.18s (0:03:35) 10:15:00 pytest -q transportpce_tests/1.2.1/test06_end2end.py 10:15:01 ....... [100%] 10:15:08 44 passed in 142.16s (0:02:22) 10:15:08 pytest -q transportpce_tests/2.2.1/test04_otn_topology.py 10:15:10 .... [100%] 10:15:18 22 passed in 74.87s (0:01:14) 10:15:50 ...................... [100%] 10:16:16 12 passed in 68.26s (0:01:08) 10:16:17 pytest -q transportpce_tests/2.2.1/test05_flex_grid.py 10:16:24 ......................................... [100%] 10:18:11 16 passed in 114.60s (0:01:54) 10:18:11 pytest -q transportpce_tests/2.2.1/test06_renderer_service_path_nominal.py 10:18:31 ................................... [100%] 10:18:48 31 passed in 36.10s 10:18:48 pytest -q transportpce_tests/2.2.1/test07_otn_renderer.py 10:18:54 ................................... [100%] 10:20:19 26 passed in 90.73s (0:01:30) 10:20:19 pytest -q transportpce_tests/2.2.1/test08_otn_sh_renderer.py 10:20:55 ....................... [100%] 10:21:58 22 passed in 98.98s (0:01:38) 10:21:58 pytest -q transportpce_tests/2.2.1/test09_olm.py 10:22:38 ................................. [100%] 10:24:05 54 passed in 545.46s (0:09:05) 10:24:09 ............ [100%] 10:24:59 40 passed in 181.07s (0:03:01) 10:25:00 pytest -q transportpce_tests/2.2.1/test11_otn_end2end.py 10:25:41 ........................................................................ [ 74%] 10:31:17 ......................... [100%] 10:33:09 97 passed in 489.43s (0:08:09) 10:33:09 pytest -q transportpce_tests/2.2.1/test12_end2end.py 10:33:48 ...................................................... [100%] 10:40:35 54 passed in 445.59s (0:07:25) 10:40:35 pytest -q transportpce_tests/2.2.1/test14_otn_switch_end2end.py 10:41:16 $ ssh-agent -k 10:41:16 unset SSH_AUTH_SOCK; 10:41:16 unset SSH_AGENT_PID; 10:41:16 echo Agent pid 1572 killed; 10:41:16 [ssh-agent] Stopped. 10:41:16 Build was aborted 10:41:16 Aborted by new patch set. 10:41:16 [PostBuildScript] - [INFO] Executing post build scripts. 10:41:16 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13818633432249899056.sh 10:41:16 ---> sysstat.sh 10:41:17 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins313609237899467704.sh 10:41:17 ---> package-listing.sh 10:41:17 ++ facter osfamily 10:41:17 ++ tr '[:upper:]' '[:lower:]' 10:41:17 + OS_FAMILY=debian 10:41:17 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 10:41:17 + START_PACKAGES=/tmp/packages_start.txt 10:41:17 + END_PACKAGES=/tmp/packages_end.txt 10:41:17 + DIFF_PACKAGES=/tmp/packages_diff.txt 10:41:17 + PACKAGES=/tmp/packages_start.txt 10:41:17 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 10:41:17 + PACKAGES=/tmp/packages_end.txt 10:41:17 + case "${OS_FAMILY}" in 10:41:17 + grep '^ii' 10:41:17 + dpkg -l 10:41:17 + '[' -f /tmp/packages_start.txt ']' 10:41:17 + '[' -f /tmp/packages_end.txt ']' 10:41:17 + diff /tmp/packages_start.txt /tmp/packages_end.txt 10:41:17 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 10:41:17 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 10:41:17 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 10:41:17 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8586664233597804701.sh 10:41:17 ---> capture-instance-metadata.sh 10:41:17 Setup pyenv: 10:41:17 system 10:41:17 3.8.20 10:41:17 3.9.20 10:41:17 3.10.15 10:41:17 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:41:17 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5cFN from file:/tmp/.os_lf_venv 10:41:20 lf-activate-venv(): INFO: Installing: lftools 10:41:22 Terminated 10:41:22 + tox_status=143 10:41:22 + echo '---> Completed tox runs' 10:41:22 ---> Completed tox runs 10:41:22 + for i in .tox/*/log 10:41:22 ++ echo .tox/build_karaf_tests121/log 10:41:22 ++ awk -F/ '{print $2}' 10:41:34 lf-activate-venv(): INFO: Adding /tmp/venv-5cFN/bin to PATH 10:41:34 INFO: Running in OpenStack, capturing instance metadata 10:41:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins6187797005560628062.sh 10:41:35 provisioning config files... 10:41:35 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #3449 10:41:35 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config12081172584709556916tmp 10:41:35 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 10:41:35 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 10:41:35 provisioning config files... 10:41:35 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 10:41:35 [EnvInject] - Injecting environment variables from a build step. 10:41:35 [EnvInject] - Injecting as environment variables the properties content 10:41:35 SERVER_ID=logs 10:41:35 10:41:35 [EnvInject] - Variables injected successfully. 10:41:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins9417883955421893978.sh 10:41:35 ---> create-netrc.sh 10:41:35 WARN: Log server credential not found. 10:41:35 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16344721431316486424.sh 10:41:35 ---> python-tools-install.sh 10:41:35 Setup pyenv: 10:41:35 system 10:41:35 3.8.20 10:41:35 3.9.20 10:41:35 3.10.15 10:41:35 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:41:36 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5cFN from file:/tmp/.os_lf_venv 10:41:38 lf-activate-venv(): INFO: Installing: lftools 10:41:48 lf-activate-venv(): INFO: Adding /tmp/venv-5cFN/bin to PATH 10:41:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins16604360021029363866.sh 10:41:48 ---> sudo-logs.sh 10:41:48 Archiving 'sudo' log.. 10:41:48 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12026073106007185601.sh 10:41:48 ---> job-cost.sh 10:41:48 Setup pyenv: 10:41:48 system 10:41:48 3.8.20 10:41:48 3.9.20 10:41:48 3.10.15 10:41:48 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:41:48 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5cFN from file:/tmp/.os_lf_venv 10:41:50 lf-activate-venv(): INFO: Installing: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 10:41:57 lf-activate-venv(): INFO: Adding /tmp/venv-5cFN/bin to PATH 10:41:57 INFO: No Stack... 10:41:57 INFO: Retrieving Pricing Info for: v3-standard-4 10:41:58 INFO: Archiving Costs 10:41:58 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins8411234115601431137.sh 10:41:58 ---> logs-deploy.sh 10:41:58 Setup pyenv: 10:41:58 system 10:41:58 3.8.20 10:41:58 3.9.20 10:41:58 3.10.15 10:41:58 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 10:41:58 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-5cFN from file:/tmp/.os_lf_venv 10:42:00 lf-activate-venv(): INFO: Installing: lftools 10:42:09 lf-activate-venv(): INFO: Adding /tmp/venv-5cFN/bin to PATH 10:42:09 WARNING: Nexus logging server not set 10:42:09 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/3449/ 10:42:09 INFO: archiving logs to S3 10:42:11 ---> uname -a: 10:42:11 Linux prd-ubuntu2204-docker-4c-16g-43485 5.15.0-131-generic #141-Ubuntu SMP Fri Jan 10 21:18:28 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux 10:42:11 10:42:11 10:42:11 ---> lscpu: 10:42:11 Architecture: x86_64 10:42:11 CPU op-mode(s): 32-bit, 64-bit 10:42:11 Address sizes: 40 bits physical, 48 bits virtual 10:42:11 Byte Order: Little Endian 10:42:11 CPU(s): 4 10:42:11 On-line CPU(s) list: 0-3 10:42:11 Vendor ID: AuthenticAMD 10:42:11 Model name: AMD EPYC-Rome Processor 10:42:11 CPU family: 23 10:42:11 Model: 49 10:42:11 Thread(s) per core: 1 10:42:11 Core(s) per socket: 1 10:42:11 Socket(s): 4 10:42:11 Stepping: 0 10:42:11 BogoMIPS: 5600.00 10:42:11 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 10:42:11 Virtualization: AMD-V 10:42:11 Hypervisor vendor: KVM 10:42:11 Virtualization type: full 10:42:11 L1d cache: 128 KiB (4 instances) 10:42:11 L1i cache: 128 KiB (4 instances) 10:42:11 L2 cache: 2 MiB (4 instances) 10:42:11 L3 cache: 64 MiB (4 instances) 10:42:11 NUMA node(s): 1 10:42:11 NUMA node0 CPU(s): 0-3 10:42:11 Vulnerability Gather data sampling: Not affected 10:42:11 Vulnerability Itlb multihit: Not affected 10:42:11 Vulnerability L1tf: Not affected 10:42:11 Vulnerability Mds: Not affected 10:42:11 Vulnerability Meltdown: Not affected 10:42:11 Vulnerability Mmio stale data: Not affected 10:42:11 Vulnerability Reg file data sampling: Not affected 10:42:11 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 10:42:11 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 10:42:11 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 10:42:11 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 10:42:11 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 10:42:11 Vulnerability Srbds: Not affected 10:42:11 Vulnerability Tsx async abort: Not affected 10:42:11 10:42:11 10:42:11 ---> nproc: 10:42:11 4 10:42:11 10:42:11 10:42:11 ---> df -h: 10:42:11 Filesystem Size Used Avail Use% Mounted on 10:42:11 tmpfs 1.6G 1.1M 1.6G 1% /run 10:42:11 /dev/vda1 78G 17G 61G 22% / 10:42:11 tmpfs 7.9G 0 7.9G 0% /dev/shm 10:42:11 tmpfs 5.0M 0 5.0M 0% /run/lock 10:42:11 /dev/vda15 105M 6.1M 99M 6% /boot/efi 10:42:11 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 10:42:11 10:42:11 10:42:11 ---> free -m: 10:42:11 total used free shared buff/cache available 10:42:11 Mem: 15989 1275 10741 3 3971 14371 10:42:11 Swap: 1023 1 1022 10:42:11 10:42:11 10:42:11 ---> ip addr: 10:42:11 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 10:42:11 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 10:42:11 inet 127.0.0.1/8 scope host lo 10:42:11 valid_lft forever preferred_lft forever 10:42:11 inet6 ::1/128 scope host 10:42:11 valid_lft forever preferred_lft forever 10:42:11 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 10:42:11 link/ether fa:16:3e:9d:ff:fb brd ff:ff:ff:ff:ff:ff 10:42:11 altname enp0s3 10:42:11 inet 10.30.171.145/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 10:42:11 valid_lft 83552sec preferred_lft 83552sec 10:42:11 inet6 fe80::f816:3eff:fe9d:fffb/64 scope link 10:42:11 valid_lft forever preferred_lft forever 10:42:11 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 10:42:11 link/ether 02:42:4f:fa:ba:ac brd ff:ff:ff:ff:ff:ff 10:42:11 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 10:42:11 valid_lft forever preferred_lft forever 10:42:11 10:42:11 10:42:11 ---> sar -b -r -n DEV: 10:42:11 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-43485) 07/17/25 _x86_64_ (4 CPU) 10:42:11 10:42:11 09:54:46 LINUX RESTART (4 CPU) 10:42:11 10:42:11 10:00:00 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 10:42:11 10:10:02 101.68 28.70 55.54 17.44 995.73 10205.17 234763.06 10:42:11 10:20:02 30.84 0.99 28.28 1.57 12.44 933.47 950.90 10:42:11 10:30:02 9.40 0.02 8.96 0.43 1.40 174.12 379.97 10:42:11 10:40:02 4.58 0.02 4.37 0.18 1.04 86.47 59.17 10:42:11 Average: 36.67 7.45 24.30 4.91 253.12 2854.46 59149.49 10:42:11 10:42:11 10:00:00 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 10:42:11 10:10:02 9330716 12886404 3046280 18.61 244796 3287768 3850796 22.10 1975524 4504864 37324 10:42:11 10:20:02 6202560 9815616 6117752 37.36 250448 3337516 6860004 39.38 2037856 7543276 332 10:42:11 10:30:02 7710248 11329528 4605724 28.13 251956 3342216 5344892 30.68 2040992 6053484 308 10:42:11 10:40:02 7785136 11409452 4525664 27.64 252660 3346548 5251856 30.15 2042252 5972604 704 10:42:11 Average: 7757165 11360250 4573855 27.94 249965 3328512 5326887 30.58 2024156 6018557 9667 10:42:11 10:42:11 10:00:00 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 10:42:11 10:10:02 lo 21.67 21.67 17.17 17.17 0.00 0.00 0.00 0.00 10:42:11 10:10:02 ens3 11.17 6.09 179.70 0.94 0.00 0.00 0.00 0.00 10:42:11 10:10:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10:42:11 10:20:02 lo 43.74 43.74 18.31 18.31 0.00 0.00 0.00 0.00 10:42:11 10:20:02 ens3 1.99 1.82 0.42 1.19 0.00 0.00 0.00 0.00 10:42:11 10:20:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10:42:11 10:30:02 lo 27.21 27.21 12.45 12.45 0.00 0.00 0.00 0.00 10:42:11 10:30:02 ens3 0.95 0.81 0.19 0.16 0.00 0.00 0.00 0.00 10:42:11 10:30:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10:42:11 10:40:02 lo 27.74 27.74 10.07 10.07 0.00 0.00 0.00 0.00 10:42:11 10:40:02 ens3 0.72 0.60 0.17 0.14 0.00 0.00 0.00 0.00 10:42:11 10:40:02 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10:42:11 Average: lo 30.08 30.08 14.50 14.50 0.00 0.00 0.00 0.00 10:42:11 Average: ens3 3.71 2.33 45.21 0.61 0.00 0.00 0.00 0.00 10:42:11 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10:42:11 10:42:11 10:42:11 ---> sar -P ALL: 10:42:11 Linux 5.15.0-131-generic (prd-ubuntu2204-docker-4c-16g-43485) 07/17/25 _x86_64_ (4 CPU) 10:42:11 10:42:11 09:54:46 LINUX RESTART (4 CPU) 10:42:11 10:42:11 10:00:00 CPU %user %nice %system %iowait %steal %idle 10:42:11 10:10:02 all 51.12 0.00 2.14 0.87 0.09 45.77 10:42:11 10:10:02 0 51.10 0.00 2.06 0.59 0.09 46.16 10:42:11 10:10:02 1 51.39 0.00 2.17 1.14 0.10 45.20 10:42:11 10:10:02 2 49.94 0.00 2.33 1.36 0.10 46.27 10:42:11 10:10:02 3 52.05 0.00 2.00 0.40 0.09 45.46 10:42:11 10:20:02 all 49.75 0.00 1.76 0.06 0.10 48.33 10:42:11 10:20:02 0 49.70 0.00 1.75 0.03 0.10 48.42 10:42:11 10:20:02 1 50.17 0.00 1.76 0.06 0.10 47.91 10:42:11 10:20:02 2 49.53 0.00 1.67 0.08 0.11 48.62 10:42:11 10:20:02 3 49.62 0.00 1.84 0.09 0.10 48.34 10:42:11 10:30:02 all 17.50 0.00 0.75 0.03 0.10 81.63 10:42:11 10:30:02 0 17.03 0.00 0.74 0.02 0.09 82.11 10:42:11 10:30:02 1 17.76 0.00 0.74 0.02 0.10 81.38 10:42:11 10:30:02 2 17.52 0.00 0.74 0.02 0.10 81.64 10:42:11 10:30:02 3 17.68 0.00 0.78 0.06 0.10 81.39 10:42:11 10:40:02 all 8.05 0.00 0.47 0.02 0.08 91.37 10:42:11 10:40:02 0 8.10 0.00 0.44 0.01 0.08 91.37 10:42:11 10:40:02 1 8.38 0.00 0.48 0.03 0.09 91.02 10:42:11 10:40:02 2 7.76 0.00 0.50 0.01 0.09 91.64 10:42:11 10:40:02 3 7.97 0.00 0.47 0.01 0.08 91.47 10:42:11 Average: all 31.60 0.00 1.28 0.25 0.09 66.78 10:42:11 Average: 0 31.48 0.00 1.25 0.16 0.09 67.02 10:42:11 Average: 1 31.90 0.00 1.29 0.31 0.09 66.40 10:42:11 Average: 2 31.17 0.00 1.31 0.37 0.10 67.06 10:42:11 Average: 3 31.83 0.00 1.27 0.14 0.09 66.66 10:42:11 10:42:11 10:42:11