Avi Drissman | 8ba1bad | 2022-09-13 19:22:36 | [diff] [blame] | 1 | // Copyright 2015 The Chromium Authors |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
Mikel Astiz | 91c345c | 2023-05-16 14:18:56 | [diff] [blame] | 5 | #include "components/sync/service/sync_stopped_reporter.h" |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 6 | |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 7 | #include "base/run_loop.h" |
Guido Urdaneta | ef4e9194 | 2020-11-09 15:06:24 | [diff] [blame] | 8 | #include "base/test/bind.h" |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 9 | #include "base/test/metrics/histogram_tester.h" |
gab | a6f7232 | 2017-03-02 00:46:14 | [diff] [blame] | 10 | #include "base/test/scoped_mock_time_message_loop_task_runner.h" |
Gabriel Charette | c710874 | 2019-08-23 03:31:40 | [diff] [blame] | 11 | #include "base/test/task_environment.h" |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 12 | #include "base/time/time.h" |
Max Bogue | fef332d | 2016-07-28 22:09:09 | [diff] [blame] | 13 | #include "components/sync/protocol/sync.pb.h" |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 14 | #include "net/http/http_status_code.h" |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 15 | #include "services/network/public/cpp/resource_request.h" |
| 16 | #include "services/network/public/cpp/shared_url_loader_factory.h" |
| 17 | #include "services/network/public/cpp/weak_wrapper_shared_url_loader_factory.h" |
| 18 | #include "services/network/test/test_url_loader_factory.h" |
John Abd-El-Malek | 2c58b14 | 2018-06-28 14:40:30 | [diff] [blame] | 19 | #include "services/network/test/test_utils.h" |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 20 | #include "testing/gtest/include/gtest/gtest.h" |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 21 | |
maxbogue | 7e006db | 2016-10-03 19:48:28 | [diff] [blame] | 22 | namespace syncer { |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 23 | |
| 24 | const char kTestURL[] = "http://chromium.org/test"; |
| 25 | const char kTestURLTrailingSlash[] = "http://chromium.org/test/"; |
| 26 | const char kEventURL[] = "http://chromium.org/test/event"; |
| 27 | |
maxbogue | b18b920 | 2015-08-11 17:52:12 | [diff] [blame] | 28 | const char kTestUserAgent[] = "the_fifth_element"; |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 29 | const char kAuthToken[] = "multipass"; |
| 30 | const char kCacheGuid[] = "leeloo"; |
| 31 | const char kBirthday[] = "2263"; |
| 32 | |
maxbogue | c5c836a | 2015-06-15 22:16:38 | [diff] [blame] | 33 | const char kAuthHeaderPrefix[] = "Bearer "; |
| 34 | |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 35 | class SyncStoppedReporterTest : public testing::Test { |
Peter Boström | 9f667c38 | 2021-10-01 20:09:31 | [diff] [blame] | 36 | public: |
| 37 | SyncStoppedReporterTest(const SyncStoppedReporterTest&) = delete; |
| 38 | SyncStoppedReporterTest& operator=(const SyncStoppedReporterTest&) = delete; |
| 39 | |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 40 | protected: |
Victor Hugo Vianna Silva | 988fe732 | 2021-09-23 18:16:56 | [diff] [blame] | 41 | SyncStoppedReporterTest() = default; |
| 42 | ~SyncStoppedReporterTest() override = default; |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 43 | |
| 44 | void SetUp() override { |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 45 | test_shared_loader_factory_ = |
| 46 | base::MakeRefCounted<network::WeakWrapperSharedURLLoaderFactory>( |
| 47 | url_loader_factory()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 48 | } |
| 49 | |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 50 | GURL interception_url(const GURL& url) { |
| 51 | return SyncStoppedReporter::GetSyncEventURL(url); |
| 52 | } |
| 53 | |
maxbogue | 455a57e3 | 2016-08-14 00:08:32 | [diff] [blame] | 54 | GURL test_url() { return GURL(kTestURL); } |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 55 | |
maxbogue | 455a57e3 | 2016-08-14 00:08:32 | [diff] [blame] | 56 | std::string user_agent() const { return std::string(kTestUserAgent); } |
maxbogue | b18b920 | 2015-08-11 17:52:12 | [diff] [blame] | 57 | |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 58 | network::TestURLLoaderFactory* url_loader_factory() { |
| 59 | return &test_url_loader_factory_; |
| 60 | } |
| 61 | |
| 62 | scoped_refptr<network::SharedURLLoaderFactory> shared_url_loader_factory() { |
| 63 | return test_shared_loader_factory_; |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 64 | } |
| 65 | |
| 66 | private: |
Gabriel Charette | 3872052 | 2019-09-10 14:14:11 | [diff] [blame] | 67 | base::test::SingleThreadTaskEnvironment task_environment_; |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 68 | network::TestURLLoaderFactory test_url_loader_factory_; |
| 69 | scoped_refptr<network::SharedURLLoaderFactory> test_shared_loader_factory_; |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 70 | }; |
| 71 | |
| 72 | // Test that the event URL gets constructed correctly. |
| 73 | TEST_F(SyncStoppedReporterTest, EventURL) { |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 74 | GURL intercepted_url; |
| 75 | url_loader_factory()->AddResponse(interception_url(GURL(kTestURL)).spec(), |
| 76 | ""); |
| 77 | url_loader_factory()->SetInterceptor( |
| 78 | base::BindLambdaForTesting([&](const network::ResourceRequest& request) { |
| 79 | intercepted_url = request.url; |
| 80 | })); |
| 81 | SyncStoppedReporter ssr(GURL(kTestURL), user_agent(), |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 82 | shared_url_loader_factory()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 83 | ssr.ReportSyncStopped(kAuthToken, kCacheGuid, kBirthday); |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 84 | EXPECT_EQ(kEventURL, intercepted_url.spec()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 85 | } |
| 86 | |
| 87 | // Test that the event URL gets constructed correctly with a trailing slash. |
| 88 | TEST_F(SyncStoppedReporterTest, EventURLWithSlash) { |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 89 | GURL intercepted_url; |
| 90 | url_loader_factory()->AddResponse( |
| 91 | interception_url(GURL(kTestURLTrailingSlash)).spec(), ""); |
| 92 | url_loader_factory()->SetInterceptor( |
| 93 | base::BindLambdaForTesting([&](const network::ResourceRequest& request) { |
| 94 | intercepted_url = request.url; |
| 95 | })); |
maxbogue | b18b920 | 2015-08-11 17:52:12 | [diff] [blame] | 96 | SyncStoppedReporter ssr(GURL(kTestURLTrailingSlash), user_agent(), |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 97 | shared_url_loader_factory()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 98 | ssr.ReportSyncStopped(kAuthToken, kCacheGuid, kBirthday); |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 99 | EXPECT_EQ(kEventURL, intercepted_url.spec()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 100 | } |
| 101 | |
| 102 | // Test that the URLFetcher gets configured correctly. |
| 103 | TEST_F(SyncStoppedReporterTest, FetcherConfiguration) { |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 104 | GURL intercepted_url; |
| 105 | net::HttpRequestHeaders intercepted_headers; |
| 106 | std::string intercepted_body; |
| 107 | url_loader_factory()->AddResponse(interception_url(test_url()).spec(), ""); |
| 108 | url_loader_factory()->SetInterceptor( |
| 109 | base::BindLambdaForTesting([&](const network::ResourceRequest& request) { |
| 110 | intercepted_url = request.url; |
| 111 | intercepted_headers = request.headers; |
John Abd-El-Malek | 2c58b14 | 2018-06-28 14:40:30 | [diff] [blame] | 112 | intercepted_body = network::GetUploadData(request); |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 113 | })); |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 114 | SyncStoppedReporter ssr(test_url(), user_agent(), |
| 115 | shared_url_loader_factory()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 116 | ssr.ReportSyncStopped(kAuthToken, kCacheGuid, kBirthday); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 117 | |
maxbogue | c5c836a | 2015-06-15 22:16:38 | [diff] [blame] | 118 | // Ensure the headers are set correctly. |
Chris Fredrickson | b5b854f | 2024-07-31 08:11:20 | [diff] [blame] | 119 | EXPECT_EQ( |
| 120 | base::StrCat({kAuthHeaderPrefix, kAuthToken}), |
| 121 | intercepted_headers.GetHeader(net::HttpRequestHeaders::kAuthorization) |
| 122 | .value_or(std::string())); |
| 123 | EXPECT_EQ(user_agent(), |
| 124 | intercepted_headers.GetHeader(net::HttpRequestHeaders::kUserAgent) |
| 125 | .value_or(std::string())); |
maxbogue | c5c836a | 2015-06-15 22:16:38 | [diff] [blame] | 126 | |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 127 | sync_pb::EventRequest event_request; |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 128 | event_request.ParseFromString(intercepted_body); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 129 | |
| 130 | EXPECT_EQ(kCacheGuid, event_request.sync_disabled().cache_guid()); |
| 131 | EXPECT_EQ(kBirthday, event_request.sync_disabled().store_birthday()); |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 132 | EXPECT_EQ(kEventURL, intercepted_url.spec()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 133 | } |
| 134 | |
| 135 | TEST_F(SyncStoppedReporterTest, HappyCase) { |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 136 | base::HistogramTester histogram_tester; |
Mark Pilgrim | 215ccf9 | 2018-06-11 22:32:19 | [diff] [blame] | 137 | url_loader_factory()->AddResponse(interception_url(test_url()).spec(), ""); |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 138 | SyncStoppedReporter ssr(test_url(), user_agent(), |
| 139 | shared_url_loader_factory()); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 140 | ssr.ReportSyncStopped(kAuthToken, kCacheGuid, kBirthday); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 141 | base::RunLoop run_loop; |
| 142 | run_loop.RunUntilIdle(); |
Victor Hugo Vianna Silva | 39fbdac | 2022-10-05 16:51:41 | [diff] [blame] | 143 | histogram_tester.ExpectUniqueSample("Sync.SyncStoppedURLFetchResponse", |
| 144 | net::HTTP_OK, 1); |
| 145 | histogram_tester.ExpectUniqueSample("Sync.SyncStoppedURLFetchTimedOut", false, |
| 146 | 1); |
maxbogue | 334611e | 2015-02-20 04:08:17 | [diff] [blame] | 147 | } |
| 148 | |
|
|