02:05:39 Started by upstream project "integration-distribution-test-scandium" build number 501 02:05:39 originally caused by: 02:05:39 Started by upstream project "autorelease-release-scandium-mvn39-openjdk21" build number 517 02:05:39 originally caused by: 02:05:39 Started by timer 02:05:39 Running as SYSTEM 02:05:39 [EnvInject] - Loading node environment variables. 02:05:39 Building remotely on prd-centos8-robot-2c-8g-17411 (centos8-robot-2c-8g) in workspace /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium 02:05:40 [ssh-agent] Looking for ssh-agent implementation... 02:05:40 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 02:05:40 $ ssh-agent 02:05:40 SSH_AUTH_SOCK=/tmp/ssh-aogtx3A84oi0/agent.5158 02:05:40 SSH_AGENT_PID=5159 02:05:40 [ssh-agent] Started. 02:05:40 Running ssh-add (command line suppressed) 02:05:41 Identity added: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium@tmp/private_key_1809883811812855224.key (/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium@tmp/private_key_1809883811812855224.key) 02:05:41 [ssh-agent] Using credentials jenkins (Release Engineering Jenkins Key) 02:05:41 The recommended git tool is: NONE 02:05:47 using credential opendaylight-jenkins-ssh 02:05:47 Wiping out workspace first. 02:05:47 Cloning the remote Git repository 02:05:47 Cloning repository git://devvexx.opendaylight.org/mirror/integration/test 02:05:47 > git init /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test # timeout=10 02:05:47 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/integration/test 02:05:47 > git --version # timeout=10 02:05:47 > git --version # 'git version 2.43.0' 02:05:47 using GIT_SSH to set credentials Release Engineering Jenkins Key 02:05:47 [INFO] Currently running in a labeled security context 02:05:47 [INFO] Currently SELinux is 'enforcing' on the host 02:05:47 > /usr/bin/chcon --type=ssh_home_t /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test@tmp/jenkins-gitclient-ssh9099901710138150866.key 02:05:47 Verifying host key using known hosts file 02:05:47 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. 02:05:47 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/integration/test +refs/heads/*:refs/remotes/origin/* # timeout=10 02:05:49 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/integration/test # timeout=10 02:05:49 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 02:05:50 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/integration/test # timeout=10 02:05:50 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/integration/test 02:05:50 using GIT_SSH to set credentials Release Engineering Jenkins Key 02:05:50 [INFO] Currently running in a labeled security context 02:05:50 [INFO] Currently SELinux is 'enforcing' on the host 02:05:50 > /usr/bin/chcon --type=ssh_home_t /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test@tmp/jenkins-gitclient-ssh3528475762571296316.key 02:05:50 Verifying host key using known hosts file 02:05:50 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. 02:05:50 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/integration/test master # timeout=10 02:05:50 > git rev-parse FETCH_HEAD^{commit} # timeout=10 02:05:50 Checking out Revision cc140aba40d20c279ad305eb08204917e9a97348 (origin/master) 02:05:50 > git config core.sparsecheckout # timeout=10 02:05:50 > git checkout -f cc140aba40d20c279ad305eb08204917e9a97348 # timeout=10 02:05:51 Commit message: "Add bgpcep variables for vanadium" 02:05:51 > git rev-parse FETCH_HEAD^{commit} # timeout=10 02:05:51 > git rev-list --no-walk 2791c5dea1951b0af9405c9ac43be0884a2c5414 # timeout=10 02:05:51 No emails were triggered. 02:05:51 provisioning config files... 02:05:51 copy managed file [npmrc] to file:/home/jenkins/.npmrc 02:05:51 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf 02:05:51 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml 02:05:51 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins4740588230277277788.sh 02:05:51 ---> python-tools-install.sh 02:05:51 Setup pyenv: 02:05:52 system 02:05:52 * 3.8.13 (set by /opt/pyenv/version) 02:05:52 * 3.9.13 (set by /opt/pyenv/version) 02:05:52 * 3.10.13 (set by /opt/pyenv/version) 02:05:52 * 3.11.7 (set by /opt/pyenv/version) 02:05:56 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-3V2V 02:05:56 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv 02:05:56 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:05:56 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:06:00 lf-activate-venv(): INFO: Base packages installed successfully 02:06:00 lf-activate-venv(): INFO: Installing additional packages: lftools 02:06:24 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:06:24 Generating Requirements File 02:06:43 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. 02:06:43 httplib2 0.31.0 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible. 02:06:44 Python 3.11.7 02:06:44 pip 25.3 from /tmp/venv-3V2V/lib/python3.11/site-packages/pip (python 3.11) 02:06:44 appdirs==1.4.4 02:06:44 argcomplete==3.6.3 02:06:44 aspy.yaml==1.3.0 02:06:44 attrs==25.4.0 02:06:44 autopage==0.5.2 02:06:44 beautifulsoup4==4.14.3 02:06:44 boto3==1.42.18 02:06:44 botocore==1.42.18 02:06:44 bs4==0.0.2 02:06:44 cachetools==6.2.4 02:06:44 certifi==2025.11.12 02:06:44 cffi==2.0.0 02:06:44 cfgv==3.5.0 02:06:44 chardet==5.2.0 02:06:44 charset-normalizer==3.4.4 02:06:44 click==8.3.1 02:06:44 cliff==4.13.1 02:06:44 cmd2==3.1.0 02:06:44 cryptography==3.3.2 02:06:44 debtcollector==3.0.0 02:06:44 decorator==5.2.1 02:06:44 defusedxml==0.7.1 02:06:44 Deprecated==1.3.1 02:06:44 distlib==0.4.0 02:06:44 dnspython==2.8.0 02:06:44 docker==7.1.0 02:06:44 dogpile.cache==1.5.0 02:06:44 durationpy==0.10 02:06:44 email-validator==2.3.0 02:06:44 filelock==3.20.1 02:06:44 future==1.0.0 02:06:44 gitdb==4.0.12 02:06:44 GitPython==3.1.45 02:06:44 google-auth==2.45.0 02:06:44 httplib2==0.31.0 02:06:44 identify==2.6.15 02:06:44 idna==3.11 02:06:44 importlib-resources==1.5.0 02:06:44 iso8601==2.1.0 02:06:44 Jinja2==3.1.6 02:06:44 jmespath==1.0.1 02:06:44 jsonpatch==1.33 02:06:44 jsonpointer==3.0.0 02:06:44 jsonschema==4.25.1 02:06:44 jsonschema-specifications==2025.9.1 02:06:44 keystoneauth1==5.12.0 02:06:44 kubernetes==34.1.0 02:06:44 lftools==0.37.18 02:06:44 lxml==6.0.2 02:06:44 markdown-it-py==4.0.0 02:06:44 MarkupSafe==3.0.3 02:06:44 mdurl==0.1.2 02:06:44 msgpack==1.1.2 02:06:44 multi_key_dict==2.0.3 02:06:44 munch==4.0.0 02:06:44 netaddr==1.3.0 02:06:44 niet==1.4.2 02:06:44 nodeenv==1.10.0 02:06:44 oauth2client==4.1.3 02:06:44 oauthlib==3.3.1 02:06:44 openstacksdk==4.8.0 02:06:44 os-service-types==1.8.2 02:06:44 osc-lib==4.3.0 02:06:44 oslo.config==10.1.0 02:06:44 oslo.context==6.2.0 02:06:44 oslo.i18n==6.7.1 02:06:44 oslo.log==8.0.0 02:06:44 oslo.serialization==5.9.0 02:06:44 oslo.utils==9.2.0 02:06:44 packaging==25.0 02:06:44 pbr==7.0.3 02:06:44 platformdirs==4.5.1 02:06:44 prettytable==3.17.0 02:06:44 psutil==7.2.1 02:06:44 pyasn1==0.6.1 02:06:44 pyasn1_modules==0.4.2 02:06:44 pycparser==2.23 02:06:44 pygerrit2==2.0.15 02:06:44 PyGithub==2.8.1 02:06:44 Pygments==2.19.2 02:06:44 PyJWT==2.10.1 02:06:44 PyNaCl==1.6.1 02:06:44 pyparsing==2.4.7 02:06:44 pyperclip==1.11.0 02:06:44 pyrsistent==0.20.0 02:06:44 python-cinderclient==9.8.0 02:06:44 python-dateutil==2.9.0.post0 02:06:44 python-heatclient==4.3.0 02:06:44 python-jenkins==1.8.3 02:06:44 python-keystoneclient==5.7.0 02:06:44 python-magnumclient==4.9.0 02:06:44 python-openstackclient==8.2.0 02:06:44 python-swiftclient==4.9.0 02:06:44 PyYAML==6.0.3 02:06:44 referencing==0.37.0 02:06:44 requests==2.32.5 02:06:44 requests-oauthlib==2.0.0 02:06:44 requestsexceptions==1.4.0 02:06:44 rfc3986==2.0.0 02:06:44 rich==14.2.0 02:06:44 rich-argparse==1.7.2 02:06:44 rpds-py==0.30.0 02:06:44 rsa==4.9.1 02:06:44 ruamel.yaml==0.18.17 02:06:44 ruamel.yaml.clib==0.2.15 02:06:44 s3transfer==0.16.0 02:06:44 simplejson==3.20.2 02:06:44 six==1.17.0 02:06:44 smmap==5.0.2 02:06:44 soupsieve==2.8.1 02:06:44 stevedore==5.6.0 02:06:44 tabulate==0.9.0 02:06:44 toml==0.10.2 02:06:44 tomlkit==0.13.3 02:06:44 tqdm==4.67.1 02:06:44 typing_extensions==4.15.0 02:06:44 tzdata==2025.3 02:06:44 urllib3==1.26.20 02:06:44 virtualenv==20.35.4 02:06:44 wcwidth==0.2.14 02:06:44 websocket-client==1.9.0 02:06:44 wrapt==2.0.1 02:06:44 xdg==6.0.0 02:06:44 xmltodict==1.0.2 02:06:44 yq==3.4.3 02:06:44 [EnvInject] - Injecting environment variables from a build step. 02:06:44 [EnvInject] - Injecting as environment variables the properties content 02:06:44 OS_STACK_TEMPLATE=csit-2-instance-type.yaml 02:06:44 OS_CLOUD=vex 02:06:44 OS_STACK_NAME=releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:06:44 OS_STACK_TEMPLATE_DIR=openstack-hot 02:06:44 02:06:44 [EnvInject] - Variables injected successfully. 02:06:44 provisioning config files... 02:06:45 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml 02:06:45 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins8097024940417929610.sh 02:06:45 ---> Create parameters file for OpenStack HOT 02:06:45 OpenStack Heat parameters generated 02:06:45 ----------------------------------- 02:06:45 parameters: 02:06:45 vm_0_count: '3' 02:06:45 vm_0_flavor: 'v3-standard-4' 02:06:45 vm_0_image: 'ZZCI - Ubuntu 22.04 - builder - x86_64 - 20251201-010221.432' 02:06:45 vm_1_count: '1' 02:06:45 vm_1_flavor: 'v3-standard-2' 02:06:45 vm_1_image: 'ZZCI - Ubuntu 22.04 - mininet-ovs-217 - x86_64 - 20250917-133034.654' 02:06:45 02:06:45 job_name: '65281-493' 02:06:45 silo: 'releng' 02:06:45 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins7804280035868623065.sh 02:06:45 ---> Create HEAT stack 02:06:45 + source /home/jenkins/lf-env.sh 02:06:45 + lf-activate-venv --python python3 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq 02:06:45 ++ mktemp -d /tmp/venv-XXXX 02:06:45 + lf_venv=/tmp/venv-b0H8 02:06:45 + local venv_file=/tmp/.os_lf_venv 02:06:45 + local python=python3 02:06:45 + local options 02:06:45 + local set_path=true 02:06:45 + local install_args= 02:06:45 ++ getopt -o np:v: -l no-path,system-site-packages,python:,venv-file: -n lf-activate-venv -- --python python3 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq 02:06:45 + options=' --python '\''python3'\'' -- '\''lftools[openstack]'\'' '\''kubernetes'\'' '\''niet'\'' '\''python-heatclient'\'' '\''python-openstackclient'\'' '\''python-magnumclient'\'' '\''urllib3~=1.26.15'\'' '\''yq'\''' 02:06:45 + eval set -- ' --python '\''python3'\'' -- '\''lftools[openstack]'\'' '\''kubernetes'\'' '\''niet'\'' '\''python-heatclient'\'' '\''python-openstackclient'\'' '\''python-magnumclient'\'' '\''urllib3~=1.26.15'\'' '\''yq'\''' 02:06:45 ++ set -- --python python3 -- 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq 02:06:45 + true 02:06:45 + case $1 in 02:06:45 + python=python3 02:06:45 + shift 2 02:06:45 + true 02:06:45 + case $1 in 02:06:45 + shift 02:06:45 + break 02:06:45 + case $python in 02:06:45 + local pkg_list= 02:06:45 + [[ -d /opt/pyenv ]] 02:06:45 + echo 'Setup pyenv:' 02:06:45 Setup pyenv: 02:06:45 + export PYENV_ROOT=/opt/pyenv 02:06:45 + PYENV_ROOT=/opt/pyenv 02:06:45 + export PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:06:45 + PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:06:45 + pyenv versions 02:06:45 system 02:06:45 3.8.13 02:06:45 3.9.13 02:06:45 3.10.13 02:06:45 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:06:45 + command -v pyenv 02:06:45 ++ pyenv init - --no-rehash 02:06:45 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH); 02:06:45 for i in ${!paths[@]}; do 02:06:45 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\''; 02:06:45 fi; done; 02:06:45 echo "${paths[*]}"'\'')" 02:06:45 export PATH="/opt/pyenv/shims:${PATH}" 02:06:45 export PYENV_SHELL=bash 02:06:45 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\'' 02:06:45 pyenv() { 02:06:45 local command 02:06:45 command="${1:-}" 02:06:45 if [ "$#" -gt 0 ]; then 02:06:45 shift 02:06:45 fi 02:06:45 02:06:45 case "$command" in 02:06:45 rehash|shell) 02:06:45 eval "$(pyenv "sh-$command" "$@")" 02:06:45 ;; 02:06:45 *) 02:06:45 command pyenv "$command" "$@" 02:06:45 ;; 02:06:45 esac 02:06:45 }' 02:06:45 +++ bash --norc -ec 'IFS=:; paths=($PATH); 02:06:45 for i in ${!paths[@]}; do 02:06:45 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\''; 02:06:45 fi; done; 02:06:45 echo "${paths[*]}"' 02:06:45 ++ PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:06:45 ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:06:45 ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:06:45 ++ export PYENV_SHELL=bash 02:06:45 ++ PYENV_SHELL=bash 02:06:45 ++ source /opt/pyenv/libexec/../completions/pyenv.bash 02:06:45 +++ complete -F _pyenv pyenv 02:06:45 ++ lf-pyver python3 02:06:45 ++ local py_version_xy=python3 02:06:45 ++ local py_version_xyz= 02:06:45 ++ awk '{ print $1 }' 02:06:45 ++ pyenv versions 02:06:45 ++ local command 02:06:45 ++ command=versions 02:06:45 ++ '[' 1 -gt 0 ']' 02:06:45 ++ shift 02:06:45 ++ case "$command" in 02:06:45 ++ command pyenv versions 02:06:45 ++ pyenv versions 02:06:45 ++ sed 's/^[ *]* //' 02:06:45 ++ grep -E '^[0-9.]*[0-9]$' 02:06:45 ++ [[ ! -s /tmp/.pyenv_versions ]] 02:06:45 +++ grep '^3' /tmp/.pyenv_versions 02:06:45 +++ tail -n 1 02:06:45 +++ sort -V 02:06:45 ++ py_version_xyz=3.11.7 02:06:45 ++ [[ -z 3.11.7 ]] 02:06:45 ++ echo 3.11.7 02:06:45 ++ return 0 02:06:45 + pyenv local 3.11.7 02:06:45 + local command 02:06:45 + command=local 02:06:45 + '[' 2 -gt 0 ']' 02:06:45 + shift 02:06:45 + case "$command" in 02:06:45 + command pyenv local 3.11.7 02:06:45 + pyenv local 3.11.7 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='lftools[openstack] ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='kubernetes ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='niet ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='python-heatclient ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='python-openstackclient ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='python-magnumclient ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='urllib3~=1.26.15 ' 02:06:45 + for arg in "$@" 02:06:45 + case $arg in 02:06:45 + pkg_list+='yq ' 02:06:45 + [[ -f /tmp/.os_lf_venv ]] 02:06:45 ++ cat /tmp/.os_lf_venv 02:06:45 + lf_venv=/tmp/venv-3V2V 02:06:45 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from' file:/tmp/.os_lf_venv 02:06:45 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:06:45 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)' 02:06:45 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:06:45 + local 'pip_opts=--upgrade --quiet' 02:06:45 + pip_opts='--upgrade --quiet --trusted-host pypi.org' 02:06:45 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org' 02:06:45 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org' 02:06:45 + [[ -n '' ]] 02:06:45 + [[ -n '' ]] 02:06:45 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...' 02:06:45 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:06:45 + /tmp/venv-3V2V/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 02:06:47 + echo 'lf-activate-venv(): INFO: Base packages installed successfully' 02:06:47 lf-activate-venv(): INFO: Base packages installed successfully 02:06:47 + [[ -z lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq ]] 02:06:47 + echo 'lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq ' 02:06:47 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq 02:06:47 + /tmp/venv-3V2V/bin/python3 -m pip install --upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org --upgrade-strategy eager 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq 02:07:05 + type python3 02:07:05 + true 02:07:05 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH' 02:07:05 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:07:05 + PATH=/tmp/venv-3V2V/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/home/jenkins/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/opt/puppetlabs/bin 02:07:05 + return 0 02:07:05 + openstack --os-cloud vex limits show --absolute 02:07:07 +--------------------------+---------+ 02:07:07 | Name | Value | 02:07:07 +--------------------------+---------+ 02:07:07 | maxTotalInstances | -1 | 02:07:07 | maxTotalCores | 450 | 02:07:07 | maxTotalRAMSize | 1000000 | 02:07:07 | maxServerMeta | 128 | 02:07:07 | maxImageMeta | 128 | 02:07:07 | maxPersonality | 5 | 02:07:07 | maxPersonalitySize | 10240 | 02:07:07 | maxTotalKeypairs | 100 | 02:07:07 | maxServerGroups | 10 | 02:07:07 | maxServerGroupMembers | 10 | 02:07:07 | maxTotalFloatingIps | -1 | 02:07:07 | maxSecurityGroups | -1 | 02:07:07 | maxSecurityGroupRules | -1 | 02:07:07 | totalRAMUsed | 737280 | 02:07:07 | totalCoresUsed | 180 | 02:07:07 | totalInstancesUsed | 79 | 02:07:07 | totalFloatingIpsUsed | 0 | 02:07:07 | totalSecurityGroupsUsed | 0 | 02:07:07 | totalServerGroupsUsed | 0 | 02:07:07 | maxTotalVolumes | -1 | 02:07:07 | maxTotalSnapshots | 10 | 02:07:07 | maxTotalVolumeGigabytes | 4096 | 02:07:07 | maxTotalBackups | 10 | 02:07:07 | maxTotalBackupGigabytes | 1000 | 02:07:07 | totalVolumesUsed | 3 | 02:07:07 | totalGigabytesUsed | 60 | 02:07:07 | totalSnapshotsUsed | 0 | 02:07:07 | totalBackupsUsed | 0 | 02:07:07 | totalBackupGigabytesUsed | 0 | 02:07:07 +--------------------------+---------+ 02:07:07 + pushd /opt/ciman/openstack-hot 02:07:07 /opt/ciman/openstack-hot /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium 02:07:07 + lftools openstack --os-cloud vex stack create releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 csit-2-instance-type.yaml /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/stack-parameters.yaml 02:07:34 Creating stack releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:07:34 Waiting to initialize infrastructure... 02:07:34 Stack initialization successful. 02:07:34 ------------------------------------ 02:07:34 Stack Details 02:07:34 ------------------------------------ 02:07:34 {'added': None, 02:07:34 'capabilities': [], 02:07:34 'created_at': '2025-12-30T02:07:10Z', 02:07:34 'deleted': None, 02:07:34 'deleted_at': None, 02:07:34 'description': 'No description', 02:07:34 'environment': None, 02:07:34 'environment_files': None, 02:07:34 'files': None, 02:07:34 'files_container': None, 02:07:34 'id': 'e06b7193-a875-428a-96e4-097465375f75', 02:07:34 'is_rollback_disabled': True, 02:07:34 'links': [{'href': 'https://orchestration.public.mtl1.vexxhost.net/v1/12c36e260d8e4bb2913965203b1b491f/stacks/releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493/e06b7193-a875-428a-96e4-097465375f75', 02:07:34 'rel': 'self'}], 02:07:34 'location': Munch({'cloud': 'vex', 'region_name': 'ca-ymq-1', 'zone': None, 'project': Munch({'id': '12c36e260d8e4bb2913965203b1b491f', 'name': '61975f2c-7c17-4d69-82fa-c3ae420ad6fd', 'domain_id': None, 'domain_name': 'Default'})}), 02:07:34 'name': 'releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493', 02:07:34 'notification_topics': [], 02:07:34 'outputs': [{'description': 'IP addresses of the 1st vm types', 02:07:34 'output_key': 'vm_0_ips', 02:07:34 'output_value': ['10.30.171.33', 02:07:34 '10.30.170.204', 02:07:34 '10.30.171.83']}, 02:07:34 {'description': 'IP addresses of the 2nd vm types', 02:07:34 'output_key': 'vm_1_ips', 02:07:34 'output_value': ['10.30.171.80']}], 02:07:34 'owner_id': ****, 02:07:34 'parameters': {'OS::project_id': '12c36e260d8e4bb2913965203b1b491f', 02:07:34 'OS::stack_id': 'e06b7193-a875-428a-96e4-097465375f75', 02:07:34 'OS::stack_name': 'releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493', 02:07:34 'job_name': '65281-493', 02:07:34 'silo': 'releng', 02:07:34 'vm_0_count': '3', 02:07:34 'vm_0_flavor': 'v3-standard-4', 02:07:34 'vm_0_image': 'ZZCI - Ubuntu 22.04 - builder - x86_64 - ' 02:07:34 '20251201-010221.432', 02:07:34 'vm_1_count': '1', 02:07:34 'vm_1_flavor': 'v3-standard-2', 02:07:34 'vm_1_image': 'ZZCI - Ubuntu 22.04 - mininet-ovs-217 - x86_64 ' 02:07:34 '- 20250917-133034.654'}, 02:07:34 'parent_id': None, 02:07:34 'replaced': None, 02:07:34 'status': 'CREATE_COMPLETE', 02:07:34 'status_reason': 'Stack CREATE completed successfully', 02:07:34 'tags': [], 02:07:34 'template': None, 02:07:34 'template_description': 'No description', 02:07:34 'template_url': None, 02:07:34 'timeout_mins': 15, 02:07:34 'unchanged': None, 02:07:34 'updated': None, 02:07:34 'updated_at': None, 02:07:34 'user_project_id': '688ffb441757443ba6b3ac2376852de1'} 02:07:34 ------------------------------------ 02:07:34 + popd 02:07:34 /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium 02:07:34 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins11845891322600658915.sh 02:07:34 ---> Copy SSH public keys to CSIT lab 02:07:34 Setup pyenv: 02:07:34 system 02:07:34 3.8.13 02:07:34 3.9.13 02:07:34 3.10.13 02:07:34 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:07:35 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:07:35 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:07:35 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:07:37 lf-activate-venv(): INFO: Base packages installed successfully 02:07:37 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes python-heatclient python-openstackclient urllib3~=1.26.15 02:07:50 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:07:52 SSH not responding on 10.30.171.83. Retrying in 10 seconds... 02:07:52 SSH not responding on 10.30.170.204. Retrying in 10 seconds... 02:07:52 SSH not responding on 10.30.171.33. Retrying in 10 seconds... 02:07:53 Warning: Permanently added '10.30.171.80' (ECDSA) to the list of known hosts. 02:07:53 releng-65281-493-1-mininet-ovs-217-0 02:07:53 Successfully copied public keys to slave 10.30.171.80 02:08:02 Ping to 10.30.171.83 successful. 02:08:02 Ping to 10.30.171.33 successful. 02:08:02 Ping to 10.30.170.204 successful. 02:08:03 SSH not responding on 10.30.171.33. Retrying in 10 seconds... 02:08:03 SSH not responding on 10.30.170.204. Retrying in 10 seconds... 02:08:03 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:08:04 releng-65281-493-0-builder-2 02:08:04 Successfully copied public keys to slave 10.30.171.83 02:08:13 Ping to 10.30.171.33 successful. 02:08:13 Ping to 10.30.170.204 successful. 02:08:14 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:08:14 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:08:14 releng-65281-493-0-builder-0 02:08:14 Successfully copied public keys to slave 10.30.171.33 02:08:14 Process 6489 ready. 02:08:14 releng-65281-493-0-builder-1 02:08:14 Successfully copied public keys to slave 10.30.170.204 02:08:14 Process 6490 ready. 02:08:14 Process 6491 ready. 02:08:14 Process 6492 ready. 02:08:14 SSH ready on all stack servers. 02:08:14 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins18358340811600853762.sh 02:08:14 Setup pyenv: 02:08:15 system 02:08:15 3.8.13 02:08:15 3.9.13 02:08:15 3.10.13 02:08:15 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:08:19 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-eklh 02:08:19 lf-activate-venv(): INFO: Save venv in file: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.robot_venv 02:08:19 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:08:19 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:08:22 lf-activate-venv(): INFO: Base packages installed successfully 02:08:22 lf-activate-venv(): INFO: Installing additional packages: setuptools wheel 02:08:24 lf-activate-venv(): INFO: Adding /tmp/venv-eklh/bin to PATH 02:08:24 + echo 'Installing Python Requirements' 02:08:24 Installing Python Requirements 02:08:24 + cat 02:08:24 + python -m pip install -r requirements.txt 02:08:24 Looking in indexes: https://nexus3.opendaylight.org/repository/PyPi/simple 02:08:24 Collecting docker-py (from -r requirements.txt (line 1)) 02:08:24 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/docker-py/1.10.6/docker_py-1.10.6-py2.py3-none-any.whl (50 kB) 02:08:24 Collecting ipaddr (from -r requirements.txt (line 2)) 02:08:24 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/ipaddr/2.2.0/ipaddr-2.2.0.tar.gz (26 kB) 02:08:24 Installing build dependencies: started 02:08:26 Installing build dependencies: finished with status 'done' 02:08:26 Getting requirements to build wheel: started 02:08:27 Getting requirements to build wheel: finished with status 'done' 02:08:27 Preparing metadata (pyproject.toml): started 02:08:27 Preparing metadata (pyproject.toml): finished with status 'done' 02:08:27 Collecting netaddr (from -r requirements.txt (line 3)) 02:08:27 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/netaddr/1.3.0/netaddr-1.3.0-py3-none-any.whl (2.3 MB) 02:08:27 Collecting netifaces (from -r requirements.txt (line 4)) 02:08:27 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/netifaces/0.11.0/netifaces-0.11.0.tar.gz (30 kB) 02:08:27 Installing build dependencies: started 02:08:28 Installing build dependencies: finished with status 'done' 02:08:28 Getting requirements to build wheel: started 02:08:28 Getting requirements to build wheel: finished with status 'done' 02:08:28 Preparing metadata (pyproject.toml): started 02:08:28 Preparing metadata (pyproject.toml): finished with status 'done' 02:08:28 Collecting pyhocon (from -r requirements.txt (line 5)) 02:08:28 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/pyhocon/0.3.61/pyhocon-0.3.61-py3-none-any.whl (25 kB) 02:08:28 Collecting requests (from -r requirements.txt (line 6)) 02:08:28 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/requests/2.32.5/requests-2.32.5-py3-none-any.whl (64 kB) 02:08:28 Collecting robotframework (from -r requirements.txt (line 7)) 02:08:28 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework/7.4.1/robotframework-7.4.1-py3-none-any.whl (806 kB) 02:08:28 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 806.9/806.9 kB 27.9 MB/s 0:00:00 02:08:28 Collecting robotframework-httplibrary (from -r requirements.txt (line 8)) 02:08:28 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-httplibrary/0.4.2/robotframework-httplibrary-0.4.2.tar.gz (9.1 kB) 02:08:29 Installing build dependencies: started 02:08:30 Installing build dependencies: finished with status 'done' 02:08:30 Getting requirements to build wheel: started 02:08:30 Getting requirements to build wheel: finished with status 'done' 02:08:30 Preparing metadata (pyproject.toml): started 02:08:30 Preparing metadata (pyproject.toml): finished with status 'done' 02:08:30 Collecting robotframework-requests==0.9.7 (from -r requirements.txt (line 9)) 02:08:30 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-requests/0.9.7/robotframework_requests-0.9.7-py3-none-any.whl (21 kB) 02:08:30 Collecting robotframework-selenium2library (from -r requirements.txt (line 10)) 02:08:30 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-selenium2library/3.0.0/robotframework_selenium2library-3.0.0-py2.py3-none-any.whl (6.2 kB) 02:08:30 Collecting robotframework-sshlibrary==3.8.0 (from -r requirements.txt (line 11)) 02:08:30 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-sshlibrary/3.8.0/robotframework-sshlibrary-3.8.0.tar.gz (51 kB) 02:08:30 Installing build dependencies: started 02:08:31 Installing build dependencies: finished with status 'done' 02:08:31 Getting requirements to build wheel: started 02:08:32 Getting requirements to build wheel: finished with status 'done' 02:08:32 Preparing metadata (pyproject.toml): started 02:08:32 Preparing metadata (pyproject.toml): finished with status 'done' 02:08:32 Collecting scapy (from -r requirements.txt (line 12)) 02:08:32 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/scapy/2.7.0/scapy-2.7.0-py3-none-any.whl (2.6 MB) 02:08:32 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 2.6/2.6 MB 43.3 MB/s 0:00:00 02:08:32 Collecting jsonpath-rw (from -r requirements.txt (line 15)) 02:08:32 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/jsonpath-rw/1.4.0/jsonpath-rw-1.4.0.tar.gz (13 kB) 02:08:32 Installing build dependencies: started 02:08:33 Installing build dependencies: finished with status 'done' 02:08:33 Getting requirements to build wheel: started 02:08:33 Getting requirements to build wheel: finished with status 'done' 02:08:33 Preparing metadata (pyproject.toml): started 02:08:33 Preparing metadata (pyproject.toml): finished with status 'done' 02:08:33 Collecting elasticsearch (from -r requirements.txt (line 18)) 02:08:33 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch/9.2.1/elasticsearch-9.2.1-py3-none-any.whl (963 kB) 02:08:33 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 963.6/963.6 kB 35.0 MB/s 0:00:00 02:08:34 Collecting elasticsearch-dsl (from -r requirements.txt (line 19)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch-dsl/8.18.0/elasticsearch_dsl-8.18.0-py3-none-any.whl (10 kB) 02:08:34 Collecting pyangbind (from -r requirements.txt (line 22)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/pyangbind/0.8.7/pyangbind-0.8.7-py3-none-any.whl (52 kB) 02:08:34 Collecting isodate (from -r requirements.txt (line 25)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/isodate/0.7.2/isodate-0.7.2-py3-none-any.whl (22 kB) 02:08:34 Collecting jmespath (from -r requirements.txt (line 28)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/jmespath/1.0.1/jmespath-1.0.1-py3-none-any.whl (20 kB) 02:08:34 Collecting jsonpatch (from -r requirements.txt (line 31)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/jsonpatch/1.33/jsonpatch-1.33-py2.py3-none-any.whl (12 kB) 02:08:34 Collecting paramiko>=1.15.3 (from robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/paramiko/4.0.0/paramiko-4.0.0-py3-none-any.whl (223 kB) 02:08:34 Collecting scp>=0.13.0 (from robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/scp/0.15.0/scp-0.15.0-py2.py3-none-any.whl (8.8 kB) 02:08:34 Collecting docker-pycreds>=0.2.1 (from docker-py->-r requirements.txt (line 1)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/docker-pycreds/0.4.0/docker_pycreds-0.4.0-py2.py3-none-any.whl (9.0 kB) 02:08:34 Collecting six>=1.4.0 (from docker-py->-r requirements.txt (line 1)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/six/1.17.0/six-1.17.0-py2.py3-none-any.whl (11 kB) 02:08:34 Collecting websocket-client>=0.32.0 (from docker-py->-r requirements.txt (line 1)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/websocket-client/1.9.0/websocket_client-1.9.0-py3-none-any.whl (82 kB) 02:08:34 Collecting pyparsing<4,>=2 (from pyhocon->-r requirements.txt (line 5)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/pyparsing/3.3.1/pyparsing-3.3.1-py3-none-any.whl (121 kB) 02:08:34 Collecting charset_normalizer<4,>=2 (from requests->-r requirements.txt (line 6)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/charset-normalizer/3.4.4/charset_normalizer-3.4.4-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (151 kB) 02:08:34 Collecting idna<4,>=2.5 (from requests->-r requirements.txt (line 6)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/idna/3.11/idna-3.11-py3-none-any.whl (71 kB) 02:08:34 Collecting urllib3<3,>=1.21.1 (from requests->-r requirements.txt (line 6)) 02:08:34 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/urllib3/2.6.2/urllib3-2.6.2-py3-none-any.whl (131 kB) 02:08:34 Collecting certifi>=2017.4.17 (from requests->-r requirements.txt (line 6)) 02:08:34 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/certifi/2025.11.12/certifi-2025.11.12-py3-none-any.whl (159 kB) 02:08:35 Collecting webtest>=2.0 (from robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/webtest/3.0.7/webtest-3.0.7-py3-none-any.whl (32 kB) 02:08:35 Collecting jsonpointer (from robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:35 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/jsonpointer/3.0.0/jsonpointer-3.0.0-py2.py3-none-any.whl (7.6 kB) 02:08:35 Collecting robotframework-seleniumlibrary>=3.0.0 (from robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-seleniumlibrary/6.8.0/robotframework_seleniumlibrary-6.8.0-py3-none-any.whl (104 kB) 02:08:35 Collecting ply (from jsonpath-rw->-r requirements.txt (line 15)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/ply/3.11/ply-3.11-py2.py3-none-any.whl (49 kB) 02:08:35 Collecting decorator (from jsonpath-rw->-r requirements.txt (line 15)) 02:08:35 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/decorator/5.2.1/decorator-5.2.1-py3-none-any.whl (9.2 kB) 02:08:35 Collecting anyio (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/anyio/4.12.0/anyio-4.12.0-py3-none-any.whl (113 kB) 02:08:35 Collecting elastic-transport<10,>=9.2.0 (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elastic-transport/9.2.1/elastic_transport-9.2.1-py3-none-any.whl (65 kB) 02:08:35 Collecting python-dateutil (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/python-dateutil/2.9.0.post0/python_dateutil-2.9.0.post0-py2.py3-none-any.whl (229 kB) 02:08:35 Collecting sniffio (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/sniffio/1.3.1/sniffio-1.3.1-py3-none-any.whl (10 kB) 02:08:35 Collecting typing-extensions (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/typing-extensions/4.15.0/typing_extensions-4.15.0-py3-none-any.whl (44 kB) 02:08:35 Collecting elasticsearch (from -r requirements.txt (line 18)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch/8.19.3/elasticsearch-8.19.3-py3-none-any.whl (952 kB) 02:08:35 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 952.8/952.8 kB 36.2 MB/s 0:00:00 02:08:35 INFO: pip is looking at multiple versions of elasticsearch-dsl to determine which version is compatible with other requirements. This could take a while. 02:08:35 Collecting elasticsearch-dsl (from -r requirements.txt (line 19)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch-dsl/8.17.1/elasticsearch_dsl-8.17.1-py3-none-any.whl (158 kB) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch-dsl/8.17.0/elasticsearch_dsl-8.17.0-py3-none-any.whl (158 kB) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch-dsl/8.16.0/elasticsearch_dsl-8.16.0-py3-none-any.whl (158 kB) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elasticsearch-dsl/8.15.4/elasticsearch_dsl-8.15.4-py3-none-any.whl (104 kB) 02:08:35 Collecting elastic-transport<9,>=8.15.1 (from elasticsearch->-r requirements.txt (line 18)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/elastic-transport/8.17.1/elastic_transport-8.17.1-py3-none-any.whl (64 kB) 02:08:35 Collecting pyang (from pyangbind->-r requirements.txt (line 22)) 02:08:35 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/pyang/2.7.1/pyang-2.7.1-py2.py3-none-any.whl (598 kB) 02:08:35 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 598.5/598.5 kB 25.8 MB/s 0:00:00 02:08:36 Collecting lxml (from pyangbind->-r requirements.txt (line 22)) 02:08:36 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/lxml/6.0.2/lxml-6.0.2-cp311-cp311-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (5.2 MB) 02:08:37 Collecting regex (from pyangbind->-r requirements.txt (line 22)) 02:08:37 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/regex/2025.11.3/regex-2025.11.3-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (800 kB) 02:08:37 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 800.4/800.4 kB 28.7 MB/s 0:00:00 02:08:37 Collecting enum34 (from pyangbind->-r requirements.txt (line 22)) 02:08:37 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/enum34/1.1.10/enum34-1.1.10-py3-none-any.whl (11 kB) 02:08:37 Collecting bcrypt>=3.2 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:37 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/bcrypt/5.0.0/bcrypt-5.0.0-cp39-abi3-manylinux_2_28_x86_64.whl (278 kB) 02:08:38 Collecting cryptography>=3.3 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:38 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/cryptography/46.0.3/cryptography-46.0.3-cp311-abi3-manylinux_2_28_x86_64.whl (4.5 MB) 02:08:38 Collecting invoke>=2.0 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:38 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/invoke/2.2.1/invoke-2.2.1-py3-none-any.whl (160 kB) 02:08:38 Collecting pynacl>=1.5 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:38 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/pynacl/1.6.1/pynacl-1.6.1-cp38-abi3-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (1.4 MB) 02:08:38 Collecting cffi>=2.0.0 (from cryptography>=3.3->paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:38 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/cffi/2.0.0/cffi-2.0.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (215 kB) 02:08:38 Collecting pycparser (from cffi>=2.0.0->cryptography>=3.3->paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11)) 02:08:38 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/pycparser/2.23/pycparser-2.23-py3-none-any.whl (118 kB) 02:08:38 Collecting selenium>=4.3.0 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:38 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/selenium/4.39.0/selenium-4.39.0-py3-none-any.whl (9.7 MB) 02:08:38 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 9.7/9.7 MB 78.2 MB/s 0:00:00 02:08:38 Collecting robotframework-pythonlibcore>=4.4.1 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:38 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/robotframework-pythonlibcore/4.4.1/robotframework_pythonlibcore-4.4.1-py2.py3-none-any.whl (12 kB) 02:08:38 Collecting click>=8.0 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:38 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/click/8.3.1/click-8.3.1-py3-none-any.whl (108 kB) 02:08:38 Collecting trio<1.0,>=0.31.0 (from selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:38 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/trio/0.32.0/trio-0.32.0-py3-none-any.whl (512 kB) 02:08:38 Collecting trio-websocket<1.0,>=0.12.2 (from selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:38 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/trio-websocket/0.12.2/trio_websocket-0.12.2-py3-none-any.whl (21 kB) 02:08:39 Collecting attrs>=23.2.0 (from trio<1.0,>=0.31.0->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/attrs/25.4.0/attrs-25.4.0-py3-none-any.whl (67 kB) 02:08:39 Collecting sortedcontainers (from trio<1.0,>=0.31.0->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/sortedcontainers/2.4.0/sortedcontainers-2.4.0-py2.py3-none-any.whl (29 kB) 02:08:39 Collecting outcome (from trio<1.0,>=0.31.0->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/outcome/1.3.0.post0/outcome-1.3.0.post0-py2.py3-none-any.whl (10 kB) 02:08:39 Collecting wsproto>=0.14 (from trio-websocket<1.0,>=0.12.2->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/wsproto/1.3.2/wsproto-1.3.2-py3-none-any.whl (24 kB) 02:08:39 Collecting pysocks!=1.5.7,<2.0,>=1.5.6 (from urllib3[socks]<3.0,>=2.5.0->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/pysocks/1.7.1/PySocks-1.7.1-py3-none-any.whl (16 kB) 02:08:39 Collecting WebOb>=1.2 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/webob/1.8.9/WebOb-1.8.9-py2.py3-none-any.whl (115 kB) 02:08:39 Collecting waitress>=3.0.2 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/waitress/3.0.2/waitress-3.0.2-py3-none-any.whl (56 kB) 02:08:39 Collecting beautifulsoup4 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:39 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/beautifulsoup4/4.14.3/beautifulsoup4-4.14.3-py3-none-any.whl (107 kB) 02:08:39 Collecting h11<1,>=0.16.0 (from wsproto>=0.14->trio-websocket<1.0,>=0.12.2->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10)) 02:08:39 Downloading https://nexus3.opendaylight.org/repository/PyPi/packages/h11/0.16.0/h11-0.16.0-py3-none-any.whl (37 kB) 02:08:39 Collecting soupsieve>=1.6.1 (from beautifulsoup4->webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8)) 02:08:39 Using cached https://nexus3.opendaylight.org/repository/PyPi/packages/soupsieve/2.8.1/soupsieve-2.8.1-py3-none-any.whl (36 kB) 02:08:39 Building wheels for collected packages: robotframework-sshlibrary, ipaddr, netifaces, robotframework-httplibrary, jsonpath-rw 02:08:39 Building wheel for robotframework-sshlibrary (pyproject.toml): started 02:08:39 Building wheel for robotframework-sshlibrary (pyproject.toml): finished with status 'done' 02:08:39 Created wheel for robotframework-sshlibrary: filename=robotframework_sshlibrary-3.8.0-py3-none-any.whl size=55205 sha256=337854cb9a47cd3cf7b5f2fe5e9a1dd2b55464bf6980c47937c4e2aba0981563 02:08:39 Stored in directory: /home/jenkins/.cache/pip/wheels/f7/c9/b3/a977b7bcc410d45ae27d240df3d00a12585509180e373ecccc 02:08:39 Building wheel for ipaddr (pyproject.toml): started 02:08:40 Building wheel for ipaddr (pyproject.toml): finished with status 'done' 02:08:40 Created wheel for ipaddr: filename=ipaddr-2.2.0-py3-none-any.whl size=18353 sha256=ad99e4c0f85c494a6bbeda47468f2d90ee1c4faec600eb346c9cda69f355f33b 02:08:40 Stored in directory: /home/jenkins/.cache/pip/wheels/dc/6c/04/da2d847fa8d45c59af3e1d83e2acc29cb8adcbaf04c0898dbf 02:08:40 Building wheel for netifaces (pyproject.toml): started 02:08:42 Building wheel for netifaces (pyproject.toml): finished with status 'done' 02:08:42 Created wheel for netifaces: filename=netifaces-0.11.0-cp311-cp311-linux_x86_64.whl size=41081 sha256=091a352593e9bab1f5b654187e76e900aa0f487a971baf0f1544a17574a966ea 02:08:42 Stored in directory: /home/jenkins/.cache/pip/wheels/f8/18/88/e61d54b995bea304bdb1d040a92b72228a1bf72ca2a3eba7c9 02:08:42 Building wheel for robotframework-httplibrary (pyproject.toml): started 02:08:42 Building wheel for robotframework-httplibrary (pyproject.toml): finished with status 'done' 02:08:42 Created wheel for robotframework-httplibrary: filename=robotframework_httplibrary-0.4.2-py3-none-any.whl size=10014 sha256=e00c9e1e44ce4735c121b09ad2cf9886ab7bad5ec2be6348af4563da63b84abc 02:08:42 Stored in directory: /home/jenkins/.cache/pip/wheels/aa/bc/0d/9a20dd51effef392aae2733cb4c7b66c6fa29fca33d88b57ed 02:08:42 Building wheel for jsonpath-rw (pyproject.toml): started 02:08:42 Building wheel for jsonpath-rw (pyproject.toml): finished with status 'done' 02:08:42 Created wheel for jsonpath-rw: filename=jsonpath_rw-1.4.0-py3-none-any.whl size=15176 sha256=45d311f50eff094811c374c948617d07f5a13239ff4f05556f6046a84f7d435f 02:08:42 Stored in directory: /home/jenkins/.cache/pip/wheels/f1/54/63/9a8da38cefae13755097b36cc852decc25d8ef69c37d58d4eb 02:08:42 Successfully built robotframework-sshlibrary ipaddr netifaces robotframework-httplibrary jsonpath-rw 02:08:42 Installing collected packages: sortedcontainers, ply, netifaces, ipaddr, enum34, websocket-client, WebOb, waitress, urllib3, typing-extensions, soupsieve, sniffio, six, scapy, robotframework-pythonlibcore, robotframework, regex, pysocks, pyparsing, pycparser, netaddr, lxml, jsonpointer, jmespath, isodate, invoke, idna, h11, decorator, click, charset_normalizer, certifi, bcrypt, attrs, wsproto, requests, python-dateutil, pyhocon, pyang, outcome, jsonpath-rw, jsonpatch, elastic-transport, docker-pycreds, cffi, beautifulsoup4, webtest, trio, robotframework-requests, pynacl, pyangbind, elasticsearch, docker-py, cryptography, trio-websocket, robotframework-httplibrary, paramiko, elasticsearch-dsl, selenium, scp, robotframework-sshlibrary, robotframework-seleniumlibrary, robotframework-selenium2library 02:08:50 02:08:50 Successfully installed WebOb-1.8.9 attrs-25.4.0 bcrypt-5.0.0 beautifulsoup4-4.14.3 certifi-2025.11.12 cffi-2.0.0 charset_normalizer-3.4.4 click-8.3.1 cryptography-46.0.3 decorator-5.2.1 docker-py-1.10.6 docker-pycreds-0.4.0 elastic-transport-8.17.1 elasticsearch-8.19.3 elasticsearch-dsl-8.15.4 enum34-1.1.10 h11-0.16.0 idna-3.11 invoke-2.2.1 ipaddr-2.2.0 isodate-0.7.2 jmespath-1.0.1 jsonpatch-1.33 jsonpath-rw-1.4.0 jsonpointer-3.0.0 lxml-6.0.2 netaddr-1.3.0 netifaces-0.11.0 outcome-1.3.0.post0 paramiko-4.0.0 ply-3.11 pyang-2.7.1 pyangbind-0.8.7 pycparser-2.23 pyhocon-0.3.61 pynacl-1.6.1 pyparsing-3.3.1 pysocks-1.7.1 python-dateutil-2.9.0.post0 regex-2025.11.3 requests-2.32.5 robotframework-7.4.1 robotframework-httplibrary-0.4.2 robotframework-pythonlibcore-4.4.1 robotframework-requests-0.9.7 robotframework-selenium2library-3.0.0 robotframework-seleniumlibrary-6.8.0 robotframework-sshlibrary-3.8.0 scapy-2.7.0 scp-0.15.0 selenium-4.39.0 six-1.17.0 sniffio-1.3.1 sortedcontainers-2.4.0 soupsieve-2.8.1 trio-0.32.0 trio-websocket-0.12.2 typing-extensions-4.15.0 urllib3-2.6.2 waitress-3.0.2 websocket-client-1.9.0 webtest-3.0.7 wsproto-1.3.2 02:08:50 + pip freeze 02:08:50 attrs==25.4.0 02:08:50 bcrypt==5.0.0 02:08:50 beautifulsoup4==4.14.3 02:08:50 certifi==2025.11.12 02:08:50 cffi==2.0.0 02:08:50 charset-normalizer==3.4.4 02:08:50 click==8.3.1 02:08:50 cryptography==46.0.3 02:08:50 decorator==5.2.1 02:08:50 distlib==0.4.0 02:08:50 docker-py==1.10.6 02:08:50 docker-pycreds==0.4.0 02:08:50 elastic-transport==8.17.1 02:08:50 elasticsearch==8.19.3 02:08:50 elasticsearch-dsl==8.15.4 02:08:50 enum34==1.1.10 02:08:50 filelock==3.20.1 02:08:50 h11==0.16.0 02:08:50 idna==3.11 02:08:50 invoke==2.2.1 02:08:50 ipaddr==2.2.0 02:08:50 isodate==0.7.2 02:08:50 jmespath==1.0.1 02:08:50 jsonpatch==1.33 02:08:50 jsonpath-rw==1.4.0 02:08:50 jsonpointer==3.0.0 02:08:50 lxml==6.0.2 02:08:50 netaddr==1.3.0 02:08:50 netifaces==0.11.0 02:08:50 outcome==1.3.0.post0 02:08:50 paramiko==4.0.0 02:08:50 platformdirs==4.5.1 02:08:50 ply==3.11 02:08:50 pyang==2.7.1 02:08:50 pyangbind==0.8.7 02:08:50 pycparser==2.23 02:08:50 pyhocon==0.3.61 02:08:50 PyNaCl==1.6.1 02:08:50 pyparsing==3.3.1 02:08:50 PySocks==1.7.1 02:08:50 python-dateutil==2.9.0.post0 02:08:50 regex==2025.11.3 02:08:50 requests==2.32.5 02:08:50 robotframework==7.4.1 02:08:50 robotframework-httplibrary==0.4.2 02:08:50 robotframework-pythonlibcore==4.4.1 02:08:50 robotframework-requests==0.9.7 02:08:50 robotframework-selenium2library==3.0.0 02:08:50 robotframework-seleniumlibrary==6.8.0 02:08:50 robotframework-sshlibrary==3.8.0 02:08:50 scapy==2.7.0 02:08:50 scp==0.15.0 02:08:50 selenium==4.39.0 02:08:50 six==1.17.0 02:08:50 sniffio==1.3.1 02:08:50 sortedcontainers==2.4.0 02:08:50 soupsieve==2.8.1 02:08:50 trio==0.32.0 02:08:50 trio-websocket==0.12.2 02:08:50 typing_extensions==4.15.0 02:08:50 urllib3==2.6.2 02:08:50 virtualenv==20.35.4 02:08:50 waitress==3.0.2 02:08:50 WebOb==1.8.9 02:08:50 websocket-client==1.9.0 02:08:50 WebTest==3.0.7 02:08:50 wsproto==1.3.2 02:08:50 [EnvInject] - Injecting environment variables from a build step. 02:08:50 [EnvInject] - Injecting as environment variables the properties file path 'env.properties' 02:08:50 [EnvInject] - Variables injected successfully. 02:08:50 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins8561011443748678771.sh 02:08:50 Setup pyenv: 02:08:51 system 02:08:51 3.8.13 02:08:51 3.9.13 02:08:51 3.10.13 02:08:51 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:08:51 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:08:51 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:08:51 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:08:53 lf-activate-venv(): INFO: Base packages installed successfully 02:08:53 lf-activate-venv(): INFO: Installing additional packages: python-heatclient python-openstackclient yq 02:09:00 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. 02:09:00 lftools 0.37.18 requires urllib3<2.1.0, but you have urllib3 2.6.2 which is incompatible. 02:09:00 kubernetes 34.1.0 requires urllib3<2.4.0,>=1.24.2, but you have urllib3 2.6.2 which is incompatible. 02:09:00 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:09:00 + ODL_SYSTEM=() 02:09:00 + TOOLS_SYSTEM=() 02:09:00 + OPENSTACK_SYSTEM=() 02:09:00 + OPENSTACK_CONTROLLERS=() 02:09:00 + mapfile -t ADDR 02:09:00 ++ openstack stack show -f json -c outputs releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:09:00 ++ jq -r '.outputs[] | select(.output_key | match("^vm_[0-9]+_ips$")) | .output_value | .[]' 02:09:02 + for i in "${ADDR[@]}" 02:09:02 ++ ssh 10.30.171.33 hostname -s 02:09:02 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:02 + REMHOST=releng-65281-493-0-builder-0 02:09:02 + case ${REMHOST} in 02:09:02 + ODL_SYSTEM=("${ODL_SYSTEM[@]}" "${i}") 02:09:02 + for i in "${ADDR[@]}" 02:09:02 ++ ssh 10.30.170.204 hostname -s 02:09:02 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:03 + REMHOST=releng-65281-493-0-builder-1 02:09:03 + case ${REMHOST} in 02:09:03 + ODL_SYSTEM=("${ODL_SYSTEM[@]}" "${i}") 02:09:03 + for i in "${ADDR[@]}" 02:09:03 ++ ssh 10.30.171.83 hostname -s 02:09:03 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:03 + REMHOST=releng-65281-493-0-builder-2 02:09:03 + case ${REMHOST} in 02:09:03 + ODL_SYSTEM=("${ODL_SYSTEM[@]}" "${i}") 02:09:03 + for i in "${ADDR[@]}" 02:09:03 ++ ssh 10.30.171.80 hostname -s 02:09:03 Warning: Permanently added '10.30.171.80' (ECDSA) to the list of known hosts. 02:09:03 + REMHOST=releng-65281-493-1-mininet-ovs-217-0 02:09:03 + case ${REMHOST} in 02:09:03 + TOOLS_SYSTEM=("${TOOLS_SYSTEM[@]}" "${i}") 02:09:03 + echo NUM_ODL_SYSTEM=3 02:09:03 + echo NUM_TOOLS_SYSTEM=1 02:09:03 + '[' '' == yes ']' 02:09:03 + NUM_OPENSTACK_SYSTEM=0 02:09:03 + echo NUM_OPENSTACK_SYSTEM=0 02:09:03 + '[' 0 -eq 2 ']' 02:09:03 + echo ODL_SYSTEM_IP=10.30.171.33 02:09:03 ++ seq 0 2 02:09:03 + for i in $(seq 0 $(( ${#ODL_SYSTEM[@]} - 1 ))) 02:09:03 + echo ODL_SYSTEM_1_IP=10.30.171.33 02:09:03 + for i in $(seq 0 $(( ${#ODL_SYSTEM[@]} - 1 ))) 02:09:03 + echo ODL_SYSTEM_2_IP=10.30.170.204 02:09:03 + for i in $(seq 0 $(( ${#ODL_SYSTEM[@]} - 1 ))) 02:09:03 + echo ODL_SYSTEM_3_IP=10.30.171.83 02:09:03 + echo TOOLS_SYSTEM_IP=10.30.171.80 02:09:03 ++ seq 0 0 02:09:03 + for i in $(seq 0 $(( ${#TOOLS_SYSTEM[@]} - 1 ))) 02:09:03 + echo TOOLS_SYSTEM_1_IP=10.30.171.80 02:09:03 + openstack_index=0 02:09:03 + NUM_OPENSTACK_CONTROL_NODES=1 02:09:03 + echo NUM_OPENSTACK_CONTROL_NODES=1 02:09:03 ++ seq 0 0 02:09:03 + for i in $(seq 0 $((NUM_OPENSTACK_CONTROL_NODES - 1))) 02:09:03 + echo OPENSTACK_CONTROL_NODE_1_IP= 02:09:03 + NUM_OPENSTACK_COMPUTE_NODES=-1 02:09:03 + echo NUM_OPENSTACK_COMPUTE_NODES=-1 02:09:03 + '[' -1 -ge 2 ']' 02:09:03 ++ seq 0 -2 02:09:03 + NUM_OPENSTACK_HAPROXY_NODES=0 02:09:03 + echo NUM_OPENSTACK_HAPROXY_NODES=0 02:09:03 ++ seq 0 -1 02:09:03 + echo 'Contents of slave_addresses.txt:' 02:09:03 Contents of slave_addresses.txt: 02:09:03 + cat slave_addresses.txt 02:09:03 NUM_ODL_SYSTEM=3 02:09:03 NUM_TOOLS_SYSTEM=1 02:09:03 NUM_OPENSTACK_SYSTEM=0 02:09:03 ODL_SYSTEM_IP=10.30.171.33 02:09:03 ODL_SYSTEM_1_IP=10.30.171.33 02:09:03 ODL_SYSTEM_2_IP=10.30.170.204 02:09:03 ODL_SYSTEM_3_IP=10.30.171.83 02:09:03 TOOLS_SYSTEM_IP=10.30.171.80 02:09:03 TOOLS_SYSTEM_1_IP=10.30.171.80 02:09:03 NUM_OPENSTACK_CONTROL_NODES=1 02:09:03 OPENSTACK_CONTROL_NODE_1_IP= 02:09:03 NUM_OPENSTACK_COMPUTE_NODES=-1 02:09:03 NUM_OPENSTACK_HAPROXY_NODES=0 02:09:03 [EnvInject] - Injecting environment variables from a build step. 02:09:03 [EnvInject] - Injecting as environment variables the properties file path 'slave_addresses.txt' 02:09:03 [EnvInject] - Variables injected successfully. 02:09:03 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/sh /tmp/jenkins11009944797071093091.sh 02:09:03 Preparing for JRE Version 21 02:09:03 Karaf artifact is karaf 02:09:03 Karaf project is integration 02:09:03 Java home is /usr/lib/jvm/java-21-openjdk-amd64 02:09:03 [EnvInject] - Injecting environment variables from a build step. 02:09:03 [EnvInject] - Injecting as environment variables the properties file path 'set_variables.env' 02:09:03 [EnvInject] - Variables injected successfully. 02:09:03 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins10387944158459063555.sh 02:09:03 Distribution bundle URL is https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:03 Distribution bundle is karaf-0.21.4.zip 02:09:03 Distribution bundle version is 0.21.4 02:09:03 Distribution folder is karaf-0.21.4 02:09:03 Nexus prefix is https://nexus.opendaylight.org 02:09:03 [EnvInject] - Injecting environment variables from a build step. 02:09:03 [EnvInject] - Injecting as environment variables the properties file path 'detect_variables.env' 02:09:03 [EnvInject] - Variables injected successfully. 02:09:04 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins17527349204455647884.sh 02:09:04 Setup pyenv: 02:09:04 system 02:09:04 3.8.13 02:09:04 3.9.13 02:09:04 3.10.13 02:09:04 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:09:04 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:09:04 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:09:04 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:09: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. 02:09:06 lftools 0.37.18 requires urllib3<2.1.0, but you have urllib3 2.6.2 which is incompatible. 02:09:06 lf-activate-venv(): INFO: Base packages installed successfully 02:09:06 lf-activate-venv(): INFO: Installing additional packages: python-heatclient python-openstackclient 02:09:12 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. 02:09:12 lftools 0.37.18 requires urllib3<2.1.0, but you have urllib3 2.6.2 which is incompatible. 02:09:12 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:09:12 Copying common-functions.sh to /tmp 02:09:14 Copying common-functions.sh to 10.30.171.33:/tmp 02:09:14 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:14 Copying common-functions.sh to 10.30.170.204:/tmp 02:09:14 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:15 Copying common-functions.sh to 10.30.171.83:/tmp 02:09:15 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:16 Copying common-functions.sh to 10.30.171.80:/tmp 02:09:16 Warning: Permanently added '10.30.171.80' (ECDSA) to the list of known hosts. 02:09:16 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins4808871456871657819.sh 02:09:16 common-functions.sh is being sourced 02:09:16 common-functions environment: 02:09:16 MAVENCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:16 ACTUALFEATURES: 02:09:16 FEATURESCONF: /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:16 CUSTOMPROP: /tmp/karaf-0.21.4/etc/custom.properties 02:09:16 LOGCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:16 MEMCONF: /tmp/karaf-0.21.4/bin/setenv 02:09:16 CONTROLLERMEM: 2048m 02:09:16 AKKACONF: /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:16 MODULESCONF: /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:16 MODULESHARDSCONF: /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:16 SUITES: 02:09:16 02:09:16 ################################################# 02:09:16 ## Configure Cluster and Start ## 02:09:16 ################################################# 02:09:16 ACTUALFEATURES: odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest 02:09:16 SPACE_SEPARATED_FEATURES: odl-infrautils-ready odl-jolokia odl-ovsdb-southbound-impl-rest 02:09:16 Locating script plan to use... 02:09:16 Finished running script plans 02:09:16 Configuring member-1 with IP address 10.30.171.33 02:09:16 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:16 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:16 + source /tmp/common-functions.sh karaf-0.21.4 scandium 02:09:16 common-functions.sh is being sourced 02:09:16 ++ [[ /tmp/common-functions.sh == \/\t\m\p\/\c\o\n\f\i\g\u\r\a\t\i\o\n\-\s\c\r\i\p\t\.\s\h ]] 02:09:16 ++ echo 'common-functions.sh is being sourced' 02:09:16 ++ BUNDLEFOLDER=karaf-0.21.4 02:09:16 ++ DISTROSTREAM=scandium 02:09:16 ++ export MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:16 ++ MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:16 ++ export FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:16 ++ FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:16 ++ export CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:16 ++ CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:16 ++ export LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:16 ++ LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:16 ++ export MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:16 ++ MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:16 ++ export CONTROLLERMEM= 02:09:16 ++ CONTROLLERMEM= 02:09:16 ++ case "${DISTROSTREAM}" in 02:09:16 ++ CLUSTER_SYSTEM=akka 02:09:16 ++ export AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:16 ++ AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:16 ++ export MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:16 ++ MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:16 ++ export MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:16 ++ MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:16 ++ print_common_env 02:09:16 ++ cat 02:09:16 common-functions environment: 02:09:16 MAVENCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:16 ACTUALFEATURES: 02:09:16 FEATURESCONF: /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:16 CUSTOMPROP: /tmp/karaf-0.21.4/etc/custom.properties 02:09:16 LOGCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:16 MEMCONF: /tmp/karaf-0.21.4/bin/setenv 02:09:16 CONTROLLERMEM: 02:09:16 AKKACONF: /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:16 MODULESCONF: /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:16 MODULESHARDSCONF: /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:16 SUITES: 02:09:16 02:09:16 ++ SSH='ssh -t -t' 02:09:16 ++ extra_services_cntl=' dnsmasq.service httpd.service libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service rabbitmq-server.service ' 02:09:16 ++ extra_services_cmp=' libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service ' 02:09:16 Changing to /tmp 02:09:16 Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:16 + echo 'Changing to /tmp' 02:09:16 + cd /tmp 02:09:16 + echo 'Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip' 02:09:16 + wget --progress=dot:mega https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:16 --2025-12-30 02:09:16-- https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:16 Resolving nexus.opendaylight.org (nexus.opendaylight.org)... 199.204.45.87, 2604:e100:1:0:f816:3eff:fe45:48d6 02:09:16 Connecting to nexus.opendaylight.org (nexus.opendaylight.org)|199.204.45.87|:443... connected. 02:09:16 HTTP request sent, awaiting response... 200 OK 02:09:16 Length: 239704812 (229M) [application/zip] 02:09:16 Saving to: ‘karaf-0.21.4.zip’ 02:09:16 02:09:16 0K ........ ........ ........ ........ ........ ........ 1% 74.5M 3s 02:09:16 3072K ........ ........ ........ ........ ........ ........ 2% 141M 2s 02:09:16 6144K ........ ........ ........ ........ ........ ........ 3% 137M 2s 02:09:16 9216K ........ ........ ........ ........ ........ ........ 5% 164M 2s 02:09:16 12288K ........ ........ ........ ........ ........ ........ 6% 211M 2s 02:09:16 15360K ........ ........ ........ ........ ........ ........ 7% 169M 2s 02:09:16 18432K ........ ........ ........ ........ ........ ........ 9% 252M 1s 02:09:16 21504K ........ ........ ........ ........ ........ ........ 10% 216M 1s 02:09:16 24576K ........ ........ ........ ........ ........ ........ 11% 251M 1s 02:09:16 27648K ........ ........ ........ ........ ........ ........ 13% 270M 1s 02:09:17 30720K ........ ........ ........ ........ ........ ........ 14% 278M 1s 02:09:17 33792K ........ ........ ........ ........ ........ ........ 15% 283M 1s 02:09:17 36864K ........ ........ ........ ........ ........ ........ 17% 321M 1s 02:09:17 39936K ........ ........ ........ ........ ........ ........ 18% 254M 1s 02:09:17 43008K ........ ........ ........ ........ ........ ........ 19% 295M 1s 02:09:17 46080K ........ ........ ........ ........ ........ ........ 20% 351M 1s 02:09:17 49152K ........ ........ ........ ........ ........ ........ 22% 355M 1s 02:09:17 52224K ........ ........ ........ ........ ........ ........ 23% 352M 1s 02:09:17 55296K ........ ........ ........ ........ ........ ........ 24% 291M 1s 02:09:17 58368K ........ ........ ........ ........ ........ ........ 26% 266M 1s 02:09:17 61440K ........ ........ ........ ........ ........ ........ 27% 335M 1s 02:09:17 64512K ........ ........ ........ ........ ........ ........ 28% 350M 1s 02:09:17 67584K ........ ........ ........ ........ ........ ........ 30% 354M 1s 02:09:17 70656K ........ ........ ........ ........ ........ ........ 31% 355M 1s 02:09:17 73728K ........ ........ ........ ........ ........ ........ 32% 344M 1s 02:09:17 76800K ........ ........ ........ ........ ........ ........ 34% 343M 1s 02:09:17 79872K ........ ........ ........ ........ ........ ........ 35% 349M 1s 02:09:17 82944K ........ ........ ........ ........ ........ ........ 36% 354M 1s 02:09:17 86016K ........ ........ ........ ........ ........ ........ 38% 342M 1s 02:09:17 89088K ........ ........ ........ ........ ........ ........ 39% 353M 1s 02:09:17 92160K ........ ........ ........ ........ ........ ........ 40% 343M 1s 02:09:17 95232K ........ ........ ........ ........ ........ ........ 41% 334M 1s 02:09:17 98304K ........ ........ ........ ........ ........ ........ 43% 352M 1s 02:09:17 101376K ........ ........ ........ ........ ........ ........ 44% 342M 1s 02:09:17 104448K ........ ........ ........ ........ ........ ........ 45% 345M 0s 02:09:17 107520K ........ ........ ........ ........ ........ ........ 47% 354M 0s 02:09:17 110592K ........ ........ ........ ........ ........ ........ 48% 339M 0s 02:09:17 113664K ........ ........ ........ ........ ........ ........ 49% 343M 0s 02:09:17 116736K ........ ........ ........ ........ ........ ........ 51% 316M 0s 02:09:17 119808K ........ ........ ........ ........ ........ ........ 52% 334M 0s 02:09:17 122880K ........ ........ ........ ........ ........ ........ 53% 336M 0s 02:09:17 125952K ........ ........ ........ ........ ........ ........ 55% 351M 0s 02:09:17 129024K ........ ........ ........ ........ ........ ........ 56% 339M 0s 02:09:17 132096K ........ ........ ........ ........ ........ ........ 57% 339M 0s 02:09:17 135168K ........ ........ ........ ........ ........ ........ 59% 343M 0s 02:09:17 138240K ........ ........ ........ ........ ........ ........ 60% 340M 0s 02:09:17 141312K ........ ........ ........ ........ ........ ........ 61% 346M 0s 02:09:17 144384K ........ ........ ........ ........ ........ ........ 62% 345M 0s 02:09:17 147456K ........ ........ ........ ........ ........ ........ 64% 336M 0s 02:09:17 150528K ........ ........ ........ ........ ........ ........ 65% 328M 0s 02:09:17 153600K ........ ........ ........ ........ ........ ........ 66% 374M 0s 02:09:17 156672K ........ ........ ........ ........ ........ ........ 68% 397M 0s 02:09:17 159744K ........ ........ ........ ........ ........ ........ 69% 393M 0s 02:09:17 162816K ........ ........ ........ ........ ........ ........ 70% 412M 0s 02:09:17 165888K ........ ........ ........ ........ ........ ........ 72% 211M 0s 02:09:17 168960K ........ ........ ........ ........ ........ ........ 73% 299M 0s 02:09:17 172032K ........ ........ ........ ........ ........ ........ 74% 345M 0s 02:09:17 175104K ........ ........ ........ ........ ........ ........ 76% 409M 0s 02:09:17 178176K ........ ........ ........ ........ ........ ........ 77% 408M 0s 02:09:17 181248K ........ ........ ........ ........ ........ ........ 78% 394M 0s 02:09:17 184320K ........ ........ ........ ........ ........ ........ 80% 393M 0s 02:09:17 187392K ........ ........ ........ ........ ........ ........ 81% 350M 0s 02:09:17 190464K ........ ........ ........ ........ ........ ........ 82% 272M 0s 02:09:17 193536K ........ ........ ........ ........ ........ ........ 83% 331M 0s 02:09:17 196608K ........ ........ ........ ........ ........ ........ 85% 319M 0s 02:09:17 199680K ........ ........ ........ ........ ........ ........ 86% 382M 0s 02:09:17 202752K ........ ........ ........ ........ ........ ........ 87% 386M 0s 02:09:17 205824K ........ ........ ........ ........ ........ ........ 89% 387M 0s 02:09:17 208896K ........ ........ ........ ........ ........ ........ 90% 383M 0s 02:09:17 211968K ........ ........ ........ ........ ........ ........ 91% 381M 0s 02:09:17 215040K ........ ........ ........ ........ ........ ........ 93% 341M 0s 02:09:17 218112K ........ ........ ........ ........ ........ ........ 94% 72.4M 0s 02:09:17 221184K ........ ........ ........ ........ ........ ........ 95% 151M 0s 02:09:17 224256K ........ ........ ........ ........ ........ ........ 97% 252M 0s 02:09:17 227328K ........ ........ ........ ........ ........ ........ 98% 499M 0s 02:09:17 230400K ........ ........ ........ ........ ........ ........ 99% 324M 0s 02:09:17 233472K ........ . 100% 237M=0.8s 02:09:17 02:09:17 2025-12-30 02:09:17 (280 MB/s) - ‘karaf-0.21.4.zip’ saved [239704812/239704812] 02:09:17 02:09:17 Extracting the new controller... 02:09:17 + echo 'Extracting the new controller...' 02:09:17 + unzip -q karaf-0.21.4.zip 02:09:19 Adding external repositories... 02:09:19 + echo 'Adding external repositories...' 02:09:19 + sed -ie 's%org.ops4j.pax.url.mvn.repositories=%org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases%g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:19 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:19 ################################################################################ 02:09:19 # 02:09:19 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:19 # contributor license agreements. See the NOTICE file distributed with 02:09:19 # this work for additional information regarding copyright ownership. 02:09:19 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:19 # (the "License"); you may not use this file except in compliance with 02:09:19 # the License. You may obtain a copy of the License at 02:09:19 # 02:09:19 # http://www.apache.org/licenses/LICENSE-2.0 02:09:19 # 02:09:19 # Unless required by applicable law or agreed to in writing, software 02:09:19 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:19 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:19 # See the License for the specific language governing permissions and 02:09:19 # limitations under the License. 02:09:19 # 02:09:19 ################################################################################ 02:09:19 02:09:19 # 02:09:19 # If set to true, the following property will not allow any certificate to be used 02:09:19 # when accessing Maven repositories through SSL 02:09:19 # 02:09:19 #org.ops4j.pax.url.mvn.certificateCheck= 02:09:19 02:09:19 # 02:09:19 # Path to the local Maven settings file. 02:09:19 # The repositories defined in this file will be automatically added to the list 02:09:19 # of default repositories if the 'org.ops4j.pax.url.mvn.repositories' property 02:09:19 # below is not set. 02:09:19 # The following locations are checked for the existence of the settings.xml file 02:09:19 # * 1. looks for the specified url 02:09:19 # * 2. if not found looks for ${user.home}/.m2/settings.xml 02:09:19 # * 3. if not found looks for ${maven.home}/conf/settings.xml 02:09:19 # * 4. if not found looks for ${M2_HOME}/conf/settings.xml 02:09:19 # 02:09:19 #org.ops4j.pax.url.mvn.settings= 02:09:19 02:09:19 # 02:09:19 # Path to the local Maven repository which is used to avoid downloading 02:09:19 # artifacts when they already exist locally. 02:09:19 # The value of this property will be extracted from the settings.xml file 02:09:19 # above, or defaulted to: 02:09:19 # System.getProperty( "user.home" ) + "/.m2/repository" 02:09:19 # 02:09:19 org.ops4j.pax.url.mvn.localRepository=${karaf.home}/${karaf.default.repository} 02:09:19 02:09:19 # 02:09:19 # Default this to false. It's just weird to use undocumented repos 02:09:19 # 02:09:19 org.ops4j.pax.url.mvn.useFallbackRepositories=false 02:09:19 02:09:19 # 02:09:19 # Uncomment if you don't wanna use the proxy settings 02:09:19 # from the Maven conf/settings.xml file 02:09:19 # 02:09:19 # org.ops4j.pax.url.mvn.proxySupport=false 02:09:19 02:09:19 # 02:09:19 # Comma separated list of repositories scanned when resolving an artifact. 02:09:19 # Those repositories will be checked before iterating through the 02:09:19 # below list of repositories and even before the local repository 02:09:19 # A repository url can be appended with zero or more of the following flags: 02:09:19 # @snapshots : the repository contains snaphots 02:09:19 # @noreleases : the repository does not contain any released artifacts 02:09:19 # 02:09:19 # The following property value will add the system folder as a repo. 02:09:19 # 02:09:19 org.ops4j.pax.url.mvn.defaultRepositories=\ 02:09:19 file:${karaf.home}/${karaf.default.repository}@id=system.repository@snapshots,\ 02:09:19 file:${karaf.data}/kar@id=kar.repository@multi@snapshots,\ 02:09:19 file:${karaf.base}/${karaf.default.repository}@id=child.system.repository@snapshots 02:09:19 02:09:19 # Use the default local repo (e.g.~/.m2/repository) as a "remote" repo 02:09:19 #org.ops4j.pax.url.mvn.defaultLocalRepoAsRemote=false 02:09:19 02:09:19 # 02:09:19 # Comma separated list of repositories scanned when resolving an artifact. 02:09:19 # The default list includes the following repositories: 02:09:19 # http://repo1.maven.org/maven2@id=central 02:09:19 # http://repository.springsource.com/maven/bundles/release@id=spring.ebr 02:09:19 # http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external 02:09:19 # http://zodiac.springsource.com/maven/bundles/release@id=gemini 02:09:19 # http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases 02:09:19 # https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases 02:09:19 # https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:19 # To add repositories to the default ones, prepend '+' to the list of repositories 02:09:19 # to add. 02:09:19 # A repository url can be appended with zero or more of the following flags: 02:09:19 # @snapshots : the repository contains snapshots 02:09:19 # @noreleases : the repository does not contain any released artifacts 02:09:19 # @id=repository.id : the id for the repository, just like in the settings.xml this is optional but recommended 02:09:19 # 02:09:19 org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:19 02:09:19 ### ^^^ No remote repositories. This is the only ODL change compared to Karaf defaults.Configuring the startup features... 02:09:19 + [[ True == \T\r\u\e ]] 02:09:19 + echo 'Configuring the startup features...' 02:09:19 + sed -ie 's/\(featuresBoot=\|featuresBoot =\)/featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest,/g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:19 + FEATURE_TEST_STRING=features-test 02:09:19 + FEATURE_TEST_VERSION=0.21.4 02:09:19 + KARAF_VERSION=karaf4 02:09:19 + [[ integration == \i\n\t\e\g\r\a\t\i\o\n ]] 02:09:19 + sed -ie 's%\(featuresRepositories=\|featuresRepositories =\)%featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features,%g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:19 + [[ ! -z '' ]] 02:09:19 + cat /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:19 ################################################################################ 02:09:19 # 02:09:19 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:19 # contributor license agreements. See the NOTICE file distributed with 02:09:19 # this work for additional information regarding copyright ownership. 02:09:19 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:19 # (the "License"); you may not use this file except in compliance with 02:09:19 # the License. You may obtain a copy of the License at 02:09:19 # 02:09:19 # http://www.apache.org/licenses/LICENSE-2.0 02:09:19 # 02:09:19 # Unless required by applicable law or agreed to in writing, software 02:09:19 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:19 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:19 # See the License for the specific language governing permissions and 02:09:19 # limitations under the License. 02:09:19 # 02:09:19 ################################################################################ 02:09:19 02:09:19 # 02:09:19 # Comma separated list of features repositories to register by default 02:09:19 # 02:09:19 featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features, file:${karaf.etc}/36abfd67-5c11-488f-909b-8f87618e3936.xml 02:09:19 02:09:19 # 02:09:19 # Comma separated list of features to install at startup 02:09:19 # 02:09:19 featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest, 57452d0e-67df-43b2-8cae-b9409b045dc0 02:09:19 02:09:19 # 02:09:19 # Resource repositories (OBR) that the features resolver can use 02:09:19 # to resolve requirements/capabilities 02:09:19 # 02:09:19 # The format of the resourceRepositories is 02:09:19 # resourceRepositories=[xml:url|json:url],... 02:09:19 # for Instance: 02:09:19 # 02:09:19 #resourceRepositories=xml:http://host/path/to/index.xml 02:09:19 # or 02:09:19 #resourceRepositories=json:http://host/path/to/index.json 02:09:19 # 02:09:19 02:09:19 # 02:09:19 # Defines if the boot features are started in asynchronous mode (in a dedicated thread) 02:09:19 # 02:09:19 featuresBootAsynchronous=false 02:09:19 02:09:19 # 02:09:19 # Service requirements enforcement 02:09:19 # 02:09:19 # By default, the feature resolver checks the service requirements/capabilities of 02:09:19 # bundles for new features (xml schema >= 1.3.0) in order to automatically installs 02:09:19 # the required bundles. 02:09:19 # The following flag can have those values: 02:09:19 # - disable: service requirements are completely ignored 02:09:19 # - default: service requirements are ignored for old features 02:09:19 # - enforce: service requirements are always verified 02:09:19 # 02:09:19 #serviceRequirements=default 02:09:19 02:09:19 # 02:09:19 # Store cfg file for config element in feature 02:09:19 # 02:09:19 #configCfgStore=true 02:09:19 02:09:19 # 02:09:19 # Define if the feature service automatically refresh bundles 02:09:19 # 02:09:19 autoRefresh=true 02:09:19 02:09:19 # 02:09:19 # Configuration of features processing mechanism (overrides, blacklisting, modification of features) 02:09:19 # XML file defines instructions related to features processing 02:09:19 # versions.properties may declare properties to resolve placeholders in XML file 02:09:19 # both files are relative to ${karaf.etc} 02:09:19 # 02:09:19 #featureProcessing=org.apache.karaf.features.xml 02:09:19 #featureProcessingVersions=versions.properties 02:09:19 + configure_karaf_log karaf4 '' 02:09:19 + local -r karaf_version=karaf4 02:09:19 + local -r controllerdebugmap= 02:09:19 + local logapi=log4j 02:09:19 + grep log4j2 /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:19 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:19 log4j2.rootLogger.level = INFO 02:09:19 #log4j2.rootLogger.type = asyncRoot 02:09:19 #log4j2.rootLogger.includeLocation = false 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:19 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:19 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:19 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:19 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:19 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:19 log4j2.logger.spifly.level = WARN 02:09:19 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:19 log4j2.logger.audit.level = INFO 02:09:19 log4j2.logger.audit.additivity = false 02:09:19 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:19 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:19 log4j2.appender.console.type = Console 02:09:19 log4j2.appender.console.name = Console 02:09:19 log4j2.appender.console.layout.type = PatternLayout 02:09:19 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:19 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:19 log4j2.appender.rolling.name = RollingFile 02:09:19 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:19 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:19 #log4j2.appender.rolling.immediateFlush = false 02:09:19 log4j2.appender.rolling.append = true 02:09:19 log4j2.appender.rolling.layout.type = PatternLayout 02:09:19 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:19 log4j2.appender.rolling.policies.type = Policies 02:09:19 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:19 log4j2.appender.rolling.policies.size.size = 64MB 02:09:19 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:19 log4j2.appender.rolling.strategy.max = 7 02:09:19 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:19 log4j2.appender.audit.name = AuditRollingFile 02:09:19 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:19 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:19 log4j2.appender.audit.append = true 02:09:19 log4j2.appender.audit.layout.type = PatternLayout 02:09:19 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:19 log4j2.appender.audit.policies.type = Policies 02:09:19 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:19 log4j2.appender.audit.policies.size.size = 8MB 02:09:19 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:19 log4j2.appender.audit.strategy.max = 7 02:09:19 log4j2.appender.osgi.type = PaxOsgi 02:09:19 log4j2.appender.osgi.name = PaxOsgi 02:09:19 log4j2.appender.osgi.filter = * 02:09:19 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:19 #log4j2.logger.aether.level = TRACE 02:09:19 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:19 #log4j2.logger.http-headers.level = DEBUG 02:09:19 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:19 #log4j2.logger.maven.level = TRACE 02:09:19 Configuring the karaf log... karaf_version: karaf4, logapi: log4j2 02:09:19 + logapi=log4j2 02:09:19 + echo 'Configuring the karaf log... karaf_version: karaf4, logapi: log4j2' 02:09:19 + '[' log4j2 == log4j2 ']' 02:09:19 + sed -ie 's/log4j2.appender.rolling.policies.size.size = 64MB/log4j2.appender.rolling.policies.size.size = 1GB/g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:19 + orgmodule=org.opendaylight.yangtools.yang.parser.repo.YangTextSchemaContextResolver 02:09:19 + orgmodule_=org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver 02:09:19 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN' 02:09:19 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN' 02:09:19 controllerdebugmap: 02:09:19 + unset IFS 02:09:19 + echo 'controllerdebugmap: ' 02:09:19 cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:19 + '[' -n '' ']' 02:09:19 + echo 'cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg' 02:09:19 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:19 ################################################################################ 02:09:19 # 02:09:19 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:19 # contributor license agreements. See the NOTICE file distributed with 02:09:19 # this work for additional information regarding copyright ownership. 02:09:19 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:19 # (the "License"); you may not use this file except in compliance with 02:09:19 # the License. You may obtain a copy of the License at 02:09:19 # 02:09:19 # http://www.apache.org/licenses/LICENSE-2.0 02:09:19 # 02:09:19 # Unless required by applicable law or agreed to in writing, software 02:09:19 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:19 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:19 # See the License for the specific language governing permissions and 02:09:19 # limitations under the License. 02:09:19 # 02:09:19 ################################################################################ 02:09:19 02:09:19 # Common pattern layout for appenders 02:09:19 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:19 02:09:19 # Root logger 02:09:19 log4j2.rootLogger.level = INFO 02:09:19 # uncomment to use asynchronous loggers, which require mvn:com.lmax/disruptor/3.3.2 library 02:09:19 #log4j2.rootLogger.type = asyncRoot 02:09:19 #log4j2.rootLogger.includeLocation = false 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:19 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:19 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:19 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:19 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:19 02:09:19 # Filters for logs marked by org.opendaylight.odlparent.Markers 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:19 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:19 02:09:19 # Loggers configuration 02:09:19 02:09:19 # Spifly logger 02:09:19 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:19 log4j2.logger.spifly.level = WARN 02:09:19 02:09:19 # Security audit logger 02:09:19 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:19 log4j2.logger.audit.level = INFO 02:09:19 log4j2.logger.audit.additivity = false 02:09:19 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:19 02:09:19 # Appenders configuration 02:09:19 02:09:19 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:19 log4j2.appender.console.type = Console 02:09:19 log4j2.appender.console.name = Console 02:09:19 log4j2.appender.console.layout.type = PatternLayout 02:09:19 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:19 02:09:19 # Rolling file appender 02:09:19 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:19 log4j2.appender.rolling.name = RollingFile 02:09:19 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:19 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:19 # uncomment to not force a disk flush 02:09:19 #log4j2.appender.rolling.immediateFlush = false 02:09:19 log4j2.appender.rolling.append = true 02:09:19 log4j2.appender.rolling.layout.type = PatternLayout 02:09:19 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:19 log4j2.appender.rolling.policies.type = Policies 02:09:19 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:19 log4j2.appender.rolling.policies.size.size = 1GB 02:09:19 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:19 log4j2.appender.rolling.strategy.max = 7 02:09:19 02:09:19 # Audit file appender 02:09:19 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:19 log4j2.appender.audit.name = AuditRollingFile 02:09:19 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:19 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:19 log4j2.appender.audit.append = true 02:09:19 log4j2.appender.audit.layout.type = PatternLayout 02:09:19 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:19 log4j2.appender.audit.policies.type = Policies 02:09:19 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:19 log4j2.appender.audit.policies.size.size = 8MB 02:09:19 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:19 log4j2.appender.audit.strategy.max = 7 02:09:19 02:09:19 # OSGi appender 02:09:19 log4j2.appender.osgi.type = PaxOsgi 02:09:19 log4j2.appender.osgi.name = PaxOsgi 02:09:19 log4j2.appender.osgi.filter = * 02:09:19 02:09:19 # help with identification of maven-related problems with pax-url-aether 02:09:19 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:19 #log4j2.logger.aether.level = TRACE 02:09:19 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:19 #log4j2.logger.http-headers.level = DEBUG 02:09:19 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:19 #log4j2.logger.maven.level = TRACE 02:09:19 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN 02:09:19 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN 02:09:19 + set_java_vars /usr/lib/jvm/java-21-openjdk-amd64 2048m /tmp/karaf-0.21.4/bin/setenv 02:09:19 + local -r java_home=/usr/lib/jvm/java-21-openjdk-amd64 02:09:19 + local -r controllermem=2048m 02:09:19 + local -r memconf=/tmp/karaf-0.21.4/bin/setenv 02:09:19 Configure 02:09:19 java home: /usr/lib/jvm/java-21-openjdk-amd64 02:09:19 max memory: 2048m 02:09:19 memconf: /tmp/karaf-0.21.4/bin/setenv 02:09:19 + echo Configure 02:09:19 + echo ' java home: /usr/lib/jvm/java-21-openjdk-amd64' 02:09:19 + echo ' max memory: 2048m' 02:09:19 + echo ' memconf: /tmp/karaf-0.21.4/bin/setenv' 02:09:19 + sed -ie 's%^# export JAVA_HOME%export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64}%g' /tmp/karaf-0.21.4/bin/setenv 02:09:19 + sed -ie 's/JAVA_MAX_MEM="2048m"/JAVA_MAX_MEM=2048m/g' /tmp/karaf-0.21.4/bin/setenv 02:09:19 cat /tmp/karaf-0.21.4/bin/setenv 02:09:19 + echo 'cat /tmp/karaf-0.21.4/bin/setenv' 02:09:19 + cat /tmp/karaf-0.21.4/bin/setenv 02:09:19 #!/bin/sh 02:09:19 # 02:09:19 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:19 # contributor license agreements. See the NOTICE file distributed with 02:09:19 # this work for additional information regarding copyright ownership. 02:09:19 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:19 # (the "License"); you may not use this file except in compliance with 02:09:19 # the License. You may obtain a copy of the License at 02:09:19 # 02:09:19 # http://www.apache.org/licenses/LICENSE-2.0 02:09:19 # 02:09:19 # Unless required by applicable law or agreed to in writing, software 02:09:19 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:19 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:19 # See the License for the specific language governing permissions and 02:09:19 # limitations under the License. 02:09:19 # 02:09:19 02:09:19 # 02:09:19 # handle specific scripts; the SCRIPT_NAME is exactly the name of the Karaf 02:09:19 # script: client, instance, shell, start, status, stop, karaf 02:09:19 # 02:09:19 # if [ "${KARAF_SCRIPT}" == "SCRIPT_NAME" ]; then 02:09:19 # Actions go here... 02:09:19 # fi 02:09:19 02:09:19 # 02:09:19 # general settings which should be applied for all scripts go here; please keep 02:09:19 # in mind that it is possible that scripts might be executed more than once, e.g. 02:09:19 # in example of the start script where the start script is executed first and the 02:09:19 # karaf script afterwards. 02:09:19 # 02:09:19 02:09:19 # 02:09:19 # The following section shows the possible configuration options for the default 02:09:19 # karaf scripts 02:09:19 # 02:09:19 export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64} # Location of Java installation 02:09:19 # export JAVA_OPTS # Generic JVM options, for instance, where you can pass the memory configuration 02:09:19 # export JAVA_NON_DEBUG_OPTS # Additional non-debug JVM options 02:09:19 # export EXTRA_JAVA_OPTS # Additional JVM options 02:09:19 # export KARAF_HOME # Karaf home folder 02:09:19 # export KARAF_DATA # Karaf data folder 02:09:19 # export KARAF_BASE # Karaf base folder 02:09:19 # export KARAF_ETC # Karaf etc folder 02:09:19 # export KARAF_LOG # Karaf log folder 02:09:19 # export KARAF_SYSTEM_OPTS # First citizen Karaf options 02:09:19 # export KARAF_OPTS # Additional available Karaf options 02:09:19 # export KARAF_DEBUG # Enable debug mode 02:09:19 # export KARAF_REDIRECT # Enable/set the std/err redirection when using bin/start 02:09:19 # export KARAF_NOROOT # Prevent execution as root if set to true 02:09:19 Set Java version 02:09:19 + echo 'Set Java version' 02:09:19 + sudo /usr/sbin/alternatives --install /usr/bin/java java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 1 02:09:19 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:19 sudo: a password is required 02:09:19 + sudo /usr/sbin/alternatives --set java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:19 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:19 sudo: a password is required 02:09:19 JDK default version ... 02:09:19 + echo 'JDK default version ...' 02:09:19 + java -version 02:09:19 openjdk version "21.0.9" 2025-10-21 02:09:19 OpenJDK Runtime Environment (build 21.0.9+10-Ubuntu-122.04) 02:09:19 OpenJDK 64-Bit Server VM (build 21.0.9+10-Ubuntu-122.04, mixed mode, sharing) 02:09:19 Set JAVA_HOME 02:09:19 + echo 'Set JAVA_HOME' 02:09:19 + export JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:19 + JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:19 ++ readlink -e /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:19 Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:19 Listing all open ports on controller system... 02:09:19 + JAVA_RESOLVED=/usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:19 + echo 'Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java' 02:09:19 + echo 'Listing all open ports on controller system...' 02:09:19 + netstat -pnatu 02:09:19 /tmp/configuration-script.sh: line 40: netstat: command not found 02:09:19 Configuring cluster 02:09:19 + '[' -f /tmp/custom_shard_config.txt ']' 02:09:19 + echo 'Configuring cluster' 02:09:19 + /tmp/karaf-0.21.4/bin/configure_cluster.sh 1 10.30.171.33 10.30.170.204 10.30.171.83 02:09:19 ################################################ 02:09:19 ## Configure Cluster ## 02:09:19 ################################################ 02:09:19 NOTE: Cluster configuration files not found. Copying from 02:09:19 /tmp/karaf-0.21.4/system/org/opendaylight/controller/sal-clustering-config/10.0.14 02:09:20 Configuring unique name in akka.conf 02:09:20 Configuring hostname in akka.conf 02:09:20 Configuring data and rpc seed nodes in akka.conf 02:09:20 modules = [ 02:09:20 02:09:20 { 02:09:20 name = "inventory" 02:09:20 namespace = "urn:opendaylight:inventory" 02:09:20 shard-strategy = "module" 02:09:20 }, 02:09:20 { 02:09:20 name = "topology" 02:09:20 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:20 shard-strategy = "module" 02:09:20 }, 02:09:20 { 02:09:20 name = "toaster" 02:09:20 namespace = "http://netconfcentral.org/ns/toaster" 02:09:20 shard-strategy = "module" 02:09:20 } 02:09:20 ] 02:09:20 Configuring replication type in module-shards.conf 02:09:20 ################################################ 02:09:20 ## NOTE: Manually restart controller to ## 02:09:20 ## apply configuration. ## 02:09:20 ################################################ 02:09:20 Dump akka.conf 02:09:20 + echo 'Dump akka.conf' 02:09:20 + cat /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:20 02:09:20 odl-cluster-data { 02:09:20 akka { 02:09:20 remote { 02:09:20 artery { 02:09:20 enabled = on 02:09:20 transport = tcp 02:09:20 canonical.hostname = "10.30.171.33" 02:09:20 canonical.port = 2550 02:09:20 } 02:09:20 } 02:09:20 02:09:20 cluster { 02:09:20 # Using artery. 02:09:20 seed-nodes = ["akka://opendaylight-cluster-data@10.30.171.33:2550", 02:09:20 "akka://opendaylight-cluster-data@10.30.170.204:2550", 02:09:20 "akka://opendaylight-cluster-data@10.30.171.83:2550"] 02:09:20 02:09:20 roles = ["member-1"] 02:09:20 02:09:20 # when under load we might trip a false positive on the failure detector 02:09:20 # failure-detector { 02:09:20 # heartbeat-interval = 4 s 02:09:20 # acceptable-heartbeat-pause = 16s 02:09:20 # } 02:09:20 } 02:09:20 02:09:20 persistence { 02:09:20 # By default the snapshots/journal directories live in KARAF_HOME. You can choose to put it somewhere else by 02:09:20 # modifying the following two properties. The directory location specified may be a relative or absolute path. 02:09:20 # The relative path is always relative to KARAF_HOME. 02:09:20 02:09:20 # snapshot-store.local.dir = "target/snapshots" 02:09:20 02:09:20 # Use lz4 compression for LocalSnapshotStore snapshots 02:09:20 snapshot-store.local.use-lz4-compression = false 02:09:20 # Size of blocks for lz4 compression: 64KB, 256KB, 1MB or 4MB 02:09:20 snapshot-store.local.lz4-blocksize = 256KB 02:09:20 } 02:09:20 disable-default-actor-system-quarantined-event-handling = "false" 02:09:20 } 02:09:20 } 02:09:20 Dump modules.conf 02:09:20 + echo 'Dump modules.conf' 02:09:20 + cat /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:20 modules = [ 02:09:20 02:09:20 { 02:09:20 name = "inventory" 02:09:20 namespace = "urn:opendaylight:inventory" 02:09:20 shard-strategy = "module" 02:09:20 }, 02:09:20 { 02:09:20 name = "topology" 02:09:20 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:20 shard-strategy = "module" 02:09:20 }, 02:09:20 { 02:09:20 name = "toaster" 02:09:20 namespace = "http://netconfcentral.org/ns/toaster" 02:09:20 shard-strategy = "module" 02:09:20 } 02:09:20 ] 02:09:20 Dump module-shards.conf 02:09:20 + echo 'Dump module-shards.conf' 02:09:20 + cat /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:20 module-shards = [ 02:09:20 { 02:09:20 name = "default" 02:09:20 shards = [ 02:09:20 { 02:09:20 name = "default" 02:09:20 replicas = ["member-1", 02:09:20 "member-2", 02:09:20 "member-3"] 02:09:20 } 02:09:20 ] 02:09:20 }, 02:09:20 { 02:09:20 name = "inventory" 02:09:20 shards = [ 02:09:20 { 02:09:20 name="inventory" 02:09:20 replicas = ["member-1", 02:09:20 "member-2", 02:09:20 "member-3"] 02:09:20 } 02:09:20 ] 02:09:20 }, 02:09:20 { 02:09:20 name = "topology" 02:09:20 shards = [ 02:09:20 { 02:09:20 name="topology" 02:09:20 replicas = ["member-1", 02:09:20 "member-2", 02:09:20 "member-3"] 02:09:20 } 02:09:20 ] 02:09:20 }, 02:09:20 { 02:09:20 name = "toaster" 02:09:20 shards = [ 02:09:20 { 02:09:20 name="toaster" 02:09:20 replicas = ["member-1", 02:09:20 "member-2", 02:09:20 "member-3"] 02:09:20 } 02:09:20 ] 02:09:20 } 02:09:20 ] 02:09:20 Configuring member-2 with IP address 10.30.170.204 02:09:20 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:20 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:20 + source /tmp/common-functions.sh karaf-0.21.4 scandium 02:09:20 ++ [[ /tmp/common-functions.sh == \/\t\m\p\/\c\o\n\f\i\g\u\r\a\t\i\o\n\-\s\c\r\i\p\t\.\s\h ]] 02:09:20 ++ echo 'common-functions.sh is being sourced' 02:09:20 common-functions.sh is being sourced 02:09:20 ++ BUNDLEFOLDER=karaf-0.21.4 02:09:20 ++ DISTROSTREAM=scandium 02:09:20 ++ export MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:20 ++ MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:20 ++ export FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:20 ++ FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:20 ++ export CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:20 ++ CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:20 ++ export LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:20 ++ LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:20 ++ export MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:20 ++ MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:20 ++ export CONTROLLERMEM= 02:09:20 ++ CONTROLLERMEM= 02:09:20 ++ case "${DISTROSTREAM}" in 02:09:20 ++ CLUSTER_SYSTEM=akka 02:09:20 ++ export AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:20 ++ AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:20 ++ export MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:20 ++ MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:20 ++ export MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:20 ++ MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:20 ++ print_common_env 02:09:20 ++ cat 02:09:20 common-functions environment: 02:09:20 MAVENCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:20 ACTUALFEATURES: 02:09:20 FEATURESCONF: /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:20 CUSTOMPROP: /tmp/karaf-0.21.4/etc/custom.properties 02:09:20 LOGCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:20 MEMCONF: /tmp/karaf-0.21.4/bin/setenv 02:09:20 CONTROLLERMEM: 02:09:20 AKKACONF: /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:20 MODULESCONF: /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:20 MODULESHARDSCONF: /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:20 SUITES: 02:09:20 02:09:20 ++ SSH='ssh -t -t' 02:09:20 ++ extra_services_cntl=' dnsmasq.service httpd.service libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service rabbitmq-server.service ' 02:09:20 ++ extra_services_cmp=' libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service ' 02:09:20 Changing to /tmp 02:09:20 + echo 'Changing to /tmp' 02:09:20 + cd /tmp 02:09:20 Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:20 + echo 'Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip' 02:09:20 + wget --progress=dot:mega https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:20 --2025-12-30 02:09:20-- https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:20 Resolving nexus.opendaylight.org (nexus.opendaylight.org)... 199.204.45.87, 2604:e100:1:0:f816:3eff:fe45:48d6 02:09:20 Connecting to nexus.opendaylight.org (nexus.opendaylight.org)|199.204.45.87|:443... connected. 02:09:20 HTTP request sent, awaiting response... 200 OK 02:09:20 Length: 239704812 (229M) [application/zip] 02:09:20 Saving to: ‘karaf-0.21.4.zip’ 02:09:20 02:09:20 0K ........ ........ ........ ........ ........ ........ 1% 58.3M 4s 02:09:20 3072K ........ ........ ........ ........ ........ ........ 2% 121M 3s 02:09:20 6144K ........ ........ ........ ........ ........ ........ 3% 123M 2s 02:09:20 9216K ........ ........ ........ ........ ........ ........ 5% 82.2M 2s 02:09:20 12288K ........ ........ ........ ........ ........ ........ 6% 134M 2s 02:09:20 15360K ........ ........ ........ ........ ........ ........ 7% 149M 2s 02:09:20 18432K ........ ........ ........ ........ ........ ........ 9% 158M 2s 02:09:20 21504K ........ ........ ........ ........ ........ ........ 10% 172M 2s 02:09:20 24576K ........ ........ ........ ........ ........ ........ 11% 164M 2s 02:09:20 27648K ........ ........ ........ ........ ........ ........ 13% 191M 2s 02:09:20 30720K ........ ........ ........ ........ ........ ........ 14% 205M 2s 02:09:20 33792K ........ ........ ........ ........ ........ ........ 15% 222M 1s 02:09:20 36864K ........ ........ ........ ........ ........ ........ 17% 257M 1s 02:09:20 39936K ........ ........ ........ ........ ........ ........ 18% 285M 1s 02:09:20 43008K ........ ........ ........ ........ ........ ........ 19% 249M 1s 02:09:20 46080K ........ ........ ........ ........ ........ ........ 20% 281M 1s 02:09:20 49152K ........ ........ ........ ........ ........ ........ 22% 290M 1s 02:09:20 52224K ........ ........ ........ ........ ........ ........ 23% 235M 1s 02:09:20 55296K ........ ........ ........ ........ ........ ........ 24% 147M 1s 02:09:20 58368K ........ ........ ........ ........ ........ ........ 26% 265M 1s 02:09:20 61440K ........ ........ ........ ........ ........ ........ 27% 280M 1s 02:09:20 64512K ........ ........ ........ ........ ........ ........ 28% 269M 1s 02:09:20 67584K ........ ........ ........ ........ ........ ........ 30% 278M 1s 02:09:20 70656K ........ ........ ........ ........ ........ ........ 31% 285M 1s 02:09:20 73728K ........ ........ ........ ........ ........ ........ 32% 280M 1s 02:09:20 76800K ........ ........ ........ ........ ........ ........ 34% 283M 1s 02:09:20 79872K ........ ........ ........ ........ ........ ........ 35% 276M 1s 02:09:20 82944K ........ ........ ........ ........ ........ ........ 36% 277M 1s 02:09:20 86016K ........ ........ ........ ........ ........ ........ 38% 128M 1s 02:09:20 89088K ........ ........ ........ ........ ........ ........ 39% 214M 1s 02:09:21 92160K ........ ........ ........ ........ ........ ........ 40% 267M 1s 02:09:21 95232K ........ ........ ........ ........ ........ ........ 41% 268M 1s 02:09:21 98304K ........ ........ ........ ........ ........ ........ 43% 279M 1s 02:09:21 101376K ........ ........ ........ ........ ........ ........ 44% 89.0M 1s 02:09:21 104448K ........ ........ ........ ........ ........ ........ 45% 173M 1s 02:09:21 107520K ........ ........ ........ ........ ........ ........ 47% 262M 1s 02:09:21 110592K ........ ........ ........ ........ ........ ........ 48% 267M 1s 02:09:21 113664K ........ ........ ........ ........ ........ ........ 49% 263M 1s 02:09:21 116736K ........ ........ ........ ........ ........ ........ 51% 268M 1s 02:09:21 119808K ........ ........ ........ ........ ........ ........ 52% 96.9M 1s 02:09:21 122880K ........ ........ ........ ........ ........ ........ 53% 179M 1s 02:09:21 125952K ........ ........ ........ ........ ........ ........ 55% 241M 1s 02:09:21 129024K ........ ........ ........ ........ ........ ........ 56% 264M 1s 02:09:21 132096K ........ ........ ........ ........ ........ ........ 57% 273M 1s 02:09:21 135168K ........ ........ ........ ........ ........ ........ 59% 274M 1s 02:09:21 138240K ........ ........ ........ ........ ........ ........ 60% 257M 0s 02:09:21 141312K ........ ........ ........ ........ ........ ........ 61% 214M 0s 02:09:21 144384K ........ ........ ........ ........ ........ ........ 62% 239M 0s 02:09:21 147456K ........ ........ ........ ........ ........ ........ 64% 271M 0s 02:09:21 150528K ........ ........ ........ ........ ........ ........ 65% 279M 0s 02:09:21 153600K ........ ........ ........ ........ ........ ........ 66% 277M 0s 02:09:21 156672K ........ ........ ........ ........ ........ ........ 68% 270M 0s 02:09:21 159744K ........ ........ ........ ........ ........ ........ 69% 261M 0s 02:09:21 162816K ........ ........ ........ ........ ........ ........ 70% 256M 0s 02:09:21 165888K ........ ........ ........ ........ ........ ........ 72% 261M 0s 02:09:21 168960K ........ ........ ........ ........ ........ ........ 73% 256M 0s 02:09:21 172032K ........ ........ ........ ........ ........ ........ 74% 274M 0s 02:09:21 175104K ........ ........ ........ ........ ........ ........ 76% 272M 0s 02:09:21 178176K ........ ........ ........ ........ ........ ........ 77% 272M 0s 02:09:21 181248K ........ ........ ........ ........ ........ ........ 78% 265M 0s 02:09:21 184320K ........ ........ ........ ........ ........ ........ 80% 273M 0s 02:09:21 187392K ........ ........ ........ ........ ........ ........ 81% 279M 0s 02:09:21 190464K ........ ........ ........ ........ ........ ........ 82% 280M 0s 02:09:21 193536K ........ ........ ........ ........ ........ ........ 83% 279M 0s 02:09:21 196608K ........ ........ ........ ........ ........ ........ 85% 272M 0s 02:09:21 199680K ........ ........ ........ ........ ........ ........ 86% 261M 0s 02:09:21 202752K ........ ........ ........ ........ ........ ........ 87% 184M 0s 02:09:21 205824K ........ ........ ........ ........ ........ ........ 89% 134M 0s 02:09:21 208896K ........ ........ ........ ........ ........ ........ 90% 243M 0s 02:09:21 211968K ........ ........ ........ ........ ........ ........ 91% 270M 0s 02:09:21 215040K ........ ........ ........ ........ ........ ........ 93% 267M 0s 02:09:21 218112K ........ ........ ........ ........ ........ ........ 94% 267M 0s 02:09:21 221184K ........ ........ ........ ........ ........ ........ 95% 279M 0s 02:09:21 224256K ........ ........ ........ ........ ........ ........ 97% 274M 0s 02:09:21 227328K ........ ........ ........ ........ ........ ........ 98% 270M 0s 02:09:21 230400K ........ ........ ........ ........ ........ ........ 99% 90.9M 0s 02:09:21 233472K ........ . 100% 71.0M=1.1s 02:09:21 02:09:21 2025-12-30 02:09:21 (204 MB/s) - ‘karaf-0.21.4.zip’ saved [239704812/239704812] 02:09:21 02:09:21 Extracting the new controller... 02:09:21 + echo 'Extracting the new controller...' 02:09:21 + unzip -q karaf-0.21.4.zip 02:09:23 Adding external repositories... 02:09:23 + echo 'Adding external repositories...' 02:09:23 + sed -ie 's%org.ops4j.pax.url.mvn.repositories=%org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases%g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:23 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:23 ################################################################################ 02:09:23 # 02:09:23 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:23 # contributor license agreements. See the NOTICE file distributed with 02:09:23 # this work for additional information regarding copyright ownership. 02:09:23 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:23 # (the "License"); you may not use this file except in compliance with 02:09:23 # the License. You may obtain a copy of the License at 02:09:23 # 02:09:23 # http://www.apache.org/licenses/LICENSE-2.0 02:09:23 # 02:09:23 # Unless required by applicable law or agreed to in writing, software 02:09:23 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:23 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:23 # See the License for the specific language governing permissions and 02:09:23 # limitations under the License. 02:09:23 # 02:09:23 ################################################################################ 02:09:23 02:09:23 # 02:09:23 # If set to true, the following property will not allow any certificate to be used 02:09:23 # when accessing Maven repositories through SSL 02:09:23 # 02:09:23 #org.ops4j.pax.url.mvn.certificateCheck= 02:09:23 02:09:23 # 02:09:23 # Path to the local Maven settings file. 02:09:23 # The repositories defined in this file will be automatically added to the list 02:09:23 # of default repositories if the 'org.ops4j.pax.url.mvn.repositories' property 02:09:23 # below is not set. 02:09:23 # The following locations are checked for the existence of the settings.xml file 02:09:23 # * 1. looks for the specified url 02:09:23 # * 2. if not found looks for ${user.home}/.m2/settings.xml 02:09:23 # * 3. if not found looks for ${maven.home}/conf/settings.xml 02:09:23 # * 4. if not found looks for ${M2_HOME}/conf/settings.xml 02:09:23 # 02:09:23 #org.ops4j.pax.url.mvn.settings= 02:09:23 02:09:23 # 02:09:23 # Path to the local Maven repository which is used to avoid downloading 02:09:23 # artifacts when they already exist locally. 02:09:23 # The value of this property will be extracted from the settings.xml file 02:09:23 # above, or defaulted to: 02:09:23 # System.getProperty( "user.home" ) + "/.m2/repository" 02:09:23 # 02:09:23 org.ops4j.pax.url.mvn.localRepository=${karaf.home}/${karaf.default.repository} 02:09:23 02:09:23 # 02:09:23 # Default this to false. It's just weird to use undocumented repos 02:09:23 # 02:09:23 org.ops4j.pax.url.mvn.useFallbackRepositories=false 02:09:23 02:09:23 # 02:09:23 # Uncomment if you don't wanna use the proxy settings 02:09:23 # from the Maven conf/settings.xml file 02:09:23 # 02:09:23 # org.ops4j.pax.url.mvn.proxySupport=false 02:09:23 02:09:23 # 02:09:23 # Comma separated list of repositories scanned when resolving an artifact. 02:09:23 # Those repositories will be checked before iterating through the 02:09:23 # below list of repositories and even before the local repository 02:09:23 # A repository url can be appended with zero or more of the following flags: 02:09:23 # @snapshots : the repository contains snaphots 02:09:23 # @noreleases : the repository does not contain any released artifacts 02:09:23 # 02:09:23 # The following property value will add the system folder as a repo. 02:09:23 # 02:09:23 org.ops4j.pax.url.mvn.defaultRepositories=\ 02:09:23 file:${karaf.home}/${karaf.default.repository}@id=system.repository@snapshots,\ 02:09:23 file:${karaf.data}/kar@id=kar.repository@multi@snapshots,\ 02:09:23 file:${karaf.base}/${karaf.default.repository}@id=child.system.repository@snapshots 02:09:23 02:09:23 # Use the default local repo (e.g.~/.m2/repository) as a "remote" repo 02:09:23 #org.ops4j.pax.url.mvn.defaultLocalRepoAsRemote=false 02:09:23 02:09:23 # 02:09:23 # Comma separated list of repositories scanned when resolving an artifact. 02:09:23 # The default list includes the following repositories: 02:09:23 # http://repo1.maven.org/maven2@id=central 02:09:23 # http://repository.springsource.com/maven/bundles/release@id=spring.ebr 02:09:23 # http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external 02:09:23 # http://zodiac.springsource.com/maven/bundles/release@id=gemini 02:09:23 # http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases 02:09:23 # https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases 02:09:23 # https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:23 # To add repositories to the default ones, prepend '+' to the list of repositories 02:09:23 # to add. 02:09:23 # A repository url can be appended with zero or more of the following flags: 02:09:23 # @snapshots : the repository contains snapshots 02:09:23 # @noreleases : the repository does not contain any released artifacts 02:09:23 # @id=repository.id : the id for the repository, just like in the settings.xml this is optional but recommended 02:09:23 # 02:09:23 org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:23 02:09:23 ### ^^^ No remote repositories. This is the only ODL change compared to Karaf defaults.Configuring the startup features... 02:09:23 + [[ True == \T\r\u\e ]] 02:09:23 + echo 'Configuring the startup features...' 02:09:23 + sed -ie 's/\(featuresBoot=\|featuresBoot =\)/featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest,/g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:23 + FEATURE_TEST_STRING=features-test 02:09:23 + FEATURE_TEST_VERSION=0.21.4 02:09:23 + KARAF_VERSION=karaf4 02:09:23 + [[ integration == \i\n\t\e\g\r\a\t\i\o\n ]] 02:09:23 + sed -ie 's%\(featuresRepositories=\|featuresRepositories =\)%featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features,%g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:23 + [[ ! -z '' ]] 02:09:23 + cat /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:23 ################################################################################ 02:09:23 # 02:09:23 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:23 # contributor license agreements. See the NOTICE file distributed with 02:09:23 # this work for additional information regarding copyright ownership. 02:09:23 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:23 # (the "License"); you may not use this file except in compliance with 02:09:23 # the License. You may obtain a copy of the License at 02:09:23 # 02:09:23 # http://www.apache.org/licenses/LICENSE-2.0 02:09:23 # 02:09:23 # Unless required by applicable law or agreed to in writing, software 02:09:23 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:23 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:23 # See the License for the specific language governing permissions and 02:09:23 # limitations under the License. 02:09:23 # 02:09:23 ################################################################################ 02:09:23 02:09:23 # 02:09:23 # Comma separated list of features repositories to register by default 02:09:23 # 02:09:23 featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features, file:${karaf.etc}/36abfd67-5c11-488f-909b-8f87618e3936.xml 02:09:23 02:09:23 # 02:09:23 # Comma separated list of features to install at startup 02:09:23 # 02:09:23 featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest, 57452d0e-67df-43b2-8cae-b9409b045dc0 02:09:23 02:09:23 # 02:09:23 # Resource repositories (OBR) that the features resolver can use 02:09:23 # to resolve requirements/capabilities 02:09:23 # 02:09:23 # The format of the resourceRepositories is 02:09:23 # resourceRepositories=[xml:url|json:url],... 02:09:23 # for Instance: 02:09:23 # 02:09:23 #resourceRepositories=xml:http://host/path/to/index.xml 02:09:23 # or 02:09:23 #resourceRepositories=json:http://host/path/to/index.json 02:09:23 # 02:09:23 02:09:23 # 02:09:23 # Defines if the boot features are started in asynchronous mode (in a dedicated thread) 02:09:23 # 02:09:23 featuresBootAsynchronous=false 02:09:23 02:09:23 # 02:09:23 # Service requirements enforcement 02:09:23 # 02:09:23 # By default, the feature resolver checks the service requirements/capabilities of 02:09:23 # bundles for new features (xml schema >= 1.3.0) in order to automatically installs 02:09:23 # the required bundles. 02:09:23 # The following flag can have those values: 02:09:23 # - disable: service requirements are completely ignored 02:09:23 # - default: service requirements are ignored for old features 02:09:23 # - enforce: service requirements are always verified 02:09:23 # 02:09:23 #serviceRequirements=default 02:09:23 02:09:23 # 02:09:23 # Store cfg file for config element in feature 02:09:23 # 02:09:23 #configCfgStore=true 02:09:23 02:09:23 # 02:09:23 # Define if the feature service automatically refresh bundles 02:09:23 # 02:09:23 autoRefresh=true 02:09:23 02:09:23 # 02:09:23 # Configuration of features processing mechanism (overrides, blacklisting, modification of features) 02:09:23 # XML file defines instructions related to features processing 02:09:23 # versions.properties may declare properties to resolve placeholders in XML file 02:09:23 # both files are relative to ${karaf.etc} 02:09:23 # 02:09:23 #featureProcessing=org.apache.karaf.features.xml 02:09:23 #featureProcessingVersions=versions.properties 02:09:23 + configure_karaf_log karaf4 '' 02:09:23 + local -r karaf_version=karaf4 02:09:23 + local -r controllerdebugmap= 02:09:23 + local logapi=log4j 02:09:23 + grep log4j2 /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:23 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:23 log4j2.rootLogger.level = INFO 02:09:23 #log4j2.rootLogger.type = asyncRoot 02:09:23 #log4j2.rootLogger.includeLocation = false 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:23 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:23 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:23 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:23 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:23 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:23 log4j2.logger.spifly.level = WARN 02:09:23 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:23 log4j2.logger.audit.level = INFO 02:09:23 log4j2.logger.audit.additivity = false 02:09:23 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:23 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:23 log4j2.appender.console.type = Console 02:09:23 log4j2.appender.console.name = Console 02:09:23 log4j2.appender.console.layout.type = PatternLayout 02:09:23 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:23 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:23 log4j2.appender.rolling.name = RollingFile 02:09:23 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:23 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:23 #log4j2.appender.rolling.immediateFlush = false 02:09:23 log4j2.appender.rolling.append = true 02:09:23 log4j2.appender.rolling.layout.type = PatternLayout 02:09:23 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:23 log4j2.appender.rolling.policies.type = Policies 02:09:23 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:23 log4j2.appender.rolling.policies.size.size = 64MB 02:09:23 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:23 log4j2.appender.rolling.strategy.max = 7 02:09:23 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:23 log4j2.appender.audit.name = AuditRollingFile 02:09:23 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:23 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:23 log4j2.appender.audit.append = true 02:09:23 log4j2.appender.audit.layout.type = PatternLayout 02:09:23 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:23 log4j2.appender.audit.policies.type = Policies 02:09:23 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:23 log4j2.appender.audit.policies.size.size = 8MB 02:09:23 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:23 log4j2.appender.audit.strategy.max = 7 02:09:23 log4j2.appender.osgi.type = PaxOsgi 02:09:23 log4j2.appender.osgi.name = PaxOsgi 02:09:23 log4j2.appender.osgi.filter = * 02:09:23 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:23 #log4j2.logger.aether.level = TRACE 02:09:23 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:23 #log4j2.logger.http-headers.level = DEBUG 02:09:23 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:23 #log4j2.logger.maven.level = TRACE 02:09:23 Configuring the karaf log... karaf_version: karaf4, logapi: log4j2 02:09:23 + logapi=log4j2 02:09:23 + echo 'Configuring the karaf log... karaf_version: karaf4, logapi: log4j2' 02:09:23 + '[' log4j2 == log4j2 ']' 02:09:23 + sed -ie 's/log4j2.appender.rolling.policies.size.size = 64MB/log4j2.appender.rolling.policies.size.size = 1GB/g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:23 + orgmodule=org.opendaylight.yangtools.yang.parser.repo.YangTextSchemaContextResolver 02:09:23 + orgmodule_=org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver 02:09:23 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN' 02:09:23 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN' 02:09:23 controllerdebugmap: 02:09:23 cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:23 + unset IFS 02:09:23 + echo 'controllerdebugmap: ' 02:09:23 + '[' -n '' ']' 02:09:23 + echo 'cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg' 02:09:23 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:23 ################################################################################ 02:09:23 # 02:09:23 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:23 # contributor license agreements. See the NOTICE file distributed with 02:09:23 # this work for additional information regarding copyright ownership. 02:09:23 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:23 # (the "License"); you may not use this file except in compliance with 02:09:23 # the License. You may obtain a copy of the License at 02:09:23 # 02:09:23 # http://www.apache.org/licenses/LICENSE-2.0 02:09:23 # 02:09:23 # Unless required by applicable law or agreed to in writing, software 02:09:23 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:23 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:23 # See the License for the specific language governing permissions and 02:09:23 # limitations under the License. 02:09:23 # 02:09:23 ################################################################################ 02:09:23 02:09:23 # Common pattern layout for appenders 02:09:23 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:23 02:09:23 # Root logger 02:09:23 log4j2.rootLogger.level = INFO 02:09:23 # uncomment to use asynchronous loggers, which require mvn:com.lmax/disruptor/3.3.2 library 02:09:23 #log4j2.rootLogger.type = asyncRoot 02:09:23 #log4j2.rootLogger.includeLocation = false 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:23 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:23 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:23 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:23 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:23 02:09:23 # Filters for logs marked by org.opendaylight.odlparent.Markers 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:23 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:23 02:09:23 # Loggers configuration 02:09:23 02:09:23 # Spifly logger 02:09:23 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:23 log4j2.logger.spifly.level = WARN 02:09:23 02:09:23 # Security audit logger 02:09:23 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:23 log4j2.logger.audit.level = INFO 02:09:23 log4j2.logger.audit.additivity = false 02:09:23 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:23 02:09:23 # Appenders configuration 02:09:23 02:09:23 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:23 log4j2.appender.console.type = Console 02:09:23 log4j2.appender.console.name = Console 02:09:23 log4j2.appender.console.layout.type = PatternLayout 02:09:23 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:23 02:09:23 # Rolling file appender 02:09:23 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:23 log4j2.appender.rolling.name = RollingFile 02:09:23 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:23 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:23 # uncomment to not force a disk flush 02:09:23 #log4j2.appender.rolling.immediateFlush = false 02:09:23 log4j2.appender.rolling.append = true 02:09:23 log4j2.appender.rolling.layout.type = PatternLayout 02:09:23 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:23 log4j2.appender.rolling.policies.type = Policies 02:09:23 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:23 log4j2.appender.rolling.policies.size.size = 1GB 02:09:23 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:23 log4j2.appender.rolling.strategy.max = 7 02:09:23 02:09:23 # Audit file appender 02:09:23 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:23 log4j2.appender.audit.name = AuditRollingFile 02:09:23 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:23 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:23 log4j2.appender.audit.append = true 02:09:23 log4j2.appender.audit.layout.type = PatternLayout 02:09:23 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:23 log4j2.appender.audit.policies.type = Policies 02:09:23 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:23 log4j2.appender.audit.policies.size.size = 8MB 02:09:23 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:23 log4j2.appender.audit.strategy.max = 7 02:09:23 02:09:23 # OSGi appender 02:09:23 log4j2.appender.osgi.type = PaxOsgi 02:09:23 log4j2.appender.osgi.name = PaxOsgi 02:09:23 log4j2.appender.osgi.filter = * 02:09:23 02:09:23 # help with identification of maven-related problems with pax-url-aether 02:09:23 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:23 #log4j2.logger.aether.level = TRACE 02:09:23 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:23 #log4j2.logger.http-headers.level = DEBUG 02:09:23 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:23 #log4j2.logger.maven.level = TRACE 02:09:23 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN 02:09:23 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN 02:09:23 + set_java_vars /usr/lib/jvm/java-21-openjdk-amd64 2048m /tmp/karaf-0.21.4/bin/setenv 02:09:23 + local -r java_home=/usr/lib/jvm/java-21-openjdk-amd64 02:09:23 + local -r controllermem=2048m 02:09:23 Configure 02:09:23 java home: /usr/lib/jvm/java-21-openjdk-amd64 02:09:23 + local -r memconf=/tmp/karaf-0.21.4/bin/setenv 02:09:23 + echo Configure 02:09:23 + echo ' java home: /usr/lib/jvm/java-21-openjdk-amd64' 02:09:23 max memory: 2048m 02:09:23 memconf: /tmp/karaf-0.21.4/bin/setenv 02:09:23 + echo ' max memory: 2048m' 02:09:23 + echo ' memconf: /tmp/karaf-0.21.4/bin/setenv' 02:09:23 + sed -ie 's%^# export JAVA_HOME%export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64}%g' /tmp/karaf-0.21.4/bin/setenv 02:09:23 + sed -ie 's/JAVA_MAX_MEM="2048m"/JAVA_MAX_MEM=2048m/g' /tmp/karaf-0.21.4/bin/setenv 02:09:23 cat /tmp/karaf-0.21.4/bin/setenv 02:09:23 + echo 'cat /tmp/karaf-0.21.4/bin/setenv' 02:09:23 + cat /tmp/karaf-0.21.4/bin/setenv 02:09:23 #!/bin/sh 02:09:23 # 02:09:23 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:23 # contributor license agreements. See the NOTICE file distributed with 02:09:23 # this work for additional information regarding copyright ownership. 02:09:23 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:23 # (the "License"); you may not use this file except in compliance with 02:09:23 # the License. You may obtain a copy of the License at 02:09:23 # 02:09:23 # http://www.apache.org/licenses/LICENSE-2.0 02:09:23 # 02:09:23 # Unless required by applicable law or agreed to in writing, software 02:09:23 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:23 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:23 # See the License for the specific language governing permissions and 02:09:23 # limitations under the License. 02:09:23 # 02:09:23 02:09:23 # 02:09:23 # handle specific scripts; the SCRIPT_NAME is exactly the name of the Karaf 02:09:23 # script: client, instance, shell, start, status, stop, karaf 02:09:23 # 02:09:23 # if [ "${KARAF_SCRIPT}" == "SCRIPT_NAME" ]; then 02:09:23 # Actions go here... 02:09:23 # fi 02:09:23 02:09:23 # 02:09:23 # general settings which should be applied for all scripts go here; please keep 02:09:23 # in mind that it is possible that scripts might be executed more than once, e.g. 02:09:23 # in example of the start script where the start script is executed first and the 02:09:23 # karaf script afterwards. 02:09:23 # 02:09:23 02:09:23 # 02:09:23 # The following section shows the possible configuration options for the default 02:09:23 # karaf scripts 02:09:23 # 02:09:23 export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64} # Location of Java installation 02:09:23 # export JAVA_OPTS # Generic JVM options, for instance, where you can pass the memory configuration 02:09:23 # export JAVA_NON_DEBUG_OPTS # Additional non-debug JVM options 02:09:23 # export EXTRA_JAVA_OPTS # Additional JVM options 02:09:23 # export KARAF_HOME # Karaf home folder 02:09:23 # export KARAF_DATA # Karaf data folder 02:09:23 # export KARAF_BASE # Karaf base folder 02:09:23 # export KARAF_ETC # Karaf etc folder 02:09:23 # export KARAF_LOG # Karaf log folder 02:09:23 # export KARAF_SYSTEM_OPTS # First citizen Karaf options 02:09:23 # export KARAF_OPTS # Additional available Karaf options 02:09:23 # export KARAF_DEBUG # Enable debug mode 02:09:23 # export KARAF_REDIRECT # Enable/set the std/err redirection when using bin/start 02:09:23 # export KARAF_NOROOT # Prevent execution as root if set to true 02:09:23 Set Java version 02:09:23 + echo 'Set Java version' 02:09:23 + sudo /usr/sbin/alternatives --install /usr/bin/java java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 1 02:09:23 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:23 sudo: a password is required 02:09:23 + sudo /usr/sbin/alternatives --set java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:23 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:23 sudo: a password is required 02:09:23 JDK default version ... 02:09:23 + echo 'JDK default version ...' 02:09:23 + java -version 02:09:24 openjdk version "21.0.9" 2025-10-21 02:09:24 OpenJDK Runtime Environment (build 21.0.9+10-Ubuntu-122.04) 02:09:24 OpenJDK 64-Bit Server VM (build 21.0.9+10-Ubuntu-122.04, mixed mode, sharing) 02:09:24 Set JAVA_HOME 02:09:24 + echo 'Set JAVA_HOME' 02:09:24 + export JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:24 + JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:24 ++ readlink -e /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:24 Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:24 Listing all open ports on controller system... 02:09:24 + JAVA_RESOLVED=/usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:24 + echo 'Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java' 02:09:24 + echo 'Listing all open ports on controller system...' 02:09:24 + netstat -pnatu 02:09:24 /tmp/configuration-script.sh: line 40: netstat: command not found 02:09:24 Configuring cluster 02:09:24 + '[' -f /tmp/custom_shard_config.txt ']' 02:09:24 + echo 'Configuring cluster' 02:09:24 + /tmp/karaf-0.21.4/bin/configure_cluster.sh 2 10.30.171.33 10.30.170.204 10.30.171.83 02:09:24 ################################################ 02:09:24 ## Configure Cluster ## 02:09:24 ################################################ 02:09:24 NOTE: Cluster configuration files not found. Copying from 02:09:24 /tmp/karaf-0.21.4/system/org/opendaylight/controller/sal-clustering-config/10.0.14 02:09:24 Configuring unique name in akka.conf 02:09:24 Configuring hostname in akka.conf 02:09:24 Configuring data and rpc seed nodes in akka.conf 02:09:24 modules = [ 02:09:24 02:09:24 { 02:09:24 name = "inventory" 02:09:24 namespace = "urn:opendaylight:inventory" 02:09:24 shard-strategy = "module" 02:09:24 }, 02:09:24 { 02:09:24 name = "topology" 02:09:24 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:24 shard-strategy = "module" 02:09:24 }, 02:09:24 { 02:09:24 name = "toaster" 02:09:24 namespace = "http://netconfcentral.org/ns/toaster" 02:09:24 shard-strategy = "module" 02:09:24 } 02:09:24 ] 02:09:24 Configuring replication type in module-shards.conf 02:09:24 ################################################ 02:09:24 ## NOTE: Manually restart controller to ## 02:09:24 ## apply configuration. ## 02:09:24 ################################################ 02:09:24 Dump akka.conf 02:09:24 + echo 'Dump akka.conf' 02:09:24 + cat /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:24 02:09:24 odl-cluster-data { 02:09:24 akka { 02:09:24 remote { 02:09:24 artery { 02:09:24 enabled = on 02:09:24 transport = tcp 02:09:24 canonical.hostname = "10.30.170.204" 02:09:24 canonical.port = 2550 02:09:24 } 02:09:24 } 02:09:24 02:09:24 cluster { 02:09:24 # Using artery. 02:09:24 seed-nodes = ["akka://opendaylight-cluster-data@10.30.171.33:2550", 02:09:24 "akka://opendaylight-cluster-data@10.30.170.204:2550", 02:09:24 "akka://opendaylight-cluster-data@10.30.171.83:2550"] 02:09:24 02:09:24 roles = ["member-2"] 02:09:24 02:09:24 # when under load we might trip a false positive on the failure detector 02:09:24 # failure-detector { 02:09:24 # heartbeat-interval = 4 s 02:09:24 # acceptable-heartbeat-pause = 16s 02:09:24 # } 02:09:24 } 02:09:24 02:09:24 persistence { 02:09:24 # By default the snapshots/journal directories live in KARAF_HOME. You can choose to put it somewhere else by 02:09:24 # modifying the following two properties. The directory location specified may be a relative or absolute path. 02:09:24 # The relative path is always relative to KARAF_HOME. 02:09:24 02:09:24 # snapshot-store.local.dir = "target/snapshots" 02:09:24 02:09:24 # Use lz4 compression for LocalSnapshotStore snapshots 02:09:24 snapshot-store.local.use-lz4-compression = false 02:09:24 # Size of blocks for lz4 compression: 64KB, 256KB, 1MB or 4MB 02:09:24 snapshot-store.local.lz4-blocksize = 256KB 02:09:24 } 02:09:24 disable-default-actor-system-quarantined-event-handling = "false" 02:09:24 } 02:09:24 } 02:09:24 Dump modules.conf 02:09:24 + echo 'Dump modules.conf' 02:09:24 + cat /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:24 modules = [ 02:09:24 02:09:24 { 02:09:24 name = "inventory" 02:09:24 namespace = "urn:opendaylight:inventory" 02:09:24 shard-strategy = "module" 02:09:24 }, 02:09:24 { 02:09:24 name = "topology" 02:09:24 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:24 shard-strategy = "module" 02:09:24 }, 02:09:24 { 02:09:24 name = "toaster" 02:09:24 namespace = "http://netconfcentral.org/ns/toaster" 02:09:24 shard-strategy = "module" 02:09:24 } 02:09:24 ] 02:09:24 Dump module-shards.conf 02:09:24 + echo 'Dump module-shards.conf' 02:09:24 + cat /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:24 module-shards = [ 02:09:24 { 02:09:24 name = "default" 02:09:24 shards = [ 02:09:24 { 02:09:24 name = "default" 02:09:24 replicas = ["member-1", 02:09:24 "member-2", 02:09:24 "member-3"] 02:09:24 } 02:09:24 ] 02:09:24 }, 02:09:24 { 02:09:24 name = "inventory" 02:09:24 shards = [ 02:09:24 { 02:09:24 name="inventory" 02:09:24 replicas = ["member-1", 02:09:24 "member-2", 02:09:24 "member-3"] 02:09:24 } 02:09:24 ] 02:09:24 }, 02:09:24 { 02:09:24 name = "topology" 02:09:24 shards = [ 02:09:24 { 02:09:24 name="topology" 02:09:24 replicas = ["member-1", 02:09:24 "member-2", 02:09:24 "member-3"] 02:09:24 } 02:09:24 ] 02:09:24 }, 02:09:24 { 02:09:24 name = "toaster" 02:09:24 shards = [ 02:09:24 { 02:09:24 name="toaster" 02:09:24 replicas = ["member-1", 02:09:24 "member-2", 02:09:24 "member-3"] 02:09:24 } 02:09:24 ] 02:09:24 } 02:09:24 ] 02:09:24 Configuring member-3 with IP address 10.30.171.83 02:09:24 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:24 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:24 + source /tmp/common-functions.sh karaf-0.21.4 scandium 02:09:24 ++ [[ /tmp/common-functions.sh == \/\t\m\p\/\c\o\n\f\i\g\u\r\a\t\i\o\n\-\s\c\r\i\p\t\.\s\h ]] 02:09:24 common-functions.sh is being sourced 02:09:24 ++ echo 'common-functions.sh is being sourced' 02:09:24 ++ BUNDLEFOLDER=karaf-0.21.4 02:09:24 ++ DISTROSTREAM=scandium 02:09:24 ++ export MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:24 ++ MAVENCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:24 ++ export FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:24 ++ FEATURESCONF=/tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:24 ++ export CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:24 ++ CUSTOMPROP=/tmp/karaf-0.21.4/etc/custom.properties 02:09:24 ++ export LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:24 ++ LOGCONF=/tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:24 ++ export MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:24 ++ MEMCONF=/tmp/karaf-0.21.4/bin/setenv 02:09:24 ++ export CONTROLLERMEM= 02:09:24 ++ CONTROLLERMEM= 02:09:24 ++ case "${DISTROSTREAM}" in 02:09:24 ++ CLUSTER_SYSTEM=akka 02:09:24 ++ export AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:24 ++ AKKACONF=/tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:24 ++ export MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:24 ++ MODULESCONF=/tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:24 ++ export MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:24 ++ MODULESHARDSCONF=/tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:24 ++ print_common_env 02:09:24 ++ cat 02:09:24 common-functions environment: 02:09:24 MAVENCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:24 ACTUALFEATURES: 02:09:24 FEATURESCONF: /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:24 CUSTOMPROP: /tmp/karaf-0.21.4/etc/custom.properties 02:09:24 LOGCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:24 MEMCONF: /tmp/karaf-0.21.4/bin/setenv 02:09:24 CONTROLLERMEM: 02:09:24 AKKACONF: /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:24 MODULESCONF: /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:24 MODULESHARDSCONF: /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:24 SUITES: 02:09:24 02:09:24 ++ SSH='ssh -t -t' 02:09:24 ++ extra_services_cntl=' dnsmasq.service httpd.service libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service rabbitmq-server.service ' 02:09:24 ++ extra_services_cmp=' libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service ' 02:09:24 Changing to /tmp 02:09:24 Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:24 + echo 'Changing to /tmp' 02:09:24 + cd /tmp 02:09:24 + echo 'Downloading the distribution from https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip' 02:09:24 + wget --progress=dot:mega https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:24 --2025-12-30 02:09:24-- https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip 02:09:24 Resolving nexus.opendaylight.org (nexus.opendaylight.org)... 199.204.45.87, 2604:e100:1:0:f816:3eff:fe45:48d6 02:09:24 Connecting to nexus.opendaylight.org (nexus.opendaylight.org)|199.204.45.87|:443... connected. 02:09:24 HTTP request sent, awaiting response... 200 OK 02:09:24 Length: 239704812 (229M) [application/zip] 02:09:24 Saving to: ‘karaf-0.21.4.zip’ 02:09:24 02:09:24 0K ........ ........ ........ ........ ........ ........ 1% 60.2M 4s 02:09:24 3072K ........ ........ ........ ........ ........ ........ 2% 108M 3s 02:09:24 6144K ........ ........ ........ ........ ........ ........ 3% 146M 2s 02:09:24 9216K ........ ........ ........ ........ ........ ........ 5% 171M 2s 02:09:24 12288K ........ ........ ........ ........ ........ ........ 6% 226M 2s 02:09:24 15360K ........ ........ ........ ........ ........ ........ 7% 183M 2s 02:09:24 18432K ........ ........ ........ ........ ........ ........ 9% 256M 2s 02:09:24 21504K ........ ........ ........ ........ ........ ........ 10% 227M 1s 02:09:24 24576K ........ ........ ........ ........ ........ ........ 11% 253M 1s 02:09:24 27648K ........ ........ ........ ........ ........ ........ 13% 232M 1s 02:09:24 30720K ........ ........ ........ ........ ........ ........ 14% 263M 1s 02:09:24 33792K ........ ........ ........ ........ ........ ........ 15% 281M 1s 02:09:24 36864K ........ ........ ........ ........ ........ ........ 17% 292M 1s 02:09:24 39936K ........ ........ ........ ........ ........ ........ 18% 259M 1s 02:09:24 43008K ........ ........ ........ ........ ........ ........ 19% 416M 1s 02:09:24 46080K ........ ........ ........ ........ ........ ........ 20% 329M 1s 02:09:24 49152K ........ ........ ........ ........ ........ ........ 22% 347M 1s 02:09:24 52224K ........ ........ ........ ........ ........ ........ 23% 383M 1s 02:09:24 55296K ........ ........ ........ ........ ........ ........ 24% 372M 1s 02:09:24 58368K ........ ........ ........ ........ ........ ........ 26% 293M 1s 02:09:24 61440K ........ ........ ........ ........ ........ ........ 27% 327M 1s 02:09:24 64512K ........ ........ ........ ........ ........ ........ 28% 369M 1s 02:09:24 67584K ........ ........ ........ ........ ........ ........ 30% 318M 1s 02:09:24 70656K ........ ........ ........ ........ ........ ........ 31% 245M 1s 02:09:24 73728K ........ ........ ........ ........ ........ ........ 32% 221M 1s 02:09:24 76800K ........ ........ ........ ........ ........ ........ 34% 282M 1s 02:09:24 79872K ........ ........ ........ ........ ........ ........ 35% 248M 1s 02:09:24 82944K ........ ........ ........ ........ ........ ........ 36% 324M 1s 02:09:24 86016K ........ ........ ........ ........ ........ ........ 38% 372M 1s 02:09:24 89088K ........ ........ ........ ........ ........ ........ 39% 374M 1s 02:09:24 92160K ........ ........ ........ ........ ........ ........ 40% 367M 1s 02:09:24 95232K ........ ........ ........ ........ ........ ........ 41% 373M 1s 02:09:24 98304K ........ ........ ........ ........ ........ ........ 43% 208M 1s 02:09:25 101376K ........ ........ ........ ........ ........ ........ 44% 323M 1s 02:09:25 104448K ........ ........ ........ ........ ........ ........ 45% 228M 1s 02:09:25 107520K ........ ........ ........ ........ ........ ........ 47% 358M 1s 02:09:25 110592K ........ ........ ........ ........ ........ ........ 48% 367M 0s 02:09:25 113664K ........ ........ ........ ........ ........ ........ 49% 346M 0s 02:09:25 116736K ........ ........ ........ ........ ........ ........ 51% 344M 0s 02:09:25 119808K ........ ........ ........ ........ ........ ........ 52% 253M 0s 02:09:25 122880K ........ ........ ........ ........ ........ ........ 53% 309M 0s 02:09:25 125952K ........ ........ ........ ........ ........ ........ 55% 359M 0s 02:09:25 129024K ........ ........ ........ ........ ........ ........ 56% 366M 0s 02:09:25 132096K ........ ........ ........ ........ ........ ........ 57% 358M 0s 02:09:25 135168K ........ ........ ........ ........ ........ ........ 59% 375M 0s 02:09:25 138240K ........ ........ ........ ........ ........ ........ 60% 374M 0s 02:09:25 141312K ........ ........ ........ ........ ........ ........ 61% 369M 0s 02:09:25 144384K ........ ........ ........ ........ ........ ........ 62% 295M 0s 02:09:25 147456K ........ ........ ........ ........ ........ ........ 64% 363M 0s 02:09:25 150528K ........ ........ ........ ........ ........ ........ 65% 368M 0s 02:09:25 153600K ........ ........ ........ ........ ........ ........ 66% 239M 0s 02:09:25 156672K ........ ........ ........ ........ ........ ........ 68% 309M 0s 02:09:25 159744K ........ ........ ........ ........ ........ ........ 69% 366M 0s 02:09:25 162816K ........ ........ ........ ........ ........ ........ 70% 351M 0s 02:09:25 165888K ........ ........ ........ ........ ........ ........ 72% 342M 0s 02:09:25 168960K ........ ........ ........ ........ ........ ........ 73% 278M 0s 02:09:25 172032K ........ ........ ........ ........ ........ ........ 74% 395M 0s 02:09:25 175104K ........ ........ ........ ........ ........ ........ 76% 434M 0s 02:09:25 178176K ........ ........ ........ ........ ........ ........ 77% 376M 0s 02:09:25 181248K ........ ........ ........ ........ ........ ........ 78% 382M 0s 02:09:25 184320K ........ ........ ........ ........ ........ ........ 80% 219M 0s 02:09:25 187392K ........ ........ ........ ........ ........ ........ 81% 375M 0s 02:09:25 190464K ........ ........ ........ ........ ........ ........ 82% 364M 0s 02:09:25 193536K ........ ........ ........ ........ ........ ........ 83% 386M 0s 02:09:25 196608K ........ ........ ........ ........ ........ ........ 85% 342M 0s 02:09:25 199680K ........ ........ ........ ........ ........ ........ 86% 196M 0s 02:09:25 202752K ........ ........ ........ ........ ........ ........ 87% 322M 0s 02:09:25 205824K ........ ........ ........ ........ ........ ........ 89% 362M 0s 02:09:25 208896K ........ ........ ........ ........ ........ ........ 90% 376M 0s 02:09:25 211968K ........ ........ ........ ........ ........ ........ 91% 378M 0s 02:09:25 215040K ........ ........ ........ ........ ........ ........ 93% 384M 0s 02:09:25 218112K ........ ........ ........ ........ ........ ........ 94% 356M 0s 02:09:25 221184K ........ ........ ........ ........ ........ ........ 95% 350M 0s 02:09:25 224256K ........ ........ ........ ........ ........ ........ 97% 206M 0s 02:09:25 227328K ........ ........ ........ ........ ........ ........ 98% 347M 0s 02:09:25 230400K ........ ........ ........ ........ ........ ........ 99% 413M 0s 02:09:25 233472K ........ . 100% 423M=0.8s 02:09:25 02:09:25 2025-12-30 02:09:25 (280 MB/s) - ‘karaf-0.21.4.zip’ saved [239704812/239704812] 02:09:25 02:09:25 Extracting the new controller... 02:09:25 + echo 'Extracting the new controller...' 02:09:25 + unzip -q karaf-0.21.4.zip 02:09:27 Adding external repositories... 02:09:27 + echo 'Adding external repositories...' 02:09:27 + sed -ie 's%org.ops4j.pax.url.mvn.repositories=%org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases%g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:27 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:27 ################################################################################ 02:09:27 # 02:09:27 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:27 # contributor license agreements. See the NOTICE file distributed with 02:09:27 # this work for additional information regarding copyright ownership. 02:09:27 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:27 # (the "License"); you may not use this file except in compliance with 02:09:27 # the License. You may obtain a copy of the License at 02:09:27 # 02:09:27 # http://www.apache.org/licenses/LICENSE-2.0 02:09:27 # 02:09:27 # Unless required by applicable law or agreed to in writing, software 02:09:27 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:27 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:27 # See the License for the specific language governing permissions and 02:09:27 # limitations under the License. 02:09:27 # 02:09:27 ################################################################################ 02:09:27 02:09:27 # 02:09:27 # If set to true, the following property will not allow any certificate to be used 02:09:27 # when accessing Maven repositories through SSL 02:09:27 # 02:09:27 #org.ops4j.pax.url.mvn.certificateCheck= 02:09:27 02:09:27 # 02:09:27 # Path to the local Maven settings file. 02:09:27 # The repositories defined in this file will be automatically added to the list 02:09:27 # of default repositories if the 'org.ops4j.pax.url.mvn.repositories' property 02:09:27 # below is not set. 02:09:27 # The following locations are checked for the existence of the settings.xml file 02:09:27 # * 1. looks for the specified url 02:09:27 # * 2. if not found looks for ${user.home}/.m2/settings.xml 02:09:27 # * 3. if not found looks for ${maven.home}/conf/settings.xml 02:09:27 # * 4. if not found looks for ${M2_HOME}/conf/settings.xml 02:09:27 # 02:09:27 #org.ops4j.pax.url.mvn.settings= 02:09:27 02:09:27 # 02:09:27 # Path to the local Maven repository which is used to avoid downloading 02:09:27 # artifacts when they already exist locally. 02:09:27 # The value of this property will be extracted from the settings.xml file 02:09:27 # above, or defaulted to: 02:09:27 # System.getProperty( "user.home" ) + "/.m2/repository" 02:09:27 # 02:09:27 org.ops4j.pax.url.mvn.localRepository=${karaf.home}/${karaf.default.repository} 02:09:27 02:09:27 # 02:09:27 # Default this to false. It's just weird to use undocumented repos 02:09:27 # 02:09:27 org.ops4j.pax.url.mvn.useFallbackRepositories=false 02:09:27 02:09:27 # 02:09:27 # Uncomment if you don't wanna use the proxy settings 02:09:27 # from the Maven conf/settings.xml file 02:09:27 # 02:09:27 # org.ops4j.pax.url.mvn.proxySupport=false 02:09:27 02:09:27 # 02:09:27 # Comma separated list of repositories scanned when resolving an artifact. 02:09:27 # Those repositories will be checked before iterating through the 02:09:27 # below list of repositories and even before the local repository 02:09:27 # A repository url can be appended with zero or more of the following flags: 02:09:27 # @snapshots : the repository contains snaphots 02:09:27 # @noreleases : the repository does not contain any released artifacts 02:09:27 # 02:09:27 # The following property value will add the system folder as a repo. 02:09:27 # 02:09:27 org.ops4j.pax.url.mvn.defaultRepositories=\ 02:09:27 file:${karaf.home}/${karaf.default.repository}@id=system.repository@snapshots,\ 02:09:27 file:${karaf.data}/kar@id=kar.repository@multi@snapshots,\ 02:09:27 file:${karaf.base}/${karaf.default.repository}@id=child.system.repository@snapshots 02:09:27 02:09:27 # Use the default local repo (e.g.~/.m2/repository) as a "remote" repo 02:09:27 #org.ops4j.pax.url.mvn.defaultLocalRepoAsRemote=false 02:09:27 02:09:27 # 02:09:27 # Comma separated list of repositories scanned when resolving an artifact. 02:09:27 # The default list includes the following repositories: 02:09:27 # http://repo1.maven.org/maven2@id=central 02:09:27 # http://repository.springsource.com/maven/bundles/release@id=spring.ebr 02:09:27 # http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external 02:09:27 # http://zodiac.springsource.com/maven/bundles/release@id=gemini 02:09:27 # http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases 02:09:27 # https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases 02:09:27 # https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:27 # To add repositories to the default ones, prepend '+' to the list of repositories 02:09:27 # to add. 02:09:27 # A repository url can be appended with zero or more of the following flags: 02:09:27 # @snapshots : the repository contains snapshots 02:09:27 # @noreleases : the repository does not contain any released artifacts 02:09:27 # @id=repository.id : the id for the repository, just like in the settings.xml this is optional but recommended 02:09:27 # 02:09:27 org.ops4j.pax.url.mvn.repositories=https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot@id=opendaylight-snapshot@snapshots, https://nexus.opendaylight.org/content/repositories/public@id=opendaylight-mirror, http://repo1.maven.org/maven2@id=central, http://repository.springsource.com/maven/bundles/release@id=spring.ebr.release, http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external, http://zodiac.springsource.com/maven/bundles/release@id=gemini, http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases, https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases, https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases 02:09:27 02:09:27 ### ^^^ No remote repositories. This is the only ODL change compared to Karaf defaults.Configuring the startup features... 02:09:27 + [[ True == \T\r\u\e ]] 02:09:27 + echo 'Configuring the startup features...' 02:09:27 + sed -ie 's/\(featuresBoot=\|featuresBoot =\)/featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest,/g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:27 + FEATURE_TEST_STRING=features-test 02:09:27 + FEATURE_TEST_VERSION=0.21.4 02:09:27 + KARAF_VERSION=karaf4 02:09:27 + [[ integration == \i\n\t\e\g\r\a\t\i\o\n ]] 02:09:27 + sed -ie 's%\(featuresRepositories=\|featuresRepositories =\)%featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features,%g' /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:27 + [[ ! -z '' ]] 02:09:27 + cat /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:27 ################################################################################ 02:09:27 # 02:09:27 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:27 # contributor license agreements. See the NOTICE file distributed with 02:09:27 # this work for additional information regarding copyright ownership. 02:09:27 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:27 # (the "License"); you may not use this file except in compliance with 02:09:27 # the License. You may obtain a copy of the License at 02:09:27 # 02:09:27 # http://www.apache.org/licenses/LICENSE-2.0 02:09:27 # 02:09:27 # Unless required by applicable law or agreed to in writing, software 02:09:27 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:27 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:27 # See the License for the specific language governing permissions and 02:09:27 # limitations under the License. 02:09:27 # 02:09:27 ################################################################################ 02:09:27 02:09:27 # 02:09:27 # Comma separated list of features repositories to register by default 02:09:27 # 02:09:27 featuresRepositories = mvn:org.opendaylight.integration/features-test/0.21.4/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features, file:${karaf.etc}/36abfd67-5c11-488f-909b-8f87618e3936.xml 02:09:27 02:09:27 # 02:09:27 # Comma separated list of features to install at startup 02:09:27 # 02:09:27 featuresBoot = odl-infrautils-ready,odl-jolokia,odl-ovsdb-southbound-impl-rest, 57452d0e-67df-43b2-8cae-b9409b045dc0 02:09:27 02:09:27 # 02:09:27 # Resource repositories (OBR) that the features resolver can use 02:09:27 # to resolve requirements/capabilities 02:09:27 # 02:09:27 # The format of the resourceRepositories is 02:09:27 # resourceRepositories=[xml:url|json:url],... 02:09:27 # for Instance: 02:09:27 # 02:09:27 #resourceRepositories=xml:http://host/path/to/index.xml 02:09:27 # or 02:09:27 #resourceRepositories=json:http://host/path/to/index.json 02:09:27 # 02:09:27 02:09:27 # 02:09:27 # Defines if the boot features are started in asynchronous mode (in a dedicated thread) 02:09:27 # 02:09:27 featuresBootAsynchronous=false 02:09:27 02:09:27 # 02:09:27 # Service requirements enforcement 02:09:27 # 02:09:27 # By default, the feature resolver checks the service requirements/capabilities of 02:09:27 # bundles for new features (xml schema >= 1.3.0) in order to automatically installs 02:09:27 # the required bundles. 02:09:27 # The following flag can have those values: 02:09:27 # - disable: service requirements are completely ignored 02:09:27 # - default: service requirements are ignored for old features 02:09:27 # - enforce: service requirements are always verified 02:09:27 # 02:09:27 #serviceRequirements=default 02:09:27 02:09:27 # 02:09:27 # Store cfg file for config element in feature 02:09:27 # 02:09:27 #configCfgStore=true 02:09:27 02:09:27 # 02:09:27 # Define if the feature service automatically refresh bundles 02:09:27 # 02:09:27 autoRefresh=true 02:09:27 02:09:27 # 02:09:27 # Configuration of features processing mechanism (overrides, blacklisting, modification of features) 02:09:27 # XML file defines instructions related to features processing 02:09:27 # versions.properties may declare properties to resolve placeholders in XML file 02:09:27 # both files are relative to ${karaf.etc} 02:09:27 # 02:09:27 #featureProcessing=org.apache.karaf.features.xml 02:09:27 #featureProcessingVersions=versions.properties 02:09:27 + configure_karaf_log karaf4 '' 02:09:27 + local -r karaf_version=karaf4 02:09:27 + local -r controllerdebugmap= 02:09:27 + local logapi=log4j 02:09:27 + grep log4j2 /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:27 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:27 log4j2.rootLogger.level = INFO 02:09:27 #log4j2.rootLogger.type = asyncRoot 02:09:27 #log4j2.rootLogger.includeLocation = false 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:27 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:27 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:27 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:27 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:27 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:27 log4j2.logger.spifly.level = WARN 02:09:27 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:27 log4j2.logger.audit.level = INFO 02:09:27 log4j2.logger.audit.additivity = false 02:09:27 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:27 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:27 log4j2.appender.console.type = Console 02:09:27 log4j2.appender.console.name = Console 02:09:27 log4j2.appender.console.layout.type = PatternLayout 02:09:27 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:27 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:27 log4j2.appender.rolling.name = RollingFile 02:09:27 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:27 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:27 #log4j2.appender.rolling.immediateFlush = false 02:09:27 log4j2.appender.rolling.append = true 02:09:27 log4j2.appender.rolling.layout.type = PatternLayout 02:09:27 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:27 log4j2.appender.rolling.policies.type = Policies 02:09:27 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:27 log4j2.appender.rolling.policies.size.size = 64MB 02:09:27 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:27 log4j2.appender.rolling.strategy.max = 7 02:09:27 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:27 log4j2.appender.audit.name = AuditRollingFile 02:09:27 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:27 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:27 log4j2.appender.audit.append = true 02:09:27 log4j2.appender.audit.layout.type = PatternLayout 02:09:27 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:27 log4j2.appender.audit.policies.type = Policies 02:09:27 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:27 log4j2.appender.audit.policies.size.size = 8MB 02:09:27 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:27 log4j2.appender.audit.strategy.max = 7 02:09:27 log4j2.appender.osgi.type = PaxOsgi 02:09:27 log4j2.appender.osgi.name = PaxOsgi 02:09:27 log4j2.appender.osgi.filter = * 02:09:27 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:27 #log4j2.logger.aether.level = TRACE 02:09:27 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:27 #log4j2.logger.http-headers.level = DEBUG 02:09:27 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:27 #log4j2.logger.maven.level = TRACE 02:09:27 + logapi=log4j2 02:09:27 Configuring the karaf log... karaf_version: karaf4, logapi: log4j2 02:09:27 + echo 'Configuring the karaf log... karaf_version: karaf4, logapi: log4j2' 02:09:27 + '[' log4j2 == log4j2 ']' 02:09:27 + sed -ie 's/log4j2.appender.rolling.policies.size.size = 64MB/log4j2.appender.rolling.policies.size.size = 1GB/g' /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:27 + orgmodule=org.opendaylight.yangtools.yang.parser.repo.YangTextSchemaContextResolver 02:09:27 + orgmodule_=org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver 02:09:27 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN' 02:09:27 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN' 02:09:27 controllerdebugmap: 02:09:27 cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:27 + unset IFS 02:09:27 + echo 'controllerdebugmap: ' 02:09:27 + '[' -n '' ']' 02:09:27 + echo 'cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg' 02:09:27 + cat /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:27 ################################################################################ 02:09:27 # 02:09:27 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:27 # contributor license agreements. See the NOTICE file distributed with 02:09:27 # this work for additional information regarding copyright ownership. 02:09:27 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:27 # (the "License"); you may not use this file except in compliance with 02:09:27 # the License. You may obtain a copy of the License at 02:09:27 # 02:09:27 # http://www.apache.org/licenses/LICENSE-2.0 02:09:27 # 02:09:27 # Unless required by applicable law or agreed to in writing, software 02:09:27 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:27 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:27 # See the License for the specific language governing permissions and 02:09:27 # limitations under the License. 02:09:27 # 02:09:27 ################################################################################ 02:09:27 02:09:27 # Common pattern layout for appenders 02:09:27 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n 02:09:27 02:09:27 # Root logger 02:09:27 log4j2.rootLogger.level = INFO 02:09:27 # uncomment to use asynchronous loggers, which require mvn:com.lmax/disruptor/3.3.2 library 02:09:27 #log4j2.rootLogger.type = asyncRoot 02:09:27 #log4j2.rootLogger.includeLocation = false 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile 02:09:27 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi 02:09:27 log4j2.rootLogger.appenderRef.Console.ref = Console 02:09:27 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter 02:09:27 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF} 02:09:27 02:09:27 # Filters for logs marked by org.opendaylight.odlparent.Markers 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY 02:09:27 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL 02:09:27 02:09:27 # Loggers configuration 02:09:27 02:09:27 # Spifly logger 02:09:27 log4j2.logger.spifly.name = org.apache.aries.spifly 02:09:27 log4j2.logger.spifly.level = WARN 02:09:27 02:09:27 # Security audit logger 02:09:27 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit 02:09:27 log4j2.logger.audit.level = INFO 02:09:27 log4j2.logger.audit.additivity = false 02:09:27 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile 02:09:27 02:09:27 # Appenders configuration 02:09:27 02:09:27 # Console appender not used by default (see log4j2.rootLogger.appenderRefs) 02:09:27 log4j2.appender.console.type = Console 02:09:27 log4j2.appender.console.name = Console 02:09:27 log4j2.appender.console.layout.type = PatternLayout 02:09:27 log4j2.appender.console.layout.pattern = ${log4j2.pattern} 02:09:27 02:09:27 # Rolling file appender 02:09:27 log4j2.appender.rolling.type = RollingRandomAccessFile 02:09:27 log4j2.appender.rolling.name = RollingFile 02:09:27 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log 02:09:27 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i 02:09:27 # uncomment to not force a disk flush 02:09:27 #log4j2.appender.rolling.immediateFlush = false 02:09:27 log4j2.appender.rolling.append = true 02:09:27 log4j2.appender.rolling.layout.type = PatternLayout 02:09:27 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern} 02:09:27 log4j2.appender.rolling.policies.type = Policies 02:09:27 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy 02:09:27 log4j2.appender.rolling.policies.size.size = 1GB 02:09:27 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy 02:09:27 log4j2.appender.rolling.strategy.max = 7 02:09:27 02:09:27 # Audit file appender 02:09:27 log4j2.appender.audit.type = RollingRandomAccessFile 02:09:27 log4j2.appender.audit.name = AuditRollingFile 02:09:27 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log 02:09:27 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i 02:09:27 log4j2.appender.audit.append = true 02:09:27 log4j2.appender.audit.layout.type = PatternLayout 02:09:27 log4j2.appender.audit.layout.pattern = ${log4j2.pattern} 02:09:27 log4j2.appender.audit.policies.type = Policies 02:09:27 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy 02:09:27 log4j2.appender.audit.policies.size.size = 8MB 02:09:27 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy 02:09:27 log4j2.appender.audit.strategy.max = 7 02:09:27 02:09:27 # OSGi appender 02:09:27 log4j2.appender.osgi.type = PaxOsgi 02:09:27 log4j2.appender.osgi.name = PaxOsgi 02:09:27 log4j2.appender.osgi.filter = * 02:09:27 02:09:27 # help with identification of maven-related problems with pax-url-aether 02:09:27 #log4j2.logger.aether.name = shaded.org.eclipse.aether 02:09:27 #log4j2.logger.aether.level = TRACE 02:09:27 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers 02:09:27 #log4j2.logger.http-headers.level = DEBUG 02:09:27 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn 02:09:27 #log4j2.logger.maven.level = TRACE 02:09:27 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN 02:09:27 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN 02:09:27 Configure 02:09:27 java home: /usr/lib/jvm/java-21-openjdk-amd64 02:09:27 max memory: 2048m 02:09:27 memconf: /tmp/karaf-0.21.4/bin/setenv 02:09:27 + set_java_vars /usr/lib/jvm/java-21-openjdk-amd64 2048m /tmp/karaf-0.21.4/bin/setenv 02:09:27 + local -r java_home=/usr/lib/jvm/java-21-openjdk-amd64 02:09:27 + local -r controllermem=2048m 02:09:27 + local -r memconf=/tmp/karaf-0.21.4/bin/setenv 02:09:27 + echo Configure 02:09:27 + echo ' java home: /usr/lib/jvm/java-21-openjdk-amd64' 02:09:27 + echo ' max memory: 2048m' 02:09:27 + echo ' memconf: /tmp/karaf-0.21.4/bin/setenv' 02:09:27 + sed -ie 's%^# export JAVA_HOME%export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64}%g' /tmp/karaf-0.21.4/bin/setenv 02:09:27 + sed -ie 's/JAVA_MAX_MEM="2048m"/JAVA_MAX_MEM=2048m/g' /tmp/karaf-0.21.4/bin/setenv 02:09:27 cat /tmp/karaf-0.21.4/bin/setenv 02:09:27 + echo 'cat /tmp/karaf-0.21.4/bin/setenv' 02:09:27 + cat /tmp/karaf-0.21.4/bin/setenv 02:09:27 #!/bin/sh 02:09:27 # 02:09:27 # Licensed to the Apache Software Foundation (ASF) under one or more 02:09:27 # contributor license agreements. See the NOTICE file distributed with 02:09:27 # this work for additional information regarding copyright ownership. 02:09:27 # The ASF licenses this file to You under the Apache License, Version 2.0 02:09:27 # (the "License"); you may not use this file except in compliance with 02:09:27 # the License. You may obtain a copy of the License at 02:09:27 # 02:09:27 # http://www.apache.org/licenses/LICENSE-2.0 02:09:27 # 02:09:27 # Unless required by applicable law or agreed to in writing, software 02:09:27 # distributed under the License is distributed on an "AS IS" BASIS, 02:09:27 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 02:09:27 # See the License for the specific language governing permissions and 02:09:27 # limitations under the License. 02:09:27 # 02:09:27 02:09:27 # 02:09:27 # handle specific scripts; the SCRIPT_NAME is exactly the name of the Karaf 02:09:27 # script: client, instance, shell, start, status, stop, karaf 02:09:27 # 02:09:27 # if [ "${KARAF_SCRIPT}" == "SCRIPT_NAME" ]; then 02:09:27 # Actions go here... 02:09:27 # fi 02:09:27 02:09:27 # 02:09:27 # general settings which should be applied for all scripts go here; please keep 02:09:27 # in mind that it is possible that scripts might be executed more than once, e.g. 02:09:27 # in example of the start script where the start script is executed first and the 02:09:27 # karaf script afterwards. 02:09:27 # 02:09:27 02:09:27 # 02:09:27 # The following section shows the possible configuration options for the default 02:09:27 # karaf scripts 02:09:27 # 02:09:27 export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64} # Location of Java installation 02:09:27 # export JAVA_OPTS # Generic JVM options, for instance, where you can pass the memory configuration 02:09:27 # export JAVA_NON_DEBUG_OPTS # Additional non-debug JVM options 02:09:27 # export EXTRA_JAVA_OPTS # Additional JVM options 02:09:27 # export KARAF_HOME # Karaf home folder 02:09:27 # export KARAF_DATA # Karaf data folder 02:09:27 # export KARAF_BASE # Karaf base folder 02:09:27 # export KARAF_ETC # Karaf etc folder 02:09:27 # export KARAF_LOG # Karaf log folder 02:09:27 # export KARAF_SYSTEM_OPTS # First citizen Karaf options 02:09:27 # export KARAF_OPTS # Additional available Karaf options 02:09:27 # export KARAF_DEBUG # Enable debug mode 02:09:27 # export KARAF_REDIRECT # Enable/set the std/err redirection when using bin/start 02:09:27 # export KARAF_NOROOT # Prevent execution as root if set to true 02:09:27 Set Java version 02:09:27 + echo 'Set Java version' 02:09:27 + sudo /usr/sbin/alternatives --install /usr/bin/java java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 1 02:09:27 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:27 sudo: a password is required 02:09:27 + sudo /usr/sbin/alternatives --set java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:27 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper 02:09:27 sudo: a password is required 02:09:27 JDK default version ... 02:09:27 + echo 'JDK default version ...' 02:09:27 + java -version 02:09:27 openjdk version "21.0.9" 2025-10-21 02:09:27 OpenJDK Runtime Environment (build 21.0.9+10-Ubuntu-122.04) 02:09:27 OpenJDK 64-Bit Server VM (build 21.0.9+10-Ubuntu-122.04, mixed mode, sharing) 02:09:27 Set JAVA_HOME 02:09:27 + echo 'Set JAVA_HOME' 02:09:27 + export JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:27 + JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64 02:09:27 ++ readlink -e /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:27 Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:27 Listing all open ports on controller system... 02:09:27 + JAVA_RESOLVED=/usr/lib/jvm/java-21-openjdk-amd64/bin/java 02:09:27 + echo 'Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java' 02:09:27 + echo 'Listing all open ports on controller system...' 02:09:27 + netstat -pnatu 02:09:27 /tmp/configuration-script.sh: line 40: netstat: command not found 02:09:27 Configuring cluster 02:09:27 + '[' -f /tmp/custom_shard_config.txt ']' 02:09:27 + echo 'Configuring cluster' 02:09:27 + /tmp/karaf-0.21.4/bin/configure_cluster.sh 3 10.30.171.33 10.30.170.204 10.30.171.83 02:09:27 ################################################ 02:09:27 ## Configure Cluster ## 02:09:27 ################################################ 02:09:27 NOTE: Cluster configuration files not found. Copying from 02:09:27 /tmp/karaf-0.21.4/system/org/opendaylight/controller/sal-clustering-config/10.0.14 02:09:27 Configuring unique name in akka.conf 02:09:27 Configuring hostname in akka.conf 02:09:27 Configuring data and rpc seed nodes in akka.conf 02:09:27 modules = [ 02:09:27 02:09:27 { 02:09:27 name = "inventory" 02:09:27 namespace = "urn:opendaylight:inventory" 02:09:27 shard-strategy = "module" 02:09:27 }, 02:09:27 { 02:09:27 name = "topology" 02:09:27 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:27 shard-strategy = "module" 02:09:27 }, 02:09:27 { 02:09:27 name = "toaster" 02:09:27 namespace = "http://netconfcentral.org/ns/toaster" 02:09:27 shard-strategy = "module" 02:09:27 } 02:09:27 ] 02:09:27 Configuring replication type in module-shards.conf 02:09:27 ################################################ 02:09:27 ## NOTE: Manually restart controller to ## 02:09:27 ## apply configuration. ## 02:09:27 ################################################ 02:09:27 Dump akka.conf 02:09:27 + echo 'Dump akka.conf' 02:09:27 + cat /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:27 02:09:27 odl-cluster-data { 02:09:27 akka { 02:09:27 remote { 02:09:27 artery { 02:09:27 enabled = on 02:09:27 transport = tcp 02:09:27 canonical.hostname = "10.30.171.83" 02:09:27 canonical.port = 2550 02:09:27 } 02:09:27 } 02:09:27 02:09:27 cluster { 02:09:27 # Using artery. 02:09:27 seed-nodes = ["akka://opendaylight-cluster-data@10.30.171.33:2550", 02:09:27 "akka://opendaylight-cluster-data@10.30.170.204:2550", 02:09:27 "akka://opendaylight-cluster-data@10.30.171.83:2550"] 02:09:27 02:09:27 roles = ["member-3"] 02:09:27 02:09:27 # when under load we might trip a false positive on the failure detector 02:09:27 # failure-detector { 02:09:27 # heartbeat-interval = 4 s 02:09:27 # acceptable-heartbeat-pause = 16s 02:09:27 # } 02:09:27 } 02:09:27 02:09:27 persistence { 02:09:27 # By default the snapshots/journal directories live in KARAF_HOME. You can choose to put it somewhere else by 02:09:27 # modifying the following two properties. The directory location specified may be a relative or absolute path. 02:09:27 # The relative path is always relative to KARAF_HOME. 02:09:27 02:09:27 # snapshot-store.local.dir = "target/snapshots" 02:09:27 02:09:27 # Use lz4 compression for LocalSnapshotStore snapshots 02:09:27 snapshot-store.local.use-lz4-compression = false 02:09:27 # Size of blocks for lz4 compression: 64KB, 256KB, 1MB or 4MB 02:09:27 snapshot-store.local.lz4-blocksize = 256KB 02:09:27 } 02:09:27 disable-default-actor-system-quarantined-event-handling = "false" 02:09:27 } 02:09:27 } 02:09:27 Dump modules.conf 02:09:27 + echo 'Dump modules.conf' 02:09:27 + cat /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:27 modules = [ 02:09:27 02:09:27 { 02:09:27 name = "inventory" 02:09:27 namespace = "urn:opendaylight:inventory" 02:09:27 shard-strategy = "module" 02:09:27 }, 02:09:27 { 02:09:27 name = "topology" 02:09:27 namespace = "urn:TBD:params:xml:ns:yang:network-topology" 02:09:27 shard-strategy = "module" 02:09:27 }, 02:09:27 { 02:09:27 name = "toaster" 02:09:27 namespace = "http://netconfcentral.org/ns/toaster" 02:09:27 shard-strategy = "module" 02:09:27 } 02:09:27 ] 02:09:27 Dump module-shards.conf 02:09:27 + echo 'Dump module-shards.conf' 02:09:27 + cat /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:27 module-shards = [ 02:09:27 { 02:09:27 name = "default" 02:09:27 shards = [ 02:09:27 { 02:09:27 name = "default" 02:09:27 replicas = ["member-1", 02:09:27 "member-2", 02:09:27 "member-3"] 02:09:27 } 02:09:27 ] 02:09:27 }, 02:09:27 { 02:09:27 name = "inventory" 02:09:27 shards = [ 02:09:27 { 02:09:27 name="inventory" 02:09:27 replicas = ["member-1", 02:09:27 "member-2", 02:09:27 "member-3"] 02:09:27 } 02:09:27 ] 02:09:27 }, 02:09:27 { 02:09:27 name = "topology" 02:09:27 shards = [ 02:09:27 { 02:09:27 name="topology" 02:09:27 replicas = ["member-1", 02:09:27 "member-2", 02:09:27 "member-3"] 02:09:27 } 02:09:27 ] 02:09:27 }, 02:09:27 { 02:09:27 name = "toaster" 02:09:27 shards = [ 02:09:27 { 02:09:27 name="toaster" 02:09:27 replicas = ["member-1", 02:09:27 "member-2", 02:09:27 "member-3"] 02:09:27 } 02:09:27 ] 02:09:27 } 02:09:27 ] 02:09:27 Locating config plan to use... 02:09:27 Finished running config plans 02:09:27 Starting member-1 with IP address 10.30.171.33 02:09:27 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:28 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:28 Redirecting karaf console output to karaf_console.log 02:09:28 Starting controller... 02:09:28 start: Redirecting Karaf output to /tmp/karaf-0.21.4/data/log/karaf_console.log 02:09:28 Starting member-2 with IP address 10.30.170.204 02:09:28 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:28 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:09:28 Redirecting karaf console output to karaf_console.log 02:09:28 Starting controller... 02:09:28 start: Redirecting Karaf output to /tmp/karaf-0.21.4/data/log/karaf_console.log 02:09:28 Starting member-3 with IP address 10.30.171.83 02:09:28 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:29 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:09:29 Redirecting karaf console output to karaf_console.log 02:09:29 Starting controller... 02:09:29 start: Redirecting Karaf output to /tmp/karaf-0.21.4/data/log/karaf_console.log 02:09:29 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins7872369495520280136.sh 02:09:29 common-functions.sh is being sourced 02:09:29 common-functions environment: 02:09:29 MAVENCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.url.mvn.cfg 02:09:29 ACTUALFEATURES: 02:09:29 FEATURESCONF: /tmp/karaf-0.21.4/etc/org.apache.karaf.features.cfg 02:09:29 CUSTOMPROP: /tmp/karaf-0.21.4/etc/custom.properties 02:09:29 LOGCONF: /tmp/karaf-0.21.4/etc/org.ops4j.pax.logging.cfg 02:09:29 MEMCONF: /tmp/karaf-0.21.4/bin/setenv 02:09:29 CONTROLLERMEM: 2048m 02:09:29 AKKACONF: /tmp/karaf-0.21.4/configuration/initial/akka.conf 02:09:29 MODULESCONF: /tmp/karaf-0.21.4/configuration/initial/modules.conf 02:09:29 MODULESHARDSCONF: /tmp/karaf-0.21.4/configuration/initial/module-shards.conf 02:09:29 SUITES: 02:09:29 02:09:29 + echo '#################################################' 02:09:29 ################################################# 02:09:29 + echo '## Verify Cluster is UP ##' 02:09:29 ## Verify Cluster is UP ## 02:09:29 + echo '#################################################' 02:09:29 ################################################# 02:09:29 + create_post_startup_script 02:09:29 + cat 02:09:29 + copy_and_run_post_startup_script 02:09:29 + seed_index=1 02:09:29 ++ seq 1 3 02:09:29 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:09:29 + CONTROLLERIP=ODL_SYSTEM_1_IP 02:09:29 + echo 'Execute the post startup script on controller 10.30.171.33' 02:09:29 Execute the post startup script on controller 10.30.171.33 02:09:29 + scp /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/post-startup-script.sh 10.30.171.33:/tmp/ 02:09:29 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:29 + ssh 10.30.171.33 'bash /tmp/post-startup-script.sh 1' 02:09:29 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:09:29 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:34 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:39 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:44 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:49 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:54 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:09:59 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:04 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:09 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:14 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:19 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:24 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:29 Waiting up to 3 minutes for controller to come up, checking every 5 seconds... 02:10:34 2025-12-30T02:10:03,778 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:10:34 Controller is UP 02:10:34 2025-12-30T02:10:03,778 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:10:34 Listing all open ports on controller system... 02:10:34 /tmp/post-startup-script.sh: line 51: netstat: command not found 02:10:34 looking for "BindException: Address already in use" in log file 02:10:34 looking for "server is unhealthy" in log file 02:10:34 + '[' 1 == 0 ']' 02:10:34 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:10:34 + CONTROLLERIP=ODL_SYSTEM_2_IP 02:10:34 + echo 'Execute the post startup script on controller 10.30.170.204' 02:10:34 Execute the post startup script on controller 10.30.170.204 02:10:34 + scp /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/post-startup-script.sh 10.30.170.204:/tmp/ 02:10:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:10:35 + ssh 10.30.170.204 'bash /tmp/post-startup-script.sh 2' 02:10:35 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:10:35 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:40 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:45 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:50 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:10:55 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:00 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:05 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:10 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:15 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:20 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:25 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:30 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:35 Waiting up to 3 minutes for controller to come up, checking every 5 seconds... 02:11:40 2025-12-30T02:10:03,237 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:11:40 Controller is UP 02:11:40 2025-12-30T02:10:03,237 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:11:40 Listing all open ports on controller system... 02:11:40 looking for "BindException: Address already in use" in log file 02:11:40 looking for "server is unhealthy" in log file 02:11:40 /tmp/post-startup-script.sh: line 51: netstat: command not found 02:11:40 + '[' 2 == 0 ']' 02:11:40 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:11:40 + CONTROLLERIP=ODL_SYSTEM_3_IP 02:11:40 + echo 'Execute the post startup script on controller 10.30.171.83' 02:11:40 Execute the post startup script on controller 10.30.171.83 02:11:40 + scp /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/post-startup-script.sh 10.30.171.83:/tmp/ 02:11:40 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:11:41 + ssh 10.30.171.83 'bash /tmp/post-startup-script.sh 3' 02:11:41 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:11:41 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:46 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:51 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:11:56 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:01 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:06 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:11 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:16 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:21 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:26 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:31 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:36 /tmp/post-startup-script.sh: line 4: netstat: command not found 02:12:41 Waiting up to 3 minutes for controller to come up, checking every 5 seconds... 02:12:46 2025-12-30T02:10:03,011 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:12:46 Controller is UP 02:12:46 2025-12-30T02:10:03,011 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 207 - org.opendaylight.infrautils.ready-api - 7.1.7 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.] 02:12:46 Listing all open ports on controller system... 02:12:46 /tmp/post-startup-script.sh: line 51: netstat: command not found 02:12:46 looking for "BindException: Address already in use" in log file 02:12:46 looking for "server is unhealthy" in log file 02:12:46 + '[' 0 == 0 ']' 02:12:46 + seed_index=1 02:12:46 + dump_controller_threads 02:12:46 ++ seq 1 3 02:12:46 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:46 + CONTROLLERIP=ODL_SYSTEM_1_IP 02:12:46 + echo 'Let'\''s take the karaf thread dump' 02:12:46 Let's take the karaf thread dump 02:12:46 + ssh 10.30.171.33 'sudo ps aux' 02:12:46 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:12:47 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_before.log 02:12:47 ++ grep -v grep 02:12:47 ++ tr -s ' ' 02:12:47 ++ cut -f2 '-d ' 02:12:47 + pid=2042 02:12:47 + echo 'karaf main: org.apache.karaf.main.Main, pid:2042' 02:12:47 karaf main: org.apache.karaf.main.Main, pid:2042 02:12:47 + ssh 10.30.171.33 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2042' 02:12:47 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:12:47 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:47 + CONTROLLERIP=ODL_SYSTEM_2_IP 02:12:47 + echo 'Let'\''s take the karaf thread dump' 02:12:47 Let's take the karaf thread dump 02:12:47 + ssh 10.30.170.204 'sudo ps aux' 02:12:47 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:12:48 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_before.log 02:12:48 ++ grep -v grep 02:12:48 ++ cut -f2 '-d ' 02:12:48 ++ tr -s ' ' 02:12:48 + pid=2045 02:12:48 + echo 'karaf main: org.apache.karaf.main.Main, pid:2045' 02:12:48 karaf main: org.apache.karaf.main.Main, pid:2045 02:12:48 + ssh 10.30.170.204 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2045' 02:12:48 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:12:48 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:48 + CONTROLLERIP=ODL_SYSTEM_3_IP 02:12:48 + echo 'Let'\''s take the karaf thread dump' 02:12:48 Let's take the karaf thread dump 02:12:48 + ssh 10.30.171.83 'sudo ps aux' 02:12:48 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:12:49 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_before.log 02:12:49 ++ cut -f2 '-d ' 02:12:49 ++ grep -v grep 02:12:49 ++ tr -s ' ' 02:12:49 + pid=2034 02:12:49 + echo 'karaf main: org.apache.karaf.main.Main, pid:2034' 02:12:49 karaf main: org.apache.karaf.main.Main, pid:2034 02:12:49 + ssh 10.30.171.83 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2034' 02:12:49 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:12:49 + '[' 0 -gt 0 ']' 02:12:49 + echo 'Generating controller variables...' 02:12:49 Generating controller variables... 02:12:49 ++ seq 1 3 02:12:49 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:49 + CONTROLLERIP=ODL_SYSTEM_1_IP 02:12:49 + odl_variables=' -v ODL_SYSTEM_1_IP:10.30.171.33' 02:12:49 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:49 + CONTROLLERIP=ODL_SYSTEM_2_IP 02:12:49 + odl_variables=' -v ODL_SYSTEM_1_IP:10.30.171.33 -v ODL_SYSTEM_2_IP:10.30.170.204' 02:12:49 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:12:49 + CONTROLLERIP=ODL_SYSTEM_3_IP 02:12:49 + odl_variables=' -v ODL_SYSTEM_1_IP:10.30.171.33 -v ODL_SYSTEM_2_IP:10.30.170.204 -v ODL_SYSTEM_3_IP:10.30.171.83' 02:12:49 + echo 'Generating mininet variables...' 02:12:49 Generating mininet variables... 02:12:49 ++ seq 1 1 02:12:49 + for i in $(seq 1 "${NUM_TOOLS_SYSTEM}") 02:12:49 + MININETIP=TOOLS_SYSTEM_1_IP 02:12:49 + tools_variables=' -v TOOLS_SYSTEM_1_IP:10.30.171.80' 02:12:49 + get_test_suites SUITES 02:12:49 + local __suite_list=SUITES 02:12:49 + echo 'Locating test plan to use...' 02:12:49 Locating test plan to use... 02:12:49 + testplan_filepath=/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/testplans/ovsdb-upstream-clustering-scandium.txt 02:12:49 + '[' '!' -f /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/testplans/ovsdb-upstream-clustering-scandium.txt ']' 02:12:49 + testplan_filepath=/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/testplans/ovsdb-upstream-clustering.txt 02:12:49 + '[' disabled '!=' disabled ']' 02:12:49 + echo 'Changing the testplan path...' 02:12:49 Changing the testplan path... 02:12:49 + sed s:integration:/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/testplans/ovsdb-upstream-clustering.txt 02:12:49 + cat testplan.txt 02:12:49 # Place the suites in run order: 02:12:49 /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster 02:12:49 /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster 02:12:49 + '[' -z '' ']' 02:12:49 ++ grep -E -v '(^[[:space:]]*#|^[[:space:]]*$)' testplan.txt 02:12:49 ++ tr '\012' ' ' 02:12:49 + suite_list='/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster ' 02:12:49 + eval 'SUITES='\''/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster '\''' 02:12:49 ++ SUITES='/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster ' 02:12:49 + echo 'Starting Robot test suites /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster ...' 02:12:49 Starting Robot test suites /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster ... 02:12:49 + robot -N ovsdb-upstream-clustering.txt --removekeywords wuks -e exclude -e skip_if_scandium -v BUNDLEFOLDER:karaf-0.21.4 -v BUNDLE_URL:https://nexus.opendaylight.org/content/repositories//autorelease-9485/org/opendaylight/integration/karaf/0.21.4/karaf-0.21.4.zip -v CONTROLLER:10.30.171.33 -v CONTROLLER1:10.30.170.204 -v CONTROLLER2:10.30.171.83 -v CONTROLLER_USER:jenkins -v JAVA_HOME:/usr/lib/jvm/java-21-openjdk-amd64 -v JDKVERSION:openjdk21 -v JENKINS_WORKSPACE:/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium -v MININET:10.30.171.80 -v MININET1: -v MININET2: -v MININET_USER:jenkins -v NEXUSURL_PREFIX:https://nexus.opendaylight.org -v NUM_ODL_SYSTEM:3 -v NUM_TOOLS_SYSTEM:1 -v ODL_STREAM:scandium -v ODL_SYSTEM_IP:10.30.171.33 -v ODL_SYSTEM_1_IP:10.30.171.33 -v ODL_SYSTEM_2_IP:10.30.170.204 -v ODL_SYSTEM_3_IP:10.30.171.83 -v ODL_SYSTEM_USER:jenkins -v TOOLS_SYSTEM_IP:10.30.171.80 -v TOOLS_SYSTEM_1_IP:10.30.171.80 -v TOOLS_SYSTEM_USER:jenkins -v USER_HOME:/home/jenkins -v IS_KARAF_APPL:True -v WORKSPACE:/tmp /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/test/csit/suites/ovsdb/Southbound_Cluster 02:12:49 ============================================================================== 02:12:49 ovsdb-upstream-clustering.txt 02:12:49 ============================================================================== 02:12:49 ovsdb-upstream-clustering.txt.Southbound Cluster 02:12:49 ============================================================================== 02:12:50 ovsdb-upstream-clustering.txt.Southbound Cluster.Ovsdb Southbound Cluster :... 02:12:50 ============================================================================== 02:12:55 Check Shards Status Before Fail :: Check Status for all shards in ... | PASS | 02:13:01 ------------------------------------------------------------------------------ 02:13:01 Start OVS Multiple Connections :: Connect OVS to all cluster insta... | PASS | 02:13:05 ------------------------------------------------------------------------------ 02:13:05 Check Entity Owner Status And Find Owner and Candidate Before Fail... | FAIL | 02:13:27 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/9a5df812-eb49-4477-a37e-2d464c02791d 02:13:27 ------------------------------------------------------------------------------ 02:13:27 Create Bridge Manually and Verify Before Fail :: Create bridge wit... | PASS | 02:13:28 ------------------------------------------------------------------------------ 02:13:28 Add Port Manually and Verify Before Fail :: Add port with OVS comm... | PASS | 02:13:29 ------------------------------------------------------------------------------ 02:13:29 Create Tap Device Before Fail :: Create tap devices to add to the ... | PASS | 02:13:31 ------------------------------------------------------------------------------ 02:13:31 Add Tap Device Manually and Verify Before Fail :: Add tap devices ... | PASS | 02:13:32 ------------------------------------------------------------------------------ 02:13:32 Delete the Bridge Manually and Verify Before Fail :: Delete bridge... | PASS | 02:13:33 ------------------------------------------------------------------------------ 02:13:33 Create Bridge In Owner and Verify Before Fail :: Create Bridge in ... | FAIL | 02:13:33 Variable '${original_owner}' not found. 02:13:33 ------------------------------------------------------------------------------ 02:13:33 Create Port In Owner and Verify Before Fail :: Create Port in Owne... | FAIL | 02:13:34 Variable '${original_owner}' not found. 02:13:34 ------------------------------------------------------------------------------ 02:13:34 Modify the destination IP of Port In Owner Before Fail :: Modify t... | FAIL | 02:13:34 Variable '${original_owner}' not found. 02:13:34 ------------------------------------------------------------------------------ 02:13:34 Verify Port Is Modified Before Fail :: Verify port is modified in ... | FAIL | 02:13:40 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9a5df812-eb49-4477-a37e-2d464c02791d%2Fbridge%2Fbr01?content=nonconfig 02:13:40 ------------------------------------------------------------------------------ 02:13:40 Delete Port In Owner Before Fail :: Delete port in Owner and verif... | FAIL | 02:13:40 Variable '${original_owner}' not found. 02:13:40 ------------------------------------------------------------------------------ 02:13:40 Delete Bridge In Owner And Verify Before Fail :: Delete bridge in ... | FAIL | 02:13:41 Variable '${original_owner}' not found. 02:13:41 ------------------------------------------------------------------------------ 02:13:41 Kill Owner Instance :: Kill Owner Instance and verify it is dead | FAIL | 02:13:41 Variable '${original_owner}' not found. 02:13:41 ------------------------------------------------------------------------------ 02:13:41 Check Shards Status After Fail :: Create original cluster list and... | FAIL | 02:13:41 Variable '${new_cluster_list}' not found. 02:13:41 ------------------------------------------------------------------------------ 02:13:41 Check Entity Owner Status And Find Owner and Candidate After Fail ... | FAIL | 02:13:42 Variable '${original_candidate}' not found. 02:13:42 ------------------------------------------------------------------------------ 02:13:42 Create Bridge Manually and Verify After Fail :: Create bridge with... | FAIL | 02:13:42 Variable '${new_cluster_list}' not found. 02:13:42 ------------------------------------------------------------------------------ 02:13:42 Add Port Manually and Verify After Fail :: Add port with OVS comma... | FAIL | 02:13:42 Variable '${new_cluster_list}' not found. 02:13:42 ------------------------------------------------------------------------------ 02:13:42 Create Tap Device After Fail :: Create tap devices to add to the b... | PASS | 02:13:44 ------------------------------------------------------------------------------ 02:13:44 Add Tap Device Manually and Verify After Fail :: Add tap devices t... | FAIL | 02:13:45 Variable '${new_cluster_list}' not found. 02:13:45 ------------------------------------------------------------------------------ 02:13:45 Delete the Bridge Manually and Verify After Fail :: Delete bridge ... | FAIL | 02:13:45 Variable '${new_cluster_list}' not found. 02:13:45 ------------------------------------------------------------------------------ 02:13:45 Create Bridge In Owner and Verify After Fail :: Create Bridge in O... | FAIL | 02:13:45 Variable '${new_owner}' not found. 02:13:45 ------------------------------------------------------------------------------ 02:13:45 Create Port In Owner and Verify After Fail :: Create Port in Owner... | FAIL | 02:13:46 Variable '${new_owner}' not found. 02:13:46 ------------------------------------------------------------------------------ 02:13:46 Modify the destination IP of Port In Owner After Fail :: Modify th... | FAIL | 02:13:46 Variable '${new_owner}' not found. 02:13:46 ------------------------------------------------------------------------------ 02:13:46 Verify Port Is Modified After Fail :: Verify port is modified in a... | FAIL | 02:13:47 Variable '${new_cluster_list}' not found. 02:13:47 ------------------------------------------------------------------------------ 02:13:47 Start Old Owner Instance :: Start Owner Instance and verify it is ... | FAIL | 02:13:47 Variable '${original_owner}' not found. 02:13:47 ------------------------------------------------------------------------------ 02:13:47 Check Shards Status After Recover :: Create original cluster list ... | PASS | 02:13:50 ------------------------------------------------------------------------------ 02:13:50 Check Entity Owner Status After Recover :: Check Entity Owner Stat... | FAIL | 02:14:10 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/9a5df812-eb49-4477-a37e-2d464c02791d 02:14:10 ------------------------------------------------------------------------------ 02:14:10 Create Bridge Manually and Verify After Recover :: Create bridge w... | PASS | 02:14:11 ------------------------------------------------------------------------------ 02:14:11 Add Port Manually and Verify After Recover :: Add port with OVS co... | PASS | 02:14:13 ------------------------------------------------------------------------------ 02:14:13 Create Tap Device After Recover :: Create tap devices to add to th... | PASS | 02:14:14 ------------------------------------------------------------------------------ 02:14:14 Add Tap Device Manually and Verify After Recover :: Add tap device... | PASS | 02:14:15 ------------------------------------------------------------------------------ 02:14:15 Delete the Bridge Manually and Verify After Recover :: Delete brid... | PASS | 02:14:16 ------------------------------------------------------------------------------ 02:14:16 Verify Modified Port After Recover :: Verify modified port exists ... | FAIL | 02:14:22 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9a5df812-eb49-4477-a37e-2d464c02791d%2Fbridge%2Fbr01?content=nonconfig 02:14:22 ------------------------------------------------------------------------------ 02:14:22 Delete Port In New Owner After Recover :: Delete port in Owner and... | FAIL | 02:14:22 Variable '${new_owner}' not found. 02:14:22 ------------------------------------------------------------------------------ 02:14:22 Delete Bridge In New Owner And Verify After Recover :: Delete brid... | FAIL | 02:14:23 Variable '${new_owner}' not found. 02:14:23 ------------------------------------------------------------------------------ 02:14:23 Create Bridge In Old Owner and Verify After Recover :: Create Brid... | FAIL | 02:14:23 Variable '${original_owner}' not found. 02:14:23 ------------------------------------------------------------------------------ 02:14:23 Create Port In Old Owner and Verify After Recover :: Create Port i... | FAIL | 02:14:23 Variable '${original_owner}' not found. 02:14:23 ------------------------------------------------------------------------------ 02:14:23 Modify the destination IP of Port In Old Owner After Recover :: Mo... | FAIL | 02:14:24 Variable '${original_owner}' not found. 02:14:24 ------------------------------------------------------------------------------ 02:14:24 Verify Port Is Modified After Recover :: Verify port is modified i... | FAIL | 02:14:29 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9a5df812-eb49-4477-a37e-2d464c02791d%2Fbridge%2Fbr01?content=nonconfig 02:14:29 ------------------------------------------------------------------------------ 02:14:29 Delete Port In Old Owner After Recover :: Delete port in Owner and... | FAIL | 02:14:30 Variable '${original_owner}' not found. 02:14:30 ------------------------------------------------------------------------------ 02:14:30 Delete Bridge In Old Owner And Verify After Recover :: Delete brid... | FAIL | 02:14:30 Variable '${original_owner}' not found. 02:14:30 ------------------------------------------------------------------------------ 02:14:30 Cleans Up Test Environment For Next Suite :: Cleans up test enviro... | PASS | 02:14:34 ------------------------------------------------------------------------------ 02:14:34 ovsdb-upstream-clustering.txt.Southbound Cluster.Ovsdb Southbound ... | FAIL | 02:14:34 44 tests, 15 passed, 29 failed 02:14:34 ============================================================================== 02:14:35 ovsdb-upstream-clustering.txt.Southbound Cluster.Southbound Cluster Extensi... 02:14:35 ============================================================================== 02:14:38 Check Shards Status Before Fail :: Check Status for all shards in ... | PASS | 02:14:40 ------------------------------------------------------------------------------ 02:14:40 Start OVS Multiple Connections :: Connect OVS to all cluster insta... | PASS | 02:14:45 ------------------------------------------------------------------------------ 02:14:45 Check Entity Owner Status And Find Owner and Candidate Before Fail... | FAIL | 02:15:06 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/b935fb21-f52c-4de6-84ce-66f6b10a508b 02:15:06 ------------------------------------------------------------------------------ 02:15:06 Create Bridge Manually and Verify Before Fail :: Create bridge wit... | PASS | 02:15:07 ------------------------------------------------------------------------------ 02:15:07 Add Port Manually and Verify Before Fail :: Add port with OVS comm... | PASS | 02:15:08 ------------------------------------------------------------------------------ 02:15:08 Delete the Bridge Manually and Verify Before Fail :: Delete bridge... | PASS | 02:15:09 ------------------------------------------------------------------------------ 02:15:09 Create Bridge In Owner and Verify Before Fail :: Create Bridge in ... | FAIL | 02:15:09 Variable '${original_owner}' not found. 02:15:09 ------------------------------------------------------------------------------ 02:15:09 Create Port In Owner and Verify Before Fail :: Create Port in Owne... | FAIL | 02:15:10 Variable '${original_owner}' not found. 02:15:10 ------------------------------------------------------------------------------ 02:15:10 Modify the destination IP of Port In Owner Before Fail :: Modify t... | FAIL | 02:15:10 Variable '${original_owner}' not found. 02:15:10 ------------------------------------------------------------------------------ 02:15:10 Verify Port Is Modified Before Fail :: Verify port is modified in ... | FAIL | 02:15:16 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2Fb935fb21-f52c-4de6-84ce-66f6b10a508b%2Fbridge%2Fbr01?content=nonconfig 02:15:16 ------------------------------------------------------------------------------ 02:15:16 Delete Port In Owner Before Fail :: Delete port in Owner and verif... | FAIL | 02:15:16 Variable '${original_owner}' not found. 02:15:16 ------------------------------------------------------------------------------ 02:15:16 Delete Bridge In Owner And Verify Before Fail :: Delete bridge in ... | FAIL | 02:15:16 Variable '${original_owner}' not found. 02:15:16 ------------------------------------------------------------------------------ 02:15:16 Kill Candidate Instance :: Kill Owner Instance and verify it is dead | FAIL | 02:15:17 Variable '${original_candidate}' not found. 02:15:17 ------------------------------------------------------------------------------ 02:15:17 Check Shards Status After Fail :: Create original cluster list and... | FAIL | 02:15:17 Variable '${new_cluster_list}' not found. 02:15:17 ------------------------------------------------------------------------------ 02:15:17 Check Entity Owner Status And Find Owner and Candidate After Fail ... | FAIL | 02:15:17 Variable '${original_owner}' not found. 02:15:17 ------------------------------------------------------------------------------ 02:15:17 Create Bridge Manually and Verify After Fail :: Create bridge with... | FAIL | 02:15:18 Variable '${new_cluster_list}' not found. 02:15:18 ------------------------------------------------------------------------------ 02:15:18 Add Port Manually and Verify After Fail :: Add port with OVS comma... | FAIL | 02:15:18 Variable '${new_cluster_list}' not found. 02:15:18 ------------------------------------------------------------------------------ 02:15:18 Delete the Bridge Manually and Verify After Fail :: Delete bridge ... | FAIL | 02:15:18 Variable '${new_cluster_list}' not found. 02:15:18 ------------------------------------------------------------------------------ 02:15:18 Create Bridge In Owner and Verify After Fail :: Create Bridge in O... | FAIL | 02:15:19 Variable '${new_owner}' not found. 02:15:19 ------------------------------------------------------------------------------ 02:15:19 Create Port In Owner and Verify After Fail :: Create Port in Owner... | FAIL | 02:15:19 Variable '${new_owner}' not found. 02:15:19 ------------------------------------------------------------------------------ 02:15:19 Modify the destination IP of Port In Owner After Fail :: Modify th... | FAIL | 02:15:20 Variable '${new_owner}' not found. 02:15:20 ------------------------------------------------------------------------------ 02:15:20 Verify Port Is Modified After Fail :: Verify port is modified in a... | FAIL | 02:15:20 Variable '${new_cluster_list}' not found. 02:15:20 ------------------------------------------------------------------------------ 02:15:20 Start Old Candidate Instance :: Start Owner Instance and verify it... | FAIL | 02:15:20 Variable '${original_candidate}' not found. 02:15:20 ------------------------------------------------------------------------------ 02:15:20 Check Shards Status After Recover :: Create original cluster list ... | PASS | 02:15:23 ------------------------------------------------------------------------------ 02:15:23 Check Entity Owner Status After Recover :: Check Entity Owner Stat... | FAIL | 02:15:44 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/b935fb21-f52c-4de6-84ce-66f6b10a508b 02:15:44 ------------------------------------------------------------------------------ 02:15:44 Create Bridge Manually and Verify After Recover :: Create bridge w... | PASS | 02:15:45 ------------------------------------------------------------------------------ 02:15:45 Add Port Manually and Verify After Recover :: Add port with OVS co... | PASS | 02:15:46 ------------------------------------------------------------------------------ 02:15:46 Delete the Bridge Manually and Verify After Recover :: Delete brid... | PASS | 02:15:47 ------------------------------------------------------------------------------ 02:15:47 Verify Modified Port After Recover :: Verify modified port exists ... | FAIL | 02:15:53 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2Fb935fb21-f52c-4de6-84ce-66f6b10a508b%2Fbridge%2Fbr01?content=nonconfig 02:15:53 ------------------------------------------------------------------------------ 02:15:53 Delete Port In New Owner After Recover :: Delete port in Owner and... | FAIL | 02:15:53 Variable '${new_owner}' not found. 02:15:53 ------------------------------------------------------------------------------ 02:15:53 Delete Bridge In New Owner And Verify After Recover :: Delete brid... | FAIL | 02:15:54 Variable '${new_owner}' not found. 02:15:54 ------------------------------------------------------------------------------ 02:15:54 Create Bridge In Old Candidate and Verify After Recover :: Create ... | FAIL | 02:15:54 Variable '${original_candidate}' not found. 02:15:54 ------------------------------------------------------------------------------ 02:15:54 Create Port In Old Owner and Verify After Recover :: Create Port i... | FAIL | 02:15:54 Variable '${original_candidate}' not found. 02:15:54 ------------------------------------------------------------------------------ 02:15:54 Modify the destination IP of Port In Old Owner After Recover :: Mo... | FAIL | 02:15:55 Variable '${original_candidate}' not found. 02:15:55 ------------------------------------------------------------------------------ 02:15:55 Verify Port Is Modified After Recover :: Verify port is modified i... | FAIL | 02:16:00 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2Fb935fb21-f52c-4de6-84ce-66f6b10a508b%2Fbridge%2Fbr01?content=nonconfig 02:16:00 ------------------------------------------------------------------------------ 02:16:00 Delete Port In Old Owner After Recover :: Delete port in Owner and... | FAIL | 02:16:01 Variable '${original_candidate}' not found. 02:16:01 ------------------------------------------------------------------------------ 02:16:01 Delete Bridge In Old Owner And Verify After Recover :: Delete brid... | FAIL | 02:16:01 Variable '${original_candidate}' not found. 02:16:01 ------------------------------------------------------------------------------ 02:16:01 Cleans Up Test Environment For Next Suite :: Cleans up test enviro... | PASS | 02:16:05 ------------------------------------------------------------------------------ 02:16:05 ovsdb-upstream-clustering.txt.Southbound Cluster.Southbound Cluste... | FAIL | 02:16:05 38 tests, 10 passed, 28 failed 02:16:05 ============================================================================== 02:16:05 ovsdb-upstream-clustering.txt.Southbound Cluster | FAIL | 02:16:05 82 tests, 25 passed, 57 failed 02:16:05 ============================================================================== 02:16:05 ovsdb-upstream-clustering.txt.Southbound Cluster 02:16:05 ============================================================================== 02:16:05 ovsdb-upstream-clustering.txt.Southbound Cluster.Ovsdb Southbound Cluster :... 02:16:05 ============================================================================== 02:16:08 Check Shards Status Before Fail :: Check Status for all shards in ... | PASS | 02:16:11 ------------------------------------------------------------------------------ 02:16:11 Start OVS Multiple Connections :: Connect OVS to all cluster insta... | PASS | 02:16:15 ------------------------------------------------------------------------------ 02:16:15 Check Entity Owner Status And Find Owner and Candidate Before Fail... | FAIL | 02:16:36 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/26851b3d-cb3a-4cc6-90e4-e79a88a66ec9 02:16:36 ------------------------------------------------------------------------------ 02:16:36 Create Bridge Manually and Verify Before Fail :: Create bridge wit... | PASS | 02:16:38 ------------------------------------------------------------------------------ 02:16:38 Add Port Manually and Verify Before Fail :: Add port with OVS comm... | PASS | 02:16:39 ------------------------------------------------------------------------------ 02:16:39 Create Tap Device Before Fail :: Create tap devices to add to the ... | PASS | 02:16:40 ------------------------------------------------------------------------------ 02:16:40 Add Tap Device Manually and Verify Before Fail :: Add tap devices ... | PASS | 02:16:41 ------------------------------------------------------------------------------ 02:16:41 Delete the Bridge Manually and Verify Before Fail :: Delete bridge... | PASS | 02:16:42 ------------------------------------------------------------------------------ 02:16:42 Create Bridge In Owner and Verify Before Fail :: Create Bridge in ... | FAIL | 02:16:43 Variable '${original_owner}' not found. 02:16:43 ------------------------------------------------------------------------------ 02:16:43 Create Port In Owner and Verify Before Fail :: Create Port in Owne... | FAIL | 02:16:43 Variable '${original_owner}' not found. 02:16:43 ------------------------------------------------------------------------------ 02:16:43 Modify the destination IP of Port In Owner Before Fail :: Modify t... | FAIL | 02:16:43 Variable '${original_owner}' not found. 02:16:43 ------------------------------------------------------------------------------ 02:16:43 Verify Port Is Modified Before Fail :: Verify port is modified in ... | FAIL | 02:16:49 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F26851b3d-cb3a-4cc6-90e4-e79a88a66ec9%2Fbridge%2Fbr01?content=nonconfig 02:16:49 ------------------------------------------------------------------------------ 02:16:49 Delete Port In Owner Before Fail :: Delete port in Owner and verif... | FAIL | 02:16:49 Variable '${original_owner}' not found. 02:16:49 ------------------------------------------------------------------------------ 02:16:49 Delete Bridge In Owner And Verify Before Fail :: Delete bridge in ... | FAIL | 02:16:50 Variable '${original_owner}' not found. 02:16:50 ------------------------------------------------------------------------------ 02:16:50 Kill Owner Instance :: Kill Owner Instance and verify it is dead | FAIL | 02:16:50 Variable '${original_owner}' not found. 02:16:50 ------------------------------------------------------------------------------ 02:16:50 Check Shards Status After Fail :: Create original cluster list and... | FAIL | 02:16:50 Variable '${new_cluster_list}' not found. 02:16:50 ------------------------------------------------------------------------------ 02:16:50 Check Entity Owner Status And Find Owner and Candidate After Fail ... | FAIL | 02:16:51 Variable '${original_candidate}' not found. 02:16:51 ------------------------------------------------------------------------------ 02:16:51 Create Bridge Manually and Verify After Fail :: Create bridge with... | FAIL | 02:16:51 Variable '${new_cluster_list}' not found. 02:16:51 ------------------------------------------------------------------------------ 02:16:51 Add Port Manually and Verify After Fail :: Add port with OVS comma... | FAIL | 02:16:51 Variable '${new_cluster_list}' not found. 02:16:51 ------------------------------------------------------------------------------ 02:16:51 Create Tap Device After Fail :: Create tap devices to add to the b... | PASS | 02:16:53 ------------------------------------------------------------------------------ 02:16:53 Add Tap Device Manually and Verify After Fail :: Add tap devices t... | FAIL | 02:16:53 Variable '${new_cluster_list}' not found. 02:16:53 ------------------------------------------------------------------------------ 02:16:53 Delete the Bridge Manually and Verify After Fail :: Delete bridge ... | FAIL | 02:16:54 Variable '${new_cluster_list}' not found. 02:16:54 ------------------------------------------------------------------------------ 02:16:54 Create Bridge In Owner and Verify After Fail :: Create Bridge in O... | FAIL | 02:16:54 Variable '${new_owner}' not found. 02:16:54 ------------------------------------------------------------------------------ 02:16:54 Create Port In Owner and Verify After Fail :: Create Port in Owner... | FAIL | 02:16:55 Variable '${new_owner}' not found. 02:16:55 ------------------------------------------------------------------------------ 02:16:55 Modify the destination IP of Port In Owner After Fail :: Modify th... | FAIL | 02:16:55 Variable '${new_owner}' not found. 02:16:55 ------------------------------------------------------------------------------ 02:16:55 Verify Port Is Modified After Fail :: Verify port is modified in a... | FAIL | 02:16:55 Variable '${new_cluster_list}' not found. 02:16:55 ------------------------------------------------------------------------------ 02:16:55 Start Old Owner Instance :: Start Owner Instance and verify it is ... | FAIL | 02:16:56 Variable '${original_owner}' not found. 02:16:56 ------------------------------------------------------------------------------ 02:16:56 Check Shards Status After Recover :: Create original cluster list ... | PASS | 02:16:58 ------------------------------------------------------------------------------ 02:16:58 Check Entity Owner Status After Recover :: Check Entity Owner Stat... | FAIL | 02:17:19 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/26851b3d-cb3a-4cc6-90e4-e79a88a66ec9 02:17:19 ------------------------------------------------------------------------------ 02:17:19 Create Bridge Manually and Verify After Recover :: Create bridge w... | PASS | 02:17:20 ------------------------------------------------------------------------------ 02:17:20 Add Port Manually and Verify After Recover :: Add port with OVS co... | PASS | 02:17:21 ------------------------------------------------------------------------------ 02:17:21 Create Tap Device After Recover :: Create tap devices to add to th... | PASS | 02:17:23 ------------------------------------------------------------------------------ 02:17:23 Add Tap Device Manually and Verify After Recover :: Add tap device... | PASS | 02:17:24 ------------------------------------------------------------------------------ 02:17:24 Delete the Bridge Manually and Verify After Recover :: Delete brid... | PASS | 02:17:25 ------------------------------------------------------------------------------ 02:17:25 Verify Modified Port After Recover :: Verify modified port exists ... | FAIL | 02:17:31 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F26851b3d-cb3a-4cc6-90e4-e79a88a66ec9%2Fbridge%2Fbr01?content=nonconfig 02:17:31 ------------------------------------------------------------------------------ 02:17:31 Delete Port In New Owner After Recover :: Delete port in Owner and... | FAIL | 02:17:31 Variable '${new_owner}' not found. 02:17:31 ------------------------------------------------------------------------------ 02:17:31 Delete Bridge In New Owner And Verify After Recover :: Delete brid... | FAIL | 02:17:31 Variable '${new_owner}' not found. 02:17:31 ------------------------------------------------------------------------------ 02:17:31 Create Bridge In Old Owner and Verify After Recover :: Create Brid... | FAIL | 02:17:32 Variable '${original_owner}' not found. 02:17:32 ------------------------------------------------------------------------------ 02:17:32 Create Port In Old Owner and Verify After Recover :: Create Port i... | FAIL | 02:17:32 Variable '${original_owner}' not found. 02:17:32 ------------------------------------------------------------------------------ 02:17:32 Modify the destination IP of Port In Old Owner After Recover :: Mo... | FAIL | 02:17:32 Variable '${original_owner}' not found. 02:17:32 ------------------------------------------------------------------------------ 02:17:32 Verify Port Is Modified After Recover :: Verify port is modified i... | FAIL | 02:17:38 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F26851b3d-cb3a-4cc6-90e4-e79a88a66ec9%2Fbridge%2Fbr01?content=nonconfig 02:17:38 ------------------------------------------------------------------------------ 02:17:38 Delete Port In Old Owner After Recover :: Delete port in Owner and... | FAIL | 02:17:38 Variable '${original_owner}' not found. 02:17:38 ------------------------------------------------------------------------------ 02:17:38 Delete Bridge In Old Owner And Verify After Recover :: Delete brid... | FAIL | 02:17:39 Variable '${original_owner}' not found. 02:17:39 ------------------------------------------------------------------------------ 02:17:39 Cleans Up Test Environment For Next Suite :: Cleans up test enviro... | PASS | 02:17:43 ------------------------------------------------------------------------------ 02:17:43 ovsdb-upstream-clustering.txt.Southbound Cluster.Ovsdb Southbound ... | FAIL | 02:17:43 44 tests, 15 passed, 29 failed 02:17:43 ============================================================================== 02:17:43 ovsdb-upstream-clustering.txt.Southbound Cluster.Southbound Cluster Extensi... 02:17:43 ============================================================================== 02:17:46 Check Shards Status Before Fail :: Check Status for all shards in ... | PASS | 02:17:50 ------------------------------------------------------------------------------ 02:17:50 Start OVS Multiple Connections :: Connect OVS to all cluster insta... | PASS | 02:17:54 ------------------------------------------------------------------------------ 02:17:54 Check Entity Owner Status And Find Owner and Candidate Before Fail... | FAIL | 02:18:15 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/9c24ff7f-fcb5-43be-8a0d-5e4342f2dd16 02:18:15 ------------------------------------------------------------------------------ 02:18:15 Create Bridge Manually and Verify Before Fail :: Create bridge wit... | PASS | 02:18:16 ------------------------------------------------------------------------------ 02:18:16 Add Port Manually and Verify Before Fail :: Add port with OVS comm... | PASS | 02:18:18 ------------------------------------------------------------------------------ 02:18:18 Delete the Bridge Manually and Verify Before Fail :: Delete bridge... | PASS | 02:18:18 ------------------------------------------------------------------------------ 02:18:18 Create Bridge In Owner and Verify Before Fail :: Create Bridge in ... | FAIL | 02:18:19 Variable '${original_owner}' not found. 02:18:19 ------------------------------------------------------------------------------ 02:18:19 Create Port In Owner and Verify Before Fail :: Create Port in Owne... | FAIL | 02:18:19 Variable '${original_owner}' not found. 02:18:19 ------------------------------------------------------------------------------ 02:18:19 Modify the destination IP of Port In Owner Before Fail :: Modify t... | FAIL | 02:18:20 Variable '${original_owner}' not found. 02:18:20 ------------------------------------------------------------------------------ 02:18:20 Verify Port Is Modified Before Fail :: Verify port is modified in ... | FAIL | 02:18:25 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9c24ff7f-fcb5-43be-8a0d-5e4342f2dd16%2Fbridge%2Fbr01?content=nonconfig 02:18:25 ------------------------------------------------------------------------------ 02:18:25 Delete Port In Owner Before Fail :: Delete port in Owner and verif... | FAIL | 02:18:25 Variable '${original_owner}' not found. 02:18:25 ------------------------------------------------------------------------------ 02:18:25 Delete Bridge In Owner And Verify Before Fail :: Delete bridge in ... | FAIL | 02:18:26 Variable '${original_owner}' not found. 02:18:26 ------------------------------------------------------------------------------ 02:18:26 Kill Candidate Instance :: Kill Owner Instance and verify it is dead | FAIL | 02:18:26 Variable '${original_candidate}' not found. 02:18:26 ------------------------------------------------------------------------------ 02:18:26 Check Shards Status After Fail :: Create original cluster list and... | FAIL | 02:18:26 Variable '${new_cluster_list}' not found. 02:18:26 ------------------------------------------------------------------------------ 02:18:26 Check Entity Owner Status And Find Owner and Candidate After Fail ... | FAIL | 02:18:27 Variable '${original_owner}' not found. 02:18:27 ------------------------------------------------------------------------------ 02:18:27 Create Bridge Manually and Verify After Fail :: Create bridge with... | FAIL | 02:18:27 Variable '${new_cluster_list}' not found. 02:18:27 ------------------------------------------------------------------------------ 02:18:27 Add Port Manually and Verify After Fail :: Add port with OVS comma... | FAIL | 02:18:28 Variable '${new_cluster_list}' not found. 02:18:28 ------------------------------------------------------------------------------ 02:18:28 Delete the Bridge Manually and Verify After Fail :: Delete bridge ... | FAIL | 02:18:28 Variable '${new_cluster_list}' not found. 02:18:28 ------------------------------------------------------------------------------ 02:18:28 Create Bridge In Owner and Verify After Fail :: Create Bridge in O... | FAIL | 02:18:28 Variable '${new_owner}' not found. 02:18:28 ------------------------------------------------------------------------------ 02:18:28 Create Port In Owner and Verify After Fail :: Create Port in Owner... | FAIL | 02:18:29 Variable '${new_owner}' not found. 02:18:29 ------------------------------------------------------------------------------ 02:18:29 Modify the destination IP of Port In Owner After Fail :: Modify th... | FAIL | 02:18:29 Variable '${new_owner}' not found. 02:18:29 ------------------------------------------------------------------------------ 02:18:29 Verify Port Is Modified After Fail :: Verify port is modified in a... | FAIL | 02:18:29 Variable '${new_cluster_list}' not found. 02:18:29 ------------------------------------------------------------------------------ 02:18:29 Start Old Candidate Instance :: Start Owner Instance and verify it... | FAIL | 02:18:30 Variable '${original_candidate}' not found. 02:18:30 ------------------------------------------------------------------------------ 02:18:30 Check Shards Status After Recover :: Create original cluster list ... | PASS | 02:18:32 ------------------------------------------------------------------------------ 02:18:32 Check Entity Owner Status After Recover :: Check Entity Owner Stat... | FAIL | 02:18:53 Keyword 'ClusterManagement.Verify_Owner_And_Successors_For_Device' failed after retrying for 20 seconds. The last error was: Could not parse owner and candidates for device ovsdb://uuid/9c24ff7f-fcb5-43be-8a0d-5e4342f2dd16 02:18:53 ------------------------------------------------------------------------------ 02:18:53 Create Bridge Manually and Verify After Recover :: Create bridge w... | PASS | 02:18:55 ------------------------------------------------------------------------------ 02:18:55 Add Port Manually and Verify After Recover :: Add port with OVS co... | PASS | 02:18:56 ------------------------------------------------------------------------------ 02:18:56 Delete the Bridge Manually and Verify After Recover :: Delete brid... | PASS | 02:18:57 ------------------------------------------------------------------------------ 02:18:57 Verify Modified Port After Recover :: Verify modified port exists ... | FAIL | 02:19:02 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9c24ff7f-fcb5-43be-8a0d-5e4342f2dd16%2Fbridge%2Fbr01?content=nonconfig 02:19:02 ------------------------------------------------------------------------------ 02:19:02 Delete Port In New Owner After Recover :: Delete port in Owner and... | FAIL | 02:19:03 Variable '${new_owner}' not found. 02:19:03 ------------------------------------------------------------------------------ 02:19:03 Delete Bridge In New Owner And Verify After Recover :: Delete brid... | FAIL | 02:19:03 Variable '${new_owner}' not found. 02:19:03 ------------------------------------------------------------------------------ 02:19:03 Create Bridge In Old Candidate and Verify After Recover :: Create ... | FAIL | 02:19:03 Variable '${original_candidate}' not found. 02:19:03 ------------------------------------------------------------------------------ 02:19:03 Create Port In Old Owner and Verify After Recover :: Create Port i... | FAIL | 02:19:04 Variable '${original_candidate}' not found. 02:19:04 ------------------------------------------------------------------------------ 02:19:04 Modify the destination IP of Port In Old Owner After Recover :: Mo... | FAIL | 02:19:04 Variable '${original_candidate}' not found. 02:19:04 ------------------------------------------------------------------------------ 02:19:04 Verify Port Is Modified After Recover :: Verify port is modified i... | FAIL | 02:19:10 Keyword 'ClusterManagement.Check_Item_Occurrence_Member_List_Or_All' failed after retrying for 5 seconds. The last error was: HTTPError: 409 Client Error: Conflict for url: http://10.30.171.33:8181/rests/data/network-topology:network-topology/topology=ovsdb%3A1/node=ovsdb%3A%2F%2Fuuid%2F9c24ff7f-fcb5-43be-8a0d-5e4342f2dd16%2Fbridge%2Fbr01?content=nonconfig 02:19:10 ------------------------------------------------------------------------------ 02:19:10 Delete Port In Old Owner After Recover :: Delete port in Owner and... | FAIL | 02:19:10 Variable '${original_candidate}' not found. 02:19:10 ------------------------------------------------------------------------------ 02:19:10 Delete Bridge In Old Owner And Verify After Recover :: Delete brid... | FAIL | 02:19:10 Variable '${original_candidate}' not found. 02:19:10 ------------------------------------------------------------------------------ 02:19:10 Cleans Up Test Environment For Next Suite :: Cleans up test enviro... | PASS | 02:19:14 ------------------------------------------------------------------------------ 02:19:14 ovsdb-upstream-clustering.txt.Southbound Cluster.Southbound Cluste... | FAIL | 02:19:14 38 tests, 10 passed, 28 failed 02:19:14 ============================================================================== 02:19:14 ovsdb-upstream-clustering.txt.Southbound Cluster | FAIL | 02:19:14 82 tests, 25 passed, 57 failed 02:19:14 ============================================================================== 02:19:14 ovsdb-upstream-clustering.txt | FAIL | 02:19:14 164 tests, 50 passed, 114 failed 02:19:14 ============================================================================== 02:19:14 Output: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/output.xml 02:19:19 Log: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/log.html 02:19:19 Report: /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/report.html 02:19:19 + true 02:19:19 + echo 'Examining the files in data/log and checking filesize' 02:19:19 Examining the files in data/log and checking filesize 02:19:19 + ssh 10.30.171.33 'ls -altr /tmp/karaf-0.21.4/data/log/' 02:19:19 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:20 total 1308 02:19:20 drwxrwxr-x 2 jenkins jenkins 4096 Dec 30 02:09 . 02:19:20 -rw-rw-r-- 1 jenkins jenkins 1720 Dec 30 02:09 karaf_console.log 02:19:20 drwxrwxr-x 9 jenkins jenkins 4096 Dec 30 02:10 .. 02:19:20 -rw-rw-r-- 1 jenkins jenkins 1326459 Dec 30 02:19 karaf.log 02:19:20 + ssh 10.30.171.33 'du -hs /tmp/karaf-0.21.4/data/log/*' 02:19:20 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:20 1.3M /tmp/karaf-0.21.4/data/log/karaf.log 02:19:20 4.0K /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:20 + ssh 10.30.170.204 'ls -altr /tmp/karaf-0.21.4/data/log/' 02:19:20 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:21 total 500 02:19:21 drwxrwxr-x 2 jenkins jenkins 4096 Dec 30 02:09 . 02:19:21 -rw-rw-r-- 1 jenkins jenkins 1720 Dec 30 02:09 karaf_console.log 02:19:21 drwxrwxr-x 9 jenkins jenkins 4096 Dec 30 02:10 .. 02:19:21 -rw-rw-r-- 1 jenkins jenkins 498410 Dec 30 02:19 karaf.log 02:19:21 + ssh 10.30.170.204 'du -hs /tmp/karaf-0.21.4/data/log/*' 02:19:21 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:21 488K /tmp/karaf-0.21.4/data/log/karaf.log 02:19:21 4.0K /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:21 + ssh 10.30.171.83 'ls -altr /tmp/karaf-0.21.4/data/log/' 02:19:21 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:21 total 492 02:19:21 drwxrwxr-x 2 jenkins jenkins 4096 Dec 30 02:09 . 02:19:21 -rw-rw-r-- 1 jenkins jenkins 1720 Dec 30 02:09 karaf_console.log 02:19:21 drwxrwxr-x 9 jenkins jenkins 4096 Dec 30 02:10 .. 02:19:21 -rw-rw-r-- 1 jenkins jenkins 488000 Dec 30 02:19 karaf.log 02:19:21 + ssh 10.30.171.83 'du -hs /tmp/karaf-0.21.4/data/log/*' 02:19:21 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:21 480K /tmp/karaf-0.21.4/data/log/karaf.log 02:19:21 4.0K /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:21 + set +e 02:19:21 ++ seq 1 3 02:19:21 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:21 + CONTROLLERIP=ODL_SYSTEM_1_IP 02:19:21 + echo 'Let'\''s take the karaf thread dump again' 02:19:21 Let's take the karaf thread dump again 02:19:21 + ssh 10.30.171.33 'sudo ps aux' 02:19:21 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:22 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_after.log 02:19:22 ++ grep -v grep 02:19:22 ++ tr -s ' ' 02:19:22 ++ cut -f2 '-d ' 02:19:22 + pid=2042 02:19:22 + echo 'karaf main: org.apache.karaf.main.Main, pid:2042' 02:19:22 karaf main: org.apache.karaf.main.Main, pid:2042 02:19:22 + ssh 10.30.171.33 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2042' 02:19:22 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:22 + echo 'killing karaf process...' 02:19:22 killing karaf process... 02:19:22 + ssh 10.30.171.33 bash -c 'ps axf | grep karaf | grep -v grep | awk '\''{print "kill -9 " $1}'\'' | sh' 02:19:22 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:22 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:22 + CONTROLLERIP=ODL_SYSTEM_2_IP 02:19:22 + echo 'Let'\''s take the karaf thread dump again' 02:19:22 Let's take the karaf thread dump again 02:19:22 + ssh 10.30.170.204 'sudo ps aux' 02:19:22 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:23 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_after.log 02:19:23 ++ grep -v grep 02:19:23 ++ cut -f2 '-d ' 02:19:23 ++ tr -s ' ' 02:19:23 + pid=2045 02:19:23 + echo 'karaf main: org.apache.karaf.main.Main, pid:2045' 02:19:23 karaf main: org.apache.karaf.main.Main, pid:2045 02:19:23 + ssh 10.30.170.204 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2045' 02:19:23 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:23 + echo 'killing karaf process...' 02:19:23 killing karaf process... 02:19:23 + ssh 10.30.170.204 bash -c 'ps axf | grep karaf | grep -v grep | awk '\''{print "kill -9 " $1}'\'' | sh' 02:19:23 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:23 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:23 + CONTROLLERIP=ODL_SYSTEM_3_IP 02:19:23 + echo 'Let'\''s take the karaf thread dump again' 02:19:23 Let's take the karaf thread dump again 02:19:23 + ssh 10.30.171.83 'sudo ps aux' 02:19:23 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:23 ++ grep org.apache.karaf.main.Main /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/ps_after.log 02:19:23 ++ grep -v grep 02:19:23 ++ tr -s ' ' 02:19:23 ++ cut -f2 '-d ' 02:19:23 + pid=2034 02:19:23 + echo 'karaf main: org.apache.karaf.main.Main, pid:2034' 02:19:23 karaf main: org.apache.karaf.main.Main, pid:2034 02:19:23 + ssh 10.30.171.83 '/usr/lib/jvm/java-21-openjdk-amd64/bin/jstack -l 2034' 02:19:23 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:24 + echo 'killing karaf process...' 02:19:24 killing karaf process... 02:19:24 + ssh 10.30.171.83 bash -c 'ps axf | grep karaf | grep -v grep | awk '\''{print "kill -9 " $1}'\'' | sh' 02:19:24 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:24 + sleep 5 02:19:29 ++ seq 1 3 02:19:29 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:29 + CONTROLLERIP=ODL_SYSTEM_1_IP 02:19:29 + echo 'Compressing karaf.log 1' 02:19:29 Compressing karaf.log 1 02:19:29 + ssh 10.30.171.33 gzip --best /tmp/karaf-0.21.4/data/log/karaf.log 02:19:29 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:29 + echo 'Fetching compressed karaf.log 1' 02:19:29 Fetching compressed karaf.log 1 02:19:29 + scp 10.30.171.33:/tmp/karaf-0.21.4/data/log/karaf.log.gz odl1_karaf.log.gz 02:19:29 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:30 + ssh 10.30.171.33 rm -f /tmp/karaf-0.21.4/data/log/karaf.log.gz 02:19:30 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:30 + scp 10.30.171.33:/tmp/karaf-0.21.4/data/log/karaf_console.log odl1_karaf_console.log 02:19:30 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:34 + ssh 10.30.171.33 rm -f /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:34 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:34 + echo 'Fetch GC logs' 02:19:34 Fetch GC logs 02:19:34 + mkdir -p gclogs-1 02:19:34 + scp '10.30.171.33:/tmp/karaf-0.21.4/data/log/*.log' gclogs-1/ 02:19:34 Warning: Permanently added '10.30.171.33' (ECDSA) to the list of known hosts. 02:19:34 scp: /tmp/karaf-0.21.4/data/log/*.log: No such file or directory 02:19:34 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:34 + CONTROLLERIP=ODL_SYSTEM_2_IP 02:19:34 + echo 'Compressing karaf.log 2' 02:19:34 Compressing karaf.log 2 02:19:34 + ssh 10.30.170.204 gzip --best /tmp/karaf-0.21.4/data/log/karaf.log 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 + echo 'Fetching compressed karaf.log 2' 02:19:34 Fetching compressed karaf.log 2 02:19:34 + scp 10.30.170.204:/tmp/karaf-0.21.4/data/log/karaf.log.gz odl2_karaf.log.gz 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 + ssh 10.30.170.204 rm -f /tmp/karaf-0.21.4/data/log/karaf.log.gz 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 + scp 10.30.170.204:/tmp/karaf-0.21.4/data/log/karaf_console.log odl2_karaf_console.log 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 + ssh 10.30.170.204 rm -f /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 + echo 'Fetch GC logs' 02:19:34 Fetch GC logs 02:19:34 + mkdir -p gclogs-2 02:19:34 + scp '10.30.170.204:/tmp/karaf-0.21.4/data/log/*.log' gclogs-2/ 02:19:34 Warning: Permanently added '10.30.170.204' (ECDSA) to the list of known hosts. 02:19:34 scp: /tmp/karaf-0.21.4/data/log/*.log: No such file or directory 02:19:34 + for i in $(seq 1 "${NUM_ODL_SYSTEM}") 02:19:34 + CONTROLLERIP=ODL_SYSTEM_3_IP 02:19:34 + echo 'Compressing karaf.log 3' 02:19:34 Compressing karaf.log 3 02:19:34 + ssh 10.30.171.83 gzip --best /tmp/karaf-0.21.4/data/log/karaf.log 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 + echo 'Fetching compressed karaf.log 3' 02:19:34 Fetching compressed karaf.log 3 02:19:34 + scp 10.30.171.83:/tmp/karaf-0.21.4/data/log/karaf.log.gz odl3_karaf.log.gz 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 + ssh 10.30.171.83 rm -f /tmp/karaf-0.21.4/data/log/karaf.log.gz 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 + scp 10.30.171.83:/tmp/karaf-0.21.4/data/log/karaf_console.log odl3_karaf_console.log 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 + ssh 10.30.171.83 rm -f /tmp/karaf-0.21.4/data/log/karaf_console.log 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 + echo 'Fetch GC logs' 02:19:34 Fetch GC logs 02:19:34 + mkdir -p gclogs-3 02:19:34 + scp '10.30.171.83:/tmp/karaf-0.21.4/data/log/*.log' gclogs-3/ 02:19:34 Warning: Permanently added '10.30.171.83' (ECDSA) to the list of known hosts. 02:19:34 scp: /tmp/karaf-0.21.4/data/log/*.log: No such file or directory 02:19:34 + echo 'Examine copied files' 02:19:34 Examine copied files 02:19:34 + ls -lt 02:19:34 total 26184 02:19:34 drwxrwxr-x. 2 jenkins jenkins 6 Dec 30 02:19 gclogs-3 02:19:34 -rw-rw-r--. 1 jenkins jenkins 1720 Dec 30 02:19 odl3_karaf_console.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 35335 Dec 30 02:19 odl3_karaf.log.gz 02:19:34 drwxrwxr-x. 2 jenkins jenkins 6 Dec 30 02:19 gclogs-2 02:19:34 -rw-rw-r--. 1 jenkins jenkins 1720 Dec 30 02:19 odl2_karaf_console.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 35449 Dec 30 02:19 odl2_karaf.log.gz 02:19:34 drwxrwxr-x. 2 jenkins jenkins 6 Dec 30 02:19 gclogs-1 02:19:34 -rw-rw-r--. 1 jenkins jenkins 1720 Dec 30 02:19 odl1_karaf_console.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 53706 Dec 30 02:19 odl1_karaf.log.gz 02:19:34 -rw-rw-r--. 1 jenkins jenkins 123075 Dec 30 02:19 karaf_3_2034_threads_after.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 13148 Dec 30 02:19 ps_after.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 121863 Dec 30 02:19 karaf_2_2045_threads_after.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 124405 Dec 30 02:19 karaf_1_2042_threads_after.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 258020 Dec 30 02:19 report.html 02:19:34 -rw-rw-r--. 1 jenkins jenkins 2956921 Dec 30 02:19 log.html 02:19:34 -rw-rw-r--. 1 jenkins jenkins 22712973 Dec 30 02:19 output.xml 02:19:34 -rw-rw-r--. 1 jenkins jenkins 245 Dec 30 02:12 testplan.txt 02:19:34 -rw-rw-r--. 1 jenkins jenkins 91678 Dec 30 02:12 karaf_3_2034_threads_before.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 13967 Dec 30 02:12 ps_before.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 90828 Dec 30 02:12 karaf_2_2045_threads_before.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 91669 Dec 30 02:12 karaf_1_2042_threads_before.log 02:19:34 -rw-rw-r--. 1 jenkins jenkins 3043 Dec 30 02:09 post-startup-script.sh 02:19:34 -rw-rw-r--. 1 jenkins jenkins 225 Dec 30 02:09 startup-script.sh 02:19:34 -rw-rw-r--. 1 jenkins jenkins 3237 Dec 30 02:09 configuration-script.sh 02:19:34 -rw-rw-r--. 1 jenkins jenkins 266 Dec 30 02:09 detect_variables.env 02:19:34 -rw-rw-r--. 1 jenkins jenkins 92 Dec 30 02:09 set_variables.env 02:19:34 -rw-rw-r--. 1 jenkins jenkins 354 Dec 30 02:09 slave_addresses.txt 02:19:34 -rw-rw-r--. 1 jenkins jenkins 570 Dec 30 02:08 requirements.txt 02:19:34 -rw-rw-r--. 1 jenkins jenkins 26 Dec 30 02:08 env.properties 02:19:34 -rw-rw-r--. 1 jenkins jenkins 334 Dec 30 02:06 stack-parameters.yaml 02:19:34 drwxrwxr-x. 7 jenkins jenkins 4096 Dec 30 02:05 test 02:19:34 drwxrwxr-x. 2 jenkins jenkins 6 Dec 30 02:05 test@tmp 02:19:34 + true 02:19:34 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/sh /tmp/jenkins4088748817319704472.sh 02:19:34 Cleaning up Robot installation... 02:19:34 $ ssh-agent -k 02:19:34 unset SSH_AUTH_SOCK; 02:19:34 unset SSH_AGENT_PID; 02:19:34 echo Agent pid 5159 killed; 02:19:34 [ssh-agent] Stopped. 02:19:34 Recording plot data 02:19:34 Robot results publisher started... 02:19:34 INFO: Checking test criticality is deprecated and will be dropped in a future release! 02:19:34 -Parsing output xml: 02:19:35 Done! 02:19:35 -Copying log files to build dir: 02:19:36 Done! 02:19:36 -Assigning results to build: 02:19:36 Done! 02:19:36 -Checking thresholds: 02:19:36 Done! 02:19:36 Done publishing Robot results. 02:19:36 Build step 'Publish Robot Framework test results' changed build result to UNSTABLE 02:19:36 [PostBuildScript] - [INFO] Executing post build scripts. 02:19:36 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins11595942880710937666.sh 02:19:36 Archiving csit artifacts 02:19:36 mv: cannot stat '*_1.png': No such file or directory 02:19:36 mv: cannot stat '/tmp/odl1_*': No such file or directory 02:19:36 mv: cannot stat '*_2.png': No such file or directory 02:19:36 mv: cannot stat '/tmp/odl2_*': No such file or directory 02:19:36 mv: cannot stat '*_3.png': No such file or directory 02:19:36 mv: cannot stat '/tmp/odl3_*': No such file or directory 02:19:36 % Total % Received % Xferd Average Speed Time Time Time Current 02:19:36 Dload Upload Total Spent Left Speed 02:19:36 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 1280k 0 1280k 0 0 3786k 0 --:--:-- --:--:-- --:--:-- 3775k 100 3093k 0 3093k 0 0 4818k 0 --:--:-- --:--:-- --:--:-- 4818k 02:19:37 Archive: robot-plugin.zip 02:19:37 inflating: ./archives/robot-plugin/log.html 02:19:37 inflating: ./archives/robot-plugin/output.xml 02:19:37 inflating: ./archives/robot-plugin/report.html 02:19:37 mv: cannot stat '*.log.gz': No such file or directory 02:19:37 mv: cannot stat '*.csv': No such file or directory 02:19:37 mv: cannot stat '*.png': No such file or directory 02:19:37 [PostBuildScript] - [INFO] Executing post build scripts. 02:19:37 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins6970692204280008402.sh 02:19:37 [PostBuildScript] - [INFO] Executing post build scripts. 02:19:37 [EnvInject] - Injecting environment variables from a build step. 02:19:37 [EnvInject] - Injecting as environment variables the properties content 02:19:37 OS_CLOUD=vex 02:19:37 OS_STACK_NAME=releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:19:37 02:19:37 [EnvInject] - Variables injected successfully. 02:19:37 provisioning config files... 02:19:37 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml 02:19:37 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins4121588669460388278.sh 02:19:37 ---> openstack-stack-delete.sh 02:19:37 Setup pyenv: 02:19:38 system 02:19:38 3.8.13 02:19:38 3.9.13 02:19:38 3.10.13 02:19:38 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:19:38 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:19:38 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:19:38 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:19:40 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. 02:19:40 lftools 0.37.18 requires urllib3<2.1.0, but you have urllib3 2.6.2 which is incompatible. 02:19:40 lf-activate-venv(): INFO: Base packages installed successfully 02:19:40 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes python-heatclient python-openstackclient urllib3~=1.26.15 02:19:56 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:19:56 INFO: Stack cost retrieval disabled, setting cost to 0 02:20:08 INFO: Deleting stack releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:20:08 Successfully deleted stack releng-ovsdb-csit-3node-upstream-clustering-only-scandium-493 02:20:08 [PostBuildScript] - [INFO] Executing post build scripts. 02:20:08 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins7513694593692271166.sh 02:20:08 ---> sysstat.sh 02:20:08 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins13630424225003171106.sh 02:20:08 ---> package-listing.sh 02:20:08 ++ facter osfamily 02:20:08 ++ tr '[:upper:]' '[:lower:]' 02:20:08 + OS_FAMILY=redhat 02:20:08 + workspace=/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium 02:20:08 + START_PACKAGES=/tmp/packages_start.txt 02:20:08 + END_PACKAGES=/tmp/packages_end.txt 02:20:08 + DIFF_PACKAGES=/tmp/packages_diff.txt 02:20:08 + PACKAGES=/tmp/packages_start.txt 02:20:08 + '[' /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium ']' 02:20:08 + PACKAGES=/tmp/packages_end.txt 02:20:08 + case "${OS_FAMILY}" in 02:20:08 + rpm -qa 02:20:08 + sort 02:20:09 + '[' -f /tmp/packages_start.txt ']' 02:20:09 + '[' -f /tmp/packages_end.txt ']' 02:20:09 + diff /tmp/packages_start.txt /tmp/packages_end.txt 02:20:09 + '[' /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium ']' 02:20:09 + mkdir -p /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/archives/ 02:20:09 + cp -f /tmp/packages_diff.txt /tmp/packages_end.txt /tmp/packages_start.txt /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/archives/ 02:20:09 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins8469184588552220579.sh 02:20:09 ---> capture-instance-metadata.sh 02:20:09 Setup pyenv: 02:20:09 system 02:20:09 3.8.13 02:20:09 3.9.13 02:20:09 3.10.13 02:20:09 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:20:10 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:20:10 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:20:10 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:20:12 lf-activate-venv(): INFO: Base packages installed successfully 02:20:12 lf-activate-venv(): INFO: Installing additional packages: lftools 02:20:25 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:20:25 INFO: Running in OpenStack, capturing instance metadata 02:20:25 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins12562733849476178782.sh 02:20:25 provisioning config files... 02:20:26 Could not find credentials [logs] for ovsdb-csit-3node-upstream-clustering-only-scandium #493 02:20:26 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium@tmp/config17296016859922935454tmp 02:20:26 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index] 02:20:26 Run condition [Regular expression match] enabling perform for step [Provide Configuration files] 02:20:26 provisioning config files... 02:20:26 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials 02:20:26 [EnvInject] - Injecting environment variables from a build step. 02:20:26 [EnvInject] - Injecting as environment variables the properties content 02:20:26 SERVER_ID=logs 02:20:26 02:20:26 [EnvInject] - Variables injected successfully. 02:20:26 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins16891917176037002386.sh 02:20:26 ---> create-netrc.sh 02:20:26 WARN: Log server credential not found. 02:20:26 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins4717152087576659037.sh 02:20:26 ---> python-tools-install.sh 02:20:26 Setup pyenv: 02:20:26 system 02:20:26 3.8.13 02:20:26 3.9.13 02:20:26 3.10.13 02:20:26 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:20:27 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:20:27 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:20:27 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:20:29 lf-activate-venv(): INFO: Base packages installed successfully 02:20:29 lf-activate-venv(): INFO: Installing additional packages: lftools 02:20:40 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:20:40 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins594606243802986175.sh 02:20:40 ---> sudo-logs.sh 02:20:40 Archiving 'sudo' log.. 02:20:40 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash /tmp/jenkins6831857504775931343.sh 02:20:40 ---> job-cost.sh 02:20:40 Setup pyenv: 02:20:40 system 02:20:40 3.8.13 02:20:40 3.9.13 02:20:40 3.10.13 02:20:40 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:20:41 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:20:41 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:20:41 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:20:42 lf-activate-venv(): INFO: Base packages installed successfully 02:20:42 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15 02:20:51 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:20:51 DEBUG: total: 0 02:20:51 INFO: Retrieving Stack Cost... 02:20:51 INFO: Retrieving Pricing Info for: v3-standard-2 02:20:51 INFO: Archiving Costs 02:20:51 [ovsdb-csit-3node-upstream-clustering-only-scandium] $ /bin/bash -l /tmp/jenkins11369136713218742500.sh 02:20:51 ---> logs-deploy.sh 02:20:51 Setup pyenv: 02:20:51 system 02:20:51 3.8.13 02:20:51 3.9.13 02:20:51 3.10.13 02:20:51 * 3.11.7 (set by /w/workspace/ovsdb-csit-3node-upstream-clustering-only-scandium/.python-version) 02:20:52 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-3V2V from file:/tmp/.os_lf_venv 02:20:52 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv) 02:20:52 lf-activate-venv(): INFO: Attempting to install with network-safe options... 02:20:54 lf-activate-venv(): INFO: Base packages installed successfully 02:20:54 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15 02:21:06 lf-activate-venv(): INFO: Adding /tmp/venv-3V2V/bin to PATH 02:21:06 WARNING: Nexus logging server not set 02:21:06 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/ovsdb-csit-3node-upstream-clustering-only-scandium/493/ 02:21:06 INFO: archiving logs to S3 02:21:07 ---> uname -a: 02:21:07 Linux prd-centos8-robot-2c-8g-17411.novalocal 4.18.0-553.5.1.el8.x86_64 #1 SMP Tue May 21 05:46:01 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux 02:21:07 02:21:07 02:21:07 ---> lscpu: 02:21:07 Architecture: x86_64 02:21:07 CPU op-mode(s): 32-bit, 64-bit 02:21:07 Byte Order: Little Endian 02:21:07 CPU(s): 2 02:21:07 On-line CPU(s) list: 0,1 02:21:07 Thread(s) per core: 1 02:21:07 Core(s) per socket: 1 02:21:07 Socket(s): 2 02:21:07 NUMA node(s): 1 02:21:07 Vendor ID: AuthenticAMD 02:21:07 CPU family: 23 02:21:07 Model: 49 02:21:07 Model name: AMD EPYC-Rome Processor 02:21:07 Stepping: 0 02:21:07 CPU MHz: 2800.000 02:21:07 BogoMIPS: 5600.00 02:21:07 Virtualization: AMD-V 02:21:07 Hypervisor vendor: KVM 02:21:07 Virtualization type: full 02:21:07 L1d cache: 32K 02:21:07 L1i cache: 32K 02:21:07 L2 cache: 512K 02:21:07 L3 cache: 16384K 02:21:07 NUMA node0 CPU(s): 0,1 02:21:07 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 xsaves clzero xsaveerptr wbnoinvd arat npt nrip_save umip rdpid arch_capabilities 02:21:07 02:21:07 02:21:07 ---> nproc: 02:21:07 2 02:21:07 02:21:07 02:21:07 ---> df -h: 02:21:07 Filesystem Size Used Avail Use% Mounted on 02:21:07 devtmpfs 3.8G 0 3.8G 0% /dev 02:21:07 tmpfs 3.8G 0 3.8G 0% /dev/shm 02:21:07 tmpfs 3.8G 17M 3.8G 1% /run 02:21:07 tmpfs 3.8G 0 3.8G 0% /sys/fs/cgroup 02:21:07 /dev/vda1 40G 8.4G 32G 21% / 02:21:07 tmpfs 770M 0 770M 0% /run/user/1001 02:21:07 02:21:07 02:21:07 ---> free -m: 02:21:07 total used free shared buff/cache available 02:21:07 Mem: 7697 603 4872 19 2221 6795 02:21:07 Swap: 1023 0 1023 02:21:07 02:21:07 02:21:07 ---> ip addr: 02:21:07 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 02:21:07 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 02:21:07 inet 127.0.0.1/8 scope host lo 02:21:07 valid_lft forever preferred_lft forever 02:21:07 inet6 ::1/128 scope host 02:21:07 valid_lft forever preferred_lft forever 02:21:07 2: eth0: mtu 1458 qdisc mq state UP group default qlen 1000 02:21:07 link/ether fa:16:3e:89:54:19 brd ff:ff:ff:ff:ff:ff 02:21:07 altname enp0s3 02:21:07 altname ens3 02:21:07 inet 10.30.171.196/23 brd 10.30.171.255 scope global dynamic noprefixroute eth0 02:21:07 valid_lft 85444sec preferred_lft 85444sec 02:21:07 inet6 fe80::f816:3eff:fe89:5419/64 scope link 02:21:07 valid_lft forever preferred_lft forever 02:21:07 02:21:07 02:21:07 ---> sar -b -r -n DEV: 02:21:07 Linux 4.18.0-553.5.1.el8.x86_64 (centos-stream-8-robot-7d7a37eb-bc14-4dd6-9530-dc22c5eae738.noval) 12/30/2025 _x86_64_ (2 CPU) 02:21:07 02:21:07 02:05:06 LINUX RESTART (2 CPU) 02:21:07 02:21:07 02:06:02 AM tps rtps wtps bread/s bwrtn/s 02:21:07 02:07:02 AM 126.91 0.27 126.64 13.15 12015.23 02:21:07 02:08:01 AM 38.82 1.49 37.33 137.74 4226.94 02:21:07 02:09:01 AM 69.81 6.78 63.03 1248.52 3983.17 02:21:07 02:10:01 AM 38.44 0.22 38.22 43.59 6524.68 02:21:07 02:11:01 AM 4.50 0.00 4.50 0.00 151.37 02:21:07 02:12:01 AM 0.27 0.00 0.27 0.00 4.43 02:21:07 02:13:01 AM 0.23 0.07 0.17 4.93 2.10 02:21:07 02:14:01 AM 2.17 0.03 2.13 1.87 223.69 02:21:07 02:15:01 AM 0.42 0.00 0.42 0.00 109.53 02:21:07 02:16:01 AM 0.42 0.00 0.42 0.00 120.58 02:21:07 02:17:01 AM 0.28 0.00 0.28 0.00 145.76 02:21:07 02:18:01 AM 0.20 0.00 0.20 0.00 101.72 02:21:07 02:19:01 AM 0.22 0.00 0.22 0.00 112.55 02:21:07 02:20:01 AM 14.95 0.32 14.63 36.92 645.82 02:21:07 02:21:01 AM 32.00 0.55 31.45 64.09 2209.33 02:21:07 Average: 21.84 0.65 21.19 103.45 2025.00 02:21:07 02:21:07 02:06:02 AM kbmemfree kbavail kbmemused %memused kbbuffers kbcached kbcommit %commit kbactive kbinact kbdirty 02:21:07 02:07:02 AM 5077248 6950100 2805176 35.59 2688 2049812 767004 8.59 191528 2263596 137204 02:21:07 02:08:01 AM 5239992 7085180 2642432 33.52 2688 2021232 627096 7.02 219464 2072068 10756 02:21:07 02:09:01 AM 4922744 7022228 2959680 37.55 2688 2265940 663832 7.43 254064 2320888 177372 02:21:07 02:10:01 AM 4955072 7055148 2927352 37.14 2688 2267324 622720 6.97 261028 2280572 16 02:21:07 02:11:01 AM 4955632 7055712 2926792 37.13 2688 2267332 622720 6.97 261032 2280500 4 02:21:07 02:12:01 AM 4955592 7055672 2926832 37.13 2688 2267332 622720 6.97 261032 2280440 12 02:21:07 02:13:01 AM 4908436 7009992 2973988 37.73 2688 2268808 689412 7.72 261388 2327100 1328 02:21:07 02:14:01 AM 4899116 7004084 2983308 37.85 2688 2272272 708552 7.93 261660 2336048 168 02:21:07 02:15:01 AM 4895852 7003892 2986572 37.89 2688 2275296 747440 8.37 261660 2339428 32 02:21:07 02:16:01 AM 4892364 7003904 2990060 37.93 2688 2278792 747440 8.37 261660 2343124 96 02:21:07 02:17:01 AM 4885040 7000968 2997384 38.03 2688 2283180 763448 8.55 261660 2350160 172 02:21:07 02:18:01 AM 4881140 7000072 3001284 38.08 2688 2286208 797844 8.93 261660 2353836 184 02:21:07 02:19:01 AM 4877716 6999952 3004708 38.12 2688 2289536 797844 8.93 261660 2357140 176 02:21:07 02:20:01 AM 5004696 6969876 2877728 36.51 2688 2138584 731172 8.19 323380 2190092 55308 02:21:07 02:21:01 AM 4998828 6966656 2883596 36.58 2688 2141748 710404 7.95 483408 2041788 25112 02:21:07 Average: 4956631 7012229 2925793 37.12 2688 2224893 707977 7.93 272419 2275785 27196 02:21:07 02:21:07 02:06:02 AM IFACE rxpck/s txpck/s rxkB/s txkB/s rxcmp/s txcmp/s rxmcst/s %ifutil 02:21:07 02:07:02 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:07:02 AM eth0 125.70 102.47 1467.96 13.48 0.00 0.00 0.00 0.00 02:21:07 02:08:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:08:01 AM eth0 13.05 10.59 6.72 4.05 0.00 0.00 0.00 0.00 02:21:07 02:09:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:09:01 AM eth0 41.32 37.77 337.65 8.32 0.00 0.00 0.00 0.00 02:21:07 02:10:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:10:01 AM eth0 600.02 434.54 118.35 99.38 0.00 0.00 0.00 0.00 02:21:07 02:11:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:11:01 AM eth0 2.28 2.12 0.50 0.49 0.00 0.00 0.00 0.00 02:21:07 02:12:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:12:01 AM eth0 2.40 1.85 0.46 0.39 0.00 0.00 0.00 0.00 02:21:07 02:13:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:13:01 AM eth0 47.49 34.81 14.35 3.36 0.00 0.00 0.00 0.00 02:21:07 02:14:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:14:01 AM eth0 229.36 229.52 39.53 16.70 0.00 0.00 0.00 0.00 02:21:07 02:15:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:15:01 AM eth0 160.79 160.49 29.63 12.49 0.00 0.00 0.00 0.00 02:21:07 02:16:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:16:01 AM eth0 248.57 250.60 43.75 17.84 0.00 0.00 0.00 0.00 02:21:07 02:17:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:17:01 AM eth0 242.48 243.39 46.75 18.34 0.00 0.00 0.00 0.00 02:21:07 02:18:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:18:01 AM eth0 154.08 154.30 29.17 12.10 0.00 0.00 0.00 0.00 02:21:07 02:19:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:19:01 AM eth0 198.17 199.87 35.36 14.37 0.00 0.00 0.00 0.00 02:21:07 02:20:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:20:01 AM eth0 171.24 137.99 147.96 106.08 0.00 0.00 0.00 0.00 02:21:07 02:21:01 AM lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 02:21:01 AM eth0 18.37 16.52 15.63 8.43 0.00 0.00 0.00 0.00 02:21:07 Average: lo 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 02:21:07 Average: eth0 150.53 134.63 154.30 22.42 0.00 0.00 0.00 0.00 02:21:07 02:21:07 02:21:07 ---> sar -P ALL: 02:21:07 Linux 4.18.0-553.5.1.el8.x86_64 (centos-stream-8-robot-7d7a37eb-bc14-4dd6-9530-dc22c5eae738.noval) 12/30/2025 _x86_64_ (2 CPU) 02:21:07 02:21:07 02:05:06 LINUX RESTART (2 CPU) 02:21:07 02:21:07 02:06:02 AM CPU %user %nice %system %iowait %steal %idle 02:21:07 02:07:02 AM all 38.53 0.00 5.11 1.37 0.10 54.89 02:21:07 02:07:02 AM 0 33.21 0.00 4.50 1.19 0.10 61.00 02:21:07 02:07:02 AM 1 43.86 0.00 5.72 1.54 0.10 48.78 02:21:07 02:08:01 AM all 16.64 0.00 2.36 0.44 0.07 80.50 02:21:07 02:08:01 AM 0 10.15 0.00 2.05 0.56 0.07 87.17 02:21:07 02:08:01 AM 1 23.12 0.00 2.66 0.32 0.07 73.83 02:21:07 02:09:01 AM all 30.58 0.00 5.76 0.56 0.09 63.01 02:21:07 02:09:01 AM 0 24.00 0.00 5.25 0.60 0.08 70.07 02:21:07 02:09:01 AM 1 37.15 0.00 6.27 0.52 0.10 55.96 02:21:07 02:10:01 AM all 8.31 0.00 2.28 0.56 0.05 88.79 02:21:07 02:10:01 AM 0 10.40 0.00 2.47 0.52 0.05 86.56 02:21:07 02:10:01 AM 1 6.23 0.00 2.09 0.60 0.05 91.02 02:21:07 02:11:01 AM all 0.35 0.00 0.09 0.02 0.03 99.51 02:21:07 02:11:01 AM 0 0.32 0.00 0.10 0.03 0.03 99.52 02:21:07 02:11:01 AM 1 0.38 0.00 0.08 0.00 0.03 99.50 02:21:07 02:12:01 AM all 0.33 0.00 0.07 0.00 0.04 99.56 02:21:07 02:12:01 AM 0 0.58 0.00 0.07 0.00 0.03 99.32 02:21:07 02:12:01 AM 1 0.08 0.00 0.07 0.00 0.05 99.80 02:21:07 02:13:01 AM all 3.49 0.00 0.49 0.00 0.04 95.97 02:21:07 02:13:01 AM 0 5.81 0.00 0.64 0.00 0.03 93.52 02:21:07 02:13:01 AM 1 1.19 0.00 0.35 0.00 0.05 98.41 02:21:07 02:14:01 AM all 11.42 0.00 1.08 0.01 0.09 87.40 02:21:07 02:14:01 AM 0 8.89 0.00 0.98 0.00 0.10 90.04 02:21:07 02:14:01 AM 1 13.97 0.00 1.18 0.02 0.08 84.75 02:21:07 02:15:01 AM all 10.99 0.00 0.94 0.00 0.07 88.00 02:21:07 02:15:01 AM 0 8.91 0.00 0.76 0.00 0.07 90.27 02:21:07 02:15:01 AM 1 13.07 0.00 1.13 0.00 0.07 85.73 02:21:07 02:16:01 AM all 10.47 0.00 1.21 0.00 0.08 88.24 02:21:07 02:16:01 AM 0 4.80 0.00 1.06 0.00 0.07 94.08 02:21:07 02:16:01 AM 1 16.22 0.00 1.36 0.00 0.08 82.34 02:21:07 02:17:01 AM all 14.44 0.00 1.39 0.01 0.08 84.09 02:21:07 02:17:01 AM 0 13.57 0.00 1.35 0.00 0.08 85.00 02:21:07 02:17:01 AM 1 15.30 0.00 1.44 0.02 0.07 83.18 02:21:07 02:21:07 02:17:01 AM CPU %user %nice %system %iowait %steal %idle 02:21:07 02:18:01 AM all 10.79 0.00 0.98 0.00 0.10 88.13 02:21:07 02:18:01 AM 0 5.31 0.00 0.84 0.00 0.10 93.75 02:21:07 02:18:01 AM 1 16.28 0.00 1.11 0.00 0.10 82.51 02:21:07 02:19:01 AM all 9.81 0.00 1.01 0.00 0.08 89.09 02:21:07 02:19:01 AM 0 7.73 0.00 0.94 0.00 0.08 91.24 02:21:07 02:19:01 AM 1 11.90 0.00 1.08 0.00 0.08 86.93 02:21:07 02:20:01 AM all 22.62 0.00 2.70 0.08 0.08 74.52 02:21:07 02:20:01 AM 0 15.04 0.00 2.19 0.07 0.07 82.64 02:21:07 02:20:01 AM 1 30.25 0.00 3.22 0.08 0.08 66.36 02:21:07 02:21:01 AM all 31.27 0.00 4.03 0.93 0.09 63.68 02:21:07 02:21:01 AM 0 15.60 0.00 3.45 0.63 0.08 80.23 02:21:07 02:21:01 AM 1 46.93 0.00 4.62 1.22 0.10 47.13 02:21:07 Average: all 14.66 0.00 1.97 0.26 0.07 83.03 02:21:07 Average: 0 10.94 0.00 1.77 0.24 0.07 86.97 02:21:07 Average: 1 18.39 0.00 2.16 0.29 0.08 79.09 02:21:07 02:21:07 02:21:07