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)); |
(...skipping 16 matching lines...) Expand all Loading... |
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; |
45 std::vector<char> buf(kHalfSize); | 47 std::vector<char> buf(kHalfSize); |
| 48 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
46 EXPECT_EQ(static_cast<int>(buf.size()), | 49 EXPECT_EQ(static_cast<int>(buf.size()), |
47 reader_->ReadSync(&buf[0], buf.size())); | 50 reader_->ReadSync(wrapped_buffer, buf.size())); |
48 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); | 51 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); |
49 bytes_.resize(kHalfSize); // Resize to compare. | 52 bytes_.resize(kHalfSize); // Resize to compare. |
50 EXPECT_EQ(bytes_, buf); | 53 EXPECT_EQ(bytes_, buf); |
51 } | 54 } |
52 | 55 |
53 TEST_F(UploadFileElementReaderTest, ReadAll) { | 56 TEST_F(UploadFileElementReaderTest, ReadAll) { |
54 std::vector<char> buf(bytes_.size()); | 57 std::vector<char> buf(bytes_.size()); |
| 58 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
55 EXPECT_EQ(static_cast<int>(buf.size()), | 59 EXPECT_EQ(static_cast<int>(buf.size()), |
56 reader_->ReadSync(&buf[0], buf.size())); | 60 reader_->ReadSync(wrapped_buffer, buf.size())); |
57 EXPECT_EQ(0U, reader_->BytesRemaining()); | 61 EXPECT_EQ(0U, reader_->BytesRemaining()); |
58 EXPECT_EQ(bytes_, buf); | 62 EXPECT_EQ(bytes_, buf); |
59 // Try to read again. | 63 // Try to read again. |
60 EXPECT_EQ(0, reader_->ReadSync(&buf[0], buf.size())); | 64 EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); |
61 } | 65 } |
62 | 66 |
63 TEST_F(UploadFileElementReaderTest, ReadTooMuch) { | 67 TEST_F(UploadFileElementReaderTest, ReadTooMuch) { |
64 const size_t kTooLargeSize = bytes_.size() * 2; | 68 const size_t kTooLargeSize = bytes_.size() * 2; |
65 std::vector<char> buf(kTooLargeSize); | 69 std::vector<char> buf(kTooLargeSize); |
| 70 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
66 EXPECT_EQ(static_cast<int>(bytes_.size()), | 71 EXPECT_EQ(static_cast<int>(bytes_.size()), |
67 reader_->ReadSync(&buf[0], buf.size())); | 72 reader_->ReadSync(wrapped_buffer, buf.size())); |
68 EXPECT_EQ(0U, reader_->BytesRemaining()); | 73 EXPECT_EQ(0U, reader_->BytesRemaining()); |
69 buf.resize(bytes_.size()); // Resize to compare. | 74 buf.resize(bytes_.size()); // Resize to compare. |
70 EXPECT_EQ(bytes_, buf); | 75 EXPECT_EQ(bytes_, buf); |
| 76 } |
| 77 |
| 78 TEST_F(UploadFileElementReaderTest, ReadPartiallyAsync) { |
| 79 const size_t kHalfSize = bytes_.size() / 2; |
| 80 std::vector<char> buf(kHalfSize); |
| 81 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 82 TestCompletionCallback test_callback; |
| 83 EXPECT_EQ(ERR_IO_PENDING, |
| 84 reader_->Read(wrapped_buffer, buf.size(), |
| 85 test_callback.callback())); |
| 86 |
| 87 EXPECT_EQ(static_cast<int>(buf.size()), test_callback.WaitForResult()); |
| 88 EXPECT_EQ(bytes_.size() - buf.size(), reader_->BytesRemaining()); |
| 89 bytes_.resize(kHalfSize); // Resize to compare. |
| 90 EXPECT_EQ(bytes_, buf); |
| 91 } |
| 92 |
| 93 TEST_F(UploadFileElementReaderTest, ReadAllAsync) { |
| 94 std::vector<char> buf(bytes_.size()); |
| 95 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 96 TestCompletionCallback test_callback; |
| 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(bytes_, buf); |
| 104 // Try to read again. |
| 105 EXPECT_EQ(0, reader_->ReadSync(wrapped_buffer, buf.size())); |
| 106 } |
| 107 |
| 108 TEST_F(UploadFileElementReaderTest, ReadTooMuchAsync) { |
| 109 const size_t kTooLargeSize = bytes_.size() * 2; |
| 110 std::vector<char> buf(kTooLargeSize); |
| 111 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
| 112 TestCompletionCallback test_callback; |
| 113 EXPECT_EQ(ERR_IO_PENDING, |
| 114 reader_->Read(wrapped_buffer, buf.size(), |
| 115 test_callback.callback())); |
| 116 |
| 117 EXPECT_EQ(static_cast<int>(bytes_.size()), test_callback.WaitForResult()); |
| 118 EXPECT_EQ(0U, reader_->BytesRemaining()); |
| 119 buf.resize(bytes_.size()); // Resize to compare. |
| 120 EXPECT_EQ(bytes_, buf); |
71 } | 121 } |
72 | 122 |
73 TEST_F(UploadFileElementReaderTest, Range) { | 123 TEST_F(UploadFileElementReaderTest, Range) { |
74 const uint64 kOffset = 2; | 124 const uint64 kOffset = 2; |
75 const uint64 kLength = bytes_.size() - kOffset * 3; | 125 const uint64 kLength = bytes_.size() - kOffset * 3; |
76 reader_.reset(new UploadFileElementReader( | 126 reader_.reset(new UploadFileElementReader( |
77 temp_file_path_, kOffset, kLength, base::Time())); | 127 temp_file_path_, kOffset, kLength, base::Time())); |
78 ASSERT_EQ(OK, reader_->InitSync()); | 128 ASSERT_EQ(OK, reader_->InitSync()); |
79 EXPECT_EQ(kLength, reader_->GetContentLength()); | 129 EXPECT_EQ(kLength, reader_->GetContentLength()); |
80 EXPECT_EQ(kLength, reader_->BytesRemaining()); | 130 EXPECT_EQ(kLength, reader_->BytesRemaining()); |
81 std::vector<char> buf(kLength); | 131 std::vector<char> buf(kLength); |
| 132 scoped_refptr<IOBuffer> wrapped_buffer = new WrappedIOBuffer(&buf[0]); |
82 EXPECT_EQ(static_cast<int>(kLength), | 133 EXPECT_EQ(static_cast<int>(kLength), |
83 reader_->ReadSync(&buf[0], kLength)); | 134 reader_->ReadSync(wrapped_buffer, kLength)); |
84 const std::vector<char> expected(bytes_.begin() + kOffset, | 135 const std::vector<char> expected(bytes_.begin() + kOffset, |
85 bytes_.begin() + kOffset + kLength); | 136 bytes_.begin() + kOffset + kLength); |
86 EXPECT_EQ(expected, buf); | 137 EXPECT_EQ(expected, buf); |
87 } | 138 } |
88 | 139 |
89 TEST_F(UploadFileElementReaderTest, FileChanged) { | 140 TEST_F(UploadFileElementReaderTest, FileChanged) { |
90 base::PlatformFileInfo info; | 141 base::PlatformFileInfo info; |
91 ASSERT_TRUE(file_util::GetFileInfo(temp_file_path_, &info)); | 142 ASSERT_TRUE(file_util::GetFileInfo(temp_file_path_, &info)); |
92 | 143 |
93 // Expect one second before the actual modification time to simulate change. | 144 // Expect one second before the actual modification time to simulate change. |
94 const base::Time expected_modification_time = | 145 const base::Time expected_modification_time = |
95 info.last_modified - base::TimeDelta::FromSeconds(1); | 146 info.last_modified - base::TimeDelta::FromSeconds(1); |
96 reader_.reset(new UploadFileElementReader( | 147 reader_.reset(new UploadFileElementReader( |
97 temp_file_path_, 0, kuint64max, expected_modification_time)); | 148 temp_file_path_, 0, kuint64max, expected_modification_time)); |
98 EXPECT_EQ(ERR_UPLOAD_FILE_CHANGED, reader_->InitSync()); | 149 EXPECT_EQ(ERR_UPLOAD_FILE_CHANGED, reader_->InitSync()); |
99 } | 150 } |
100 | 151 |
101 TEST_F(UploadFileElementReaderTest, WrongPath) { | 152 TEST_F(UploadFileElementReaderTest, WrongPath) { |
102 const FilePath wrong_path(FILE_PATH_LITERAL("wrong_path")); | 153 const FilePath wrong_path(FILE_PATH_LITERAL("wrong_path")); |
103 reader_.reset(new UploadFileElementReader( | 154 reader_.reset(new UploadFileElementReader( |
104 wrong_path, 0, kuint64max, base::Time())); | 155 wrong_path, 0, kuint64max, base::Time())); |
105 ASSERT_EQ(OK, reader_->InitSync()); | 156 ASSERT_EQ(OK, reader_->InitSync()); |
106 EXPECT_EQ(0U, reader_->GetContentLength()); | 157 EXPECT_EQ(0U, reader_->GetContentLength()); |
107 EXPECT_EQ(0U, reader_->BytesRemaining()); | 158 EXPECT_EQ(0U, reader_->BytesRemaining()); |
108 } | 159 } |
109 | 160 |
110 } // namespace net | 161 } // namespace net |
OLD | NEW |