2015-09-26 11:54:49 -07:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2015-10-17 03:31:51 -07:00
|
|
|
set -euf -o pipefail
|
2015-09-26 11:54:49 -07:00
|
|
|
|
2016-01-14 01:51:11 -08:00
|
|
|
collectors=$(cat << COLLECTORS
|
2017-02-07 07:11:22 -08:00
|
|
|
buddyinfo
|
2016-01-14 01:51:11 -08:00
|
|
|
conntrack
|
|
|
|
diskstats
|
2016-12-05 02:37:35 -08:00
|
|
|
drbd
|
2017-01-08 03:58:04 -08:00
|
|
|
edac
|
2016-01-14 01:51:11 -08:00
|
|
|
entropy
|
|
|
|
filefd
|
2016-10-06 08:33:24 -07:00
|
|
|
hwmon
|
2017-02-07 08:46:51 -08:00
|
|
|
infiniband
|
2015-11-11 05:02:41 -08:00
|
|
|
ksmd
|
2016-01-14 01:51:11 -08:00
|
|
|
loadavg
|
|
|
|
mdadm
|
|
|
|
meminfo
|
2015-11-13 01:23:21 -08:00
|
|
|
meminfo_numa
|
2016-12-12 13:46:45 -08:00
|
|
|
mountstats
|
2016-01-14 01:51:11 -08:00
|
|
|
netdev
|
|
|
|
netstat
|
2016-11-29 05:32:52 -08:00
|
|
|
nfs
|
2016-01-14 01:51:11 -08:00
|
|
|
sockstat
|
|
|
|
stat
|
|
|
|
textfile
|
|
|
|
bonding
|
|
|
|
megacli
|
2017-01-09 11:37:59 -08:00
|
|
|
wifi
|
2017-01-08 08:17:06 -08:00
|
|
|
zfs
|
2016-01-14 01:51:11 -08:00
|
|
|
COLLECTORS
|
|
|
|
)
|
2015-09-26 11:54:49 -07:00
|
|
|
cd "$(dirname $0)"
|
|
|
|
|
|
|
|
port="$((10000 + (RANDOM % 10000)))"
|
|
|
|
tmpdir=$(mktemp -d /tmp/node_exporter_e2e_test.XXXXXX)
|
|
|
|
|
2017-03-16 10:21:00 -07:00
|
|
|
skip_re="^(go_|node_exporter_build_info|node_scrape_collector_duration_seconds|process_|node_textfile_mtime)"
|
2015-09-26 11:54:49 -07:00
|
|
|
|
|
|
|
keep=0; update=0; verbose=0
|
|
|
|
while getopts 'hkuv' opt
|
|
|
|
do
|
|
|
|
case "$opt" in
|
|
|
|
k)
|
|
|
|
keep=1
|
|
|
|
;;
|
|
|
|
u)
|
|
|
|
update=1
|
|
|
|
;;
|
|
|
|
v)
|
|
|
|
verbose=1
|
|
|
|
set -x
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "Usage: $0 [-k] [-u] [-v]"
|
|
|
|
echo " -k: keep temporary files and leave node_exporter running"
|
|
|
|
echo " -u: update fixture"
|
|
|
|
echo " -v: verbose output"
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2015-10-16 12:39:12 -07:00
|
|
|
if [ ! -x ./node_exporter ]
|
|
|
|
then
|
|
|
|
echo './node_exporter not found. Consider running `go build` first.' >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
2015-09-26 11:54:49 -07:00
|
|
|
|
|
|
|
./node_exporter \
|
|
|
|
-collector.procfs="collector/fixtures/proc" \
|
|
|
|
-collector.sysfs="collector/fixtures/sys" \
|
2016-01-14 01:51:11 -08:00
|
|
|
-collectors.enabled="$(echo ${collectors} | tr ' ' ',')" \
|
2015-09-26 11:54:49 -07:00
|
|
|
-collector.textfile.directory="collector/fixtures/textfile/two_metric_files/" \
|
|
|
|
-collector.megacli.command="collector/fixtures/megacli" \
|
2017-01-09 11:37:59 -08:00
|
|
|
-collector.wifi="collector/fixtures/wifi" \
|
2015-09-26 11:54:49 -07:00
|
|
|
-web.listen-address "127.0.0.1:${port}" \
|
|
|
|
-log.level="debug" > "${tmpdir}/node_exporter.log" 2>&1 &
|
|
|
|
|
|
|
|
echo $! > "${tmpdir}/node_exporter.pid"
|
|
|
|
|
|
|
|
finish() {
|
2016-12-21 02:51:53 -08:00
|
|
|
if [ $? -ne 0 -o ${verbose} -ne 0 ]
|
2015-09-26 11:54:49 -07:00
|
|
|
then
|
2016-12-21 02:51:53 -08:00
|
|
|
cat << EOF >&2
|
|
|
|
LOG =====================
|
|
|
|
$(cat "${tmpdir}/node_exporter.log")
|
|
|
|
=========================
|
|
|
|
EOF
|
2015-09-26 11:54:49 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ${update} -ne 0 ]
|
|
|
|
then
|
|
|
|
cp "${tmpdir}/e2e-output.txt" "collector/fixtures/e2e-output.txt"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ${keep} -eq 0 ]
|
|
|
|
then
|
|
|
|
kill -9 "$(cat ${tmpdir}/node_exporter.pid)"
|
|
|
|
# This silences the "Killed" message
|
2015-10-16 12:39:12 -07:00
|
|
|
set +e
|
2015-09-26 11:54:49 -07:00
|
|
|
wait "$(cat ${tmpdir}/node_exporter.pid)" > /dev/null 2>&1
|
|
|
|
rm -rf "${tmpdir}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
trap finish EXIT
|
|
|
|
|
|
|
|
get() {
|
2016-12-21 10:00:38 -08:00
|
|
|
if command -v curl > /dev/null 2>&1
|
2015-09-26 11:54:49 -07:00
|
|
|
then
|
|
|
|
curl -s -f "$@"
|
2016-12-21 10:00:38 -08:00
|
|
|
elif command -v wget > /dev/null 2>&1
|
2015-09-26 11:54:49 -07:00
|
|
|
then
|
|
|
|
wget -O - "$@"
|
|
|
|
else
|
|
|
|
echo "Neither curl nor wget found"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
|
2017-01-06 03:36:26 -08:00
|
|
|
get "127.0.0.1:${port}/metrics" | grep -E -v "${skip_re}" > "${tmpdir}/e2e-output.txt"
|
2015-09-26 11:54:49 -07:00
|
|
|
|
|
|
|
diff -u \
|
2017-01-06 03:36:26 -08:00
|
|
|
"collector/fixtures/e2e-output.txt" \
|
|
|
|
"${tmpdir}/e2e-output.txt"
|