blob: 346b5ef66fa01e0313c35f7abc12ead7e48512c2 [file] [log] [blame]
#!/usr/bin/env groovy
// -----------------------------------------------------------------------
// Copyright 2021-2024 Open Networking Foundation (ONF) and the ONF Contributors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// -----------------------------------------------------------------------
def call(Map config) {
String iam = 'vars/setOnosLogLevels.groovy'
println("** ${iam}: ENTER")
def defaultConfig = [
onosNamespace: "infra",
apps: ['org.opencord.dhcpl2relay', 'org.opencord.olt', 'org.opencord.aaa'],
logLevel: "DEBUG",
]
if (!config) {
config = [:]
}
def cfg = defaultConfig + config
def onosInstances = sh (
script: "kubectl get pods -n ${cfg.onosNamespace} -l app=onos-classic --no-headers | awk '{print \$1}'",
returnStdout: true
).trim()
for(int i = 0;i<onosInstances.split( '\n' ).size();i++) {
def instance = onosInstances.split('\n')[i]
println "Setting log levels on ${instance}"
sh """
_TAG="onos-pf" bash -c "while true; do kubectl port-forward -n ${cfg.onosNamespace} ${instance} 8101; done"&
ps aux | grep port-forward
"""
for (int j = 0; j < cfg.apps.size(); j++) {
def app = cfg.apps[j]
sh """
sshpass -p karaf ssh -q -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -p 8101 karaf@localhost log:set ${cfg.logLevel} ${app} || true
"""
}
sh """
ps e -ww -A | grep _TAG="onos-pf" | grep -v grep | awk '{print \$1}' | xargs --no-run-if-empty kill -9
ps aux | grep port-forward
"""
}
println("** ${iam}: LEAVE")
}
// [EOF]