Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "modules/fetch/FetchFormDataConsumerHandle.h" | 5 #include "modules/fetch/FetchFormDataConsumerHandle.h" |
| 6 | 6 |
| 7 #include "core/dom/DOMTypedArray.h" | 7 #include "core/dom/DOMTypedArray.h" |
| 8 #include "core/html/FormData.h" | 8 #include "core/html/FormData.h" |
| 9 #include "core/loader/ThreadableLoader.h" | 9 #include "core/loader/MockThreadableLoader.h" |
| 10 #include "core/loader/ThreadableLoaderClient.h" | 10 #include "core/loader/ThreadableLoaderClient.h" |
| 11 #include "core/testing/DummyPageHolder.h" | 11 #include "core/testing/DummyPageHolder.h" |
| 12 #include "modules/fetch/DataConsumerHandleTestUtil.h" | 12 #include "modules/fetch/DataConsumerHandleTestUtil.h" |
| 13 #include "platform/network/ResourceResponse.h" | 13 #include "platform/network/ResourceResponse.h" |
| 14 #include "platform/testing/UnitTestHelpers.h" | 14 #include "platform/testing/UnitTestHelpers.h" |
| 15 #include "platform/weborigin/KURL.h" | 15 #include "platform/weborigin/KURL.h" |
| 16 #include "testing/gmock/include/gmock/gmock.h" | |
| 16 #include "testing/gtest/include/gtest/gtest.h" | 17 #include "testing/gtest/include/gtest/gtest.h" |
| 18 #include "wtf/PassOwnPtr.h" | |
| 17 #include "wtf/PassRefPtr.h" | 19 #include "wtf/PassRefPtr.h" |
| 18 #include "wtf/RefPtr.h" | 20 #include "wtf/RefPtr.h" |
| 19 #include "wtf/Vector.h" | 21 #include "wtf/Vector.h" |
| 20 #include "wtf/text/TextEncoding.h" | 22 #include "wtf/text/TextEncoding.h" |
| 21 #include "wtf/text/WTFString.h" | 23 #include "wtf/text/WTFString.h" |
| 22 #include <string.h> | 24 #include <string.h> |
| 23 | 25 |
| 24 namespace blink { | 26 namespace blink { |
| 25 namespace { | 27 namespace { |
| 26 | 28 |
| 27 using Result = WebDataConsumerHandle::Result; | 29 using Result = WebDataConsumerHandle::Result; |
| 28 const Result kOk = WebDataConsumerHandle::Ok; | 30 const Result kOk = WebDataConsumerHandle::Ok; |
| 29 const Result kDone = WebDataConsumerHandle::Done; | 31 const Result kDone = WebDataConsumerHandle::Done; |
| 30 const Result kShouldWait = WebDataConsumerHandle::ShouldWait; | 32 const Result kShouldWait = WebDataConsumerHandle::ShouldWait; |
| 31 const WebDataConsumerHandle::Flags kNone = WebDataConsumerHandle::FlagNone; | 33 const WebDataConsumerHandle::Flags kNone = WebDataConsumerHandle::FlagNone; |
| 32 using HandleReader = DataConsumerHandleTestUtil::HandleReader; | 34 using HandleReader = DataConsumerHandleTestUtil::HandleReader; |
| 33 using HandleTwoPhaseReader = DataConsumerHandleTestUtil::HandleTwoPhaseReader; | 35 using HandleTwoPhaseReader = DataConsumerHandleTestUtil::HandleTwoPhaseReader; |
| 34 using HandleReadResult = DataConsumerHandleTestUtil::HandleReadResult; | 36 using HandleReadResult = DataConsumerHandleTestUtil::HandleReadResult; |
| 35 template <typename T> | 37 template <typename T> |
| 36 using HandleReaderRunner = DataConsumerHandleTestUtil::HandleReaderRunner<T>; | 38 using HandleReaderRunner = DataConsumerHandleTestUtil::HandleReaderRunner<T>; |
| 37 using ReplayingHandle = DataConsumerHandleTestUtil::ReplayingHandle; | 39 using ReplayingHandle = DataConsumerHandleTestUtil::ReplayingHandle; |
| 38 using Command = DataConsumerHandleTestUtil::Command; | 40 using Command = DataConsumerHandleTestUtil::Command; |
| 39 | 41 |
| 42 using ::testing::_; | |
| 43 using ::testing::InvokeWithoutArgs; | |
| 44 | |
| 40 String toString(const Vector<char>& data) | 45 String toString(const Vector<char>& data) |
| 41 { | 46 { |
| 42 return String(data.data(), data.size()); | 47 return String(data.data(), data.size()); |
| 43 } | 48 } |
| 44 | 49 |
| 45 class NoopLoader final : public ThreadableLoader { | |
| 46 public: | |
| 47 static PassRefPtr<ThreadableLoader> create() { return adoptRef(new NoopLoade r); } | |
| 48 void overrideTimeout(unsigned long) override {} | |
| 49 void cancel() override {} | |
| 50 }; | |
| 51 | |
| 52 class LoaderFactory : public FetchBlobDataConsumerHandle::LoaderFactory { | 50 class LoaderFactory : public FetchBlobDataConsumerHandle::LoaderFactory { |
| 53 public: | 51 public: |
| 54 explicit LoaderFactory(PassOwnPtr<WebDataConsumerHandle> handle) : m_handle( handle) {} | 52 explicit LoaderFactory(PassOwnPtr<WebDataConsumerHandle> handle) |
| 55 PassRefPtr<ThreadableLoader> create(ExecutionContext&, ThreadableLoaderClien t* client, const ResourceRequest&, const ThreadableLoaderOptions&, const Resourc eLoaderOptions&) override | 53 : m_client(nullptr) |
| 54 , m_handle(handle) {} | |
| 55 PassRefPtr<ThreadableLoader> create(ExecutionContext&, ThreadableLoaderClien t* client, const ThreadableLoaderOptions&, const ResourceLoaderOptions&) overrid e | |
| 56 { | 56 { |
| 57 RefPtr<ThreadableLoader> loader = NoopLoader::create(); | 57 m_client = client; |
| 58 client->didReceiveResponse(0, ResourceResponse(), m_handle.release()); | 58 |
| 59 RefPtr<MockThreadableLoader> loader = MockThreadableLoader::create(); | |
| 60 EXPECT_CALL(*loader, start(_)).Times(1).WillOnce(InvokeWithoutArgs(this, &LoaderFactory::handleDidReceiveResponse)); | |
|
hiroshige
2016/02/05 08:11:53
nit: |Times(1).WillOnce(...)| looks redundant. Is
tyoshino (SeeGerritForStatus)
2016/02/09 14:42:02
Yeah. We're using the StrictMock, so WillOnce() is
| |
| 61 EXPECT_CALL(*loader, cancel()).Times(1); | |
| 59 return loader.release(); | 62 return loader.release(); |
| 60 } | 63 } |
| 61 | 64 |
| 62 private: | 65 private: |
| 66 void handleDidReceiveResponse() | |
| 67 { | |
| 68 m_client->didReceiveResponse(0, ResourceResponse(), m_handle.release()); | |
| 69 } | |
| 70 | |
| 71 ThreadableLoaderClient* m_client; | |
| 63 OwnPtr<WebDataConsumerHandle> m_handle; | 72 OwnPtr<WebDataConsumerHandle> m_handle; |
| 64 }; | 73 }; |
| 65 | 74 |
| 66 class FetchFormDataConsumerHandleTest : public ::testing::Test { | 75 class FetchFormDataConsumerHandleTest : public ::testing::Test { |
| 67 public: | 76 public: |
| 68 FetchFormDataConsumerHandleTest() : m_page(DummyPageHolder::create(IntSize(1 , 1))) {} | 77 FetchFormDataConsumerHandleTest() : m_page(DummyPageHolder::create(IntSize(1 , 1))) {} |
| 69 | 78 |
| 70 protected: | 79 protected: |
| 71 Document* document() { return &m_page->document(); } | 80 Document* document() { return &m_page->document(); } |
| 72 | 81 |
| (...skipping 355 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 428 EXPECT_EQ(kShouldWait, reader->beginRead(&buffer, kNone, &available)); | 437 EXPECT_EQ(kShouldWait, reader->beginRead(&buffer, kNone, &available)); |
| 429 testing::runPendingTasks(); | 438 testing::runPendingTasks(); |
| 430 EXPECT_EQ(kOk, reader->beginRead(&buffer, kNone, &available)); | 439 EXPECT_EQ(kOk, reader->beginRead(&buffer, kNone, &available)); |
| 431 EXPECT_FALSE(reader->drainAsFormData()); | 440 EXPECT_FALSE(reader->drainAsFormData()); |
| 432 reader->endRead(0); | 441 reader->endRead(0); |
| 433 EXPECT_FALSE(reader->drainAsFormData()); | 442 EXPECT_FALSE(reader->drainAsFormData()); |
| 434 } | 443 } |
| 435 | 444 |
| 436 } // namespace | 445 } // namespace |
| 437 } // namespace blink | 446 } // namespace blink |
| OLD | NEW |