// Copyright (c) 2012 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 "net/base/upload_file_element_reader.h" #include "base/file_util.h" #include "base/scoped_temp_dir.h" #include "net/base/io_buffer.h" #include "net/base/net_errors.h" #include "net/base/test_completion_callback.h" #include "testing/gtest/include/gtest/gtest.h" #include "testing/platform_test.h" namespace net { class UploadFileElementReaderTest : public PlatformTest { protected: virtual void SetUp() OVERRIDE { // Some tests (*.ReadPartially) rely on bytes_.size() being even. const char kData[] = "123456789abcdefghi"; bytes_.assign(kData, kData + arraysize(kData) - 1); ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); ASSERT_TRUE(file_util::CreateTemporaryFileInDir(temp_dir_.path(), &temp_file_path_)); ASSERT_EQ( static_cast(bytes_.size()), file_util::WriteFile(temp_file_path_, &bytes_[0], bytes_.size())); reader_.reset(new UploadFileElementReader( temp_file_path_, 0, kuint64max, base::Time())); ASSERT_EQ(OK, reader_->InitSync()); EXPECT_EQ(bytes_.size(), reader_->GetContentLength()); EXPECT_EQ(bytes_.size(), reader_->BytesRemaining()); EXPECT_FALSE(reader_->IsInMemory()); } std::vector bytes_; scoped_ptr reader_; ScopedTempDir temp_dir_; FilePath temp_file_path_; }; TEST_F(UploadFileElementReaderTest, ReadPartially) { const size_t kHalfSize = bytes_.size() / 2; ASSERT_EQ(bytes_.size(), kHalfSize * 2); std::vector buf(kHalfSize); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); EXPECT_EQ(static_cast(buf.size()), reader_->ReadSync(wrapped_buffer, buf.size())); EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); EXPECT_EQ(std::vector(bytes_.begin(), bytes_.begin() + kHalfSize), buf); EXPECT_EQ(static_cast(buf.size()), reader_->ReadSync(wrapped_buffer, buf.size())); EXPECT_EQ(0U, reader_->BytesRemaining()); EXPECT_EQ(std::vector(bytes_.begin() + kHalfSize, bytes_.end()), buf); } TEST_F(UploadFileElementReaderTest, ReadAll) { std::vector buf(bytes_.size()); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); EXPECT_EQ(static_cast(buf.size()), reader_->ReadSync(wrapped_buffer, buf.size())); EXPECT_EQ(0U, reader_->BytesRemaining()); EXPECT_EQ(bytes_, buf); // Try to read again. EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); } TEST_F(UploadFileElementReaderTest, ReadTooMuch) { const size_t kTooLargeSize = bytes_.size() * 2; std::vector buf(kTooLargeSize); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); EXPECT_EQ(static_cast(bytes_.size()), reader_->ReadSync(wrapped_buffer, buf.size())); EXPECT_EQ(0U, reader_->BytesRemaining()); buf.resize(bytes_.size()); // Resize to compare. EXPECT_EQ(bytes_, buf); } TEST_F(UploadFileElementReaderTest, ReadPartiallyAsync) { const size_t kHalfSize = bytes_.size() / 2; ASSERT_EQ(bytes_.size(), kHalfSize * 2); std::vector buf(kHalfSize); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); TestCompletionCallback test_callback; EXPECT_EQ(ERR_IO_PENDING, reader_->Read(wrapped_buffer, buf.size(), test_callback.callback())); EXPECT_EQ(static_cast(buf.size()), test_callback.WaitForResult()); EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); EXPECT_EQ(std::vector(bytes_.begin(), bytes_.begin() + kHalfSize), buf); EXPECT_EQ(ERR_IO_PENDING, reader_->Read(wrapped_buffer, buf.size(), test_callback.callback())); EXPECT_EQ(static_cast(buf.size()), test_callback.WaitForResult()); EXPECT_EQ(0U, reader_->BytesRemaining()); EXPECT_EQ(std::vector(bytes_.begin() + kHalfSize, bytes_.end()), buf); } TEST_F(UploadFileElementReaderTest, ReadAllAsync) { std::vector buf(bytes_.size()); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); TestCompletionCallback test_callback; EXPECT_EQ(ERR_IO_PENDING, reader_->Read(wrapped_buffer, buf.size(), test_callback.callback())); EXPECT_EQ(static_cast(buf.size()), test_callback.WaitForResult()); EXPECT_EQ(0U, reader_->BytesRemaining()); EXPECT_EQ(bytes_, buf); // Try to read again. EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); } TEST_F(UploadFileElementReaderTest, ReadTooMuchAsync) { const size_t kTooLargeSize = bytes_.size() * 2; std::vector buf(kTooLargeSize); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); TestCompletionCallback test_callback; EXPECT_EQ(ERR_IO_PENDING, reader_->Read(wrapped_buffer, buf.size(), test_callback.callback())); EXPECT_EQ(static_cast(bytes_.size()), test_callback.WaitForResult()); EXPECT_EQ(0U, reader_->BytesRemaining()); buf.resize(bytes_.size()); // Resize to compare. EXPECT_EQ(bytes_, buf); } TEST_F(UploadFileElementReaderTest, Range) { const uint64 kOffset = 2; const uint64 kLength = bytes_.size() - kOffset * 3; reader_.reset(new UploadFileElementReader( temp_file_path_, kOffset, kLength, base::Time())); ASSERT_EQ(OK, reader_->InitSync()); EXPECT_EQ(kLength, reader_->GetContentLength()); EXPECT_EQ(kLength, reader_->BytesRemaining()); std::vector buf(kLength); scoped_refptr wrapped_buffer = new WrappedIOBuffer(&buf[0]); EXPECT_EQ(static_cast(kLength), reader_->ReadSync(wrapped_buffer, kLength)); const std::vector expected(bytes_.begin() + kOffset, bytes_.begin() + kOffset + kLength); EXPECT_EQ(expected, buf); } TEST_F(UploadFileElementReaderTest, FileChanged) { base::PlatformFileInfo info; ASSERT_TRUE(file_util::GetFileInfo(temp_file_path_, &info)); // Expect one second before the actual modification time to simulate change. const base::Time expected_modification_time = info.last_modified - base::TimeDelta::FromSeconds(1); reader_.reset(new UploadFileElementReader( temp_file_path_, 0, kuint64max, expected_modification_time)); EXPECT_EQ(ERR_UPLOAD_FILE_CHANGED, reader_->InitSync()); } TEST_F(UploadFileElementReaderTest, WrongPath) { const FilePath wrong_path(FILE_PATH_LITERAL("wrong_path")); reader_.reset(new UploadFileElementReader( wrong_path, 0, kuint64max, base::Time())); ASSERT_EQ(OK, reader_->InitSync()); EXPECT_EQ(0U, reader_->GetContentLength()); EXPECT_EQ(0U, reader_->BytesRemaining()); } } // namespace net