Chromium Code Reviews| OLD | NEW |
|---|---|
| (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 "modules/fetch/BytesConsumerForDataConsumerHandle.h" | |
| 6 | |
| 7 #include "modules/fetch/BytesConsumer.h" | |
| 8 #include "modules/fetch/DataConsumerHandleTestUtil.h" | |
| 9 #include "modules/fetch/DataConsumerHandleUtil.h" | |
| 10 #include "platform/testing/UnitTestHelpers.h" | |
| 11 #include "testing/gmock/include/gmock/gmock.h" | |
| 12 #include "testing/gtest/include/gtest/gtest.h" | |
| 13 | |
| 14 namespace blink { | |
| 15 | |
| 16 namespace { | |
| 17 | |
| 18 using Command = DataConsumerHandleTestUtil::Command; | |
| 19 using Checkpoint = ::testing::StrictMock<::testing::MockFunction<void(int)>>; | |
| 20 using ReplayingHandle = DataConsumerHandleTestUtil::ReplayingHandle; | |
| 21 using Result = BytesConsumer::Result; | |
| 22 using ::testing::InSequence; | |
| 23 using ::testing::Return; | |
| 24 | |
| 25 class BytesConsumerForDataConsumerHandleTest : public ::testing::Test { | |
| 26 protected: | |
| 27 ~BytesConsumerForDataConsumerHandleTest() | |
| 28 { | |
| 29 ThreadHeap::collectAllGarbage(); | |
| 30 } | |
| 31 }; | |
| 32 | |
| 33 class MockClient : public GarbageCollectedFinalized<MockClient>, public BytesCon sumer::Client { | |
| 34 USING_GARBAGE_COLLECTED_MIXIN(MockClient); | |
| 35 public: | |
| 36 static MockClient* create() { return new ::testing::StrictMock<MockClient>() ; } | |
| 37 MOCK_METHOD0(onStateChange, void()); | |
| 38 | |
| 39 protected: | |
| 40 MockClient() {} | |
| 41 }; | |
| 42 | |
| 43 class MockDataConsumerHandle final : public FetchDataConsumerHandle { | |
| 44 public: | |
| 45 class MockReaderProxy : public GarbageCollectedFinalized<MockReaderProxy> { | |
| 46 public: | |
| 47 MOCK_METHOD4(read, WebDataConsumerHandle::Result(void*, size_t, WebDataC onsumerHandle::Flags, size_t*)); | |
| 48 MOCK_METHOD3(beginRead, WebDataConsumerHandle::Result(const void**, WebD ataConsumerHandle::Flags, size_t*)); | |
| 49 MOCK_METHOD1(endRead, WebDataConsumerHandle::Result(size_t)); | |
| 50 MOCK_METHOD1(drainAsBlobDataHandle, PassRefPtr<BlobDataHandle>(FetchData ConsumerHandle::Reader::BlobSizePolicy)); | |
| 51 MOCK_METHOD0(drainAsFormData, PassRefPtr<EncodedFormData>()); | |
| 52 | |
| 53 DEFINE_INLINE_TRACE() {} | |
| 54 }; | |
| 55 | |
| 56 MockDataConsumerHandle() : m_proxy(new MockReaderProxy) {} | |
| 57 MockReaderProxy* proxy() { return m_proxy; } | |
| 58 const char* debugName() const { return "MockDataConsumerHandle"; } | |
| 59 | |
| 60 private: | |
| 61 class Reader final : public FetchDataConsumerHandle::Reader { | |
| 62 public: | |
| 63 explicit Reader(MockReaderProxy* proxy) : m_proxy(proxy) {} | |
| 64 Result read(void* buffer, size_t size, WebDataConsumerHandle::Flags flag s, size_t* read) override | |
| 65 { | |
| 66 return m_proxy->read(buffer, size, flags, read); | |
| 67 } | |
| 68 Result beginRead(const void** buffer, Flags flags, size_t* available) ov erride | |
| 69 { | |
| 70 return m_proxy->beginRead(buffer, flags, available); | |
| 71 } | |
| 72 Result endRead(size_t readSize) override | |
| 73 { | |
| 74 return m_proxy->endRead(readSize); | |
| 75 } | |
| 76 PassRefPtr<BlobDataHandle> drainAsBlobDataHandle(BlobSizePolicy policy) override | |
| 77 { | |
| 78 return m_proxy->drainAsBlobDataHandle(policy); | |
| 79 } | |
| 80 PassRefPtr<EncodedFormData> drainAsFormData() override | |
| 81 { | |
| 82 return m_proxy->drainAsFormData(); | |
| 83 } | |
| 84 | |
| 85 private: | |
| 86 Persistent<MockReaderProxy> m_proxy; | |
| 87 }; | |
| 88 | |
| 89 Reader* obtainReaderInternal(Client*) { return new Reader(m_proxy); } | |
| 90 Persistent<MockReaderProxy> m_proxy; | |
| 91 }; | |
| 92 | |
| 93 } // namespace | |
| 94 | |
| 95 TEST_F(BytesConsumerForDataConsumerHandleTest, Create) | |
| 96 { | |
| 97 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 98 handle->add(Command(Command::Data, "hello")); | |
| 99 handle->add(Command(Command::Done)); | |
| 100 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 101 } | |
| 102 | |
| 103 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeReadable) | |
| 104 { | |
| 105 Checkpoint checkpoint; | |
| 106 Persistent<MockClient> client = MockClient::create(); | |
| 107 | |
| 108 InSequence s; | |
| 109 EXPECT_CALL(checkpoint, Call(1)); | |
| 110 EXPECT_CALL(*client, onStateChange()); | |
| 111 EXPECT_CALL(checkpoint, Call(2)); | |
| 112 | |
| 113 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 114 handle->add(Command(Command::Data, "hello")); | |
| 115 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 116 consumer->setClient(client); | |
| 117 EXPECT_EQ(BytesConsumer::PublicState::ReadableOrWaiting, consumer->getPublic State()); | |
| 118 | |
| 119 checkpoint.Call(1); | |
| 120 testing::runPendingTasks(); | |
| 121 checkpoint.Call(2); | |
| 122 EXPECT_EQ(BytesConsumer::PublicState::ReadableOrWaiting, consumer->getPublic State()); | |
| 123 } | |
| 124 | |
| 125 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeClosed) | |
| 126 { | |
| 127 Checkpoint checkpoint; | |
| 128 Persistent<MockClient> client = MockClient::create(); | |
| 129 | |
| 130 InSequence s; | |
| 131 EXPECT_CALL(checkpoint, Call(1)); | |
| 132 EXPECT_CALL(*client, onStateChange()); | |
| 133 EXPECT_CALL(checkpoint, Call(2)); | |
| 134 | |
| 135 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 136 handle->add(Command(Command::Done)); | |
| 137 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 138 consumer->setClient(client); | |
| 139 EXPECT_EQ(BytesConsumer::PublicState::ReadableOrWaiting, consumer->getPublic State()); | |
| 140 | |
| 141 checkpoint.Call(1); | |
| 142 testing::runPendingTasks(); | |
| 143 checkpoint.Call(2); | |
| 144 EXPECT_EQ(BytesConsumer::PublicState::Closed, consumer->getPublicState()); | |
| 145 } | |
| 146 | |
| 147 TEST_F(BytesConsumerForDataConsumerHandleTest, BecomeErrored) | |
| 148 { | |
| 149 Checkpoint checkpoint; | |
| 150 Persistent<MockClient> client = MockClient::create(); | |
| 151 | |
| 152 InSequence s; | |
| 153 EXPECT_CALL(checkpoint, Call(1)); | |
| 154 EXPECT_CALL(*client, onStateChange()); | |
| 155 EXPECT_CALL(checkpoint, Call(2)); | |
| 156 | |
| 157 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 158 handle->add(Command(Command::Error)); | |
| 159 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 160 consumer->setClient(client); | |
| 161 EXPECT_EQ(BytesConsumer::PublicState::ReadableOrWaiting, consumer->getPublic State()); | |
| 162 | |
| 163 checkpoint.Call(1); | |
| 164 testing::runPendingTasks(); | |
| 165 checkpoint.Call(2); | |
| 166 EXPECT_EQ(BytesConsumer::PublicState::Errored, consumer->getPublicState()); | |
| 167 } | |
| 168 | |
| 169 TEST_F(BytesConsumerForDataConsumerHandleTest, ClearClient) | |
| 170 { | |
| 171 Checkpoint checkpoint; | |
| 172 Persistent<MockClient> client = MockClient::create(); | |
| 173 | |
| 174 InSequence s; | |
| 175 EXPECT_CALL(checkpoint, Call(1)); | |
| 176 EXPECT_CALL(checkpoint, Call(2)); | |
| 177 | |
| 178 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 179 handle->add(Command(Command::Error)); | |
| 180 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 181 consumer->setClient(client); | |
| 182 consumer->clearClient(); | |
| 183 | |
| 184 checkpoint.Call(1); | |
| 185 testing::runPendingTasks(); | |
| 186 checkpoint.Call(2); | |
| 187 } | |
| 188 | |
| 189 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenReadable) | |
|
hiroshige
2016/07/26 06:48:12
Following tests do not have clients, but how about
yhirano
2016/07/27 13:19:52
Done.
| |
| 190 { | |
| 191 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 192 handle->add(Command(Command::Data, "hello")); | |
| 193 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 194 | |
| 195 char buffer[16]; | |
| 196 size_t read; | |
| 197 Result r = consumer->read(buffer, sizeof(buffer), &read); | |
| 198 ASSERT_EQ(Result::Ok, r); | |
| 199 EXPECT_EQ("hello", String(buffer, read)); | |
| 200 } | |
| 201 | |
| 202 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenWaiting) | |
| 203 { | |
| 204 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 205 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 206 | |
| 207 char buffer[16]; | |
| 208 size_t read; | |
| 209 Result r = consumer->read(buffer, sizeof(buffer), &read); | |
| 210 ASSERT_EQ(Result::ShouldWait, r); | |
|
hiroshige
2016/07/26 06:48:12
How about setting |size_t read = 42;| and adding E
yhirano
2016/07/27 13:19:52
Done.
| |
| 211 } | |
| 212 | |
| 213 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenClosed) | |
| 214 { | |
| 215 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 216 handle->add(Command(Command::Done)); | |
| 217 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 218 | |
| 219 char buffer[16]; | |
| 220 size_t read; | |
| 221 Result r = consumer->read(buffer, sizeof(buffer), &read); | |
| 222 ASSERT_EQ(Result::Done, r); | |
|
hiroshige
2016/07/26 06:48:12
ditto.
yhirano
2016/07/27 13:19:52
Done.
| |
| 223 } | |
| 224 | |
| 225 TEST_F(BytesConsumerForDataConsumerHandleTest, ReadWhenErrored) | |
| 226 { | |
| 227 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 228 handle->add(Command(Command::Error)); | |
| 229 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 230 | |
| 231 char buffer[16]; | |
| 232 size_t read; | |
| 233 Result r = consumer->read(buffer, sizeof(buffer), &read); | |
| 234 ASSERT_EQ(Result::Error, r); | |
| 235 EXPECT_EQ(BytesConsumer::Error("error"), consumer->getError()); | |
| 236 } | |
| 237 | |
| 238 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenReadable) | |
| 239 { | |
| 240 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 241 handle->add(Command(Command::Data, "hello")); | |
| 242 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 243 | |
| 244 const char* buffer = nullptr; | |
| 245 size_t available = 0; | |
| 246 ASSERT_EQ(Result::Ok, consumer->beginRead(&buffer, &available)); | |
| 247 EXPECT_EQ("hello", String(buffer, available)); | |
| 248 | |
| 249 ASSERT_EQ(Result::Ok, consumer->endRead(1)); | |
| 250 ASSERT_EQ(Result::Ok, consumer->beginRead(&buffer, &available)); | |
| 251 EXPECT_EQ("ello", String(buffer, available)); | |
| 252 | |
| 253 ASSERT_EQ(Result::Ok, consumer->endRead(4)); | |
| 254 ASSERT_EQ(Result::ShouldWait, consumer->beginRead(&buffer, &available)); | |
| 255 } | |
| 256 | |
| 257 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenWaiting) | |
| 258 { | |
| 259 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 260 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 261 const char* buffer = nullptr; | |
| 262 size_t available = 0; | |
| 263 ASSERT_EQ(Result::ShouldWait, consumer->beginRead(&buffer, &available)); | |
| 264 } | |
| 265 | |
| 266 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenClosed) | |
| 267 { | |
| 268 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 269 handle->add(Command(Command::Done)); | |
| 270 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 271 const char* buffer = nullptr; | |
| 272 size_t available = 0; | |
| 273 ASSERT_EQ(Result::Done, consumer->beginRead(&buffer, &available)); | |
| 274 } | |
| 275 | |
| 276 TEST_F(BytesConsumerForDataConsumerHandleTest, TwoPhaseReadWhenErrored) | |
| 277 { | |
| 278 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 279 handle->add(Command(Command::Error)); | |
| 280 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 281 const char* buffer = nullptr; | |
| 282 size_t available = 0; | |
| 283 ASSERT_EQ(Result::Error, consumer->beginRead(&buffer, &available)); | |
| 284 EXPECT_EQ(BytesConsumer::Error("error"), consumer->getError()); | |
| 285 } | |
| 286 | |
| 287 TEST_F(BytesConsumerForDataConsumerHandleTest, Cancel) | |
| 288 { | |
| 289 std::unique_ptr<ReplayingHandle> handle = ReplayingHandle::create(); | |
| 290 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( createFetchDataConsumerHandleFromWebHandle(std::move(handle))); | |
| 291 consumer->cancel(); | |
| 292 const char* buffer = nullptr; | |
| 293 size_t available = 0; | |
| 294 ASSERT_EQ(Result::Done, consumer->beginRead(&buffer, &available)); | |
| 295 } | |
| 296 | |
| 297 TEST_F(BytesConsumerForDataConsumerHandleTest, drainAsBlobDataHandle) | |
| 298 { | |
| 299 // FetchDataConsumerHandle::Reader::drainAsBlobDataHandle should return | |
| 300 // nullptr from the second time, but we don't care that here. | |
| 301 std::unique_ptr<MockDataConsumerHandle> handle = wrapUnique(new MockDataCons umerHandle); | |
| 302 Persistent<MockDataConsumerHandle::MockReaderProxy> proxy = handle->proxy(); | |
| 303 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( std::move(handle)); | |
| 304 RefPtr<BlobDataHandle> blobDataHandle = BlobDataHandle::create(); | |
| 305 | |
| 306 Checkpoint checkpoint; | |
| 307 InSequence s; | |
| 308 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::D isallowBlobWithInvalidSize)).WillOnce(Return(nullptr)); | |
| 309 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::A llowBlobWithInvalidSize)).WillOnce(Return(nullptr)); | |
| 310 EXPECT_CALL(*proxy, drainAsBlobDataHandle(FetchDataConsumerHandle::Reader::A llowBlobWithInvalidSize)).WillOnce(Return(blobDataHandle)); | |
| 311 | |
| 312 EXPECT_FALSE(consumer->drainAsBlobDataHandle(BytesConsumer::BlobSizePolicy:: DisallowBlobWithInvalidSize)); | |
| 313 EXPECT_FALSE(consumer->drainAsBlobDataHandle(BytesConsumer::BlobSizePolicy:: AllowBlobWithInvalidSize)); | |
| 314 EXPECT_TRUE(blobDataHandle); | |
| 315 EXPECT_EQ(blobDataHandle, consumer->drainAsBlobDataHandle(BytesConsumer::Blo bSizePolicy::AllowBlobWithInvalidSize)); | |
|
hiroshige
2016/07/26 06:48:12
Please check that consumer->getPublicState() is Cl
yhirano
2016/07/27 13:19:52
Done.
| |
| 316 } | |
| 317 | |
| 318 TEST_F(BytesConsumerForDataConsumerHandleTest, drainAsFormData) | |
| 319 { | |
| 320 std::unique_ptr<MockDataConsumerHandle> handle = wrapUnique(new MockDataCons umerHandle); | |
| 321 Persistent<MockDataConsumerHandle::MockReaderProxy> proxy = handle->proxy(); | |
| 322 Persistent<BytesConsumer> consumer = new BytesConsumerForDataConsumerHandle( std::move(handle)); | |
| 323 RefPtr<EncodedFormData> formData = EncodedFormData::create(); | |
| 324 | |
| 325 Checkpoint checkpoint; | |
| 326 InSequence s; | |
| 327 EXPECT_CALL(*proxy, drainAsFormData()).WillOnce(Return(formData)); | |
| 328 | |
| 329 EXPECT_EQ(formData, consumer->drainAsFormData()); | |
|
hiroshige
2016/07/26 06:48:12
ditto.
yhirano
2016/07/27 13:19:52
Done.
| |
| 330 } | |
| 331 | |
| 332 } // namespace blink | |
| OLD | NEW |