OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "net/base/upload_file_element_reader.h" | 5 #include "net/base/upload_file_element_reader.h" |
6 | 6 |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "base/scoped_temp_dir.h" | 8 #include "base/scoped_temp_dir.h" |
| 9 #include "net/base/io_buffer.h" |
9 #include "net/base/net_errors.h" | 10 #include "net/base/net_errors.h" |
| 11 #include "net/base/test_completion_callback.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
11 #include "testing/platform_test.h" | 13 #include "testing/platform_test.h" |
12 | 14 |
13 namespace net { | 15 namespace net { |
14 | 16 |
15 class UploadFileElementReaderTest : public PlatformTest { | 17 class UploadFileElementReaderTest : public PlatformTest { |
16 protected: | 18 protected: |
17 virtual void SetUp() OVERRIDE { | 19 virtual void SetUp() OVERRIDE { |
18 const char kData[] = "123456789abcdefghi"; | 20 const char kData[] = "123456789abcdefghi"; |
19 bytes_.assign(kData, kData + arraysize(kData)); | 21 bytes_.assign(kData, kData + arraysize(kData) - 1); |
20 | 22 |
21 ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); | 23 ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); |
22 | 24 |
23 ASSERT_TRUE(file_util::CreateTemporaryFileInDir(temp_dir_.path(), | 25 ASSERT_TRUE(file_util::CreateTemporaryFileInDir(temp_dir_.path(), |
24 &temp_file_path_)); | 26 &temp_file_path_)); |
25 ASSERT_EQ( | 27 ASSERT_EQ( |
26 static_cast<int>(bytes_.size()), | 28 static_cast<int>(bytes_.size()), |
27 file_util::WriteFile(temp_file_path_, &bytes_[0], bytes_.size())); | 29 file_util::WriteFile(temp_file_path_, &bytes_[0], bytes_.size())); |
28 | 30 |
29 reader_.reset(new UploadFileElementReader( | 31 reader_.reset(new UploadFileElementReader( |
30 temp_file_path_, 0, kuint64max, base::Time())); | 32 temp_file_path_, 0, kuint64max, base::Time())); |
31 ASSERT_EQ(OK, reader_->InitSync()); | 33 ASSERT_EQ(OK, reader_->InitSync()); |
32 EXPECT_EQ(bytes_.size(), reader_->GetContentLength()); | 34 EXPECT_EQ(bytes_.size(), reader_->GetContentLength()); |
33 EXPECT_EQ(bytes_.size(), reader_->BytesRemaining()); | 35 EXPECT_EQ(bytes_.size(), reader_->BytesRemaining()); |
34 EXPECT_FALSE(reader_->IsInMemory()); | 36 EXPECT_FALSE(reader_->IsInMemory()); |
35 } | 37 } |
36 | 38 |
37 std::vector<char> bytes_; | 39 std::vector<char> bytes_; |
38 scoped_ptr<UploadElementReader> reader_; | 40 scoped_ptr<UploadElementReader> reader_; |
39 ScopedTempDir temp_dir_; | 41 ScopedTempDir temp_dir_; |
40 FilePath temp_file_path_; | 42 FilePath temp_file_path_; |
41 }; | 43 }; |
42 | 44 |
43 TEST_F(UploadFileElementReaderTest, ReadPartially) { | 45 TEST_F(UploadFileElementReaderTest, ReadPartially) { |
44 const size_t kHalfSize = bytes_.size() / 2; | 46 const size_t kHalfSize = bytes_.size() / 2; |
| 47 ASSERT_EQ(bytes_.size(), kHalfSize * 2); |
45 std::vector<char> buf(kHalfSize); | 48 std::vector<char> buf(kHalfSize); |
| 49 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
46 EXPECT_EQ(static_cast<int>(buf.size()), | 50 EXPECT_EQ(static_cast<int>(buf.size()), |
47 reader_->ReadSync(&buf[0], buf.size())); | 51 reader_->ReadSync(wrapped_buffer, buf.size())); |
48 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); | 52 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); |
49 bytes_.resize(kHalfSize); // Resize to compare. | 53 EXPECT_EQ(std::vector<char>(bytes_.begin(), bytes_.begin() + kHalfSize), buf); |
50 EXPECT_EQ(bytes_, buf); | 54 |
| 55 EXPECT_EQ(static_cast<int>(buf.size()), |
| 56 reader_->ReadSync(wrapped_buffer, buf.size())); |
| 57 EXPECT_EQ(0U, reader_->BytesRemaining()); |
| 58 EXPECT_EQ(std::vector<char>(bytes_.begin() + kHalfSize, bytes_.end()), buf); |
51 } | 59 } |
52 | 60 |
53 TEST_F(UploadFileElementReaderTest, ReadAll) { | 61 TEST_F(UploadFileElementReaderTest, ReadAll) { |
54 std::vector<char> buf(bytes_.size()); | 62 std::vector<char> buf(bytes_.size()); |
| 63 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
55 EXPECT_EQ(static_cast<int>(buf.size()), | 64 EXPECT_EQ(static_cast<int>(buf.size()), |
56 reader_->ReadSync(&buf[0], buf.size())); | 65 reader_->ReadSync(wrapped_buffer, buf.size())); |
57 EXPECT_EQ(0U, reader_->BytesRemaining()); | 66 EXPECT_EQ(0U, reader_->BytesRemaining()); |
58 EXPECT_EQ(bytes_, buf); | 67 EXPECT_EQ(bytes_, buf); |
59 // Try to read again. | 68 // Try to read again. |
60 EXPECT_EQ(0, reader_->ReadSync(&buf[0], buf.size())); | 69 EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); |
61 } | 70 } |
62 | 71 |
63 TEST_F(UploadFileElementReaderTest, ReadTooMuch) { | 72 TEST_F(UploadFileElementReaderTest, ReadTooMuch) { |
64 const size_t kTooLargeSize = bytes_.size() * 2; | 73 const size_t kTooLargeSize = bytes_.size() * 2; |
65 std::vector<char> buf(kTooLargeSize); | 74 std::vector<char> buf(kTooLargeSize); |
| 75 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
66 EXPECT_EQ(static_cast<int>(bytes_.size()), | 76 EXPECT_EQ(static_cast<int>(bytes_.size()), |
67 reader_->ReadSync(&buf[0], buf.size())); | 77 reader_->ReadSync(wrapped_buffer, buf.size())); |
68 EXPECT_EQ(0U, reader_->BytesRemaining()); | 78 EXPECT_EQ(0U, reader_->BytesRemaining()); |
69 buf.resize(bytes_.size()); // Resize to compare. | 79 buf.resize(bytes_.size()); // Resize to compare. |
70 EXPECT_EQ(bytes_, buf); | 80 EXPECT_EQ(bytes_, buf); |
| 81 } |
| 82 |
| 83 TEST_F(UploadFileElementReaderTest, ReadPartiallyAsync) { |
| 84 const size_t kHalfSize = bytes_.size() / 2; |
| 85 ASSERT_EQ(bytes_.size(), kHalfSize * 2); |
| 86 std::vector<char> buf(kHalfSize); |
| 87 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 88 TestCompletionCallback test_callback; |
| 89 EXPECT_EQ(ERR_IO_PENDING, |
| 90 reader_->Read(wrapped_buffer, buf.size(), |
| 91 test_callback.callback())); |
| 92 |
| 93 EXPECT_EQ(static_cast<int>(buf.size()), test_callback.WaitForResult()); |
| 94 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); |
| 95 EXPECT_EQ(std::vector<char>(bytes_.begin(), bytes_.begin() + kHalfSize), buf); |
| 96 |
| 97 EXPECT_EQ(ERR_IO_PENDING, |
| 98 reader_->Read(wrapped_buffer, buf.size(), |
| 99 test_callback.callback())); |
| 100 |
| 101 EXPECT_EQ(static_cast<int>(buf.size()), test_callback.WaitForResult()); |
| 102 EXPECT_EQ(0U, reader_->BytesRemaining()); |
| 103 EXPECT_EQ(std::vector<char>(bytes_.begin() + kHalfSize, bytes_.end()), buf); |
| 104 } |
| 105 |
| 106 TEST_F(UploadFileElementReaderTest, ReadAllAsync) { |
| 107 std::vector<char> buf(bytes_.size()); |
| 108 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 109 TestCompletionCallback test_callback; |
| 110 EXPECT_EQ(ERR_IO_PENDING, |
| 111 reader_->Read(wrapped_buffer, buf.size(), |
| 112 test_callback.callback())); |
| 113 |
| 114 EXPECT_EQ(static_cast<int>(buf.size()), test_callback.WaitForResult()); |
| 115 EXPECT_EQ(0U, reader_->BytesRemaining()); |
| 116 EXPECT_EQ(bytes_, buf); |
| 117 // Try to read again. |
| 118 EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); |
| 119 } |
| 120 |
| 121 TEST_F(UploadFileElementReaderTest, ReadTooMuchAsync) { |
| 122 const size_t kTooLargeSize = bytes_.size() * 2; |
| 123 std::vector<char> buf(kTooLargeSize); |
| 124 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 125 TestCompletionCallback test_callback; |
| 126 EXPECT_EQ(ERR_IO_PENDING, |
| 127 reader_->Read(wrapped_buffer, buf.size(), |
| 128 test_callback.callback())); |
| 129 |
| 130 EXPECT_EQ(static_cast<int>(bytes_.size()), test_callback.WaitForResult()); |
| 131 EXPECT_EQ(0U, reader_->BytesRemaining()); |
| 132 buf.resize(bytes_.size()); // Resize to compare. |
| 133 EXPECT_EQ(bytes_, buf); |
71 } | 134 } |
72 | 135 |
73 TEST_F(UploadFileElementReaderTest, Range) { | 136 TEST_F(UploadFileElementReaderTest, Range) { |
74 const uint64 kOffset = 2; | 137 const uint64 kOffset = 2; |
75 const uint64 kLength = bytes_.size() - kOffset * 3; | 138 const uint64 kLength = bytes_.size() - kOffset * 3; |
76 reader_.reset(new UploadFileElementReader( | 139 reader_.reset(new UploadFileElementReader( |
77 temp_file_path_, kOffset, kLength, base::Time())); | 140 temp_file_path_, kOffset, kLength, base::Time())); |
78 ASSERT_EQ(OK, reader_->InitSync()); | 141 ASSERT_EQ(OK, reader_->InitSync()); |
79 EXPECT_EQ(kLength, reader_->GetContentLength()); | 142 EXPECT_EQ(kLength, reader_->GetContentLength()); |
80 EXPECT_EQ(kLength, reader_->BytesRemaining()); | 143 EXPECT_EQ(kLength, reader_->BytesRemaining()); |
81 std::vector<char> buf(kLength); | 144 std::vector<char> buf(kLength); |
| 145 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
82 EXPECT_EQ(static_cast<int>(kLength), | 146 EXPECT_EQ(static_cast<int>(kLength), |
83 reader_->ReadSync(&buf[0], kLength)); | 147 reader_->ReadSync(wrapped_buffer, kLength)); |
84 const std::vector<char> expected(bytes_.begin() + kOffset, | 148 const std::vector<char> expected(bytes_.begin() + kOffset, |
85 bytes_.begin() + kOffset + kLength); | 149 bytes_.begin() + kOffset + kLength); |
86 EXPECT_EQ(expected, buf); | 150 EXPECT_EQ(expected, buf); |
87 } | 151 } |
88 | 152 |
89 TEST_F(UploadFileElementReaderTest, FileChanged) { | 153 TEST_F(UploadFileElementReaderTest, FileChanged) { |
90 base::PlatformFileInfo info; | 154 base::PlatformFileInfo info; |
91 ASSERT_TRUE(file_util::GetFileInfo(temp_file_path_, &info)); | 155 ASSERT_TRUE(file_util::GetFileInfo(temp_file_path_, &info)); |
92 | 156 |
93 // Expect one second before the actual modification time to simulate change. | 157 // Expect one second before the actual modification time to simulate change. |
94 const base::Time expected_modification_time = | 158 const base::Time expected_modification_time = |
95 info.last_modified - base::TimeDelta::FromSeconds(1); | 159 info.last_modified - base::TimeDelta::FromSeconds(1); |
96 reader_.reset(new UploadFileElementReader( | 160 reader_.reset(new UploadFileElementReader( |
97 temp_file_path_, 0, kuint64max, expected_modification_time)); | 161 temp_file_path_, 0, kuint64max, expected_modification_time)); |
98 EXPECT_EQ(ERR_UPLOAD_FILE_CHANGED, reader_->InitSync()); | 162 EXPECT_EQ(ERR_UPLOAD_FILE_CHANGED, reader_->InitSync()); |
99 } | 163 } |
100 | 164 |
101 TEST_F(UploadFileElementReaderTest, WrongPath) { | 165 TEST_F(UploadFileElementReaderTest, WrongPath) { |
102 const FilePath wrong_path(FILE_PATH_LITERAL("wrong_path")); | 166 const FilePath wrong_path(FILE_PATH_LITERAL("wrong_path")); |
103 reader_.reset(new UploadFileElementReader( | 167 reader_.reset(new UploadFileElementReader( |
104 wrong_path, 0, kuint64max, base::Time())); | 168 wrong_path, 0, kuint64max, base::Time())); |
105 ASSERT_EQ(OK, reader_->InitSync()); | 169 ASSERT_EQ(OK, reader_->InitSync()); |
106 EXPECT_EQ(0U, reader_->GetContentLength()); | 170 EXPECT_EQ(0U, reader_->GetContentLength()); |
107 EXPECT_EQ(0U, reader_->BytesRemaining()); | 171 EXPECT_EQ(0U, reader_->BytesRemaining()); |
108 } | 172 } |
109 | 173 |
110 } // namespace net | 174 } // namespace net |
OLD | NEW |