Fixes threading annotations and compatibility with C++11, which doesn't
allow exepctions to be thrown in a destructor.
This commit is contained in:
		
							parent
							
								
									cdb24f86d5
								
							
						
					
					
						commit
						a3b859162d
					
				| @ -3530,7 +3530,7 @@ void StreamingListener::MakeConnection() { | ||||
| // Pushes the given source file location and message onto a per-thread
 | ||||
| // trace stack maintained by Google Test.
 | ||||
| ScopedTrace::ScopedTrace(const char* file, int line, const Message& message) | ||||
|     GTEST_LOCK_EXCLUDED_(UnitTest::mutex_) { | ||||
|     GTEST_LOCK_EXCLUDED_(&UnitTest::mutex_) { | ||||
|   TraceInfo trace; | ||||
|   trace.file = file; | ||||
|   trace.line = line; | ||||
| @ -3541,7 +3541,7 @@ ScopedTrace::ScopedTrace(const char* file, int line, const Message& message) | ||||
| 
 | ||||
| // Pops the info pushed by the c'tor.
 | ||||
| ScopedTrace::~ScopedTrace() | ||||
|     GTEST_LOCK_EXCLUDED_(UnitTest::mutex_) { | ||||
|     GTEST_LOCK_EXCLUDED_(&UnitTest::mutex_) { | ||||
|   UnitTest::GetInstance()->PopGTestTrace(); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -117,14 +117,17 @@ class CatchCxxExceptionsTest(gtest_test_utils.TestCase): | ||||
|                  '"CxxExceptionInConstructorTest" (no quotes) ' | ||||
|                  'appears on the same line as words "called unexpectedly"') | ||||
| 
 | ||||
|   def testCatchesCxxExceptionsInFixtureDestructor(self): | ||||
|     self.assert_('C++ exception with description ' | ||||
|                  '"Standard C++ exception" thrown ' | ||||
|                  'in the test fixture\'s destructor' | ||||
|                  in EX_BINARY_OUTPUT) | ||||
|     self.assert_('CxxExceptionInDestructorTest::TearDownTestCase() ' | ||||
|                  'called as expected.' | ||||
|                  in EX_BINARY_OUTPUT) | ||||
|   if ('CxxExceptionInDestructorTest.ThrowsExceptionInDestructor' in | ||||
|       EX_BINARY_OUTPUT): | ||||
| 
 | ||||
|     def testCatchesCxxExceptionsInFixtureDestructor(self): | ||||
|       self.assert_('C++ exception with description ' | ||||
|                    '"Standard C++ exception" thrown ' | ||||
|                    'in the test fixture\'s destructor' | ||||
|                    in EX_BINARY_OUTPUT) | ||||
|       self.assert_('CxxExceptionInDestructorTest::TearDownTestCase() ' | ||||
|                    'called as expected.' | ||||
|                    in EX_BINARY_OUTPUT) | ||||
| 
 | ||||
|   def testCatchesCxxExceptionsInSetUpTestCase(self): | ||||
|     self.assert_('C++ exception with description "Standard C++ exception"' | ||||
|  | ||||
| @ -137,6 +137,8 @@ TEST_F(CxxExceptionInConstructorTest, ThrowsExceptionInConstructor) { | ||||
|                 << "called unexpectedly."; | ||||
| } | ||||
| 
 | ||||
| // Exceptions in destructors are not supported in C++11.
 | ||||
| #if !defined(__GXX_EXPERIMENTAL_CXX0X__) &&  __cplusplus < 201103L | ||||
| class CxxExceptionInDestructorTest : public Test { | ||||
|  public: | ||||
|   static void TearDownTestCase() { | ||||
| @ -153,6 +155,7 @@ class CxxExceptionInDestructorTest : public Test { | ||||
| }; | ||||
| 
 | ||||
| TEST_F(CxxExceptionInDestructorTest, ThrowsExceptionInDestructor) {} | ||||
| #endif  // C++11 mode
 | ||||
| 
 | ||||
| class CxxExceptionInSetUpTestCaseTest : public Test { | ||||
|  public: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user