Chromium Code Reviews| Index: webkit/media/test_response_generator.cc |
| diff --git a/webkit/media/test_response_generator.cc b/webkit/media/test_response_generator.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..631dc51a724aa0ad18e94853801aab6e4b6b335b |
| --- /dev/null |
| +++ b/webkit/media/test_response_generator.cc |
| @@ -0,0 +1,84 @@ |
| +// Copyright (c) 2011 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 "webkit/media/test_response_generator.h" |
| + |
| +#include "base/format_macros.h" |
| +#include "base/string_number_conversions.h" |
| +#include "base/stringprintf.h" |
| +#include "net/base/net_errors.h" |
| +#include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h" |
| +#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLResponse.h" |
| + |
| +using WebKit::WebString; |
| +using WebKit::WebURLError; |
| +using WebKit::WebURLResponse; |
| + |
| +namespace webkit_media { |
| + |
| +TestResponseGenerator::TestResponseGenerator(const GURL& gurl, |
| + int64 content_length) |
| + : gurl_(gurl), |
| + content_length_(content_length) { |
| +} |
| + |
| +WebURLError TestResponseGenerator::GenerateError() { |
| + WebURLError error; |
| + error.reason = net::ERR_ABORTED; |
| + error.domain = WebString::fromUTF8(net::kErrorDomain); |
| + return error; |
| +} |
| + |
| +WebURLResponse TestResponseGenerator::Generate200() { |
| + WebURLResponse response(gurl_); |
| + response.setHTTPStatusCode(200); |
| + |
| + response.setHTTPHeaderField( |
| + WebString::fromUTF8("Content-Length"), |
| + WebString::fromUTF8(base::Int64ToString(content_length_))); |
| + response.setExpectedContentLength(content_length_); |
| + return response; |
| +} |
| + |
| +WebURLResponse TestResponseGenerator::Generate206(int64 first_byte_offset) { |
| + return Generate206(first_byte_offset, kNormal); |
| +} |
| + |
| +WebURLResponse TestResponseGenerator::Generate206(int64 first_byte_offset, |
| + Flags flags) { |
|
Ami GONE FROM CHROMIUM
2011/11/24 01:20:38
indent
scherkus (not reviewing)
2011/11/28 18:30:47
Done.
|
| + int64 range_content_length = content_length_ - first_byte_offset; |
| + int64 last_byte_offset = content_length_ - 1; |
| + |
| + WebURLResponse response(gurl_); |
| + response.setHTTPStatusCode(206); |
| + |
| + if ((flags & kNoAcceptRanges) == 0) { |
| + response.setHTTPHeaderField(WebString::fromUTF8("Accept-Ranges"), |
| + WebString::fromUTF8("bytes")); |
| + } |
| + |
| + if ((flags & kNoContentRange) == 0) { |
| + std::string content_range = base::StringPrintf( |
| + "bytes %" PRId64 "-%" PRId64 "/%" PRId64, |
| + first_byte_offset, last_byte_offset, content_length_); |
| + response.setHTTPHeaderField(WebString::fromUTF8("Content-Range"), |
| + WebString::fromUTF8(content_range)); |
| + } |
| + |
| + if ((flags & kNoContentLength) == 0) { |
| + response.setHTTPHeaderField( |
| + WebString::fromUTF8("Content-Length"), |
| + WebString::fromUTF8(base::Int64ToString(range_content_length))); |
| + response.setExpectedContentLength(range_content_length); |
| + } |
| + return response; |
| +} |
| + |
| +WebURLResponse TestResponseGenerator::Generate404() { |
| + WebURLResponse response(gurl_); |
| + response.setHTTPStatusCode(404); |
| + return response; |
| +} |
| + |
| +} // namespace webkit_media |