Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1094)

Unified Diff: sandbox/win/src/address_sanitizer_test.cc

Issue 868253011: Make chrome.exe built with ASan/Win work with sandbox enabled (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed a review comment Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: sandbox/win/src/address_sanitizer_test.cc
diff --git a/sandbox/win/src/address_sanitizer_test.cc b/sandbox/win/src/address_sanitizer_test.cc
new file mode 100644
index 0000000000000000000000000000000000000000..eaf36cc1814f4a4b9c0f2579c54e4e8e8fcf5397
--- /dev/null
+++ b/sandbox/win/src/address_sanitizer_test.cc
@@ -0,0 +1,94 @@
+// Copyright (c) 2015 The Chromium Authors. All rights reserved.
rvargas (doing something else) 2015/02/02 20:55:58 nit: no (c)
Timur Iskhodzhanov 2015/02/03 13:25:22 Thanks for catching this! Self-for-the-record: I'v
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include <stdio.h>
+
+#include "base/environment.h"
+#include "base/files/file_path.h"
+#include "base/files/file_util.h"
+#include "base/win/windows_version.h"
+#include "sandbox/win/tests/common/controller.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace sandbox {
+
+class AddressSanitizerTests : public ::testing::Test {
+ public:
+ void SetUp() {
+ env_.reset(base::Environment::Create());
+ had_asan_options_ = env_->GetVar("ASAN_OPTIONS", &old_asan_options_);
+ }
+
+ void TearDown() {
+ if (had_asan_options_)
+ ASSERT_TRUE(env_->SetVar("ASAN_OPTIONS", old_asan_options_));
+ else
+ env_->UnSetVar("ASAN_OPTIONS");
+ }
+
+ protected:
+ scoped_ptr<base::Environment> env_;
+ bool had_asan_options_;
+ std::string old_asan_options_;
+};
+
+SBOX_TESTS_COMMAND int AddressSanitizerTests_Report(int argc, wchar_t** argv) {
+ volatile int idx = 42;
+ int *blah = new int[42];
+ blah[idx] = 42;
+ return SBOX_TEST_FAILED;
+}
+
+#if defined(ADDRESS_SANITIZER)
rvargas (doing something else) 2015/02/02 20:55:58 Can we just have the whole test inside the ifdef?
Timur Iskhodzhanov 2015/02/02 21:28:38 The idea behind using MAYBE_ here was that I want
rvargas (doing something else) 2015/02/03 00:42:29 That's a good point. Maybe we need another name fo
Timur Iskhodzhanov 2015/02/03 13:25:22 Why do you think disabling tests leads to regressi
rvargas (doing something else) 2015/02/03 19:47:11 What I've seen happening with disabled tests is th
+#define MAYBE_TestAddressSanitizer TestAddressSanitizer
+#else
+#define MAYBE_TestAddressSanitizer DISABLED_TestAddressSanitizer
+#endif
+TEST_F(AddressSanitizerTests, MAYBE_TestAddressSanitizer) {
+ wchar_t temp_directory[MAX_PATH];
+ wchar_t temp_file_name[MAX_PATH];
+ ASSERT_NE(::GetTempPath(MAX_PATH, temp_directory), 0u);
+ ASSERT_NE(::GetTempFileName(temp_directory, L"test", 0, temp_file_name), 0u);
+
+ SECURITY_ATTRIBUTES attrs = {};
+ attrs.nLength = sizeof(attrs);
+ attrs.bInheritHandle = TRUE;
+ HANDLE file_handle = CreateFile(
+ temp_file_name, GENERIC_WRITE,
+ FILE_SHARE_WRITE | FILE_SHARE_READ | FILE_SHARE_DELETE,
+ &attrs, OPEN_EXISTING, 0, NULL);
+ ASSERT_NE(file_handle, INVALID_HANDLE_VALUE);
+
+ TestRunner runner;
+ ASSERT_EQ(SBOX_ALL_OK, runner.GetPolicy()->SetStderrHandle(file_handle));
+
+ base::FilePath exe;
+ ASSERT_TRUE(PathService::Get(base::FILE_EXE, &exe);
+ base::FilePath pdb_path = exe.DirName().Append(L"*.pdb");
+ ASSERT_TRUE(runner.AddFsRule(sandbox::TargetPolicy::FILES_ALLOW_READONLY,
+ pdb_path.value().c_str()));
+
+ env_->SetVar("ASAN_OPTIONS", "exitcode=123");
+ int result = runner.RunTest(L"AddressSanitizerTests_Report");
+ EXPECT_EQ(123, result);
+ EXPECT_TRUE(::CloseHandle(file_handle));
+
+ std::string data;
+ ASSERT_TRUE(base::ReadFileToString(base::FilePath(temp_file_name), &data));
+ // Redirection uses a feature that was added in Windows Vista.
+ if (base::win::GetVersion() >= base::win::VERSION_VISTA) {
+ ASSERT_TRUE(strstr(data.c_str(), "ERROR: AddressSanitizer"))
+ << "There doesn't seem to be an ASan report:\n" << data;
+ ASSERT_TRUE(strstr(data.c_str(), "AddressSanitizerTests_Report"))
+ << "The ASan report doesn't appear to be symbolized:\n" << data;
+ ASSERT_TRUE(strstr(data.c_str(), strrchr(__FILE__, '\\')))
+ << "The stack trace doesn't have a correct filename:\n" << data;
+ } else {
+ EXPECT_EQ("", data);
+ }
+
+ EXPECT_TRUE(::DeleteFile(temp_file_name));
+}
+
+}

Powered by Google App Engine
This is Rietveld 408576698