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

Side by Side Diff: net/base/upload_file_element_reader_unittest.cc

Issue 10910268: net: Make UploadDataStream::Read() asynchronous (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add comments, fix a bug where IsEOF() does not get true when the buf size equals to data size Created 8 years, 2 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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);
mmenke 2012/10/16 19:13:41 Suggest a comment that some tests rely on this bei
hashimoto 2012/10/17 08:04:31 Done.
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698