Index: base/mac/call_with_eh_frame_unittest.mm |
diff --git a/base/mac/call_with_eh_frame_unittest.mm b/base/mac/call_with_eh_frame_unittest.mm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..46bf285c2cd957c3ce763f2b2cbf7d1f7caed411 |
--- /dev/null |
+++ b/base/mac/call_with_eh_frame_unittest.mm |
@@ -0,0 +1,53 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/mac/call_with_eh_frame.h" |
+ |
+#import <Foundation/Foundation.h> |
+ |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace base { |
+namespace mac { |
+namespace { |
+ |
+class CallWithEHFrameTest : public testing::Test { |
+ protected: |
+ void ThrowException() { |
+ [NSArray arrayWithObject:nil]; |
+ } |
+}; |
+ |
+// Catching from within the EHFrame is allowed. |
+TEST_F(CallWithEHFrameTest, CatchExceptionHigher) { |
+ bool __block saw_exception = false; |
+ base::mac::CallWithEHFrame(^{ |
+ @try { |
+ ThrowException(); |
+ } @catch (NSException* exception) { |
+ saw_exception = true; |
+ } |
+ }); |
+ EXPECT_TRUE(saw_exception); |
+} |
+ |
+// Trying to catch an exception outside the EHFrame is blocked. |
+TEST_F(CallWithEHFrameTest, CatchExceptionLower) { |
+ auto catch_exception_lower = ^{ |
+ bool saw_exception = false; |
+ @try { |
+ base::mac::CallWithEHFrame(^{ |
+ ThrowException(); |
+ }); |
+ } @catch (NSException* exception) { |
+ saw_exception = true; |
+ } |
+ ASSERT_FALSE(saw_exception); |
+ }; |
+ EXPECT_DEATH(catch_exception_lower(), ""); |
+} |
+ |
+} // namespace |
+} // namespace mac |
+} // namespace base |