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..d10cbb46714efc1f92528bf60f9c40b9a3eb393c 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,13 +6,21 @@ |
#include <stdint.h> |
+#include "base/run_loop.h" |
+#include "base/single_thread_task_runner.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.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" |
#include "testing/gtest/include/gtest/gtest.h" |
#include "ui/base/page_transition_types.h" |
#include "url/gurl.h" |
@@ -21,35 +29,174 @@ namespace chrome { |
namespace android { |
+namespace { |
+ |
+class TestDataUseTabModel : public DataUseTabModel { |
+ public: |
+ TestDataUseTabModel( |
+ ExternalDataUseObserver* external_data_use_observer, |
+ scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner) |
+ : DataUseTabModel(external_data_use_observer, ui_task_runner) {} |
+ |
+ ~TestDataUseTabModel() override {} |
+ |
+ using DataUseTabModel::NotifyObserversOfTrackingStarting; |
+ using DataUseTabModel::NotifyObserversOfTrackingEnding; |
+}; |
+ |
+// Base this class off ChromeRenderViewHostTestHarness so that |web_contents| is |
+// accessible. |
class DataUseUITabModelTest : public ChromeRenderViewHostTestHarness { |
sclittle
2015/11/25 22:49:11
As per our discussion offline, you don't actually
tbansal1
2015/11/26 00:31:21
Creating DataUseUITabModel object directly, althou
sclittle
2015/11/30 22:33:38
OK, then can you use a TestingProfile instead, lik
|
public: |
- using ChromeRenderViewHostTestHarness::web_contents; |
+ DataUseUITabModel* data_use_ui_tab_model() { return data_use_ui_tab_model_; } |
+ |
+ ExternalDataUseObserver* external_data_use_observer() const { |
+ return external_data_use_observer_.get(); |
+ } |
+ |
+ TestDataUseTabModel* data_use_tab_model() const { |
+ return data_use_tab_model_.get(); |
+ } |
- DataUseUITabModel* data_use_ui_tab_model() { |
- return chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
- Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
+ protected: |
+ void SetUp() override { |
+ ChromeRenderViewHostTestHarness::SetUp(); |
+ |
+ data_use_ui_tab_model_ = |
+ chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
+ Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
+ |
+ io_task_runner_ = content::BrowserThread::GetMessageLoopProxyForThread( |
+ content::BrowserThread::IO); |
+ ui_task_runner_ = content::BrowserThread::GetMessageLoopProxyForThread( |
+ content::BrowserThread::UI); |
+ |
+ data_use_aggregator_.reset( |
+ new data_usage::DataUseAggregator(nullptr, nullptr)); |
+ |
+ external_data_use_observer_.reset(new ExternalDataUseObserver( |
+ data_use_aggregator_.get(), io_task_runner_, ui_task_runner_)); |
+ // Wait for |external_data_use_observer_| to create the Java object. |
+ base::RunLoop().RunUntilIdle(); |
+ |
+ data_use_tab_model_.reset( |
+ new TestDataUseTabModel(external_data_use_observer(), ui_task_runner_)); |
+ data_use_tab_model_->AddObserver(data_use_ui_tab_model()->GetWeakPtr()); |
+ data_use_ui_tab_model_->SetDataUseTabModel( |
+ data_use_tab_model_->GetWeakPtr()); |
} |
+ |
+ private: |
+ using ChromeRenderViewHostTestHarness::web_contents; |
+ |
+ DataUseUITabModel* data_use_ui_tab_model_; |
+ scoped_refptr<base::SingleThreadTaskRunner> io_task_runner_; |
+ scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner_; |
+ scoped_ptr<data_usage::DataUseAggregator> data_use_aggregator_; |
+ scoped_ptr<ExternalDataUseObserver> external_data_use_observer_; |
+ scoped_ptr<TestDataUseTabModel> data_use_tab_model_; |
}; |
-// Tests that DataUseTabModel is notified of tab closure and navigation events. |
+} // namespace |
+ |
+// 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"); |
sclittle
2015/11/25 22:49:11
nit: Make these and the other variables like these
tbansal1
2015/11/26 00:31:21
Done.
|
+ std::string foo_package("com.foo"); |
+ |
+ 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(), foo_package), url_regexes, |
+ std::vector<std::string>(url_regexes.size(), foo_label)); |
+ |
+ 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()}, |
+ }; |
+ |
+ SessionID::id_type foo_tab_id = 0; |
sclittle
2015/11/25 22:49:11
nit: use a non-zero tab ID, e.g. 100, so that this
tbansal1
2015/11/26 00:31:21
Done, but 0 is a valid tab id.
|
+ |
+ for (size_t i = 0; i < arraysize(tests); ++i) { |
+ // Start a new tab. |
+ ++foo_tab_id; |
+ data_use_ui_tab_model()->ReportBrowserNavigation( |
+ GURL("https://www.foo.com/#q=abc"), tests[i].transition_type, |
+ foo_tab_id); |
+ // Wait for DataUseUITabModel to notify DataUseTabModel, which should notify |
+ // DataUseUITabModel back. |
+ 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"), |
+ base::TimeTicks::Now(), |
+ GURL("http://foobar.com"), foo_tab_id, |
+ net::NetworkChangeNotifier::CONNECTION_UNKNOWN, |
+ 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. |
+ EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)); |
+ data_use.request_start = |
+ base::TimeTicks::Now() + base::TimeDelta::FromMinutes(10); |
+ data_use_tab_model()->GetLabelForDataUse(data_use, &got_label); |
+ EXPECT_EQ(std::string(), got_label) << i; |
+ } |
+ |
+ ++foo_tab_id; |
sclittle
2015/11/25 22:49:11
Use a different variable for this, e.g. bar_tab_id
tbansal1
2015/11/26 00:31:21
Done.
|
+ EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingStarted(foo_tab_id)); |
+ data_use_ui_tab_model()->ReportCustomTabInitialNavigation( |
+ foo_tab_id, std::string(), foo_package); |
+ base::RunLoop().RunUntilIdle(); |
+ |
+ // |data_use_ui_tab_model| should receive callback about starting of |
+ // tracking of data usage for |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)); |
+ |
+ data_use_ui_tab_model()->ReportTabClosure(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
+ EXPECT_FALSE(data_use_ui_tab_model()->HasDataUseTrackingEnded(foo_tab_id)); |
} |
// Tests if the Entrance/Exit UI state is tracked correctly. |
TEST_F(DataUseUITabModelTest, EntranceExitState) { |
- int32_t foo_tab_id = 1; |
- int32_t bar_tab_id = 2; |
- int32_t baz_tab_id = 3; |
+ SessionID::id_type foo_tab_id = 1; |
+ SessionID::id_type bar_tab_id = 2; |
+ SessionID::id_type 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_tab_model()->NotifyObserversOfTrackingStarting(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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 +204,36 @@ 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_tab_model()->NotifyObserversOfTrackingEnding(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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_tab_model()->NotifyObserversOfTrackingStarting(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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_tab_model()->NotifyObserversOfTrackingEnding(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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_tab_model()->NotifyObserversOfTrackingStarting(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
+ data_use_tab_model()->NotifyObserversOfTrackingStarting(foo_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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_tab_model()->NotifyObserversOfTrackingEnding(bar_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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 +243,73 @@ 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_tab_model()->NotifyObserversOfTrackingStarting(baz_tab_id); |
+ base::RunLoop().RunUntilIdle(); |
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 |