| 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/spdy/spdy_stream_test_util.h" | 5 #include "net/spdy/spdy_stream_test_util.h" |
| 6 | 6 |
| 7 #include <cstddef> | 7 #include <cstddef> |
| 8 | 8 |
| 9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 10 #include "net/base/completion_callback.h" | 10 #include "net/base/completion_callback.h" |
| 11 #include "net/spdy/spdy_stream.h" | 11 #include "net/spdy/spdy_stream.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 | 13 |
| 14 namespace net { | 14 namespace net { |
| 15 | 15 |
| 16 namespace test { | 16 namespace test { |
| 17 | 17 |
| 18 ClosingDelegate::ClosingDelegate( | 18 ClosingDelegate::ClosingDelegate( |
| 19 const base::WeakPtr<SpdyStream>& stream) : stream_(stream) {} | 19 const base::WeakPtr<SpdyStream>& stream) : stream_(stream) {} |
| 20 | 20 |
| 21 ClosingDelegate::~ClosingDelegate() {} | 21 ClosingDelegate::~ClosingDelegate() {} |
| 22 | 22 |
| 23 void ClosingDelegate::OnSendRequestHeadersComplete() {} | 23 void ClosingDelegate::OnRequestHeadersSent() {} |
| 24 | 24 |
| 25 void ClosingDelegate::OnSendBody() { | 25 int ClosingDelegate::OnResponseHeadersReceived(const SpdyHeaderBlock& response, |
| 26 ADD_FAILURE() << "OnSendBody should not be called"; | 26 base::Time response_time, |
| 27 } | 27 int status) { |
| 28 | |
| 29 void ClosingDelegate::OnSendBodyComplete() {} | |
| 30 | |
| 31 int ClosingDelegate::OnResponseReceived(const SpdyHeaderBlock& response, | |
| 32 base::Time response_time, | |
| 33 int status) { | |
| 34 return OK; | 28 return OK; |
| 35 } | 29 } |
| 36 | 30 |
| 37 int ClosingDelegate::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) { | 31 int ClosingDelegate::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) { |
| 38 return OK; | 32 return OK; |
| 39 } | 33 } |
| 40 | 34 |
| 41 void ClosingDelegate::OnDataSent() {} | 35 void ClosingDelegate::OnDataSent() {} |
| 42 | 36 |
| 43 void ClosingDelegate::OnClose(int status) { | 37 void ClosingDelegate::OnClose(int status) { |
| 44 DCHECK(stream_); | 38 DCHECK(stream_); |
| 45 stream_->Close(); | 39 stream_->Close(); |
| 46 DCHECK(!stream_); | 40 DCHECK(!stream_); |
| 47 } | 41 } |
| 48 | 42 |
| 49 StreamDelegateBase::StreamDelegateBase( | 43 StreamDelegateBase::StreamDelegateBase( |
| 50 const base::WeakPtr<SpdyStream>& stream) | 44 const base::WeakPtr<SpdyStream>& stream) |
| 51 : stream_(stream), | 45 : stream_(stream), |
| 52 stream_id_(0), | 46 stream_id_(0), |
| 53 send_headers_completed_(false) { | 47 send_headers_completed_(false) { |
| 54 } | 48 } |
| 55 | 49 |
| 56 StreamDelegateBase::~StreamDelegateBase() { | 50 StreamDelegateBase::~StreamDelegateBase() { |
| 57 } | 51 } |
| 58 | 52 |
| 59 void StreamDelegateBase::OnSendRequestHeadersComplete() { | 53 void StreamDelegateBase::OnRequestHeadersSent() { |
| 60 stream_id_ = stream_->stream_id(); | 54 stream_id_ = stream_->stream_id(); |
| 61 EXPECT_NE(stream_id_, 0u); | 55 EXPECT_NE(stream_id_, 0u); |
| 62 send_headers_completed_ = true; | 56 send_headers_completed_ = true; |
| 63 } | 57 } |
| 64 | 58 |
| 65 int StreamDelegateBase::OnResponseReceived(const SpdyHeaderBlock& response, | 59 int StreamDelegateBase::OnResponseHeadersReceived( |
| 66 base::Time response_time, | 60 const SpdyHeaderBlock& response, |
| 67 int status) { | 61 base::Time response_time, |
| 62 int status) { |
| 68 EXPECT_TRUE(send_headers_completed_); | 63 EXPECT_TRUE(send_headers_completed_); |
| 69 response_ = response; | 64 response_ = response; |
| 70 return status; | 65 return status; |
| 71 } | 66 } |
| 72 | 67 |
| 73 int StreamDelegateBase::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) { | 68 int StreamDelegateBase::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) { |
| 74 if (buffer) | 69 if (buffer) |
| 75 received_data_queue_.Enqueue(buffer.Pass()); | 70 received_data_queue_.Enqueue(buffer.Pass()); |
| 76 return OK; | 71 return OK; |
| 77 } | 72 } |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 109 return (it == response_.end()) ? std::string() : it->second; | 104 return (it == response_.end()) ? std::string() : it->second; |
| 110 } | 105 } |
| 111 | 106 |
| 112 StreamDelegateDoNothing::StreamDelegateDoNothing( | 107 StreamDelegateDoNothing::StreamDelegateDoNothing( |
| 113 const base::WeakPtr<SpdyStream>& stream) | 108 const base::WeakPtr<SpdyStream>& stream) |
| 114 : StreamDelegateBase(stream) {} | 109 : StreamDelegateBase(stream) {} |
| 115 | 110 |
| 116 StreamDelegateDoNothing::~StreamDelegateDoNothing() { | 111 StreamDelegateDoNothing::~StreamDelegateDoNothing() { |
| 117 } | 112 } |
| 118 | 113 |
| 119 void StreamDelegateDoNothing::OnSendBody() { | |
| 120 ADD_FAILURE() << "OnSendBody should not be called"; | |
| 121 } | |
| 122 | |
| 123 void StreamDelegateDoNothing::OnSendBodyComplete() {} | |
| 124 | |
| 125 StreamDelegateSendImmediate::StreamDelegateSendImmediate( | 114 StreamDelegateSendImmediate::StreamDelegateSendImmediate( |
| 126 const base::WeakPtr<SpdyStream>& stream, | 115 const base::WeakPtr<SpdyStream>& stream, |
| 127 base::StringPiece data) | 116 base::StringPiece data) |
| 128 : StreamDelegateBase(stream), | 117 : StreamDelegateBase(stream), |
| 129 data_(data) {} | 118 data_(data) {} |
| 130 | 119 |
| 131 StreamDelegateSendImmediate::~StreamDelegateSendImmediate() { | 120 StreamDelegateSendImmediate::~StreamDelegateSendImmediate() { |
| 132 } | 121 } |
| 133 | 122 |
| 134 void StreamDelegateSendImmediate::OnSendBody() { | 123 int StreamDelegateSendImmediate::OnResponseHeadersReceived( |
| 135 ADD_FAILURE() << "OnSendBody should not be called"; | |
| 136 } | |
| 137 | |
| 138 void StreamDelegateSendImmediate::OnSendBodyComplete() { | |
| 139 ADD_FAILURE() << "OnSendBodyComplete should not be called"; | |
| 140 } | |
| 141 | |
| 142 int StreamDelegateSendImmediate::OnResponseReceived( | |
| 143 const SpdyHeaderBlock& response, | 124 const SpdyHeaderBlock& response, |
| 144 base::Time response_time, | 125 base::Time response_time, |
| 145 int status) { | 126 int status) { |
| 146 status = | 127 status = |
| 147 StreamDelegateBase::OnResponseReceived(response, response_time, status); | 128 StreamDelegateBase::OnResponseHeadersReceived( |
| 129 response, response_time, status); |
| 148 if (data_.data()) { | 130 if (data_.data()) { |
| 149 scoped_refptr<StringIOBuffer> buf(new StringIOBuffer(data_.as_string())); | 131 scoped_refptr<StringIOBuffer> buf(new StringIOBuffer(data_.as_string())); |
| 150 stream()->SendStreamData(buf, buf->size(), MORE_DATA_TO_SEND); | 132 stream()->SendData(buf, buf->size(), MORE_DATA_TO_SEND); |
| 151 } | 133 } |
| 152 return status; | 134 return status; |
| 153 } | 135 } |
| 154 | 136 |
| 155 StreamDelegateWithBody::StreamDelegateWithBody( | 137 StreamDelegateWithBody::StreamDelegateWithBody( |
| 156 const base::WeakPtr<SpdyStream>& stream, | 138 const base::WeakPtr<SpdyStream>& stream, |
| 157 base::StringPiece data) | 139 base::StringPiece data) |
| 158 : StreamDelegateBase(stream), | 140 : StreamDelegateBase(stream), |
| 159 buf_(new StringIOBuffer(data.as_string())) {} | 141 buf_(new StringIOBuffer(data.as_string())) {} |
| 160 | 142 |
| 161 StreamDelegateWithBody::~StreamDelegateWithBody() { | 143 StreamDelegateWithBody::~StreamDelegateWithBody() { |
| 162 } | 144 } |
| 163 | 145 |
| 164 void StreamDelegateWithBody::OnSendBody() { | 146 void StreamDelegateWithBody::OnRequestHeadersSent() { |
| 165 stream()->SendStreamData(buf_.get(), buf_->size(), NO_MORE_DATA_TO_SEND); | 147 StreamDelegateBase::OnRequestHeadersSent(); |
| 148 stream()->SendData(buf_.get(), buf_->size(), NO_MORE_DATA_TO_SEND); |
| 166 } | 149 } |
| 167 | 150 |
| 168 void StreamDelegateWithBody::OnSendBodyComplete() {} | |
| 169 | |
| 170 } // namespace test | 151 } // namespace test |
| 171 | 152 |
| 172 } // namespace net | 153 } // namespace net |
| OLD | NEW |