#!/bin/bash # # Copyright (C) 2015 Sami Kerola # # This file is part of util-linux. # # This file is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This file is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # TS_TOPDIR="${0%/*}/../.." TS_DESC="errors" . $TS_TOPDIR/functions.sh ts_init "$*" ts_check_test_command "$TS_HELPER_LOGGER" export TZ="GMT" export LOGGER_TEST_TIMEOFDAY="1234567890.123456" export LOGGER_TEST_HOSTNAME="test-hostname" export LOGGER_TEST_GETPID="98765" DEVLOG="$(mktemp "/tmp/ultest-$TS_COMPONENT-$TS_TESTNAME-XXXXXX")" \ || ts_die "mktemp failed" SOCKIN="${TS_OUTDIR}/${TS_TESTNAME}_socketin" ts_init_socket_to_file $DEVLOG $SOCKIN SOCAT_PID="$!" function logger_fun { # logger without --no-act to write all data to the socket echo "socket data, ${TS_SUBNAME}:" |socat -u - UNIX-CONNECT:$DEVLOG $TS_HELPER_LOGGER -u $DEVLOG --stderr "$@" >> "$TS_OUTPUT" 2>&1 echo "ret: $?" >> "$TS_OUTPUT" echo |socat -u - UNIX-CONNECT:$DEVLOG } function logger_printf { # logger without --no-act to write all data to the socket local fmt="$1" shift echo "socket data, ${TS_SUBNAME}:" |socat -u - UNIX-CONNECT:$DEVLOG printf "$fmt" | $TS_HELPER_LOGGER -u $DEVLOG --stderr "$@" >> "$TS_OUTPUT" 2>&1 echo "ret: $?" >> "$TS_OUTPUT" echo |socat -u - UNIX-CONNECT:$DEVLOG } ts_init_subtest "kern_priority" logger_fun -t "prio" -p kern.emerg "message" ts_finalize_subtest ts_init_subtest "kern_priority_numeric" logger_fun -t "prio" -p 0 "message" ts_finalize_subtest ts_init_subtest "invalid_prio" logger_fun -t "prio" -p 8 "message" ts_finalize_subtest # should truncate ts_init_subtest "rfc5424_exceed_size" logger_fun -t "rfc5424_exceed_size" --rfc5424 --size 3 "abcd" ts_finalize_subtest ts_init_subtest "id_with_space" logger_fun -t "id_with_space" --id="A B" "message" logger_fun -t "rfc5424_id_with_space" --rfc5424 --id="A B" "message" logger_fun -t "id_with_space" --id="1 23" "message" logger_fun -t "id_with_leading space" --id=" 123" "message" logger_fun -t "id_with_trailing space" --id="123 " "message" ts_finalize_subtest # should not fail ts_init_subtest "tag_with_space" logger_fun -t "A B" "tag_with_space" logger_fun -t "A B" --rfc5424 "tag_with_space_rfc5424" ts_finalize_subtest ts_init_subtest "tcp" logger_fun --tcp -t "tcp" "message" ts_finalize_subtest ts_init_subtest "multi-line" logger_printf "AAA\nBBB\nCCC\n" -t "multi" ts_finalize_subtest ts_init_subtest "rfc5424_msgid_with_space" logger_fun -t "rfc5424_msgid_with_space" --rfc5424 --msgid="A B" "message" ts_finalize_subtest ts_init_subtest "invalid_socket" logger_fun -u /bad/boy -t "invalid_socket" "message" ts_finalize_subtest ts_init_subtest "check_socket" ts_log "Check written socket data of all subtests." sleep 1 kill $SOCAT_PID wait $SOCAT_PID &>/dev/null cat "$SOCKIN" >> "$TS_OUTPUT" 2>&1 rm -f "$DEVLOG" "$SOCKIN" ts_finalize_subtest ts_finalize