Chromium Code Reviews| Index: chrome/browser/android/data_usage/data_use_ui_tab_model_unittest.cc |
| diff --git a/chrome/browser/android/data_usage/data_use_ui_tab_model_unittest.cc b/chrome/browser/android/data_usage/data_use_ui_tab_model_unittest.cc |
| index 47ddf55444ea5b18cb57b01085df9b15cdd23616..84796e7ead3e0df14f7878d0033840f845c54d8b 100644 |
| --- a/chrome/browser/android/data_usage/data_use_ui_tab_model_unittest.cc |
| +++ b/chrome/browser/android/data_usage/data_use_ui_tab_model_unittest.cc |
| @@ -6,10 +6,18 @@ |
| #include <stdint.h> |
| +#include "base/message_loop/message_loop.h" |
| +#include "base/run_loop.h" |
| +#include "chrome/browser/android/data_usage/data_use_tab_model.h" |
| #include "chrome/browser/android/data_usage/data_use_ui_tab_model_factory.h" |
| +#include "chrome/browser/android/data_usage/external_data_use_observer.h" |
| #include "chrome/browser/profiles/profile.h" |
| #include "chrome/browser/sessions/session_tab_helper.h" |
| #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
| +#include "components/data_usage/core/data_use_aggregator.h" |
| +#include "components/data_usage/core/data_use_amortizer.h" |
| +#include "components/data_usage/core/data_use_annotator.h" |
| +#include "content/public/browser/browser_thread.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/test/test_renderer_host.h" |
| #include "content/public/test/web_contents_tester.h" |
| @@ -21,6 +29,21 @@ namespace chrome { |
| namespace android { |
| +class DataUseTabModelTest : public DataUseTabModel { |
|
sclittle
2015/11/16 23:13:43
nit: Name this TestDataUseTabModel, so that it isn
tbansal1
2015/11/17 21:12:33
Done.
|
| + public: |
| + DataUseTabModelTest(ExternalDataUseObserver* external_data_use_observer, |
| + scoped_refptr<base::SingleThreadTaskRunner> task_runner_) |
| + : DataUseTabModel(external_data_use_observer, task_runner_.get()), |
| + weak_factory_(this) {} |
| + |
| + base::WeakPtr<DataUseTabModelTest> GetWeakPtr() { |
| + return weak_factory_.GetWeakPtr(); |
| + } |
| + |
| + private: |
| + base::WeakPtrFactory<DataUseTabModelTest> weak_factory_; |
| +}; |
| + |
| class DataUseUITabModelTest : public ChromeRenderViewHostTestHarness { |
| public: |
| using ChromeRenderViewHostTestHarness::web_contents; |
| @@ -31,15 +54,100 @@ class DataUseUITabModelTest : public ChromeRenderViewHostTestHarness { |
| } |
| }; |
| -// Tests that DataUseTabModel is notified of tab closure and navigation events. |
| +// Tests that DataUseTabModel is notified of tab closure and navigation events, |
| +// and DataUseTabModel notifies DataUseUITabModel. |
| TEST_F(DataUseUITabModelTest, ReportTabEventsTest) { |
| - data_use_ui_tab_model()->ReportBrowserNavigation( |
| - GURL("https://www.example.com"), |
| - ui::PageTransition::PAGE_TRANSITION_TYPED, |
| - SessionTabHelper::IdForTab(web_contents())); |
| - data_use_ui_tab_model()->ReportTabClosure( |
| - SessionTabHelper::IdForTab(web_contents())); |
| - // TODO(tbansal): Test that DataUseTabModel is notified. |
| + std::string foo_label("foo_label"); |
| + |
| + scoped_refptr<base::SingleThreadTaskRunner> io_task_runner = |
| + content::BrowserThread::GetMessageLoopProxyForThread( |
| + content::BrowserThread::IO); |
| + scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner = |
| + content::BrowserThread::GetMessageLoopProxyForThread( |
| + content::BrowserThread::UI); |
| + |
| + scoped_ptr<data_usage::DataUseAggregator> data_use_aggregator( |
|
sclittle
2015/11/16 23:13:42
nit: This doesn't have to be a scoped_ptr, this co
tbansal1
2015/11/17 21:12:33
Done.
|
| + new data_usage::DataUseAggregator( |
| + scoped_ptr<data_usage::DataUseAnnotator>(), |
| + scoped_ptr<data_usage::DataUseAmortizer>())); |
| + |
| + scoped_ptr<ExternalDataUseObserver> external_data_use_observer( |
|
sclittle
2015/11/16 23:13:43
nit: same here, this doesn't need to be a scoped_p
tbansal1
2015/11/17 21:12:33
Done.
|
| + new ExternalDataUseObserver(data_use_aggregator.get(), |
| + io_task_runner.get(), ui_task_runner.get())); |
| + base::RunLoop().RunUntilIdle(); |
| + std::vector<std::string> url_regexes; |
| + url_regexes.push_back( |
| + "http://www[.]foo[.]com/#q=.*|https://www[.]foo[.]com/#q=.*"); |
| + external_data_use_observer->RegisterURLRegexes( |
| + std::vector<std::string>(url_regexes.size(), std::string()), url_regexes, |
| + std::vector<std::string>(url_regexes.size(), foo_label)); |
| + |
| + DataUseTabModelTest data_use_tab_model( |
| + external_data_use_observer.get(), |
| + content::BrowserThread::GetMessageLoopProxyForThread( |
| + content::BrowserThread::IO)); |
| + data_use_ui_tab_model()->SetIODataUseTabModel( |
| + data_use_tab_model.GetWeakPtr()); |
| + data_use_ui_tab_model()->SetUIDataUseTabModel( |
| + data_use_tab_model.GetWeakPtr()); |
| + |
| + const struct { |
| + ui::PageTransition transition_type; |
| + std::string expected_label; |
| + } tests[] = { |
| + {ui::PageTransitionFromInt(ui::PageTransition::PAGE_TRANSITION_LINK | |
| + ui::PAGE_TRANSITION_FROM_API), |
| + std::string()}, |
| + {ui::PageTransition::PAGE_TRANSITION_LINK, std::string()}, |
| + {ui::PageTransition::PAGE_TRANSITION_TYPED, foo_label}, |
| + {ui::PageTransition::PAGE_TRANSITION_AUTO_BOOKMARK, std::string()}, |
| + {ui::PageTransition::PAGE_TRANSITION_AUTO_TOPLEVEL, std::string()}, |
| + {ui::PageTransition::PAGE_TRANSITION_GENERATED, foo_label}, |
| + {ui::PageTransition::PAGE_TRANSITION_RELOAD, std::string()}, |
| + }; |
| + |
| + for (size_t i = 0; i < arraysize(tests); ++i) { |
| + // Start a new tab. |
| + int32_t foo_tab_id = i + 1; |
| + data_use_ui_tab_model()->ReportBrowserNavigation( |
| + GURL("https://www.foo.com/#q=abc"), tests[i].transition_type, |
| + foo_tab_id); |
| + base::RunLoop().RunUntilIdle(); |
| + |
| + // |data_use_ui_tab_model| should receive callback about starting of |
| + // tracking of data usage for |foo_tab_id|. |
| + EXPECT_EQ(!tests[i].expected_label.empty(), |
| + data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)) |
| + << i; |
| + EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)) |
| + << i; |
| + EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)) |
| + << i; |
| + |
| + // DataUse object should be labeled correctly. |
| + data_usage::DataUse data_use(GURL("http://foo.com/#q=abc"), |
|
sclittle
2015/11/16 23:13:42
Add an include for data_use.h
tbansal1
2015/11/17 21:12:33
Done.
|
| + base::TimeTicks::Now(), |
| + GURL("http://foobar.com"), foo_tab_id, |
| + net::NetworkChangeNotifier::CONNECTION_UNKNOWN, |
|
sclittle
2015/11/16 23:13:42
nit: Pull this DataUse creation and the DataUse cr
tbansal1
2015/11/17 21:12:33
Reduced it to one function call.
|
| + std::string(), 1000, 1000); |
| + std::string got_label; |
| + data_use_tab_model.GetLabelForDataUse(data_use, &got_label); |
| + EXPECT_EQ(tests[i].expected_label, got_label) << i; |
| + |
| + // Report closure of tab. |
| + data_use_ui_tab_model()->ReportTabClosure(foo_tab_id); |
| + base::RunLoop().RunUntilIdle(); |
| + |
| + // DataUse object should not be labeled. |
| + data_usage::DataUse data_use_expired( |
| + GURL("http://foo.com/#q=abc"), base::TimeTicks::Now(), |
|
sclittle
2015/11/16 23:13:43
base::TimeTicks::Now() could be the same as it was
tbansal1
2015/11/17 21:12:33
Done.
|
| + GURL("http://foobar.com"), foo_tab_id, |
| + net::NetworkChangeNotifier::CONNECTION_UNKNOWN, std::string(), 1000, |
| + 1000); |
| + |
| + data_use_tab_model.GetLabelForDataUse(data_use_expired, &got_label); |
| + EXPECT_EQ(std::string(), got_label) << i; |
| + } |
| } |
| // Tests if the Entrance/Exit UI state is tracked correctly. |
| @@ -48,8 +156,8 @@ TEST_F(DataUseUITabModelTest, EntranceExitState) { |
| int32_t bar_tab_id = 2; |
| int32_t baz_tab_id = 3; |
| - // ShowEntrance should return true only once. |
| - data_use_ui_tab_model()->OnTrackingStarted(foo_tab_id); |
| + // HasDataUseTrackingStarted should return true only once. |
| + data_use_ui_tab_model()->NotifyTrackingStarting(foo_tab_id); |
| EXPECT_TRUE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)); |
| @@ -57,30 +165,30 @@ TEST_F(DataUseUITabModelTest, EntranceExitState) { |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(bar_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(bar_tab_id)); |
| - // ShowExit should return true only once. |
| - data_use_ui_tab_model()->OnTrackingEnded(foo_tab_id); |
| + // HasDataUseTrackingEnded should return true only once. |
| + data_use_ui_tab_model()->NotifyTrackingEnding(foo_tab_id); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| EXPECT_TRUE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| // The tab enters the tracking state again. |
| - data_use_ui_tab_model()->OnTrackingStarted(foo_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingStarting(foo_tab_id); |
| EXPECT_TRUE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| // The tab exits the tracking state. |
| - data_use_ui_tab_model()->OnTrackingEnded(foo_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingEnding(foo_tab_id); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| // The tab enters the tracking state again. |
| - data_use_ui_tab_model()->OnTrackingStarted(foo_tab_id); |
| - data_use_ui_tab_model()->OnTrackingStarted(foo_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingStarting(foo_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingStarting(foo_tab_id); |
| EXPECT_TRUE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
| // ShowExit should return true only once. |
| - data_use_ui_tab_model()->OnTrackingEnded(bar_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingEnding(bar_tab_id); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(bar_tab_id)); |
| EXPECT_TRUE(data_use_ui_tab_model()->HasDataUseTrackingEnded(bar_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(bar_tab_id)); |
| @@ -90,12 +198,72 @@ TEST_F(DataUseUITabModelTest, EntranceExitState) { |
| data_use_ui_tab_model()->ReportTabClosure(bar_tab_id); |
| // HasDataUseTrackingStarted/Ended should return false for closed tabs. |
| - data_use_ui_tab_model()->OnTrackingStarted(baz_tab_id); |
| + data_use_ui_tab_model()->NotifyTrackingStarting(baz_tab_id); |
| data_use_ui_tab_model()->ReportTabClosure(baz_tab_id); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(baz_tab_id)); |
| EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(baz_tab_id)); |
| } |
| +// Checks if page transition type is converted correctly. |
| +TEST_F(DataUseUITabModelTest, ConvertTransitionType) { |
| + DataUseTabModel::TransitionType transition_type; |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_TYPED), &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_NAVIGATION, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_TYPED | 0xFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_NAVIGATION, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_TYPED | 0xFFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_NAVIGATION, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_TYPED | 0x12FFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_NAVIGATION, transition_type); |
| + |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_AUTO_BOOKMARK), &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_BOOKMARK, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_AUTO_BOOKMARK | 0xFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_BOOKMARK, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_AUTO_BOOKMARK | 0xFFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_BOOKMARK, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_AUTO_BOOKMARK | 0x12FFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_BOOKMARK, transition_type); |
| + |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_GENERATED), &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_SEARCH, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_GENERATED | 0xFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_SEARCH, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_GENERATED | 0xFFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_SEARCH, transition_type); |
| + EXPECT_TRUE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_GENERATED | 0x12FFFF00), |
| + &transition_type)); |
| + EXPECT_EQ(DataUseTabModel::TRANSITION_OMNIBOX_SEARCH, transition_type); |
| + |
| + EXPECT_FALSE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_AUTO_SUBFRAME), &transition_type)); |
| + EXPECT_FALSE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_MANUAL_SUBFRAME), |
| + &transition_type)); |
| + EXPECT_FALSE(data_use_ui_tab_model()->ConvertTransitionType( |
| + ui::PageTransition(ui::PAGE_TRANSITION_FORM_SUBMIT), &transition_type)); |
| +} |
| + |
| } // namespace android |
| } // namespace chrome |