| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677 | #include "HttpResponse.h"#include <iostream>#include <cppunit/extensions/HelperMacros.h>#include "TestUtil.h"#include "prefs.h"#include "PiecedSegment.h"#include "Piece.h"#include "Request.h"#include "HttpHeader.h"#include "HttpRequest.h"#include "Exception.h"#include "A2STR.h"#include "DlRetryEx.h"#include "CookieStorage.h"#include "AuthConfigFactory.h"#include "AuthConfig.h"#include "StreamFilter.h"#include "MetalinkHttpEntry.h"#include "Option.h"#include "Checksum.h"namespace aria2 {class HttpResponseTest : public CppUnit::TestFixture {  CPPUNIT_TEST_SUITE(HttpResponseTest);  CPPUNIT_TEST(testGetContentLength_null);  CPPUNIT_TEST(testGetContentLength_contentLength);  //CPPUNIT_TEST(testGetContentLength_range);  CPPUNIT_TEST(testGetEntityLength);  CPPUNIT_TEST(testGetContentType);  CPPUNIT_TEST(testDetermineFilename_without_ContentDisposition);  CPPUNIT_TEST(testDetermineFilename_with_ContentDisposition_zero_length);  CPPUNIT_TEST(testDetermineFilename_with_ContentDisposition);  CPPUNIT_TEST(testGetRedirectURI_without_Location);  CPPUNIT_TEST(testGetRedirectURI_with_Location);  CPPUNIT_TEST(testIsRedirect);  CPPUNIT_TEST(testIsTransferEncodingSpecified);  CPPUNIT_TEST(testGetTransferEncoding);  CPPUNIT_TEST(testGetTransferEncodingStreamFilter);  CPPUNIT_TEST(testIsContentEncodingSpecified);  CPPUNIT_TEST(testGetContentEncoding);  CPPUNIT_TEST(testGetContentEncodingStreamFilter);  CPPUNIT_TEST(testValidateResponse);  CPPUNIT_TEST(testValidateResponse_good_range);  CPPUNIT_TEST(testValidateResponse_bad_range);  CPPUNIT_TEST(testValidateResponse_chunked);  CPPUNIT_TEST(testValidateResponse_withIfModifiedSince);  CPPUNIT_TEST(testProcessRedirect);  CPPUNIT_TEST(testRetrieveCookie);  CPPUNIT_TEST(testSupportsPersistentConnection);  CPPUNIT_TEST(testGetMetalinKHttpEntries);#ifdef ENABLE_MESSAGE_DIGEST  CPPUNIT_TEST(testGetDigest);#endif // ENABLE_MESSAGE_DIGEST  CPPUNIT_TEST_SUITE_END();private:public:  void setUp() {  }  void testGetContentLength_null();  void testGetContentLength_contentLength();  void testGetEntityLength();  void testGetContentType();  void testDetermineFilename_without_ContentDisposition();  void testDetermineFilename_with_ContentDisposition_zero_length();  void testDetermineFilename_with_ContentDisposition();  void testGetRedirectURI_without_Location();  void testGetRedirectURI_with_Location();  void testIsRedirect();  void testIsTransferEncodingSpecified();  void testGetTransferEncoding();  void testGetTransferEncodingStreamFilter();  void testIsContentEncodingSpecified();  void testGetContentEncoding();  void testGetContentEncodingStreamFilter();  void testValidateResponse();  void testValidateResponse_good_range();  void testValidateResponse_bad_range();  void testValidateResponse_chunked();  void testValidateResponse_withIfModifiedSince();  void testProcessRedirect();  void testRetrieveCookie();  void testSupportsPersistentConnection();  void testGetMetalinKHttpEntries();#ifdef ENABLE_MESSAGE_DIGEST  void testGetDigest();#endif // ENABLE_MESSAGE_DIGEST};CPPUNIT_TEST_SUITE_REGISTRATION( HttpResponseTest );void HttpResponseTest::testGetContentLength_null(){  HttpResponse httpResponse;  CPPUNIT_ASSERT_EQUAL((int64_t)0LL, httpResponse.getContentLength());}void HttpResponseTest::testGetContentLength_contentLength(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::CONTENT_LENGTH, "4294967296");  httpResponse.setHttpHeader(std::move(httpHeader));  CPPUNIT_ASSERT_EQUAL((int64_t)4294967296LL, httpResponse.getContentLength());}void HttpResponseTest::testGetEntityLength(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::CONTENT_LENGTH, "4294967296");  httpResponse.setHttpHeader(std::move(httpHeader));  CPPUNIT_ASSERT_EQUAL((int64_t)4294967296LL, httpResponse.getEntityLength());  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_RANGE,                                    "bytes 1-4294967296/4294967297");  CPPUNIT_ASSERT_EQUAL((int64_t)4294967297LL, httpResponse.getEntityLength());}void HttpResponseTest::testGetContentType(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::CONTENT_TYPE,                  "application/metalink+xml; charset=UTF-8");  httpResponse.setHttpHeader(std::move(httpHeader));  // See paramter is ignored.  CPPUNIT_ASSERT_EQUAL(std::string("application/metalink+xml"),                       httpResponse.getContentType());}void HttpResponseTest::testDetermineFilename_without_ContentDisposition(){  HttpResponse httpResponse;  auto httpRequest = make_unique<HttpRequest>();  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.setHttpRequest(std::move(httpRequest));  CPPUNIT_ASSERT_EQUAL(std::string("aria2-1.0.0.tar.bz2"),                       httpResponse.determineFilename());}void HttpResponseTest::testDetermineFilename_with_ContentDisposition_zero_length(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::CONTENT_DISPOSITION, "attachment; filename=\"\"");  auto httpRequest = make_unique<HttpRequest>();  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpHeader(std::move(httpHeader));  httpResponse.setHttpRequest(std::move(httpRequest));  CPPUNIT_ASSERT_EQUAL(std::string("aria2-1.0.0.tar.bz2"),                       httpResponse.determineFilename());}void HttpResponseTest::testDetermineFilename_with_ContentDisposition(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::CONTENT_DISPOSITION,                  "attachment; filename=\"aria2-current.tar.bz2\"");  auto httpRequest = make_unique<HttpRequest>();  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpHeader(std::move(httpHeader));  httpResponse.setHttpRequest(std::move(httpRequest));  CPPUNIT_ASSERT_EQUAL(std::string("aria2-current.tar.bz2"),                       httpResponse.determineFilename());}void HttpResponseTest::testGetRedirectURI_without_Location(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT_EQUAL(std::string(""),                       httpResponse.getRedirectURI());}void HttpResponseTest::testGetRedirectURI_with_Location(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->put(HttpHeader::LOCATION,                  "http://localhost/download/aria2-1.0.0.tar.bz2");  httpResponse.setHttpHeader(std::move(httpHeader));  CPPUNIT_ASSERT_EQUAL    (std::string("http://localhost/download/aria2-1.0.0.tar.bz2"),     httpResponse.getRedirectURI());}void HttpResponseTest::testIsRedirect(){  HttpResponse httpResponse;  auto httpHeader = make_unique<HttpHeader>();  httpHeader->setStatusCode(200);  httpHeader->put(HttpHeader::LOCATION,                  "http://localhost/download/aria2-1.0.0.tar.bz2");  httpResponse.setHttpHeader(std::move(httpHeader));  CPPUNIT_ASSERT(!httpResponse.isRedirect());  httpResponse.getHttpHeader()->setStatusCode(301);  CPPUNIT_ASSERT(httpResponse.isRedirect());}void HttpResponseTest::testIsTransferEncodingSpecified(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT(!httpResponse.isTransferEncodingSpecified());  httpResponse.getHttpHeader()->put(HttpHeader::TRANSFER_ENCODING, "chunked");  CPPUNIT_ASSERT(httpResponse.isTransferEncodingSpecified());}void HttpResponseTest::testGetTransferEncoding(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT_EQUAL(std::string(""), httpResponse.getTransferEncoding());  httpResponse.getHttpHeader()->put(HttpHeader::TRANSFER_ENCODING, "chunked");  CPPUNIT_ASSERT_EQUAL(std::string("chunked"),                       httpResponse.getTransferEncoding());}void HttpResponseTest::testGetTransferEncodingStreamFilter(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT(!httpResponse.getTransferEncodingStreamFilter());  httpResponse.getHttpHeader()->put(HttpHeader::TRANSFER_ENCODING, "chunked");  CPPUNIT_ASSERT(httpResponse.getTransferEncodingStreamFilter());}void HttpResponseTest::testIsContentEncodingSpecified(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT(!httpResponse.isContentEncodingSpecified());  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_ENCODING, "gzip");  CPPUNIT_ASSERT(httpResponse.isContentEncodingSpecified());}void HttpResponseTest::testGetContentEncoding(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT_EQUAL(A2STR::NIL, httpResponse.getContentEncoding());  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_ENCODING, "gzip");  CPPUNIT_ASSERT_EQUAL(std::string("gzip"), httpResponse.getContentEncoding());}void HttpResponseTest::testGetContentEncodingStreamFilter(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  CPPUNIT_ASSERT(!httpResponse.getContentEncodingStreamFilter());#ifdef HAVE_ZLIB  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_ENCODING, "gzip");  {    std::shared_ptr<StreamFilter> filter =      httpResponse.getContentEncodingStreamFilter();    CPPUNIT_ASSERT(filter);    CPPUNIT_ASSERT_EQUAL(std::string("GZipDecodingStreamFilter"),                         filter->getName());  }  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_ENCODING, "deflate");  {    std::shared_ptr<StreamFilter> filter =      httpResponse.getContentEncodingStreamFilter();    CPPUNIT_ASSERT(filter);    CPPUNIT_ASSERT_EQUAL(std::string("GZipDecodingStreamFilter"),                         filter->getName());  }#endif // HAVE_ZLIB  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_ENCODING, "bzip2");  {    std::shared_ptr<StreamFilter> filter =      httpResponse.getContentEncodingStreamFilter();    CPPUNIT_ASSERT(!filter);  }}void HttpResponseTest::testValidateResponse(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.getHttpHeader()->setStatusCode(301);  try {    httpResponse.validateResponse();    CPPUNIT_FAIL("exception must be thrown.");  } catch(Exception& e) {  }  httpResponse.getHttpHeader()->put    (HttpHeader::LOCATION,     "http://localhost/archives/aria2-1.0.0.tar.bz2");  try {    httpResponse.validateResponse();  } catch(Exception& e) {    CPPUNIT_FAIL("exception must not be thrown.");  }}void HttpResponseTest::testValidateResponse_good_range(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  auto httpRequest = make_unique<HttpRequest>();  auto p = std::make_shared<Piece>(1, 1024*1024);  auto segment = std::make_shared<PiecedSegment>(1024*1024, p);  httpRequest->setSegment(segment);  auto fileEntry = std::make_shared<FileEntry>("file", 1024*1024*10, 0);  httpRequest->setFileEntry(fileEntry);  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->setStatusCode(206);  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_RANGE,                                    "bytes 1048576-10485760/10485760");  try {    httpResponse.validateResponse();  } catch(Exception& e) {    std::cerr << e.stackTrace() << std::endl;    CPPUNIT_FAIL("exception must not be thrown.");  }}void HttpResponseTest::testValidateResponse_bad_range(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  auto httpRequest = make_unique<HttpRequest>();  auto p = std::make_shared<Piece>(1, 1024*1024);  auto segment = std::make_shared<PiecedSegment>(1024*1024, p);  httpRequest->setSegment(segment);  auto fileEntry = std::make_shared<FileEntry>("file", 1024*1024*10, 0);  httpRequest->setFileEntry(fileEntry);  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->setStatusCode(206);  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_RANGE,                                    "bytes 0-10485760/10485761");  try {    httpResponse.validateResponse();    CPPUNIT_FAIL("exception must be thrown.");  } catch(Exception& e) {  }}void HttpResponseTest::testValidateResponse_chunked(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  auto httpRequest = make_unique<HttpRequest>();  auto p = std::make_shared<Piece>(1, 1024*1024);  auto segment = std::make_shared<PiecedSegment>(1024*1024, p);  httpRequest->setSegment(segment);  auto fileEntry = std::make_shared<FileEntry>("file", 1024*1024*10, 0);  httpRequest->setFileEntry(fileEntry);  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->setStatusCode(206);  httpResponse.getHttpHeader()->put(HttpHeader::CONTENT_RANGE,                                    "bytes 0-10485760/10485761");  httpResponse.getHttpHeader()->put(HttpHeader::TRANSFER_ENCODING, "chunked");  // if transfer-encoding is specified, then range validation is skipped.  try {    httpResponse.validateResponse();  } catch(Exception& e) {    CPPUNIT_FAIL("exception must not be thrown.");  }}void HttpResponseTest::testValidateResponse_withIfModifiedSince(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.getHttpHeader()->setStatusCode(304);  auto httpRequest = make_unique<HttpRequest>();  httpResponse.setHttpRequest(std::move(httpRequest));  try {    httpResponse.validateResponse();    CPPUNIT_FAIL("exception must be thrown.");  } catch(Exception& e) {  }  httpRequest = make_unique<HttpRequest>();  httpRequest->setIfModifiedSinceHeader("Fri, 16 Jul 2010 12:56:59 GMT");  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.validateResponse();}void HttpResponseTest::testProcessRedirect(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  auto httpRequest = make_unique<HttpRequest>();  auto request = std::make_shared<Request>();  request->setUri("http://localhost/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->put(HttpHeader::LOCATION,                                    "http://mirror/aria2-1.0.0.tar.bz2");  httpResponse.processRedirect();  httpResponse.getHttpHeader()->clearField();  // Test for percent-encode  httpResponse.getHttpHeader()->put(HttpHeader::LOCATION,                                    "http://example.org/white space#aria2");  httpResponse.processRedirect();  CPPUNIT_ASSERT_EQUAL(std::string("http://example.org/white%20space"),                       request->getCurrentUri());  httpResponse.getHttpHeader()->clearField();  // Give unsupported scheme  httpResponse.getHttpHeader()->put    (HttpHeader::LOCATION, "unsupported://mirror/aria2-1.0.0.tar.bz2");  try {    httpResponse.processRedirect();    CPPUNIT_FAIL("DlRetryEx exception must be thrown.");  } catch(DlRetryEx& e) {    // Success  } catch(...) {    CPPUNIT_FAIL("DlRetryEx exception must be thrown.");  }}void HttpResponseTest::testRetrieveCookie(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  auto httpRequest = make_unique<HttpRequest>();  auto request = std::make_shared<Request>();  request->setUri("http://www.aria2.org/archives/aria2-1.0.0.tar.bz2");  httpRequest->setRequest(request);  CookieStorage  st;  httpRequest->setCookieStorage(&st);  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->put    (HttpHeader::SET_COOKIE,     "k1=v1; expires=Sun, 10-Jun-2007 11:00:00 GMT;"     "path=/; domain=.aria2.org;");  httpResponse.getHttpHeader()->put    (HttpHeader::SET_COOKIE,     "k2=v2; expires=Sun, 01-Jan-38 00:00:00 GMT;"     "path=/; domain=.aria2.org;");  httpResponse.getHttpHeader()->put(HttpHeader::SET_COOKIE, "k3=v3;");  httpResponse.retrieveCookie();  CPPUNIT_ASSERT_EQUAL((size_t)2, st.size());  auto cookies = std::vector<const Cookie*>{};  st.dumpCookie(std::back_inserter(cookies));  std::sort(std::begin(cookies), std::end(cookies), CookieSorter());  CPPUNIT_ASSERT_EQUAL(std::string("k2=v2"), cookies[0]->toString());  CPPUNIT_ASSERT_EQUAL(std::string("k3=v3"), cookies[1]->toString());}void HttpResponseTest::testSupportsPersistentConnection(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  httpResponse.setHttpRequest(make_unique<HttpRequest>());  httpResponse.getHttpHeader()->setVersion("HTTP/1.1");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "close");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "keep-alive");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->setVersion("HTTP/1.0");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "close");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "keep-alive");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  // test proxy connection  auto httpRequest = make_unique<HttpRequest>();  httpRequest->setProxyRequest(std::make_shared<Request>());  httpResponse.setHttpRequest(std::move(httpRequest));  httpResponse.getHttpHeader()->setVersion("HTTP/1.1");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "close");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "keep-alive");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->setVersion("HTTP/1.0");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "close");  CPPUNIT_ASSERT(!httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();  httpResponse.getHttpHeader()->put(HttpHeader::CONNECTION, "keep-alive");  CPPUNIT_ASSERT(httpResponse.supportsPersistentConnection());  httpResponse.getHttpHeader()->clearField();}void HttpResponseTest::testGetMetalinKHttpEntries(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  std::shared_ptr<Option> option(new Option());  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://uri1/>; rel=duplicate; pri=1; pref; geo=JP");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://uri2/>; rel=duplicate");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://uri3/>;;;;;;;;rel=duplicate;;;;;pri=2;;;;;");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://uri4/>;rel=duplicate;=pri=1;pref");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://describedby>; rel=describedby");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<http://norel/>");  httpResponse.getHttpHeader()->put    (HttpHeader::LINK,     "<baduri>; rel=duplicate; pri=-1;");  std::vector<MetalinkHttpEntry> result;  httpResponse.getMetalinKHttpEntries(result, option);  CPPUNIT_ASSERT_EQUAL((size_t)5, result.size());  MetalinkHttpEntry e = result[0];  CPPUNIT_ASSERT_EQUAL(std::string("http://uri1/"), e.uri);  CPPUNIT_ASSERT_EQUAL(1, e.pri);  CPPUNIT_ASSERT(e.pref);  CPPUNIT_ASSERT_EQUAL(std::string("jp"), e.geo);  e = result[1];  CPPUNIT_ASSERT_EQUAL(std::string("http://uri4/"), e.uri);  CPPUNIT_ASSERT_EQUAL(999999, e.pri);  CPPUNIT_ASSERT(e.pref);  CPPUNIT_ASSERT(e.geo.empty());  e = result[2];  CPPUNIT_ASSERT_EQUAL(std::string("http://uri3/"), e.uri);  CPPUNIT_ASSERT_EQUAL(2, e.pri);  CPPUNIT_ASSERT(!e.pref);  CPPUNIT_ASSERT(e.geo.empty());  e = result[3];  CPPUNIT_ASSERT_EQUAL(std::string("http://uri2/"), e.uri);  CPPUNIT_ASSERT_EQUAL(999999, e.pri);  CPPUNIT_ASSERT(!e.pref);  CPPUNIT_ASSERT(e.geo.empty());  e = result[4];  CPPUNIT_ASSERT_EQUAL(std::string("baduri"), e.uri);  CPPUNIT_ASSERT_EQUAL(999999, e.pri);  CPPUNIT_ASSERT(!e.pref);  CPPUNIT_ASSERT(e.geo.empty());}#ifdef ENABLE_MESSAGE_DIGESTvoid HttpResponseTest::testGetDigest(){  HttpResponse httpResponse;  httpResponse.setHttpHeader(make_unique<HttpHeader>());  std::shared_ptr<Option> option(new Option());  // Python binascii.hexlify(base64.b64decode(B64ED_HASH)) is handy to  // retrieve ascii hex hash string.  httpResponse.getHttpHeader()->put(HttpHeader::DIGEST,                                    "SHA-1=82AD8itGL/oYQ5BTPFANiYnp9oE=");  httpResponse.getHttpHeader()->put(HttpHeader::DIGEST, "NOT_SUPPORTED");  httpResponse.getHttpHeader()->put    (HttpHeader::DIGEST,     "SHA-224=rQdowoLHQJTMVZ3rF7vmYOIzUXlu7F+FcMbPnA==");  httpResponse.getHttpHeader()->put    (HttpHeader::DIGEST,     "SHA-224=6Ik6LNZ1iPy6cbmlKO4NHfvxzaiurmHilMyhGA==");  httpResponse.getHttpHeader()->put    (HttpHeader::DIGEST,     "SHA-256=+D8nGudz3G/kpkVKQeDrI3xD57v0UeQmzGCZOk03nsU=,"     "MD5=LJDK2+9ClF8Nz/K5WZd/+A==");  std::vector<Checksum> result;  httpResponse.getDigest(result);#ifdef USE_INTERNAL_MD  CPPUNIT_ASSERT_EQUAL((size_t)2, result.size());#else  CPPUNIT_ASSERT_EQUAL((size_t)3, result.size());#endif  Checksum c = result[0];#ifndef USE_INTERNAL_MD  CPPUNIT_ASSERT_EQUAL(std::string("sha-256"), c.getHashType());  CPPUNIT_ASSERT_EQUAL(std::string("f83f271ae773dc6fe4a6454a41e0eb237c43e7bbf451e426cc60993a4d379ec5"),                       util::toHex(c.getDigest()));  c = result[1];#endif  CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), c.getHashType());  CPPUNIT_ASSERT_EQUAL(std::string("f36003f22b462ffa184390533c500d8989e9f681"),                       util::toHex(c.getDigest()));}#endif // ENABLE_MESSAGE_DIGEST} // namespace aria2
 |