OLD | NEW |
---|---|
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/resources/resource_provider.h" | 5 #include "cc/resources/resource_provider.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <map> | 8 #include <map> |
9 #include <set> | 9 #include <set> |
10 | 10 |
(...skipping 1027 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1038 id1); | 1038 id1); |
1039 child_resource_provider_->DeleteResource(id1); | 1039 child_resource_provider_->DeleteResource(id1); |
1040 EXPECT_EQ(1u, child_resource_provider_->num_resources()); | 1040 EXPECT_EQ(1u, child_resource_provider_->num_resources()); |
1041 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | 1041 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); |
1042 } | 1042 } |
1043 | 1043 |
1044 EXPECT_EQ(0u, child_resource_provider_->num_resources()); | 1044 EXPECT_EQ(0u, child_resource_provider_->num_resources()); |
1045 resource_provider_->DestroyChild(child_id); | 1045 resource_provider_->DestroyChild(child_id); |
1046 } | 1046 } |
1047 | 1047 |
1048 TEST_P(ResourceProviderTest, ReadLockFenceStopsReturnToChildOrDelete) { | |
1049 if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) | |
1050 return; | |
1051 gfx::Size size(1, 1); | |
1052 ResourceFormat format = RGBA_8888; | |
1053 | |
1054 ResourceId id1 = child_resource_provider_->CreateResource( | |
1055 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
1056 uint8_t data1[4] = {1, 2, 3, 4}; | |
1057 child_resource_provider_->CopyToResource(id1, data1, size); | |
1058 child_resource_provider_->EnableReadLockFences(id1); | |
1059 ReturnedResourceArray returned_to_child; | |
1060 int child_id = | |
1061 resource_provider_->CreateChild(GetReturnCallback(&returned_to_child)); | |
1062 | |
1063 // Transfer some resources to the parent. | |
1064 ResourceProvider::ResourceIdArray resource_ids_to_transfer; | |
1065 resource_ids_to_transfer.push_back(id1); | |
1066 TransferableResourceArray list; | |
1067 child_resource_provider_->PrepareSendToParent(resource_ids_to_transfer, | |
1068 &list); | |
1069 ASSERT_EQ(1u, list.size()); | |
1070 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | |
1071 | |
1072 resource_provider_->ReceiveFromChild(child_id, list); | |
1073 class TestFence : public ResourceProvider::Fence { | |
1074 public: | |
1075 TestFence() {} | |
1076 | |
1077 void Set() override { NOTIMPLEMENTED(); } | |
1078 bool HasPassed() override { return passed; } | |
1079 void Wait() override { NOTIMPLEMENTED(); } | |
1080 | |
1081 bool passed = false; | |
1082 | |
1083 private: | |
1084 ~TestFence() override {} | |
1085 }; | |
1086 | |
1087 scoped_refptr<TestFence> fence(new TestFence); | |
1088 resource_provider_->SetReadLockFence(fence.get()); | |
1089 { | |
1090 unsigned parent_id = list.front().id; | |
1091 resource_provider_->WaitSyncPointIfNeeded(parent_id); | |
1092 ResourceProvider::ScopedReadLockGL lock(resource_provider_.get(), | |
1093 parent_id); | |
1094 } | |
1095 resource_provider_->DeclareUsedResourcesFromChild( | |
1096 child_id, ResourceProvider::ResourceIdSet()); | |
1097 EXPECT_EQ(0u, returned_to_child.size()); | |
1098 | |
1099 resource_provider_->DeclareUsedResourcesFromChild( | |
1100 child_id, ResourceProvider::ResourceIdSet()); | |
1101 EXPECT_EQ(0u, returned_to_child.size()); | |
1102 fence->passed = true; | |
1103 | |
1104 resource_provider_->DeclareUsedResourcesFromChild( | |
1105 child_id, ResourceProvider::ResourceIdSet()); | |
1106 EXPECT_EQ(1u, returned_to_child.size()); | |
1107 | |
1108 child_resource_provider_->ReceiveReturnsFromParent(returned_to_child); | |
1109 child_resource_provider_->DeleteResource(id1); | |
1110 EXPECT_EQ(0u, child_resource_provider_->num_resources()); | |
1111 } | |
piman
2015/06/12 01:53:52
Could you add another test for the lost resource c
Daniele Castagna
2015/06/12 23:36:42
If DestroyChild is called after a context lost Fen
| |
1112 | |
1048 TEST_P(ResourceProviderTest, TransferSoftwareResources) { | 1113 TEST_P(ResourceProviderTest, TransferSoftwareResources) { |
1049 if (GetParam() != ResourceProvider::RESOURCE_TYPE_BITMAP) | 1114 if (GetParam() != ResourceProvider::RESOURCE_TYPE_BITMAP) |
1050 return; | 1115 return; |
1051 | 1116 |
1052 gfx::Size size(1, 1); | 1117 gfx::Size size(1, 1); |
1053 ResourceFormat format = RGBA_8888; | 1118 ResourceFormat format = RGBA_8888; |
1054 size_t pixel_size = TextureSizeBytes(size, format); | 1119 size_t pixel_size = TextureSizeBytes(size, format); |
1055 ASSERT_EQ(4U, pixel_size); | 1120 ASSERT_EQ(4U, pixel_size); |
1056 | 1121 |
1057 ResourceId id1 = child_resource_provider_->CreateResource( | 1122 ResourceId id1 = child_resource_provider_->CreateResource( |
(...skipping 2570 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3628 resource_provider->AllocateForTesting(id); | 3693 resource_provider->AllocateForTesting(id); |
3629 Mock::VerifyAndClearExpectations(context); | 3694 Mock::VerifyAndClearExpectations(context); |
3630 | 3695 |
3631 DCHECK_EQ(10u, context->PeekTextureId()); | 3696 DCHECK_EQ(10u, context->PeekTextureId()); |
3632 resource_provider->DeleteResource(id); | 3697 resource_provider->DeleteResource(id); |
3633 } | 3698 } |
3634 } | 3699 } |
3635 | 3700 |
3636 } // namespace | 3701 } // namespace |
3637 } // namespace cc | 3702 } // namespace cc |
OLD | NEW |