blob: e5cd13bca5f906041af5fd47d9dd2021ccc2625a [file] [log] [blame]
stevenvanrossem2fdfbf42016-05-13 15:08:47 +02001#!/bin/bash
stevenvanrossema01329c2016-05-17 10:06:30 +02002# test if a vnf can be deployed and monitored
stevenvanrossem2fdfbf42016-05-13 15:08:47 +02003
stevenvanrossema01329c2016-05-17 10:06:30 +02004#start test emulator topology
stevenvanrossem02aa1962016-05-17 15:45:43 +02005#python src/emuvim/examples/monitoring_demo_topology.py &
stevenvanrossema01329c2016-05-17 10:06:30 +02006
7# start a vnf
stevenvanrossem73efd192016-06-29 01:44:07 +02008son-emu-cli compute start -d datacenter1 -n vnf1 --net '(id=input,ip=10.0.10.3/24),(id=output,ip=10.0.10.4/24)'
stevenvanrossem48db0512016-05-18 15:43:24 +02009
10sleep 1
11
stevenvanrossema01329c2016-05-17 10:06:30 +020012# monitor a metric
13son-emu-cli monitor setup_metric -vnf vnf1:output --metric tx_packets
14
stevenvanrossem73efd192016-06-29 01:44:07 +020015# allow some time to gather metrics
16sleep 20
stevenvanrossema01329c2016-05-17 10:06:30 +020017
stevenvanrossem000237b2016-06-28 13:15:28 +020018# check if metric is monitored as expected (exported by son-emu, has vnf name as metric id)
stevenvanrossem73efd192016-06-29 01:44:07 +020019tx_rate=$(son-emu-cli monitor-zapi prometheus -d datacenter1 -vnf vnf1 -q 'rate(sonemu_tx_count_packets{vnf_name="vnf1"}[10s])')
stevenvanrossem000237b2016-06-28 13:15:28 +020020
stevenvanrossem73efd192016-06-29 01:44:07 +020021sleep 1
stevenvanrossem000237b2016-06-28 13:15:28 +020022
23# test if prometheus query worked
24echo $tx_rate
25
26regex='\[[0-9.]*, .*\]'
27
28if [[ $tx_rate =~ $regex ]] ; then
29 echo " tx_rate monitor test OK"
30else
31 echo "tx_rate monitor test not OK"
32 exit 1
33fi
34
35
36# check if cpu load can be monitored (exported by cAdvisor, needs uuid)
stevenvanrossem73efd192016-06-29 01:44:07 +020037cpu_load=$(son-emu-cli monitor-zapi prometheus -d datacenter1 -vnf vnf1 -q 'sum(rate(container_cpu_usage_seconds_total{id="/docker/<uuid>"}[10s]))')
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020038
stevenvanrossem48db0512016-05-18 15:43:24 +020039sleep 1
40
stevenvanrossema01329c2016-05-17 10:06:30 +020041
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020042# test if prometheus query worked
stevenvanrossem75009bd2016-05-18 10:59:48 +020043echo $cpu_load
stevenvanrossem1a6843a2016-05-19 12:19:36 +020044
45regex='\[[0-9.]*, .*\]'
46
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020047if [[ $cpu_load =~ $regex ]] ; then
stevenvanrossema01329c2016-05-17 10:06:30 +020048 echo " cpu monitor test OK"
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020049else
stevenvanrossema01329c2016-05-17 10:06:30 +020050 echo "cpu monitor test not OK"
stevenvanrossem2fdfbf42016-05-13 15:08:47 +020051 exit 1
52fi
stevenvanrossem1a6843a2016-05-19 12:19:36 +020053
stevenvanrossem000237b2016-06-28 13:15:28 +020054exit 0
55
stevenvanrossem1a6843a2016-05-19 12:19:36 +020056