Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(75)

Side by Side Diff: chrome/browser/chromeos/arc/accessibility/arc_accessibility_helper_bridge_unittest.cc

Issue 2826423003: Expand Chrome OS ARC support to create one tree source per package (Closed)
Patch Set: Test for tree source management. Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698