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

Unified Diff: media/blink/buffered_data_source_unittest.cc

Issue 2272163002: Delete now deprecated BufferedDataSource and friends. (Closed)
Patch Set: Delete BufferedResourceLoader too. 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/blink/buffered_data_source_host_impl.h ('k') | media/blink/buffered_resource_loader.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/blink/buffered_data_source_unittest.cc
diff --git a/media/blink/buffered_data_source_unittest.cc b/media/blink/buffered_data_source_unittest.cc
deleted file mode 100644
index 5a925cddf2176e5f4e3238e2087bcb733bcb094f..0000000000000000000000000000000000000000
--- a/media/blink/buffered_data_source_unittest.cc
+++ /dev/null
@@ -1,1115 +0,0 @@
-// Copyright 2013 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 <stdint.h>
-
-#include "base/bind.h"
-#include "base/macros.h"
-#include "base/message_loop/message_loop.h"
-#include "base/run_loop.h"
-#include "build/build_config.h"
-#include "media/base/media_log.h"
-#include "media/base/mock_filters.h"
-#include "media/base/test_helpers.h"
-#include "media/blink/buffered_data_source.h"
-#include "media/blink/mock_webframeclient.h"
-#include "media/blink/mock_weburlloader.h"
-#include "media/blink/test_response_generator.h"
-#include "third_party/WebKit/public/platform/WebURLResponse.h"
-#include "third_party/WebKit/public/web/WebLocalFrame.h"
-#include "third_party/WebKit/public/web/WebView.h"
-
-using ::testing::_;
-using ::testing::Assign;
-using ::testing::DoAll;
-using ::testing::Invoke;
-using ::testing::InvokeWithoutArgs;
-using ::testing::InSequence;
-using ::testing::NiceMock;
-using ::testing::StrictMock;
-
-using blink::WebLocalFrame;
-using blink::WebString;
-using blink::WebURLLoader;
-using blink::WebURLResponse;
-using blink::WebView;
-
-namespace media {
-
-class MockBufferedDataSourceHost : public BufferedDataSourceHost {
- public:
- MockBufferedDataSourceHost() {}
- virtual ~MockBufferedDataSourceHost() {}
-
- MOCK_METHOD1(SetTotalBytes, void(int64_t total_bytes));
- MOCK_METHOD2(AddBufferedByteRange, void(int64_t start, int64_t end));
-
- private:
- DISALLOW_COPY_AND_ASSIGN(MockBufferedDataSourceHost);
-};
-
-// Overrides CreateResourceLoader() to permit injecting a MockWebURLLoader.
-// Also keeps track of whether said MockWebURLLoader is actively loading.
-class MockBufferedDataSource : public BufferedDataSource {
- public:
- MockBufferedDataSource(
- const GURL& url,
- BufferedResourceLoader::CORSMode cors_mode,
- const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
- WebLocalFrame* frame,
- BufferedDataSourceHost* host)
- : BufferedDataSource(url,
- cors_mode,
- task_runner,
- frame,
- new media::MediaLog(),
- host,
- base::Bind(&MockBufferedDataSource::set_downloading,
- base::Unretained(this))),
- downloading_(false),
- loading_(false) {}
- virtual ~MockBufferedDataSource() {}
-
- MOCK_METHOD2(CreateResourceLoader, BufferedResourceLoader*(int64_t, int64_t));
- BufferedResourceLoader* CreateMockResourceLoader(int64_t first_byte_position,
- int64_t last_byte_position) {
- CHECK(!loading_) << "Previous resource load wasn't cancelled";
-
- BufferedResourceLoader* loader =
- BufferedDataSource::CreateResourceLoader(first_byte_position,
- last_byte_position);
-
- // Keep track of active loading state via loadAsynchronously() and cancel().
- NiceMock<MockWebURLLoader>* url_loader = new NiceMock<MockWebURLLoader>();
- ON_CALL(*url_loader, loadAsynchronously(_, _))
- .WillByDefault(Assign(&loading_, true));
- ON_CALL(*url_loader, cancel())
- .WillByDefault(Assign(&loading_, false));
-
- // |test_loader_| will be used when Start() is called.
- loader->test_loader_ = std::unique_ptr<WebURLLoader>(url_loader);
- return loader;
- }
-
- bool loading() { return loading_; }
- void set_loading(bool loading) { loading_ = loading; }
- bool downloading() { return downloading_; }
- void set_downloading(bool downloading) { downloading_ = downloading; }
-
- private:
- // Whether the resource is downloading or deferred.
- bool downloading_;
-
- // Whether the resource load has starting loading but yet to been cancelled.
- bool loading_;
-
- DISALLOW_COPY_AND_ASSIGN(MockBufferedDataSource);
-};
-
-static const int64_t kFileSize = 5000000;
-static const int64_t kFarReadPosition = 4000000;
-static const int kDataSize = 1024;
-
-static const char kHttpUrl[] = "http://localhost/foo.webm";
-static const char kFileUrl[] = "file:///tmp/bar.webm";
-static const char kHttpDifferentPathUrl[] = "http://localhost/bar.webm";
-static const char kHttpDifferentOriginUrl[] = "http://127.0.0.1/foo.webm";
-
-class BufferedDataSourceTest : public testing::Test {
- public:
- BufferedDataSourceTest()
- : view_(WebView::create(nullptr, blink::WebPageVisibilityStateVisible)),
- frame_(
- WebLocalFrame::create(blink::WebTreeScopeType::Document, &client_)),
- bytes_received_(0),
- preload_(BufferedDataSource::AUTO) {
- view_->setMainFrame(frame_);
- }
-
- virtual ~BufferedDataSourceTest() {
- view_->close();
- frame_->close();
- }
-
- MOCK_METHOD1(OnInitialize, void(bool));
-
- void InitializeWithCORS(const char* url,
- bool expected,
- BufferedResourceLoader::CORSMode cors_mode) {
- GURL gurl(url);
- data_source_.reset(new MockBufferedDataSource(
- gurl, cors_mode, message_loop_.task_runner(),
- view_->mainFrame()->toWebLocalFrame(), &host_));
- data_source_->SetPreload(preload_);
-
- response_generator_.reset(new TestResponseGenerator(gurl, kFileSize));
- ExpectCreateResourceLoader();
- EXPECT_CALL(*this, OnInitialize(expected));
- data_source_->Initialize(base::Bind(&BufferedDataSourceTest::OnInitialize,
- base::Unretained(this)));
- base::RunLoop().RunUntilIdle();
-
- bool is_http = gurl.SchemeIsHTTPOrHTTPS();
- EXPECT_EQ(data_source_->downloading(), is_http);
- }
-
- void Initialize(const char* url, bool expected) {
- InitializeWithCORS(url, expected, BufferedResourceLoader::kUnspecified);
- }
-
- // Helper to initialize tests with a valid 200 response.
- void InitializeWith200Response() {
- Initialize(kHttpUrl, true);
-
- EXPECT_CALL(host_, SetTotalBytes(response_generator_->content_length()));
- Respond(response_generator_->Generate200());
- }
-
- // Helper to initialize tests with a valid 206 response.
- void InitializeWith206Response() {
- Initialize(kHttpUrl, true);
-
- EXPECT_CALL(host_, SetTotalBytes(response_generator_->content_length()));
- Respond(response_generator_->Generate206(0));
- }
-
- // Helper to initialize tests with a valid file:// response.
- void InitializeWithFileResponse() {
- Initialize(kFileUrl, true);
-
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kFileSize));
- Respond(response_generator_->GenerateFileResponse(0));
- }
-
- // Stops any active loaders and shuts down the data source.
- //
- // This typically happens when the page is closed and for our purposes is
- // appropriate to do when tearing down a test.
- void Stop() {
- if (data_source_->loading()) {
- loader()->didFail(url_loader(), response_generator_->GenerateError());
- base::RunLoop().RunUntilIdle();
- }
-
- data_source_->Stop();
- base::RunLoop().RunUntilIdle();
- }
-
- void ExpectCreateResourceLoader() {
- EXPECT_CALL(*data_source_, CreateResourceLoader(_, _))
- .WillOnce(Invoke(data_source_.get(),
- &MockBufferedDataSource::CreateMockResourceLoader));
- base::RunLoop().RunUntilIdle();
- bytes_received_ = 0;
- }
-
- void Respond(const WebURLResponse& response) {
- loader()->didReceiveResponse(url_loader(), response);
- base::RunLoop().RunUntilIdle();
- }
-
- void ReceiveData(int size) {
- std::unique_ptr<char[]> data(new char[size]);
- memset(data.get(), 0xA5, size); // Arbitrary non-zero value.
-
- loader()->didReceiveData(url_loader(), data.get(), size, size, size);
- base::RunLoop().RunUntilIdle();
- bytes_received_ += size;
- EXPECT_EQ(bytes_received_, data_source_->GetMemoryUsage());
- }
-
- void FinishLoading() {
- data_source_->set_loading(false);
- loader()->didFinishLoading(url_loader(), 0, -1);
- base::RunLoop().RunUntilIdle();
- }
-
- MOCK_METHOD1(ReadCallback, void(int size));
-
- void ReadAt(int64_t position) {
- data_source_->Read(position, kDataSize, buffer_,
- base::Bind(&BufferedDataSourceTest::ReadCallback,
- base::Unretained(this)));
- base::RunLoop().RunUntilIdle();
- }
-
- void ExecuteMixedResponseSuccessTest(const WebURLResponse& response1,
- const WebURLResponse& response2) {
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- EXPECT_CALL(host_, AddBufferedByteRange(kDataSize, kDataSize * 2 - 1));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- EXPECT_CALL(*this, ReadCallback(kDataSize)).Times(2);
-
- Respond(response1);
- ReadAt(0);
- ReceiveData(kDataSize);
- EXPECT_TRUE(data_source_->loading());
-
- ExpectCreateResourceLoader();
- FinishLoading();
- ReadAt(kDataSize);
- Respond(response2);
- ReceiveData(kDataSize);
- FinishLoading();
- Stop();
- }
-
- void ExecuteMixedResponseFailureTest(const WebURLResponse& response1,
- const WebURLResponse& response2) {
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
-
- Respond(response1);
- ReadAt(0);
- ReceiveData(kDataSize);
- EXPECT_TRUE(data_source_->loading());
-
- ExpectCreateResourceLoader();
- FinishLoading();
- ReadAt(kDataSize);
- Respond(response2);
- Stop();
- }
-
- // Accessors for private variables on |data_source_|.
- BufferedResourceLoader* loader() {
- return data_source_->loader_.get();
- }
- ActiveLoader* active_loader() { return loader()->active_loader_.get(); }
- WebURLLoader* url_loader() {
- return loader()->active_loader_->loader_.get();
- }
-
- BufferedDataSource::Preload preload() { return data_source_->preload_; }
- void set_preload(BufferedDataSource::Preload preload) { preload_ = preload; }
- BufferedResourceLoader::DeferStrategy defer_strategy() {
- return loader()->defer_strategy_;
- }
- int data_source_bitrate() { return data_source_->bitrate_; }
- double data_source_playback_rate() { return data_source_->playback_rate_; }
- int loader_bitrate() { return loader()->bitrate_; }
- double loader_playback_rate() { return loader()->playback_rate_; }
- bool is_local_source() { return data_source_->assume_fully_buffered(); }
- void set_might_be_reused_from_cache_in_future(bool value) {
- loader()->might_be_reused_from_cache_in_future_ = value;
- }
- GURL url() { return data_source_->url_; }
-
- std::unique_ptr<MockBufferedDataSource> data_source_;
-
- std::unique_ptr<TestResponseGenerator> response_generator_;
- MockWebFrameClient client_;
- WebView* view_;
- WebLocalFrame* frame_;
-
- StrictMock<MockBufferedDataSourceHost> host_;
- base::MessageLoop message_loop_;
- int bytes_received_;
-
- private:
- // Used for calling BufferedDataSource::Read().
- uint8_t buffer_[kDataSize];
-
- BufferedDataSource::Preload preload_;
-
- DISALLOW_COPY_AND_ASSIGN(BufferedDataSourceTest);
-};
-
-TEST_F(BufferedDataSourceTest, Range_Supported) {
- InitializeWith206Response();
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_FALSE(data_source_->IsStreaming());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_InstanceSizeUnknown) {
- Initialize(kHttpUrl, true);
-
- Respond(response_generator_->Generate206(
- 0, TestResponseGenerator::kNoContentRangeInstanceSize));
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_TRUE(data_source_->IsStreaming());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_NotFound) {
- Initialize(kHttpUrl, false);
- Respond(response_generator_->Generate404());
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_NotSupported) {
- InitializeWith200Response();
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_TRUE(data_source_->IsStreaming());
- Stop();
-}
-
-// Special carve-out for Apache versions that choose to return a 200 for
-// Range:0- ("because it's more efficient" than a 206)
-TEST_F(BufferedDataSourceTest, Range_SupportedButReturned200) {
- Initialize(kHttpUrl, true);
- EXPECT_CALL(host_, SetTotalBytes(response_generator_->content_length()));
- WebURLResponse response = response_generator_->Generate200();
- response.setHTTPHeaderField(WebString::fromUTF8("Accept-Ranges"),
- WebString::fromUTF8("bytes"));
- Respond(response);
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_FALSE(data_source_->IsStreaming());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_MissingContentRange) {
- Initialize(kHttpUrl, false);
- Respond(response_generator_->Generate206(
- 0, TestResponseGenerator::kNoContentRange));
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_MissingContentLength) {
- Initialize(kHttpUrl, true);
-
- // It'll manage without a Content-Length response.
- EXPECT_CALL(host_, SetTotalBytes(response_generator_->content_length()));
- Respond(response_generator_->Generate206(
- 0, TestResponseGenerator::kNoContentLength));
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_FALSE(data_source_->IsStreaming());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Range_WrongContentRange) {
- Initialize(kHttpUrl, false);
-
- // Now it's done and will fail.
- Respond(response_generator_->Generate206(1337));
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-// Test the case where the initial response from the server indicates that
-// Range requests are supported, but a later request prove otherwise.
-TEST_F(BufferedDataSourceTest, Range_ServerLied) {
- InitializeWith206Response();
-
- // Read causing a new request to be made -- we'll expect it to error.
- ExpectCreateResourceLoader();
- ReadAt(kFarReadPosition);
-
- // Return a 200 in response to a range request.
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- Respond(response_generator_->Generate200());
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_AbortWhileReading) {
- InitializeWith206Response();
-
- // Make sure there's a pending read -- we'll expect it to error.
- ReadAt(0);
-
- // Abort!!!
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- data_source_->Abort();
- base::RunLoop().RunUntilIdle();
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_AbortWhileReading) {
- InitializeWithFileResponse();
-
- // Make sure there's a pending read -- we'll expect it to error.
- ReadAt(0);
-
- // Abort!!!
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- data_source_->Abort();
- base::RunLoop().RunUntilIdle();
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_Retry) {
- InitializeWith206Response();
-
- // Read to advance our position.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReadAt(0);
- ReceiveData(kDataSize);
-
- // Issue a pending read but terminate the connection to force a retry.
- ReadAt(kDataSize);
- ExpectCreateResourceLoader();
- FinishLoading();
- Respond(response_generator_->Generate206(kDataSize));
-
- // Complete the read.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(kDataSize, (kDataSize * 2) - 1));
- ReceiveData(kDataSize);
-
- EXPECT_TRUE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_RetryOnError) {
- InitializeWith206Response();
-
- // Read to advance our position.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReadAt(0);
- ReceiveData(kDataSize);
-
- // Issue a pending read but trigger an error to force a retry.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(kDataSize, (kDataSize * 2) - 1));
- ReadAt(kDataSize);
- base::RunLoop run_loop;
- EXPECT_CALL(*data_source_, CreateResourceLoader(_, _))
- .WillOnce(
- DoAll(InvokeWithoutArgs(&run_loop, &base::RunLoop::Quit),
- Invoke(data_source_.get(),
- &MockBufferedDataSource::CreateMockResourceLoader)));
- bytes_received_ = 0;
- loader()->didFail(url_loader(), response_generator_->GenerateError());
- run_loop.Run();
- Respond(response_generator_->Generate206(kDataSize));
- ReceiveData(kDataSize);
- FinishLoading();
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-#if defined(OS_ANDROID)
-// If the initial response is a redirect, BDS saves it and uses it for future
-// requests.
-TEST_F(BufferedDataSourceTest, Http_InitialReponseRedirectsAreCached) {
- Initialize(kHttpUrl, true);
-
- WebURLResponse redirect =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- redirect.setURL(GURL(kHttpDifferentPathUrl));
-
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- Respond(redirect);
- ASSERT_TRUE(url() == GURL(kHttpDifferentPathUrl));
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_RedirectsAfterTheInitialReponseAreNotCached) {
- Initialize(kHttpUrl, true);
-
- WebURLResponse response =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response.setURL(GURL(kHttpUrl));
-
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- EXPECT_CALL(host_, AddBufferedByteRange(kDataSize, kDataSize * 2 - 1));
- EXPECT_CALL(*this, ReadCallback(kDataSize)).Times(2);
-
- Respond(response);
- ReadAt(0);
- ReceiveData(kDataSize);
-
- WebURLResponse redirect =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- redirect.setURL(GURL(kHttpDifferentPathUrl));
-
- ExpectCreateResourceLoader();
- FinishLoading();
- ReadAt(kDataSize);
- Respond(redirect);
- // The redirect isn't cached.
- ASSERT_TRUE(url() == GURL(kHttpUrl));
- ReceiveData(kDataSize);
- FinishLoading();
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_ServiceWorkerRedirectsAreNotCached) {
- Initialize(kHttpUrl, true);
-
- WebURLResponse redirect =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- redirect.setURL(GURL(kHttpDifferentPathUrl));
- redirect.setWasFetchedViaServiceWorker(true);
-
- EXPECT_CALL(host_, SetTotalBytes(kFileSize));
- Respond(redirect);
- ASSERT_TRUE(url() == GURL(kHttpUrl));
-}
-#endif // defined(OS_ANDROID)
-
-TEST_F(BufferedDataSourceTest, Http_PartialResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // The origin URL of response1 and response2 are same. So no error should
- // occur.
- ExecuteMixedResponseSuccessTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_RedirectedToDifferentPathResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- response2.setURL(GURL(kHttpDifferentPathUrl));
- // The origin URL of response1 and response2 are same. So no error should
- // occur.
- ExecuteMixedResponseSuccessTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_RedirectedToDifferentOriginResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- response2.setURL(GURL(kHttpDifferentOriginUrl));
- // The origin URL of response1 and response2 are different. So an error should
- // occur.
- ExecuteMixedResponseFailureTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_ServiceWorkerGeneratedResponseAndNormalResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response1.setWasFetchedViaServiceWorker(true);
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // response1 is generated in a Service Worker but response2 is from a native
- // server. So an error should occur.
- ExecuteMixedResponseFailureTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_ServiceWorkerProxiedAndSameURLResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response1.setWasFetchedViaServiceWorker(true);
- response1.setOriginalURLViaServiceWorker(GURL(kHttpUrl));
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // The origin URL of response1 and response2 are same. So no error should
- // occur.
- ExecuteMixedResponseSuccessTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_ServiceWorkerProxiedAndDifferentPathResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response1.setWasFetchedViaServiceWorker(true);
- response1.setOriginalURLViaServiceWorker(GURL(kHttpDifferentPathUrl));
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // The origin URL of response1 and response2 are same. So no error should
- // occur.
- ExecuteMixedResponseSuccessTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_ServiceWorkerProxiedAndDifferentOriginResponse) {
- Initialize(kHttpUrl, true);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response1.setWasFetchedViaServiceWorker(true);
- response1.setOriginalURLViaServiceWorker(GURL(kHttpDifferentOriginUrl));
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // The origin URL of response1 and response2 are different. So an error should
- // occur.
- ExecuteMixedResponseFailureTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest,
- Http_MixedResponse_ServiceWorkerProxiedAndDifferentOriginResponseCORS) {
- InitializeWithCORS(kHttpUrl, true, BufferedResourceLoader::kAnonymous);
- WebURLResponse response1 =
- response_generator_->GeneratePartial206(0, kDataSize - 1);
- response1.setWasFetchedViaServiceWorker(true);
- response1.setOriginalURLViaServiceWorker(GURL(kHttpDifferentOriginUrl));
- WebURLResponse response2 =
- response_generator_->GeneratePartial206(kDataSize, kDataSize * 2 - 1);
- // The origin URL of response1 and response2 are different, but a CORS check
- // has been passed for each request, so expect success.
- ExecuteMixedResponseSuccessTest(response1, response2);
-}
-
-TEST_F(BufferedDataSourceTest, File_Retry) {
- InitializeWithFileResponse();
-
- // Read to advance our position.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- ReadAt(0);
- ReceiveData(kDataSize);
-
- // Issue a pending read but terminate the connection to force a retry.
- ReadAt(kDataSize);
- ExpectCreateResourceLoader();
- FinishLoading();
- Respond(response_generator_->GenerateFileResponse(kDataSize));
-
- // Complete the read.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- ReceiveData(kDataSize);
-
- EXPECT_TRUE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_TooManyRetries) {
- InitializeWith206Response();
-
- // Make sure there's a pending read -- we'll expect it to error.
- ReadAt(0);
-
- for (int i = 0; i < BufferedDataSource::kLoaderRetries; i++) {
- ExpectCreateResourceLoader();
- FinishLoading();
- Respond(response_generator_->Generate206(0));
- }
-
- // It'll error after this.
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- FinishLoading();
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_TooManyRetries) {
- InitializeWithFileResponse();
-
- // Make sure there's a pending read -- we'll expect it to error.
- ReadAt(0);
-
- for (int i = 0; i < BufferedDataSource::kLoaderRetries; i++) {
- ExpectCreateResourceLoader();
- FinishLoading();
- Respond(response_generator_->GenerateFileResponse(0));
- }
-
- // It'll error after this.
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- FinishLoading();
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_InstanceSizeUnknown) {
- Initialize(kFileUrl, false);
- EXPECT_FALSE(data_source_->downloading());
-
- Respond(response_generator_->GenerateFileResponse(-1));
-
- EXPECT_FALSE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_Successful) {
- InitializeWithFileResponse();
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_FALSE(data_source_->IsStreaming());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, StopDuringRead) {
- InitializeWith206Response();
-
- uint8_t buffer[256];
- data_source_->Read(0, arraysize(buffer), buffer, base::Bind(
- &BufferedDataSourceTest::ReadCallback, base::Unretained(this)));
-
- // The outstanding read should fail before the stop callback runs.
- {
- InSequence s;
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- data_source_->Stop();
- }
- base::RunLoop().RunUntilIdle();
-}
-
-TEST_F(BufferedDataSourceTest, DefaultValues) {
- InitializeWith206Response();
-
- // Ensure we have sane values for default loading scenario.
- EXPECT_EQ(BufferedDataSource::AUTO, preload());
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- EXPECT_EQ(0, data_source_bitrate());
- EXPECT_EQ(0.0, data_source_playback_rate());
- EXPECT_EQ(0, loader_bitrate());
- EXPECT_EQ(0.0, loader_playback_rate());
-
- EXPECT_TRUE(data_source_->loading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, SetBitrate) {
- InitializeWith206Response();
-
- data_source_->SetBitrate(1234);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1234, data_source_bitrate());
- EXPECT_EQ(1234, loader_bitrate());
-
- // Read so far ahead to cause the loader to get recreated.
- BufferedResourceLoader* old_loader = loader();
- ExpectCreateResourceLoader();
- ReadAt(kFarReadPosition);
- Respond(response_generator_->Generate206(kFarReadPosition));
-
- // Verify loader changed but still has same bitrate.
- EXPECT_NE(old_loader, loader());
- EXPECT_EQ(1234, loader_bitrate());
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, MediaPlaybackRateChanged) {
- InitializeWith206Response();
-
- data_source_->MediaPlaybackRateChanged(2.0);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(2.0, data_source_playback_rate());
- EXPECT_EQ(2.0, loader_playback_rate());
-
- // Read so far ahead to cause the loader to get recreated.
- BufferedResourceLoader* old_loader = loader();
- ExpectCreateResourceLoader();
- ReadAt(kFarReadPosition);
- Respond(response_generator_->Generate206(kFarReadPosition));
-
- // Verify loader changed but still has same playback rate.
- EXPECT_NE(old_loader, loader());
-
- EXPECT_TRUE(data_source_->loading());
- EXPECT_CALL(*this, ReadCallback(media::DataSource::kReadError));
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_Read) {
- InitializeWith206Response();
-
- ReadAt(0);
-
- // Receive first half of the read.
- EXPECT_CALL(host_, AddBufferedByteRange(0, (kDataSize / 2) - 1));
- ReceiveData(kDataSize / 2);
-
- // Receive last half of the read.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReceiveData(kDataSize / 2);
-
- EXPECT_TRUE(data_source_->downloading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_Read_Seek) {
- InitializeWith206Response();
-
- // Read a bit from the beginning.
- ReadAt(0);
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReceiveData(kDataSize);
-
- // Simulate a seek by reading a bit beyond kDataSize.
- ReadAt(kDataSize * 2);
-
- // We receive data leading up to but not including our read.
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize * 2 - 1));
- ReceiveData(kDataSize);
-
- // We now receive the rest of the data for our read.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize * 3 - 1));
- ReceiveData(kDataSize);
-
- EXPECT_TRUE(data_source_->downloading());
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_Read) {
- InitializeWithFileResponse();
-
- ReadAt(0);
-
- // Receive first half of the read but no buffering update.
- ReceiveData(kDataSize / 2);
-
- // Receive last half of the read but no buffering update.
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- ReceiveData(kDataSize / 2);
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, Http_FinishLoading) {
- InitializeWith206Response();
-
- EXPECT_TRUE(data_source_->downloading());
- FinishLoading();
- EXPECT_FALSE(data_source_->downloading());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, File_FinishLoading) {
- InitializeWithFileResponse();
-
- EXPECT_FALSE(data_source_->downloading());
- FinishLoading();
- EXPECT_FALSE(data_source_->downloading());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, LocalResource_DeferStrategy) {
- InitializeWithFileResponse();
-
- EXPECT_EQ(BufferedDataSource::AUTO, preload());
- EXPECT_TRUE(is_local_source());
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, LocalResource_PreloadMetadata_DeferStrategy) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWithFileResponse();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_TRUE(is_local_source());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, ExternalResource_Reponse200_DeferStrategy) {
- InitializeWith200Response();
-
- EXPECT_EQ(BufferedDataSource::AUTO, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_FALSE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest,
- ExternalResource_Response200_PreloadMetadata_DeferStrategy) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWith200Response();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_FALSE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, ExternalResource_Reponse206_DeferStrategy) {
- InitializeWith206Response();
-
- EXPECT_EQ(BufferedDataSource::AUTO, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_TRUE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
- set_might_be_reused_from_cache_in_future(true);
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kNeverDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_NORMAL);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- set_might_be_reused_from_cache_in_future(false);
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest,
- ExternalResource_Response206_PreloadMetadata_DeferStrategy) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWith206Response();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_TRUE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- data_source_->MediaIsPlaying();
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- set_might_be_reused_from_cache_in_future(true);
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kNeverDefer, defer_strategy());
-
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_NORMAL);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- set_might_be_reused_from_cache_in_future(false);
- data_source_->SetBufferingStrategy(
- BufferedDataSource::BUFFERING_STRATEGY_AGGRESSIVE);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
-
- Stop();
-}
-
-TEST_F(BufferedDataSourceTest, ExternalResource_Response206_VerifyDefer) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWith206Response();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_TRUE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- // Read a bit from the beginning.
- ReadAt(0);
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReceiveData(kDataSize);
-
- ASSERT_TRUE(active_loader());
- EXPECT_TRUE(active_loader()->deferred());
-}
-
-TEST_F(BufferedDataSourceTest, ExternalResource_Response206_CancelAfterDefer) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWith206Response();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_TRUE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- data_source_->OnBufferingHaveEnough(false);
-
- ASSERT_TRUE(active_loader());
-
- // Read a bit from the beginning.
- ReadAt(0);
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReceiveData(kDataSize);
-
- EXPECT_FALSE(active_loader());
-}
-
-TEST_F(BufferedDataSourceTest, ExternalResource_Response206_CancelAfterPlay) {
- set_preload(BufferedDataSource::METADATA);
- InitializeWith206Response();
-
- EXPECT_EQ(BufferedDataSource::METADATA, preload());
- EXPECT_FALSE(is_local_source());
- EXPECT_TRUE(loader()->range_supported());
- EXPECT_EQ(BufferedResourceLoader::kReadThenDefer, defer_strategy());
-
- // Marking the media as playing should prevent deferral. It also switches the
- // data source into kCapacityDefer.
- data_source_->MediaIsPlaying();
- data_source_->OnBufferingHaveEnough(false);
- EXPECT_EQ(BufferedResourceLoader::kCapacityDefer, defer_strategy());
- ASSERT_TRUE(active_loader());
-
- // Read a bit from the beginning and ensure deferral hasn't happened yet.
- ReadAt(0);
- EXPECT_CALL(*this, ReadCallback(kDataSize));
- EXPECT_CALL(host_, AddBufferedByteRange(0, kDataSize - 1));
- ReceiveData(kDataSize);
- ASSERT_TRUE(active_loader());
- ASSERT_FALSE(active_loader()->deferred());
- data_source_->OnBufferingHaveEnough(true);
-
- // Deliver data until capacity is reached and verify deferral.
- int bytes_received = 0;
- EXPECT_CALL(host_, AddBufferedByteRange(_, _)).Times(testing::AtLeast(1));
- while (active_loader() && !active_loader()->deferred()) {
- ReceiveData(kDataSize);
- bytes_received += kDataSize;
- }
- EXPECT_GT(bytes_received, 0);
- EXPECT_LT(bytes_received + kDataSize, kFileSize);
- EXPECT_FALSE(active_loader());
-}
-
-} // namespace media
« no previous file with comments | « media/blink/buffered_data_source_host_impl.h ('k') | media/blink/buffered_resource_loader.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698