| Index: google_apis/gcm/engine/unregistration_request_unittest.cc
|
| diff --git a/google_apis/gcm/engine/unregistration_request_unittest.cc b/google_apis/gcm/engine/unregistration_request_unittest.cc
|
| index 1c736de1ad10b2ce6738e1d4f4f68c238fda142d..9e602974df1b0d9b8bd685268a1ff9ac0f81dec9 100644
|
| --- a/google_apis/gcm/engine/unregistration_request_unittest.cc
|
| +++ b/google_apis/gcm/engine/unregistration_request_unittest.cc
|
| @@ -8,7 +8,8 @@
|
|
|
| #include "base/strings/string_number_conversions.h"
|
| #include "base/strings/string_tokenizer.h"
|
| -#include "google_apis/gcm/engine/unregistration_request.h"
|
| +#include "google_apis/gcm/engine/gcm_unregistration_request_handler.h"
|
| +#include "google_apis/gcm/engine/instance_id_delete_token_request_handler.h"
|
| #include "google_apis/gcm/monitoring/fake_gcm_stats_recorder.h"
|
| #include "net/url_request/test_url_fetcher_factory.h"
|
| #include "net/url_request/url_request_test_util.h"
|
| @@ -21,8 +22,13 @@ const uint64 kAndroidId = 42UL;
|
| const char kLoginHeader[] = "AidLogin";
|
| const char kAppId[] = "TestAppId";
|
| const char kDeletedAppId[] = "deleted=TestAppId";
|
| +const char kDeletedToken[] = "token=SomeToken";
|
| const char kRegistrationURL[] = "http://foo.bar/register";
|
| const uint64 kSecurityToken = 77UL;
|
| +const int kGCMVersion = 40;
|
| +const char kInstanceId[] = "IID1";
|
| +const char kDeveloperId[] = "Project1";
|
| +const char kScope[] = "GCM";
|
|
|
| // Backoff policy for testing registration request.
|
| const net::BackoffEntry::Policy kDefaultBackoffPolicy = {
|
| @@ -61,7 +67,6 @@ class UnregistrationRequestTest : public testing::Test {
|
|
|
| void UnregistrationCallback(UnregistrationRequest::Status status);
|
|
|
| - void CreateRequest();
|
| void SetResponseStatusAndString(net::HttpStatusCode status_code,
|
| const std::string& response_body);
|
| void CompleteFetch();
|
| @@ -90,19 +95,6 @@ void UnregistrationRequestTest::UnregistrationCallback(
|
| status_ = status;
|
| }
|
|
|
| -void UnregistrationRequestTest::CreateRequest() {
|
| - request_.reset(new UnregistrationRequest(
|
| - GURL(kRegistrationURL),
|
| - UnregistrationRequest::RequestInfo(kAndroidId,
|
| - kSecurityToken,
|
| - kAppId),
|
| - kDefaultBackoffPolicy,
|
| - base::Bind(&UnregistrationRequestTest::UnregistrationCallback,
|
| - base::Unretained(this)),
|
| - url_request_context_getter_.get(),
|
| - &recorder_));
|
| -}
|
| -
|
| void UnregistrationRequestTest::SetResponseStatusAndString(
|
| net::HttpStatusCode status_code,
|
| const std::string& response_body) {
|
| @@ -120,7 +112,37 @@ void UnregistrationRequestTest::CompleteFetch() {
|
| fetcher->delegate()->OnURLFetchComplete(fetcher);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, RequestDataPassedToFetcher) {
|
| +class GCMUnregistrationRequestTest : public UnregistrationRequestTest {
|
| + public:
|
| + GCMUnregistrationRequestTest();
|
| + ~GCMUnregistrationRequestTest() override;
|
| +
|
| + void CreateRequest();
|
| +};
|
| +
|
| +GCMUnregistrationRequestTest::GCMUnregistrationRequestTest() {
|
| +}
|
| +
|
| +GCMUnregistrationRequestTest::~GCMUnregistrationRequestTest() {
|
| +}
|
| +
|
| +void GCMUnregistrationRequestTest::CreateRequest() {
|
| + UnregistrationRequest::RequestInfo request_info(
|
| + kAndroidId, kSecurityToken, kAppId);
|
| + scoped_ptr<GCMUnregistrationRequestHandler> request_handler(
|
| + new GCMUnregistrationRequestHandler(kAppId));
|
| + request_.reset(new UnregistrationRequest(
|
| + GURL(kRegistrationURL),
|
| + request_info,
|
| + request_handler.Pass(),
|
| + kDefaultBackoffPolicy,
|
| + base::Bind(&UnregistrationRequestTest::UnregistrationCallback,
|
| + base::Unretained(this)),
|
| + url_request_context_getter_.get(),
|
| + &recorder_));
|
| +}
|
| +
|
| +TEST_F(GCMUnregistrationRequestTest, RequestDataPassedToFetcher) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -168,7 +190,7 @@ TEST_F(UnregistrationRequestTest, RequestDataPassedToFetcher) {
|
| EXPECT_EQ(0UL, expected_pairs.size());
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, SuccessfulUnregistration) {
|
| +TEST_F(GCMUnregistrationRequestTest, SuccessfulUnregistration) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -179,7 +201,7 @@ TEST_F(UnregistrationRequestTest, SuccessfulUnregistration) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, ResponseHttpStatusNotOK) {
|
| +TEST_F(GCMUnregistrationRequestTest, ResponseHttpStatusNotOK) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -190,7 +212,7 @@ TEST_F(UnregistrationRequestTest, ResponseHttpStatusNotOK) {
|
| EXPECT_EQ(UnregistrationRequest::HTTP_NOT_OK, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, ResponseEmpty) {
|
| +TEST_F(GCMUnregistrationRequestTest, ResponseEmpty) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -206,7 +228,7 @@ TEST_F(UnregistrationRequestTest, ResponseEmpty) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, InvalidParametersError) {
|
| +TEST_F(GCMUnregistrationRequestTest, InvalidParametersError) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -217,7 +239,7 @@ TEST_F(UnregistrationRequestTest, InvalidParametersError) {
|
| EXPECT_EQ(UnregistrationRequest::INVALID_PARAMETERS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, UnkwnownError) {
|
| +TEST_F(GCMUnregistrationRequestTest, UnkwnownError) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -228,7 +250,7 @@ TEST_F(UnregistrationRequestTest, UnkwnownError) {
|
| EXPECT_EQ(UnregistrationRequest::UNKNOWN_ERROR, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, ServiceUnavailable) {
|
| +TEST_F(GCMUnregistrationRequestTest, ServiceUnavailable) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -244,7 +266,7 @@ TEST_F(UnregistrationRequestTest, ServiceUnavailable) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, InternalServerError) {
|
| +TEST_F(GCMUnregistrationRequestTest, InternalServerError) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -260,7 +282,7 @@ TEST_F(UnregistrationRequestTest, InternalServerError) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, IncorrectAppId) {
|
| +TEST_F(GCMUnregistrationRequestTest, IncorrectAppId) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -276,7 +298,7 @@ TEST_F(UnregistrationRequestTest, IncorrectAppId) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| -TEST_F(UnregistrationRequestTest, ResponseParsingFailed) {
|
| +TEST_F(GCMUnregistrationRequestTest, ResponseParsingFailed) {
|
| CreateRequest();
|
| request_->Start();
|
|
|
| @@ -292,4 +314,113 @@ TEST_F(UnregistrationRequestTest, ResponseParsingFailed) {
|
| EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| }
|
|
|
| +class InstaceIDDeleteTokenRequestTest : public UnregistrationRequestTest {
|
| + public:
|
| + InstaceIDDeleteTokenRequestTest();
|
| + ~InstaceIDDeleteTokenRequestTest() override;
|
| +
|
| + void CreateRequest(const std::string& instance_id,
|
| + const std::string& authorized_entity,
|
| + const std::string& scope);
|
| +};
|
| +
|
| +InstaceIDDeleteTokenRequestTest::InstaceIDDeleteTokenRequestTest() {
|
| +}
|
| +
|
| +InstaceIDDeleteTokenRequestTest::~InstaceIDDeleteTokenRequestTest() {
|
| +}
|
| +
|
| +void InstaceIDDeleteTokenRequestTest::CreateRequest(
|
| + const std::string& instance_id,
|
| + const std::string& authorized_entity,
|
| + const std::string& scope) {
|
| + UnregistrationRequest::RequestInfo request_info(
|
| + kAndroidId, kSecurityToken, kAppId);
|
| + scoped_ptr<InstanceIDDeleteTokenRequestHandler> request_handler(
|
| + new InstanceIDDeleteTokenRequestHandler(
|
| + instance_id, authorized_entity, scope, kGCMVersion));
|
| + request_.reset(new UnregistrationRequest(
|
| + GURL(kRegistrationURL),
|
| + request_info,
|
| + request_handler.Pass(),
|
| + kDefaultBackoffPolicy,
|
| + base::Bind(&UnregistrationRequestTest::UnregistrationCallback,
|
| + base::Unretained(this)),
|
| + url_request_context_getter_.get(),
|
| + &recorder_));
|
| +}
|
| +
|
| +TEST_F(InstaceIDDeleteTokenRequestTest, RequestDataPassedToFetcher) {
|
| + CreateRequest(kInstanceId, kDeveloperId, kScope);
|
| + request_->Start();
|
| +
|
| + // Get data sent by request.
|
| + net::TestURLFetcher* fetcher = url_fetcher_factory_.GetFetcherByID(0);
|
| + ASSERT_TRUE(fetcher);
|
| +
|
| + EXPECT_EQ(GURL(kRegistrationURL), fetcher->GetOriginalURL());
|
| +
|
| + // Verify that authorization header was put together properly.
|
| + net::HttpRequestHeaders headers;
|
| + fetcher->GetExtraRequestHeaders(&headers);
|
| + std::string auth_header;
|
| + headers.GetHeader(net::HttpRequestHeaders::kAuthorization, &auth_header);
|
| + base::StringTokenizer auth_tokenizer(auth_header, " :");
|
| + ASSERT_TRUE(auth_tokenizer.GetNext());
|
| + EXPECT_EQ(kLoginHeader, auth_tokenizer.token());
|
| + ASSERT_TRUE(auth_tokenizer.GetNext());
|
| + EXPECT_EQ(base::Uint64ToString(kAndroidId), auth_tokenizer.token());
|
| + ASSERT_TRUE(auth_tokenizer.GetNext());
|
| + EXPECT_EQ(base::Uint64ToString(kSecurityToken), auth_tokenizer.token());
|
| + std::string app_id_header;
|
| + headers.GetHeader("app", &app_id_header);
|
| + EXPECT_EQ(kAppId, app_id_header);
|
| +
|
| + std::map<std::string, std::string> expected_pairs;
|
| + expected_pairs["gmsv"] = base::IntToString(kGCMVersion);
|
| + expected_pairs["app"] = kAppId;
|
| + expected_pairs["device"] = base::Uint64ToString(kAndroidId);
|
| + expected_pairs["delete"] = "true";
|
| + expected_pairs["appid"] = kInstanceId;
|
| + expected_pairs["sender"] = kDeveloperId;
|
| + expected_pairs["scope"] = kScope;
|
| +
|
| + // Verify data was formatted properly.
|
| + std::string upload_data = fetcher->upload_data();
|
| + base::StringTokenizer data_tokenizer(upload_data, "&=");
|
| + while (data_tokenizer.GetNext()) {
|
| + std::map<std::string, std::string>::iterator iter =
|
| + expected_pairs.find(data_tokenizer.token());
|
| + ASSERT_TRUE(iter != expected_pairs.end()) << data_tokenizer.token();
|
| + ASSERT_TRUE(data_tokenizer.GetNext()) << data_tokenizer.token();
|
| + EXPECT_EQ(iter->second, data_tokenizer.token());
|
| + // Ensure that none of the keys appears twice.
|
| + expected_pairs.erase(iter);
|
| + }
|
| +
|
| + EXPECT_EQ(0UL, expected_pairs.size());
|
| +}
|
| +
|
| +TEST_F(InstaceIDDeleteTokenRequestTest, SuccessfulUnregistration) {
|
| + CreateRequest(kInstanceId, kDeveloperId, kScope);
|
| + request_->Start();
|
| +
|
| + SetResponseStatusAndString(net::HTTP_OK, kDeletedToken);
|
| + CompleteFetch();
|
| +
|
| + EXPECT_TRUE(callback_called_);
|
| + EXPECT_EQ(UnregistrationRequest::SUCCESS, status_);
|
| +}
|
| +
|
| +TEST_F(InstaceIDDeleteTokenRequestTest, ResponseHttpStatusNotOK) {
|
| + CreateRequest(kInstanceId, kDeveloperId, kScope);
|
| + request_->Start();
|
| +
|
| + SetResponseStatusAndString(net::HTTP_UNAUTHORIZED, "");
|
| + CompleteFetch();
|
| +
|
| + EXPECT_TRUE(callback_called_);
|
| + EXPECT_EQ(UnregistrationRequest::HTTP_NOT_OK, status_);
|
| +}
|
| +
|
| } // namespace gcm
|
|
|