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

Unified Diff: third_party/WebKit/Source/modules/fetch/FetchBlobDataConsumerHandleTest.cpp

Issue 2342233002: Remove Fetch[Blob|FormData]ConsumerHandle (Closed)
Patch Set: rebase Created 4 years, 3 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 side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/modules/fetch/FetchBlobDataConsumerHandleTest.cpp
diff --git a/third_party/WebKit/Source/modules/fetch/FetchBlobDataConsumerHandleTest.cpp b/third_party/WebKit/Source/modules/fetch/FetchBlobDataConsumerHandleTest.cpp
deleted file mode 100644
index 8bd1ea4945852e59438d43d3e95c9687375abfed..0000000000000000000000000000000000000000
--- a/third_party/WebKit/Source/modules/fetch/FetchBlobDataConsumerHandleTest.cpp
+++ /dev/null
@@ -1,449 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "modules/fetch/FetchBlobDataConsumerHandle.h"
-
-#include "core/dom/ExecutionContext.h"
-#include "core/fetch/ResourceLoaderOptions.h"
-#include "core/loader/MockThreadableLoader.h"
-#include "core/loader/ThreadableLoaderClient.h"
-#include "core/testing/DummyPageHolder.h"
-#include "modules/fetch/DataConsumerHandleTestUtil.h"
-#include "platform/blob/BlobData.h"
-#include "platform/blob/BlobURL.h"
-#include "platform/network/ResourceError.h"
-#include "platform/network/ResourceRequest.h"
-#include "platform/network/ResourceResponse.h"
-#include "platform/testing/UnitTestHelpers.h"
-#include "testing/gmock/include/gmock/gmock.h"
-#include "testing/gtest/include/gtest/gtest.h"
-#include "wtf/PassRefPtr.h"
-#include "wtf/PtrUtil.h"
-#include "wtf/RefPtr.h"
-#include <memory>
-#include <string.h>
-
-namespace blink {
-namespace {
-
-using Result = WebDataConsumerHandle::Result;
-const Result kShouldWait = WebDataConsumerHandle::ShouldWait;
-const Result kUnexpectedError = WebDataConsumerHandle::UnexpectedError;
-const Result kDone = WebDataConsumerHandle::Done;
-using Flags = WebDataConsumerHandle::Flags;
-const Flags kNone = WebDataConsumerHandle::FlagNone;
-using Thread = DataConsumerHandleTestUtil::Thread;
-using HandleReader = DataConsumerHandleTestUtil::HandleReader;
-using HandleTwoPhaseReader = DataConsumerHandleTestUtil::HandleTwoPhaseReader;
-using HandleReadResult = DataConsumerHandleTestUtil::HandleReadResult;
-using ReplayingHandle = DataConsumerHandleTestUtil::ReplayingHandle;
-using Command = DataConsumerHandleTestUtil::Command;
-template <typename T>
-using HandleReaderRunner = DataConsumerHandleTestUtil::HandleReaderRunner<T>;
-
-using ::testing::_;
-using ::testing::DoAll;
-using ::testing::InSequence;
-using ::testing::Ref;
-using ::testing::Return;
-using ::testing::SaveArg;
-using ::testing::StrictMock;
-using Checkpoint = StrictMock<::testing::MockFunction<void(int)>>;
-
-class MockLoaderFactory : public FetchBlobDataConsumerHandle::LoaderFactory {
-public:
- MOCK_METHOD4(create, ThreadableLoader*(ExecutionContext&, ThreadableLoaderClient*, const ThreadableLoaderOptions&, const ResourceLoaderOptions&));
-};
-
-PassRefPtr<BlobDataHandle> createBlobDataHandle(const char* s)
-{
- std::unique_ptr<BlobData> data = BlobData::create();
- data->appendText(s, false);
- auto size = data->length();
- return BlobDataHandle::create(std::move(data), size);
-}
-
-String toString(const Vector<char>& data)
-{
- return String(data.data(), data.size());
-}
-
-class FetchBlobDataConsumerHandleTest : public ::testing::Test {
-public:
- FetchBlobDataConsumerHandleTest()
- : m_dummyPageHolder(DummyPageHolder::create(IntSize(1, 1))) {}
- ~FetchBlobDataConsumerHandleTest() override
- {
- m_dummyPageHolder = nullptr;
- // We need this to collect garbage-collected mocks.
- ThreadState::current()-> collectAllGarbage();
- }
-
- Document& document() { return m_dummyPageHolder->document(); }
-
-private:
- std::unique_ptr<DummyPageHolder> m_dummyPageHolder;
-};
-
-TEST_F(FetchBlobDataConsumerHandleTest, CreateLoader)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- ResourceRequest request;
- ThreadableLoaderOptions options;
- ResourceLoaderOptions resourceLoaderOptions;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(DoAll(
- SaveArg<2>(&options),
- SaveArg<3>(&resourceLoaderOptions),
- Return(loader.get())));
- EXPECT_CALL(*loader, start(_)).WillOnce(SaveArg<0>(&request));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(*loader, cancel());
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- testing::runPendingTasks();
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
-
- EXPECT_TRUE(request.url().getString().startsWith("blob:"));
- EXPECT_TRUE(request.useStreamOnResponse());
-
- EXPECT_EQ(ConsiderPreflight, options.preflightPolicy);
- EXPECT_EQ(DenyCrossOriginRequests, options.crossOriginRequestPolicy);
- EXPECT_EQ(DoNotEnforceContentSecurityPolicy, options.contentSecurityPolicyEnforcement);
-
- EXPECT_EQ(DoNotBufferData, resourceLoaderOptions.dataBufferingPolicy);
- EXPECT_EQ(DoNotAllowStoredCredentials, resourceLoaderOptions.allowCredentials);
- EXPECT_EQ(ClientDidNotRequestCredentials, resourceLoaderOptions.credentialsRequested);
- EXPECT_EQ(CheckContentSecurityPolicy, resourceLoaderOptions.contentSecurityPolicyOption);
- EXPECT_EQ(DocumentContext, resourceLoaderOptions.requestInitiatorContext);
- EXPECT_EQ(RequestAsynchronously, resourceLoaderOptions.synchronousPolicy);
- EXPECT_EQ(NotCORSEnabled, resourceLoaderOptions.corsEnabled);
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, ZeroByteReadDoesNotCreateLoader)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(checkpoint, Call(2));
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- testing::runPendingTasks();
-
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(nullptr, 0, kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, CancelLoaderWhenStopped)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(Return(loader.get()));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(*loader, cancel());
- EXPECT_CALL(checkpoint, Call(3));
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- testing::runPendingTasks();
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- document().stopActiveDOMObjects();
- checkpoint.Call(3);
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, CancelLoaderWhenDestinationDetached)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(Return(loader.get()));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(checkpoint, Call(3));
- EXPECT_CALL(*loader, cancel());
- EXPECT_CALL(checkpoint, Call(4));
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- std::unique_ptr<WebDataConsumerHandle::Reader> reader = handle->obtainReader(nullptr);
- testing::runPendingTasks();
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, reader->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- handle = nullptr;
- reader = nullptr;
- checkpoint.Call(3);
- ThreadState::current()-> collectAllGarbage();
- checkpoint.Call(4);
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, ReadTest)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
- ThreadableLoaderClient* client = nullptr;
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(DoAll(SaveArg<1>(&client), Return(loader.get())));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(*loader, cancel());
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- std::unique_ptr<ReplayingHandle> src = ReplayingHandle::create();
- src->add(Command(Command::Wait));
- src->add(Command(Command::Data, "hello, "));
- src->add(Command(Command::Data, "world"));
- src->add(Command(Command::Wait));
- src->add(Command(Command::Done));
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- client->didReceiveResponse(0, ResourceResponse(), std::move(src));
- HandleReaderRunner<HandleReader> runner(std::move(handle));
- std::unique_ptr<HandleReadResult> r = runner.wait();
- EXPECT_EQ(kDone, r->result());
- EXPECT_EQ("hello, world", toString(r->data()));
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, TwoPhaseReadTest)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
- ThreadableLoaderClient* client = nullptr;
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(DoAll(SaveArg<1>(&client), Return(loader.get())));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(*loader, cancel());
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- std::unique_ptr<ReplayingHandle> src = ReplayingHandle::create();
- src->add(Command(Command::Wait));
- src->add(Command(Command::Data, "hello, "));
- src->add(Command(Command::Data, "world"));
- src->add(Command(Command::Wait));
- src->add(Command(Command::Done));
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- client->didReceiveResponse(0, ResourceResponse(), std::move(src));
- HandleReaderRunner<HandleTwoPhaseReader> runner(std::move(handle));
- std::unique_ptr<HandleReadResult> r = runner.wait();
- EXPECT_EQ(kDone, r->result());
- EXPECT_EQ("hello, world", toString(r->data()));
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, LoadErrorTest)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
- ThreadableLoaderClient* client = nullptr;
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(DoAll(SaveArg<1>(&client), Return(loader.get())));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- client->didFail(ResourceError());
- HandleReaderRunner<HandleReader> runner(std::move(handle));
- std::unique_ptr<HandleReadResult> r = runner.wait();
- EXPECT_EQ(kUnexpectedError, r->result());
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, BodyLoadErrorTest)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
- Checkpoint checkpoint;
-
- Persistent<MockThreadableLoader> loader = MockThreadableLoader::create();
- ThreadableLoaderClient* client = nullptr;
-
- InSequence s;
- EXPECT_CALL(checkpoint, Call(1));
- EXPECT_CALL(*factory, create(Ref(document()), _, _, _)).WillOnce(DoAll(SaveArg<1>(&client), Return(loader.get())));
- EXPECT_CALL(*loader, start(_));
- EXPECT_CALL(checkpoint, Call(2));
- EXPECT_CALL(*loader, cancel());
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<WebDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- std::unique_ptr<ReplayingHandle> src = ReplayingHandle::create();
- src->add(Command(Command::Wait));
- src->add(Command(Command::Data, "hello, "));
- src->add(Command(Command::Error));
-
- char buffer[1];
- size_t size = 0;
- ASSERT_EQ(kShouldWait, handle->obtainReader(nullptr)->read(buffer, sizeof(buffer), kNone, &size));
- checkpoint.Call(1);
- testing::runPendingTasks();
- checkpoint.Call(2);
- client->didReceiveResponse(0, ResourceResponse(), std::move(src));
- HandleReaderRunner<HandleReader> runner(std::move(handle));
- std::unique_ptr<HandleReadResult> r = runner.wait();
- EXPECT_EQ(kUnexpectedError, r->result());
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, DrainAsBlobDataHandle)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<FetchDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- size_t size = 0;
- EXPECT_EQ(blobDataHandle, handle->obtainFetchDataReader(nullptr)->drainAsBlobDataHandle());
- EXPECT_FALSE(handle->obtainFetchDataReader(nullptr)->drainAsFormData());
-
- EXPECT_EQ(kDone, handle->obtainReader(nullptr)->read(nullptr, 0, kNone, &size));
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, DrainAsFormData)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<FetchDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
-
- RefPtr<EncodedFormData> formData = handle->obtainFetchDataReader(nullptr)->drainAsFormData();
- ASSERT_TRUE(formData);
- EXPECT_TRUE(formData->isSafeToSendToAnotherThread());
- ASSERT_EQ(1u, formData->elements().size());
- EXPECT_EQ(FormDataElement::encodedBlob, formData->elements()[0].m_type);
- EXPECT_EQ(blobDataHandle->uuid(), formData->elements()[0].m_blobUUID);
- EXPECT_EQ(blobDataHandle, formData->elements()[0].m_optionalBlobDataHandle);
-
- EXPECT_FALSE(handle->obtainFetchDataReader(nullptr)->drainAsBlobDataHandle());
- size_t size;
- EXPECT_EQ(kDone, handle->obtainFetchDataReader(nullptr)->read(nullptr, 0, kNone, &size));
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, ZeroByteReadDoesNotAffectDraining)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<FetchDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- std::unique_ptr<FetchDataConsumerHandle::Reader> reader = handle->obtainFetchDataReader(nullptr);
-
- size_t readSize;
- EXPECT_EQ(kShouldWait, reader->read(nullptr, 0, kNone, &readSize));
- EXPECT_EQ(blobDataHandle, reader->drainAsBlobDataHandle());
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, OneByteReadAffectsDraining)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<FetchDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- std::unique_ptr<FetchDataConsumerHandle::Reader> reader = handle->obtainFetchDataReader(nullptr);
-
- size_t readSize;
- char c;
- EXPECT_EQ(kShouldWait, reader->read(&c, 1, kNone, &readSize));
- EXPECT_FALSE(reader->drainAsFormData());
-}
-
-TEST_F(FetchBlobDataConsumerHandleTest, BeginReadAffectsDraining)
-{
- auto factory = new StrictMock<MockLoaderFactory>;
-
- RefPtr<BlobDataHandle> blobDataHandle = createBlobDataHandle("Once upon a time");
- std::unique_ptr<FetchDataConsumerHandle> handle
- = FetchBlobDataConsumerHandle::create(&document(), blobDataHandle, factory);
- std::unique_ptr<FetchDataConsumerHandle::Reader> reader = handle->obtainFetchDataReader(nullptr);
-
- const void* buffer;
- size_t available;
- EXPECT_EQ(kShouldWait, reader->beginRead(&buffer, kNone, &available));
- EXPECT_FALSE(reader->drainAsBlobDataHandle());
-}
-
-} // namespace
-} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698