// Copyright (c) 2012 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/spdy/spdy_stream_test_util.h" #include <cstddef> #include "base/stl_util.h" #include "net/base/completion_callback.h" #include "net/spdy/spdy_stream.h" #include "testing/gtest/include/gtest/gtest.h" namespace net { namespace test { ClosingDelegate::ClosingDelegate( const base::WeakPtr<SpdyStream>& stream) : stream_(stream) { DCHECK(stream_); } ClosingDelegate::~ClosingDelegate() {} void ClosingDelegate::OnRequestHeadersSent() {} SpdyResponseHeadersStatus ClosingDelegate::OnResponseHeadersUpdated( const SpdyHeaderBlock& response_headers) { return RESPONSE_HEADERS_ARE_COMPLETE; } void ClosingDelegate::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) {} void ClosingDelegate::OnDataSent() {} void ClosingDelegate::OnClose(int status) { DCHECK(stream_); stream_->Close(); // The |stream_| may still be alive (if it is our delegate). } StreamDelegateBase::StreamDelegateBase( const base::WeakPtr<SpdyStream>& stream) : stream_(stream), stream_id_(0), send_headers_completed_(false) { } StreamDelegateBase::~StreamDelegateBase() { } void StreamDelegateBase::OnRequestHeadersSent() { stream_id_ = stream_->stream_id(); EXPECT_NE(stream_id_, 0u); send_headers_completed_ = true; } SpdyResponseHeadersStatus StreamDelegateBase::OnResponseHeadersUpdated( const SpdyHeaderBlock& response_headers) { EXPECT_EQ(stream_->type() != SPDY_PUSH_STREAM, send_headers_completed_); response_headers_ = response_headers; return RESPONSE_HEADERS_ARE_COMPLETE; } void StreamDelegateBase::OnDataReceived(scoped_ptr<SpdyBuffer> buffer) { if (buffer) received_data_queue_.Enqueue(buffer.Pass()); } void StreamDelegateBase::OnDataSent() {} void StreamDelegateBase::OnClose(int status) { if (!stream_.get()) return; stream_id_ = stream_->stream_id(); stream_.reset(); callback_.callback().Run(status); } int StreamDelegateBase::WaitForClose() { int result = callback_.WaitForResult(); EXPECT_TRUE(!stream_.get()); return result; } std::string StreamDelegateBase::TakeReceivedData() { size_t len = received_data_queue_.GetTotalSize(); std::string received_data(len, '\0'); if (len > 0) { EXPECT_EQ( len, received_data_queue_.Dequeue(string_as_array(&received_data), len)); } return received_data; } std::string StreamDelegateBase::GetResponseHeaderValue( const std::string& name) const { SpdyHeaderBlock::const_iterator it = response_headers_.find(name); return (it == response_headers_.end()) ? std::string() : it->second; } StreamDelegateDoNothing::StreamDelegateDoNothing( const base::WeakPtr<SpdyStream>& stream) : StreamDelegateBase(stream) {} StreamDelegateDoNothing::~StreamDelegateDoNothing() { } StreamDelegateSendImmediate::StreamDelegateSendImmediate( const base::WeakPtr<SpdyStream>& stream, base::StringPiece data) : StreamDelegateBase(stream), data_(data) {} StreamDelegateSendImmediate::~StreamDelegateSendImmediate() { } SpdyResponseHeadersStatus StreamDelegateSendImmediate::OnResponseHeadersUpdated( const SpdyHeaderBlock& response_headers) { SpdyResponseHeadersStatus status = StreamDelegateBase::OnResponseHeadersUpdated(response_headers); if (data_.data()) { scoped_refptr<StringIOBuffer> buf(new StringIOBuffer(data_.as_string())); stream()->SendData(buf.get(), buf->size(), MORE_DATA_TO_SEND); } return status; } StreamDelegateWithBody::StreamDelegateWithBody( const base::WeakPtr<SpdyStream>& stream, base::StringPiece data) : StreamDelegateBase(stream), buf_(new StringIOBuffer(data.as_string())) {} StreamDelegateWithBody::~StreamDelegateWithBody() { } void StreamDelegateWithBody::OnRequestHeadersSent() { StreamDelegateBase::OnRequestHeadersSent(); stream()->SendData(buf_.get(), buf_->size(), NO_MORE_DATA_TO_SEND); } } // namespace test } // namespace net