summaryrefslogtreecommitdiffstats
path: root/thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh
diff options
context:
space:
mode:
authorYalei Wang <william.wangyalei@huawei.com>2018-03-09 11:04:03 +0800
committerYalei Wang <william.wangyalei@huawei.com>2018-03-09 11:08:49 +0800
commit71e33ec17c12e6ca43f149215ca05fc9d8b1d5a9 (patch)
tree0156b92e35311499b75ba21d5b547b47b10061a9 /thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh
parent71a4e2f34afa8018426f0e830050e50a1de6d375 (diff)
Add some third-party src code for DMM
glog-0.3.4 is necessary for the DMM project. Change-Id: Id42f7370ebaff0e584a00d57d66bca98db8004e1 Signed-off-by: Yalei Wang <william.wangyalei@huawei.com>
Diffstat (limited to 'thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh')
-rw-r--r--thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh79
1 files changed, 79 insertions, 0 deletions
diff --git a/thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh b/thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh
new file mode 100644
index 0000000..73492bd
--- /dev/null
+++ b/thirdparty/glog/glog-0.3.4/src/logging_striplog_test.sh
@@ -0,0 +1,79 @@
+#! /bin/sh
+#
+# Copyright (c) 2007, Google Inc.
+# All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above
+# copyright notice, this list of conditions and the following disclaimer
+# in the documentation and/or other materials provided with the
+# distribution.
+# * Neither the name of Google Inc. nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+#
+# Author: Sergey Ioffe
+
+get_strings () {
+ if test -e ".libs/$1"; then
+ binary=".libs/$1"
+ elif test -e "$1.exe"; then
+ binary="$1.exe"
+ else
+ echo "We coundn't find $1 binary."
+ exit 1
+ fi
+
+ strings -n 10 $binary | sort | awk '/TESTMESSAGE/ {printf "%s ", $2}'
+}
+
+# Die if "$1" != "$2", print $3 as death reason
+check_eq () {
+ if [ "$1" != "$2" ]; then
+ echo "Check failed: '$1' == '$2' ${3:+ ($3)}"
+ exit 1
+ fi
+}
+
+die () {
+ echo $1
+ exit 1
+}
+
+# Check that the string literals are appropriately stripped. This will
+# not be the case in debug mode.
+
+mode=`GLOG_check_mode=1 ./logging_striptest0 2> /dev/null`
+if [ "$mode" = "opt" ];
+then
+ echo "In OPT mode"
+ check_eq "`get_strings logging_striptest0`" "COND ERROR FATAL INFO USAGE WARNING "
+ check_eq "`get_strings logging_striptest2`" "COND ERROR FATAL USAGE "
+ check_eq "`get_strings logging_striptest10`" ""
+else
+ echo "In DBG mode; not checking strings"
+fi
+
+# Check that LOG(FATAL) aborts even for large STRIP_LOG
+
+./logging_striptest2 2>/dev/null && die "Did not abort for STRIP_LOG=2"
+./logging_striptest10 2>/dev/null && die "Did not abort for STRIP_LOG=10"
+
+echo "PASS"