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 "cc/quads/list_container.h" | 5 #include "cc/quads/list_container.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 #include "cc/quads/draw_quad.h" | 8 #include "cc/quads/draw_quad.h" |
9 #include "cc/quads/largest_draw_quad.h" | 9 #include "cc/quads/largest_draw_quad.h" |
10 #include "cc/quads/render_pass_draw_quad.h" | 10 #include "cc/quads/render_pass_draw_quad.h" |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
57 class MockDrawQuad : public DrawQuad { | 57 class MockDrawQuad : public DrawQuad { |
58 public: | 58 public: |
59 virtual ~MockDrawQuad() { Destruct(); } | 59 virtual ~MockDrawQuad() { Destruct(); } |
60 virtual void IterateResources( | 60 virtual void IterateResources( |
61 const ResourceIteratorCallback& callback) override {} | 61 const ResourceIteratorCallback& callback) override {} |
62 virtual void ExtendValue(base::debug::TracedValue* value) const override {} | 62 virtual void ExtendValue(base::debug::TracedValue* value) const override {} |
63 MOCK_METHOD0(Destruct, void()); | 63 MOCK_METHOD0(Destruct, void()); |
64 }; | 64 }; |
65 | 65 |
66 TEST(ListContainerTest, ConstructorCalledInAllocateAndConstruct) { | 66 TEST(ListContainerTest, ConstructorCalledInAllocateAndConstruct) { |
67 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 67 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
68 | 68 |
69 size_t size = 2; | 69 size_t size = 2; |
70 SimpleDrawQuadConstructMagicNumberOne* dq_1 = | 70 SimpleDrawQuadConstructMagicNumberOne* dq_1 = |
71 list.AllocateAndConstruct<SimpleDrawQuadConstructMagicNumberOne>(); | 71 list.AllocateAndConstruct<SimpleDrawQuadConstructMagicNumberOne>(); |
72 SimpleDrawQuadConstructMagicNumberTwo* dq_2 = | 72 SimpleDrawQuadConstructMagicNumberTwo* dq_2 = |
73 list.AllocateAndConstruct<SimpleDrawQuadConstructMagicNumberTwo>(); | 73 list.AllocateAndConstruct<SimpleDrawQuadConstructMagicNumberTwo>(); |
74 | 74 |
75 EXPECT_EQ(size, list.size()); | 75 EXPECT_EQ(size, list.size()); |
76 EXPECT_EQ(dq_1, list.front()); | 76 EXPECT_EQ(dq_1, list.front()); |
77 EXPECT_EQ(dq_2, list.back()); | 77 EXPECT_EQ(dq_2, list.back()); |
78 | 78 |
79 EXPECT_EQ(kMagicNumberToUseForDrawQuadOne, dq_1->get_value()); | 79 EXPECT_EQ(kMagicNumberToUseForDrawQuadOne, dq_1->get_value()); |
80 EXPECT_EQ(kMagicNumberToUseForDrawQuadTwo, dq_2->get_value()); | 80 EXPECT_EQ(kMagicNumberToUseForDrawQuadTwo, dq_2->get_value()); |
81 } | 81 } |
82 | 82 |
83 TEST(ListContainerTest, DestructorCalled) { | 83 TEST(ListContainerTest, DestructorCalled) { |
84 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 84 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
85 | 85 |
86 size_t size = 1; | 86 size_t size = 1; |
87 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); | 87 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); |
88 | 88 |
89 EXPECT_CALL(*dq_1, Destruct()); | 89 EXPECT_CALL(*dq_1, Destruct()); |
90 EXPECT_EQ(size, list.size()); | 90 EXPECT_EQ(size, list.size()); |
91 EXPECT_EQ(dq_1, list.front()); | 91 EXPECT_EQ(dq_1, list.front()); |
92 } | 92 } |
93 | 93 |
94 TEST(ListContainerTest, DestructorCalledOnceWhenClear) { | 94 TEST(ListContainerTest, DestructorCalledOnceWhenClear) { |
95 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 95 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
96 size_t size = 1; | 96 size_t size = 1; |
97 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); | 97 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); |
98 | 98 |
99 EXPECT_EQ(size, list.size()); | 99 EXPECT_EQ(size, list.size()); |
100 EXPECT_EQ(dq_1, list.front()); | 100 EXPECT_EQ(dq_1, list.front()); |
101 | 101 |
102 // Make sure destructor is called once during clear, and won't be called | 102 // Make sure destructor is called once during clear, and won't be called |
103 // again. | 103 // again. |
104 testing::MockFunction<void()> separator; | 104 testing::MockFunction<void()> separator; |
105 { | 105 { |
106 testing::InSequence s; | 106 testing::InSequence s; |
107 EXPECT_CALL(*dq_1, Destruct()); | 107 EXPECT_CALL(*dq_1, Destruct()); |
108 EXPECT_CALL(separator, Call()); | 108 EXPECT_CALL(separator, Call()); |
109 EXPECT_CALL(*dq_1, Destruct()).Times(0); | 109 EXPECT_CALL(*dq_1, Destruct()).Times(0); |
110 } | 110 } |
111 | 111 |
112 list.clear(); | 112 list.clear(); |
113 separator.Call(); | 113 separator.Call(); |
114 } | 114 } |
115 | 115 |
116 TEST(ListContainerTest, DestructorCalledOnceWhenErase) { | 116 TEST(ListContainerTest, DestructorCalledOnceWhenErase) { |
117 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 117 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
118 size_t size = 1; | 118 size_t size = 1; |
119 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); | 119 MockDrawQuad* dq_1 = list.AllocateAndConstruct<MockDrawQuad>(); |
120 | 120 |
121 EXPECT_EQ(size, list.size()); | 121 EXPECT_EQ(size, list.size()); |
122 EXPECT_EQ(dq_1, list.front()); | 122 EXPECT_EQ(dq_1, list.front()); |
123 | 123 |
124 // Make sure destructor is called once during clear, and won't be called | 124 // Make sure destructor is called once during clear, and won't be called |
125 // again. | 125 // again. |
126 testing::MockFunction<void()> separator; | 126 testing::MockFunction<void()> separator; |
127 { | 127 { |
(...skipping 300 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
428 sqs_list.rbegin(); | 428 sqs_list.rbegin(); |
429 sqs_iter != sqs_list.rend(); | 429 sqs_iter != sqs_list.rend(); |
430 ++sqs_iter) { | 430 ++sqs_iter) { |
431 EXPECT_EQ(*sqs_iter, *iter); | 431 EXPECT_EQ(*sqs_iter, *iter); |
432 ++iter; | 432 ++iter; |
433 } | 433 } |
434 } | 434 } |
435 } | 435 } |
436 | 436 |
437 TEST(ListContainerTest, SimpleDeletion) { | 437 TEST(ListContainerTest, SimpleDeletion) { |
438 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 438 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
439 std::vector<SimpleDrawQuad*> sdq_list; | 439 std::vector<SimpleDrawQuad*> sdq_list; |
440 size_t size = 10; | 440 size_t size = 10; |
441 for (size_t i = 0; i < size; ++i) { | 441 for (size_t i = 0; i < size; ++i) { |
442 sdq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); | 442 sdq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); |
443 sdq_list.back()->set_value(i); | 443 sdq_list.back()->set_value(i); |
444 } | 444 } |
445 EXPECT_EQ(size, list.size()); | 445 EXPECT_EQ(size, list.size()); |
446 | 446 |
447 list.EraseAndInvalidateAllPointers(list.begin()); | 447 list.EraseAndInvalidateAllPointers(list.begin()); |
448 --size; | 448 --size; |
449 EXPECT_EQ(size, list.size()); | 449 EXPECT_EQ(size, list.size()); |
450 int i = 1; | 450 int i = 1; |
451 for (ListContainer<DrawQuad>::Iterator iter = list.begin(); | 451 for (ListContainer<DrawQuad>::Iterator iter = list.begin(); |
452 iter != list.end(); | 452 iter != list.end(); |
453 ++iter) { | 453 ++iter) { |
454 EXPECT_EQ(i, static_cast<SimpleDrawQuad*>(*iter)->get_value()); | 454 EXPECT_EQ(i, static_cast<SimpleDrawQuad*>(*iter)->get_value()); |
455 ++i; | 455 ++i; |
456 } | 456 } |
457 } | 457 } |
458 | 458 |
459 TEST(ListContainerTest, SimpleIterationAndManipulation) { | 459 TEST(ListContainerTest, SimpleIterationAndManipulation) { |
460 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 460 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
461 std::vector<SimpleDrawQuad*> sdq_list; | 461 std::vector<SimpleDrawQuad*> sdq_list; |
462 size_t size = 10; | 462 size_t size = 10; |
463 for (size_t i = 0; i < size; ++i) { | 463 for (size_t i = 0; i < size; ++i) { |
464 SimpleDrawQuad* simple_dq = list.AllocateAndConstruct<SimpleDrawQuad>(); | 464 SimpleDrawQuad* simple_dq = list.AllocateAndConstruct<SimpleDrawQuad>(); |
465 sdq_list.push_back(simple_dq); | 465 sdq_list.push_back(simple_dq); |
466 } | 466 } |
467 EXPECT_EQ(size, list.size()); | 467 EXPECT_EQ(size, list.size()); |
468 | 468 |
469 ListContainer<DrawQuad>::Iterator iter = list.begin(); | 469 ListContainer<DrawQuad>::Iterator iter = list.begin(); |
470 for (int i = 0; i < 10; ++i) { | 470 for (int i = 0; i < 10; ++i) { |
471 static_cast<SimpleDrawQuad*>(*iter)->set_value(i); | 471 static_cast<SimpleDrawQuad*>(*iter)->set_value(i); |
472 ++iter; | 472 ++iter; |
473 } | 473 } |
474 | 474 |
475 int i = 0; | 475 int i = 0; |
476 for (std::vector<SimpleDrawQuad*>::const_iterator sdq_iter = sdq_list.begin(); | 476 for (std::vector<SimpleDrawQuad*>::const_iterator sdq_iter = sdq_list.begin(); |
477 sdq_iter < sdq_list.end(); | 477 sdq_iter < sdq_list.end(); |
478 ++sdq_iter) { | 478 ++sdq_iter) { |
479 EXPECT_EQ(i, (*sdq_iter)->get_value()); | 479 EXPECT_EQ(i, (*sdq_iter)->get_value()); |
480 ++i; | 480 ++i; |
481 } | 481 } |
482 } | 482 } |
483 | 483 |
484 TEST(ListContainerTest, SimpleManipulationWithIndexSimpleDrawQuad) { | 484 TEST(ListContainerTest, SimpleManipulationWithIndexSimpleDrawQuad) { |
485 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad)); | 485 ListContainer<DrawQuad> list(LargestDrawQuadSize()); |
486 std::vector<SimpleDrawQuad*> dq_list; | 486 std::vector<SimpleDrawQuad*> dq_list; |
487 size_t size = 10; | 487 size_t size = 10; |
488 for (size_t i = 0; i < size; ++i) { | 488 for (size_t i = 0; i < size; ++i) { |
489 dq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); | 489 dq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); |
490 } | 490 } |
491 EXPECT_EQ(size, list.size()); | 491 EXPECT_EQ(size, list.size()); |
492 | 492 |
493 for (size_t i = 0; i < size; ++i) { | 493 for (size_t i = 0; i < size; ++i) { |
494 static_cast<SimpleDrawQuad*>(list.ElementAt(i))->set_value(i); | 494 static_cast<SimpleDrawQuad*>(list.ElementAt(i))->set_value(i); |
495 } | 495 } |
496 | 496 |
497 int i = 0; | 497 int i = 0; |
498 for (std::vector<SimpleDrawQuad*>::const_iterator dq_iter = dq_list.begin(); | 498 for (std::vector<SimpleDrawQuad*>::const_iterator dq_iter = dq_list.begin(); |
499 dq_iter != dq_list.end(); | 499 dq_iter != dq_list.end(); |
500 ++dq_iter, ++i) { | 500 ++dq_iter, ++i) { |
501 EXPECT_EQ(i, (*dq_iter)->get_value()); | 501 EXPECT_EQ(i, (*dq_iter)->get_value()); |
502 } | 502 } |
503 } | 503 } |
504 | 504 |
505 TEST(ListContainerTest, | 505 TEST(ListContainerTest, |
506 SimpleManipulationWithIndexMoreThanOneAllocationSimpleDrawQuad) { | 506 SimpleManipulationWithIndexMoreThanOneAllocationSimpleDrawQuad) { |
507 ListContainer<DrawQuad> list(sizeof(kLargestDrawQuad), 2); | 507 ListContainer<DrawQuad> list(LargestDrawQuadSize(), 2); |
508 std::vector<SimpleDrawQuad*> dq_list; | 508 std::vector<SimpleDrawQuad*> dq_list; |
509 size_t size = 10; | 509 size_t size = 10; |
510 for (size_t i = 0; i < size; ++i) { | 510 for (size_t i = 0; i < size; ++i) { |
511 dq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); | 511 dq_list.push_back(list.AllocateAndConstruct<SimpleDrawQuad>()); |
512 } | 512 } |
513 EXPECT_EQ(size, list.size()); | 513 EXPECT_EQ(size, list.size()); |
514 | 514 |
515 for (size_t i = 0; i < size; ++i) { | 515 for (size_t i = 0; i < size; ++i) { |
516 static_cast<SimpleDrawQuad*>(list.ElementAt(i))->set_value(i); | 516 static_cast<SimpleDrawQuad*>(list.ElementAt(i))->set_value(i); |
517 } | 517 } |
(...skipping 28 matching lines...) Expand all Loading... |
546 for (ListContainer<SharedQuadState>::ReverseIterator iter = list.rbegin(); | 546 for (ListContainer<SharedQuadState>::ReverseIterator iter = list.rbegin(); |
547 iter != list.rend(); | 547 iter != list.rend(); |
548 ++iter) { | 548 ++iter) { |
549 EXPECT_EQ(i, iter.index()); | 549 EXPECT_EQ(i, iter.index()); |
550 ++i; | 550 ++i; |
551 } | 551 } |
552 } | 552 } |
553 | 553 |
554 } // namespace | 554 } // namespace |
555 } // namespace cc | 555 } // namespace cc |
OLD | NEW |