01:48:19 Started by upstream project "integration-distribution-test-titanium" build number 725
01:48:19 originally caused by:
01:48:19 Started by upstream project "autorelease-release-titanium-mvn39-openjdk21" build number 620
01:48:19 originally caused by:
01:48:19 Started by timer
01:48:19 Running as SYSTEM
01:48:19 [EnvInject] - Loading node environment variables.
01:48:19 Building remotely on prd-ubuntu2404-robot-2c-8g-11583 (ubuntu2404-robot-2c-8g) in workspace /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium
01:48:20 [ssh-agent] Looking for ssh-agent implementation...
01:48:20 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine)
01:48:20 $ ssh-agent
01:48:20 SSH_AUTH_SOCK=/tmp/ssh-tw3OMjh9gGl9/agent.3148
01:48:20 SSH_AGENT_PID=3150
01:48:20 [ssh-agent] Started.
01:48:20 Running ssh-add (command line suppressed)
01:48:20 Identity added: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium@tmp/private_key_7324221062940978085.key (/w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium@tmp/private_key_7324221062940978085.key)
01:48:20 [ssh-agent] Using credentials jenkins (Release Engineering Jenkins Key)
01:48:20 The recommended git tool is: NONE
01:48:22 using credential opendaylight-jenkins-ssh
01:48:22 Wiping out workspace first.
01:48:22 Cloning the remote Git repository
01:48:22 Cloning repository git://devvexx.opendaylight.org/mirror/integration/test
01:48:22 > git init /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test # timeout=10
01:48:22 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/integration/test
01:48:22 > git --version # timeout=10
01:48:22 > git --version # 'git version 2.43.0'
01:48:22 using GIT_SSH to set credentials Release Engineering Jenkins Key
01:48:22 Verifying host key using known hosts file, will automatically accept unseen keys
01:48:22 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/integration/test +refs/heads/*:refs/remotes/origin/* # timeout=10
01:48:25 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/integration/test # timeout=10
01:48:25 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10
01:48:25 > git config remote.origin.url git://devvexx.opendaylight.org/mirror/integration/test # timeout=10
01:48:25 Fetching upstream changes from git://devvexx.opendaylight.org/mirror/integration/test
01:48:25 using GIT_SSH to set credentials Release Engineering Jenkins Key
01:48:25 Verifying host key using known hosts file, will automatically accept unseen keys
01:48:25 > git fetch --tags --force --progress -- git://devvexx.opendaylight.org/mirror/integration/test master # timeout=10
01:48:25 > git rev-parse FETCH_HEAD^{commit} # timeout=10
01:48:25 Checking out Revision 901c7e139945b436d95a44b3b592904c3d7a4f9f (origin/master)
01:48:25 > git config core.sparsecheckout # timeout=10
01:48:25 > git checkout -f 901c7e139945b436d95a44b3b592904c3d7a4f9f # timeout=10
01:48:26 Commit message: "Adapt updater.py to use new lsp-flags container"
01:48:26 > git rev-parse FETCH_HEAD^{commit} # timeout=10
01:48:26 > git rev-list --no-walk f65244a2a093016c71f9a7a564be7d086941e15c # timeout=10
01:48:26 No emails were triggered.
01:48:26 provisioning config files...
01:48:26 copy managed file [npmrc] to file:/home/jenkins/.npmrc
01:48:26 copy managed file [pipconf] to file:/home/jenkins/.config/pip/pip.conf
01:48:26 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml
01:48:26 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins17343156354958028449.sh
01:48:26 ---> python-tools-install.sh
01:48:26 Setup pyenv:
01:48:26 * system (set by /opt/pyenv/version)
01:48:26 * 3.8.20 (set by /opt/pyenv/version)
01:48:26 * 3.9.20 (set by /opt/pyenv/version)
01:48:26 3.10.15
01:48:26 3.11.10
01:48:31 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-wCb3
01:48:31 lf-activate-venv(): INFO: Save venv in file: /tmp/.os_lf_venv
01:48:31 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:48:31 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:48:35 lf-activate-venv(): INFO: Base packages installed successfully
01:48:35 lf-activate-venv(): INFO: Installing additional packages: lftools
01:49:01 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:49:01 Generating Requirements File
01:49:19 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.
01:49:19 httplib2 0.30.2 requires pyparsing<4,>=3.0.4, but you have pyparsing 2.4.7 which is incompatible.
01:49:19 Python 3.11.10
01:49:20 pip 26.1.1 from /tmp/venv-wCb3/lib/python3.11/site-packages/pip (python 3.11)
01:49:20 appdirs==1.4.4
01:49:20 argcomplete==3.6.3
01:49:20 aspy.yaml==1.3.0
01:49:20 attrs==26.1.0
01:49:20 autopage==0.6.0
01:49:20 beautifulsoup4==4.14.3
01:49:20 boto3==1.43.5
01:49:20 botocore==1.43.5
01:49:20 bs4==0.0.2
01:49:20 certifi==2026.4.22
01:49:20 cffi==2.0.0
01:49:20 cfgv==3.5.0
01:49:20 chardet==7.4.3
01:49:20 charset-normalizer==3.4.7
01:49:20 click==8.3.3
01:49:20 cliff==4.13.3
01:49:20 cmd2==3.5.1
01:49:20 cryptography==3.3.2
01:49:20 debtcollector==3.1.0
01:49:20 decorator==5.2.1
01:49:20 defusedxml==0.7.1
01:49:20 Deprecated==1.3.1
01:49:20 distlib==0.4.0
01:49:20 dnspython==2.8.0
01:49:20 docker==7.1.0
01:49:20 dogpile.cache==1.5.0
01:49:20 durationpy==0.10
01:49:20 email-validator==2.3.0
01:49:20 filelock==3.29.0
01:49:20 future==1.0.0
01:49:20 gitdb==4.0.12
01:49:20 GitPython==3.1.50
01:49:20 httplib2==0.30.2
01:49:20 identify==2.6.19
01:49:20 idna==3.13
01:49:20 importlib-resources==1.5.0
01:49:20 iso8601==2.1.0
01:49:20 Jinja2==3.1.6
01:49:20 jmespath==1.1.0
01:49:20 jsonpatch==1.33
01:49:20 jsonpointer==3.1.1
01:49:20 jsonschema==4.26.0
01:49:20 jsonschema-specifications==2025.9.1
01:49:20 keystoneauth1==5.13.1
01:49:20 kubernetes==35.0.0
01:49:20 lftools==0.37.22
01:49:20 lxml==6.1.0
01:49:20 markdown-it-py==4.1.0
01:49:20 MarkupSafe==3.0.3
01:49:20 mdurl==0.1.2
01:49:20 msgpack==1.1.2
01:49:20 multi_key_dict==2.0.3
01:49:20 munch==4.0.0
01:49:20 netaddr==1.3.0
01:49:20 niet==1.4.2
01:49:20 nodeenv==1.10.0
01:49:20 oauth2client==4.1.3
01:49:20 oauthlib==3.3.1
01:49:20 openstacksdk==4.12.0
01:49:20 os-service-types==1.8.2
01:49:20 osc-lib==4.6.0
01:49:20 oslo.config==10.3.0
01:49:20 oslo.context==6.3.0
01:49:20 oslo.i18n==6.7.2
01:49:20 oslo.log==8.1.0
01:49:20 oslo.serialization==5.9.1
01:49:20 oslo.utils==10.0.1
01:49:20 packaging==26.2
01:49:20 pbr==7.0.3
01:49:20 platformdirs==4.9.6
01:49:20 prettytable==3.17.0
01:49:20 psutil==7.2.2
01:49:20 pyasn1==0.6.3
01:49:20 pyasn1_modules==0.4.2
01:49:20 pycparser==3.0
01:49:20 pygerrit2==2.0.15
01:49:20 PyGithub==2.9.1
01:49:20 Pygments==2.20.0
01:49:20 PyJWT==2.12.1
01:49:20 PyNaCl==1.6.2
01:49:20 pyparsing==2.4.7
01:49:20 pyperclip==1.11.0
01:49:20 pyrsistent==0.20.0
01:49:20 python-cinderclient==9.9.0
01:49:20 python-dateutil==2.9.0.post0
01:49:20 python-discovery==1.3.0
01:49:20 python-heatclient==5.1.0
01:49:20 python-jenkins==1.8.3
01:49:20 python-keystoneclient==5.8.0
01:49:20 python-magnumclient==4.10.0
01:49:20 python-openstackclient==9.0.0
01:49:20 python-swiftclient==4.10.0
01:49:20 PyYAML==6.0.3
01:49:20 referencing==0.37.0
01:49:20 requests==2.33.1
01:49:20 requests-oauthlib==2.0.0
01:49:20 rfc3986==2.0.0
01:49:20 rich==15.0.0
01:49:20 rich-argparse==1.8.0
01:49:20 rpds-py==0.30.0
01:49:20 rsa==4.9.1
01:49:20 ruamel.yaml==0.19.1
01:49:20 ruamel.yaml.clib==0.2.15
01:49:20 s3transfer==0.17.0
01:49:20 simplejson==4.1.1
01:49:20 six==1.17.0
01:49:20 smmap==5.0.3
01:49:20 soupsieve==2.8.3
01:49:20 stevedore==5.7.0
01:49:20 tabulate==0.10.0
01:49:20 toml==0.10.2
01:49:20 tomlkit==0.14.0
01:49:20 tqdm==4.67.3
01:49:20 typing_extensions==4.15.0
01:49:20 urllib3==1.26.20
01:49:20 virtualenv==21.3.1
01:49:20 wcwidth==0.7.0
01:49:20 websocket-client==1.9.0
01:49:20 wrapt==2.1.2
01:49:20 xdg==6.0.0
01:49:20 xmltodict==1.0.4
01:49:20 yq==3.4.3
01:49:20 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/sh /tmp/jenkins10342557294767323227.sh
01:49:20 ---> uv-install.sh
01:49:20 Installing uv/uvx (latest) using shell installer
01:49:20 2026-05-07 01:49:20 URL:https://releases.astral.sh/installers/uv/latest/uv-installer.sh [71233/71233] -> "/tmp/uv-install-wQthTK.sh" [1]
01:49:20 downloading uv 0.11.11 x86_64-unknown-linux-gnu
01:49:21 installing to /home/jenkins/.local/bin
01:49:21 uv
01:49:21 uvx
01:49:21 everything's installed!
01:49:21
01:49:21 To add $HOME/.local/bin to your PATH, either restart your shell or run:
01:49:21
01:49:21 source $HOME/.local/bin/env (sh, bash, zsh)
01:49:21 source $HOME/.local/bin/env.fish (fish)
01:49:21 Adding install location to PATH
01:49:21 ---> Validating uv/uvx install
01:49:21 uvx 0.11.11 (x86_64-unknown-linux-gnu)
01:49:21 [EnvInject] - Injecting environment variables from a build step.
01:49:21 [EnvInject] - Injecting as environment variables the properties content
01:49:21 OS_STACK_TEMPLATE=csit-2-instance-type.yaml
01:49:21 OS_CLOUD=vex
01:49:21 OS_STACK_NAME=releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:49:21 OS_STACK_TEMPLATE_DIR=openstack-hot
01:49:21
01:49:21 [EnvInject] - Variables injected successfully.
01:49:21 provisioning config files...
01:49:22 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml
01:49:22 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins11097381934070610387.sh
01:49:22 ---> Create parameters file for OpenStack HOT
01:49:22 OpenStack Heat parameters generated
01:49:22 -----------------------------------
01:49:22 parameters:
01:49:22 vm_0_count: '1'
01:49:22 vm_0_flavor: 'v3-standard-4'
01:49:22 vm_0_image: 'ZZCI - Ubuntu 22.04 - builder - x86_64 - 20260401-010115.623'
01:49:22 vm_1_count: '1'
01:49:22 vm_1_flavor: 'v3-standard-2'
01:49:22 vm_1_image: 'ZZCI - Ubuntu 22.04 - mininet-ovs-217 - x86_64 - 20250917-133034.654'
01:49:22
01:49:22 job_name: '36899-712'
01:49:22 silo: 'releng'
01:49:22 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins2170824502861488237.sh
01:49:22 ---> Create HEAT stack
01:49:22 + source /home/jenkins/lf-env.sh
01:49:22 + lf-activate-venv --python python3 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq
01:49:22 ++ mktemp -d /tmp/venv-XXXX
01:49:22 + lf_venv=/tmp/venv-brGs
01:49:22 + local venv_file=/tmp/.os_lf_venv
01:49:22 + local python=python3
01:49:22 + local options
01:49:22 + local set_path=true
01:49:22 + local install_args=
01:49:22 ++ 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
01:49:22 + options=' --python '\''python3'\'' -- '\''lftools[openstack]'\'' '\''kubernetes'\'' '\''niet'\'' '\''python-heatclient'\'' '\''python-openstackclient'\'' '\''python-magnumclient'\'' '\''urllib3~=1.26.15'\'' '\''yq'\'''
01:49:22 + eval set -- ' --python '\''python3'\'' -- '\''lftools[openstack]'\'' '\''kubernetes'\'' '\''niet'\'' '\''python-heatclient'\'' '\''python-openstackclient'\'' '\''python-magnumclient'\'' '\''urllib3~=1.26.15'\'' '\''yq'\'''
01:49:22 ++ set -- --python python3 -- 'lftools[openstack]' kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq
01:49:22 + true
01:49:22 + case $1 in
01:49:22 + python=python3
01:49:22 + shift 2
01:49:22 + true
01:49:22 + case $1 in
01:49:22 + shift
01:49:22 + break
01:49:22 + case $python in
01:49:22 + local pkg_list=
01:49:22 + [[ -d /opt/pyenv ]]
01:49:22 + echo 'Setup pyenv:'
01:49:22 Setup pyenv:
01:49:22 + export PYENV_ROOT=/opt/pyenv
01:49:22 + PYENV_ROOT=/opt/pyenv
01:49:22 + export PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:22 + PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:22 + pyenv versions
01:49:22 system
01:49:22 3.8.20
01:49:22 3.9.20
01:49:22 3.10.15
01:49:22 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:49:22 + command -v pyenv
01:49:22 ++ pyenv init - --no-rehash
01:49:22 + eval 'PATH="$(bash --norc -ec '\''IFS=:; paths=($PATH);
01:49:22 for i in ${!paths[@]}; do
01:49:22 if [[ ${paths[i]} == "'\'''\''/opt/pyenv/shims'\'''\''" ]]; then unset '\''\'\'''\''paths[i]'\''\'\'''\'';
01:49:22 fi; done;
01:49:22 echo "${paths[*]}"'\'')"
01:49:22 export PATH="/opt/pyenv/shims:${PATH}"
01:49:22 export PYENV_SHELL=bash
01:49:22 source '\''/opt/pyenv/libexec/../completions/pyenv.bash'\''
01:49:22 pyenv() {
01:49:22 local command
01:49:22 command="${1:-}"
01:49:22 if [ "$#" -gt 0 ]; then
01:49:22 shift
01:49:22 fi
01:49:22
01:49:22 case "$command" in
01:49:22 rehash|shell)
01:49:22 eval "$(pyenv "sh-$command" "$@")"
01:49:22 ;;
01:49:22 *)
01:49:22 command pyenv "$command" "$@"
01:49:22 ;;
01:49:22 esac
01:49:22 }'
01:49:22 +++ bash --norc -ec 'IFS=:; paths=($PATH);
01:49:22 for i in ${!paths[@]}; do
01:49:22 if [[ ${paths[i]} == "/opt/pyenv/shims" ]]; then unset '\''paths[i]'\'';
01:49:22 fi; done;
01:49:22 echo "${paths[*]}"'
01:49:22 ++ PATH=/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:22 ++ export PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:22 ++ PATH=/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:22 ++ export PYENV_SHELL=bash
01:49:22 ++ PYENV_SHELL=bash
01:49:22 ++ source /opt/pyenv/libexec/../completions/pyenv.bash
01:49:22 +++ complete -F _pyenv pyenv
01:49:22 ++ lf-pyver python3
01:49:22 ++ local py_version_xy=python3
01:49:22 ++ local py_version_xyz=
01:49:22 ++ pyenv versions
01:49:22 ++ local command
01:49:22 ++ command=versions
01:49:22 ++ '[' 1 -gt 0 ']'
01:49:22 ++ shift
01:49:22 ++ case "$command" in
01:49:22 ++ command pyenv versions
01:49:22 ++ sed 's/^[ *]* //'
01:49:22 ++ grep -E '^[0-9.]*[0-9]$'
01:49:22 ++ awk '{ print $1 }'
01:49:22 ++ [[ ! -s /tmp/.pyenv_versions ]]
01:49:22 +++ grep '^3' /tmp/.pyenv_versions
01:49:22 +++ sort -V
01:49:22 +++ tail -n 1
01:49:22 ++ py_version_xyz=3.11.10
01:49:22 ++ [[ -z 3.11.10 ]]
01:49:22 ++ echo 3.11.10
01:49:22 ++ return 0
01:49:22 + pyenv local 3.11.10
01:49:22 + local command
01:49:22 + command=local
01:49:22 + '[' 2 -gt 0 ']'
01:49:22 + shift
01:49:22 + case "$command" in
01:49:22 + command pyenv local 3.11.10
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='lftools[openstack] '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='kubernetes '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='niet '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='python-heatclient '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='python-openstackclient '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='python-magnumclient '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='urllib3~=1.26.15 '
01:49:22 + for arg in "$@"
01:49:22 + case $arg in
01:49:22 + pkg_list+='yq '
01:49:22 + [[ -f /tmp/.os_lf_venv ]]
01:49:22 ++ cat /tmp/.os_lf_venv
01:49:22 + lf_venv=/tmp/venv-wCb3
01:49:22 + echo 'lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from' file:/tmp/.os_lf_venv
01:49:22 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:49:22 + echo 'lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)'
01:49:22 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:49:22 + local 'pip_opts=--upgrade --quiet'
01:49:22 + pip_opts='--upgrade --quiet --trusted-host pypi.org'
01:49:22 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org'
01:49:22 + pip_opts='--upgrade --quiet --trusted-host pypi.org --trusted-host files.pythonhosted.org --trusted-host pypi.python.org'
01:49:22 + [[ -n '' ]]
01:49:22 + [[ -n '' ]]
01:49:22 + echo 'lf-activate-venv(): INFO: Attempting to install with network-safe options...'
01:49:22 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:49:22 + /tmp/venv-wCb3/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
01:49:24 + echo 'lf-activate-venv(): INFO: Base packages installed successfully'
01:49:24 lf-activate-venv(): INFO: Base packages installed successfully
01:49:24 + [[ -z lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq ]]
01:49:24 + echo 'lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq '
01:49:24 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes niet python-heatclient python-openstackclient python-magnumclient urllib3~=1.26.15 yq
01:49:24 + /tmp/venv-wCb3/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
01:49:39 + type python3
01:49:39 + true
01:49:39 + echo 'lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH'
01:49:39 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:49:39 + PATH=/tmp/venv-wCb3/bin:/opt/pyenv/shims:/opt/pyenv/bin:/home/jenkins/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
01:49:39 + return 0
01:49:39 + openstack --os-cloud vex limits show --absolute
01:49:41 +--------------------------+---------+
01:49:41 | Name | Value |
01:49:41 +--------------------------+---------+
01:49:41 | maxTotalInstances | -1 |
01:49:41 | maxTotalCores | 450 |
01:49:41 | maxTotalRAMSize | 1000000 |
01:49:41 | maxServerMeta | 128 |
01:49:41 | maxImageMeta | 128 |
01:49:41 | maxPersonality | 5 |
01:49:41 | maxPersonalitySize | 10240 |
01:49:41 | maxTotalKeypairs | 100 |
01:49:41 | maxServerGroups | 10 |
01:49:41 | maxServerGroupMembers | 10 |
01:49:41 | maxTotalFloatingIps | -1 |
01:49:41 | maxSecurityGroups | -1 |
01:49:41 | maxSecurityGroupRules | -1 |
01:49:41 | totalRAMUsed | 418816 |
01:49:41 | totalCoresUsed | 103 |
01:49:41 | totalInstancesUsed | 39 |
01:49:41 | totalFloatingIpsUsed | 0 |
01:49:41 | totalSecurityGroupsUsed | 0 |
01:49:41 | totalServerGroupsUsed | 0 |
01:49:41 | maxTotalVolumes | -1 |
01:49:41 | maxTotalSnapshots | 10 |
01:49:41 | maxTotalVolumeGigabytes | 4096 |
01:49:41 | maxTotalBackups | 10 |
01:49:41 | maxTotalBackupGigabytes | 1000 |
01:49:41 | totalVolumesUsed | 1 |
01:49:41 | totalGigabytesUsed | 20 |
01:49:41 | totalSnapshotsUsed | 0 |
01:49:41 | totalBackupsUsed | 0 |
01:49:41 | totalBackupGigabytesUsed | 0 |
01:49:41 +--------------------------+---------+
01:49:41 + pushd /opt/ciman/openstack-hot
01:49:41 /opt/ciman/openstack-hot /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium
01:49:41 + lftools openstack --os-cloud vex stack create releng-openflowplugin-csit-1node-scale-switch-only-titanium-712 csit-2-instance-type.yaml /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/stack-parameters.yaml
01:50:06 Creating stack releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:50:06 Waiting to initialize infrastructure...
01:50:06 Stack initialization successful.
01:50:06 ------------------------------------
01:50:06 Stack Details
01:50:06 ------------------------------------
01:50:06 {'added': None,
01:50:06 'capabilities': [],
01:50:06 'created_at': '2026-05-07T01:49:44Z',
01:50:06 'deleted': None,
01:50:06 'deleted_at': None,
01:50:06 'description': 'No description',
01:50:06 'environment': None,
01:50:06 'environment_files': None,
01:50:06 'files': None,
01:50:06 'files_container': None,
01:50:06 'id': '2fe6fe1c-c916-48e5-9cdf-71fd92cd12f9',
01:50:06 'is_rollback_disabled': True,
01:50:06 'links': [{'href': 'https://orchestration.public.mtl1.vexxhost.net/v1/12c36e260d8e4bb2913965203b1b491f/stacks/releng-openflowplugin-csit-1node-scale-switch-only-titanium-712/2fe6fe1c-c916-48e5-9cdf-71fd92cd12f9',
01:50:06 'rel': 'self'}],
01:50:06 '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'})}),
01:50:06 'name': 'releng-openflowplugin-csit-1node-scale-switch-only-titanium-712',
01:50:06 'notification_topics': [],
01:50:06 'outputs': [{'description': 'IP addresses of the 2nd vm types',
01:50:06 'output_key': 'vm_1_ips',
01:50:06 'output_value': ['10.30.171.236']},
01:50:06 {'description': 'IP addresses of the 1st vm types',
01:50:06 'output_key': 'vm_0_ips',
01:50:06 'output_value': ['10.30.171.114']}],
01:50:06 'owner_id': ****,
01:50:06 'parameters': {'OS::project_id': '12c36e260d8e4bb2913965203b1b491f',
01:50:06 'OS::stack_id': '2fe6fe1c-c916-48e5-9cdf-71fd92cd12f9',
01:50:06 'OS::stack_name': 'releng-openflowplugin-csit-1node-scale-switch-only-titanium-712',
01:50:06 'job_name': '36899-712',
01:50:06 'silo': 'releng',
01:50:06 'vm_0_count': '1',
01:50:06 'vm_0_flavor': 'v3-standard-4',
01:50:06 'vm_0_image': 'ZZCI - Ubuntu 22.04 - builder - x86_64 - '
01:50:06 '20260401-010115.623',
01:50:06 'vm_1_count': '1',
01:50:06 'vm_1_flavor': 'v3-standard-2',
01:50:06 'vm_1_image': 'ZZCI - Ubuntu 22.04 - mininet-ovs-217 - x86_64 '
01:50:06 '- 20250917-133034.654'},
01:50:06 'parent_id': None,
01:50:06 'replaced': None,
01:50:06 'status': 'CREATE_COMPLETE',
01:50:06 'status_reason': 'Stack CREATE completed successfully',
01:50:06 'tags': [],
01:50:06 'template': None,
01:50:06 'template_description': 'No description',
01:50:06 'template_url': None,
01:50:06 'timeout_mins': 15,
01:50:06 'unchanged': None,
01:50:06 'updated': None,
01:50:06 'updated_at': None,
01:50:06 'user_project_id': '3c009e20057f48d2af19889fa08c47a9'}
01:50:06 ------------------------------------
01:50:06 + popd
01:50:06 /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium
01:50:06 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins10829381288807415758.sh
01:50:06 ---> Copy SSH public keys to CSIT lab
01:50:06 Setup pyenv:
01:50:06 system
01:50:06 3.8.20
01:50:06 3.9.20
01:50:06 3.10.15
01:50:06 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:50:07 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:50:07 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:50:07 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:50:09 lf-activate-venv(): INFO: Base packages installed successfully
01:50:09 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes python-heatclient python-openstackclient urllib3~=1.26.15
01:50:21 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:50:23 SSH not responding on 10.30.171.114. Retrying in 10 seconds...
01:50:24 Warning: Permanently added '10.30.171.236' (ED25519) to the list of known hosts.
01:50:24 releng-36899-712-1-mininet-ovs-217-0
01:50:24 Successfully copied public keys to slave 10.30.171.236
01:50:24 Process 4927 ready.
01:50:33 Ping to 10.30.171.114 successful.
01:50:34 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:50:35 releng-36899-712-0-builder-0
01:50:35 Successfully copied public keys to slave 10.30.171.114
01:50:35 Process 4928 ready.
01:50:35 SSH ready on all stack servers.
01:50:35 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins1731674543712669529.sh
01:50:35 Setup pyenv:
01:50:35 system
01:50:35 3.8.20
01:50:35 3.9.20
01:50:35 3.10.15
01:50:35 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:50:39 lf-activate-venv(): INFO: Creating python3 venv at /tmp/venv-6kTb
01:50:39 lf-activate-venv(): INFO: Save venv in file: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.robot_venv
01:50:39 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:50:39 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:50:44 lf-activate-venv(): INFO: Base packages installed successfully
01:50:44 lf-activate-venv(): INFO: Installing additional packages: setuptools wheel
01:50:45 lf-activate-venv(): INFO: Adding /tmp/venv-6kTb/bin to PATH
01:50:45 + echo 'Installing Python Requirements'
01:50:45 Installing Python Requirements
01:50:45 + cat
01:50:45 + python -m pip install -r requirements.txt
01:50:46 Looking in indexes: https://nexus3.opendaylight.org/repository/PyPi/simple
01:50:46 Collecting docker-py (from -r requirements.txt (line 1))
01:50:46 Downloading docker_py-1.10.6-py2.py3-none-any.whl (50 kB)
01:50:46 Collecting ipaddr (from -r requirements.txt (line 2))
01:50:46 Downloading ipaddr-2.2.0.tar.gz (26 kB)
01:50:46 Installing build dependencies: started
01:50:47 Installing build dependencies: finished with status 'done'
01:50:47 Getting requirements to build wheel: started
01:50:47 Getting requirements to build wheel: finished with status 'done'
01:50:47 Preparing metadata (pyproject.toml): started
01:50:47 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:47 Collecting netaddr (from -r requirements.txt (line 3))
01:50:47 Using cached netaddr-1.3.0-py3-none-any.whl (2.3 MB)
01:50:47 Collecting netifaces (from -r requirements.txt (line 4))
01:50:47 Downloading netifaces-0.11.0.tar.gz (30 kB)
01:50:47 Installing build dependencies: started
01:50:48 Installing build dependencies: finished with status 'done'
01:50:48 Getting requirements to build wheel: started
01:50:49 Getting requirements to build wheel: finished with status 'done'
01:50:49 Preparing metadata (pyproject.toml): started
01:50:49 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:49 Collecting pyhocon (from -r requirements.txt (line 5))
01:50:49 Downloading pyhocon-0.3.63.tar.gz (307 kB)
01:50:49 Installing build dependencies: started
01:50:50 Installing build dependencies: finished with status 'done'
01:50:50 Getting requirements to build wheel: started
01:50:50 Getting requirements to build wheel: finished with status 'done'
01:50:50 Preparing metadata (pyproject.toml): started
01:50:50 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:50 Collecting requests (from -r requirements.txt (line 6))
01:50:50 Using cached requests-2.33.1-py3-none-any.whl (64 kB)
01:50:51 Collecting robotframework (from -r requirements.txt (line 7))
01:50:51 Downloading robotframework-7.4.2-py3-none-any.whl (807 kB)
01:50:51 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 807.1/807.1 kB 28.7 MB/s 0:00:00
01:50:51 Collecting robotframework-httplibrary (from -r requirements.txt (line 8))
01:50:51 Downloading robotframework-httplibrary-0.4.2.tar.gz (9.1 kB)
01:50:51 Installing build dependencies: started
01:50:51 Installing build dependencies: finished with status 'done'
01:50:51 Getting requirements to build wheel: started
01:50:52 Getting requirements to build wheel: finished with status 'done'
01:50:52 Preparing metadata (pyproject.toml): started
01:50:52 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:52 Collecting robotframework-requests==0.9.7 (from -r requirements.txt (line 9))
01:50:52 Downloading robotframework_requests-0.9.7-py3-none-any.whl (21 kB)
01:50:52 Collecting robotframework-selenium2library (from -r requirements.txt (line 10))
01:50:52 Downloading robotframework_selenium2library-3.0.0-py2.py3-none-any.whl (6.2 kB)
01:50:52 Collecting robotframework-sshlibrary==3.8.0 (from -r requirements.txt (line 11))
01:50:52 Downloading robotframework-sshlibrary-3.8.0.tar.gz (51 kB)
01:50:52 Installing build dependencies: started
01:50:53 Installing build dependencies: finished with status 'done'
01:50:53 Getting requirements to build wheel: started
01:50:53 Getting requirements to build wheel: finished with status 'done'
01:50:53 Preparing metadata (pyproject.toml): started
01:50:54 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:54 Collecting scapy (from -r requirements.txt (line 12))
01:50:54 Downloading scapy-2.7.0-py3-none-any.whl (2.6 MB)
01:50:54 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 2.6/2.6 MB 43.9 MB/s 0:00:00
01:50:54 Collecting jsonpath-rw (from -r requirements.txt (line 15))
01:50:54 Downloading jsonpath-rw-1.4.0.tar.gz (13 kB)
01:50:54 Installing build dependencies: started
01:50:55 Installing build dependencies: finished with status 'done'
01:50:55 Getting requirements to build wheel: started
01:50:55 Getting requirements to build wheel: finished with status 'done'
01:50:55 Preparing metadata (pyproject.toml): started
01:50:55 Preparing metadata (pyproject.toml): finished with status 'done'
01:50:55 Collecting elasticsearch (from -r requirements.txt (line 18))
01:50:55 Downloading elasticsearch-9.4.0-py3-none-any.whl (992 kB)
01:50:55 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 992.7/992.7 kB 37.1 MB/s 0:00:00
01:50:55 Collecting elasticsearch-dsl (from -r requirements.txt (line 19))
01:50:55 Downloading elasticsearch_dsl-8.18.0-py3-none-any.whl (10 kB)
01:50:55 Collecting pyangbind (from -r requirements.txt (line 22))
01:50:55 Downloading pyangbind-0.8.7-py3-none-any.whl (52 kB)
01:50:56 Collecting isodate (from -r requirements.txt (line 25))
01:50:56 Downloading isodate-0.7.2-py3-none-any.whl (22 kB)
01:50:56 Collecting jmespath (from -r requirements.txt (line 28))
01:50:56 Using cached jmespath-1.1.0-py3-none-any.whl (20 kB)
01:50:56 Collecting jsonpatch (from -r requirements.txt (line 31))
01:50:56 Using cached jsonpatch-1.33-py2.py3-none-any.whl (12 kB)
01:50:56 Collecting paramiko>=1.15.3 (from robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:56 Downloading paramiko-4.0.0-py3-none-any.whl (223 kB)
01:50:56 Collecting scp>=0.13.0 (from robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:56 Downloading scp-0.15.0-py2.py3-none-any.whl (8.8 kB)
01:50:56 Collecting docker-pycreds>=0.2.1 (from docker-py->-r requirements.txt (line 1))
01:50:56 Downloading docker_pycreds-0.4.0-py2.py3-none-any.whl (9.0 kB)
01:50:56 Collecting six>=1.4.0 (from docker-py->-r requirements.txt (line 1))
01:50:56 Using cached six-1.17.0-py2.py3-none-any.whl (11 kB)
01:50:56 Collecting websocket-client>=0.32.0 (from docker-py->-r requirements.txt (line 1))
01:50:56 Using cached websocket_client-1.9.0-py3-none-any.whl (82 kB)
01:50:56 Collecting pyparsing>=3.0.0 (from pyhocon->-r requirements.txt (line 5))
01:50:56 Using cached pyparsing-3.3.2-py3-none-any.whl (122 kB)
01:50:56 Collecting charset_normalizer<4,>=2 (from requests->-r requirements.txt (line 6))
01:50:56 Using cached charset_normalizer-3.4.7-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (214 kB)
01:50:56 Collecting idna<4,>=2.5 (from requests->-r requirements.txt (line 6))
01:50:56 Using cached idna-3.13-py3-none-any.whl (68 kB)
01:50:56 Collecting urllib3<3,>=1.26 (from requests->-r requirements.txt (line 6))
01:50:56 Using cached urllib3-2.6.3-py3-none-any.whl (131 kB)
01:50:56 Collecting certifi>=2023.5.7 (from requests->-r requirements.txt (line 6))
01:50:56 Using cached certifi-2026.4.22-py3-none-any.whl (135 kB)
01:50:56 Collecting webtest>=2.0 (from robotframework-httplibrary->-r requirements.txt (line 8))
01:50:56 Downloading webtest-3.0.7-py3-none-any.whl (32 kB)
01:50:56 Collecting jsonpointer (from robotframework-httplibrary->-r requirements.txt (line 8))
01:50:56 Using cached jsonpointer-3.1.1-py3-none-any.whl (7.7 kB)
01:50:56 Collecting robotframework-seleniumlibrary>=3.0.0 (from robotframework-selenium2library->-r requirements.txt (line 10))
01:50:56 Downloading robotframework_seleniumlibrary-6.8.0-py3-none-any.whl (104 kB)
01:50:56 Collecting ply (from jsonpath-rw->-r requirements.txt (line 15))
01:50:56 Downloading ply-3.11-py2.py3-none-any.whl (49 kB)
01:50:56 Collecting decorator (from jsonpath-rw->-r requirements.txt (line 15))
01:50:56 Using cached decorator-5.2.1-py3-none-any.whl (9.2 kB)
01:50:57 Collecting anyio (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Downloading anyio-4.13.0-py3-none-any.whl (114 kB)
01:50:57 Collecting elastic-transport<10,>=9.2.0 (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Downloading elastic_transport-9.4.0-py3-none-any.whl (65 kB)
01:50:57 Collecting python-dateutil (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Using cached python_dateutil-2.9.0.post0-py2.py3-none-any.whl (229 kB)
01:50:57 Collecting sniffio (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Downloading sniffio-1.3.1-py3-none-any.whl (10 kB)
01:50:57 Collecting typing-extensions (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Using cached typing_extensions-4.15.0-py3-none-any.whl (44 kB)
01:50:57 Collecting elasticsearch (from -r requirements.txt (line 18))
01:50:57 Downloading elasticsearch-8.19.3-py3-none-any.whl (952 kB)
01:50:57 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 952.8/952.8 kB 29.8 MB/s 0:00:00
01:50:57 INFO: pip is looking at multiple versions of elasticsearch-dsl to determine which version is compatible with other requirements. This could take a while.
01:50:57 Collecting elasticsearch-dsl (from -r requirements.txt (line 19))
01:50:57 Downloading elasticsearch_dsl-8.17.1-py3-none-any.whl (158 kB)
01:50:57 Downloading elasticsearch_dsl-8.17.0-py3-none-any.whl (158 kB)
01:50:57 Downloading elasticsearch_dsl-8.16.0-py3-none-any.whl (158 kB)
01:50:57 Downloading elasticsearch_dsl-8.15.4-py3-none-any.whl (104 kB)
01:50:57 Collecting elastic-transport<9,>=8.15.1 (from elasticsearch->-r requirements.txt (line 18))
01:50:57 Downloading elastic_transport-8.17.1-py3-none-any.whl (64 kB)
01:50:57 Collecting pyang (from pyangbind->-r requirements.txt (line 22))
01:50:57 Downloading pyang-2.7.1-py2.py3-none-any.whl (598 kB)
01:50:57 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 598.5/598.5 kB 22.6 MB/s 0:00:00
01:50:57 Collecting lxml (from pyangbind->-r requirements.txt (line 22))
01:50:57 Using cached lxml-6.1.0-cp311-cp311-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (5.2 MB)
01:50:58 Collecting regex (from pyangbind->-r requirements.txt (line 22))
01:50:58 Downloading regex-2026.4.4-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (799 kB)
01:50:58 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 799.8/799.8 kB 31.3 MB/s 0:00:00
01:50:58 Collecting enum34 (from pyangbind->-r requirements.txt (line 22))
01:50:58 Downloading enum34-1.1.10-py3-none-any.whl (11 kB)
01:50:59 Collecting bcrypt>=3.2 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Downloading bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl (278 kB)
01:50:59 Collecting cryptography>=3.3 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Using cached cryptography-48.0.0-cp311-abi3-manylinux_2_34_x86_64.whl (4.7 MB)
01:50:59 Collecting invoke>=2.0 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Downloading invoke-3.0.3-py3-none-any.whl (160 kB)
01:50:59 Collecting pynacl>=1.5 (from paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Using cached pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl (1.4 MB)
01:50:59 Collecting cffi>=2.0.0 (from cryptography>=3.3->paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Using cached cffi-2.0.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (215 kB)
01:50:59 Collecting pycparser (from cffi>=2.0.0->cryptography>=3.3->paramiko>=1.15.3->robotframework-sshlibrary==3.8.0->-r requirements.txt (line 11))
01:50:59 Using cached pycparser-3.0-py3-none-any.whl (48 kB)
01:50:59 Collecting selenium>=4.3.0 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10))
01:50:59 Downloading selenium-4.43.0-py3-none-any.whl (9.6 MB)
01:51:00 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 9.6/9.6 MB 67.9 MB/s 0:00:00
01:51:00 Collecting robotframework-pythonlibcore>=4.4.1 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10))
01:51:00 Downloading robotframework_pythonlibcore-4.5.0-py3-none-any.whl (19 kB)
01:51:00 Collecting click>=8.0 (from robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10))
01:51:00 Using cached click-8.3.3-py3-none-any.whl (110 kB)
01:51:00 Collecting trio<1.0,>=0.31.0 (from selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10))
01:51:00 Downloading trio-0.33.0-py3-none-any.whl (510 kB)
01:51:00 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))
01:51:00 Downloading trio_websocket-0.12.2-py3-none-any.whl (21 kB)
01:51:00 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))
01:51:00 Using cached attrs-26.1.0-py3-none-any.whl (67 kB)
01:51:00 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))
01:51:00 Downloading sortedcontainers-2.4.0-py2.py3-none-any.whl (29 kB)
01:51:00 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))
01:51:00 Downloading outcome-1.3.0.post0-py2.py3-none-any.whl (10 kB)
01:51:00 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))
01:51:00 Downloading wsproto-1.3.2-py3-none-any.whl (24 kB)
01:51:00 Collecting pysocks!=1.5.7,<2.0,>=1.5.6 (from urllib3[socks]<3.0,>=2.6.3->selenium>=4.3.0->robotframework-seleniumlibrary>=3.0.0->robotframework-selenium2library->-r requirements.txt (line 10))
01:51:00 Downloading PySocks-1.7.1-py3-none-any.whl (16 kB)
01:51:00 Collecting WebOb>=1.2 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8))
01:51:00 Downloading WebOb-1.8.9-py2.py3-none-any.whl (115 kB)
01:51:00 Collecting waitress>=3.0.2 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8))
01:51:00 Downloading waitress-3.0.2-py3-none-any.whl (56 kB)
01:51:00 Collecting beautifulsoup4 (from webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8))
01:51:00 Using cached beautifulsoup4-4.14.3-py3-none-any.whl (107 kB)
01:51:00 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))
01:51:00 Downloading h11-0.16.0-py3-none-any.whl (37 kB)
01:51:00 Collecting soupsieve>=1.6.1 (from beautifulsoup4->webtest>=2.0->robotframework-httplibrary->-r requirements.txt (line 8))
01:51:00 Using cached soupsieve-2.8.3-py3-none-any.whl (37 kB)
01:51:00 Building wheels for collected packages: robotframework-sshlibrary, ipaddr, netifaces, pyhocon, robotframework-httplibrary, jsonpath-rw
01:51:00 Building wheel for robotframework-sshlibrary (pyproject.toml): started
01:51:01 Building wheel for robotframework-sshlibrary (pyproject.toml): finished with status 'done'
01:51:01 Created wheel for robotframework-sshlibrary: filename=robotframework_sshlibrary-3.8.0-py3-none-any.whl size=55205 sha256=d192244e904777e14b77cb5914804937a7311cf65e4fb280c0b9e4c55feaa8d5
01:51:01 Stored in directory: /home/jenkins/.cache/pip/wheels/f7/c9/b3/a977b7bcc410d45ae27d240df3d00a12585509180e373ecccc
01:51:01 Building wheel for ipaddr (pyproject.toml): started
01:51:01 Building wheel for ipaddr (pyproject.toml): finished with status 'done'
01:51:01 Created wheel for ipaddr: filename=ipaddr-2.2.0-py3-none-any.whl size=18355 sha256=957f93f0f5cd079c97386e5be50da2f2fa5cdeab3138459a8c30111fe05df69f
01:51:01 Stored in directory: /home/jenkins/.cache/pip/wheels/dc/6c/04/da2d847fa8d45c59af3e1d83e2acc29cb8adcbaf04c0898dbf
01:51:01 Building wheel for netifaces (pyproject.toml): started
01:51:03 Building wheel for netifaces (pyproject.toml): finished with status 'done'
01:51:03 Created wheel for netifaces: filename=netifaces-0.11.0-cp311-cp311-linux_x86_64.whl size=34980 sha256=d417e42ee4eb5fddefed96dc7ab12b63cd829320df0696ec05842154ddfa3d7a
01:51:03 Stored in directory: /home/jenkins/.cache/pip/wheels/f8/18/88/e61d54b995bea304bdb1d040a92b72228a1bf72ca2a3eba7c9
01:51:04 Building wheel for pyhocon (pyproject.toml): started
01:51:04 Building wheel for pyhocon (pyproject.toml): finished with status 'done'
01:51:04 Created wheel for pyhocon: filename=pyhocon-0.3.63-py3-none-any.whl size=24721 sha256=f8d3dd9e6b62a7754da66f43840a978f45428b593743c731791774379a63f21b
01:51:04 Stored in directory: /home/jenkins/.cache/pip/wheels/ce/9e/92/cb17e17d79fafd46a767074b3ed1dca8f78036163f9bea914d
01:51:04 Building wheel for robotframework-httplibrary (pyproject.toml): started
01:51:04 Building wheel for robotframework-httplibrary (pyproject.toml): finished with status 'done'
01:51:04 Created wheel for robotframework-httplibrary: filename=robotframework_httplibrary-0.4.2-py3-none-any.whl size=10014 sha256=9f9781b0efa0cfa216197821489289c7b16da44aa86f624040da0ad4b9f83d3c
01:51:04 Stored in directory: /home/jenkins/.cache/pip/wheels/aa/bc/0d/9a20dd51effef392aae2733cb4c7b66c6fa29fca33d88b57ed
01:51:04 Building wheel for jsonpath-rw (pyproject.toml): started
01:51:04 Building wheel for jsonpath-rw (pyproject.toml): finished with status 'done'
01:51:04 Created wheel for jsonpath-rw: filename=jsonpath_rw-1.4.0-py3-none-any.whl size=15176 sha256=d9c64f99cc494d0f5b82a1794d9657fef9622bc407c145483b4f0bcffdfa0bbb
01:51:04 Stored in directory: /home/jenkins/.cache/pip/wheels/f1/54/63/9a8da38cefae13755097b36cc852decc25d8ef69c37d58d4eb
01:51:04 Successfully built robotframework-sshlibrary ipaddr netifaces pyhocon robotframework-httplibrary jsonpath-rw
01:51:04 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
01:51:12
01:51:12 Successfully installed WebOb-1.8.9 attrs-26.1.0 bcrypt-5.0.0 beautifulsoup4-4.14.3 certifi-2026.4.22 cffi-2.0.0 charset_normalizer-3.4.7 click-8.3.3 cryptography-48.0.0 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.13 invoke-3.0.3 ipaddr-2.2.0 isodate-0.7.2 jmespath-1.1.0 jsonpatch-1.33 jsonpath-rw-1.4.0 jsonpointer-3.1.1 lxml-6.1.0 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-3.0 pyhocon-0.3.63 pynacl-1.6.2 pyparsing-3.3.2 pysocks-1.7.1 python-dateutil-2.9.0.post0 regex-2026.4.4 requests-2.33.1 robotframework-7.4.2 robotframework-httplibrary-0.4.2 robotframework-pythonlibcore-4.5.0 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.43.0 six-1.17.0 sniffio-1.3.1 sortedcontainers-2.4.0 soupsieve-2.8.3 trio-0.33.0 trio-websocket-0.12.2 typing-extensions-4.15.0 urllib3-2.6.3 waitress-3.0.2 websocket-client-1.9.0 webtest-3.0.7 wsproto-1.3.2
01:51:12 + pip freeze
01:51:12 attrs==26.1.0
01:51:12 bcrypt==5.0.0
01:51:12 beautifulsoup4==4.14.3
01:51:12 certifi==2026.4.22
01:51:12 cffi==2.0.0
01:51:12 charset-normalizer==3.4.7
01:51:12 click==8.3.3
01:51:12 cryptography==48.0.0
01:51:12 decorator==5.2.1
01:51:12 distlib==0.4.0
01:51:12 docker-py==1.10.6
01:51:12 docker-pycreds==0.4.0
01:51:12 elastic-transport==8.17.1
01:51:12 elasticsearch==8.19.3
01:51:12 elasticsearch-dsl==8.15.4
01:51:12 enum34==1.1.10
01:51:12 filelock==3.29.0
01:51:12 h11==0.16.0
01:51:12 idna==3.13
01:51:12 invoke==3.0.3
01:51:12 ipaddr==2.2.0
01:51:12 isodate==0.7.2
01:51:12 jmespath==1.1.0
01:51:12 jsonpatch==1.33
01:51:12 jsonpath-rw==1.4.0
01:51:12 jsonpointer==3.1.1
01:51:12 lxml==6.1.0
01:51:12 netaddr==1.3.0
01:51:12 netifaces==0.11.0
01:51:12 outcome==1.3.0.post0
01:51:12 packaging==26.2
01:51:12 paramiko==4.0.0
01:51:12 platformdirs==4.9.6
01:51:12 ply==3.11
01:51:12 pyang==2.7.1
01:51:12 pyangbind==0.8.7
01:51:12 pycparser==3.0
01:51:12 pyhocon==0.3.63
01:51:12 PyNaCl==1.6.2
01:51:12 pyparsing==3.3.2
01:51:12 PySocks==1.7.1
01:51:12 python-dateutil==2.9.0.post0
01:51:12 python-discovery==1.3.0
01:51:12 regex==2026.4.4
01:51:12 requests==2.33.1
01:51:12 robotframework==7.4.2
01:51:12 robotframework-httplibrary==0.4.2
01:51:12 robotframework-pythonlibcore==4.5.0
01:51:12 robotframework-requests==0.9.7
01:51:12 robotframework-selenium2library==3.0.0
01:51:12 robotframework-seleniumlibrary==6.8.0
01:51:12 robotframework-sshlibrary==3.8.0
01:51:12 scapy==2.7.0
01:51:12 scp==0.15.0
01:51:12 selenium==4.43.0
01:51:12 six==1.17.0
01:51:12 sniffio==1.3.1
01:51:12 sortedcontainers==2.4.0
01:51:12 soupsieve==2.8.3
01:51:12 trio==0.33.0
01:51:12 trio-websocket==0.12.2
01:51:12 typing_extensions==4.15.0
01:51:12 urllib3==2.6.3
01:51:12 virtualenv==21.3.1
01:51:12 waitress==3.0.2
01:51:12 WebOb==1.8.9
01:51:12 websocket-client==1.9.0
01:51:12 WebTest==3.0.7
01:51:12 wsproto==1.3.2
01:51:12 [EnvInject] - Injecting environment variables from a build step.
01:51:12 [EnvInject] - Injecting as environment variables the properties file path 'env.properties'
01:51:12 [EnvInject] - Variables injected successfully.
01:51:12 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins7950913600042567606.sh
01:51:12 Setup pyenv:
01:51:12 system
01:51:12 3.8.20
01:51:12 3.9.20
01:51:12 3.10.15
01:51:12 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:51:13 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:51:13 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:51:13 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:51:14 lf-activate-venv(): INFO: Base packages installed successfully
01:51:14 lf-activate-venv(): INFO: Installing additional packages: python-heatclient python-openstackclient yq
01:51:22 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:51:22 + ODL_SYSTEM=()
01:51:22 + TOOLS_SYSTEM=()
01:51:22 + OPENSTACK_SYSTEM=()
01:51:22 + OPENSTACK_CONTROLLERS=()
01:51:22 + mapfile -t ADDR
01:51:22 ++ openstack stack show -f json -c outputs releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:51:22 ++ jq -r '.outputs[] | select(.output_key | match("^vm_[0-9]+_ips$")) | .output_value | .[]'
01:51:24 + for i in "${ADDR[@]}"
01:51:24 ++ ssh 10.30.171.236 hostname -s
01:51:24 Warning: Permanently added '10.30.171.236' (ED25519) to the list of known hosts.
01:51:25 + REMHOST=releng-36899-712-1-mininet-ovs-217-0
01:51:25 + case ${REMHOST} in
01:51:25 + TOOLS_SYSTEM=("${TOOLS_SYSTEM[@]}" "${i}")
01:51:25 + for i in "${ADDR[@]}"
01:51:25 ++ ssh 10.30.171.114 hostname -s
01:51:25 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:25 + REMHOST=releng-36899-712-0-builder-0
01:51:25 + case ${REMHOST} in
01:51:25 + ODL_SYSTEM=("${ODL_SYSTEM[@]}" "${i}")
01:51:25 + echo NUM_ODL_SYSTEM=1
01:51:25 + echo NUM_TOOLS_SYSTEM=1
01:51:25 + '[' '' == yes ']'
01:51:25 + NUM_OPENSTACK_SYSTEM=0
01:51:25 + echo NUM_OPENSTACK_SYSTEM=0
01:51:25 + '[' 0 -eq 2 ']'
01:51:25 + echo ODL_SYSTEM_IP=10.30.171.114
01:51:25 ++ seq 0 0
01:51:25 + for i in $(seq 0 $(( ${#ODL_SYSTEM[@]} - 1 )))
01:51:25 + echo ODL_SYSTEM_1_IP=10.30.171.114
01:51:25 + echo TOOLS_SYSTEM_IP=10.30.171.236
01:51:25 ++ seq 0 0
01:51:25 + for i in $(seq 0 $(( ${#TOOLS_SYSTEM[@]} - 1 )))
01:51:25 + echo TOOLS_SYSTEM_1_IP=10.30.171.236
01:51:25 + openstack_index=0
01:51:25 + NUM_OPENSTACK_CONTROL_NODES=1
01:51:25 + echo NUM_OPENSTACK_CONTROL_NODES=1
01:51:25 ++ seq 0 0
01:51:25 + for i in $(seq 0 $((NUM_OPENSTACK_CONTROL_NODES - 1)))
01:51:25 + echo OPENSTACK_CONTROL_NODE_1_IP=
01:51:25 + NUM_OPENSTACK_COMPUTE_NODES=-1
01:51:25 + echo NUM_OPENSTACK_COMPUTE_NODES=-1
01:51:25 + '[' -1 -ge 2 ']'
01:51:25 ++ seq 0 -2
01:51:25 + NUM_OPENSTACK_HAPROXY_NODES=0
01:51:25 + echo NUM_OPENSTACK_HAPROXY_NODES=0
01:51:25 ++ seq 0 -1
01:51:25 + echo 'Contents of slave_addresses.txt:'
01:51:25 Contents of slave_addresses.txt:
01:51:25 + cat slave_addresses.txt
01:51:25 NUM_ODL_SYSTEM=1
01:51:25 NUM_TOOLS_SYSTEM=1
01:51:25 NUM_OPENSTACK_SYSTEM=0
01:51:25 ODL_SYSTEM_IP=10.30.171.114
01:51:25 ODL_SYSTEM_1_IP=10.30.171.114
01:51:25 TOOLS_SYSTEM_IP=10.30.171.236
01:51:25 TOOLS_SYSTEM_1_IP=10.30.171.236
01:51:25 NUM_OPENSTACK_CONTROL_NODES=1
01:51:25 OPENSTACK_CONTROL_NODE_1_IP=
01:51:25 NUM_OPENSTACK_COMPUTE_NODES=-1
01:51:25 NUM_OPENSTACK_HAPROXY_NODES=0
01:51:25 [EnvInject] - Injecting environment variables from a build step.
01:51:25 [EnvInject] - Injecting as environment variables the properties file path 'slave_addresses.txt'
01:51:25 [EnvInject] - Variables injected successfully.
01:51:25 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/sh /tmp/jenkins17845527460916308461.sh
01:51:25 Preparing for JRE Version 21
01:51:25 Karaf artifact is karaf
01:51:25 Karaf project is integration
01:51:25 Java home is /usr/lib/jvm/java-21-openjdk-amd64
01:51:25 [EnvInject] - Injecting environment variables from a build step.
01:51:25 [EnvInject] - Injecting as environment variables the properties file path 'set_variables.env'
01:51:25 [EnvInject] - Variables injected successfully.
01:51:25 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins9341727348072816982.sh
01:51:25 2026-05-07 01:51:25 URL:https://raw.githubusercontent.com/opendaylight/integration-distribution/stable/titanium/pom.xml [2619/2619] -> "pom.xml" [1]
01:51:26 Bundle version is 0.22.3-SNAPSHOT
01:51:26 --2026-05-07 01:51:26-- https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/maven-metadata.xml
01:51:26 Resolving nexus.opendaylight.org (nexus.opendaylight.org)... 199.204.45.87, 2604:e100:1:0:f816:3eff:fe45:48d6
01:51:26 Connecting to nexus.opendaylight.org (nexus.opendaylight.org)|199.204.45.87|:443... connected.
01:51:26 HTTP request sent, awaiting response... 200 OK
01:51:26 Length: 1410 (1.4K) [application/xml]
01:51:26 Saving to: ‘maven-metadata.xml’
01:51:26
01:51:26 0K . 100% 31.6M=0s
01:51:26
01:51:26 2026-05-07 01:51:26 (31.6 MB/s) - ‘maven-metadata.xml’ saved [1410/1410]
01:51:26
01:51:26
01:51:26
01:51:26 org.opendaylight.integration
01:51:26 karaf
01:51:26 0.22.3-SNAPSHOT
01:51:26
01:51:26
01:51:26 20260507.015016
01:51:26 123
01:51:26
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26 pom
01:51:26 0.22.3-20260507.015016-123
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26 tar.gz
01:51:26 0.22.3-20260507.015016-123
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26 zip
01:51:26 0.22.3-20260507.015016-123
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26 cyclonedx
01:51:26 xml
01:51:26 0.22.3-20260507.015016-123
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26 cyclonedx
01:51:26 json
01:51:26 0.22.3-20260507.015016-123
01:51:26 20260507015016
01:51:26
01:51:26
01:51:26
01:51:26
01:51:26 Nexus timestamp is 0.22.3-20260507.015016-123
01:51:26 Distribution bundle URL is https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/karaf-0.22.3-20260507.015016-123.zip
01:51:26 Distribution bundle is karaf-0.22.3-20260507.015016-123.zip
01:51:26 Distribution bundle version is 0.22.3-SNAPSHOT
01:51:26 Distribution folder is karaf-0.22.3-SNAPSHOT
01:51:26 Nexus prefix is https://nexus.opendaylight.org
01:51:26 [EnvInject] - Injecting environment variables from a build step.
01:51:26 [EnvInject] - Injecting as environment variables the properties file path 'detect_variables.env'
01:51:26 [EnvInject] - Variables injected successfully.
01:51:26 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins7345866664830851134.sh
01:51:26 Setup pyenv:
01:51:26 system
01:51:26 3.8.20
01:51:26 3.9.20
01:51:26 3.10.15
01:51:26 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:51:26 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:51:26 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:51:26 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:51:28 lf-activate-venv(): INFO: Base packages installed successfully
01:51:28 lf-activate-venv(): INFO: Installing additional packages: python-heatclient python-openstackclient
01:51:33 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:51:33 Copying common-functions.sh to /tmp
01:51:35 Copying common-functions.sh to 10.30.171.236:/tmp
01:51:35 Warning: Permanently added '10.30.171.236' (ED25519) to the list of known hosts.
01:51:35 Copying common-functions.sh to 10.30.171.114:/tmp
01:51:35 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:36 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins18383809486657376253.sh
01:51:36 common-functions.sh is being sourced
01:51:36 common-functions environment:
01:51:36 MAVENCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:36 ACTUALFEATURES:
01:51:36 FEATURESCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:36 CUSTOMPROP: /tmp/karaf-0.22.3-SNAPSHOT/etc/custom.properties
01:51:36 LOGCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:36 MEMCONF: /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:36 CONTROLLERMEM: 2048m
01:51:36 AKKACONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/pekko.conf
01:51:36 MODULESCONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/modules.conf
01:51:36 MODULESHARDSCONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/module-shards.conf
01:51:36 SUITES:
01:51:36
01:51:36 #################################################
01:51:36 ## Configure Cluster and Start ##
01:51:36 #################################################
01:51:36 ACTUALFEATURES: odl-infrautils-ready,odl-openflowplugin-flow-services-rest
01:51:36 SPACE_SEPARATED_FEATURES: odl-infrautils-ready odl-openflowplugin-flow-services-rest
01:51:36 Locating script plan to use...
01:51:36 Finished running script plans
01:51:36 Configuring member-1 with IP address 10.30.171.114
01:51:36 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:37 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:37 + source /tmp/common-functions.sh karaf-0.22.3-SNAPSHOT titanium
01:51:37 common-functions.sh is being sourced
01:51:37 ++ [[ /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 ]]
01:51:37 ++ echo 'common-functions.sh is being sourced'
01:51:37 ++ BUNDLEFOLDER=karaf-0.22.3-SNAPSHOT
01:51:37 ++ DISTROSTREAM=titanium
01:51:37 ++ export MAVENCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:37 ++ MAVENCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:37 ++ export FEATURESCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:37 ++ FEATURESCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:37 ++ export CUSTOMPROP=/tmp/karaf-0.22.3-SNAPSHOT/etc/custom.properties
01:51:37 ++ CUSTOMPROP=/tmp/karaf-0.22.3-SNAPSHOT/etc/custom.properties
01:51:37 ++ export LOGCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:37 ++ LOGCONF=/tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:37 ++ export MEMCONF=/tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:37 ++ MEMCONF=/tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:37 ++ export CONTROLLERMEM=
01:51:37 ++ CONTROLLERMEM=
01:51:37 ++ case "${DISTROSTREAM}" in
01:51:37 ++ CLUSTER_SYSTEM=pekko
01:51:37 ++ export AKKACONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/pekko.conf
01:51:37 ++ AKKACONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/pekko.conf
01:51:37 ++ export MODULESCONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/modules.conf
01:51:37 ++ MODULESCONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/modules.conf
01:51:37 ++ export MODULESHARDSCONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/module-shards.conf
01:51:37 ++ MODULESHARDSCONF=/tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/module-shards.conf
01:51:37 ++ print_common_env
01:51:37 ++ cat
01:51:37 common-functions environment:
01:51:37 MAVENCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:37 ACTUALFEATURES:
01:51:37 FEATURESCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:37 CUSTOMPROP: /tmp/karaf-0.22.3-SNAPSHOT/etc/custom.properties
01:51:37 LOGCONF: /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:37 MEMCONF: /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:37 CONTROLLERMEM:
01:51:37 AKKACONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/pekko.conf
01:51:37 MODULESCONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/modules.conf
01:51:37 MODULESHARDSCONF: /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/module-shards.conf
01:51:37 SUITES:
01:51:37
01:51:37 ++ SSH='ssh -t -t'
01:51:37 ++ extra_services_cntl=' dnsmasq.service httpd.service libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service rabbitmq-server.service '
01:51:37 ++ extra_services_cmp=' libvirtd.service openvswitch.service ovs-vswitchd.service ovsdb-server.service '
01:51:37 Changing to /tmp
01:51:37 Downloading the distribution from https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/karaf-0.22.3-20260507.015016-123.zip
01:51:37 + echo 'Changing to /tmp'
01:51:37 + cd /tmp
01:51:37 + echo 'Downloading the distribution from https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/karaf-0.22.3-20260507.015016-123.zip'
01:51:37 + wget --progress=dot:mega https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/karaf-0.22.3-20260507.015016-123.zip
01:51:37 --2026-05-07 01:51:37-- https://nexus.opendaylight.org/content/repositories/opendaylight.snapshot/org/opendaylight/integration/karaf/0.22.3-SNAPSHOT/karaf-0.22.3-20260507.015016-123.zip
01:51:37 Resolving nexus.opendaylight.org (nexus.opendaylight.org)... 199.204.45.87, 2604:e100:1:0:f816:3eff:fe45:48d6
01:51:37 Connecting to nexus.opendaylight.org (nexus.opendaylight.org)|199.204.45.87|:443... connected.
01:51:37 HTTP request sent, awaiting response... 200 OK
01:51:37 Length: 238741049 (228M) [application/zip]
01:51:37 Saving to: ‘karaf-0.22.3-20260507.015016-123.zip’
01:51:37
01:51:37 0K ........ ........ ........ ........ ........ ........ 1% 63.2M 4s
01:51:37 3072K ........ ........ ........ ........ ........ ........ 2% 133M 3s
01:51:37 6144K ........ ........ ........ ........ ........ ........ 3% 194M 2s
01:51:37 9216K ........ ........ ........ ........ ........ ........ 5% 238M 2s
01:51:37 12288K ........ ........ ........ ........ ........ ........ 6% 233M 2s
01:51:37 15360K ........ ........ ........ ........ ........ ........ 7% 205M 1s
01:51:37 18432K ........ ........ ........ ........ ........ ........ 9% 270M 1s
01:51:37 21504K ........ ........ ........ ........ ........ ........ 10% 192M 1s
01:51:37 24576K ........ ........ ........ ........ ........ ........ 11% 260M 1s
01:51:37 27648K ........ ........ ........ ........ ........ ........ 13% 251M 1s
01:51:37 30720K ........ ........ ........ ........ ........ ........ 14% 269M 1s
01:51:37 33792K ........ ........ ........ ........ ........ ........ 15% 291M 1s
01:51:37 36864K ........ ........ ........ ........ ........ ........ 17% 295M 1s
01:51:37 39936K ........ ........ ........ ........ ........ ........ 18% 272M 1s
01:51:37 43008K ........ ........ ........ ........ ........ ........ 19% 268M 1s
01:51:37 46080K ........ ........ ........ ........ ........ ........ 21% 252M 1s
01:51:37 49152K ........ ........ ........ ........ ........ ........ 22% 277M 1s
01:51:37 52224K ........ ........ ........ ........ ........ ........ 23% 199M 1s
01:51:37 55296K ........ ........ ........ ........ ........ ........ 25% 264M 1s
01:51:37 58368K ........ ........ ........ ........ ........ ........ 26% 280M 1s
01:51:37 61440K ........ ........ ........ ........ ........ ........ 27% 329M 1s
01:51:37 64512K ........ ........ ........ ........ ........ ........ 28% 280M 1s
01:51:37 67584K ........ ........ ........ ........ ........ ........ 30% 207M 1s
01:51:37 70656K ........ ........ ........ ........ ........ ........ 31% 384M 1s
01:51:37 73728K ........ ........ ........ ........ ........ ........ 32% 279M 1s
01:51:37 76800K ........ ........ ........ ........ ........ ........ 34% 286M 1s
01:51:37 79872K ........ ........ ........ ........ ........ ........ 35% 282M 1s
01:51:37 82944K ........ ........ ........ ........ ........ ........ 36% 263M 1s
01:51:37 86016K ........ ........ ........ ........ ........ ........ 38% 268M 1s
01:51:37 89088K ........ ........ ........ ........ ........ ........ 39% 279M 1s
01:51:37 92160K ........ ........ ........ ........ ........ ........ 40% 195M 1s
01:51:37 95232K ........ ........ ........ ........ ........ ........ 42% 214M 1s
01:51:37 98304K ........ ........ ........ ........ ........ ........ 43% 263M 1s
01:51:37 101376K ........ ........ ........ ........ ........ ........ 44% 318M 1s
01:51:37 104448K ........ ........ ........ ........ ........ ........ 46% 212M 1s
01:51:37 107520K ........ ........ ........ ........ ........ ........ 47% 208M 1s
01:51:37 110592K ........ ........ ........ ........ ........ ........ 48% 200M 1s
01:51:37 113664K ........ ........ ........ ........ ........ ........ 50% 271M 1s
01:51:37 116736K ........ ........ ........ ........ ........ ........ 51% 292M 0s
01:51:37 119808K ........ ........ ........ ........ ........ ........ 52% 333M 0s
01:51:37 122880K ........ ........ ........ ........ ........ ........ 54% 323M 0s
01:51:37 125952K ........ ........ ........ ........ ........ ........ 55% 174M 0s
01:51:37 129024K ........ ........ ........ ........ ........ ........ 56% 263M 0s
01:51:37 132096K ........ ........ ........ ........ ........ ........ 57% 245M 0s
01:51:37 135168K ........ ........ ........ ........ ........ ........ 59% 296M 0s
01:51:37 138240K ........ ........ ........ ........ ........ ........ 60% 337M 0s
01:51:37 141312K ........ ........ ........ ........ ........ ........ 61% 318M 0s
01:51:37 144384K ........ ........ ........ ........ ........ ........ 63% 290M 0s
01:51:37 147456K ........ ........ ........ ........ ........ ........ 64% 310M 0s
01:51:37 150528K ........ ........ ........ ........ ........ ........ 65% 274M 0s
01:51:37 153600K ........ ........ ........ ........ ........ ........ 67% 284M 0s
01:51:37 156672K ........ ........ ........ ........ ........ ........ 68% 264M 0s
01:51:37 159744K ........ ........ ........ ........ ........ ........ 69% 165M 0s
01:51:37 162816K ........ ........ ........ ........ ........ ........ 71% 240M 0s
01:51:37 165888K ........ ........ ........ ........ ........ ........ 72% 260M 0s
01:51:37 168960K ........ ........ ........ ........ ........ ........ 73% 239M 0s
01:51:37 172032K ........ ........ ........ ........ ........ ........ 75% 297M 0s
01:51:37 175104K ........ ........ ........ ........ ........ ........ 76% 229M 0s
01:51:38 178176K ........ ........ ........ ........ ........ ........ 77% 221M 0s
01:51:38 181248K ........ ........ ........ ........ ........ ........ 79% 241M 0s
01:51:38 184320K ........ ........ ........ ........ ........ ........ 80% 231M 0s
01:51:38 187392K ........ ........ ........ ........ ........ ........ 81% 193M 0s
01:51:38 190464K ........ ........ ........ ........ ........ ........ 83% 205M 0s
01:51:38 193536K ........ ........ ........ ........ ........ ........ 84% 246M 0s
01:51:38 196608K ........ ........ ........ ........ ........ ........ 85% 229M 0s
01:51:38 199680K ........ ........ ........ ........ ........ ........ 86% 233M 0s
01:51:38 202752K ........ ........ ........ ........ ........ ........ 88% 206M 0s
01:51:38 205824K ........ ........ ........ ........ ........ ........ 89% 219M 0s
01:51:38 208896K ........ ........ ........ ........ ........ ........ 90% 215M 0s
01:51:38 211968K ........ ........ ........ ........ ........ ........ 92% 217M 0s
01:51:38 215040K ........ ........ ........ ........ ........ ........ 93% 228M 0s
01:51:38 218112K ........ ........ ........ ........ ........ ........ 94% 202M 0s
01:51:38 221184K ........ ........ ........ ........ ........ ........ 96% 238M 0s
01:51:38 224256K ........ ........ ........ ........ ........ ........ 97% 296M 0s
01:51:38 227328K ........ ........ ........ ........ ........ ........ 98% 114M 0s
01:51:38 230400K ........ ........ ........ ........ ........ .. 100% 177M=1.0s
01:51:38
01:51:38 2026-05-07 01:51:38 (231 MB/s) - ‘karaf-0.22.3-20260507.015016-123.zip’ saved [238741049/238741049]
01:51:38
01:51:38 Extracting the new controller...
01:51:38 + echo 'Extracting the new controller...'
01:51:38 + unzip -q karaf-0.22.3-20260507.015016-123.zip
01:51:40 Adding external repositories...
01:51:40 + echo 'Adding external repositories...'
01:51:40 + 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.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.url.mvn.cfg
01:51:40 ################################################################################
01:51:40 #
01:51:40 # Licensed to the Apache Software Foundation (ASF) under one or more
01:51:40 # contributor license agreements. See the NOTICE file distributed with
01:51:40 # this work for additional information regarding copyright ownership.
01:51:40 # The ASF licenses this file to You under the Apache License, Version 2.0
01:51:40 # (the "License"); you may not use this file except in compliance with
01:51:40 # the License. You may obtain a copy of the License at
01:51:40 #
01:51:40 # http://www.apache.org/licenses/LICENSE-2.0
01:51:40 #
01:51:40 # Unless required by applicable law or agreed to in writing, software
01:51:40 # distributed under the License is distributed on an "AS IS" BASIS,
01:51:40 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
01:51:40 # See the License for the specific language governing permissions and
01:51:40 # limitations under the License.
01:51:40 #
01:51:40 ################################################################################
01:51:40
01:51:40 #
01:51:40 # If set to true, the following property will not allow any certificate to be used
01:51:40 # when accessing Maven repositories through SSL
01:51:40 #
01:51:40 #org.ops4j.pax.url.mvn.certificateCheck=
01:51:40
01:51:40 #
01:51:40 # Path to the local Maven settings file.
01:51:40 # The repositories defined in this file will be automatically added to the list
01:51:40 # of default repositories if the 'org.ops4j.pax.url.mvn.repositories' property
01:51:40 # below is not set.
01:51:40 # The following locations are checked for the existence of the settings.xml file
01:51:40 # * 1. looks for the specified url
01:51:40 # * 2. if not found looks for ${user.home}/.m2/settings.xml
01:51:40 # * 3. if not found looks for ${maven.home}/conf/settings.xml
01:51:40 # * 4. if not found looks for ${M2_HOME}/conf/settings.xml
01:51:40 #
01:51:40 #org.ops4j.pax.url.mvn.settings=
01:51:40
01:51:40 #
01:51:40 # Path to the local Maven repository which is used to avoid downloading
01:51:40 # artifacts when they already exist locally.
01:51:40 # The value of this property will be extracted from the settings.xml file
01:51:40 # above, or defaulted to:
01:51:40 # System.getProperty( "user.home" ) + "/.m2/repository"
01:51:40 #
01:51:40 org.ops4j.pax.url.mvn.localRepository=${karaf.home}/${karaf.default.repository}
01:51:40
01:51:40 #
01:51:40 # Default this to false. It's just weird to use undocumented repos
01:51:40 #
01:51:40 org.ops4j.pax.url.mvn.useFallbackRepositories=false
01:51:40
01:51:40 #
01:51:40 # Uncomment if you don't wanna use the proxy settings
01:51:40 # from the Maven conf/settings.xml file
01:51:40 #
01:51:40 # org.ops4j.pax.url.mvn.proxySupport=false
01:51:40
01:51:40 #
01:51:40 # Comma separated list of repositories scanned when resolving an artifact.
01:51:40 # Those repositories will be checked before iterating through the
01:51:40 # below list of repositories and even before the local repository
01:51:40 # A repository url can be appended with zero or more of the following flags:
01:51:40 # @snapshots : the repository contains snaphots
01:51:40 # @noreleases : the repository does not contain any released artifacts
01:51:40 #
01:51:40 # The following property value will add the system folder as a repo.
01:51:40 #
01:51:40 org.ops4j.pax.url.mvn.defaultRepositories=\
01:51:40 file:${karaf.home}/${karaf.default.repository}@id=system.repository@snapshots,\
01:51:40 file:${karaf.data}/kar@id=kar.repository@multi@snapshots,\
01:51:40 file:${karaf.base}/${karaf.default.repository}@id=child.system.repository@snapshots
01:51:40
01:51:40 # Use the default local repo (e.g.~/.m2/repository) as a "remote" repo
01:51:40 #org.ops4j.pax.url.mvn.defaultLocalRepoAsRemote=false
01:51:40
01:51:40 #
01:51:40 # Comma separated list of repositories scanned when resolving an artifact.
01:51:40 # The default list includes the following repositories:
01:51:40 # http://repo1.maven.org/maven2@id=central
01:51:40 # http://repository.springsource.com/maven/bundles/release@id=spring.ebr
01:51:40 # http://repository.springsource.com/maven/bundles/external@id=spring.ebr.external
01:51:40 # http://zodiac.springsource.com/maven/bundles/release@id=gemini
01:51:40 # http://repository.apache.org/content/groups/snapshots-group@id=apache@snapshots@noreleases
01:51:40 # https://oss.sonatype.org/content/repositories/snapshots@id=sonatype.snapshots.deploy@snapshots@noreleases
01:51:40 # https://oss.sonatype.org/content/repositories/ops4j-snapshots@id=ops4j.sonatype.snapshots.deploy@snapshots@noreleases
01:51:40 # To add repositories to the default ones, prepend '+' to the list of repositories
01:51:40 # to add.
01:51:40 # A repository url can be appended with zero or more of the following flags:
01:51:40 # @snapshots : the repository contains snapshots
01:51:40 # @noreleases : the repository does not contain any released artifacts
01:51:40 # @id=repository.id : the id for the repository, just like in the settings.xml this is optional but recommended
01:51:40 #
01:51:40 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
01:51:40
01:51:40 ### ^^^ No remote repositories. This is the only ODL change compared to Karaf defaults.Configuring the startup features...
01:51:40 + [[ True == \T\r\u\e ]]
01:51:40 + echo 'Configuring the startup features...'
01:51:40 + sed -ie 's/\(featuresBoot=\|featuresBoot =\)/featuresBoot = odl-infrautils-ready,odl-openflowplugin-flow-services-rest,/g' /tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:40 + FEATURE_TEST_STRING=features-test
01:51:40 + FEATURE_TEST_VERSION=0.22.3-SNAPSHOT
01:51:40 + KARAF_VERSION=karaf4
01:51:40 + [[ integration == \i\n\t\e\g\r\a\t\i\o\n ]]
01:51:40 + sed -ie 's%\(featuresRepositories=\|featuresRepositories =\)%featuresRepositories = mvn:org.opendaylight.integration/features-test/0.22.3-SNAPSHOT/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features,%g' /tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:40 + [[ ! -z '' ]]
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/etc/org.apache.karaf.features.cfg
01:51:40 ################################################################################
01:51:40 #
01:51:40 # Licensed to the Apache Software Foundation (ASF) under one or more
01:51:40 # contributor license agreements. See the NOTICE file distributed with
01:51:40 # this work for additional information regarding copyright ownership.
01:51:40 # The ASF licenses this file to You under the Apache License, Version 2.0
01:51:40 # (the "License"); you may not use this file except in compliance with
01:51:40 # the License. You may obtain a copy of the License at
01:51:40 #
01:51:40 # http://www.apache.org/licenses/LICENSE-2.0
01:51:40 #
01:51:40 # Unless required by applicable law or agreed to in writing, software
01:51:40 # distributed under the License is distributed on an "AS IS" BASIS,
01:51:40 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
01:51:40 # See the License for the specific language governing permissions and
01:51:40 # limitations under the License.
01:51:40 #
01:51:40 ################################################################################
01:51:40
01:51:40 #
01:51:40 # Comma separated list of features repositories to register by default
01:51:40 #
01:51:40 featuresRepositories = mvn:org.opendaylight.integration/features-test/0.22.3-SNAPSHOT/xml/features,mvn:org.apache.karaf.decanter/apache-karaf-decanter/1.2.0/xml/features, file:${karaf.etc}/73a23c50-2e81-4e47-bc2c-7d83fe083816.xml
01:51:40
01:51:40 #
01:51:40 # Comma separated list of features to install at startup
01:51:40 #
01:51:40 featuresBoot = odl-infrautils-ready,odl-openflowplugin-flow-services-rest, 432a2482-ca64-4804-9d0e-40f236d59321
01:51:40
01:51:40 #
01:51:40 # Resource repositories (OBR) that the features resolver can use
01:51:40 # to resolve requirements/capabilities
01:51:40 #
01:51:40 # The format of the resourceRepositories is
01:51:40 # resourceRepositories=[xml:url|json:url],...
01:51:40 # for Instance:
01:51:40 #
01:51:40 #resourceRepositories=xml:http://host/path/to/index.xml
01:51:40 # or
01:51:40 #resourceRepositories=json:http://host/path/to/index.json
01:51:40 #
01:51:40
01:51:40 #
01:51:40 # Defines if the boot features are started in asynchronous mode (in a dedicated thread)
01:51:40 #
01:51:40 featuresBootAsynchronous=false
01:51:40
01:51:40 #
01:51:40 # Service requirements enforcement
01:51:40 #
01:51:40 # By default, the feature resolver checks the service requirements/capabilities of
01:51:40 # bundles for new features (xml schema >= 1.3.0) in order to automatically installs
01:51:40 # the required bundles.
01:51:40 # The following flag can have those values:
01:51:40 # - disable: service requirements are completely ignored
01:51:40 # - default: service requirements are ignored for old features
01:51:40 # - enforce: service requirements are always verified
01:51:40 #
01:51:40 #serviceRequirements=default
01:51:40
01:51:40 #
01:51:40 # Store cfg file for config element in feature
01:51:40 #
01:51:40 #configCfgStore=true
01:51:40
01:51:40 #
01:51:40 # Define if the feature service automatically refresh bundles
01:51:40 #
01:51:40 autoRefresh=true
01:51:40
01:51:40 #
01:51:40 # Configuration of features processing mechanism (overrides, blacklisting, modification of features)
01:51:40 # XML file defines instructions related to features processing
01:51:40 # versions.properties may declare properties to resolve placeholders in XML file
01:51:40 # both files are relative to ${karaf.etc}
01:51:40 #
01:51:40 #featureProcessing=org.apache.karaf.features.xml
01:51:40 #featureProcessingVersions=versions.properties
01:51:40 + configure_karaf_log karaf4 ''
01:51:40 + local -r karaf_version=karaf4
01:51:40 + local -r controllerdebugmap=
01:51:40 + local logapi=log4j
01:51:40 + grep log4j2 /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:40 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n
01:51:40 log4j2.rootLogger.level = INFO
01:51:40 #log4j2.rootLogger.type = asyncRoot
01:51:40 #log4j2.rootLogger.includeLocation = false
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile
01:51:40 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi
01:51:40 log4j2.rootLogger.appenderRef.Console.ref = Console
01:51:40 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter
01:51:40 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF}
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL
01:51:40 log4j2.logger.spifly.name = org.apache.aries.spifly
01:51:40 log4j2.logger.spifly.level = WARN
01:51:40 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit
01:51:40 log4j2.logger.audit.level = INFO
01:51:40 log4j2.logger.audit.additivity = false
01:51:40 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile
01:51:40 # Console appender not used by default (see log4j2.rootLogger.appenderRefs)
01:51:40 log4j2.appender.console.type = Console
01:51:40 log4j2.appender.console.name = Console
01:51:40 log4j2.appender.console.layout.type = PatternLayout
01:51:40 log4j2.appender.console.layout.pattern = ${log4j2.pattern}
01:51:40 log4j2.appender.rolling.type = RollingRandomAccessFile
01:51:40 log4j2.appender.rolling.name = RollingFile
01:51:40 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log
01:51:40 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i
01:51:40 #log4j2.appender.rolling.immediateFlush = false
01:51:40 log4j2.appender.rolling.append = true
01:51:40 log4j2.appender.rolling.layout.type = PatternLayout
01:51:40 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern}
01:51:40 log4j2.appender.rolling.policies.type = Policies
01:51:40 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
01:51:40 log4j2.appender.rolling.policies.size.size = 64MB
01:51:40 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy
01:51:40 log4j2.appender.rolling.strategy.max = 7
01:51:40 log4j2.appender.audit.type = RollingRandomAccessFile
01:51:40 log4j2.appender.audit.name = AuditRollingFile
01:51:40 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log
01:51:40 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i
01:51:40 log4j2.appender.audit.append = true
01:51:40 log4j2.appender.audit.layout.type = PatternLayout
01:51:40 log4j2.appender.audit.layout.pattern = ${log4j2.pattern}
01:51:40 log4j2.appender.audit.policies.type = Policies
01:51:40 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy
01:51:40 log4j2.appender.audit.policies.size.size = 8MB
01:51:40 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy
01:51:40 log4j2.appender.audit.strategy.max = 7
01:51:40 log4j2.appender.osgi.type = PaxOsgi
01:51:40 log4j2.appender.osgi.name = PaxOsgi
01:51:40 log4j2.appender.osgi.filter = *
01:51:40 #log4j2.logger.aether.name = shaded.org.eclipse.aether
01:51:40 #log4j2.logger.aether.level = TRACE
01:51:40 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers
01:51:40 #log4j2.logger.http-headers.level = DEBUG
01:51:40 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn
01:51:40 #log4j2.logger.maven.level = TRACE
01:51:40 Configuring the karaf log... karaf_version: karaf4, logapi: log4j2
01:51:40 + logapi=log4j2
01:51:40 + echo 'Configuring the karaf log... karaf_version: karaf4, logapi: log4j2'
01:51:40 + '[' log4j2 == log4j2 ']'
01:51:40 + sed -ie 's/log4j2.appender.rolling.policies.size.size = 64MB/log4j2.appender.rolling.policies.size.size = 1GB/g' /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:40 controllerdebugmap:
01:51:40 cat /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:40 + orgmodule=org.opendaylight.yangtools.yang.parser.repo.YangTextSchemaContextResolver
01:51:40 + orgmodule_=org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver
01:51:40 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN'
01:51:40 + echo 'log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN'
01:51:40 + unset IFS
01:51:40 + echo 'controllerdebugmap: '
01:51:40 + '[' -n '' ']'
01:51:40 + echo 'cat /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg'
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/etc/org.ops4j.pax.logging.cfg
01:51:40 ################################################################################
01:51:40 #
01:51:40 # Licensed to the Apache Software Foundation (ASF) under one or more
01:51:40 # contributor license agreements. See the NOTICE file distributed with
01:51:40 # this work for additional information regarding copyright ownership.
01:51:40 # The ASF licenses this file to You under the Apache License, Version 2.0
01:51:40 # (the "License"); you may not use this file except in compliance with
01:51:40 # the License. You may obtain a copy of the License at
01:51:40 #
01:51:40 # http://www.apache.org/licenses/LICENSE-2.0
01:51:40 #
01:51:40 # Unless required by applicable law or agreed to in writing, software
01:51:40 # distributed under the License is distributed on an "AS IS" BASIS,
01:51:40 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
01:51:40 # See the License for the specific language governing permissions and
01:51:40 # limitations under the License.
01:51:40 #
01:51:40 ################################################################################
01:51:40
01:51:40 # Common pattern layout for appenders
01:51:40 log4j2.pattern = %d{ISO8601} | %-5p | %-16t | %-32c{1} | %X{bundle.id} - %X{bundle.name} - %X{bundle.version} | %m%n
01:51:40
01:51:40 # Root logger
01:51:40 log4j2.rootLogger.level = INFO
01:51:40 # uncomment to use asynchronous loggers, which require mvn:com.lmax/disruptor/3.3.2 library
01:51:40 #log4j2.rootLogger.type = asyncRoot
01:51:40 #log4j2.rootLogger.includeLocation = false
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.ref = RollingFile
01:51:40 log4j2.rootLogger.appenderRef.PaxOsgi.ref = PaxOsgi
01:51:40 log4j2.rootLogger.appenderRef.Console.ref = Console
01:51:40 log4j2.rootLogger.appenderRef.Console.filter.threshold.type = ThresholdFilter
01:51:40 log4j2.rootLogger.appenderRef.Console.filter.threshold.level = ${karaf.log.console:-OFF}
01:51:40
01:51:40 # Filters for logs marked by org.opendaylight.odlparent.Markers
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.type = ContextMapFilter
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.type = KeyValuePair
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.key = slf4j.marker
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.pair1.value = CONFIDENTIAL
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.operator = or
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMatch = DENY
01:51:40 log4j2.rootLogger.appenderRef.RollingFile.filter.confidential.onMismatch = NEUTRAL
01:51:40
01:51:40 # Loggers configuration
01:51:40
01:51:40 # Spifly logger
01:51:40 log4j2.logger.spifly.name = org.apache.aries.spifly
01:51:40 log4j2.logger.spifly.level = WARN
01:51:40
01:51:40 # Security audit logger
01:51:40 log4j2.logger.audit.name = org.apache.karaf.jaas.modules.audit
01:51:40 log4j2.logger.audit.level = INFO
01:51:40 log4j2.logger.audit.additivity = false
01:51:40 log4j2.logger.audit.appenderRef.AuditRollingFile.ref = AuditRollingFile
01:51:40
01:51:40 # Appenders configuration
01:51:40
01:51:40 # Console appender not used by default (see log4j2.rootLogger.appenderRefs)
01:51:40 log4j2.appender.console.type = Console
01:51:40 log4j2.appender.console.name = Console
01:51:40 log4j2.appender.console.layout.type = PatternLayout
01:51:40 log4j2.appender.console.layout.pattern = ${log4j2.pattern}
01:51:40
01:51:40 # Rolling file appender
01:51:40 log4j2.appender.rolling.type = RollingRandomAccessFile
01:51:40 log4j2.appender.rolling.name = RollingFile
01:51:40 log4j2.appender.rolling.fileName = ${karaf.data}/log/karaf.log
01:51:40 log4j2.appender.rolling.filePattern = ${karaf.data}/log/karaf.log.%i
01:51:40 # uncomment to not force a disk flush
01:51:40 #log4j2.appender.rolling.immediateFlush = false
01:51:40 log4j2.appender.rolling.append = true
01:51:40 log4j2.appender.rolling.layout.type = PatternLayout
01:51:40 log4j2.appender.rolling.layout.pattern = ${log4j2.pattern}
01:51:40 log4j2.appender.rolling.policies.type = Policies
01:51:40 log4j2.appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
01:51:40 log4j2.appender.rolling.policies.size.size = 1GB
01:51:40 log4j2.appender.rolling.strategy.type = DefaultRolloverStrategy
01:51:40 log4j2.appender.rolling.strategy.max = 7
01:51:40
01:51:40 # Audit file appender
01:51:40 log4j2.appender.audit.type = RollingRandomAccessFile
01:51:40 log4j2.appender.audit.name = AuditRollingFile
01:51:40 log4j2.appender.audit.fileName = ${karaf.data}/security/audit.log
01:51:40 log4j2.appender.audit.filePattern = ${karaf.data}/security/audit.log.%i
01:51:40 log4j2.appender.audit.append = true
01:51:40 log4j2.appender.audit.layout.type = PatternLayout
01:51:40 log4j2.appender.audit.layout.pattern = ${log4j2.pattern}
01:51:40 log4j2.appender.audit.policies.type = Policies
01:51:40 log4j2.appender.audit.policies.size.type = SizeBasedTriggeringPolicy
01:51:40 log4j2.appender.audit.policies.size.size = 8MB
01:51:40 log4j2.appender.audit.strategy.type = DefaultRolloverStrategy
01:51:40 log4j2.appender.audit.strategy.max = 7
01:51:40
01:51:40 # OSGi appender
01:51:40 log4j2.appender.osgi.type = PaxOsgi
01:51:40 log4j2.appender.osgi.name = PaxOsgi
01:51:40 log4j2.appender.osgi.filter = *
01:51:40
01:51:40 # help with identification of maven-related problems with pax-url-aether
01:51:40 #log4j2.logger.aether.name = shaded.org.eclipse.aether
01:51:40 #log4j2.logger.aether.level = TRACE
01:51:40 #log4j2.logger.http-headers.name = shaded.org.apache.http.headers
01:51:40 #log4j2.logger.http-headers.level = DEBUG
01:51:40 #log4j2.logger.maven.name = org.ops4j.pax.url.mvn
01:51:40 #log4j2.logger.maven.level = TRACE
01:51:40 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.name = WARN
01:51:40 log4j2.logger.org_opendaylight_yangtools_yang_parser_repo_YangTextSchemaContextResolver.level = WARN
01:51:40 + set_java_vars /usr/lib/jvm/java-21-openjdk-amd64 2048m /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 + local -r java_home=/usr/lib/jvm/java-21-openjdk-amd64
01:51:40 Configure
01:51:40 java home: /usr/lib/jvm/java-21-openjdk-amd64
01:51:40 max memory: 2048m
01:51:40 memconf: /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 + local -r controllermem=2048m
01:51:40 + local -r memconf=/tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 + echo Configure
01:51:40 + echo ' java home: /usr/lib/jvm/java-21-openjdk-amd64'
01:51:40 + echo ' max memory: 2048m'
01:51:40 + echo ' memconf: /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv'
01:51:40 + sed -ie 's%^# export JAVA_HOME%export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64}%g' /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 + sed -ie 's/JAVA_MAX_MEM="2048m"/JAVA_MAX_MEM=2048m/g' /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 cat /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 + echo 'cat /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv'
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/bin/setenv
01:51:40 #!/bin/sh
01:51:40 #
01:51:40 # Licensed to the Apache Software Foundation (ASF) under one or more
01:51:40 # contributor license agreements. See the NOTICE file distributed with
01:51:40 # this work for additional information regarding copyright ownership.
01:51:40 # The ASF licenses this file to You under the Apache License, Version 2.0
01:51:40 # (the "License"); you may not use this file except in compliance with
01:51:40 # the License. You may obtain a copy of the License at
01:51:40 #
01:51:40 # http://www.apache.org/licenses/LICENSE-2.0
01:51:40 #
01:51:40 # Unless required by applicable law or agreed to in writing, software
01:51:40 # distributed under the License is distributed on an "AS IS" BASIS,
01:51:40 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
01:51:40 # See the License for the specific language governing permissions and
01:51:40 # limitations under the License.
01:51:40 #
01:51:40
01:51:40 #
01:51:40 # handle specific scripts; the SCRIPT_NAME is exactly the name of the Karaf
01:51:40 # script: client, instance, shell, start, status, stop, karaf
01:51:40 #
01:51:40 # if [ "${KARAF_SCRIPT}" == "SCRIPT_NAME" ]; then
01:51:40 # Actions go here...
01:51:40 # fi
01:51:40
01:51:40 #
01:51:40 # general settings which should be applied for all scripts go here; please keep
01:51:40 # in mind that it is possible that scripts might be executed more than once, e.g.
01:51:40 # in example of the start script where the start script is executed first and the
01:51:40 # karaf script afterwards.
01:51:40 #
01:51:40
01:51:40 #
01:51:40 # The following section shows the possible configuration options for the default
01:51:40 # karaf scripts
01:51:40 #
01:51:40 export JAVA_HOME=${JAVA_HOME:-/usr/lib/jvm/java-21-openjdk-amd64} # Location of Java installation
01:51:40 # export JAVA_OPTS # Generic JVM options, for instance, where you can pass the memory configuration
01:51:40 # export JAVA_NON_DEBUG_OPTS # Additional non-debug JVM options
01:51:40 # export EXTRA_JAVA_OPTS # Additional JVM options
01:51:40 # export KARAF_HOME # Karaf home folder
01:51:40 # export KARAF_DATA # Karaf data folder
01:51:40 # export KARAF_BASE # Karaf base folder
01:51:40 # export KARAF_ETC # Karaf etc folder
01:51:40 # export KARAF_LOG # Karaf log folder
01:51:40 # export KARAF_SYSTEM_OPTS # First citizen Karaf options
01:51:40 # export KARAF_OPTS # Additional available Karaf options
01:51:40 # export KARAF_DEBUG # Enable debug mode
01:51:40 # export KARAF_REDIRECT # Enable/set the std/err redirection when using bin/start
01:51:40 # export KARAF_NOROOT # Prevent execution as root if set to true
01:51:40 Set Java version
01:51:40 + echo 'Set Java version'
01:51:40 + sudo /usr/sbin/alternatives --install /usr/bin/java java /usr/lib/jvm/java-21-openjdk-amd64/bin/java 1
01:51:40 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper
01:51:40 sudo: a password is required
01:51:40 + sudo /usr/sbin/alternatives --set java /usr/lib/jvm/java-21-openjdk-amd64/bin/java
01:51:40 sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper
01:51:40 sudo: a password is required
01:51:40 JDK default version ...
01:51:40 + echo 'JDK default version ...'
01:51:40 + java -version
01:51:40 openjdk version "21.0.10" 2026-01-20
01:51:40 OpenJDK Runtime Environment (build 21.0.10+7-Ubuntu-122.04)
01:51:40 OpenJDK 64-Bit Server VM (build 21.0.10+7-Ubuntu-122.04, mixed mode, sharing)
01:51:40 Set JAVA_HOME
01:51:40 + echo 'Set JAVA_HOME'
01:51:40 + export JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64
01:51:40 + JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64
01:51:40 ++ readlink -e /usr/lib/jvm/java-21-openjdk-amd64/bin/java
01:51:40 Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java
01:51:40 Listing all open ports on controller system...
01:51:40 + JAVA_RESOLVED=/usr/lib/jvm/java-21-openjdk-amd64/bin/java
01:51:40 + echo 'Java binary pointed at by JAVA_HOME: /usr/lib/jvm/java-21-openjdk-amd64/bin/java'
01:51:40 + echo 'Listing all open ports on controller system...'
01:51:40 + netstat -pnatu
01:51:40 /tmp/configuration-script.sh: line 40: netstat: command not found
01:51:40 Configuring cluster
01:51:40 + '[' -f /tmp/custom_shard_config.txt ']'
01:51:40 + echo 'Configuring cluster'
01:51:40 + /tmp/karaf-0.22.3-SNAPSHOT/bin/configure_cluster.sh 1 10.30.171.114
01:51:40 ################################################
01:51:40 ## Configure Cluster ##
01:51:40 ################################################
01:51:40 NOTE: Cluster configuration files not found. Copying from
01:51:40 /tmp/karaf-0.22.3-SNAPSHOT/system/org/opendaylight/controller/sal-clustering-config/11.0.4
01:51:40 Configuring unique name in pekko.conf
01:51:40 Configuring hostname in pekko.conf
01:51:40 Configuring data and rpc seed nodes in pekko.conf
01:51:40 modules = [
01:51:40
01:51:40 {
01:51:40 name = "inventory"
01:51:40 namespace = "urn:opendaylight:inventory"
01:51:40 shard-strategy = "module"
01:51:40 },
01:51:40 {
01:51:40 name = "topology"
01:51:40 namespace = "urn:TBD:params:xml:ns:yang:network-topology"
01:51:40 shard-strategy = "module"
01:51:40 },
01:51:40 {
01:51:40 name = "toaster"
01:51:40 namespace = "http://netconfcentral.org/ns/toaster"
01:51:40 shard-strategy = "module"
01:51:40 }
01:51:40 ]
01:51:40 Configuring replication type in module-shards.conf
01:51:40 ################################################
01:51:40 ## NOTE: Manually restart controller to ##
01:51:40 ## apply configuration. ##
01:51:40 ################################################
01:51:40 Dump pekko.conf
01:51:40 + echo 'Dump pekko.conf'
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/pekko.conf
01:51:40
01:51:40 odl-cluster-data {
01:51:40 pekko {
01:51:40 remote {
01:51:40 artery {
01:51:40 enabled = on
01:51:40 transport = tcp
01:51:40 canonical.hostname = "10.30.171.114"
01:51:40 canonical.port = 2550
01:51:40 }
01:51:40 }
01:51:40
01:51:40 cluster {
01:51:40 # Using artery.
01:51:40 seed-nodes = ["pekko://opendaylight-cluster-data@10.30.171.114:2550"]
01:51:40
01:51:40 roles = ["member-1"]
01:51:40
01:51:40 # when under load we might trip a false positive on the failure detector
01:51:40 # failure-detector {
01:51:40 # heartbeat-interval = 4 s
01:51:40 # acceptable-heartbeat-pause = 16s
01:51:40 # }
01:51:40 }
01:51:40
01:51:40 persistence {
01:51:40 # By default the snapshots/journal directories live in KARAF_HOME. You can choose to put it somewhere else by
01:51:40 # modifying the following two properties. The directory location specified may be a relative or absolute path.
01:51:40 # The relative path is always relative to KARAF_HOME.
01:51:40
01:51:40 # snapshot-store.local.dir = "target/snapshots"
01:51:40
01:51:40 # Use lz4 compression for LocalSnapshotStore snapshots
01:51:40 snapshot-store.local.use-lz4-compression = false
01:51:40 # Size of blocks for lz4 compression: 64KB, 256KB, 1MB or 4MB
01:51:40 snapshot-store.local.lz4-blocksize = 256KB
01:51:40 }
01:51:40 disable-default-actor-system-quarantined-event-handling = "false"
01:51:40 }
01:51:40 }
01:51:40 Dump modules.conf
01:51:40 + echo 'Dump modules.conf'
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/modules.conf
01:51:40 modules = [
01:51:40
01:51:40 {
01:51:40 name = "inventory"
01:51:40 namespace = "urn:opendaylight:inventory"
01:51:40 shard-strategy = "module"
01:51:40 },
01:51:40 {
01:51:40 name = "topology"
01:51:40 namespace = "urn:TBD:params:xml:ns:yang:network-topology"
01:51:40 shard-strategy = "module"
01:51:40 },
01:51:40 {
01:51:40 name = "toaster"
01:51:40 namespace = "http://netconfcentral.org/ns/toaster"
01:51:40 shard-strategy = "module"
01:51:40 }
01:51:40 ]
01:51:40 Dump module-shards.conf
01:51:40 + echo 'Dump module-shards.conf'
01:51:40 + cat /tmp/karaf-0.22.3-SNAPSHOT/configuration/initial/module-shards.conf
01:51:40 module-shards = [
01:51:40 {
01:51:40 name = "default"
01:51:40 shards = [
01:51:40 {
01:51:40 name = "default"
01:51:40 replicas = ["member-1"]
01:51:40 }
01:51:40 ]
01:51:40 },
01:51:40 {
01:51:40 name = "inventory"
01:51:40 shards = [
01:51:40 {
01:51:40 name="inventory"
01:51:40 replicas = ["member-1"]
01:51:40 }
01:51:40 ]
01:51:40 },
01:51:40 {
01:51:40 name = "topology"
01:51:40 shards = [
01:51:40 {
01:51:40 name="topology"
01:51:40 replicas = ["member-1"]
01:51:40 }
01:51:40 ]
01:51:40 },
01:51:40 {
01:51:40 name = "toaster"
01:51:40 shards = [
01:51:40 {
01:51:40 name="toaster"
01:51:40 replicas = ["member-1"]
01:51:40 }
01:51:40 ]
01:51:40 }
01:51:40 ]
01:51:40 Locating config plan to use...
01:51:40 config plan exists!!!
01:51:40 Changing the config plan path...
01:51:40 # Place the suites in run order:
01:51:40 /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/scripts/set_persistence_off.sh
01:51:40 /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/scripts/increase_of_stats_interval.sh
01:51:40 Executing /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/scripts/set_persistence_off.sh...
01:51:40 Disable persistence in member-1 with IP address 10.30.171.114
01:51:40 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:40 NOTE: Cluster configuration file not found. Copying from
01:51:40 /tmp/karaf-0.22.3-SNAPSHOT/system/org/opendaylight/controller/sal-clustering-config/11.0.4
01:51:40 disabling config datastore persistence
01:51:40 ################################################
01:51:40 ## NOTE: Manually restart controller to ##
01:51:40 ## apply configuration. ##
01:51:40 ################################################
01:51:40 Executing /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/scripts/increase_of_stats_interval.sh...
01:51:40 Running bundleresync_flag script on ODL Controller(s)
01:51:40 Enabling bundleresync_flag on 10.30.171.114
01:51:41 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:41 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:41 # vim:set ft=jproperties:
01:51:41 ################################################################################
01:51:41 # OpenFlowPlugin configuration file
01:51:41 #
01:51:41 # All config parameters listed here require to be configured before switch
01:51:41 # connection, else requires a switch restart.
01:51:41 # All parameters here will be persisted, however need to change it explicitly
01:51:41 # for each node of the cluster.
01:51:41 ################################################################################
01:51:41
01:51:41 #
01:51:41 # Quota for maximum number of RPC requests
01:51:41 #
01:51:41 # rpc-requests-quota=20000
01:51:41
01:51:41 #
01:51:41 # This parameter indicates whether it is mandatory for switch to support OF1.3
01:51:41 # features : table, flow, meter,group. If this is set to true and switch doesn't
01:51:41 # support these features its connection will be denied.
01:51:41 #
01:51:41 # switch-features-mandatory=false
01:51:41
01:51:41 #
01:51:41 # Global notification quota
01:51:41 #
01:51:41 # global-notification-quota=64000
01:51:41
01:51:41 #
01:51:41 # If enabled, periodic statistics gathering will be turned on
01:51:41 #
01:51:41 # is-statistics-polling-on=true
01:51:41
01:51:41 #
01:51:41 # If enabled, periodic statistics gathering will be turned on for the given capability
01:51:41 #
01:51:41 # is-table-statistics-polling-on=true
01:51:41 # is-flow-statistics-polling-on=true
01:51:41 # is-group-statistics-polling-on=true
01:51:41 # is-meter-statistics-polling-on=true
01:51:41 # is-port-statistics-polling-on=true
01:51:41 # is-queue-statistics-polling-on=true
01:51:41
01:51:41 #
01:51:41 # Expose backward compatible statistics RPCs providing result in form of
01:51:41 # asynchronous notification. This is deprecated, use direct statistics instead.
01:51:41 #
01:51:41 # is-statistics-rpc-enabled=false
01:51:41
01:51:41 #
01:51:41 # Barrier timeout
01:51:41 #
01:51:41 # barrier-interval-timeout-limit=500
01:51:41
01:51:41 #
01:51:41 # Barrier limit
01:51:41 #
01:51:41 # barrier-count-limit=25600
01:51:41
01:51:41 #
01:51:41 # How long we should wait for echo reply (value is in milliseconds)
01:51:41 #
01:51:41 # echo-reply-timeout=2000
01:51:41
01:51:41 #
01:51:41 # Minimum (starting) number of threads in thread pool
01:51:41 #
01:51:41 # thread-pool-min-threads=1
01:51:41
01:51:41 #
01:51:41 # Maximum number of threads in thread pool
01:51:41 #
01:51:41 # thread-pool-max-threads=32000
01:51:41
01:51:41 #
01:51:41 # After how much time (in seconds) of inactivity will be threads in pool
01:51:41 # terminated
01:51:41 #
01:51:41 # thread-pool-timeout=60
01:51:41
01:51:41 #
01:51:41 # Turning on flow removed notification
01:51:41 #
01:51:41 # enable-flow-removed-notification=true
01:51:41
01:51:41 #
01:51:41 # Ability to skip pulling and storing of large table features. These features
01:51:41 # are still available via rpc but if set to true then maintenance in DS will be
01:51:41 # omitted
01:51:41 #
01:51:41 # skip-table-features=true
01:51:41
01:51:41 #
01:51:41 # Initial delay used in polling the statistics, value is in milliseconds
01:51:41 #
01:51:41 basic-timer-delay=10000
01:51:41
01:51:41 #
01:51:41 # Maximum timer delay is the wait time to collect next statistics used in
01:51:41 # polling the statistics, value is in milliseconds
01:51:41 #
01:51:41 # maximum-timer-delay=900000
01:51:41
01:51:41 #
01:51:41 # When true, openflowplugin won't send any specific role
01:51:41 # request down to the switch after plugin internally decides the
01:51:41 # ownership of the device using Entity Ownership Service. In this
01:51:41 # scenario, controller connection for the device will be in equal
01:51:41 # role. The behavior will be same for single node setup and clustered
01:51:41 # setup. In clustered scenario, all the controller will be in equal
01:51:41 # role for the device. In this case device will send all asynchronous
01:51:41 # event messages (e.g packet_in) to all the controllers, but openflowplugin
01:51:41 # will drop these events for the controller instances that is internally
01:51:41 # not owning the device.
01:51:41 #
01:51:41 # enable-equal-role=false
01:51:41
01:51:41 #
01:51:41 # When true, Yang models are serialized and deserialized directly to and from
01:51:41 # format supported by device, so serialization and deserialization is faster.
01:51:41 # Otherwise, models are first serialized to Openflow specification models and
01:51:41 # then to format supported by device, and reversed when deserializing.
01:51:41 #
01:51:41 # use-single-layer-serialization=true
01:51:41
01:51:41 #
01:51:41 # To limit the number of datapath nodes to be connected to the controller instance
01:51:41 # per minute. When the default value of zero is set, then the device connection rate
01:51:41 # limitter will be disabled. If it is set to any value, then only those many
01:51:41 # number of datapath nodes are allowed to connect to the controller in a minute
01:51:41 #
01:51:41 # device-connection-rate-limit-per-min=0
01:51:41
01:51:41 #
01:51:41 # Device connection hold time is the least time delay in seconds a device has
01:51:41 # to maintain between its consecutive connection attempts. If time delay between
01:51:41 # the previous connection and the current connection is within device connection
01:51:41 # hold time, the device will not be allowed to connect to the controller.
01:51:41 # Default value of the device connection hold time is 0 second
01:51:41 #
01:51:41 # device-connection-hold-time-in-seconds=0
01:51:41
01:51:41 #
01:51:41 # Delay (in milliseconds) before device is removed from the operational data
01:51:41 # store in the event of device disconnection from the controller.
01:51:41 #
01:51:41 # device-datastore-removal-delay=500
01:51:41
01:51:41 #############################################################################
01:51:41 # #
01:51:41 # Forwarding Rule Manager Application Configuration #
01:51:41 # #
01:51:41 #############################################################################
01:51:41
01:51:41 #
01:51:41 # Disable the default switch reconciliation mechanism
01:51:41 #
01:51:41 # disable-reconciliation=false
01:51:41
01:51:41 #
01:51:41 # Enable stale marking for switch reconciliation. Once user enable this feature
01:51:41 # forwarding rule manager will keep track of any change to the config data store
01:51:41 # while the switch is disconnected from controller. Once switch reconnect to the
01:51:41 # controller it will apply those changes to the switch and do the reconciliation
01:51:41 # of other configuration as well.
01:51:41 # NOTE: This option will be effective only if disable-reconciliation=false.
01:51:41 #
01:51:41 # stale-marking-enabled=false
01:51:41
01:51:41 #
01:51:41 # Number of time forwarding rules manager should retry to reconcile any specific
01:51:41 # configuration.
01:51:41 #
01:51:41 # reconciliation-retry-count=5
01:51:41
01:51:41 #
01:51:41 # Bundle reconciliation can be enabled by making this flag to true.
01:51:41 # By default bundle reconciliation is disabled and reconciliation happens
01:51:41 # via normal flow/group mods.
01:51:41 # NOTE: This option will be effective with disable-reconciliation=false.
01:51:41 #
01:51:41 # bundle-based-reconciliation-enabled=false
01:51:41
01:51:41 #############################################################################
01:51:41 # #
01:51:41 # Topology Lldp Discovery Configuration #
01:51:41 # #
01:51:41 #############################################################################
01:51:41
01:51:41 # Periodic interval for sending LLDP packet for link discovery
01:51:41 # topology-lldp-interval=5000
01:51:41
01:51:41 # Timeout duration for LLDP response message
01:51:41 # topology-lldp-expiration-interval=60000
01:51:41 Finished running config plans
01:51:41 Starting member-1 with IP address 10.30.171.114
01:51:41 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:42 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:42 Redirecting karaf console output to karaf_console.log
01:51:42 Starting controller...
01:51:42 start: Redirecting Karaf output to /tmp/karaf-0.22.3-SNAPSHOT/data/log/karaf_console.log
01:51:42 Execute the post startup script on controller 10.30.171.114
01:51:42 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:42 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:51:43 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:51:48 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:51:53 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:51:58 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:03 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:08 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:13 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:18 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:23 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:28 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:33 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:38 /tmp/post-startup-script.sh: line 4: netstat: command not found
01:52:43 Waiting up to 3 minutes for controller to come up, checking every 5 seconds...
01:52:48 2026-05-07T01:51:59,385 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 201 - org.opendaylight.infrautils.ready-api - 7.1.12 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.]
01:52:48 Controller is UP
01:52:48 2026-05-07T01:51:59,385 | INFO | SystemReadyService-0 | SimpleSystemReadyMonitor | 201 - org.opendaylight.infrautils.ready-api - 7.1.12 | System ready; AKA: Aye captain, all warp coils are now operating at peak efficiency! [M.]
01:52:48 Listing all open ports on controller system...
01:52:48 /tmp/post-startup-script.sh: line 51: netstat: command not found
01:52:48 looking for "BindException: Address already in use" in log file
01:52:48 looking for "server is unhealthy" in log file
01:52:48 Let's take the karaf thread dump
01:52:48 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:52:48 karaf main: org.apache.karaf.main.Main, pid:2193
01:52:48 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:52:49 Generating mininet variables...
01:52:49 Locating test plan to use...
01:52:49 Changing the testplan path...
01:52:49 # Place the suites in run order:
01:52:49 /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/suites/openflowplugin/Maximum_Switches/010__finding_max_switches.robot
01:52:49 Starting Robot test suites /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/test/csit/suites/openflowplugin/Maximum_Switches/010__finding_max_switches.robot ...
01:52:50 ==============================================================================
01:52:50 openflowplugin-scale-switch.txt :: Test suite for finding out max number of...
01:52:50 ==============================================================================
01:52:51 Find Max Switches :: Find max number of switches starting from 100...
01:52:51
01:52:51 Starting mininet linear 100 switches
01:52:59 Verify controller is OK
01:53:00 :1: SyntaxWarning: "is not" with a literal. Did you mean "!="?
01:53:00 :1: SyntaxWarning: "is not" with a literal. Did you mean "!="?
01:53:01 :1: SyntaxWarning: "is not" with a literal. Did you mean "!="?
01:53:01 Checking 100 switches
01:53:07 Add table miss flows
01:53:11 Checking Table Miss Flows
01:53:15 Checking Linear Topology
01:53:18 Topology Discovery Time = 18.748 seconds
01:53:18 Adding 10000 flows
01:54:13 Checking 10000 flows in Mininet
01:54:16 Checking 10000 flows in Operational DS
01:54:25 Sleep for 0 seconds
01:54:25 Deleting 10000 flows
01:55:06 Checking no flows in Mininet
01:55:10 Checking no flows in Operational DS
01:55:14 Stopping Mininet
01:55:22 Checking No Switches
01:55:52
01:55:52
01:55:52 Execution stopped because: Fail checking no switch
01:55:52 Max Switches: 0
01:55:52 | PASS |
01:55:52 ------------------------------------------------------------------------------
01:55:54 openflowplugin-scale-switch.txt :: Test suite for finding out max ... | PASS |
01:55:54 1 test, 1 passed, 0 failed
01:55:54 ==============================================================================
01:55:54 Output: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/output.xml
01:55:55 Log: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/log.html
01:55:55 Report: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/report.html
01:55:55 Examining the files in data/log and checking filesize
01:55:56 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:55:56 total 396
01:55:56 drwxrwxr-x 2 jenkins jenkins 4096 May 7 01:51 .
01:55:56 -rw-rw-r-- 1 jenkins jenkins 1720 May 7 01:51 karaf_console.log
01:55:56 drwxrwxr-x 9 jenkins jenkins 4096 May 7 01:51 ..
01:55:56 -rw-rw-r-- 1 jenkins jenkins 391700 May 7 01:53 karaf.log
01:55:56 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:55:56 384K /tmp/karaf-0.22.3-SNAPSHOT/data/log/karaf.log
01:55:56 4.0K /tmp/karaf-0.22.3-SNAPSHOT/data/log/karaf_console.log
01:55:56 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:55:57 ls: cannot access '/tmp/karaf-0.22.3-SNAPSHOT/*.hprof': No such file or directory
01:55:57 Let's take the karaf thread dump again...
01:55:57 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:55:57 karaf main: org.apache.karaf.main.Main, pid:2193
01:55:57 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:55:58 Killing ODL
01:55:58 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:03 Compressing karaf.log 1
01:56:03 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:03 Fetching compressed karaf.log 1
01:56:03 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:04 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:04 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:04 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:05 Fetch GC logs
01:56:05 Warning: Permanently added '10.30.171.114' (ED25519) to the list of known hosts.
01:56:05 scp: /tmp/karaf-0.22.3-SNAPSHOT/data/log/*.log: No such file or directory
01:56:05 Examine copied files
01:56:05 total 15444
01:56:05 drwxrwxr-x 2 jenkins jenkins 4096 May 7 01:56 gclogs-1
01:56:05 -rw-rw-r-- 1 jenkins jenkins 1720 May 7 01:56 odl1_karaf_console.log
01:56:05 -rw-rw-r-- 1 jenkins jenkins 30036 May 7 01:56 odl1_karaf.log.gz
01:56:05 -rw-rw-r-- 1 jenkins jenkins 190342 May 7 01:55 karaf_1_2193_threads_after.log
01:56:05 -rw-rw-r-- 1 jenkins jenkins 13852 May 7 01:55 ps_after.log
01:56:05 -rw-rw-r-- 1 jenkins jenkins 244321 May 7 01:55 report.html
01:56:05 -rw-rw-r-- 1 jenkins jenkins 1314811 May 7 01:55 log.html
01:56:05 -rw-rw-r-- 1 jenkins jenkins 13802914 May 7 01:55 output.xml
01:56:05 -rw-rw-r-- 1 jenkins jenkins 15 May 7 01:55 switches.csv
01:56:05 -rw-rw-r-- 1 jenkins jenkins 16 May 7 01:55 time.csv
01:56:05 -rw-rw-r-- 1 jenkins jenkins 180 May 7 01:52 testplan.txt
01:56:05 -rw-rw-r-- 1 jenkins jenkins 111516 May 7 01:52 karaf_1_2193_threads_before.log
01:56:05 -rw-rw-r-- 1 jenkins jenkins 14266 May 7 01:52 ps_before.log
01:56:05 -rw-rw-r-- 1 jenkins jenkins 254 May 7 01:51 configplan.txt
01:56:05 -rw-rw-r-- 1 jenkins jenkins 3222 May 7 01:51 post-startup-script.sh
01:56:05 -rw-rw-r-- 1 jenkins jenkins 252 May 7 01:51 startup-script.sh
01:56:05 -rw-rw-r-- 1 jenkins jenkins 3420 May 7 01:51 configuration-script.sh
01:56:05 -rw-rw-r-- 1 jenkins jenkins 337 May 7 01:51 detect_variables.env
01:56:05 -rw-rw-r-- 1 jenkins jenkins 2619 May 7 01:51 pom.xml
01:56:05 -rw-rw-r-- 1 jenkins jenkins 92 May 7 01:51 set_variables.env
01:56:05 -rw-rw-r-- 1 jenkins jenkins 299 May 7 01:51 slave_addresses.txt
01:56:05 -rw-rw-r-- 1 jenkins jenkins 570 May 7 01:50 requirements.txt
01:56:05 -rw-rw-r-- 1 jenkins jenkins 26 May 7 01:50 env.properties
01:56:05 -rw-rw-r-- 1 jenkins jenkins 1410 May 7 01:50 maven-metadata.xml
01:56:05 -rw-rw-r-- 1 jenkins jenkins 334 May 7 01:49 stack-parameters.yaml
01:56:05 drwxrwxr-x 7 jenkins jenkins 4096 May 7 01:48 test
01:56:05 drwxrwxr-x 2 jenkins jenkins 4096 May 7 01:48 test@tmp
01:56:05 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins7140563907619855874.sh
01:56:05 Karaf Deployments, Tests must have already run
01:56:05 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/sh /tmp/jenkins13894408456516323896.sh
01:56:05 Cleaning up Robot installation...
01:56:05 $ ssh-agent -k
01:56:05 unset SSH_AUTH_SOCK;
01:56:05 unset SSH_AGENT_PID;
01:56:05 echo Agent pid 3150 killed;
01:56:05 [ssh-agent] Stopped.
01:56:05 Recording plot data
01:56:06 Robot results publisher started...
01:56:06 INFO: Checking test criticality is deprecated and will be dropped in a future release!
01:56:06 -Parsing output xml:
01:56:06 Done!
01:56:06 -Copying log files to build dir:
01:56:07 Done!
01:56:07 -Assigning results to build:
01:56:07 Done!
01:56:07 -Checking thresholds:
01:56:07 Done!
01:56:07 Done publishing Robot results.
01:56:07 [PostBuildScript] - [INFO] Executing post build scripts.
01:56:07 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins4940286449123753841.sh
01:56:07 Archiving csit artifacts
01:56:07 mv: cannot stat '*_1.png': No such file or directory
01:56:07 mv: cannot stat '/tmp/odl1_*': No such file or directory
01:56:07 % Total % Received % Xferd Average Speed Time Time Time Current
01:56:07 Dload Upload Total Spent Left Speed
01:56:07
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
100 1223k 0 1223k 0 0 1989k 0 --:--:-- --:--:-- --:--:-- 1989k
01:56:07 Archive: robot-plugin.zip
01:56:07 inflating: ./archives/robot-plugin/log.html
01:56:07 inflating: ./archives/robot-plugin/output.xml
01:56:07 inflating: ./archives/robot-plugin/report.html
01:56:07 mv: cannot stat '*.log.gz': No such file or directory
01:56:07 mv: cannot stat '*.png': No such file or directory
01:56:07 [PostBuildScript] - [INFO] Executing post build scripts.
01:56:07 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins5714902239616628975.sh
01:56:07 [PostBuildScript] - [INFO] Executing post build scripts.
01:56:07 [EnvInject] - Injecting environment variables from a build step.
01:56:07 [EnvInject] - Injecting as environment variables the properties content
01:56:07 OS_CLOUD=vex
01:56:07 OS_STACK_NAME=releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:56:07
01:56:07 [EnvInject] - Variables injected successfully.
01:56:07 provisioning config files...
01:56:08 copy managed file [clouds-yaml] to file:/home/jenkins/.config/openstack/clouds.yaml
01:56:08 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins17999404319396682360.sh
01:56:08 ---> openstack-stack-delete.sh
01:56:08 Setup pyenv:
01:56:08 system
01:56:08 3.8.20
01:56:08 3.9.20
01:56:08 3.10.15
01:56:08 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:56:08 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:56:08 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:56:08 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:56:10 lf-activate-venv(): INFO: Base packages installed successfully
01:56:10 lf-activate-venv(): INFO: Installing additional packages: lftools[openstack] kubernetes python-heatclient python-openstackclient urllib3~=1.26.15
01:56:24 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:56:24 INFO: Stack cost retrieval disabled, setting cost to 0
01:56:37 INFO: Deleting stack releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:56:37 Successfully deleted stack releng-openflowplugin-csit-1node-scale-switch-only-titanium-712
01:56:37 [PostBuildScript] - [INFO] Executing post build scripts.
01:56:37 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins15602705113973477677.sh
01:56:37 ---> sysstat.sh
01:56:37 /tmp/jenkins15602705113973477677.sh: line 19: facter: command not found
01:56:37 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins13472853319260708772.sh
01:56:37 ---> package-listing.sh
01:56:37 ++ tr '[:upper:]' '[:lower:]'
01:56:37 ++ facter osfamily
01:56:37 /tmp/jenkins13472853319260708772.sh: line 19: facter: command not found
01:56:37 + OS_FAMILY=
01:56:37 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins6300628774369421837.sh
01:56:37 ---> capture-instance-metadata.sh
01:56:37 Setup pyenv:
01:56:37 system
01:56:37 3.8.20
01:56:37 3.9.20
01:56:37 3.10.15
01:56:37 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:56:37 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:56:37 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:56:37 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:56:39 lf-activate-venv(): INFO: Base packages installed successfully
01:56:39 lf-activate-venv(): INFO: Installing additional packages: lftools
01:56:51 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:56:51 INFO: Running in OpenStack, capturing instance metadata
01:56:51 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins14188648084019116329.sh
01:56:51 provisioning config files...
01:56:51 Could not find credentials [logs] for openflowplugin-csit-1node-scale-switch-only-titanium #712
01:56:51 copy managed file [jenkins-log-archives-settings] to file:/w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium@tmp/config13306858673696178188tmp
01:56:51 Regular expression run condition: Expression=[^.*logs-s3.*], Label=[odl-logs-s3-cloudfront-index]
01:56:51 Run condition [Regular expression match] enabling perform for step [Provide Configuration files]
01:56:51 provisioning config files...
01:56:52 copy managed file [jenkins-s3-log-ship] to file:/home/jenkins/.aws/credentials
01:56:52 [EnvInject] - Injecting environment variables from a build step.
01:56:52 [EnvInject] - Injecting as environment variables the properties content
01:56:52 SERVER_ID=logs
01:56:52
01:56:52 [EnvInject] - Variables injected successfully.
01:56:52 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins12306113392544833212.sh
01:56:52 ---> create-netrc.sh
01:56:52 WARN: Log server credential not found.
01:56:52 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins645180071956356565.sh
01:56:52 ---> python-tools-install.sh
01:56:52 Setup pyenv:
01:56:52 system
01:56:52 3.8.20
01:56:52 3.9.20
01:56:52 3.10.15
01:56:52 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:56:52 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:56:52 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:56:52 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:56:54 lf-activate-venv(): INFO: Base packages installed successfully
01:56:54 lf-activate-venv(): INFO: Installing additional packages: lftools
01:57:03 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:57:03 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/sh /tmp/jenkins7001911416221061069.sh
01:57:03 ---> uv-install.sh
01:57:03 uv 0.11.11 is already installed
01:57:03 uvx 0.11.11 (x86_64-unknown-linux-gnu)
01:57:03 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins5510355753050711518.sh
01:57:03 ---> sudo-logs.sh
01:57:03 Archiving 'sudo' log..
01:57:03 /tmp/jenkins5510355753050711518.sh: line 41: facter: command not found
01:57:03 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash /tmp/jenkins14255356482978957820.sh
01:57:03 ---> job-cost.sh
01:57:03 INFO: Activating Python virtual environment...
01:57:03 Setup pyenv:
01:57:03 system
01:57:03 3.8.20
01:57:03 3.9.20
01:57:03 3.10.15
01:57:03 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:57:03 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:57:03 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:57:03 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:57:05 lf-activate-venv(): INFO: Base packages installed successfully
01:57:05 lf-activate-venv(): INFO: Installing additional packages: zipp==1.1.0 python-openstackclient urllib3~=1.26.15
01:57:11 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:57:11 DEBUG: Contents of stack-cost file:
01:57:11 total: 0
01:57:11 INFO: Retrieving Stack Cost...
01:57:11 INFO: Stack cost: 0
01:57:11 INFO: Instance uptime: 565s
01:57:11 INFO: Fetching instance metadata (attempt 1 of 3)...
01:57:11 DEBUG: URL: http://169.254.169.254/latest/meta-data/instance-type
01:57:12 INFO: Successfully fetched instance metadata
01:57:12 INFO: Instance type: v3-standard-2
01:57:12 INFO: Retrieving pricing info for: v3-standard-2
01:57:12 INFO: Fetching Vexxhost pricing API (attempt 1 of 3)...
01:57:12 DEBUG: URL: https://pricing.vexxhost.net/v1/pricing/v3-standard-2/cost?seconds=565
01:57:12 INFO: Successfully fetched Vexxhost pricing API
01:57:12 INFO: Retrieved cost: 0.06
01:57:12 INFO: Retrieved resource: v3-standard-2
01:57:12 INFO: Creating archive directory: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/archives/cost
01:57:12 INFO: Archiving costs to: /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/archives/cost.csv
01:57:12 INFO: Successfully archived job cost data
01:57:12 DEBUG: Cost data: openflowplugin-csit-1node-scale-switch-only-titanium,712,2026-05-07 01:57:12,v3-standard-2,565,0.06,0.00,SUCCESS
01:57:12 [openflowplugin-csit-1node-scale-switch-only-titanium] $ /bin/bash -l /tmp/jenkins14726999000107596976.sh
01:57:12 ---> logs-deploy.sh
01:57:12 Setup pyenv:
01:57:12 system
01:57:12 3.8.20
01:57:12 3.9.20
01:57:12 3.10.15
01:57:12 * 3.11.10 (set by /w/workspace/openflowplugin-csit-1node-scale-switch-only-titanium/.python-version)
01:57:12 lf-activate-venv(): INFO: Reuse venv:/tmp/venv-wCb3 from file:/tmp/.os_lf_venv
01:57:12 lf-activate-venv(): INFO: Installing base packages (pip, setuptools, virtualenv)
01:57:12 lf-activate-venv(): INFO: Attempting to install with network-safe options...
01:57:14 lf-activate-venv(): INFO: Base packages installed successfully
01:57:14 lf-activate-venv(): INFO: Installing additional packages: lftools urllib3~=1.26.15
01:57:24 lf-activate-venv(): INFO: Adding /tmp/venv-wCb3/bin to PATH
01:57:24 WARNING: Nexus logging server not set
01:57:24 INFO: S3 path logs/releng/vex-yul-odl-jenkins-1/openflowplugin-csit-1node-scale-switch-only-titanium/712/
01:57:24 INFO: archiving logs to S3
01:57:25 ---> uname -a:
01:57:25 Linux prd-ubuntu2404-robot-2c-8g-11583 6.8.0-90-generic #91-Ubuntu SMP PREEMPT_DYNAMIC Tue Nov 18 14:14:30 UTC 2025 x86_64 x86_64 x86_64 GNU/Linux
01:57:25
01:57:25
01:57:25 ---> lscpu:
01:57:25 Architecture: x86_64
01:57:25 CPU op-mode(s): 32-bit, 64-bit
01:57:25 Address sizes: 40 bits physical, 48 bits virtual
01:57:25 Byte Order: Little Endian
01:57:25 CPU(s): 2
01:57:25 On-line CPU(s) list: 0,1
01:57:25 Vendor ID: AuthenticAMD
01:57:25 Model name: AMD EPYC-Rome Processor
01:57:25 CPU family: 23
01:57:25 Model: 49
01:57:25 Thread(s) per core: 1
01:57:25 Core(s) per socket: 1
01:57:25 Socket(s): 2
01:57:25 Stepping: 0
01:57:25 BogoMIPS: 5600.00
01:57:25 Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm rep_good nopl cpuid extd_apicid tsc_known_freq pni pclmulqdq ssse3 fma cx16 sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm cmp_legacy svm cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw topoext perfctr_core ssbd ibrs ibpb stibp vmmcall fsgsbase tsc_adjust bmi1 avx2 smep bmi2 rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 clzero xsaveerptr wbnoinvd arat npt nrip_save umip rdpid arch_capabilities
01:57:25 Virtualization: AMD-V
01:57:25 Hypervisor vendor: KVM
01:57:25 Virtualization type: full
01:57:25 L1d cache: 64 KiB (2 instances)
01:57:25 L1i cache: 64 KiB (2 instances)
01:57:25 L2 cache: 1 MiB (2 instances)
01:57:25 L3 cache: 32 MiB (2 instances)
01:57:25 NUMA node(s): 1
01:57:25 NUMA node0 CPU(s): 0,1
01:57:25 Vulnerability Gather data sampling: Not affected
01:57:25 Vulnerability Itlb multihit: Not affected
01:57:25 Vulnerability L1tf: Not affected
01:57:25 Vulnerability Mds: Not affected
01:57:25 Vulnerability Meltdown: Not affected
01:57:25 Vulnerability Mmio stale data: Not affected
01:57:25 Vulnerability Reg file data sampling: Not affected
01:57:25 Vulnerability Retbleed: Mitigation; untrained return thunk; SMT disabled
01:57:25 Vulnerability Spec rstack overflow: Vulnerable: Safe RET, no microcode
01:57:25 Vulnerability Spec store bypass: Mitigation; Speculative Store Bypass disabled via prctl
01:57:25 Vulnerability Spectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitization
01:57:25 Vulnerability Spectre v2: Mitigation; Retpolines; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Not affected
01:57:25 Vulnerability Srbds: Not affected
01:57:25 Vulnerability Tsx async abort: Not affected
01:57:25 Vulnerability Vmscape: Not affected
01:57:25
01:57:25
01:57:25 ---> nproc:
01:57:25 2
01:57:25
01:57:25
01:57:25 ---> df -h:
01:57:25 Filesystem Size Used Avail Use% Mounted on
01:57:25 tmpfs 795M 1.1M 794M 1% /run
01:57:25 /dev/vda1 38G 7.9G 30G 21% /
01:57:25 tmpfs 3.9G 0 3.9G 0% /dev/shm
01:57:25 tmpfs 5.0M 0 5.0M 0% /run/lock
01:57:25 /dev/vda16 881M 117M 703M 15% /boot
01:57:25 /dev/vda15 105M 6.2M 99M 6% /boot/efi
01:57:25 tmpfs 795M 16K 795M 1% /run/user/1001
01:57:25
01:57:25
01:57:25 ---> free -m:
01:57:25 total used free shared buff/cache available
01:57:25 Mem: 7941 769 5280 4 2180 7172
01:57:25 Swap: 1023 0 1023
01:57:25
01:57:25
01:57:25 ---> ip addr:
01:57:25 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
01:57:25 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
01:57:25 inet 127.0.0.1/8 scope host lo
01:57:25 valid_lft forever preferred_lft forever
01:57:25 inet6 ::1/128 scope host noprefixroute
01:57:25 valid_lft forever preferred_lft forever
01:57:25 2: ens3: mtu 1458 qdisc mq state UP group default qlen 1000
01:57:25 link/ether fa:16:3e:a7:f4:ac brd ff:ff:ff:ff:ff:ff
01:57:25 altname enp0s3
01:57:25 inet 10.30.170.109/23 metric 100 brd 10.30.171.255 scope global dynamic ens3
01:57:25 valid_lft 85831sec preferred_lft 85831sec
01:57:25 inet6 fe80::f816:3eff:fea7:f4ac/64 scope link
01:57:25 valid_lft forever preferred_lft forever
01:57:25
01:57:25
01:57:25 ---> sar -b -r -n DEV:
01:57:25 Linux 6.8.0-90-generic (prd-ubuntu2404-robot-2c-8g-11583) 05/07/26 _x86_64_ (2 CPU)
01:57:25
01:57:25 01:48:00 LINUX RESTART (2 CPU)
01:57:25
01:57:25
01:57:25 ---> sar -P ALL:
01:57:25 Linux 6.8.0-90-generic (prd-ubuntu2404-robot-2c-8g-11583) 05/07/26 _x86_64_ (2 CPU)
01:57:25
01:57:25 01:48:00 LINUX RESTART (2 CPU)
01:57:25
01:57:25
01:57:25