Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(133)

Side by Side Diff: components/image_fetcher/image_data_fetcher_unittest.cc

Issue 2687873002: Use mime type for image extension (Closed)
Patch Set: Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/image_fetcher/image_data_fetcher.h" 5 #include "components/image_fetcher/image_data_fetcher.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/callback.h" 9 #include "base/callback.h"
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "base/memory/ref_counted.h" 11 #include "base/memory/ref_counted.h"
12 #include "base/message_loop/message_loop.h" 12 #include "base/message_loop/message_loop.h"
13 #include "net/http/http_response_headers.h"
13 #include "net/url_request/test_url_fetcher_factory.h" 14 #include "net/url_request/test_url_fetcher_factory.h"
14 #include "net/url_request/url_request_status.h" 15 #include "net/url_request/url_request_status.h"
15 #include "net/url_request/url_request_test_util.h" 16 #include "net/url_request/url_request_test_util.h"
16 #include "testing/gmock/include/gmock/gmock.h" 17 #include "testing/gmock/include/gmock/gmock.h"
17 #include "testing/gtest/include/gtest/gtest.h" 18 #include "testing/gtest/include/gtest/gtest.h"
18 19
19 namespace { 20 namespace {
20 21
21 const char kImageURL[] = "http://www.example.com/image"; 22 const char kImageURL[] = "http://www.example.com/image";
22 const char kURLResponseData[] = "EncodedImageData"; 23 const char kURLResponseData[] = "EncodedImageData";
23 24
24 } // namespace 25 } // namespace
25 26
26 namespace image_fetcher { 27 namespace image_fetcher {
27 28
28 class ImageDataFetcherTest : public testing::Test { 29 class ImageDataFetcherTest : public testing::Test {
29 public: 30 public:
30 ImageDataFetcherTest() 31 ImageDataFetcherTest()
31 : test_request_context_getter_( 32 : test_request_context_getter_(
32 new net::TestURLRequestContextGetter(message_loop_.task_runner())), 33 new net::TestURLRequestContextGetter(message_loop_.task_runner())),
33 image_data_fetcher_(test_request_context_getter_.get()) {} 34 image_data_fetcher_(test_request_context_getter_.get()) {}
34 ~ImageDataFetcherTest() override {} 35 ~ImageDataFetcherTest() override {}
35 36
36 MOCK_METHOD1(OnImageDataFetched, void(const std::string&)); 37 MOCK_METHOD2(OnImageDataFetched,
38 void(const std::string&, const std::string&));
37 39
38 MOCK_METHOD1(OnImageDataFetchedFailedRequest, void(const std::string&)); 40 MOCK_METHOD2(OnImageDataFetchedFailedRequest,
41 void(const std::string&, const std::string&));
39 42
40 MOCK_METHOD1(OnImageDataFetchedMultipleRequests, void(const std::string&)); 43 MOCK_METHOD2(OnImageDataFetchedMultipleRequests,
44 void(const std::string&, const std::string&));
41 45
42 protected: 46 protected:
43 base::MessageLoop message_loop_; 47 base::MessageLoop message_loop_;
44 48
45 scoped_refptr<net::URLRequestContextGetter> test_request_context_getter_; 49 scoped_refptr<net::URLRequestContextGetter> test_request_context_getter_;
46 50
47 ImageDataFetcher image_data_fetcher_; 51 ImageDataFetcher image_data_fetcher_;
48 52
49 net::TestURLFetcherFactory fetcher_factory_; 53 net::TestURLFetcherFactory fetcher_factory_;
50 54
51 private: 55 private:
52 DISALLOW_COPY_AND_ASSIGN(ImageDataFetcherTest); 56 DISALLOW_COPY_AND_ASSIGN(ImageDataFetcherTest);
53 }; 57 };
54 58
55 TEST_F(ImageDataFetcherTest, FetchImageData) { 59 TEST_F(ImageDataFetcherTest, FetchImageData) {
56 image_data_fetcher_.FetchImageData( 60 image_data_fetcher_.FetchImageData(
57 GURL(kImageURL), 61 GURL(kImageURL),
58 base::Bind(&ImageDataFetcherTest::OnImageDataFetched, 62 base::Bind(&ImageDataFetcherTest::OnImageDataFetched,
59 base::Unretained(this))); 63 base::Unretained(this)));
60 EXPECT_CALL(*this, OnImageDataFetched(std::string(kURLResponseData))); 64 EXPECT_CALL(*this, OnImageDataFetched(std::string(kURLResponseData),
65 std::string("image/gif")));
61 66
62 // Get and configure the TestURLFetcher. 67 // Get and configure the TestURLFetcher.
63 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0); 68 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0);
64 ASSERT_NE(nullptr, test_url_fetcher); 69 ASSERT_NE(nullptr, test_url_fetcher);
65 test_url_fetcher->set_status( 70 test_url_fetcher->set_status(
66 net::URLRequestStatus(net::URLRequestStatus::SUCCESS, net::OK)); 71 net::URLRequestStatus(net::URLRequestStatus::SUCCESS, net::OK));
67 test_url_fetcher->SetResponseString(kURLResponseData); 72 test_url_fetcher->SetResponseString(kURLResponseData);
68 73
74 std::string rawHeader =
Marc Treib 2017/02/09 12:34:45 raw_header
gambard 2017/02/09 13:44:12 Done.
75 "HTTP/1.1 200 OK\n"
76 "Content-type: image/gif\n\n";
77 std::replace(rawHeader.begin(), rawHeader.end(), '\n', '\0');
78 scoped_refptr<net::HttpResponseHeaders> headers(
79 new net::HttpResponseHeaders(rawHeader));
80
81 test_url_fetcher->set_response_headers(headers);
82
69 // Call the URLFetcher delegate to continue the test. 83 // Call the URLFetcher delegate to continue the test.
70 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher); 84 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher);
71 } 85 }
72 86
73 TEST_F(ImageDataFetcherTest, FetchImageData_FailedRequest) { 87 TEST_F(ImageDataFetcherTest, FetchImageData_FailedRequest) {
74 image_data_fetcher_.FetchImageData( 88 image_data_fetcher_.FetchImageData(
75 GURL(kImageURL), 89 GURL(kImageURL),
76 base::Bind(&ImageDataFetcherTest::OnImageDataFetchedFailedRequest, 90 base::Bind(&ImageDataFetcherTest::OnImageDataFetchedFailedRequest,
77 base::Unretained(this))); 91 base::Unretained(this)));
78 EXPECT_CALL(*this, OnImageDataFetchedFailedRequest(std::string())); 92 EXPECT_CALL(*this,
93 OnImageDataFetchedFailedRequest(std::string(), std::string()));
79 94
80 // Get and configure the TestURLFetcher. 95 // Get and configure the TestURLFetcher.
81 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0); 96 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0);
82 ASSERT_NE(nullptr, test_url_fetcher); 97 ASSERT_NE(nullptr, test_url_fetcher);
83 test_url_fetcher->set_status( 98 test_url_fetcher->set_status(
84 net::URLRequestStatus(net::URLRequestStatus::FAILED, 99 net::URLRequestStatus(net::URLRequestStatus::FAILED,
85 net::ERR_INVALID_URL)); 100 net::ERR_INVALID_URL));
86 101
87 // Call the URLFetcher delegate to continue the test. 102 // Call the URLFetcher delegate to continue the test.
88 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher); 103 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher);
89 } 104 }
90 105
91 TEST_F(ImageDataFetcherTest, FetchImageData_MultipleRequests) { 106 TEST_F(ImageDataFetcherTest, FetchImageData_MultipleRequests) {
92 ImageDataFetcher::ImageDataFetcherCallback callback = 107 ImageDataFetcher::ImageDataFetcherCallback callback =
93 base::Bind(&ImageDataFetcherTest::OnImageDataFetchedMultipleRequests, 108 base::Bind(&ImageDataFetcherTest::OnImageDataFetchedMultipleRequests,
94 base::Unretained(this)); 109 base::Unretained(this));
95 EXPECT_CALL(*this, OnImageDataFetchedMultipleRequests(testing::_)).Times(2); 110 EXPECT_CALL(*this, OnImageDataFetchedMultipleRequests(testing::_, testing::_))
111 .Times(2);
96 112
97 image_data_fetcher_.FetchImageData(GURL(kImageURL), callback); 113 image_data_fetcher_.FetchImageData(GURL(kImageURL), callback);
98 image_data_fetcher_.FetchImageData(GURL(kImageURL), callback); 114 image_data_fetcher_.FetchImageData(GURL(kImageURL), callback);
99 115
100 // Multiple calls to FetchImageData for the same URL will result in 116 // Multiple calls to FetchImageData for the same URL will result in
101 // multiple URLFetchers being created. 117 // multiple URLFetchers being created.
102 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0); 118 net::TestURLFetcher* test_url_fetcher = fetcher_factory_.GetFetcherByID(0);
103 ASSERT_NE(nullptr, test_url_fetcher); 119 ASSERT_NE(nullptr, test_url_fetcher);
104 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher); 120 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher);
105 121
106 test_url_fetcher = fetcher_factory_.GetFetcherByID(1); 122 test_url_fetcher = fetcher_factory_.GetFetcherByID(1);
107 ASSERT_NE(nullptr, test_url_fetcher); 123 ASSERT_NE(nullptr, test_url_fetcher);
108 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher); 124 test_url_fetcher->delegate()->OnURLFetchComplete(test_url_fetcher);
109 } 125 }
110 126
111 } // namespace image_fetcher 127 } // namespace image_fetcher
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698