[llvm-commits] [compiler-rt] r160428 - /compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc

Alexey Samsonov samsonov at google.com
Tue Jul 17 23:29:18 PDT 2012


Author: samsonov
Date: Wed Jul 18 01:29:18 2012
New Revision: 160428

URL: http://llvm.org/viewvc/llvm-project?rev=160428&view=rev
Log:
[Sanitizer] add missing unit test for flag parsing (forgot to run svn add before)

Added:
    compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc

Added: compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc?rev=160428&view=auto
==============================================================================
--- compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc (added)
+++ compiler-rt/trunk/lib/sanitizer_common/tests/sanitizer_flags_test.cc Wed Jul 18 01:29:18 2012
@@ -0,0 +1,72 @@
+//===-- sanitizer_flags_test.cc -------------------------------------------===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file is a part of ThreadSanitizer/AddressSanitizer runtime.
+//
+//===----------------------------------------------------------------------===//
+#include "sanitizer_common/sanitizer_common.h"
+#include "sanitizer_common/sanitizer_flags.h"
+#include "gtest/gtest.h"
+
+#include "tsan_rtl.h"  // FIXME: break dependency from TSan runtime.
+using __tsan::ScopedInRtl;
+
+#include <string.h>
+
+namespace __sanitizer {
+
+static const char kFlagName[] = "flag_name";
+
+template <typename T>
+static void TestFlag(T start_value, const char *env, T final_value) {
+  T flag = start_value;
+  ParseFlag(env, &flag, kFlagName);
+  EXPECT_EQ(final_value, flag);
+}
+
+static void TestStrFlag(const char *start_value, const char *env,
+                        const char *final_value) {
+  const char *flag = start_value;
+  ParseFlag(env, &flag, kFlagName);
+  EXPECT_STREQ(final_value, flag);
+}
+
+TEST(SanitizerCommon, BooleanFlags) {
+  ScopedInRtl in_rtl;
+  TestFlag(true, "--flag_name", true);
+  TestFlag(false, "flag_name", false);
+  TestFlag(false, "--flag_name=1", true);
+  TestFlag(true, "asdas flag_name=0 asdas", false);
+  TestFlag(true, "    --flag_name=0   ", false);
+  TestFlag(false, "flag_name=yes", true);
+  TestFlag(false, "flag_name=true", true);
+  TestFlag(true, "flag_name=no", false);
+  TestFlag(true, "flag_name=false", false);
+}
+
+TEST(SanitizerCommon, IntFlags) {
+  ScopedInRtl in_rtl;
+  TestFlag(-11, 0, -11);
+  TestFlag(-11, "flag_name", 0);
+  TestFlag(-11, "--flag_name=", 0);
+  TestFlag(-11, "--flag_name=42", 42);
+  TestFlag(-11, "--flag_name=-42", -42);
+}
+
+TEST(SanitizerCommon, StrFlags) {
+  ScopedInRtl in_rtl;
+  TestStrFlag("zzz", 0, "zzz");
+  TestStrFlag("zzz", "flag_name", "");
+  TestStrFlag("zzz", "--flag_name=", "");
+  TestStrFlag("", "--flag_name=abc", "abc");
+  TestStrFlag("", "--flag_name='abc zxc'", "abc zxc");
+  TestStrFlag("", "--flag_name=\"abc qwe\" asd", "abc qwe");
+}
+
+}  // namespace __sanitizer





More information about the llvm-commits mailing list