| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/autofill/content/browser/wallet/wallet_signin_helper.h" | 5 #include "components/autofill/content/browser/wallet/wallet_signin_helper.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/run_loop.h" | 9 #include "base/run_loop.h" |
| 10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
| 11 #include "chrome/test/base/testing_profile.h" | 11 #include "chrome/test/base/testing_profile.h" |
| 12 #include "components/autofill/content/browser/wallet/wallet_service_url.h" | 12 #include "components/autofill/content/browser/wallet/wallet_service_url.h" |
| 13 #include "components/autofill/content/browser/wallet/wallet_signin_helper_delega
te.h" | 13 #include "components/autofill/content/browser/wallet/wallet_signin_helper_delega
te.h" |
| 14 #include "content/public/browser/storage_partition.h" |
| 14 #include "content/public/test/test_browser_thread_bundle.h" | 15 #include "content/public/test/test_browser_thread_bundle.h" |
| 15 #include "google_apis/gaia/gaia_constants.h" | 16 #include "google_apis/gaia/gaia_constants.h" |
| 16 #include "google_apis/gaia/gaia_urls.h" | 17 #include "google_apis/gaia/gaia_urls.h" |
| 17 #include "google_apis/gaia/google_service_auth_error.h" | 18 #include "google_apis/gaia/google_service_auth_error.h" |
| 18 #include "net/cookies/canonical_cookie.h" | 19 #include "net/cookies/canonical_cookie.h" |
| 19 #include "net/cookies/cookie_monster.h" | 20 #include "net/cookies/cookie_monster.h" |
| 20 #include "net/cookies/cookie_options.h" | 21 #include "net/cookies/cookie_options.h" |
| 21 #include "net/http/http_status_code.h" | 22 #include "net/http/http_status_code.h" |
| 22 #include "net/url_request/test_url_fetcher_factory.h" | 23 #include "net/url_request/test_url_fetcher_factory.h" |
| 23 #include "net/url_request/url_request.h" | 24 #include "net/url_request/url_request.h" |
| (...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 194 } | 195 } |
| 195 | 196 |
| 196 TEST_F(WalletSigninHelperTest, PassiveUserInfoFailedUserInfo) { | 197 TEST_F(WalletSigninHelperTest, PassiveUserInfoFailedUserInfo) { |
| 197 EXPECT_CALL(mock_delegate_, OnUserNameFetchFailure(_)); | 198 EXPECT_CALL(mock_delegate_, OnUserNameFetchFailure(_)); |
| 198 signin_helper_->StartUserNameFetch(); | 199 signin_helper_->StartUserNameFetch(); |
| 199 MockFailedGetAccountInfoResponse404(); | 200 MockFailedGetAccountInfoResponse404(); |
| 200 } | 201 } |
| 201 | 202 |
| 202 TEST_F(WalletSigninHelperTest, GetWalletCookieValueWhenPresent) { | 203 TEST_F(WalletSigninHelperTest, GetWalletCookieValueWhenPresent) { |
| 203 EXPECT_CALL(mock_delegate_, OnDidFetchWalletCookieValue("gdToken")); | 204 EXPECT_CALL(mock_delegate_, OnDidFetchWalletCookieValue("gdToken")); |
| 204 net::CookieMonster* cookie_monster = new net::CookieMonster(NULL, NULL); | |
| 205 net::CookieOptions httponly_options; | 205 net::CookieOptions httponly_options; |
| 206 httponly_options.set_include_httponly(); | 206 httponly_options.set_include_httponly(); |
| 207 scoped_ptr<net::CanonicalCookie> cookie( | 207 scoped_ptr<net::CanonicalCookie> cookie( |
| 208 net::CanonicalCookie::Create(GetPassiveAuthUrl().GetWithEmptyPath(), | 208 net::CanonicalCookie::Create(GetPassiveAuthUrl().GetWithEmptyPath(), |
| 209 "gdToken=gdToken; HttpOnly", | 209 "gdToken=gdToken; HttpOnly", |
| 210 base::Time::Now(), | 210 base::Time::Now(), |
| 211 httponly_options)); | 211 httponly_options)); |
| 212 | 212 |
| 213 net::CookieList cookie_list; | 213 net::CookieList cookie_list; |
| 214 cookie_list.push_back(*cookie); | 214 cookie_list.push_back(*cookie); |
| 215 |
| 216 net::CookieMonster* cookie_monster = |
| 217 content::BrowserContext::GetDefaultStoragePartition(&browser_context_)-> |
| 218 GetCookieStoreForScheme(GetPassiveAuthUrl().scheme())-> |
| 219 GetCookieMonster(); |
| 215 cookie_monster->InitializeFrom(cookie_list); | 220 cookie_monster->InitializeFrom(cookie_list); |
| 216 browser_context_.GetRequestContext()->GetURLRequestContext() | |
| 217 ->set_cookie_store(cookie_monster); | |
| 218 signin_helper_->StartWalletCookieValueFetch(); | 221 signin_helper_->StartWalletCookieValueFetch(); |
| 219 base::RunLoop().RunUntilIdle(); | 222 base::RunLoop().RunUntilIdle(); |
| 220 } | 223 } |
| 221 | 224 |
| 222 TEST_F(WalletSigninHelperTest, GetWalletCookieValueWhenMissing) { | 225 TEST_F(WalletSigninHelperTest, GetWalletCookieValueWhenMissing) { |
| 223 EXPECT_CALL(mock_delegate_, OnDidFetchWalletCookieValue(std::string())); | 226 EXPECT_CALL(mock_delegate_, OnDidFetchWalletCookieValue(std::string())); |
| 224 net::CookieMonster* cookie_monster = new net::CookieMonster(NULL, NULL); | 227 net::CookieMonster* cookie_monster = new net::CookieMonster(NULL, NULL); |
| 225 net::CookieOptions httponly_options; | 228 net::CookieOptions httponly_options; |
| 226 httponly_options.set_include_httponly(); | 229 httponly_options.set_include_httponly(); |
| 227 scoped_ptr<net::CanonicalCookie> cookie( | 230 scoped_ptr<net::CanonicalCookie> cookie( |
| 228 net::CanonicalCookie::Create(GetPassiveAuthUrl().GetWithEmptyPath(), | 231 net::CanonicalCookie::Create(GetPassiveAuthUrl().GetWithEmptyPath(), |
| 229 "fake_cookie=monkeys; HttpOnly", | 232 "fake_cookie=monkeys; HttpOnly", |
| 230 base::Time::Now(), | 233 base::Time::Now(), |
| 231 httponly_options)); | 234 httponly_options)); |
| 232 | 235 |
| 233 net::CookieList cookie_list; | 236 net::CookieList cookie_list; |
| 234 cookie_list.push_back(*cookie); | 237 cookie_list.push_back(*cookie); |
| 235 cookie_monster->InitializeFrom(cookie_list); | 238 cookie_monster->InitializeFrom(cookie_list); |
| 236 browser_context_.GetRequestContext()->GetURLRequestContext() | 239 browser_context_.GetRequestContext()->GetURLRequestContext() |
| 237 ->set_cookie_store(cookie_monster); | 240 ->set_cookie_store(cookie_monster); |
| 238 signin_helper_->StartWalletCookieValueFetch(); | 241 signin_helper_->StartWalletCookieValueFetch(); |
| 239 base::RunLoop().RunUntilIdle(); | 242 base::RunLoop().RunUntilIdle(); |
| 240 } | 243 } |
| 241 | 244 |
| 242 // TODO(aruslan): http://crbug.com/188317 Need more tests. | 245 // TODO(aruslan): http://crbug.com/188317 Need more tests. |
| 243 | 246 |
| 244 } // namespace wallet | 247 } // namespace wallet |
| 245 } // namespace autofill | 248 } // namespace autofill |
| OLD | NEW |