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

Side by Side Diff: content/browser/blob_storage/blob_slice_unittest.cc

Issue 2055053003: [BlobAsync] Disk support for blob storage (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Combined BlobSlice & BlobFlattener files, more comments, a little cleanup. Created 4 years, 4 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 "storage/browser/blob/blob_flattener.h"
6
7 #include <memory>
8
9 #include "storage/browser/blob/blob_data_builder.h"
10 #include "storage/browser/blob/blob_data_item.h"
11 #include "storage/browser/blob/internal_blob_data.h"
12 #include "storage/browser/blob/shareable_blob_data_item.h"
13 #include "storage/common/data_element.h"
14 #include "testing/gtest/include/gtest/gtest.h"
15
16 namespace storage {
17 namespace {
18 const char kType[] = "type";
19 const char kDisposition[] = "";
20
21 void ExpectFirstSlice(const BlobSlice& slice,
22 scoped_refptr<ShareableBlobDataItem> source_item,
23 size_t first_item_slice_offset,
24 size_t size) {
25 EXPECT_TRUE(slice.first_source_item);
26 EXPECT_EQ(first_item_slice_offset, slice.first_item_slice_offset);
27
28 ASSERT_LE(1u, slice.dest_items.size());
29 const DataElement& dest_element = slice.dest_items[0]->item()->data_element();
30
31 EXPECT_EQ(DataElement::TYPE_BYTES_DESCRIPTION, dest_element.type());
32 EXPECT_EQ(static_cast<uint64_t>(size), dest_element.length());
33
34 EXPECT_EQ(*source_item, *slice.first_source_item);
35 }
36
37 void ExpectLastSlice(const BlobSlice& slice,
38 scoped_refptr<ShareableBlobDataItem> source_item,
39 size_t size) {
40 EXPECT_TRUE(slice.last_source_item);
41
42 ASSERT_LE(2u, slice.dest_items.size());
43 const DataElement& dest_element =
44 slice.dest_items.back()->item()->data_element();
45
46 EXPECT_EQ(DataElement::TYPE_BYTES_DESCRIPTION, dest_element.type());
47 EXPECT_EQ(static_cast<uint64_t>(size), dest_element.length());
48
49 EXPECT_EQ(*source_item, *slice.last_source_item);
50 }
51
52 scoped_refptr<ShareableBlobDataItem> CreateDataItem(size_t size) {
53 std::unique_ptr<DataElement> element(new DataElement());
54 element->SetToAllocatedBytes(size);
55 for (size_t i = 0; i < size; i++) {
56 *(element->mutable_bytes() + i) = i;
57 }
58 return scoped_refptr<ShareableBlobDataItem>(
59 new ShareableBlobDataItem(new BlobDataItem(std::move(element)),
60 ShareableBlobDataItem::QUOTA_NEEDED));
61 };
62
63 scoped_refptr<ShareableBlobDataItem> CreateFileItem(size_t offset,
64 size_t size) {
65 std::unique_ptr<DataElement> element(new DataElement());
66 element->SetToFilePathRange(base::FilePath("kFakePath"), offset, size,
67 base::Time::Max());
68 return scoped_refptr<ShareableBlobDataItem>(new ShareableBlobDataItem(
69 new BlobDataItem(std::move(element)),
70 ShareableBlobDataItem::POPULATED_WITHOUT_QUOTA));
71 };
72
73 scoped_refptr<ShareableBlobDataItem> CreateTempFileItem(size_t offset,
74 size_t size) {
75 std::unique_ptr<DataElement> element(new DataElement());
76 element->SetToFilePathRange(
77 base::FilePath(BlobDataBuilder::kAppendFutureFileTemporaryFileName),
78 offset, size, base::Time::Max());
79 return scoped_refptr<ShareableBlobDataItem>(
80 new ShareableBlobDataItem(new BlobDataItem(std::move(element)),
81 ShareableBlobDataItem::QUOTA_NEEDED));
82 };
83
84 TEST(BlobSlice, FullItem) {
85 const std::string kBlobUUID = "kId";
86 const size_t kSize = 5u;
87
88 InternalBlobData data(kType, kDisposition);
89 scoped_refptr<ShareableBlobDataItem> item = CreateDataItem(kSize);
90 data.AppendSharedBlobItem(kBlobUUID, item);
91
92 BlobSlice slice(data, 0, 5);
93 EXPECT_EQ(0u, slice.copying_memory_size);
94 EXPECT_FALSE(slice.first_source_item);
95 EXPECT_FALSE(slice.last_source_item);
96 EXPECT_FALSE(slice.first_source_item);
97 EXPECT_FALSE(slice.last_source_item);
98 ASSERT_EQ(1u, slice.dest_items.size());
99 EXPECT_EQ(item, slice.dest_items[0]);
100 }
101
102 TEST(BlobSlice, SliceSingleItem) {
103 const std::string kBlobUUID = "kId";
104 const size_t kSize = 5u;
105
106 InternalBlobData data(kType, kDisposition);
107 scoped_refptr<ShareableBlobDataItem> item = CreateDataItem(kSize);
108 data.AppendSharedBlobItem(kBlobUUID, item);
109
110 BlobSlice slice(data, 1, 3);
111 EXPECT_EQ(3u, slice.copying_memory_size);
112 EXPECT_FALSE(slice.last_source_item);
113 ExpectFirstSlice(slice, item, 1, 3);
114 ASSERT_EQ(1u, slice.dest_items.size());
115 }
116
117 TEST(BlobSlice, SliceSingleLastItem) {
118 const std::string kBlobUUID = "kId";
119 const size_t kSize1 = 5u;
120 const size_t kSize2 = 10u;
121
122 InternalBlobData data(kType, kDisposition);
123 scoped_refptr<ShareableBlobDataItem> item1 = CreateDataItem(kSize1);
124 scoped_refptr<ShareableBlobDataItem> item2 = CreateDataItem(kSize2);
125 data.AppendSharedBlobItem(kBlobUUID, item1);
126 data.AppendSharedBlobItem(kBlobUUID, item2);
127
128 BlobSlice slice(data, 6, 2);
129 EXPECT_EQ(2u, slice.copying_memory_size);
130 ExpectFirstSlice(slice, item2, 1, 2);
131 ASSERT_EQ(1u, slice.dest_items.size());
132 }
133
134 TEST(BlobSlice, SliceAcrossTwoItems) {
135 const std::string kBlobUUID = "kId";
136 const size_t kSize1 = 5u;
137 const size_t kSize2 = 10u;
138
139 InternalBlobData data(kType, kDisposition);
140 scoped_refptr<ShareableBlobDataItem> item1 = CreateDataItem(kSize1);
141 scoped_refptr<ShareableBlobDataItem> item2 = CreateDataItem(kSize2);
142 data.AppendSharedBlobItem(kBlobUUID, item1);
143 data.AppendSharedBlobItem(kBlobUUID, item2);
144
145 BlobSlice slice(data, 4, 10);
146 EXPECT_EQ(10u, slice.copying_memory_size);
147 ExpectFirstSlice(slice, item1, 4, 1);
148 ExpectLastSlice(slice, item2, 9);
149 ASSERT_EQ(2u, slice.dest_items.size());
150 }
151
152 TEST(BlobSlice, SliceFileAndLastItem) {
153 const std::string kBlobUUID = "kId";
154 const size_t kSize1 = 5u;
155 const size_t kSize2 = 10u;
156
157 InternalBlobData data(kType, kDisposition);
158 scoped_refptr<ShareableBlobDataItem> item1 = CreateFileItem(0u, kSize1);
159 scoped_refptr<ShareableBlobDataItem> item2 = CreateDataItem(kSize2);
160 data.AppendSharedBlobItem(kBlobUUID, item1);
161 data.AppendSharedBlobItem(kBlobUUID, item2);
162
163 BlobSlice slice(data, 4, 2);
164 EXPECT_EQ(1u, slice.copying_memory_size);
165 EXPECT_FALSE(slice.first_source_item);
166 ExpectLastSlice(slice, item2, 1);
167 ASSERT_EQ(2u, slice.dest_items.size());
168
169 EXPECT_EQ(*CreateFileItem(4u, 1u)->item(), *slice.dest_items[0]->item());
170 }
171
172 TEST(BlobSlice, SliceAcrossLargeItem) {
173 const std::string kBlobUUID = "kId";
174 const size_t kSize1 = 5u;
175 const size_t kSize2 = 10u;
176 const size_t kSize3 = 10u;
177
178 InternalBlobData data(kType, kDisposition);
179 scoped_refptr<ShareableBlobDataItem> item1 = CreateDataItem(kSize1);
180 scoped_refptr<ShareableBlobDataItem> item2 = CreateFileItem(0u, kSize2);
181 scoped_refptr<ShareableBlobDataItem> item3 = CreateDataItem(kSize3);
182 data.AppendSharedBlobItem(kBlobUUID, item1);
183 data.AppendSharedBlobItem(kBlobUUID, item2);
184 data.AppendSharedBlobItem(kBlobUUID, item3);
185
186 BlobSlice slice(data, 2, 20);
187 EXPECT_EQ(3u + 7u, slice.copying_memory_size);
188 ExpectFirstSlice(slice, item1, 2, 3);
189 ExpectLastSlice(slice, item3, 7);
190 ASSERT_EQ(3u, slice.dest_items.size());
191
192 EXPECT_EQ(*item2, *slice.dest_items[1]);
193 }
194
195 TEST(BlobSlice, SliceTempFileItem) {
196 const std::string kBlobUUID = "kId";
197
198 InternalBlobData data(kType, kDisposition);
199 scoped_refptr<ShareableBlobDataItem> item1 = CreateTempFileItem(1u, 10u);
200 data.AppendSharedBlobItem(kBlobUUID, item1);
201
202 BlobSlice slice(data, 2, 5);
203 EXPECT_EQ(0u, slice.copying_memory_size);
204
205 EXPECT_TRUE(slice.first_source_item);
206 EXPECT_EQ(2u, slice.first_item_slice_offset);
207
208 ASSERT_LE(1u, slice.dest_items.size());
209 const DataElement& dest_element = slice.dest_items[0]->item()->data_element();
210
211 EXPECT_EQ(DataElement::TYPE_FILE, dest_element.type());
212 EXPECT_EQ(static_cast<uint64_t>(5), dest_element.length());
213
214 EXPECT_EQ(*item1, *slice.first_source_item);
215
216 ASSERT_EQ(1u, slice.dest_items.size());
217 }
218
219 } // namespace
220 } // namespace storage
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698