OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ui/aura/test/aura_test_base.h" | 5 #include "ui/aura/test/aura_test_base.h" |
6 | 6 |
7 #include "ui/aura/root_window.h" | 7 #include "ui/aura/root_window.h" |
8 #include "ui/aura/test/test_stacking_client.h" | 8 #include "ui/aura/test/test_stacking_client.h" |
9 | 9 |
10 namespace aura { | 10 namespace aura { |
11 namespace test { | 11 namespace test { |
12 | 12 |
13 AuraTestBase::AuraTestBase() : root_window_(RootWindow::GetInstance()) { | 13 AuraTestBase::AuraTestBase() { |
14 helper_.InitRootWindow(root_window_); | |
15 } | 14 } |
16 | 15 |
17 AuraTestBase::~AuraTestBase() { | 16 AuraTestBase::~AuraTestBase() { |
18 // Flush the message loop because we have pending release tasks | |
19 // and these tasks if un-executed would upset Valgrind. | |
20 helper_.RunAllPendingInMessageLoop(root_window_); | |
21 | |
22 // Ensure that we don't use the previously-allocated static RootWindow object | |
23 // later -- on Linux, it holds a reference to our message loop's X connection. | |
24 RootWindow::DeleteInstance(); | |
25 } | 17 } |
26 | 18 |
27 void AuraTestBase::SetUp() { | 19 void AuraTestBase::SetUp() { |
28 testing::Test::SetUp(); | 20 testing::Test::SetUp(); |
| 21 root_window_.reset(new aura::RootWindow); |
| 22 helper_.InitRootWindow(root_window()); |
29 helper_.SetUp(); | 23 helper_.SetUp(); |
30 stacking_client_.reset(new TestStackingClient(root_window())); | 24 stacking_client_.reset(new TestStackingClient(root_window())); |
31 } | 25 } |
32 | 26 |
33 void AuraTestBase::TearDown() { | 27 void AuraTestBase::TearDown() { |
| 28 // Flush the message loop because we have pending release tasks |
| 29 // and these tasks if un-executed would upset Valgrind. |
| 30 RunAllPendingInMessageLoop(); |
| 31 |
34 stacking_client_.reset(); | 32 stacking_client_.reset(); |
35 helper_.TearDown(); | 33 helper_.TearDown(); |
| 34 root_window_.reset(); |
36 testing::Test::TearDown(); | 35 testing::Test::TearDown(); |
37 } | 36 } |
38 | 37 |
39 void AuraTestBase::RunAllPendingInMessageLoop() { | 38 void AuraTestBase::RunAllPendingInMessageLoop() { |
40 helper_.RunAllPendingInMessageLoop(root_window_); | 39 helper_.RunAllPendingInMessageLoop(root_window()); |
41 } | 40 } |
42 | 41 |
43 } // namespace test | 42 } // namespace test |
44 } // namespace aura | 43 } // namespace aura |
OLD | NEW |