OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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 #import <Cocoa/Cocoa.h> | 5 #import <Cocoa/Cocoa.h> |
6 | 6 |
7 #include "base/scoped_nsobject.h" | 7 #include "base/scoped_nsobject.h" |
8 #include "base/sys_string_conversions.h" | 8 #include "base/sys_string_conversions.h" |
9 #import "chrome/browser/cocoa/bookmark_editor_controller.h" | 9 #import "chrome/browser/cocoa/bookmark_editor_controller.h" |
10 #include "chrome/browser/cocoa/browser_test_helper.h" | 10 #include "chrome/browser/cocoa/browser_test_helper.h" |
11 #import "chrome/browser/cocoa/cocoa_test_helper.h" | 11 #import "chrome/browser/cocoa/cocoa_test_helper.h" |
12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
13 #include "testing/platform_test.h" | 13 #include "testing/platform_test.h" |
14 | 14 |
15 class BookmarkEditorControllerTest : public PlatformTest { | 15 class BookmarkEditorControllerTest : public CocoaTest { |
16 public: | 16 public: |
17 CocoaTestHelper cocoa_helper_; // Inits Cocoa, creates window, etc... | |
18 BrowserTestHelper helper_; | 17 BrowserTestHelper helper_; |
19 const BookmarkNode* default_node_; | 18 const BookmarkNode* default_node_; |
20 const BookmarkNode* default_parent_; | 19 const BookmarkNode* default_parent_; |
21 const char* default_name_; | 20 const char* default_name_; |
22 std::wstring default_title_; | 21 std::wstring default_title_; |
23 scoped_nsobject<BookmarkEditorController> default_controller_; | 22 BookmarkEditorController* default_controller_; |
24 | 23 |
25 BookmarkEditorControllerTest() { | 24 virtual void SetUp() { |
| 25 CocoaTest::SetUp(); |
26 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); | 26 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); |
27 default_parent_ = model->GetBookmarkBarNode(); | 27 default_parent_ = model->GetBookmarkBarNode(); |
28 default_name_ = "http://www.zim-bop-a-dee.com/"; | 28 default_name_ = "http://www.zim-bop-a-dee.com/"; |
29 default_title_ = L"ooh title"; | 29 default_title_ = L"ooh title"; |
30 const BookmarkNode* default_node = model->AddURL(default_parent_, 0, | 30 const BookmarkNode* default_node = model->AddURL(default_parent_, 0, |
31 default_title_, | 31 default_title_, |
32 GURL(default_name_)); | 32 GURL(default_name_)); |
33 default_controller_.reset([[BookmarkEditorController alloc] | 33 default_controller_ = [[BookmarkEditorController alloc] |
34 initWithParentWindow:cocoa_helper_.window() | 34 initWithParentWindow:test_window() |
35 profile:helper_.profile() | 35 profile:helper_.profile() |
36 parent:default_parent_ | 36 parent:default_parent_ |
37 node:default_node | 37 node:default_node |
38 configuration:BookmarkEditor::NO_TREE | 38 configuration:BookmarkEditor::NO_TREE |
39 handler:nil]); | 39 handler:nil]; |
40 [default_controller_ window]; // Forces a nib load | 40 [default_controller_ window]; // Forces a nib load |
41 } | 41 } |
| 42 |
| 43 virtual void TearDown() { |
| 44 [default_controller_ close]; |
| 45 CocoaTest::TearDown(); |
| 46 } |
42 }; | 47 }; |
43 | 48 |
44 TEST_F(BookmarkEditorControllerTest, NoNodeNoTree) { | 49 TEST_F(BookmarkEditorControllerTest, NoNodeNoTree) { |
45 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); | 50 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); |
46 const BookmarkNode* parent = model->GetBookmarkBarNode(); | 51 const BookmarkNode* parent = model->GetBookmarkBarNode(); |
47 const BookmarkNode* node = NULL; | 52 const BookmarkNode* node = NULL; |
48 | 53 |
49 scoped_nsobject<BookmarkEditorController> | 54 BookmarkEditorController* controller = |
50 controller([[BookmarkEditorController alloc] | 55 [[BookmarkEditorController alloc] |
51 initWithParentWindow:cocoa_helper_.window() | 56 initWithParentWindow:test_window() |
52 profile:helper_.profile() | 57 profile:helper_.profile() |
53 parent:parent | 58 parent:parent |
54 node:node | 59 node:node |
55 configuration:BookmarkEditor::NO_TREE | 60 configuration:BookmarkEditor::NO_TREE |
56 handler:nil]); | 61 handler:nil]; |
57 | 62 |
58 EXPECT_NE((NSWindow*)nil, [controller window]); // Forces a nib load | 63 EXPECT_NE((NSWindow*)nil, [controller window]); // Forces a nib load |
59 EXPECT_EQ(@"", [controller displayName]); | 64 EXPECT_EQ(@"", [controller displayName]); |
60 EXPECT_EQ(@"", [controller displayURL]); | 65 EXPECT_EQ(@"", [controller displayURL]); |
61 EXPECT_FALSE([controller okButtonEnabled]); | 66 EXPECT_FALSE([controller okButtonEnabled]); |
| 67 [controller close]; |
62 } | 68 } |
63 | 69 |
64 TEST_F(BookmarkEditorControllerTest, YesNodeShowTree) { | 70 TEST_F(BookmarkEditorControllerTest, YesNodeShowTree) { |
65 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); | 71 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); |
66 const BookmarkNode* parent = model->GetBookmarkBarNode(); | 72 const BookmarkNode* parent = model->GetBookmarkBarNode(); |
67 const char* url_name = "http://www.zim-bop-a-dee.com/"; | 73 const char* url_name = "http://www.zim-bop-a-dee.com/"; |
68 const BookmarkNode* node = model->AddURL(parent, 0, default_title_, | 74 const BookmarkNode* node = model->AddURL(parent, 0, default_title_, |
69 GURL(url_name)); | 75 GURL(url_name)); |
70 | 76 |
71 scoped_nsobject<BookmarkEditorController> | 77 BookmarkEditorController* controller = |
72 controller([[BookmarkEditorController alloc] | 78 [[BookmarkEditorController alloc] |
73 initWithParentWindow:cocoa_helper_.window() | 79 initWithParentWindow:test_window() |
74 profile:helper_.profile() | 80 profile:helper_.profile() |
75 parent:parent | 81 parent:parent |
76 node:node | 82 node:node |
77 configuration:BookmarkEditor::SHOW_TREE | 83 configuration:BookmarkEditor::SHOW_TREE |
78 handler:nil]); | 84 handler:nil]; |
79 | 85 |
80 EXPECT_NE((NSWindow*)nil, [controller window]); // Forces a nib load | 86 EXPECT_NE((NSWindow*)nil, [controller window]); // Forces a nib load |
81 EXPECT_TRUE([base::SysWideToNSString(default_title_) | 87 EXPECT_TRUE([base::SysWideToNSString(default_title_) |
82 isEqual:[controller displayName]]); | 88 isEqual:[controller displayName]]); |
83 EXPECT_TRUE([[NSString stringWithCString:url_name | 89 EXPECT_TRUE([[NSString stringWithCString:url_name |
84 encoding:NSUTF8StringEncoding] | 90 encoding:NSUTF8StringEncoding] |
85 isEqual:[controller displayURL]]); | 91 isEqual:[controller displayURL]]); |
| 92 [controller close]; |
86 } | 93 } |
87 | 94 |
88 TEST_F(BookmarkEditorControllerTest, NoEdit) { | 95 TEST_F(BookmarkEditorControllerTest, NoEdit) { |
89 [default_controller_ ok:nil]; | 96 [default_controller_ ok:nil]; |
90 ASSERT_EQ(default_parent_->GetChildCount(), 1); | 97 ASSERT_EQ(default_parent_->GetChildCount(), 1); |
91 const BookmarkNode* child = default_parent_->GetChild(0); | 98 const BookmarkNode* child = default_parent_->GetChild(0); |
92 EXPECT_EQ(child->GetTitle(), default_title_); | 99 EXPECT_EQ(child->GetTitle(), default_title_); |
93 EXPECT_EQ(child->GetURL(), GURL(default_name_)); | 100 EXPECT_EQ(child->GetURL(), GURL(default_name_)); |
94 } | 101 } |
95 | 102 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
134 EXPECT_FALSE([default_controller_ okButtonEnabled]); | 141 EXPECT_FALSE([default_controller_ okButtonEnabled]); |
135 [default_controller_ setDisplayName:@" "]; | 142 [default_controller_ setDisplayName:@" "]; |
136 EXPECT_TRUE([default_controller_ okButtonEnabled]); | 143 EXPECT_TRUE([default_controller_ okButtonEnabled]); |
137 // Then little mix of both. | 144 // Then little mix of both. |
138 [default_controller_ setDisplayName:@"name"]; | 145 [default_controller_ setDisplayName:@"name"]; |
139 EXPECT_TRUE([default_controller_ okButtonEnabled]); | 146 EXPECT_TRUE([default_controller_ okButtonEnabled]); |
140 [default_controller_ setDisplayURL:@""]; | 147 [default_controller_ setDisplayURL:@""]; |
141 EXPECT_FALSE([default_controller_ okButtonEnabled]); | 148 EXPECT_FALSE([default_controller_ okButtonEnabled]); |
142 } | 149 } |
143 | 150 |
144 class BookmarkEditorControllerTreeTest : public PlatformTest { | 151 class BookmarkEditorControllerTreeTest : public CocoaTest { |
145 public: | 152 public: |
146 CocoaTestHelper cocoa_helper_; // Inits Cocoa, creates window, etc... | |
147 BrowserTestHelper helper_; | 153 BrowserTestHelper helper_; |
148 scoped_nsobject<BookmarkEditorController> default_controller_; | 154 BookmarkEditorController* default_controller_; |
149 const BookmarkNode* group_a_; | 155 const BookmarkNode* group_a_; |
150 const BookmarkNode* group_b_; | 156 const BookmarkNode* group_b_; |
151 const BookmarkNode* group_bb_; | 157 const BookmarkNode* group_bb_; |
152 const BookmarkNode* group_c_; | 158 const BookmarkNode* group_c_; |
153 const BookmarkNode* bookmark_bb_3_; | 159 const BookmarkNode* bookmark_bb_3_; |
154 | 160 |
155 BookmarkEditorControllerTreeTest() { | 161 BookmarkEditorControllerTreeTest() { |
156 // Set up a small bookmark hierarchy, which will look as follows: | 162 // Set up a small bookmark hierarchy, which will look as follows: |
157 // a b c d | 163 // a b c d |
158 // a-0 b-0 c-0 | 164 // a-0 b-0 c-0 |
(...skipping 23 matching lines...) Expand all Loading... |
182 model.AddURL(group_b_, 2, L"b-2", GURL("http://b-2.com")); | 188 model.AddURL(group_b_, 2, L"b-2", GURL("http://b-2.com")); |
183 model.AddURL(group_b_, 3, L"b-2", GURL("http://b-3.com")); | 189 model.AddURL(group_b_, 3, L"b-2", GURL("http://b-3.com")); |
184 | 190 |
185 group_c_ = model.AddGroup(root, 2, L"c"); | 191 group_c_ = model.AddGroup(root, 2, L"c"); |
186 model.AddURL(group_c_, 0, L"c-0", GURL("http://c-0.com")); | 192 model.AddURL(group_c_, 0, L"c-0", GURL("http://c-0.com")); |
187 model.AddURL(group_c_, 1, L"c-1", GURL("http://c-1.com")); | 193 model.AddURL(group_c_, 1, L"c-1", GURL("http://c-1.com")); |
188 model.AddURL(group_c_, 2, L"c-2", GURL("http://c-2.com")); | 194 model.AddURL(group_c_, 2, L"c-2", GURL("http://c-2.com")); |
189 model.AddURL(group_c_, 3, L"c-3", GURL("http://c-3.com")); | 195 model.AddURL(group_c_, 3, L"c-3", GURL("http://c-3.com")); |
190 | 196 |
191 model.AddURL(root, 3, L"d", GURL("http://d-0.com")); | 197 model.AddURL(root, 3, L"d", GURL("http://d-0.com")); |
| 198 } |
192 | 199 |
193 default_controller_.reset([[BookmarkEditorController alloc] | 200 virtual BookmarkEditorController* CreateController() { |
194 initWithParentWindow:cocoa_helper_.window() | 201 return [[BookmarkEditorController alloc] |
195 profile:helper_.profile() | 202 initWithParentWindow:test_window() |
196 parent:group_bb_ | 203 profile:helper_.profile() |
| 204 parent:group_bb_ |
197 node:bookmark_bb_3_ | 205 node:bookmark_bb_3_ |
198 configuration:BookmarkEditor::SHOW_TREE | 206 configuration:BookmarkEditor::SHOW_TREE |
199 handler:nil]); | 207 handler:nil]; |
200 [default_controller_ window]; // Forces a nib load | 208 } |
| 209 |
| 210 virtual void SetUp() { |
| 211 CocoaTest::SetUp(); |
| 212 default_controller_ = CreateController(); |
| 213 EXPECT_TRUE([default_controller_ window]); |
| 214 } |
| 215 |
| 216 virtual void TearDown() { |
| 217 [default_controller_ close]; |
| 218 CocoaTest::TearDown(); |
201 } | 219 } |
202 }; | 220 }; |
203 | 221 |
204 TEST_F(BookmarkEditorControllerTreeTest, VerifyBookmarkTestModel) { | 222 TEST_F(BookmarkEditorControllerTreeTest, VerifyBookmarkTestModel) { |
205 BookmarkModel& model(*(helper_.profile()->GetBookmarkModel())); | 223 BookmarkModel& model(*(helper_.profile()->GetBookmarkModel())); |
| 224 model.root_node(); |
206 const BookmarkNode& root(*model.GetBookmarkBarNode()); | 225 const BookmarkNode& root(*model.GetBookmarkBarNode()); |
207 EXPECT_EQ(4, root.GetChildCount()); | 226 EXPECT_EQ(4, root.GetChildCount()); |
208 const BookmarkNode* child = root.GetChild(0); | 227 const BookmarkNode* child = root.GetChild(0); |
209 EXPECT_EQ(3, child->GetChildCount()); | 228 EXPECT_EQ(3, child->GetChildCount()); |
210 const BookmarkNode* subchild = child->GetChild(0); | 229 const BookmarkNode* subchild = child->GetChild(0); |
211 EXPECT_EQ(0, subchild->GetChildCount()); | 230 EXPECT_EQ(0, subchild->GetChildCount()); |
212 subchild = child->GetChild(1); | 231 subchild = child->GetChild(1); |
213 EXPECT_EQ(0, subchild->GetChildCount()); | 232 EXPECT_EQ(0, subchild->GetChildCount()); |
214 subchild = child->GetChild(2); | 233 subchild = child->GetChild(2); |
215 EXPECT_EQ(0, subchild->GetChildCount()); | 234 EXPECT_EQ(0, subchild->GetChildCount()); |
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
294 [default_controller_ newFolder:nil]; | 313 [default_controller_ newFolder:nil]; |
295 [default_controller_ cancel:nil]; | 314 [default_controller_ cancel:nil]; |
296 EXPECT_EQ(6, group_bb_->GetChildCount()); | 315 EXPECT_EQ(6, group_bb_->GetChildCount()); |
297 const BookmarkNode* folderChild = group_bb_->GetChild(5); | 316 const BookmarkNode* folderChild = group_bb_->GetChild(5); |
298 EXPECT_EQ(folderChild->GetTitle(), L"New folder"); | 317 EXPECT_EQ(folderChild->GetTitle(), L"New folder"); |
299 } | 318 } |
300 | 319 |
301 class BookmarkEditorControllerTreeNoNodeTest : | 320 class BookmarkEditorControllerTreeNoNodeTest : |
302 public BookmarkEditorControllerTreeTest { | 321 public BookmarkEditorControllerTreeTest { |
303 public: | 322 public: |
304 BookmarkEditorControllerTreeNoNodeTest() { | 323 virtual BookmarkEditorController* CreateController() { |
305 // Reset the controller so that we have no |node|. | 324 return [[BookmarkEditorController alloc] |
306 default_controller_.reset([[BookmarkEditorController alloc] | 325 initWithParentWindow:test_window() |
307 initWithParentWindow:cocoa_helper_.window() | 326 profile:helper_.profile() |
308 profile:helper_.profile() | 327 parent:group_bb_ |
309 parent:group_bb_ | |
310 node:nil | 328 node:nil |
311 configuration:BookmarkEditor::SHOW_TREE | 329 configuration:BookmarkEditor::SHOW_TREE |
312 handler:nil]); | 330 handler:nil]; |
313 [default_controller_ window]; // Forces a nib load | |
314 } | 331 } |
| 332 |
315 }; | 333 }; |
316 | 334 |
317 TEST_F(BookmarkEditorControllerTreeNoNodeTest, NewBookmarkNoNode) { | 335 TEST_F(BookmarkEditorControllerTreeNoNodeTest, NewBookmarkNoNode) { |
318 [default_controller_ setDisplayName:@"NEW BOOKMARK"]; | 336 [default_controller_ setDisplayName:@"NEW BOOKMARK"]; |
319 [default_controller_ setDisplayURL:@"http://NEWURL.com"]; | 337 [default_controller_ setDisplayURL:@"http://NEWURL.com"]; |
320 [default_controller_ ok:nil]; | 338 [default_controller_ ok:nil]; |
321 const BookmarkNode* new_node = group_bb_->GetChild(5); | 339 const BookmarkNode* new_node = group_bb_->GetChild(5); |
322 ASSERT_EQ(0, new_node->GetChildCount()); | 340 ASSERT_EQ(0, new_node->GetChildCount()); |
323 EXPECT_EQ(new_node->GetTitle(), L"NEW BOOKMARK"); | 341 EXPECT_EQ(new_node->GetTitle(), L"NEW BOOKMARK"); |
324 EXPECT_EQ(new_node->GetURL(), GURL("http://NEWURL.com")); | 342 EXPECT_EQ(new_node->GetURL(), GURL("http://NEWURL.com")); |
325 } | 343 } |
326 | 344 |
327 class BookmarkEditorControllerTreeNoParentTest : | 345 class BookmarkEditorControllerTreeNoParentTest : |
328 public BookmarkEditorControllerTreeTest { | 346 public BookmarkEditorControllerTreeTest { |
329 public: | 347 public: |
330 BookmarkEditorControllerTreeNoParentTest() { | 348 virtual BookmarkEditorController* CreateController() { |
331 // Reset the controller so that we have no |node|. | 349 return [[BookmarkEditorController alloc] |
332 default_controller_.reset([[BookmarkEditorController alloc] | 350 initWithParentWindow:test_window() |
333 initWithParentWindow:cocoa_helper_.window() | 351 profile:helper_.profile() |
334 profile:helper_.profile() | 352 parent:nil |
335 parent:nil | 353 node:nil |
336 node:nil | 354 configuration:BookmarkEditor::SHOW_TREE |
337 configuration:BookmarkEditor::SHOW_TREE | 355 handler:nil]; |
338 handler:nil]); | 356 } |
339 [default_controller_ window]; // Forces a nib load | |
340 } | |
341 }; | 357 }; |
342 | 358 |
343 TEST_F(BookmarkEditorControllerTreeNoParentTest, AddFolderWithNoGroupSelected) { | 359 TEST_F(BookmarkEditorControllerTreeNoParentTest, AddFolderWithNoGroupSelected) { |
344 [default_controller_ newFolder:nil]; | 360 [default_controller_ newFolder:nil]; |
345 [default_controller_ cancel:nil]; | 361 [default_controller_ cancel:nil]; |
346 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); | 362 BookmarkModel* model = helper_.profile()->GetBookmarkModel(); |
347 const BookmarkNode* bookmarkBar = model->GetBookmarkBarNode(); | 363 const BookmarkNode* bookmarkBar = model->GetBookmarkBarNode(); |
348 EXPECT_EQ(5, bookmarkBar->GetChildCount()); | 364 EXPECT_EQ(5, bookmarkBar->GetChildCount()); |
349 const BookmarkNode* folderChild = bookmarkBar->GetChild(4); | 365 const BookmarkNode* folderChild = bookmarkBar->GetChild(4); |
350 EXPECT_EQ(folderChild->GetTitle(), L"New folder"); | 366 EXPECT_EQ(folderChild->GetTitle(), L"New folder"); |
351 } | 367 } |
352 | 368 |
OLD | NEW |