Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | |
|
hidehiko
2017/05/08 06:13:11
Wow, nice adding tests!
| |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/chromeos/arc/accessibility/arc_accessibility_helper_bri dge.h" | |
| 6 #include "base/command_line.h" | |
|
hidehiko
2017/05/08 06:13:11
Style: could you add an empty line between L5 and
David Tseng
2017/05/08 16:10:21
Done.
| |
| 7 #include "chromeos/chromeos_switches.h" | |
| 8 #include "components/arc/arc_bridge_service.h" | |
| 9 #include "components/arc/common/accessibility_helper.mojom.h" | |
| 10 #include "testing/gtest/include/gtest/gtest.h" | |
| 11 | |
| 12 namespace arc { | |
| 13 | |
| 14 class ArcAccessibilityHelperBridgeTest : public testing::Test { | |
| 15 public: | |
| 16 ArcAccessibilityHelperBridgeTest() {} | |
|
hidehiko
2017/05/08 06:13:11
style: s/{}/= default/ for consistency in ARC?
David Tseng
2017/05/08 16:10:21
Done.
| |
| 17 void SetUp() override { | |
| 18 bridge_service_.reset(new ArcBridgeService()); | |
|
hidehiko
2017/05/08 06:13:11
Style/optional:
bridge_service_ = base::MakeUniqu
David Tseng
2017/05/08 16:10:21
Done.
| |
| 19 accessibility_helper_bridge_.reset( | |
| 20 new ArcAccessibilityHelperBridge(bridge_service_.get())); | |
| 21 } | |
| 22 | |
| 23 ArcAccessibilityHelperBridge* accessibility_helper_bridge() { | |
| 24 return accessibility_helper_bridge_.get(); | |
| 25 } | |
| 26 | |
| 27 private: | |
| 28 std::unique_ptr<ArcBridgeService> bridge_service_; | |
| 29 std::unique_ptr<ArcAccessibilityHelperBridge> accessibility_helper_bridge_; | |
| 30 | |
| 31 DISALLOW_COPY_AND_ASSIGN(ArcAccessibilityHelperBridgeTest); | |
| 32 }; | |
| 33 | |
| 34 TEST_F(ArcAccessibilityHelperBridgeTest, TaskLifecycle) { | |
| 35 ArcAccessibilityHelperBridge* ahb = accessibility_helper_bridge(); | |
|
hidehiko
2017/05/08 06:13:11
could you avoid "ahb" variable name?
Recommendatio
David Tseng
2017/05/08 16:10:21
Done.
| |
| 36 const auto& package_to_tree = ahb->package_name_to_tree_for_test(); | |
| 37 const auto& package_to_ids = ahb->package_name_to_task_ids_for_test(); | |
| 38 | |
| 39 EXPECT_EQ(0U, package_to_tree.size()); | |
| 40 EXPECT_EQ(0U, package_to_ids.size()); | |
| 41 | |
| 42 ahb->OnTaskCreated(1, "com.android.vending", "launch", ""); | |
| 43 EXPECT_EQ(0U, package_to_tree.size()); | |
| 44 EXPECT_EQ(1U, package_to_ids.size()); | |
| 45 auto entry1 = package_to_ids.find("com.android.vending"); | |
|
hidehiko
2017/05/08 06:13:11
Actually, this is not entry but iterator? How abou
David Tseng
2017/05/08 16:10:21
Done. Also, converted everything to ASSERT_* since
| |
| 46 EXPECT_NE(package_to_ids.end(), entry1); | |
| 47 EXPECT_EQ(1U, entry1->second.size()); | |
| 48 EXPECT_TRUE(entry1->second.count(1)); | |
| 49 | |
| 50 ahb->OnTaskCreated(2, "com.android.vending", "app", ""); | |
| 51 EXPECT_EQ(0U, package_to_tree.size()); | |
| 52 EXPECT_EQ(1U, package_to_ids.size()); | |
| 53 auto entry2 = package_to_ids.find("com.android.vending"); | |
| 54 EXPECT_NE(package_to_ids.end(), entry2); | |
| 55 EXPECT_EQ(2U, entry2->second.size()); | |
| 56 EXPECT_TRUE(entry2->second.count(1)); | |
| 57 EXPECT_TRUE(entry2->second.count(2)); | |
| 58 | |
| 59 ahb->OnTaskCreated(3, "com.android.music", "app", ""); | |
| 60 EXPECT_EQ(0U, package_to_tree.size()); | |
| 61 EXPECT_EQ(2U, package_to_ids.size()); | |
| 62 auto entry3 = package_to_ids.find("com.android.music"); | |
| 63 EXPECT_NE(package_to_ids.end(), entry3); | |
| 64 EXPECT_EQ(1U, entry3->second.size()); | |
| 65 EXPECT_TRUE(entry3->second.count(3)); | |
| 66 | |
| 67 ahb->OnTaskDestroyed(1); | |
| 68 EXPECT_EQ(0U, package_to_tree.size()); | |
| 69 EXPECT_EQ(2U, package_to_ids.size()); | |
| 70 entry1 = package_to_ids.find("com.android.vending"); | |
| 71 EXPECT_NE(package_to_ids.end(), entry1); | |
| 72 EXPECT_EQ(1U, entry1->second.size()); | |
| 73 EXPECT_FALSE(entry1->second.count(1)); | |
| 74 EXPECT_TRUE(entry1->second.count(2)); | |
| 75 | |
| 76 ahb->OnTaskDestroyed(2); | |
| 77 EXPECT_EQ(0U, package_to_tree.size()); | |
| 78 EXPECT_EQ(1U, package_to_ids.size()); | |
| 79 entry2 = package_to_ids.find("com.android.vending"); | |
| 80 EXPECT_EQ(package_to_ids.end(), entry2); | |
| 81 | |
| 82 ahb->OnTaskDestroyed(3); | |
| 83 EXPECT_EQ(0U, package_to_tree.size()); | |
| 84 EXPECT_EQ(0U, package_to_ids.size()); | |
| 85 } | |
| 86 | |
| 87 TEST_F(ArcAccessibilityHelperBridgeTest, AXTreeSourceLifetime) { | |
| 88 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 89 chromeos::switches::kEnableChromeVoxArcSupport); | |
| 90 | |
| 91 ArcAccessibilityHelperBridge* ahb = accessibility_helper_bridge(); | |
| 92 const auto& package_to_tree = ahb->package_name_to_tree_for_test(); | |
| 93 const auto& package_to_ids = ahb->package_name_to_task_ids_for_test(); | |
| 94 | |
| 95 EXPECT_EQ(0U, package_to_tree.size()); | |
| 96 EXPECT_EQ(0U, package_to_ids.size()); | |
| 97 | |
| 98 ahb->OnTaskCreated(1, "com.android.vending", "launch", ""); | |
| 99 EXPECT_EQ(0U, package_to_tree.size()); | |
| 100 EXPECT_EQ(1U, package_to_ids.size()); | |
| 101 auto entry1 = package_to_ids.find("com.android.vending"); | |
| 102 EXPECT_NE(package_to_ids.end(), entry1); | |
| 103 EXPECT_EQ(1U, entry1->second.size()); | |
| 104 EXPECT_TRUE(entry1->second.count(1)); | |
| 105 | |
| 106 auto event = arc::mojom::AccessibilityEventData::New(); | |
| 107 event->sourceId = 1; | |
| 108 event->eventType = arc::mojom::AccessibilityEventType::VIEW_FOCUSED; | |
| 109 event->nodeData.push_back(arc::mojom::AccessibilityNodeInfoData::New()); | |
| 110 event->nodeData[0]->id = 1; | |
| 111 event->nodeData[0]->stringProperties = | |
| 112 std::unordered_map<arc::mojom::AccessibilityStringProperty, | |
| 113 std::string>(); | |
| 114 event->nodeData[0]->stringProperties.value().insert( | |
| 115 std::make_pair(arc::mojom::AccessibilityStringProperty::PACKAGE_NAME, | |
| 116 "com.android.vending")); | |
| 117 | |
| 118 // Task 1 is not current; gets rejected. | |
| 119 ahb->OnAccessibilityEvent(event.Clone()); | |
| 120 EXPECT_EQ(0U, package_to_tree.size()); | |
| 121 | |
| 122 // Task 1 is now current. | |
| 123 ahb->OnTaskSetActive(1); | |
| 124 ahb->OnAccessibilityEvent(event.Clone()); | |
| 125 EXPECT_EQ(1U, package_to_tree.size()); | |
| 126 } | |
| 127 | |
| 128 } // namespace arc | |
| OLD | NEW |