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); | |
mmenke
2012/10/12 21:30:29
How about reading the rest of the file, too, in a
hashimoto
2012/10/15 11:21:37
Done for both ReadPartially and ReadPartiallyAsync
| |
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 |