Blob Blame History Raw
#!/usr/bin/env sh

UNIT_TEST=./check_set_max_msg_size
MAX_MESSAGE_LOG_FILE=${UNIT_TEST}.output
TOO_LONG_MESSAGE="Message string too long"

# This test reduces the maximal message size using the provided function,
# so that the assertion message becomes too long.
# We set the maximal size to 32, which is shorter than the message.

rm -f ${MAX_MESSAGE_LOG_FILE}
${UNIT_TEST} 32 2>&1 | tee ${MAX_MESSAGE_LOG_FILE}

NUM_TOO_LONG_MESSAGES=$(grep "${TOO_LONG_MESSAGE}" ${MAX_MESSAGE_LOG_FILE} | wc -l)

if test ${NUM_TOO_LONG_MESSAGES} -gt 0; then
    echo "Maximal message size was reduced by function call."
    rm -f ${MAX_MESSAGE_LOG_FILE}
else
    echo "ERROR: Maximal message size was not reduced by function call."
    echo "Test output was preserved in ${MAX_MESSAGE_LOG_FILE}"
    exit 1
fi

rm -f ${MAX_MESSAGE_LOG_FILE}
export CK_MAX_MSG_SIZE=32
${UNIT_TEST} 4096 2>&1 | tee ${MAX_MESSAGE_LOG_FILE}

NUM_TOO_LONG_MESSAGES=$(grep "${TOO_LONG_MESSAGE}" ${MAX_MESSAGE_LOG_FILE} | wc -l)

if test ${NUM_TOO_LONG_MESSAGES} -gt 0; then
    echo "Maximal message size was reduced by environment variable."
else
    echo "ERROR: Maximal message size was not reduced by environment variable."
    echo "Test output was preserved in ${MAX_MESSAGE_LOG_FILE}"
    exit 1
fi

rm -f ${MAX_MESSAGE_LOG_FILE}
exit 0