mirror of
https://github.com/tstack/lnav
synced 2024-11-15 18:13:10 +00:00
554918b96c
Fixes #1078
520 lines
14 KiB
Bash
520 lines
14 KiB
Bash
#! /bin/bash
|
|
|
|
export YES_COLOR=1
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view help" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test env TZ=UTC ${lnav_test} -n \
|
|
-c ":goto 2011-11-03 00:19:39" \
|
|
-c ";SELECT log_top_line()" \
|
|
${test_dir}/logfile_bro_http.log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 1" \
|
|
-c ":mark" \
|
|
-c ":hide-unmarked-lines" \
|
|
-c ":goto 0" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":unix-time" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":unix-time abc" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test env TZ=UTC ${lnav_test} -n \
|
|
-c ":unix-time 1612072409" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test env TZ=UTC ${lnav_test} -n \
|
|
-c ":current-time" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":write-to" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ";SELECT 1 AS c1, 'Hello ' || char(10) || 'World!' AS c2" \
|
|
-c ":write-csv-to -" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ";SELECT 1 AS c1, 'Hello, World!' AS c2" \
|
|
-c ":write-table-to -" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ";SELECT 1 AS c1, 'Hello, World!' AS c2" \
|
|
-c ":write-raw-to -" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":write-view-to -" \
|
|
"${test_dir}/logfile_access_log.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":write-view-to --anonymize -" \
|
|
"${test_dir}/logfile_access_log.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":write-view-to --anonymize -" \
|
|
"${test_dir}/logfile_pretty.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-expr timeslice(:log_time_msecs, 'bad') is not null" \
|
|
"${test_dir}/logfile_multiline.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-expr :log_text LIKE '%How are%'" \
|
|
"${test_dir}/logfile_multiline.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-expr not json_contains(:log_tags, '#bad')" \
|
|
-c ":goto 0" \
|
|
-c ":tag #bad" \
|
|
"${test_dir}/logfile_access_log.0"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-expr :sc_bytes > 2000" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-expr :sc_bytes # ff" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":goto 0" \
|
|
-c ":close" \
|
|
-c ":goto 0" \
|
|
"${test_dir}/logfile_access_log.*"
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":goto 0" \
|
|
-c ":hide-file" \
|
|
${test_dir}/logfile_access_log.*
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":goto 0" \
|
|
-c ":next-mark error" \
|
|
-c ":prev-location" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":goto 0" \
|
|
-c ":next-mark error" \
|
|
-c ":prev-location" \
|
|
-c ":next-location" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-in vmk" \
|
|
-c ":disable-filter vmk" \
|
|
-c ":goto 0" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":filter-in vmk" \
|
|
-c ":rebuild" \
|
|
-c ":reset-session" \
|
|
-c ":rebuild" \
|
|
-c ":goto 0" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav.err \
|
|
-c ":goto 0" \
|
|
-c ":filter-out vmk" \
|
|
-c ":toggle-filtering" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-fields foobar" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-fields cs_uri_stem" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-fields access_log.c_ip access_log.cs_uri_stem" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -f- -n < ${test_dir}/formats/scripts/multiline-echo.lnav
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":config /bad/option" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -nvq \
|
|
-c ":config /ui/clock-format" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -nv \
|
|
-c ":config /ui/clock-format" \
|
|
-c ":config /ui/clock-format abc" \
|
|
-c ":config /ui/clock-format" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -nv \
|
|
-c ":config /ui/clock-format abc" \
|
|
-c ":reset-config /ui/clock-format" \
|
|
-c ":config /ui/clock-format" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c "|${test_dir}/toplevel.lnav 123 456 789" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-f "nonexistent.lnav" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":adjust-log-time 2010-01-01T00:00:00" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":adjust-log-time -1h" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ':goto 2022-06-16Tabc' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ':goto 17:00:01.' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 1" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto -1" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":goto 2 hours later" \
|
|
${test_dir}/logfile_syslog_with_mixed_times.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":goto 3:45" \
|
|
${test_dir}/logfile_syslog_with_mixed_times.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto invalid" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 1" \
|
|
-c ":relative-goto -1" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":next-mark error" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto -1" \
|
|
-c ":prev-mark error" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":next-mark foobar" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-in vmk" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-in vmk" \
|
|
-c ":reset-session" \
|
|
-c ":filter-in cgi" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-in today" \
|
|
${test_dir}/logfile_multiline.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-out vmk" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-out today" \
|
|
${test_dir}/logfile_multiline.0
|
|
|
|
cp ${test_dir}/logfile_multiline.0 logfile_append.0
|
|
chmod ug+w logfile_append.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ";update generic_log set log_mark=1" \
|
|
-c ":filter-in Goodbye" \
|
|
-c ":append-to logfile_append.0" \
|
|
-c ":rebuild" \
|
|
logfile_append.0
|
|
|
|
cp ${test_dir}/logfile_multiline.0 logfile_append.0
|
|
chmod ug+w logfile_append.0
|
|
|
|
run_cap_test ${lnav_test} -n -d /tmp/lnav-search.err \
|
|
-c "/goodbye" \
|
|
-c ";update generic_log set log_mark=1" \
|
|
-c ":filter-in Goodbye" \
|
|
-c ":append-to logfile_append.0" \
|
|
-c ":rebuild" \
|
|
-c ":next-mark search" \
|
|
logfile_append.0
|
|
|
|
cp ${test_dir}/logfile_multiline.0 logfile_append.0
|
|
chmod ug+w logfile_append.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-out Goodbye" \
|
|
-c ":shexec echo '2009-07-20 22:59:30,221:ERROR:Goodbye, World!' >> logfile_append.0" \
|
|
-c ":rebuild" \
|
|
logfile_append.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-in avahi" \
|
|
-c ":delete-filter avahi" \
|
|
-c ":filter-in avahi" \
|
|
-c ":filter-in dnsmasq" \
|
|
${test_dir}/logfile_filter.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view text" \
|
|
-c ":filter-in World" \
|
|
${test_dir}/logfile_plain.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view text" \
|
|
-c ":filter-out World" \
|
|
${test_dir}/logfile_plain.0
|
|
|
|
TOO_MANY_FILTERS=""
|
|
for i in `seq 1 32`; do
|
|
TOO_MANY_FILTERS="$TOO_MANY_FILTERS -c ':filter-out $i'"
|
|
done
|
|
run_cap_test eval ${lnav_test} -d /tmp/lnav.err -n \
|
|
$TOO_MANY_FILTERS \
|
|
${test_dir}/logfile_filter.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":close" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":close" \
|
|
-c ":close" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":open" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":close" \
|
|
-c ":open ${test_dir}/logfile_multiline.0" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":close" \
|
|
-c ":open /non-existent" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 1" \
|
|
-c ":write-screen-to -" \
|
|
"${test_dir}/logfile_access_log.0"
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ";select * from access_log" \
|
|
-c ':write-json-to -' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ";select * from access_log" \
|
|
-c ':write-jsonlines-to -' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
# By setting the LNAVSECURE mode before executing the command, we will disable
|
|
# the access to the write-json-to command and the output would just be the
|
|
# actual display of select query rather than json output.
|
|
export LNAVSECURE=1
|
|
run_cap_test env TEST_COMMENT="secure mode write test" ${lnav_test} -n \
|
|
-c ";select * from access_log" \
|
|
-c ':write-json-to /tmp/bad' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
unset LNAVSECURE
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ";update generic_log set log_mark=1" \
|
|
-c ":pipe-to sed -e 's/World!/Bork!/g' -e 's/2009//g'" \
|
|
${test_dir}/logfile_multiline.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":echo Hello, World!" \
|
|
-c ":goto 2" \
|
|
-c ":pipe-line-to sed -e 's/World!/Bork!/g' -e 's/2009//g'" \
|
|
${test_dir}/logfile_multiline.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":pipe-line-to echo \$cs_uri_stem \$sc_status" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view pretty" \
|
|
${test_dir}/textfile_json_one_line.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view pretty" \
|
|
${test_dir}/textfile_json_one_line.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view pretty" \
|
|
${test_dir}/textfile_quoted_json.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view pretty" \
|
|
${test_dir}/logfile_vami.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":switch-to-view pretty" \
|
|
${test_dir}/logfile_pretty.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":set-min-log-level error" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":highlight foobar" \
|
|
-c ":clear-highlight foobar" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":clear-highlight foobar" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":zoom-to 4-hour" \
|
|
${test_dir}/textfile_json_indented.0
|
|
|
|
cp ${test_dir}/logfile_rollover.1 logfile_rollover.1.live
|
|
chmod ug+w logfile_rollover.1.live
|
|
touch -t 200711030923 logfile_rollover.1.live
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":shexec echo 'Jan 3 09:23:38 veridian automount[16442]: attempting to mount entry /auto/opt' >> logfile_rollover.1.live" \
|
|
-c ":rebuild" \
|
|
-c ":switch-to-view histogram" \
|
|
-c ":goto 0" \
|
|
logfile_rollover.1.live
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":goto next year" \
|
|
logfile_rollover.1.live
|
|
|
|
touch -t 200711030923 ${srcdir}/logfile_syslog.0
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view histogram" \
|
|
-c ":zoom-to 4-hour" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":switch-to-view histogram" \
|
|
-c ":zoom-to 1-day" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":filter-in sudo" \
|
|
-c ":switch-to-view histogram" \
|
|
-c ":zoom-to 4-hour" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":mark-expr" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":mark-expr :log_procname lik" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":mark-expr :cs_uri_stem LIKE '%vmk%'" \
|
|
-c ":write-to -" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":goto 0" \
|
|
-c ":mark" \
|
|
-c ":switch-to-view histogram" \
|
|
${test_dir}/logfile_syslog.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":zoom-to bad" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-f ${test_dir}/multiline.lnav \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
printf "Hello, World!" | run_cap_test env TEST_COMMENT="text view" ${lnav_test} -n \
|
|
-c ":switch-to-view text"
|
|
|
|
run_cap_test ${lnav_test} -Nnv \
|
|
-c ":hide-lines-before 2009-07-20T22:59:29" \
|
|
-c ":hide-lines-before"
|
|
|
|
run_cap_test ${lnav_test} -Nnv \
|
|
-c ":hide-lines-after 2009-07-20T22:59:29" \
|
|
-c ":hide-lines-after"
|
|
|
|
run_cap_test ${lnav_test} -Nnv \
|
|
-c ":hide-lines-before 2009-07-20T22:00:29" \
|
|
-c ":hide-lines-after 2009-07-20T22:59:29" \
|
|
-c ":hide-lines-before"
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-lines-before 2009-07-20T22:59:29" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-lines-after 2009-07-20T22:59:26" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ":hide-lines-after 2009-07-20T22:59:26" \
|
|
-c ":show-lines-before-and-after" \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
export XYZ="World"
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ':echo Hello, \$XYZ!' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
export XYZ="World"
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ':echo -n Hello, ' \
|
|
-c ':echo World!' \
|
|
${test_dir}/logfile_access_log.0
|
|
|
|
run_cap_test ${lnav_test} -n \
|
|
-c ':echo Hello, $XYZ!' \
|
|
${test_dir}/logfile_access_log.0
|