OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "mojo/services/view_manager/public/cpp/view_manager.h" | 5 #include "mojo/services/view_manager/public/cpp/view_manager.h" |
6 | 6 |
7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "mojo/application_manager/application_manager.h" | 10 #include "mojo/application_manager/application_manager.h" |
(...skipping 255 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
266 ViewManagerTest() | 266 ViewManagerTest() |
267 : connect_loop_(NULL), | 267 : connect_loop_(NULL), |
268 loaded_view_manager_(NULL), | 268 loaded_view_manager_(NULL), |
269 window_manager_(NULL), | 269 window_manager_(NULL), |
270 commit_count_(0) {} | 270 commit_count_(0) {} |
271 | 271 |
272 protected: | 272 protected: |
273 ViewManager* window_manager() { return window_manager_; } | 273 ViewManager* window_manager() { return window_manager_; } |
274 | 274 |
275 View* CreateViewInParent(View* parent) { | 275 View* CreateViewInParent(View* parent) { |
276 ViewManager* parent_manager = ViewPrivate(parent).view_manager(); | 276 ViewManager* parent_manager = parent->view_manager(); |
277 View* view = View::Create(parent_manager); | 277 View* view = parent_manager->CreateView(); |
278 view->SetVisible(true); | 278 view->SetVisible(true); |
279 parent->AddChild(view); | 279 parent->AddChild(view); |
280 return view; | 280 return view; |
281 } | 281 } |
282 | 282 |
283 // Embeds another version of the test app @ view. | 283 // Embeds another version of the test app @ view. |
284 ViewManager* Embed(ViewManager* view_manager, View* view) { | 284 ViewManager* Embed(ViewManager* view_manager, View* view) { |
285 DCHECK_EQ(view_manager, ViewPrivate(view).view_manager()); | 285 DCHECK_EQ(view_manager, view->view_manager()); |
286 view->Embed(kEmbeddedApp1URL); | 286 view->Embed(kEmbeddedApp1URL); |
287 RunRunLoop(); | 287 RunRunLoop(); |
288 return GetLoadedViewManager(); | 288 return GetLoadedViewManager(); |
289 } | 289 } |
290 | 290 |
291 ViewManager* GetLoadedViewManager() { | 291 ViewManager* GetLoadedViewManager() { |
292 ViewManager* view_manager = loaded_view_manager_; | 292 ViewManager* view_manager = loaded_view_manager_; |
293 loaded_view_manager_ = NULL; | 293 loaded_view_manager_ = NULL; |
294 return view_manager; | 294 return view_manager; |
295 } | 295 } |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
339 | 339 |
340 DISALLOW_COPY_AND_ASSIGN(ViewManagerTest); | 340 DISALLOW_COPY_AND_ASSIGN(ViewManagerTest); |
341 }; | 341 }; |
342 | 342 |
343 // TODO(sky): all of these tests are disabled as each test triggers running | 343 // TODO(sky): all of these tests are disabled as each test triggers running |
344 // ViewsInit, which tries to register the same set of paths with the | 344 // ViewsInit, which tries to register the same set of paths with the |
345 // PathService, triggering a DCHECK. | 345 // PathService, triggering a DCHECK. |
346 TEST_F(ViewManagerTest, DISABLED_SetUp) {} | 346 TEST_F(ViewManagerTest, DISABLED_SetUp) {} |
347 | 347 |
348 TEST_F(ViewManagerTest, DISABLED_Embed) { | 348 TEST_F(ViewManagerTest, DISABLED_Embed) { |
349 View* view = View::Create(window_manager()); | 349 View* view = window_manager()->CreateView(); |
350 view->SetVisible(true); | 350 view->SetVisible(true); |
351 window_manager()->GetRoot()->AddChild(view); | 351 window_manager()->GetRoot()->AddChild(view); |
352 ViewManager* embedded = Embed(window_manager(), view); | 352 ViewManager* embedded = Embed(window_manager(), view); |
353 EXPECT_TRUE(NULL != embedded); | 353 EXPECT_TRUE(NULL != embedded); |
354 | 354 |
355 View* view_in_embedded = embedded->GetRoot(); | 355 View* view_in_embedded = embedded->GetRoot(); |
356 EXPECT_EQ(view->parent(), window_manager()->GetRoot()); | 356 EXPECT_EQ(view->parent(), window_manager()->GetRoot()); |
357 EXPECT_EQ(NULL, view_in_embedded->parent()); | 357 EXPECT_EQ(NULL, view_in_embedded->parent()); |
358 } | 358 } |
359 | 359 |
360 // Window manager has two views, N1 and N11. Embeds A at N1. A should not see | 360 // Window manager has two views, N1 and N11. Embeds A at N1. A should not see |
361 // N11. | 361 // N11. |
362 // TODO(sky): Update client lib to match server. | 362 // TODO(sky): Update client lib to match server. |
363 TEST_F(ViewManagerTest, DISABLED_EmbeddedDoesntSeeChild) { | 363 TEST_F(ViewManagerTest, DISABLED_EmbeddedDoesntSeeChild) { |
364 View* view = View::Create(window_manager()); | 364 View* view = window_manager()->CreateView(); |
365 view->SetVisible(true); | 365 view->SetVisible(true); |
366 window_manager()->GetRoot()->AddChild(view); | 366 window_manager()->GetRoot()->AddChild(view); |
367 View* nested = View::Create(window_manager()); | 367 View* nested = window_manager()->CreateView(); |
368 nested->SetVisible(true); | 368 nested->SetVisible(true); |
369 view->AddChild(nested); | 369 view->AddChild(nested); |
370 | 370 |
371 ViewManager* embedded = Embed(window_manager(), view); | 371 ViewManager* embedded = Embed(window_manager(), view); |
372 EXPECT_EQ(embedded->GetRoot()->children().front()->id(), | 372 EXPECT_EQ(embedded->GetRoot()->children().front()->id(), |
373 nested->id()); | 373 nested->id()); |
374 EXPECT_TRUE(embedded->GetRoot()->children().empty()); | 374 EXPECT_TRUE(embedded->GetRoot()->children().empty()); |
375 EXPECT_TRUE(nested->parent() == NULL); | 375 EXPECT_TRUE(nested->parent() == NULL); |
376 } | 376 } |
377 | 377 |
378 // http://crbug.com/396300 | 378 // http://crbug.com/396300 |
379 TEST_F(ViewManagerTest, DISABLED_ViewManagerDestroyed_CleanupView) { | 379 TEST_F(ViewManagerTest, DISABLED_ViewManagerDestroyed_CleanupView) { |
380 View* view = View::Create(window_manager()); | 380 View* view = window_manager()->CreateView(); |
381 view->SetVisible(true); | 381 view->SetVisible(true); |
382 window_manager()->GetRoot()->AddChild(view); | 382 window_manager()->GetRoot()->AddChild(view); |
383 ViewManager* embedded = Embed(window_manager(), view); | 383 ViewManager* embedded = Embed(window_manager(), view); |
384 | 384 |
385 Id view_id = view->id(); | 385 Id view_id = view->id(); |
386 | 386 |
387 UnloadApplication(GURL(kWindowManagerURL)); | 387 UnloadApplication(GURL(kWindowManagerURL)); |
388 | 388 |
389 std::set<Id> views; | 389 std::set<Id> views; |
390 views.insert(view_id); | 390 views.insert(view_id); |
(...skipping 10 matching lines...) Expand all Loading... |
401 // -> the view should still exist (since the second connection is live) but | 401 // -> the view should still exist (since the second connection is live) but |
402 // should be disconnected from any views. | 402 // should be disconnected from any views. |
403 // http://crbug.com/396300 | 403 // http://crbug.com/396300 |
404 // | 404 // |
405 // TODO(beng): The new test should validate the scenario as described above | 405 // TODO(beng): The new test should validate the scenario as described above |
406 // except that the second connection still has a valid tree. | 406 // except that the second connection still has a valid tree. |
407 | 407 |
408 // Verifies that bounds changes applied to a view hierarchy in one connection | 408 // Verifies that bounds changes applied to a view hierarchy in one connection |
409 // are reflected to another. | 409 // are reflected to another. |
410 TEST_F(ViewManagerTest, DISABLED_SetBounds) { | 410 TEST_F(ViewManagerTest, DISABLED_SetBounds) { |
411 View* view = View::Create(window_manager()); | 411 View* view = window_manager()->CreateView(); |
412 view->SetVisible(true); | 412 view->SetVisible(true); |
413 window_manager()->GetRoot()->AddChild(view); | 413 window_manager()->GetRoot()->AddChild(view); |
414 ViewManager* embedded = Embed(window_manager(), view); | 414 ViewManager* embedded = Embed(window_manager(), view); |
415 | 415 |
416 View* view_in_embedded = embedded->GetViewById(view->id()); | 416 View* view_in_embedded = embedded->GetViewById(view->id()); |
417 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); | 417 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); |
418 | 418 |
419 Rect rect; | 419 Rect rect; |
420 rect.width = rect.height = 100; | 420 rect.width = rect.height = 100; |
421 view->SetBounds(rect); | 421 view->SetBounds(rect); |
422 EXPECT_NE(view->bounds(), view_in_embedded->bounds()); | 422 EXPECT_NE(view->bounds(), view_in_embedded->bounds()); |
423 WaitForBoundsToChange(view_in_embedded); | 423 WaitForBoundsToChange(view_in_embedded); |
424 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); | 424 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); |
425 } | 425 } |
426 | 426 |
427 // Verifies that bounds changes applied to a view owned by a different | 427 // Verifies that bounds changes applied to a view owned by a different |
428 // connection are refused. | 428 // connection are refused. |
429 TEST_F(ViewManagerTest, DISABLED_SetBoundsSecurity) { | 429 TEST_F(ViewManagerTest, DISABLED_SetBoundsSecurity) { |
430 View* view = View::Create(window_manager()); | 430 View* view = window_manager()->CreateView(); |
431 view->SetVisible(true); | 431 view->SetVisible(true); |
432 window_manager()->GetRoot()->AddChild(view); | 432 window_manager()->GetRoot()->AddChild(view); |
433 ViewManager* embedded = Embed(window_manager(), view); | 433 ViewManager* embedded = Embed(window_manager(), view); |
434 | 434 |
435 View* view_in_embedded = embedded->GetViewById(view->id()); | 435 View* view_in_embedded = embedded->GetViewById(view->id()); |
436 Rect rect; | 436 Rect rect; |
437 rect.width = 800; | 437 rect.width = 800; |
438 rect.height = 600; | 438 rect.height = 600; |
439 view->SetBounds(rect); | 439 view->SetBounds(rect); |
440 WaitForBoundsToChange(view_in_embedded); | 440 WaitForBoundsToChange(view_in_embedded); |
441 | 441 |
442 rect.width = 1024; | 442 rect.width = 1024; |
443 rect.height = 768; | 443 rect.height = 768; |
444 view_in_embedded->SetBounds(rect); | 444 view_in_embedded->SetBounds(rect); |
445 // Bounds change should have been rejected. | 445 // Bounds change should have been rejected. |
446 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); | 446 EXPECT_EQ(view->bounds(), view_in_embedded->bounds()); |
447 } | 447 } |
448 | 448 |
449 // Verifies that a view can only be destroyed by the connection that created it. | 449 // Verifies that a view can only be destroyed by the connection that created it. |
450 TEST_F(ViewManagerTest, DISABLED_DestroySecurity) { | 450 TEST_F(ViewManagerTest, DISABLED_DestroySecurity) { |
451 View* view = View::Create(window_manager()); | 451 View* view = window_manager()->CreateView(); |
452 view->SetVisible(true); | 452 view->SetVisible(true); |
453 window_manager()->GetRoot()->AddChild(view); | 453 window_manager()->GetRoot()->AddChild(view); |
454 ViewManager* embedded = Embed(window_manager(), view); | 454 ViewManager* embedded = Embed(window_manager(), view); |
455 | 455 |
456 View* view_in_embedded = embedded->GetViewById(view->id()); | 456 View* view_in_embedded = embedded->GetViewById(view->id()); |
457 | 457 |
458 ViewTracker tracker2(view_in_embedded); | 458 ViewTracker tracker2(view_in_embedded); |
459 view_in_embedded->Destroy(); | 459 view_in_embedded->Destroy(); |
460 // View should not have been destroyed. | 460 // View should not have been destroyed. |
461 EXPECT_TRUE(tracker2.is_valid()); | 461 EXPECT_TRUE(tracker2.is_valid()); |
462 | 462 |
463 ViewTracker tracker1(view); | 463 ViewTracker tracker1(view); |
464 view->Destroy(); | 464 view->Destroy(); |
465 EXPECT_FALSE(tracker1.is_valid()); | 465 EXPECT_FALSE(tracker1.is_valid()); |
466 } | 466 } |
467 | 467 |
468 TEST_F(ViewManagerTest, DISABLED_MultiRoots) { | 468 TEST_F(ViewManagerTest, DISABLED_MultiRoots) { |
469 View* view1 = View::Create(window_manager()); | 469 View* view1 = window_manager()->CreateView(); |
470 view1->SetVisible(true); | 470 view1->SetVisible(true); |
471 window_manager()->GetRoot()->AddChild(view1); | 471 window_manager()->GetRoot()->AddChild(view1); |
472 View* view2 = View::Create(window_manager()); | 472 View* view2 = window_manager()->CreateView(); |
473 view2->SetVisible(true); | 473 view2->SetVisible(true); |
474 window_manager()->GetRoot()->AddChild(view2); | 474 window_manager()->GetRoot()->AddChild(view2); |
475 ViewManager* embedded1 = Embed(window_manager(), view1); | 475 ViewManager* embedded1 = Embed(window_manager(), view1); |
476 ViewManager* embedded2 = Embed(window_manager(), view2); | 476 ViewManager* embedded2 = Embed(window_manager(), view2); |
477 EXPECT_EQ(embedded1, embedded2); | 477 EXPECT_EQ(embedded1, embedded2); |
478 } | 478 } |
479 | 479 |
480 TEST_F(ViewManagerTest, DISABLED_EmbeddingIdentity) { | 480 TEST_F(ViewManagerTest, DISABLED_EmbeddingIdentity) { |
481 View* view = View::Create(window_manager()); | 481 View* view = window_manager()->CreateView(); |
482 view->SetVisible(true); | 482 view->SetVisible(true); |
483 window_manager()->GetRoot()->AddChild(view); | 483 window_manager()->GetRoot()->AddChild(view); |
484 ViewManager* embedded = Embed(window_manager(), view); | 484 ViewManager* embedded = Embed(window_manager(), view); |
485 EXPECT_EQ(kWindowManagerURL, embedded->GetEmbedderURL()); | 485 EXPECT_EQ(kWindowManagerURL, embedded->GetEmbedderURL()); |
486 } | 486 } |
487 | 487 |
488 TEST_F(ViewManagerTest, DISABLED_Reorder) { | 488 TEST_F(ViewManagerTest, DISABLED_Reorder) { |
489 View* view1 = View::Create(window_manager()); | 489 View* view1 = window_manager()->CreateView(); |
490 view1->SetVisible(true); | 490 view1->SetVisible(true); |
491 window_manager()->GetRoot()->AddChild(view1); | 491 window_manager()->GetRoot()->AddChild(view1); |
492 | 492 |
493 ViewManager* embedded = Embed(window_manager(), view1); | 493 ViewManager* embedded = Embed(window_manager(), view1); |
494 | 494 |
495 View* view11 = View::Create(embedded); | 495 View* view11 = embedded->CreateView(); |
496 view11->SetVisible(true); | 496 view11->SetVisible(true); |
497 embedded->GetRoot()->AddChild(view11); | 497 embedded->GetRoot()->AddChild(view11); |
498 View* view12 = View::Create(embedded); | 498 View* view12 = embedded->CreateView(); |
499 view12->SetVisible(true); | 499 view12->SetVisible(true); |
500 embedded->GetRoot()->AddChild(view12); | 500 embedded->GetRoot()->AddChild(view12); |
501 | 501 |
502 View* view1_in_wm = window_manager()->GetViewById(view1->id()); | 502 View* view1_in_wm = window_manager()->GetViewById(view1->id()); |
503 | 503 |
504 { | 504 { |
505 WaitForTreeSizeToMatch(view1, 2u); | 505 WaitForTreeSizeToMatch(view1, 2u); |
506 view11->MoveToFront(); | 506 view11->MoveToFront(); |
507 WaitForOrderChange(window_manager(), | 507 WaitForOrderChange(window_manager(), |
508 window_manager()->GetViewById(view11->id())); | 508 window_manager()->GetViewById(view11->id())); |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
542 } | 542 } |
543 | 543 |
544 View* view_; | 544 View* view_; |
545 | 545 |
546 DISALLOW_COPY_AND_ASSIGN(VisibilityChangeObserver); | 546 DISALLOW_COPY_AND_ASSIGN(VisibilityChangeObserver); |
547 }; | 547 }; |
548 | 548 |
549 } // namespace | 549 } // namespace |
550 | 550 |
551 TEST_F(ViewManagerTest, DISABLED_Visible) { | 551 TEST_F(ViewManagerTest, DISABLED_Visible) { |
552 View* view1 = View::Create(window_manager()); | 552 View* view1 = window_manager()->CreateView(); |
553 view1->SetVisible(true); | 553 view1->SetVisible(true); |
554 window_manager()->GetRoot()->AddChild(view1); | 554 window_manager()->GetRoot()->AddChild(view1); |
555 | 555 |
556 // Embed another app and verify initial state. | 556 // Embed another app and verify initial state. |
557 ViewManager* embedded = Embed(window_manager(), view1); | 557 ViewManager* embedded = Embed(window_manager(), view1); |
558 ASSERT_NE(nullptr, embedded->GetRoot()); | 558 ASSERT_NE(nullptr, embedded->GetRoot()); |
559 View* embedded_root = embedded->GetRoot(); | 559 View* embedded_root = embedded->GetRoot(); |
560 EXPECT_TRUE(embedded_root->visible()); | 560 EXPECT_TRUE(embedded_root->visible()); |
561 EXPECT_TRUE(embedded_root->IsDrawn()); | 561 EXPECT_TRUE(embedded_root->IsDrawn()); |
562 | 562 |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
605 } | 605 } |
606 | 606 |
607 View* view_; | 607 View* view_; |
608 | 608 |
609 DISALLOW_COPY_AND_ASSIGN(DrawnChangeObserver); | 609 DISALLOW_COPY_AND_ASSIGN(DrawnChangeObserver); |
610 }; | 610 }; |
611 | 611 |
612 } // namespace | 612 } // namespace |
613 | 613 |
614 TEST_F(ViewManagerTest, DISABLED_Drawn) { | 614 TEST_F(ViewManagerTest, DISABLED_Drawn) { |
615 View* view1 = View::Create(window_manager()); | 615 View* view1 = window_manager()->CreateView(); |
616 view1->SetVisible(true); | 616 view1->SetVisible(true); |
617 window_manager()->GetRoot()->AddChild(view1); | 617 window_manager()->GetRoot()->AddChild(view1); |
618 | 618 |
619 // Embed another app and verify initial state. | 619 // Embed another app and verify initial state. |
620 ViewManager* embedded = Embed(window_manager(), view1); | 620 ViewManager* embedded = Embed(window_manager(), view1); |
621 ASSERT_NE(nullptr, embedded->GetRoot()); | 621 ASSERT_NE(nullptr, embedded->GetRoot()); |
622 View* embedded_root = embedded->GetRoot(); | 622 View* embedded_root = embedded->GetRoot(); |
623 EXPECT_TRUE(embedded_root->visible()); | 623 EXPECT_TRUE(embedded_root->visible()); |
624 EXPECT_TRUE(embedded_root->IsDrawn()); | 624 EXPECT_TRUE(embedded_root->IsDrawn()); |
625 | 625 |
(...skipping 17 matching lines...) Expand all Loading... |
643 | 643 |
644 // TODO(beng): tests for focus: | 644 // TODO(beng): tests for focus: |
645 // - focus between two views known to a connection | 645 // - focus between two views known to a connection |
646 // - focus between views unknown to one of the connections. | 646 // - focus between views unknown to one of the connections. |
647 // - focus between views unknown to either connection. | 647 // - focus between views unknown to either connection. |
648 | 648 |
649 // TODO(sky): need test of root being destroyed with existing views. See | 649 // TODO(sky): need test of root being destroyed with existing views. See |
650 // 434555 for specific case. | 650 // 434555 for specific case. |
651 | 651 |
652 } // namespace mojo | 652 } // namespace mojo |
OLD | NEW |