#!/bin/sh
# PCP QA Test No. 1707
# Exercise the bpftrace PMDA - custom output blocks
#

seq=`basename $0`
echo "QA output created by $seq"

. ./common.bpftrace

_pmdabpftrace_check

status=1       # failure is the default!
$sudo rm -rf $tmp.* $seq.full

_prepare_pmda bpftrace
trap "_pmdabpftrace_cleanup; exit \$status" 0 1 2 3 15
_stop_auto_restart pmcd


# real QA test starts here
cat <<EOF | _pmdabpftrace_install
# Installed by PCP QA test $seq on `date`
[authentication]
enabled = false
EOF

echo "=== start bpftrace script ==="
pmstore bpftrace.control.register "// name: testscript
// custom-output-block
tracepoint:raw_syscalls:sys_enter { @ = count(); @scalar = 2; }
interval:s:1 { print(@scalar); }"

echo "=== check metadata metrics ==="
_pmdabpftrace_wait_for_value bpftrace.scripts.testscript.data.scalar
pminfo -dfmtT bpftrace.scripts.testscript.data.scalar

echo "=== we disabled default output block, therefore we should get output only for @scalar ==="
pminfo -dfmtT bpftrace.scripts.testscript.data.root


_pmdabpftrace_remove
status=0
exit
