3 Star 0 Fork 1

Gitee 极速下载/log4sh

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/kward/log4sh
克隆/下载
log4sh_base_test.sh 6.14 KB
一键复制 编辑 原始数据 按行查看 历史
Kate Ward 提交于 2018-01-18 05:27 +08:00 . Updated copyright and license info.
#!/bin/sh
# vim:et:ft=sh:sts=2:sw=2
#
# Copyright 2008-2018 Kate Ward. All Rights Reserved.
# Released under the Apache License 2.0 license.
#
# log4sh unit test for the ConsoleAppender.
# https://github.com/kward/log4sh
#
# Author: [email protected] (Kate Ward)
# load test helpers
. ./log4sh_test_helpers
#------------------------------------------------------------------------------
# suite tests
#
test__log4sh_getsetValue()
{
# getValue
_log4sh_getValue >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_ERROR} $?
assertError 'invalid argument count'
value=`_log4sh_getValue 'missing_key' 2>"${stderrF}"`
assertFalse 'a missing key should be missed' $?
# setValue
_log4sh_setValue >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_ERROR} $?
assertError 'invalid argument count'
_log4sh_setValue 'abc' 123 >"${stdoutF}" 2>"${stderrF}"
assertSuccess $?
diff "${__log4sh_dictFile}" - >/dev/null <<EOF
abc 123
EOF
assertTrue 'invalid data written to dictionary' $? || cat "${__log4sh_dictFile}"
value=`_log4sh_getValue 'abc' 2>"${stderrF}"`
assertSuccess $?
assertEquals 'unable to get key value' 123 "${value}"
}
test_log4sh_addLogger()
{
log4sh_addLogger >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_ERROR} $?
assertError 'invalid argument count'
log4sh_addLogger 'root' >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_FALSE} $?
assertError 'logger already exists'
log4sh_addLogger 'newLogger' >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_TRUE} $?
_logger_isValid 'newLogger'
assertTrue 'new logger should exist' $?
}
test__logger_isValid()
{
_logger_isValid ''
assertFalse 'empty logger should fail' $?
_logger_isValid 'root'
assertTrue 'root logger should exist' $?
_logger_isValid 'invalid'
assertFalse 'invalid logger should not exist' $?
}
test_logger_addAppender()
{
logger_addAppender >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_ERROR} $?
assertError 'invalid argument count'
logger_addAppender 'newRootAppender' >"${stdoutF}" 2>"${stderrF}"
assertSuccess $?
_appender_isValid 'newRootAppender'
assertTrue 'newRootAppender should exist' $?
log4sh_addLogger 'newLogger'
logger_addAppender 'newLoggerAppender' 'newLogger' \
>"${stdoutF}" 2>"${stderrF}"
assertSuccess $?
_appender_isValid 'newLogger.newLoggerAppender'
assertTrue 'newLogger.newLoggerAppender should exist' $?
}
test_logger_getAppenders()
{
# root logger
appenders=`logger_getAppenders 2>"${stderrF}"`
assertTrue 'default mode to retrieve root logger should succeed' $?
assertNull "${appenders}"
appenders=`logger_getAppenders root 2>"${stderrF}"`
assertTrue 'getting appenders for root logger should succeed' $?
assertNull "${appenders}"
logger_addAppender 'newRootAppender'
appenders=`logger_getAppenders 2>"${stderrF}"`
assertTrue 'just added the newRootAppender. where is it?' $?
assertEquals 'newRootAppender' "${appenders}"
# invalid logger
appenders=`logger_getAppenders invalidLogger 2>"${stderrF}"`
assertFalse 'getting appenders for an invalid logger should not succeed' $?
assertNull "${appenders}"
# custom
log4sh_addLogger custom
appenders=`logger_getAppenders custom 2>"${stderrF}"`
assertTrue 'getting appenders for custom logger should succeed' $?
assertNull "${appenders}"
logger_addAppender newCustomAppender custom
appenders=`logger_getAppenders custom 2>"${stderrF}"`
assertTrue 'just added the newCustomAppender. where is it?' $?
assertEquals 'newCustomAppender' "${appenders}"
}
test__appender_isValid()
{
_appender_isValid ''
assertFalse 'empty appender should fail' $?
}
test__appender_isValidType()
{
_appender_isValidType ''
assertFalse 'empty type should fail' $?
_appender_isValidType 'DummyAppender'
assertFalse 'unregistered Dummy appender type should fail' $?
_log4sh_register_appender 'DummyAppender'
_appender_isValidType 'DummyAppender'
assertTrue 'registered Dummy appender type should succeed' $?
}
test_appender_getsetType()
{
# getType
appType=`appender_getType 2>"${stderrF}"`
assertEquals ${LOG4SH_ERROR} $?
assertError 'getType' 'invalid argument count'
appType=`appender_getType 'invalidAppender' 2>"${stderrF}"`
assertFalse $?
assertError 'getType' 'invalid appender'
# setType
appender_setType >"${stdoutF}" 2>"${stderrF}"
assertEquals ${LOG4SH_ERROR} $?
assertError 'setType' 'invalid argument count'
appender_setType 'invalidAppender' 'DummyAppender' \
>"${stdoutF}" 2>"${stderrF}"
assertFalse $?
assertError 'setType' 'invalid appender'
# default appender type is a ConsoleAppender
logger_addAppender 'myConsoleAppender'
appType=`appender_getType 'myConsoleAppender' 2>"${stderrF}"`
assertSuccess 'failed to get myConsoleAppender type' $?
assertEquals 'ConsoleAppender' "${appType}"
_log4sh_register_appender 'DummyAppender'
logger_addAppender 'myDummyAppender'
appender_setType 'myDummyAppender' 'DummyAppender' >"${stdoutF}" 2>"${stderrF}"
assertSuccess 'failed to set myDummyAppender type' $?
appType=`appender_getType 'myDummyAppender' 2>"${stderrF}"`
assertSuccess 'failed to get myDummyAppender type' $?
assertEquals 'DummyAppender' "${appType}"
}
testSplitLoggerAppenderMacro()
{
set -- 'appender'
${_LOG4SH_SPLIT_LOGGER_APPENDER_}
assertEquals 'root' "${log4sh_logger_}"
assertEquals 'appender' "${log4sh_appender_}"
assertEquals 'root.appender' "${log4sh_fqAppender_}"
set -- 'logger.appender'
${_LOG4SH_SPLIT_LOGGER_APPENDER_}
assertEquals 'logger' "${log4sh_logger_}"
assertEquals 'appender' "${log4sh_appender_}"
assertEquals 'logger.appender' "${log4sh_fqAppender_}"
}
#
# stub functions
#
_appender_register_ConsoleAppender() { :; }
_appender_new_ConsoleAppender() { return ${LOG4SH_TRUE}; }
_appender_register_DummyAppender() { :; }
_appender_new_DummyAppender() { return ${LOG4SH_TRUE}; }
#------------------------------------------------------------------------------
# suite functions
#
oneTimeSetUp()
{
th_oneTimeSetUp
# load libraries
. ./log4sh_base
_log4sh_register_appender ConsoleAppender
}
setUp()
{
log4sh_resetConfiguration
}
# load and run shUnit2
[ -n "${ZSH_VERSION:-}" ] && SHUNIT_PARENT=$0
. ${TH_SHUNIT}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Shell
1
https://gitee.com/mirrors/log4sh.git
[email protected]:mirrors/log4sh.git
mirrors
log4sh
log4sh
master

搜索帮助