12:33:44 Triggered by Gerrit: https://git.opendaylight.org/gerrit/c/transportpce/+/120303 12:33:44 Running as SYSTEM 12:33:44 [EnvInject] - Loading node environment variables. 12:33:44 Building remotely on prd-ubuntu2204-docker-4c-16g-14098 (ubuntu2204-docker-4c-16g) in workspace /w/workspace/transportpce-tox-verify-transportpce-master 12:33:45 [ssh-agent] Looking for ssh-agent implementation... 12:33:45 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 12:33:45 $ ssh-agent 12:33:46 SSH_AUTH_SOCK=/tmp/ssh-XXXXXX9lsF5F/agent.1570 12:33:46 SSH_AGENT_PID=1572 12:33:46 [ssh-agent] Started. 12:33:46 Running ssh-add (command line suppressed) 12:33:46 Identity added: /w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_10191901467472859518.key (/w/workspace/transportpce-tox-verify-transportpce-master@tmp/private_key_10191901467472859518.key) 12:33:46 [ssh-agent] Using credentials jenkins (jenkins-ssh) 12:33:46 The recommended git tool is: NONE 12:33:48 using credential jenkins-ssh 12:33:48 Wiping out workspace first. 12:33:48 Cloning the remote Git repository 12:33:48 Cloning repository git://devvexx.opendaylight.org/mirror/transportpce 12:33:48 > git init /w/workspace/transportpce-tox-verify-transportpce-master # timeout=10 12:33:48 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 12:33:48 > git --version # timeout=10 12:33:48 > git --version # 'git version 2.34.1' 12:33:48 using GIT_SSH to set credentials jenkins-ssh 12:33:48 Verifying host key using known hosts file 12:33:48 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. 12:33:48 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce +refs/heads/*:refs/remotes/origin/* # timeout=10 12:33:52 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 12:33:52 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 12:33:53 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/transportpce # timeout=10 12:33:53 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/transportpce 12:33:53 using GIT_SSH to set credentials jenkins-ssh 12:33:53 Verifying host key using known hosts file 12:33:53 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. 12:33:53 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/transportpce refs/changes/03/120303/6 # timeout=10 12:33:53 > git rev-parse 938fbb0c86afe89dd340796db68f62994206c8ea^{commit} # timeout=10 12:33:53 JENKINS-19022: warning: possible memory leak due to Git plugin usage; see: https://plugins.jenkins.io/git/#remove-git-plugin-buildsbybranch-builddata-script 12:33:53 Checking out Revision 938fbb0c86afe89dd340796db68f62994206c8ea (refs/changes/03/120303/6) 12:33:53 > git config core.sparsecheckout # timeout=10 12:33:53 > git checkout -f 938fbb0c86afe89dd340796db68f62994206c8ea # timeout=10 12:33:53 Commit message: "TAPI - Refactor photonic NEP spectrum construction" 12:33:53 > git rev-parse FETCH_HEAD^{commit} # timeout=10 12:33:54 > git rev-list --no-walk e03794ea919e6f279cc9e8e1682dd749ae0238ec # timeout=10 12:33:54 > git remote # timeout=10 12:33:54 > git submodule init # timeout=10 12:33:54 > git submodule sync # timeout=10 12:33:54 > git config --get remote.origin.url # timeout=10 12:33:54 > git submodule init # timeout=10 12:33:54 > git config -f .gitmodules --get-regexp ^submodule\.(.+)\.url # timeout=10 12:33:54 ERROR: No submodules found. 12:33:57 provisioning config files... 12:33:57 copy managed file [npmrc] to file:/home/jenkins/.npmrc 12:33:57 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 12:33:57 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins7221258513131130923.sh 12:33:57 ---> python-tools-install.sh 12:33:57 Setup pyenv: 12:33:57 * system (set by /opt/pyenv/version) 12:33:57 * 3.8.20 (set by /opt/pyenv/version) 12:33:57 * 3.9.20 (set by /opt/pyenv/version) 12:33:57 3.10.15 12:33:57 3.11.10 12:34:03 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-D0HF 12:34:03 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 12:34:03 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:34:03 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:34:10 lf-activate-venv(): INFO: Base packages installed successfully 12:34:10 lf-activate-venv(): INFO: Installing additional packages: lftools 12:36:40 lf-activate-venv(): INFO: Adding /tmp/venv-D0HF/bin to PATH 12:36:40 Generating Requirements File 12:37:06 ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts. 12:37:06 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 12:37:06 Python 3.11.10 12:37:06 pip 26.0.1 from /tmp/venv-D0HF/lib/python3.11/site-packages/pip (python 3.11) 12:37:07 appdirs==1.4.4 12:37:07 argcomplete==3.6.3 12:37:07 aspy.yaml==1.3.0 12:37:07 attrs==25.4.0 12:37:07 autopage==0.6.0 12:37:07 beautifulsoup4==4.14.3 12:37:07 boto3==1.42.51 12:37:07 botocore==1.42.51 12:37:07 bs4==0.0.2 12:37:07 certifi==2026.1.4 12:37:07 cffi==2.0.0 12:37:07 cfgv==3.5.0 12:37:07 chardet==5.2.0 12:37:07 charset-normalizer==3.4.4 12:37:07 click==8.3.1 12:37:07 cliff==4.13.2 12:37:07 cmd2==3.2.0 12:37:07 cryptography==3.3.2 12:37:07 debtcollector==3.0.0 12:37:07 decorator==5.2.1 12:37:07 defusedxml==0.7.1 12:37:07 Deprecated==1.3.1 12:37:07 distlib==0.4.0 12:37:07 dnspython==2.8.0 12:37:07 docker==7.1.0 12:37:07 dogpile.cache==1.5.0 12:37:07 durationpy==0.10 12:37:07 email-validator==2.3.0 12:37:07 filelock==3.24.2 12:37:07 future==1.0.0 12:37:07 gitdb==4.0.12 12:37:07 GitPython==3.1.46 12:37:07 httplib2==0.30.2 12:37:07 identify==2.6.16 12:37:07 idna==3.11 12:37:07 importlib-resources==1.5.0 12:37:07 iso8601==2.1.0 12:37:07 Jinja2==3.1.6 12:37:07 jmespath==1.1.0 12:37:07 jsonpatch==1.33 12:37:07 jsonpointer==3.0.0 12:37:07 jsonschema==4.26.0 12:37:07 jsonschema-specifications==2025.9.1 12:37:07 keystoneauth1==5.13.0 12:37:07 kubernetes==35.0.0 12:37:07 lftools==0.37.21 12:37:07 lxml==6.0.2 12:37:07 markdown-it-py==4.0.0 12:37:07 MarkupSafe==3.0.3 12:37:07 mdurl==0.1.2 12:37:07 msgpack==1.1.2 12:37:07 multi_key_dict==2.0.3 12:37:07 munch==4.0.0 12:37:07 netaddr==1.3.0 12:37:07 niet==1.4.2 12:37:07 nodeenv==1.10.0 12:37:07 oauth2client==4.1.3 12:37:07 oauthlib==3.3.1 12:37:07 openstacksdk==4.10.0 12:37:07 os-service-types==1.8.2 12:37:07 osc-lib==4.4.0 12:37:07 oslo.config==10.3.0 12:37:07 oslo.context==6.3.0 12:37:07 oslo.i18n==6.7.2 12:37:07 oslo.log==8.0.0 12:37:07 oslo.serialization==5.9.1 12:37:07 oslo.utils==9.2.0 12:37:07 packaging==26.0 12:37:07 pbr==7.0.3 12:37:07 platformdirs==4.9.2 12:37:07 prettytable==3.17.0 12:37:07 psutil==7.2.2 12:37:07 pyasn1==0.6.2 12:37:07 pyasn1_modules==0.4.2 12:37:07 pycparser==3.0 12:37:07 pygerrit2==2.0.15 12:37:07 PyGithub==2.8.1 12:37:07 Pygments==2.19.2 12:37:07 PyJWT==2.11.0 12:37:07 PyNaCl==1.6.2 12:37:07 pyparsing==2.4.7 12:37:07 pyperclip==1.11.0 12:37:07 pyrsistent==0.20.0 12:37:07 python-cinderclient==9.8.0 12:37:07 python-dateutil==2.9.0.post0 12:37:07 python-heatclient==5.0.0 12:37:07 python-jenkins==1.8.3 12:37:07 python-keystoneclient==5.7.0 12:37:07 python-magnumclient==4.9.0 12:37:07 python-openstackclient==9.0.0 12:37:07 python-swiftclient==4.9.0 12:37:07 PyYAML==6.0.3 12:37:07 referencing==0.37.0 12:37:07 requests==2.32.5 12:37:07 requests-oauthlib==2.0.0 12:37:07 requestsexceptions==1.4.0 12:37:07 rfc3986==2.0.0 12:37:07 rich==14.3.2 12:37:07 rich-argparse==1.7.2 12:37:07 rpds-py==0.30.0 12:37:07 rsa==4.9.1 12:37:07 ruamel.yaml==0.19.1 12:37:07 ruamel.yaml.clib==0.2.15 12:37:07 s3transfer==0.16.0 12:37:07 simplejson==3.20.2 12:37:07 six==1.17.0 12:37:07 smmap==5.0.2 12:37:07 soupsieve==2.8.3 12:37:07 stevedore==5.6.0 12:37:07 tabulate==0.9.0 12:37:07 toml==0.10.2 12:37:07 tomlkit==0.14.0 12:37:07 tqdm==4.67.3 12:37:07 typing_extensions==4.15.0 12:37:07 tzdata==2025.3 12:37:07 urllib3==1.26.20 12:37:07 virtualenv==20.37.0 12:37:07 wcwidth==0.6.0 12:37:07 websocket-client==1.9.0 12:37:07 wrapt==2.1.1 12:37:07 xdg==6.0.0 12:37:07 xmltodict==1.0.3 12:37:07 yq==3.4.3 12:37:07 [EnvInject] - Injecting environment variables from a build step. 12:37:07 [EnvInject] - Injecting as environment variables the properties content 12:37:07 PYTHON=python3 12:37:07 12:37:07 [EnvInject] - Variables injected successfully. 12:37:07 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins17165815369169395844.sh 12:37:07 ---> tox-install.sh 12:37:07 + source /home/jenkins/lf-env.sh 12:37:07 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 12:37:07 ++ mktemp -d /tmp/venv-XXXX 12:37:07 + lf_venv=/tmp/venv-eJwr 12:37:07 + local venv_file=/tmp/.os_lf_venv 12:37:07 + local python=python3 12:37:07 + local options 12:37:07 + local set_path=true 12:37:07 + local install_args= 12:37:07 ++ 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 12:37:07 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:37:07 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:37:07 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 12:37:07 + true 12:37:07 + case $1 in 12:37:07 + venv_file=/tmp/.toxenv 12:37:07 + shift 2 12:37:07 + true 12:37:07 + case $1 in 12:37:07 + shift 12:37:07 + break 12:37:07 + case $python in 12:37:07 + local pkg_list= 12:37:07 + [[ -d /opt/pyenv ]] 12:37:07 + echo 'Setup pyenv:' 12:37:07 Setup pyenv: 12:37:07 + export PYENV_ROOT=/opt/pyenv 12:37:07 + PYENV_ROOT=/opt/pyenv 12:37:07 + 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 12:37:07 + 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 12:37:07 + pyenv versions 12:37:07 system 12:37:07 3.8.20 12:37:07 3.9.20 12:37:07 3.10.15 12:37:07 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:37:07 + command -v pyenv 12:37:07 ++ pyenv init - --no-rehash 12:37:07 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 12:37:07 for i in ${!paths[@]}; do 12:37:07 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 12:37:07 fi; done; 12:37:07 echo "${paths[*]}"'\'')" 12:37:07 export PATH="/opt/pyenv/shims:${PATH}" 12:37:07 export PYENV_SHELL=bash 12:37:07 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 12:37:07 pyenv() { 12:37:07 local command 12:37:07 command="${1:-}" 12:37:07 if [ "$#" -gt 0 ]; then 12:37:07 shift 12:37:07 fi 12:37:07 12:37:07 case "$command" in 12:37:07 rehash|shell) 12:37:07 eval "$(pyenv "sh-$command" "$@")" 12:37:07 ;; 12:37:07 *) 12:37:07 command pyenv "$command" "$@" 12:37:07 ;; 12:37:07 esac 12:37:07 }' 12:37:07 +++ bash --norc -ec 'IFS=:; paths=($PATH); 12:37:07 for i in ${!paths[@]}; do 12:37:07 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 12:37:07 fi; done; 12:37:07 echo "${paths[*]}"' 12:37:07 ++ 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 12:37:07 ++ 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 12:37:07 ++ 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 12:37:07 ++ export PYENV_SHELL=bash 12:37:07 ++ PYENV_SHELL=bash 12:37:07 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 12:37:07 +++ complete -F _pyenv pyenv 12:37:07 ++ lf-pyver python3 12:37:07 ++ local py_version_xy=python3 12:37:07 ++ local py_version_xyz= 12:37:07 ++ pyenv versions 12:37:07 ++ local command 12:37:07 ++ command=versions 12:37:07 ++ '[' 1 -gt 0 ']' 12:37:07 ++ shift 12:37:07 ++ case "$command" in 12:37:07 ++ command pyenv versions 12:37:07 ++ sed 's/^[ *]* //' 12:37:07 ++ awk '{ print $1 }' 12:37:07 ++ grep -E '^[0-9.]*[0-9]$' 12:37:07 ++ [[ ! -s /tmp/.pyenv_versions ]] 12:37:07 +++ grep '^3' /tmp/.pyenv_versions 12:37:07 +++ sort -V 12:37:07 +++ tail -n 1 12:37:07 ++ py_version_xyz=3.11.10 12:37:07 ++ [[ -z 3.11.10 ]] 12:37:07 ++ echo 3.11.10 12:37:07 ++ return 0 12:37:07 + pyenv local 3.11.10 12:37:07 + local command 12:37:07 + command=local 12:37:07 + '[' 2 -gt 0 ']' 12:37:07 + shift 12:37:07 + case "$command" in 12:37:07 + command pyenv local 3.11.10 12:37:07 + for arg in "$@" 12:37:07 + case $arg in 12:37:07 + pkg_list+='tox ' 12:37:07 + for arg in "$@" 12:37:07 + case $arg in 12:37:07 + pkg_list+='virtualenv ' 12:37:07 + for arg in "$@" 12:37:07 + case $arg in 12:37:07 + pkg_list+='urllib3~=1.26.15 ' 12:37:07 + [[ -f /tmp/.toxenv ]] 12:37:07 + [[ ! -f /tmp/.toxenv ]] 12:37:07 + [[ -n '' ]] 12:37:07 + python3 -m venv /tmp/venv-eJwr 12:37:12 + echo 'lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-eJwr' 12:37:12 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-eJwr 12:37:12 + echo /tmp/venv-eJwr 12:37:12 + echo 'lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv' 12:37:12 lf-activate-venv(): INFO: Save venv in file: /tmp/.toxenv 12:37:12 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 12:37:12 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:37:12 + local 'pip_opts=--upgrade --quiet' 12:37:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 12:37:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 12:37:12 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 12:37:12 + [[ -n '' ]] 12:37:12 + [[ -n '' ]] 12:37:12 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 12:37:12 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:37:12 + /tmp/venv-eJwr/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org pip 'setuptools<66' virtualenv 12:37:17 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 12:37:17 lf-activate-venv(): INFO: Base packages installed successfully 12:37:17 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 12:37:17 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 12:37:17 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 12:37:17 + /tmp/venv-eJwr/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 12:37:23 + type python3 12:37:23 + true 12:37:23 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-eJwr/bin to PATH' 12:37:23 lf-activate-venv(): INFO: Adding /tmp/venv-eJwr/bin to PATH 12:37:23 + PATH=/tmp/venv-eJwr/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 12:37:23 + return 0 12:37:23 + python3 --version 12:37:23 Python 3.11.10 12:37:23 + python3 -m pip --version 12:37:23 pip 26.0.1 from /tmp/venv-eJwr/lib/python3.11/site-packages/pip (python 3.11) 12:37:23 + python3 -m pip freeze 12:37:23 cachetools==7.0.1 12:37:23 chardet==5.2.0 12:37:23 colorama==0.4.6 12:37:23 distlib==0.4.0 12:37:23 filelock==3.24.2 12:37:23 packaging==26.0 12:37:23 platformdirs==4.9.2 12:37:23 pluggy==1.6.0 12:37:23 pyproject-api==1.10.0 12:37:23 tox==4.38.0 12:37:23 urllib3==1.26.20 12:37:23 virtualenv==20.37.0 12:37:23 [transportpce-tox-verify-transportpce-master] $ /bin/sh -xe /tmp/jenkins15780421999417511720.sh 12:37:23 [EnvInject] - Injecting environment variables from a build step. 12:37:23 [EnvInject] - Injecting as environment variables the properties content 12:37:23 PARALLEL=True 12:37:23 12:37:23 [EnvInject] - Variables injected successfully. 12:37:23 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins5097511298006353246.sh 12:37:23 ---> tox-run.sh 12:37:23 + 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 12:37:23 + ARCHIVE_TOX_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 12:37:23 + ARCHIVE_DOC_DIR=/w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 12:37:23 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox 12:37:23 + cd /w/workspace/transportpce-tox-verify-transportpce-master/. 12:37:23 + source /home/jenkins/lf-env.sh 12:37:23 + lf-activate-venv --venv-file /tmp/.toxenv tox virtualenv urllib3~=1.26.15 12:37:23 ++ mktemp -d /tmp/venv-XXXX 12:37:23 + lf_venv=/tmp/venv-SZgF 12:37:23 + local venv_file=/tmp/.os_lf_venv 12:37:23 + local python=python3 12:37:23 + local options 12:37:23 + local set_path=true 12:37:23 + local install_args= 12:37:23 ++ 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 12:37:23 + options=' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:37:23 + eval set -- ' --venv-file '\''/tmp/.toxenv'\'' -- '\''tox'\'' '\''virtualenv'\'' '\''urllib3~=1.26.15'\''' 12:37:23 ++ set -- --venv-file /tmp/.toxenv -- tox virtualenv urllib3~=1.26.15 12:37:23 + true 12:37:23 + case $1 in 12:37:23 + venv_file=/tmp/.toxenv 12:37:23 + shift 2 12:37:23 + true 12:37:23 + case $1 in 12:37:23 + shift 12:37:23 + break 12:37:23 + case $python in 12:37:23 + local pkg_list= 12:37:23 + [[ -d /opt/pyenv ]] 12:37:23 + echo 'Setup pyenv:' 12:37:23 Setup pyenv: 12:37:23 + export PYENV_ROOT=/opt/pyenv 12:37:23 + PYENV_ROOT=/opt/pyenv 12:37:23 + 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 12:37:23 + 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 12:37:23 + pyenv versions 12:37:23 system 12:37:23 3.8.20 12:37:23 3.9.20 12:37:23 3.10.15 12:37:23 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 12:37:23 + command -v pyenv 12:37:23 ++ pyenv init - --no-rehash 12:37:23 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 12:37:23 for i in ${!paths[@]}; do 12:37:23 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 12:37:23 fi; done; 12:37:23 echo "${paths[*]}"'\'')" 12:37:23 export PATH="/opt/pyenv/shims:${PATH}" 12:37:23 export PYENV_SHELL=bash 12:37:23 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 12:37:23 pyenv() { 12:37:23 local command 12:37:23 command="${1:-}" 12:37:23 if [ "$#" -gt 0 ]; then 12:37:23 shift 12:37:23 fi 12:37:23 12:37:23 case "$command" in 12:37:23 rehash|shell) 12:37:23 eval "$(pyenv "sh-$command" "$@")" 12:37:23 ;; 12:37:23 *) 12:37:23 command pyenv "$command" "$@" 12:37:23 ;; 12:37:23 esac 12:37:23 }' 12:37:23 +++ bash --norc -ec 'IFS=:; paths=($PATH); 12:37:23 for i in ${!paths[@]}; do 12:37:23 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 12:37:23 fi; done; 12:37:23 echo "${paths[*]}"' 12:37:23 ++ 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 12:37:23 ++ 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 12:37:23 ++ 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 12:37:23 ++ export PYENV_SHELL=bash 12:37:23 ++ PYENV_SHELL=bash 12:37:23 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 12:37:23 +++ complete -F _pyenv pyenv 12:37:23 ++ lf-pyver python3 12:37:23 ++ local py_version_xy=python3 12:37:23 ++ local py_version_xyz= 12:37:23 ++ pyenv versions 12:37:23 ++ local command 12:37:23 ++ command=versions 12:37:23 ++ '[' 1 -gt 0 ']' 12:37:23 ++ shift 12:37:23 ++ case "$command" in 12:37:23 ++ command pyenv versions 12:37:23 ++ sed 's/^[ *]* //' 12:37:23 ++ grep -E '^[0-9.]*[0-9]$' 12:37:23 ++ awk '{ print $1 }' 12:37:23 ++ [[ ! -s /tmp/.pyenv_versions ]] 12:37:23 +++ grep '^3' /tmp/.pyenv_versions 12:37:23 +++ sort -V 12:37:23 +++ tail -n 1 12:37:23 ++ py_version_xyz=3.11.10 12:37:23 ++ [[ -z 3.11.10 ]] 12:37:23 ++ echo 3.11.10 12:37:23 ++ return 0 12:37:23 + pyenv local 3.11.10 12:37:23 + local command 12:37:23 + command=local 12:37:23 + '[' 2 -gt 0 ']' 12:37:23 + shift 12:37:23 + case "$command" in 12:37:23 + command pyenv local 3.11.10 12:37:23 + for arg in "$@" 12:37:23 + case $arg in 12:37:23 + pkg_list+='tox ' 12:37:23 + for arg in "$@" 12:37:23 + case $arg in 12:37:23 + pkg_list+='virtualenv ' 12:37:23 + for arg in "$@" 12:37:23 + case $arg in 12:37:23 + pkg_list+='urllib3~=1.26.15 ' 12:37:23 + [[ -f /tmp/.toxenv ]] 12:37:23 ++ cat /tmp/.toxenv 12:37:23 + lf_venv=/tmp/venv-eJwr 12:37:23 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-eJwr from' file:/tmp/.toxenv 12:37:23 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-eJwr from file:/tmp/.toxenv 12:37:23 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 12:37:23 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 12:37:23 + local 'pip_opts=--upgrade --quiet' 12:37:23 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 12:37:23 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 12:37:23 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 12:37:23 + [[ -n '' ]] 12:37:23 + [[ -n '' ]] 12:37:23 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 12:37:23 lf-activate-venv(): INFO: Attempting to install with network-safe options... 12:37:23 + /tmp/venv-eJwr/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org pip 'setuptools<66' virtualenv 12:37:24 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 12:37:24 lf-activate-venv(): INFO: Base packages installed successfully 12:37:24 + [[ -z tox virtualenv urllib3~=1.26.15 ]] 12:37:24 + echo 'lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 ' 12:37:24 lf-activate-venv(): INFO: Installing additional packages: tox virtualenv urllib3~=1.26.15 12:37:24 + /tmp/venv-eJwr/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org --upgrade-strategy eager tox virtualenv urllib3~=1.26.15 12:37:26 + type python3 12:37:26 + true 12:37:26 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-eJwr/bin to PATH' 12:37:26 lf-activate-venv(): INFO: Adding /tmp/venv-eJwr/bin to PATH 12:37:26 + PATH=/tmp/venv-eJwr/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 12:37:26 + return 0 12:37:26 + [[ -d /opt/pyenv ]] 12:37:26 + echo '---> Setting up pyenv' 12:37:26 ---> Setting up pyenv 12:37:26 + export PYENV_ROOT=/opt/pyenv 12:37:26 + PYENV_ROOT=/opt/pyenv 12:37:26 + export PATH=/opt/pyenv/bin:/tmp/venv-eJwr/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 12:37:26 + PATH=/opt/pyenv/bin:/tmp/venv-eJwr/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 12:37:26 ++ pwd 12:37:26 + PYTHONPATH=/w/workspace/transportpce-tox-verify-transportpce-master 12:37:26 + export PYTHONPATH 12:37:26 + export TOX_TESTENV_PASSENV=PYTHONPATH 12:37:26 + TOX_TESTENV_PASSENV=PYTHONPATH 12:37:26 + tox --version 12:37:26 4.38.0 from /tmp/venv-eJwr/lib/python3.11/site-packages/tox/__init__.py 12:37:26 + PARALLEL=True 12:37:26 + TOX_OPTIONS_LIST= 12:37:26 + [[ -n '' ]] 12:37:26 + case ${PARALLEL,,} in 12:37:26 + TOX_OPTIONS_LIST=' --parallel auto --parallel-live' 12:37:26 + tox --parallel auto --parallel-live 12:37:26 + tee -a /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tox.log 12:37:27 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 12:37:27 docs: install_deps> python -I -m pip install -r docs/requirements.txt 12:37:27 docs-linkcheck: install_deps> python -I -m pip install -r docs/requirements.txt 12:37:27 checkbashisms: freeze> python -m pip freeze --all 12:37:28 checkbashisms: pip==26.0.1,setuptools==82.0.0 12:37:28 checkbashisms: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 12:37:28 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)' 12:37:28 checkbashisms: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> find . -not -path '*/\.*' -name '*.sh' -exec checkbashisms -f '{}' + 12:37:30 checkbashisms: OK ✔ in 3.36 seconds 12:37:30 pre-commit: install_deps> python -I -m pip install pre-commit 12:37:33 pre-commit: freeze> python -m pip freeze --all 12:37:33 pre-commit: cfgv==3.5.0,distlib==0.4.0,filelock==3.24.2,identify==2.6.16,nodeenv==1.10.0,pip==26.0.1,platformdirs==4.9.2,pre_commit==4.5.1,PyYAML==6.0.3,setuptools==82.0.0,virtualenv==20.37.0 12:37:33 pre-commit: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./fixCIcentOS8reposMirrors.sh 12:37:33 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)' 12:37:33 /usr/bin/cpan 12:37:33 pre-commit: commands[2] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run --all-files --show-diff-on-failure 12:37:33 [WARNING] hook id `remove-tabs` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 12:37:33 [WARNING] hook id `perltidy` uses deprecated stage names (commit) which will be removed in a future version. run: `pre-commit migrate-config` to automatically fix this. 12:37:33 [INFO] Initializing environment for https://github.com/pre-commit/pre-commit-hooks. 12:37:34 [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. 12:37:34 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint. 12:37:35 [INFO] Initializing environment for https://github.com/jorisroovers/gitlint:./gitlint-core[trusted-deps]. 12:37:35 [INFO] Initializing environment for https://github.com/Lucas-C/pre-commit-hooks. 12:37:36 [INFO] Initializing environment for https://github.com/pre-commit/mirrors-autopep8. 12:37:36 [INFO] Initializing environment for https://github.com/perltidy/perltidy. 12:37:38 [INFO] Installing environment for https://github.com/pre-commit/pre-commit-hooks. 12:37:38 [INFO] Once installed this environment will be reused. 12:37:38 [INFO] This may take a few minutes... 12:37:39 buildcontroller: freeze> python -m pip freeze --all 12:37:40 buildcontroller: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:37:40 buildcontroller: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_controller.sh 12:37:40 + update-java-alternatives -l 12:37:40 java-1.11.0-openjdk-amd64 1111 /usr/lib/jvm/java-1.11.0-openjdk-amd64 12:37:40 java-1.17.0-openjdk-amd64 1711 /usr/lib/jvm/java-1.17.0-openjdk-amd64 12:37:40 java-1.21.0-openjdk-amd64 2111 /usr/lib/jvm/java-1.21.0-openjdk-amd64 12:37:40 + sudo update-java-alternatives -s java-1.21.0-openjdk-amd64 12:37:40 update-alternatives: error: no alternatives for jaotc 12:37:41 update-alternatives: error: no alternatives for rmic 12:37:41 + java -version 12:37:41 + sed -n ;s/.* version "\(.*\)\.\(.*\)\..*".*$/\1/p; 12:37:41 + JAVA_VER=21 12:37:41 + echo 21 12:37:41 21 12:37:41 + javac -version 12:37:41 + sed -n ;s/javac \(.*\)\.\(.*\)\..*.*$/\1/p; 12:37:42 + JAVAC_VER=21 12:37:42 + echo 21 12:37:42 + [ 21 -ge 21 ] 12:37:42 21 12:37:42 ok, java is 21 or newer 12:37:42 + [ 21 -ge 21 ] 12:37:42 + echo ok, java is 21 or newer 12:37:42 + wget -nv https://dlcdn.apache.org/maven/maven-3/3.9.12/binaries/apache-maven-3.9.12-bin.tar.gz -P /tmp 12:37:42 2026-02-18 12:37:42 URL:https://dlcdn.apache.org/maven/maven-3/3.9.12/binaries/apache-maven-3.9.12-bin.tar.gz [9233336/9233336] -> "/tmp/apache-maven-3.9.12-bin.tar.gz" [1] 12:37:42 + sudo mkdir -p /opt 12:37:42 + sudo tar xf /tmp/apache-maven-3.9.12-bin.tar.gz -C /opt 12:37:42 + sudo ln -s /opt/apache-maven-3.9.12 /opt/maven 12:37:42 + sudo ln -s /opt/maven/bin/mvn /usr/bin/mvn 12:37:42 + mvn --version 12:37:43 Apache Maven 3.9.12 (848fbb4bf2d427b72bdb2471c22fced7ebd9a7a1) 12:37:43 Maven home: /opt/maven 12:37:43 Java version: 21.0.9, vendor: Ubuntu, runtime: /usr/lib/jvm/java-21-openjdk-amd64 12:37:43 Default locale: en, platform encoding: UTF-8 12:37:43 OS name: "linux", version: "5.15.0-168-generic", arch: "amd64", family: "unix" 12:37:43 NOTE: Picked up JDK_JAVA_OPTIONS: 12:37:43 --add-opens=java.base/java.io=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.lang=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.net=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.nio=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.util=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:37:43 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:37:43 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:37:43 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:37:43 -Xlog:disable 12:37:44 [INFO] Installing environment for https://github.com/Lucas-C/pre-commit-hooks. 12:37:44 [INFO] Once installed this environment will be reused. 12:37:44 [INFO] This may take a few minutes... 12:37:55 [INFO] Installing environment for https://github.com/pre-commit/mirrors-autopep8. 12:37:55 [INFO] Once installed this environment will be reused. 12:37:55 [INFO] This may take a few minutes... 12:38:16 [INFO] Installing environment for https://github.com/perltidy/perltidy. 12:38:16 [INFO] Once installed this environment will be reused. 12:38:16 [INFO] This may take a few minutes... 12:38:26 docs: freeze> python -m pip freeze --all 12:38:26 docs-linkcheck: freeze> python -m pip freeze --all 12:38:26 docs: alabaster==1.0.0,attrs==25.4.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.1.4,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.61.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.2,nwdiag==3.0.0,packaging==26.0,pillow==12.1.1,pip==26.0.1,Pygments==2.19.2,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.4.7,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 12:38:26 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 12:38:26 docs-linkcheck: alabaster==1.0.0,attrs==25.4.0,babel==2.18.0,blockdiag==3.0.0,certifi==2026.1.4,charset-normalizer==3.4.4,contourpy==1.3.3,cycler==0.12.1,docutils==0.21.2,fonttools==4.61.1,funcparserlib==2.0.0a0,future==1.0.0,idna==3.11,imagesize==1.4.1,Jinja2==3.1.6,jsonschema==3.2.0,kiwisolver==1.4.9,lfdocs_conf==0.10.0,MarkupSafe==3.0.3,matplotlib==3.10.8,numpy==2.4.2,nwdiag==3.0.0,packaging==26.0,pillow==12.1.1,pip==26.0.1,Pygments==2.19.2,pyparsing==3.3.2,pyrsistent==0.20.0,python-dateutil==2.9.0.post0,PyYAML==6.0.3,requests==2.32.5,requests-file==1.5.1,roman-numerals==4.1.0,roman-numerals-py==4.1.0,seqdiag==3.0.0,setuptools==82.0.0,six==1.17.0,snowballstemmer==3.0.1,Sphinx==8.2.3,sphinx-bootstrap-theme==0.8.1,sphinx-data-viewer==0.1.5,sphinx-tabs==3.4.7,sphinx_rtd_theme==3.1.0,sphinxcontrib-applehelp==2.0.0,sphinxcontrib-blockdiag==3.0.0,sphinxcontrib-devhelp==2.0.0,sphinxcontrib-htmlhelp==2.1.0,sphinxcontrib-jquery==4.1,sphinxcontrib-jsmath==1.0.1,sphinxcontrib-needs==0.7.9,sphinxcontrib-nwdiag==2.0.0,sphinxcontrib-plantuml==0.31,sphinxcontrib-qthelp==2.0.0,sphinxcontrib-seqdiag==3.0.0,sphinxcontrib-serializinghtml==2.0.0,sphinxcontrib-swaggerdoc==0.1.7,urllib3==2.6.3,webcolors==25.10.0 12:38:26 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 12:38:30 trim trailing whitespace.................................................Passed 12:38:31 Tabs remover.............................................................Passed 12:38:31 autopep8.................................................................docs: OK ✔ in 1 minute 4.22 seconds 12:38:31 pylint: install_deps> python -I -m pip install 'pylint>=2.6.0' 12:38:36 Passed 12:38:36 perltidy.................................................................Passed 12:38:37 docs-linkcheck: OK ✔ in 1 minute 5.46 seconds 12:38:37 pre-commit: commands[3] /w/workspace/transportpce-tox-verify-transportpce-master/tests> pre-commit run gitlint-ci --hook-stage manual 12:38:38 [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. 12:38:38 [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. 12:38:38 [INFO] Installing environment for https://github.com/jorisroovers/gitlint. 12:38:38 [INFO] Once installed this environment will be reused. 12:38:38 [INFO] This may take a few minutes... 12:38:41 pylint: freeze> python -m pip freeze --all 12:38:41 pylint: astroid==4.0.4,dill==0.4.1,isort==7.0.0,mccabe==0.7.0,pip==26.0.1,platformdirs==4.9.2,pylint==4.0.4,setuptools==82.0.0,tomlkit==0.14.0 12:38: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}$' '{}' + 12:38:47 gitlint..................................................................Passed 12:39:06 12:39:06 ------------------------------------ 12:39:06 Your code has been rated at 10.00/10 12:39:06 12:39:58 pre-commit: OK ✔ in 1 minute 17.54 seconds 12:39:58 pylint: OK ✔ in 37.65 seconds 12:39:58 buildcontroller: OK ✔ in 2 minutes 30.79 seconds 12:39:58 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:39:58 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:39:58 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:39:58 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:40:10 build_karaf_tests221: freeze> python -m pip freeze --all 12:40:10 build_karaf_tests121: freeze> python -m pip freeze --all 12:40:10 build_karaf_tests190: freeze> python -m pip freeze --all 12:40:10 build_karaf_tests71: freeze> python -m pip freeze --all 12:40:10 build_karaf_tests221: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:40:10 build_karaf_tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:40:10 build karaf in karaf221 with ./karaf221.env 12:40:10 build_karaf_tests121: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:40:10 build_karaf_tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:40:10 build karaf in karaf121 with ./karaf121.env 12:40:10 build_karaf_tests190: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:40:10 build_karaf_tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:40:10 build karaf in karafoc with ./karafoc.env 12:40:10 build_karaf_tests71: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:40:10 build_karaf_tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./build_karaf_for_tests.sh 12:40:10 NOTE: Picked up JDK_JAVA_OPTIONS: 12:40:10 --add-opens=java.base/java.io=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.net=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:40:10 -Xlog:disable 12:40:10 build karaf in karaf71 with ./karaf71.env 12:40:10 NOTE: Picked up JDK_JAVA_OPTIONS: 12:40:10 --add-opens=java.base/java.io=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.net=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:40:10 -Xlog:disable 12:40:10 NOTE: Picked up JDK_JAVA_OPTIONS: 12:40:10 --add-opens=java.base/java.io=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.net=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:40:10 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:40:10 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:40:10 -Xlog:disable 12:40:11 NOTE: Picked up JDK_JAVA_OPTIONS: 12:40:11 --add-opens=java.base/java.io=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.lang=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.lang.invoke=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.lang.reflect=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.net=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.nio=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.nio.charset=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.nio.file=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.util=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.util.jar=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.util.stream=ALL-UNNAMED 12:40:11 --add-opens=java.base/java.util.zip=ALL-UNNAMED 12:40:11 --add-opens java.base/sun.nio.ch=ALL-UNNAMED 12:40:11 --add-opens java.base/sun.nio.fs=ALL-UNNAMED 12:40:11 -Xlog:disable 12:41:25 build_karaf_tests71: OK ✔ in 1 minute 27.27 seconds 12:41:25 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 12:41:45 build_karaf_tests121: OK ✔ in 1 minute 46.61 seconds 12:41:45 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:41:46 build_karaf_tests221: OK ✔ in 1 minute 49.2 seconds 12:41:46 build_karaf_tests190: OK ✔ in 1 minute 49.23 seconds 12:41:46 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:41:52 buildlighty: freeze> python -m pip freeze --all 12:41:52 buildlighty: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:41:52 buildlighty: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/lighty> ./build.sh 12:41:52 NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.nio=ALL-UNNAMED 12:41:52 sims: freeze> python -m pip freeze --all 12:41:52 sims: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:41:52 sims: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./install_lightynode.sh 12:41:52 Using lighynode version 22.1.0.6 12:41:52 Installing lightynode device to ./lightynode/lightynode-openroadm-device directory 12:42:39 sims: OK ✔ in 11.64 seconds 12:42:39 buildlighty: OK ✔ in 51.51 seconds 12:42:39 testsPCE: freeze> python -m pip freeze --all 12:42:39 testsPCE: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,click==8.3.1,contourpy==1.3.3,cryptography==3.3.2,cycler==0.12.1,dict2xml==1.7.8,Flask==2.1.3,Flask-Injector==0.14.0,fonttools==4.61.1,gnpy4tpce==2.4.7,idna==3.11,iniconfig==2.3.0,injector==0.24.0,invoke==2.2.1,itsdangerous==2.2.0,Jinja2==3.1.6,kiwisolver==1.4.9,lxml==6.0.2,MarkupSafe==3.0.3,matplotlib==3.10.8,netconf-client==3.5.0,networkx==2.8.8,numpy==1.26.4,packaging==26.0,pandas==1.5.3,paramiko==4.0.0,pbr==5.11.1,pillow==12.1.1,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pyparsing==3.3.2,pytest==9.0.2,python-dateutil==2.9.0.post0,pytz==2025.2,requests==2.32.5,scipy==1.17.0,setuptools==50.3.2,six==1.17.0,urllib3==2.6.3,Werkzeug==2.0.3,xlrd==1.2.0 12:42:39 testsPCE: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh pce 12:42:39 pytest -q transportpce_tests/pce/test01_pce.py 12:43:29 .................... [100%] 12:44:32 20 passed in 113.16s (0:01:53) 12:44:32 pytest -q transportpce_tests/pce/test02_pce_400G.py 12:44:51 ............ [100%] 12:45:21 12 passed in 48.49s 12:45:21 pytest -q transportpce_tests/pce/test03_gnpy.py 12:45:39 ........ [100%] 12:46:00 8 passed in 38.79s 12:46:00 pytest -q transportpce_tests/pce/test04_pce_bug_fix.py 12:46:33 ... [100%] 12:46:38 3 passed in 37.52s 12:46:39 testsPCE: OK ✔ in 4 minutes 52.02 seconds 12:46:39 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:46:39 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:46:39 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:46:45 tests190: freeze> python -m pip freeze --all 12:46:45 tests121: freeze> python -m pip freeze --all 12:46:46 tests_tapi: freeze> python -m pip freeze --all 12:46:46 tests190: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:46:46 tests190: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh oc 12:46:46 using environment variables from ./karafoc.env 12:46:46 pytest -q transportpce_tests/oc/test01_portmapping.py 12:46:46 tests121: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:46:46 tests121: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 1.2.1 12:46:46 using environment variables from ./karaf121.env 12:46:46 pytest -q transportpce_tests/1.2.1/test01_portmapping.py 12:46:46 tests_tapi: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:46:46 tests_tapi: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh tapi 12:46:46 using environment variables from ./karaf221.env 12:46:46 pytest -q transportpce_tests/tapi/test01_abstracted_topology.py 12:47:51 .......... [100%] 12:48:09 10 passed in 83.41s (0:01:23) 12:48:10 pytest -q transportpce_tests/oc/test02_topology.py 12:48:10 ....................... [100%] 12:49:08 21 passed in 142.31s (0:02:22) 12:49:09 pytest -q transportpce_tests/1.2.1/test02_topo_portmapping.py 12:49:10 ..................................... [100%] 12:49:39 14 passed in 88.74s (0:01:28) 12:49:39 pytest -q transportpce_tests/oc/test03_renderer.py 12:49:41 ............................. [100%] 12:50:36 6 passed in 87.50s (0:01:27) 12:50:37 pytest -q transportpce_tests/1.2.1/test03_topology.py 12:50:37 ........ [100%] 12:50:47 19 passed in 67.52s (0:01:07) 12:50:47 tests190: OK ✔ in 4 minutes 8.89 seconds 12:50:47 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:50:48 .tests71: freeze> python -m pip freeze --all 12:51:00 tests71: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 12:51:00 tests71: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 7.1 12:51:00 using environment variables from ./karaf71.env 12:51:00 pytest -q transportpce_tests/7.1/test01_portmapping.py 12:51:08 .............................. [100%] 12:52:00 12 passed in 60.04s (0:01:00) 12:52:00 pytest -q transportpce_tests/7.1/test02_otn_renderer.py 12:52:02 ......................................................... [100%] 12:53:20 44 passed in 163.26s (0:02:43) 12:53:20 pytest -q transportpce_tests/1.2.1/test04_renderer_service_path_nominal.py 12:53:22 ................................................................. [100%] 12:54:46 62 passed in 165.13s (0:02:45) 12:54:46 pytest -q transportpce_tests/7.1/test03_renderer_or_modes.py 12:54:47 . [100%] 12:54:49 24 passed in 88.79s (0:01:28) 12:54:49 pytest -q transportpce_tests/1.2.1/test05_olm.py 12:55:36 ............................................................................. [100%] 12:57:21 48 passed in 154.89s (0:02:34) 12:57:21 pytest -q transportpce_tests/7.1/test04_renderer_regen_mode.py 12:57:25 ........................ [100%] 12:58:16 40 passed in 206.69s (0:03:26) 12:58:17 pytest -q transportpce_tests/1.2.1/test06_end2end.py 12:58:18 ..... [100%] 12:58:25 51 passed in 699.31s (0:11:39) 12:58:26 pytest -q transportpce_tests/tapi/test02_full_topology.py 12:58:26 ...... [100%] 12:58:39 22 passed in 77.49s (0:01:17) 12:59:21 .................................................................................... [100%] 13:04:30 36 passed in 364.04s (0:06:04) 13:04:30 pytest -q transportpce_tests/tapi/test03_tapi_device_change_notifications.py 13:05:25 ............................................. [100%] 13:07:40 54 passed in 563.26s (0:09:23) 13:07:41 ................................ [100%] 13:15:58 71 passed in 687.55s (0:11:27) 13:15:58 pytest -q transportpce_tests/tapi/test04_topo_extension.py 13:16:56 ................... [100%] 13:18:28 19 passed in 149.35s (0:02:29) 13:18:28 pytest -q transportpce_tests/tapi/test05_pce_tapi.py 13:20:37 ...................... [100%] 13:29:13 22 passed in 645.13s (0:10:45) 13:29:13 tests71: OK ✔ in 7 minutes 51.76 seconds 13:29:13 tests121: OK ✔ in 21 minutes 2 seconds 13:29:13 tests_tapi: OK ✔ in 42 minutes 34.96 seconds 13:29:13 tests221: install_deps> python -I -m pip install 'setuptools>=7.0' -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/requirements.txt -r /w/workspace/transportpce-tox-verify-transportpce-master/tests/test-requirements.txt 13:29:21 tests221: freeze> python -m pip freeze --all 13:29:21 tests221: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 13:29:21 tests221: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 13:29:21 using environment variables from ./karaf221.env 13:29:21 pytest -q transportpce_tests/2.2.1/test01_portmapping.py 13:30:01 ................................... [100%] 13:33:42 35 passed in 260.38s (0:04:20) 13:33:42 pytest -q transportpce_tests/2.2.1/test02_topo_portmapping.py 13:34:50 FF.... [100%] 13:38:08 =================================== FAILURES =================================== 13:38:08 _____________ TestTransportPCETopoPortmapping.test_01_connect_rdm ______________ 13:38:08 13:38:08 self = 13:38:08 conn = 13:38:08 method = 'PUT' 13:38:08 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADM-A1' 13:38:08 body = '{"node": [{"node-id": "ROADM-A1", "netconf-node-topology:netconf-node": {"netconf-node-topology:host": "127.0.0.1", "...ff-millis": 1800000, "netconf-node-topology:backoff-multiplier": 1.5, "netconf-node-topology:keepalive-delay": 120}}]}' 13:38:08 headers = {'User-Agent': 'python-requests/2.32.5', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'application/json', 'Connection': 'keep-alive', 'Content-Type': 'application/json', 'Content-Length': '710', 'Authorization': 'Basic YWRtaW46YWRtaW4='} 13:38:08 retries = Retry(total=0, connect=None, read=False, redirect=None, status=None) 13:38:08 timeout = Timeout(connect=30, read=30, total=None), chunked = False 13:38:08 response_conn = 13:38:08 preload_content = False, decode_content = False, enforce_content_length = True 13:38:08 13:38:08 def _make_request( 13:38:08 self, 13:38:08 conn: BaseHTTPConnection, 13:38:08 method: str, 13:38:08 url: str, 13:38:08 body: _TYPE_BODY | None = None, 13:38:08 headers: typing.Mapping[str, str] | None = None, 13:38:08 retries: Retry | None = None, 13:38:08 timeout: _TYPE_TIMEOUT = _DEFAULT_TIMEOUT, 13:38:08 chunked: bool = False, 13:38:08 response_conn: BaseHTTPConnection | None = None, 13:38:08 preload_content: bool = True, 13:38:08 decode_content: bool = True, 13:38:08 enforce_content_length: bool = True, 13:38:08 ) -> BaseHTTPResponse: 13:38:08 """ 13:38:08 Perform a request on a given urllib connection object taken from our 13:38:08 pool. 13:38:08 13:38:08 :param conn: 13:38:08 a connection from one of our connection pools 13:38:08 13:38:08 :param method: 13:38:08 HTTP request method (such as GET, POST, PUT, etc.) 13:38:08 13:38:08 :param url: 13:38:08 The URL to perform the request on. 13:38:08 13:38:08 :param body: 13:38:08 Data to send in the request body, either :class:`str`, :class:`bytes`, 13:38:08 an iterable of :class:`str`/:class:`bytes`, or a file-like object. 13:38:08 13:38:08 :param headers: 13:38:08 Dictionary of custom headers to send, such as User-Agent, 13:38:08 If-None-Match, etc. If None, pool headers are used. If provided, 13:38:08 these headers completely replace any pool-specific headers. 13:38:08 13:38:08 :param retries: 13:38:08 Configure the number of retries to allow before raising a 13:38:08 :class:`~urllib3.exceptions.MaxRetryError` exception. 13:38:08 13:38:08 Pass ``None`` to retry until you receive a response. Pass a 13:38:08 :class:`~urllib3.util.retry.Retry` object for fine-grained control 13:38:08 over different types of retries. 13:38:08 Pass an integer number to retry connection errors that many times, 13:38:08 but no other types of errors. Pass zero to never retry. 13:38:08 13:38:08 If ``False``, then retries are disabled and any exception is raised 13:38:08 immediately. Also, instead of raising a MaxRetryError on redirects, 13:38:08 the redirect response will be returned. 13:38:08 13:38:08 :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. 13:38:08 13:38:08 :param timeout: 13:38:08 If specified, overrides the default timeout for this one 13:38:08 request. It may be a float (in seconds) or an instance of 13:38:08 :class:`urllib3.util.Timeout`. 13:38:08 13:38:08 :param chunked: 13:38:08 If True, urllib3 will send the body using chunked transfer 13:38:08 encoding. Otherwise, urllib3 will send the body using the standard 13:38:08 content-length form. Defaults to False. 13:38:08 13:38:08 :param response_conn: 13:38:08 Set this to ``None`` if you will handle releasing the connection or 13:38:08 set the connection to have the response release it. 13:38:08 13:38:08 :param preload_content: 13:38:08 If True, the response's body will be preloaded during construction. 13:38:08 13:38:08 :param decode_content: 13:38:08 If True, will attempt to decode the body based on the 13:38:08 'content-encoding' header. 13:38:08 13:38:08 :param enforce_content_length: 13:38:08 Enforce content length checking. Body returned by server must match 13:38:08 value of Content-Length header, if present. Otherwise, raise error. 13:38:08 """ 13:38:08 self.num_requests += 1 13:38:08 13:38:08 timeout_obj = self._get_timeout(timeout) 13:38:08 timeout_obj.start_connect() 13:38:08 conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) 13:38:08 13:38:08 try: 13:38:08 # Trigger any extra validation we need to do. 13:38:08 try: 13:38:08 self._validate_conn(conn) 13:38:08 except (SocketTimeout, BaseSSLError) as e: 13:38:08 self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) 13:38:08 raise 13:38:08 13:38:08 # _validate_conn() starts the connection to an HTTPS proxy 13:38:08 # so we need to wrap errors with 'ProxyError' here too. 13:38:08 except ( 13:38:08 OSError, 13:38:08 NewConnectionError, 13:38:08 TimeoutError, 13:38:08 BaseSSLError, 13:38:08 CertificateError, 13:38:08 SSLError, 13:38:08 ) as e: 13:38:08 new_e: Exception = e 13:38:08 if isinstance(e, (BaseSSLError, CertificateError)): 13:38:08 new_e = SSLError(e) 13:38:08 # If the connection didn't successfully connect to it's proxy 13:38:08 # then there 13:38:08 if isinstance( 13:38:08 new_e, (OSError, NewConnectionError, TimeoutError, SSLError) 13:38:08 ) and (conn and conn.proxy and not conn.has_connected_to_proxy): 13:38:08 new_e = _wrap_proxy_error(new_e, conn.proxy.scheme) 13:38:08 raise new_e 13:38:08 13:38:08 # conn.request() calls http.client.*.request, not the method in 13:38:08 # urllib3.request. It also calls makefile (recv) on the socket. 13:38:08 try: 13:38:08 conn.request( 13:38:08 method, 13:38:08 url, 13:38:08 body=body, 13:38:08 headers=headers, 13:38:08 chunked=chunked, 13:38:08 preload_content=preload_content, 13:38:08 decode_content=decode_content, 13:38:08 enforce_content_length=enforce_content_length, 13:38:08 ) 13:38:08 13:38:08 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is 13:38:08 # legitimately able to close the connection after sending a valid response. 13:38:08 # With this behaviour, the received response is still readable. 13:38:08 except BrokenPipeError: 13:38:08 pass 13:38:08 except OSError as e: 13:38:08 # MacOS/Linux 13:38:08 # EPROTOTYPE and ECONNRESET are needed on macOS 13:38:08 # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ 13:38:08 # Condition changed later to emit ECONNRESET instead of only EPROTOTYPE. 13:38:08 if e.errno != errno.EPROTOTYPE and e.errno != errno.ECONNRESET: 13:38:08 raise 13:38:08 13:38:08 # Reset the timeout for the recv() on the socket 13:38:08 read_timeout = timeout_obj.read_timeout 13:38:08 13:38:08 if not conn.is_closed: 13:38:08 # In Python 3 socket.py will catch EAGAIN and return None when you 13:38:08 # try and read into the file pointer created by http.client, which 13:38:08 # instead raises a BadStatusLine exception. Instead of catching 13:38:08 # the exception and assuming all BadStatusLine exceptions are read 13:38:08 # timeouts, check for a zero timeout before making the request. 13:38:08 if read_timeout == 0: 13:38:08 raise ReadTimeoutError( 13:38:08 self, url, f"Read timed out. (read timeout={read_timeout})" 13:38:08 ) 13:38:08 conn.timeout = read_timeout 13:38:08 13:38:08 # Receive the response from the server 13:38:08 try: 13:38:08 > response = conn.getresponse() 13:38:08 ^^^^^^^^^^^^^^^^^^ 13:38:08 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connectionpool.py:534: 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connection.py:571: in getresponse 13:38:08 httplib_response = super().getresponse() 13:38:08 ^^^^^^^^^^^^^^^^^^^^^ 13:38:08 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:1395: in getresponse 13:38:08 response.begin() 13:38:08 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:325: in begin 13:38:08 version, status, reason = self._read_status() 13:38:08 ^^^^^^^^^^^^^^^^^^^ 13:38:08 /opt/pyenv/versions/3.11.10/lib/python3.11/http/client.py:286: in _read_status 13:38:08 line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1") 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 13:38:08 self = 13:38:08 b = 13:38:08 13:38:08 def readinto(self, b): 13:38:08 """Read up to len(b) bytes into the writable buffer *b* and return 13:38:08 the number of bytes read. If the socket is non-blocking and no bytes 13:38:08 are available, None is returned. 13:38:08 13:38:08 If *b* is non-empty, a 0 return value indicates that the connection 13:38:08 was shutdown at the other end. 13:38:08 """ 13:38:08 self._checkClosed() 13:38:08 self._checkReadable() 13:38:08 if self._timeout_occurred: 13:38:08 raise OSError("cannot read from timed out object") 13:38:08 while True: 13:38:08 try: 13:38:08 > return self._sock.recv_into(b) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 E TimeoutError: timed out 13:38:08 13:38:08 /opt/pyenv/versions/3.11.10/lib/python3.11/socket.py:718: TimeoutError 13:38:08 13:38:08 The above exception was the direct cause of the following exception: 13:38:08 13:38:08 self = 13:38:08 request = , stream = False 13:38:08 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:38:08 proxies = OrderedDict() 13:38:08 13:38:08 def send( 13:38:08 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:38:08 ): 13:38:08 """Sends PreparedRequest object. Returns Response object. 13:38:08 13:38:08 :param request: The :class:`PreparedRequest ` being sent. 13:38:08 :param stream: (optional) Whether to stream the request content. 13:38:08 :param timeout: (optional) How long to wait for the server to send 13:38:08 data before giving up, as a float, or a :ref:`(connect timeout, 13:38:08 read timeout) ` tuple. 13:38:08 :type timeout: float or tuple or urllib3 Timeout object 13:38:08 :param verify: (optional) Either a boolean, in which case it controls whether 13:38:08 we verify the server's TLS certificate, or a string, in which case it 13:38:08 must be a path to a CA bundle to use 13:38:08 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:38:08 :param proxies: (optional) The proxies dictionary to apply to the request. 13:38:08 :rtype: requests.Response 13:38:08 """ 13:38:08 13:38:08 try: 13:38:08 conn = self.get_connection_with_tls_context( 13:38:08 request, verify, proxies=proxies, cert=cert 13:38:08 ) 13:38:08 except LocationValueError as e: 13:38:08 raise InvalidURL(e, request=request) 13:38:08 13:38:08 self.cert_verify(conn, request.url, verify, cert) 13:38:08 url = self.request_url(request, proxies) 13:38:08 self.add_headers( 13:38:08 request, 13:38:08 stream=stream, 13:38:08 timeout=timeout, 13:38:08 verify=verify, 13:38:08 cert=cert, 13:38:08 proxies=proxies, 13:38:08 ) 13:38:08 13:38:08 chunked = not (request.body is None or "Content-Length" in request.headers) 13:38:08 13:38:08 if isinstance(timeout, tuple): 13:38:08 try: 13:38:08 connect, read = timeout 13:38:08 timeout = TimeoutSauce(connect=connect, read=read) 13:38:08 except ValueError: 13:38:08 raise ValueError( 13:38:08 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:38:08 f"or a single float to set both timeouts to the same value." 13:38:08 ) 13:38:08 elif isinstance(timeout, TimeoutSauce): 13:38:08 pass 13:38:08 else: 13:38:08 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:38:08 13:38:08 try: 13:38:08 > resp = conn.urlopen( 13:38:08 method=request.method, 13:38:08 url=url, 13:38:08 body=request.body, 13:38:08 headers=request.headers, 13:38:08 redirect=False, 13:38:08 assert_same_host=False, 13:38:08 preload_content=False, 13:38:08 decode_content=False, 13:38:08 retries=self.max_retries, 13:38:08 timeout=timeout, 13:38:08 chunked=chunked, 13:38:08 ) 13:38:08 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/requests/adapters.py:644: 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connectionpool.py:841: in urlopen 13:38:08 retries = retries.increment( 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/util/retry.py:490: in increment 13:38:08 raise reraise(type(error), error, _stacktrace) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/util/util.py:39: in reraise 13:38:08 raise value 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connectionpool.py:787: in urlopen 13:38:08 response = self._make_request( 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connectionpool.py:536: in _make_request 13:38:08 self._raise_timeout(err=e, url=url, timeout_value=read_timeout) 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 13:38:08 self = 13:38:08 err = TimeoutError('timed out') 13:38:08 url = '/rests/data/network-topology:network-topology/topology=topology-netconf/node=ROADM-A1' 13:38:08 timeout_value = 30 13:38:08 13:38:08 def _raise_timeout( 13:38:08 self, 13:38:08 err: BaseSSLError | OSError | SocketTimeout, 13:38:08 url: str, 13:38:08 timeout_value: _TYPE_TIMEOUT | None, 13:38:08 ) -> None: 13:38:08 """Is the error actually a timeout? Will raise a ReadTimeout or pass""" 13:38:08 13:38:08 if isinstance(err, SocketTimeout): 13:38:08 > raise ReadTimeoutError( 13:38:08 self, url, f"Read timed out. (read timeout={timeout_value})" 13:38:08 ) from err 13:38:08 E urllib3.exceptions.ReadTimeoutError: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 13:38:08 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/urllib3/connectionpool.py:367: ReadTimeoutError 13:38:08 13:38:08 During handling of the above exception, another exception occurred: 13:38:08 13:38:08 self = 13:38:08 13:38:08 def test_01_connect_rdm(self): 13:38:08 > response = test_utils.mount_device("ROADM-A1", ('roadma', self.NODE_VERSION)) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 13:38:08 transportpce_tests/2.2.1/test02_topo_portmapping.py:49: 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 transportpce_tests/common/test_utils.py:376: in mount_device 13:38:08 response = put_request(url[RESTCONF_VERSION].format('{}', node), body) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 transportpce_tests/common/test_utils.py:125: in put_request 13:38:08 return requests.request( 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/requests/api.py:59: in request 13:38:08 return session.request(method=method, url=url, **kwargs) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/requests/sessions.py:589: in request 13:38:08 resp = self.send(prep, **send_kwargs) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/requests/sessions.py:703: in send 13:38:08 r = adapter.send(request, **kwargs) 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 13:38:08 13:38:08 self = 13:38:08 request = , stream = False 13:38:08 timeout = Timeout(connect=30, read=30, total=None), verify = True, cert = None 13:38:08 proxies = OrderedDict() 13:38:08 13:38:08 def send( 13:38:08 self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None 13:38:08 ): 13:38:08 """Sends PreparedRequest object. Returns Response object. 13:38:08 13:38:08 :param request: The :class:`PreparedRequest ` being sent. 13:38:08 :param stream: (optional) Whether to stream the request content. 13:38:08 :param timeout: (optional) How long to wait for the server to send 13:38:08 data before giving up, as a float, or a :ref:`(connect timeout, 13:38:08 read timeout) ` tuple. 13:38:08 :type timeout: float or tuple or urllib3 Timeout object 13:38:08 :param verify: (optional) Either a boolean, in which case it controls whether 13:38:08 we verify the server's TLS certificate, or a string, in which case it 13:38:08 must be a path to a CA bundle to use 13:38:08 :param cert: (optional) Any user-provided SSL certificate to be trusted. 13:38:08 :param proxies: (optional) The proxies dictionary to apply to the request. 13:38:08 :rtype: requests.Response 13:38:08 """ 13:38:08 13:38:08 try: 13:38:08 conn = self.get_connection_with_tls_context( 13:38:08 request, verify, proxies=proxies, cert=cert 13:38:08 ) 13:38:08 except LocationValueError as e: 13:38:08 raise InvalidURL(e, request=request) 13:38:08 13:38:08 self.cert_verify(conn, request.url, verify, cert) 13:38:08 url = self.request_url(request, proxies) 13:38:08 self.add_headers( 13:38:08 request, 13:38:08 stream=stream, 13:38:08 timeout=timeout, 13:38:08 verify=verify, 13:38:08 cert=cert, 13:38:08 proxies=proxies, 13:38:08 ) 13:38:08 13:38:08 chunked = not (request.body is None or "Content-Length" in request.headers) 13:38:08 13:38:08 if isinstance(timeout, tuple): 13:38:08 try: 13:38:08 connect, read = timeout 13:38:08 timeout = TimeoutSauce(connect=connect, read=read) 13:38:08 except ValueError: 13:38:08 raise ValueError( 13:38:08 f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " 13:38:08 f"or a single float to set both timeouts to the same value." 13:38:08 ) 13:38:08 elif isinstance(timeout, TimeoutSauce): 13:38:08 pass 13:38:08 else: 13:38:08 timeout = TimeoutSauce(connect=timeout, read=timeout) 13:38:08 13:38:08 try: 13:38:08 resp = conn.urlopen( 13:38:08 method=request.method, 13:38:08 url=url, 13:38:08 body=request.body, 13:38:08 headers=request.headers, 13:38:08 redirect=False, 13:38:08 assert_same_host=False, 13:38:08 preload_content=False, 13:38:08 decode_content=False, 13:38:08 retries=self.max_retries, 13:38:08 timeout=timeout, 13:38:08 chunked=chunked, 13:38:08 ) 13:38:08 13:38:08 except (ProtocolError, OSError) as err: 13:38:08 raise ConnectionError(err, request=request) 13:38:08 13:38:08 except MaxRetryError as e: 13:38:08 if isinstance(e.reason, ConnectTimeoutError): 13:38:08 # TODO: Remove this in 3.0.0: see #2811 13:38:08 if not isinstance(e.reason, NewConnectionError): 13:38:08 raise ConnectTimeout(e, request=request) 13:38:08 13:38:08 if isinstance(e.reason, ResponseError): 13:38:08 raise RetryError(e, request=request) 13:38:08 13:38:08 if isinstance(e.reason, _ProxyError): 13:38:08 raise ProxyError(e, request=request) 13:38:08 13:38:08 if isinstance(e.reason, _SSLError): 13:38:08 # This branch is for urllib3 v1.22 and later. 13:38:08 raise SSLError(e, request=request) 13:38:08 13:38:08 raise ConnectionError(e, request=request) 13:38:08 13:38:08 except ClosedPoolError as e: 13:38:08 raise ConnectionError(e, request=request) 13:38:08 13:38:08 except _ProxyError as e: 13:38:08 raise ProxyError(e) 13:38:08 13:38:08 except (_SSLError, _HTTPError) as e: 13:38:08 if isinstance(e, _SSLError): 13:38:08 # This branch is for urllib3 versions earlier than v1.22 13:38:08 raise SSLError(e, request=request) 13:38:08 elif isinstance(e, ReadTimeoutError): 13:38:08 > raise ReadTimeout(e, request=request) 13:38:08 E requests.exceptions.ReadTimeout: HTTPConnectionPool(host='localhost', port=8183): Read timed out. (read timeout=30) 13:38:08 13:38:08 ../.tox/tests221/lib/python3.11/site-packages/requests/adapters.py:690: ReadTimeout 13:38:08 ---------------------------- Captured stdout setup ----------------------------- 13:38:08 starting OpenDaylight... 13:38:08 starting KARAF (karaf221) TransportPCE build... 13:38:08 Searching for patterns in karaf.log... Pattern found! OpenDaylight started ! 13:38:08 starting simulator xpdra in OpenROADM device version 2.2.1... 13:38:08 Searching for patterns in xpdra-221.log... Pattern found! simulator for xpdra started 13:38:08 starting simulator roadma in OpenROADM device version 2.2.1... 13:38:08 Searching for patterns in roadma-221.log... Pattern found! simulator for roadma started 13:38:08 _ TestTransportPCETopoPortmapping.test_02_compareOpenroadmTopologyPortMapping_rdm _ 13:38:08 13:38:08 self = 13:38:08 13:38:08 def test_02_compareOpenroadmTopologyPortMapping_rdm(self): 13:38:08 resTopo = test_utils.get_ietf_network_request('openroadm-topology', 'config') 13:38:08 self.assertEqual(resTopo['status_code'], requests.codes.ok) 13:38:08 nbMapCumul = 0 13:38:08 nbMappings = 0 13:38:08 > for node in resTopo['network'][0]['node']: 13:38:08 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 13:38:08 E KeyError: 'node' 13:38:08 13:38:08 transportpce_tests/2.2.1/test02_topo_portmapping.py:58: KeyError 13:38:08 =========================== short test summary info ============================ 13:38:08 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_01_connect_rdm 13:38:08 FAILED transportpce_tests/2.2.1/test02_topo_portmapping.py::TestTransportPCETopoPortmapping::test_02_compareOpenroadmTopologyPortMapping_rdm 13:38:08 2 failed, 4 passed in 265.98s (0:04:25) 13:38:08 tests221: exit 1 (527.01 seconds) /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh 2.2.1 pid=27723 13:38:08 tests221: FAIL ✖ in 8 minutes 54.73 seconds 13:38:08 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:38:15 tests_hybrid: freeze> python -m pip freeze --all 13:38:15 tests_hybrid: bcrypt==5.0.0,certifi==2026.1.4,cffi==2.0.0,charset-normalizer==3.4.4,cryptography==46.0.5,dict2xml==1.7.8,idna==3.11,iniconfig==2.3.0,invoke==2.2.1,lxml==6.0.2,netconf-client==3.5.0,packaging==26.0,paramiko==4.0.0,pip==26.0.1,pluggy==1.6.0,psutil==7.2.2,pycparser==3.0,Pygments==2.19.2,PyNaCl==1.6.2,pytest==9.0.2,requests==2.32.5,setuptools==82.0.0,urllib3==2.6.3 13:38:15 tests_hybrid: commands[0] /w/workspace/transportpce-tox-verify-transportpce-master/tests> ./launch_tests.sh hybrid 13:38:15 using environment variables from ./karaf221.env 13:38:15 pytest -q transportpce_tests/hybrid/test01_device_change_notifications.py 13:39:00 ................................................... [100%] 13:40:48 51 passed in 152.33s (0:02:32) 13:40:48 pytest -q transportpce_tests/hybrid/test02_B100G_end2end.py 13:41:33 ........................................................................ [ 66%] 13:45:56 ..................................... [100%] 13:48:02 109 passed in 433.51s (0:07:13) 13:48:02 pytest -q transportpce_tests/hybrid/test03_autonomous_reroute.py 13:48:54 ..................................................... [100%] 13:52:27 53 passed in 265.23s (0:04:25) 13:52:27 buildcontroller: OK (150.79=setup[13.55]+cmd[137.24] seconds) 13:52:27 sims: OK (11.64=setup[8.82]+cmd[2.82] seconds) 13:52:27 build_karaf_tests121: OK (106.61=setup[13.41]+cmd[93.19] seconds) 13:52:27 testsPCE: OK (292.02=setup[52.66]+cmd[239.37] seconds) 13:52:27 tests121: OK (1262.00=setup[7.59]+cmd[1254.41] seconds) 13:52:27 build_karaf_tests221: OK (109.20=setup[13.40]+cmd[95.81] seconds) 13:52:27 tests_tapi: OK (2554.96=setup[7.67]+cmd[2547.29] seconds) 13:52:27 tests221: FAIL code 1 (534.73=setup[7.71]+cmd[527.01] seconds) 13:52:27 build_karaf_tests71: OK (87.27=setup[13.48]+cmd[73.79] seconds) 13:52:27 tests71: OK (471.76=setup[12.60]+cmd[459.16] seconds) 13:52:27 build_karaf_tests190: OK (109.22=setup[13.45]+cmd[95.77] seconds) 13:52:27 tests190: OK (248.89=setup[7.47]+cmd[241.42] seconds) 13:52:27 tests_hybrid: OK (859.47=setup[7.44]+cmd[852.03] seconds) 13:52:27 buildlighty: OK (51.51=setup[27.73]+cmd[23.78] seconds) 13:52:27 docs: OK (64.22=setup[60.09]+cmd[4.12] seconds) 13:52:27 docs-linkcheck: OK (65.46=setup[60.20]+cmd[5.26] seconds) 13:52:27 checkbashisms: OK (3.36=setup[1.97]+cmd[0.01,0.06,1.33] seconds) 13:52:27 pre-commit: OK (77.54=setup[3.69]+cmd[0.00,0.00,64.12,9.73] seconds) 13:52:27 pylint: OK (37.65=setup[11.03]+cmd[26.62] seconds) 13:52:27 evaluation failed :( (4501.26 seconds) 13:52:28 + tox_status=255 13:52:28 + echo '---> Completed tox runs' 13:52:28 ---> Completed tox runs 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/build_karaf_tests121/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=build_karaf_tests121 13:52:28 + cp -r .tox/build_karaf_tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests121 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/build_karaf_tests190/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=build_karaf_tests190 13:52:28 + cp -r .tox/build_karaf_tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests190 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/build_karaf_tests221/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=build_karaf_tests221 13:52:28 + cp -r .tox/build_karaf_tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests221 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/build_karaf_tests71/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=build_karaf_tests71 13:52:28 + cp -r .tox/build_karaf_tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/build_karaf_tests71 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/buildcontroller/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=buildcontroller 13:52:28 + cp -r .tox/buildcontroller/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildcontroller 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/buildlighty/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=buildlighty 13:52:28 + cp -r .tox/buildlighty/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/buildlighty 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/checkbashisms/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=checkbashisms 13:52:28 + cp -r .tox/checkbashisms/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/checkbashisms 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/docs-linkcheck/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=docs-linkcheck 13:52:28 + cp -r .tox/docs-linkcheck/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs-linkcheck 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/docs/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=docs 13:52:28 + cp -r .tox/docs/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/docs 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/pre-commit/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=pre-commit 13:52:28 + cp -r .tox/pre-commit/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pre-commit 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/pylint/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=pylint 13:52:28 + cp -r .tox/pylint/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/pylint 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/sims/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=sims 13:52:28 + cp -r .tox/sims/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/sims 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/tests121/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=tests121 13:52:28 + cp -r .tox/tests121/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests121 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/tests190/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=tests190 13:52:28 + cp -r .tox/tests190/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests190 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/tests221/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=tests221 13:52:28 + cp -r .tox/tests221/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests221 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/tests71/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=tests71 13:52:28 + cp -r .tox/tests71/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests71 13:52:28 + for i in .tox/*/log 13:52:28 ++ echo .tox/testsPCE/log 13:52:28 ++ awk -F/ '{print $2}' 13:52:28 + tox_env=testsPCE 13:52:28 + cp -r .tox/testsPCE/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/testsPCE 13:52:29 + for i in .tox/*/log 13:52:29 ++ echo .tox/tests_hybrid/log 13:52:29 ++ awk -F/ '{print $2}' 13:52:29 + tox_env=tests_hybrid 13:52:29 + cp -r .tox/tests_hybrid/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_hybrid 13:52:29 + for i in .tox/*/log 13:52:29 ++ echo .tox/tests_tapi/log 13:52:29 ++ awk -F/ '{print $2}' 13:52:29 + tox_env=tests_tapi 13:52:29 + cp -r .tox/tests_tapi/log /w/workspace/transportpce-tox-verify-transportpce-master/archives/tox/tests_tapi 13:52:29 + DOC_DIR=docs/_build/html 13:52:29 + [[ -d docs/_build/html ]] 13:52:29 + echo '---> Archiving generated docs' 13:52:29 ---> Archiving generated docs 13:52:29 + mv docs/_build/html /w/workspace/transportpce-tox-verify-transportpce-master/archives/docs 13:52:29 + echo '---> tox-run.sh ends' 13:52:29 ---> tox-run.sh ends 13:52:29 + test 255 -eq 0 13:52:29 + exit 255 13:52:29 ++ '[' 1 = 1 ']' 13:52:29 ++ '[' -x /usr/bin/clear_console ']' 13:52:29 ++ /usr/bin/clear_console -q 13:52:29 Build step 'Execute shell' marked build as failure 13:52:29 $ ssh-agent -k 13:52:29 unset SSH_AUTH_SOCK; 13:52:29 unset SSH_AGENT_PID; 13:52:29 echo Agent pid 1572 killed; 13:52:29 [ssh-agent] Stopped. 13:52:30 [PostBuildScript] - [INFO] Executing post build scripts. 13:52:30 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins8510339698286096828.sh 13:52:31 ---> sysstat.sh 13:52:31 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1580992373336699875.sh 13:52:31 ---> package-listing.sh 13:52:31 ++ facter osfamily 13:52:31 ++ tr '[:upper:]' '[:lower:]' 13:52:32 + OS_FAMILY=debian 13:52:32 + workspace=/w/workspace/transportpce-tox-verify-transportpce-master 13:52:32 + START_PACKAGES=/tmp/packages_start.txt 13:52:32 + END_PACKAGES=/tmp/packages_end.txt 13:52:32 + DIFF_PACKAGES=/tmp/packages_diff.txt 13:52:32 + PACKAGES=/tmp/packages_start.txt 13:52:32 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:52:32 + PACKAGES=/tmp/packages_end.txt 13:52:32 + case "${OS_FAMILY}" in 13:52:32 + dpkg -l 13:52:32 + grep '^ii' 13:52:32 + '[' -f /tmp/packages_start.txt ']' 13:52:32 + '[' -f /tmp/packages_end.txt ']' 13:52:32 + diff /tmp/packages_start.txt /tmp/packages_end.txt 13:52:32 + '[' /w/workspace/transportpce-tox-verify-transportpce-master ']' 13:52:32 + mkdir -p /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:52:32 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/transportpce-tox-verify-transportpce-master/archives/ 13:52:32 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins12944127226256648695.sh 13:52:32 ---> capture-instance-metadata.sh 13:52:32 Setup pyenv: 13:52:32 system 13:52:32 3.8.20 13:52:32 3.9.20 13:52:32 3.10.15 13:52:32 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:52:32 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-D0HF from file:/tmp/.os_lf_venv 13:52:32 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:52:32 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:52:36 lf-activate-venv(): INFO: Base packages installed successfully 13:52:36 lf-activate-venv(): INFO: Installing additional packages: lftools 13:52:52 lf-activate-venv(): INFO: Adding /tmp/venv-D0HF/bin to PATH 13:52:52 INFO: Running in OpenStack, capturing instance metadata 13:52:52 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13835525091891454715.sh 13:52:52 provisioning config files... 13:52:52 Could not find credentials [logs] for transportpce-tox-verify-transportpce-master #4350 13:52:52 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/transportpce-tox-verify-transportpce-master@tmp/config6206109952225612538tmp 13:52:52 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 13:52:52 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 13:52:52 provisioning config files... 13:52:53 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 13:52:53 [EnvInject] - Injecting environment variables from a build step. 13:52:53 [EnvInject] - Injecting as environment variables the properties content 13:52:53 SERVER_ID=logs 13:52:53 13:52:53 [EnvInject] - Variables injected successfully. 13:52:53 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1947479836834171499.sh 13:52:53 ---> create-netrc.sh 13:52:53 WARN: Log server credential not found. 13:52:53 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins13712009973977244860.sh 13:52:53 ---> python-tools-install.sh 13:52:53 Setup pyenv: 13:52:53 system 13:52:53 3.8.20 13:52:53 3.9.20 13:52:53 3.10.15 13:52:53 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:52:53 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-D0HF from file:/tmp/.os_lf_venv 13:52:53 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:52:53 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:52:55 lf-activate-venv(): INFO: Base packages installed successfully 13:52:55 lf-activate-venv(): INFO: Installing additional packages: lftools 13:53:09 lf-activate-venv(): INFO: Adding /tmp/venv-D0HF/bin to PATH 13:53:09 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins1275830893440100908.sh 13:53:09 ---> sudo-logs.sh 13:53:09 Archiving 'sudo' log.. 13:53:09 [transportpce-tox-verify-transportpce-master] $ /bin/bash /tmp/jenkins3318186396374003394.sh 13:53:09 ---> job-cost.sh 13:53:09 INFO: Activating Python virtual environment... 13:53:09 Setup pyenv: 13:53:10 system 13:53:10 3.8.20 13:53:10 3.9.20 13:53:10 3.10.15 13:53:10 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:53:10 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-D0HF from file:/tmp/.os_lf_venv 13:53:10 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:53:10 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:53:14 lf-activate-venv(): INFO: Base packages installed successfully 13:53:14 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 13:53:49 lf-activate-venv(): INFO: Adding /tmp/venv-D0HF/bin to PATH 13:53:49 INFO: No stack-cost file found 13:53:49 INFO: Instance uptime: 4877s 13:53:49 INFO: Fetching instance metadata (attempt 1 of 3)... 13:53:49 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type 13:53:50 INFO: Successfully fetched instance metadata 13:53:50 INFO: Instance type: v3-standard-4 13:53:50 INFO: Retrieving pricing info for: v3-standard-4 13:53:50 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)... 13:53:50 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-4/cost?seconds=4877 13:53:50 INFO: Successfully fetched Vexxhost pricing API 13:53:50 INFO: Retrieved cost: 0.22 13:53:50 INFO: Retrieved resource: v3-standard-4 13:53:50 INFO: Creating archive directory: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost 13:53:50 INFO: Archiving costs to: /w/workspace/transportpce-tox-verify-transportpce-master/archives/cost.csv 13:53:50 INFO: Successfully archived job cost data 13:53:50 DEBUG: Cost data: transportpce-tox-verify-transportpce-master,4350,2026-02-18 13:53:50,v3-standard-4,4877,0.22,0.00,FAILURE 13:53:50 [transportpce-tox-verify-transportpce-master] $ /bin/bash -l /tmp/jenkins6883742511466498149.sh 13:53:50 ---> logs-deploy.sh 13:53:50 Setup pyenv: 13:53:50 system 13:53:50 3.8.20 13:53:50 3.9.20 13:53:50 3.10.15 13:53:50 * 3.11.10 (set by /w/workspace/transportpce-tox-verify-transportpce-master/.python-version) 13:53:50 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-D0HF from file:/tmp/.os_lf_venv 13:53:50 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 13:53:50 lf-activate-venv(): INFO: Attempting to install with network-safe options... 13:53:54 lf-activate-venv(): INFO: Base packages installed successfully 13:53:54 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 13:54:14 lf-activate-venv(): INFO: Adding /tmp/venv-D0HF/bin to PATH 13:54:14 WARNING: Nexus logging server not set 13:54:14 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/transportpce-tox-verify-transportpce-master/4350/ 13:54:14 INFO: archiving logs to S3 13:54:17 ---> uname -a: 13:54:17 Linux prd-ubuntu2204-docker-4c-16g-14098 5.15.0-168-generic #178-Ubuntu SMP Fri Jan 9 19:05:03 UTC 2026 x86_64 x86_64 x86_64 GNU/Linux 13:54:17 13:54:17 13:54:17 ---> lscpu: 13:54:17 Architecture: x86_64 13:54:17 CPU op-mode(s): 32-bit, 64-bit 13:54:17 Address sizes: 40 bits physical, 48 bits virtual 13:54:17 Byte Order: Little Endian 13:54:17 CPU(s): 4 13:54:17 On-line CPU(s) list: 0-3 13:54:17 Vendor ID: AuthenticAMD 13:54:17 Model name: AMD EPYC-Rome Processor 13:54:17 CPU family: 23 13:54:17 Model: 49 13:54:17 Thread(s) per core: 1 13:54:17 Core(s) per socket: 1 13:54:17 Socket(s): 4 13:54:17 Stepping: 0 13:54:17 BogoMIPS: 5599.99 13:54:17 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:54:17 Virtualization: AMD-V 13:54:17 Hypervisor vendor: KVM 13:54:17 Virtualization type: full 13:54:17 L1d cache: 128 KiB (4 instances) 13:54:17 L1i cache: 128 KiB (4 instances) 13:54:17 L2 cache: 2 MiB (4 instances) 13:54:17 L3 cache: 64 MiB (4 instances) 13:54:17 NUMA node(s): 1 13:54:17 NUMA node0 CPU(s): 0-3 13:54:17 Vulnerability Gather data sampling: Not affected 13:54:17 Vulnerability Indirect target selection: Not affected 13:54:17 Vulnerability Itlb multihit: Not affected 13:54:17 Vulnerability L1tf: Not affected 13:54:17 Vulnerability Mds: Not affected 13:54:17 Vulnerability Meltdown: Not affected 13:54:17 Vulnerability Mmio stale data: Not affected 13:54:17 Vulnerability Reg file data sampling: Not affected 13:54:17 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled 13:54:17 Vulnerability Spec rstack overflow: Mitigation; SMT disabled 13:54:17 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl and seccomp 13:54:17 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization 13:54:17 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected 13:54:17 Vulnerability Srbds: Not affected 13:54:17 Vulnerability Tsa: Not affected 13:54:17 Vulnerability Tsx async abort: Not affected 13:54:17 Vulnerability Vmscape: Not affected 13:54:17 13:54:17 13:54:17 ---> nproc: 13:54:17 4 13:54:17 13:54:17 13:54:17 ---> df -h: 13:54:17 Filesystem Size Used Avail Use% Mounted on 13:54:17 tmpfs 1.6G 1.1M 1.6G 1% /run 13:54:17 /dev/vda1 78G 17G 61G 22% / 13:54:17 tmpfs 7.9G 0 7.9G 0% /dev/shm 13:54:17 tmpfs 5.0M 0 5.0M 0% /run/lock 13:54:17 /dev/vda15 105M 6.1M 99M 6% /boot/efi 13:54:17 tmpfs 1.6G 4.0K 1.6G 1% /run/user/1001 13:54:17 13:54:17 13:54:17 ---> free -m: 13:54:17 total used free shared buff/cache available 13:54:17 Mem: 15989 680 11940 3 3368 14962 13:54:17 Swap: 1023 23 1000 13:54:17 13:54:17 13:54:18 ---> ip addr: 13:54:18 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 13:54:18 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 13:54:18 inet 127.0.0.1/8 scope host lo 13:54:18 valid_lft forever preferred_lft forever 13:54:18 inet6 ::1/128 scope host 13:54:18 valid_lft forever preferred_lft forever 13:54:18 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000 13:54:18 link/ether fa:16:3e:23:c3:26 brd ff:ff:ff:ff:ff:ff 13:54:18 altname enp0s3 13:54:18 inet 10.30.171.52/23 metric 100 brd 10.30.171.255 scope global dynamic ens3 13:54:18 valid_lft 81504sec preferred_lft 81504sec 13:54:18 inet6 fe80::f816:3eff:fe23:c326/64 scope link 13:54:18 valid_lft forever preferred_lft forever 13:54:18 3: docker0: mtu 1458 qdisc noqueue state DOWN group default 13:54:18 link/ether fa:d7:cc:b8:6f:a9 brd ff:ff:ff:ff:ff:ff 13:54:18 inet 10.250.0.254/24 brd 10.250.0.255 scope global docker0 13:54:18 valid_lft forever preferred_lft forever 13:54:18 13:54:18 13:54:18 ---> sar -b -r -n DEV: 13:54:18 Linux 5.15.0-168-generic (prd-ubuntu2204-docker-4c-16g-14098) 02/18/26 _x86_64_ (4 CPU) 13:54:18 13:54:18 12:32:43 LINUX RESTART (4 CPU) 13:54:18 13:54:18 12:40:25 tps rtps wtps dtps bread/s bwrtn/s bdscd/s 13:54:18 12:50:25 93.10 2.41 87.46 3.23 130.39 27346.25 9400.31 13:54:18 13:00:01 59.40 30.59 27.23 1.57 419.23 1800.50 2667.27 13:54:18 13:10:00 6.40 1.09 5.08 0.23 26.75 182.25 300.32 13:54:18 13:20:25 7.50 0.66 6.49 0.34 27.61 214.93 575.01 13:54:18 13:30:01 24.47 0.16 8.06 16.25 4.60 433.96 221064.51 13:54:18 13:40:25 11.82 2.90 8.54 0.38 47.63 450.63 108.74 13:54:18 13:50:25 6.94 0.36 6.30 0.28 8.55 190.60 272.48 13:54:18 Average: 29.59 5.30 21.20 3.09 93.02 4365.42 32221.48 13:54:18 13:54:18 12:40:25 kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 13:54:18 12:50:25 168300 4560080 11366876 69.42 251560 4034204 12800388 73.47 2066020 13464304 448 13:54:18 13:00:01 4856076 7459140 8473972 51.76 255880 2396656 9306548 53.42 1933768 9072172 1108 13:54:18 13:10:00 8515396 11139452 4794228 29.28 256880 2416684 5533876 31.76 1950680 5391564 84 13:54:18 13:20:25 7238156 9881740 6053552 36.97 258536 2434672 6854996 39.35 1962168 6662724 76 13:54:18 13:30:01 9770136 12505912 3430880 20.95 264416 2521084 4321848 24.81 1986388 4124216 1456 13:54:18 13:40:25 8569060 11399328 4536620 27.71 267944 2611912 5270060 30.25 2020640 5286348 56 13:54:18 13:50:25 7812576 10667312 5268300 32.18 268828 2635472 5931388 34.05 2041220 6022124 348 13:54:18 Average: 6704243 9658995 6274918 38.32 260578 2721526 7145586 41.02 1994412 7146207 511 13:54:18 13:54:18 12:40:25 IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 13:54:18 12:50:25 lo 11.03 11.03 10.72 10.72 0.00 0.00 0.00 0.00 13:54:18 12:50:25 ens3 40.76 30.58 644.07 3.20 0.00 0.00 0.00 0.00 13:54:18 12:50:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:00:01 lo 36.86 36.86 18.17 18.17 0.00 0.00 0.00 0.00 13:54:18 13:00:01 ens3 1.85 1.79 0.43 0.37 0.00 0.00 0.00 0.00 13:54:18 13:00:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:10:00 lo 30.47 30.47 11.90 11.90 0.00 0.00 0.00 0.00 13:54:18 13:10:00 ens3 1.33 0.84 0.40 0.29 0.00 0.00 0.00 0.00 13:54:18 13:10:00 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:20:25 lo 4.85 4.85 3.67 3.67 0.00 0.00 0.00 0.00 13:54:18 13:20:25 ens3 0.73 0.34 0.19 0.12 0.00 0.00 0.00 0.00 13:54:18 13:20:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:30:01 lo 8.55 8.55 3.62 3.62 0.00 0.00 0.00 0.00 13:54:18 13:30:01 ens3 0.52 0.38 0.15 0.11 0.00 0.00 0.00 0.00 13:54:18 13:30:01 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:40:25 lo 7.58 7.58 4.79 4.79 0.00 0.00 0.00 0.00 13:54:18 13:40:25 ens3 1.57 1.91 0.28 1.75 0.00 0.00 0.00 0.00 13:54:18 13:40:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:50:25 lo 24.66 24.66 10.44 10.44 0.00 0.00 0.00 0.00 13:54:18 13:50:25 ens3 0.83 0.66 0.17 0.13 0.00 0.00 0.00 0.00 13:54:18 13:50:25 docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 Average: lo 17.52 17.52 8.97 8.97 0.00 0.00 0.00 0.00 13:54:18 Average: ens3 6.80 5.22 92.24 0.86 0.00 0.00 0.00 0.00 13:54:18 Average: docker0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13:54:18 13:54:18 13:54:18 ---> sar -P ALL: 13:54:18 Linux 5.15.0-168-generic (prd-ubuntu2204-docker-4c-16g-14098) 02/18/26 _x86_64_ (4 CPU) 13:54:18 13:54:18 12:32:43 LINUX RESTART (4 CPU) 13:54:18 13:54:18 12:40:25 CPU %user %nice %system %iowait %steal %idle 13:54:18 12:50:25 all 51.60 0.00 2.34 7.10 0.14 38.82 13:54:18 12:50:25 0 49.76 0.00 2.26 8.40 0.14 39.42 13:54:18 12:50:25 1 51.18 0.00 2.40 7.66 0.14 38.63 13:54:18 12:50:25 2 51.24 0.00 2.26 5.46 0.13 40.92 13:54:18 12:50:25 3 54.20 0.00 2.46 6.89 0.14 36.31 13:54:18 13:00:01 all 52.41 0.00 2.14 0.50 0.16 44.79 13:54:18 13:00:01 0 52.71 0.00 1.88 0.27 0.16 44.98 13:54:18 13:00:01 1 51.69 0.00 2.34 0.54 0.16 45.27 13:54:18 13:00:01 2 52.49 0.00 2.25 0.67 0.16 44.43 13:54:18 13:00:01 3 52.74 0.00 2.10 0.52 0.16 44.48 13:54:18 13:10:00 all 13.19 0.00 0.89 0.23 0.10 85.59 13:54:18 13:10:00 0 13.16 0.00 0.84 0.24 0.10 85.65 13:54:18 13:10:00 1 12.95 0.00 0.92 0.29 0.11 85.73 13:54:18 13:10:00 2 13.46 0.00 0.99 0.13 0.10 85.32 13:54:18 13:10:00 3 13.17 0.00 0.82 0.25 0.09 85.67 13:54:18 13:20:25 all 15.93 0.00 0.68 0.34 0.07 82.99 13:54:18 13:20:25 0 16.31 0.00 0.60 0.87 0.07 82.16 13:54:18 13:20:25 1 15.86 0.00 0.78 0.30 0.07 82.99 13:54:18 13:20:25 2 16.28 0.00 0.66 0.12 0.08 82.87 13:54:18 13:20:25 3 15.26 0.00 0.67 0.05 0.07 83.94 13:54:18 13:30:01 all 7.70 0.00 0.41 0.24 0.06 91.58 13:54:18 13:30:01 0 7.17 0.00 0.33 0.24 0.06 92.19 13:54:18 13:30:01 1 8.36 0.00 0.48 0.31 0.07 90.77 13:54:18 13:30:01 2 7.71 0.00 0.39 0.20 0.06 91.63 13:54:18 13:30:01 3 7.56 0.00 0.44 0.19 0.07 91.74 13:54:18 13:40:25 all 11.49 0.00 0.53 5.75 0.06 82.17 13:54:18 13:40:25 0 10.74 0.00 0.52 12.23 0.05 76.46 13:54:18 13:40:25 1 11.98 0.00 0.56 4.23 0.06 83.17 13:54:18 13:40:25 2 11.18 0.00 0.51 3.10 0.06 85.15 13:54:18 13:40:25 3 12.06 0.00 0.55 3.44 0.05 83.91 13:54:18 13:50:25 all 16.11 0.00 0.62 0.68 0.06 82.53 13:54:18 13:50:25 0 16.45 0.00 0.70 0.24 0.06 82.55 13:54:18 13:50:25 1 16.24 0.00 0.55 0.40 0.06 82.75 13:54:18 13:50:25 2 16.04 0.00 0.59 0.91 0.07 82.39 13:54:18 13:50:25 3 15.72 0.00 0.63 1.17 0.06 82.42 13:54:18 Average: all 23.86 0.00 1.08 2.15 0.09 72.82 13:54:18 Average: 0 23.57 0.00 1.01 3.29 0.09 72.04 13:54:18 Average: 1 23.82 0.00 1.14 1.98 0.10 72.97 13:54:18 Average: 2 23.86 0.00 1.08 1.52 0.09 73.44 13:54:18 Average: 3 24.18 0.00 1.09 1.80 0.09 72.84 13:54:18 13:54:18 13:54:18