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

Side by Side Diff: chrome/browser/chromeos/arc/open_with_menu_controller_delegate_unittest.cc

Issue 1760773004: Add "Open with <ARC-app-name>" items to the context menu (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: return std::pair Created 4 years, 9 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 2016 The Chromium Authors. All rights reserved.
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 "base/strings/stringprintf.h"
6 #include "chrome/app/chrome_command_ids.h"
7 #include "chrome/browser/chromeos/arc/open_with_menu_controller_delegate.h"
8 #include "testing/gtest/include/gtest/gtest.h"
9
10 namespace arc {
11
12 namespace {
13
14 std::pair<OpenWithMenuControllerDelegate::HandlerMap, int> BuildHandlersMap(
15 size_t num_apps) {
16 mojo::Array<UrlHandlerInfoPtr> handlers;
17 for (size_t i = 0; i < num_apps; ++i) {
18 UrlHandlerInfoPtr p = UrlHandlerInfo::New();
19 p->name = base::StringPrintf("App %zu", i);
20 handlers.push_back(std::move(p));
21 }
22 return OpenWithMenuControllerDelegate::BuildHandlersMapForTesting(
23 IDC_CONTENT_CONTEXT_OPEN_WITH1,
24 IDC_CONTENT_CONTEXT_OPEN_WITH_LAST - IDC_CONTENT_CONTEXT_OPEN_WITH1 + 1,
25 std::move(handlers));
26 }
27
28 } // namespace
29
30 // All tests in this file assume that 4 and 10 IDC command IDs are reserved
31 // for the main and sub menus, respectively.
32
33 TEST(OpenWithMenuControllerDelegateTest, TestGetCommandIdsToEnable) {
34 auto result = BuildHandlersMap(0);
35 EXPECT_EQ(0U, result.first.size());
36 EXPECT_EQ(-1, result.second);
37
38 result = BuildHandlersMap(1);
39 ASSERT_EQ(1U, result.first.size());
40 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
41 EXPECT_EQ(-1, result.second);
42 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
43
44 result = BuildHandlersMap(2);
45 EXPECT_EQ(2U, result.first.size());
46 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
47 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
48 EXPECT_EQ(-1, result.second);
49 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
50 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
51
52 result = BuildHandlersMap(3);
53 EXPECT_EQ(3U, result.first.size());
54 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
55 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
56 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH3));
57 EXPECT_EQ(-1, result.second);
58 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
59 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
60 EXPECT_EQ("App 2", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH3]->name);
61
62 // Test if app names will overflow to the sub menu.
63 result = BuildHandlersMap(4);
64 EXPECT_EQ(4U, result.first.size());
65 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
66 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
67 // In this case, IDC_CONTENT_CONTEXT_OPEN_WITH3 should be hidden.
68 EXPECT_EQ(IDC_CONTENT_CONTEXT_OPEN_WITH_LAST, result.second);
69 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1));
70 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP2));
71 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
72 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
73 EXPECT_EQ("App 2",
74 result.first[IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1]->name);
75 EXPECT_EQ("App 3",
76 result.first[IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP2]->name);
77
78 result = BuildHandlersMap(11);
79 EXPECT_EQ(11U, result.first.size());
80 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
81 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
82 EXPECT_EQ(IDC_CONTENT_CONTEXT_OPEN_WITH_LAST, result.second);
83 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
84 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
85 for (size_t i = 0; i < 9; ++i) {
86 ASSERT_EQ(1U,
87 result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1 + i))
88 << i;
89 }
90
91 // The main and sub menus can show up to 12 (=3+10-1) app names.
92 result = BuildHandlersMap(12);
93 EXPECT_EQ(12U, result.first.size());
94 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
95 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
96 EXPECT_EQ(IDC_CONTENT_CONTEXT_OPEN_WITH_LAST, result.second);
97 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
98 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
99 for (size_t i = 0; i < 10; ++i) {
100 const int id = IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1 + i;
101 ASSERT_EQ(1U, result.first.count(id)) << i;
102 EXPECT_EQ(base::StringPrintf("App %zu", i + 2), result.first[id]->name)
103 << i;
104 }
105
106 result = BuildHandlersMap(13);
107 EXPECT_EQ(12U, result.first.size()); // still 12
108 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
109 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
110 EXPECT_EQ(IDC_CONTENT_CONTEXT_OPEN_WITH_LAST, result.second);
111 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
112 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
113 for (size_t i = 0; i < 10; ++i) { // still 10
114 const int id = IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1 + i;
115 ASSERT_EQ(1U, result.first.count(id)) << i;
116 EXPECT_EQ(base::StringPrintf("App %zu", i + 2), result.first[id]->name)
117 << i;
118 }
119
120 result = BuildHandlersMap(1000);
121 EXPECT_EQ(12U, result.first.size()); // still 12
122 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH1));
123 ASSERT_EQ(1U, result.first.count(IDC_CONTENT_CONTEXT_OPEN_WITH2));
124 EXPECT_EQ(IDC_CONTENT_CONTEXT_OPEN_WITH_LAST, result.second);
125 EXPECT_EQ("App 0", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH1]->name);
126 EXPECT_EQ("App 1", result.first[IDC_CONTENT_CONTEXT_OPEN_WITH2]->name);
127 for (size_t i = 0; i < 10; ++i) { // still 10
128 const int id = IDC_CONTENT_CONTEXT_OPEN_WITH_ARC_APP1 + i;
129 ASSERT_EQ(1U, result.first.count(id)) << i;
130 EXPECT_EQ(base::StringPrintf("App %zu", i + 2), result.first[id]->name)
131 << i;
132 }
133 }
134
135 } // namespace arc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698