| OLD | NEW | 
|---|
| 1 // Copyright (c) 2012, the Dart project authors.  Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors.  Please see the AUTHORS file | 
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a | 
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "platform/assert.h" | 5 #include "platform/assert.h" | 
| 6 #include "vm/isolate.h" | 6 #include "vm/isolate.h" | 
| 7 #include "vm/unit_test.h" | 7 #include "vm/unit_test.h" | 
|  | 8 #include "vm/signal_handler.h" | 
| 8 #include "vm/thread.h" | 9 #include "vm/thread.h" | 
| 9 | 10 | 
| 10 namespace dart { | 11 namespace dart { | 
| 11 | 12 | 
| 12 UNIT_TEST_CASE(Mutex) { | 13 UNIT_TEST_CASE(Mutex) { | 
| 13   // This unit test case needs a running isolate. | 14   // This unit test case needs a running isolate. | 
| 14   Isolate* isolate = Isolate::Init(NULL); | 15   Isolate* isolate = Isolate::Init(NULL); | 
| 15 | 16 | 
| 16   Mutex* mutex = new Mutex(); | 17   Mutex* mutex = new Mutex(); | 
| 17   mutex->Lock(); | 18   mutex->Lock(); | 
| (...skipping 17 matching lines...) Expand all  Loading... | 
| 35   // This unit test case needs a running isolate. | 36   // This unit test case needs a running isolate. | 
| 36   Isolate* isolate = Isolate::Init(NULL); | 37   Isolate* isolate = Isolate::Init(NULL); | 
| 37 | 38 | 
| 38   Monitor* monitor = new Monitor(); | 39   Monitor* monitor = new Monitor(); | 
| 39   monitor->Enter(); | 40   monitor->Enter(); | 
| 40   monitor->Exit(); | 41   monitor->Exit(); | 
| 41 | 42 | 
| 42   const int kNumAttempts = 5; | 43   const int kNumAttempts = 5; | 
| 43   int attempts = 0; | 44   int attempts = 0; | 
| 44   while (attempts < kNumAttempts) { | 45   while (attempts < kNumAttempts) { | 
|  | 46     // This test verifies that a monitor returns after the specified timeout. If | 
|  | 47     // a signal is delivered to this thread, the monitor may return early. | 
|  | 48     // Block signal delivery in this scope. | 
|  | 49     ScopedSignalBlocker ssb; | 
| 45     MonitorLocker ml(monitor); | 50     MonitorLocker ml(monitor); | 
| 46     int64_t start = OS::GetCurrentTimeMillis(); | 51     int64_t start = OS::GetCurrentTimeMillis(); | 
| 47     int64_t wait_time = 2017; | 52     int64_t wait_time = 2017; | 
| 48     Monitor::WaitResult wait_result = ml.Wait(wait_time); | 53     Monitor::WaitResult wait_result = ml.Wait(wait_time); | 
| 49     int64_t stop = OS::GetCurrentTimeMillis(); | 54     int64_t stop = OS::GetCurrentTimeMillis(); | 
| 50 | 55 | 
| 51     // We expect to be timing out here. | 56     // We expect to be timing out here. | 
| 52     EXPECT_EQ(Monitor::kTimedOut, wait_result); | 57     EXPECT_EQ(Monitor::kTimedOut, wait_result); | 
| 53 | 58 | 
| 54     // Check whether this attempt falls within the exptected time limits. | 59     // Check whether this attempt falls within the exptected time limits. | 
| (...skipping 12 matching lines...) Expand all  Loading... | 
| 67   EXPECT_LT(attempts, kNumAttempts); | 72   EXPECT_LT(attempts, kNumAttempts); | 
| 68 | 73 | 
| 69   // The isolate shutdown and the destruction of the mutex are out-of-order on | 74   // The isolate shutdown and the destruction of the mutex are out-of-order on | 
| 70   // purpose. | 75   // purpose. | 
| 71   isolate->Shutdown(); | 76   isolate->Shutdown(); | 
| 72   delete isolate; | 77   delete isolate; | 
| 73   delete monitor; | 78   delete monitor; | 
| 74 } | 79 } | 
| 75 | 80 | 
| 76 }  // namespace dart | 81 }  // namespace dart | 
| OLD | NEW | 
|---|