diff options
author | phajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-28 20:30:09 +0000 |
---|---|---|
committer | phajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-28 20:30:09 +0000 |
commit | c2972193bd0d0c2354d0862444b7ce4662d52d77 (patch) | |
tree | a6cbb8ce07493d2dd6aa9062f44a741e5082739a /net/ftp/ftp_ctrl_response_buffer_unittest.cc | |
parent | 1b2bb88355feef67a2b67968f0c4a91d16799e38 (diff) | |
download | chromium_src-c2972193bd0d0c2354d0862444b7ce4662d52d77.zip chromium_src-c2972193bd0d0c2354d0862444b7ce4662d52d77.tar.gz chromium_src-c2972193bd0d0c2354d0862444b7ce4662d52d77.tar.bz2 |
Rework FTP control response parsing code and fix socket Write misuse.
It also fixes other minor issues in the code, and makes ftp.vim.org work!
TEST=Visit ftp.vim.org on Linux with Chromium compiled in Debug mode. You should see directory listing after a short while.
BUG=http://crbug.com/15792
Review URL: http://codereview.chromium.org/149368
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@21881 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/ftp/ftp_ctrl_response_buffer_unittest.cc')
-rw-r--r-- | net/ftp/ftp_ctrl_response_buffer_unittest.cc | 152 |
1 files changed, 152 insertions, 0 deletions
diff --git a/net/ftp/ftp_ctrl_response_buffer_unittest.cc b/net/ftp/ftp_ctrl_response_buffer_unittest.cc new file mode 100644 index 0000000..c2aeee2 --- /dev/null +++ b/net/ftp/ftp_ctrl_response_buffer_unittest.cc @@ -0,0 +1,152 @@ +// Copyright (c) 2009 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/ftp/ftp_ctrl_response_buffer.h" + +#include <string.h> + +#include "net/base/net_errors.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace { + +class FtpCtrlResponseBufferTest : public testing::Test { + protected: + int PushDataToBuffer(const char* data) { + return buffer_.ConsumeData(data, strlen(data)); + } + + net::FtpCtrlResponseBuffer buffer_; +}; + +TEST_F(FtpCtrlResponseBufferTest, Basic) { + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("200 Status Text\r\n")); + EXPECT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(200, response.status_code); + ASSERT_EQ(1U, response.lines.size()); + EXPECT_EQ("Status Text", response.lines[0]); +} + +TEST_F(FtpCtrlResponseBufferTest, Chunks) { + EXPECT_EQ(net::OK, PushDataToBuffer("20")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(net::OK, PushDataToBuffer("0 Status")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(net::OK, PushDataToBuffer(" Text")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(net::OK, PushDataToBuffer("\r")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(net::OK, PushDataToBuffer("\n")); + EXPECT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(200, response.status_code); + ASSERT_EQ(1U, response.lines.size()); + EXPECT_EQ("Status Text", response.lines[0]); +} + +TEST_F(FtpCtrlResponseBufferTest, Continuation) { + EXPECT_EQ(net::OK, PushDataToBuffer("230-FirstLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230-SecondLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230 LastLine\r\n")); + EXPECT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(230, response.status_code); + ASSERT_EQ(3U, response.lines.size()); + EXPECT_EQ("FirstLine", response.lines[0]); + EXPECT_EQ("SecondLine", response.lines[1]); + EXPECT_EQ("LastLine", response.lines[2]); +} + +TEST_F(FtpCtrlResponseBufferTest, MultilineContinuation) { + EXPECT_EQ(net::OK, PushDataToBuffer("230-FirstLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("Continued\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230-SecondLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("215 Continued\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230 LastLine\r\n")); + EXPECT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(230, response.status_code); + ASSERT_EQ(3U, response.lines.size()); + EXPECT_EQ("FirstLineContinued", response.lines[0]); + EXPECT_EQ("SecondLine215 Continued", response.lines[1]); + EXPECT_EQ("LastLine", response.lines[2]); +} + +TEST_F(FtpCtrlResponseBufferTest, SimilarContinuation) { + EXPECT_EQ(net::OK, PushDataToBuffer("230-FirstLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + // Notice the space at the start of the line. It should be recognized + // as a continuation, and not the last line. + EXPECT_EQ(net::OK, PushDataToBuffer(" 230 Continued\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230 TrueLastLine\r\n")); + EXPECT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(230, response.status_code); + ASSERT_EQ(2U, response.lines.size()); + EXPECT_EQ("FirstLine 230 Continued", response.lines[0]); + EXPECT_EQ("TrueLastLine", response.lines[1]); +} + +// The nesting of multi-line responses is not allowed. +TEST_F(FtpCtrlResponseBufferTest, NoNesting) { + EXPECT_EQ(net::OK, PushDataToBuffer("230-FirstLine\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("300-Continuation\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("300 Still continuation\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); + + EXPECT_EQ(net::OK, PushDataToBuffer("230 Real End\r\n")); + ASSERT_TRUE(buffer_.ResponseAvailable()); + + net::FtpCtrlResponse response = buffer_.PopResponse(); + EXPECT_FALSE(buffer_.ResponseAvailable()); + EXPECT_EQ(230, response.status_code); + ASSERT_EQ(2U, response.lines.size()); + EXPECT_EQ("FirstLine300-Continuation300 Still continuation", + response.lines[0]); + EXPECT_EQ("Real End", response.lines[1]); +} + +TEST_F(FtpCtrlResponseBufferTest, NonNumericResponse) { + EXPECT_EQ(net::ERR_INVALID_RESPONSE, PushDataToBuffer("Non-numeric\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); +} + +TEST_F(FtpCtrlResponseBufferTest, OutOfRangeResponse) { + EXPECT_EQ(net::ERR_INVALID_RESPONSE, PushDataToBuffer("777 OK?\r\n")); + EXPECT_FALSE(buffer_.ResponseAvailable()); +} + +} // namespace |