Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 <stddef.h> | 5 #include <stddef.h> |
| 6 #include <stdint.h> | 6 #include <stdint.h> |
| 7 | 7 |
| 8 #include <memory> | 8 #include <memory> |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| 11 #include "base/base64.h" | 11 #include "base/base64.h" |
| 12 #include "base/files/file_path.h" | 12 #include "base/files/file_path.h" |
| 13 #include "base/json/json_reader.h" | 13 #include "base/json/json_reader.h" |
| 14 #include "base/json/json_writer.h" | 14 #include "base/json/json_writer.h" |
| 15 #include "base/macros.h" | 15 #include "base/macros.h" |
| 16 #include "base/path_service.h" | 16 #include "base/path_service.h" |
| 17 #include "base/strings/string_number_conversions.h" | 17 #include "base/strings/string_number_conversions.h" |
| 18 #include "base/strings/string_piece.h" | 18 #include "base/strings/string_piece.h" |
| 19 #include "base/strings/stringprintf.h" | 19 #include "base/strings/stringprintf.h" |
| 20 #include "base/strings/utf_string_conversions.h" | 20 #include "base/strings/utf_string_conversions.h" |
| 21 #include "base/synchronization/waitable_event.h" | 21 #include "base/synchronization/waitable_event.h" |
| 22 #include "base/values.h" | 22 #include "base/values.h" |
| 23 #include "build/build_config.h" | 23 #include "build/build_config.h" |
| 24 #include "chrome/browser/chrome_notification_types.h" | 24 #include "chrome/browser/chrome_notification_types.h" |
| 25 #include "chrome/browser/extensions/api/messaging/incognito_connectability.h" | 25 #include "chrome/browser/extensions/api/messaging/incognito_connectability.h" |
| 26 #include "chrome/browser/extensions/chrome_extension_test_notification_observer. h" | |
| 26 #include "chrome/browser/extensions/extension_apitest.h" | 27 #include "chrome/browser/extensions/extension_apitest.h" |
| 28 #include "chrome/browser/extensions/extension_util.h" | |
| 27 #include "chrome/browser/extensions/test_extension_dir.h" | 29 #include "chrome/browser/extensions/test_extension_dir.h" |
| 28 #include "chrome/browser/infobars/infobar_service.h" | 30 #include "chrome/browser/infobars/infobar_service.h" |
| 29 #include "chrome/browser/profiles/profile.h" | 31 #include "chrome/browser/profiles/profile.h" |
| 30 #include "chrome/browser/ui/browser.h" | 32 #include "chrome/browser/ui/browser.h" |
| 31 #include "chrome/browser/ui/browser_commands.h" | 33 #include "chrome/browser/ui/browser_commands.h" |
| 32 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 34 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 33 #include "chrome/common/chrome_paths.h" | 35 #include "chrome/common/chrome_paths.h" |
| 34 #include "chrome/common/chrome_switches.h" | 36 #include "chrome/common/chrome_switches.h" |
| 35 #include "chrome/test/base/ui_test_utils.h" | 37 #include "chrome/test/base/ui_test_utils.h" |
| 36 #include "content/public/browser/notification_registrar.h" | 38 #include "content/public/browser/notification_registrar.h" |
| (...skipping 739 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 776 | 778 |
| 777 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); | 779 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); |
| 778 | 780 |
| 779 Browser* incognito_browser = OpenURLOffTheRecord( | 781 Browser* incognito_browser = OpenURLOffTheRecord( |
| 780 profile()->GetOffTheRecordProfile(), chromium_org_url()); | 782 profile()->GetOffTheRecordProfile(), chromium_org_url()); |
| 781 content::RenderFrameHost* incognito_frame = | 783 content::RenderFrameHost* incognito_frame = |
| 782 incognito_browser->tab_strip_model() | 784 incognito_browser->tab_strip_model() |
| 783 ->GetActiveWebContents() | 785 ->GetActiveWebContents() |
| 784 ->GetMainFrame(); | 786 ->GetMainFrame(); |
| 785 | 787 |
| 786 { | 788 IncognitoConnectability::ScopedAlertTracker alert_tracker( |
| 787 IncognitoConnectability::ScopedAlertTracker alert_tracker( | 789 IncognitoConnectability::ScopedAlertTracker::ALWAYS_DENY); |
| 788 IncognitoConnectability::ScopedAlertTracker::ALWAYS_DENY); | |
| 789 | 790 |
| 790 // The alert doesn't show for extensions. | 791 // Extensions disabled in incognito mode are not loaded in an incognito |
| 791 EXPECT_EQ(COULD_NOT_ESTABLISH_CONNECTION_ERROR, | 792 // renderer. |
| 792 CanConnectAndSendMessagesToFrame( | 793 EXPECT_EQ(NAMESPACE_NOT_DEFINED, CanConnectAndSendMessagesToFrame( |
| 793 incognito_frame, extension.get(), NULL)); | 794 incognito_frame, extension.get(), NULL)); |
| 794 EXPECT_EQ(0, alert_tracker.GetAndResetAlertCount()); | |
| 795 } | |
| 796 | 795 |
| 797 // Allowing the extension in incognito mode will bypass the deny. | 796 // Allowing the extension in incognito mode loads the extension in the |
| 798 ExtensionPrefs::Get(profile())->SetIsIncognitoEnabled(extension->id(), true); | 797 // incognito renderer, allowing it to receive connections. |
| 799 EXPECT_EQ( | 798 ChromeExtensionTestNotificationObserver observer(incognito_browser); |
| 800 OK, | 799 util::SetIsIncognitoEnabled(extension->id(), |
| 801 CanConnectAndSendMessagesToFrame(incognito_frame, extension.get(), NULL)); | 800 profile()->GetOffTheRecordProfile(), true); |
| 801 observer.WaitForExtensionLoad(); | |
| 802 EXPECT_EQ(OK, CanConnectAndSendMessagesToFrame(incognito_frame, | |
| 803 extension.get(), NULL)); | |
|
Devlin
2017/03/23 22:08:36
Subtle: when we reload the extension, the Extensio
Devlin
2017/03/23 22:08:37
prefer nullptr in new code
karandeepb
2017/04/04 03:44:15
Done.
karandeepb
2017/04/04 03:44:15
Done.
| |
| 804 | |
| 805 // No alert is shown for extensions which support being enabled in incognito | |
| 806 // mode. | |
| 807 EXPECT_EQ(0, alert_tracker.GetAndResetAlertCount()); | |
| 802 } | 808 } |
| 803 | 809 |
| 804 // Tests connection from incognito tabs when the extension doesn't have an event | 810 // Tests connection from incognito tabs when the extension doesn't have an event |
| 805 // handler for the connection event. | 811 // handler for the connection event. |
| 806 IN_PROC_BROWSER_TEST_F(ExternallyConnectableMessagingTest, | 812 IN_PROC_BROWSER_TEST_F(ExternallyConnectableMessagingTest, |
| 807 FromIncognitoNoEventHandlerInApp) { | 813 FromIncognitoNoEventHandlerInApp) { |
| 808 InitializeTestServer(); | 814 InitializeTestServer(); |
| 809 | 815 |
| 810 scoped_refptr<const Extension> app = LoadChromiumConnectableApp(false); | 816 scoped_refptr<const Extension> app = LoadChromiumConnectableApp(false); |
| 811 ASSERT_TRUE(app->is_platform_app()); | 817 ASSERT_TRUE(app->is_platform_app()); |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 951 | 957 |
| 952 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); | 958 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); |
| 953 | 959 |
| 954 Browser* incognito_browser = OpenURLOffTheRecord( | 960 Browser* incognito_browser = OpenURLOffTheRecord( |
| 955 profile()->GetOffTheRecordProfile(), chromium_org_url()); | 961 profile()->GetOffTheRecordProfile(), chromium_org_url()); |
| 956 content::RenderFrameHost* incognito_frame = | 962 content::RenderFrameHost* incognito_frame = |
| 957 incognito_browser->tab_strip_model() | 963 incognito_browser->tab_strip_model() |
| 958 ->GetActiveWebContents() | 964 ->GetActiveWebContents() |
| 959 ->GetMainFrame(); | 965 ->GetMainFrame(); |
| 960 | 966 |
| 961 { | 967 IncognitoConnectability::ScopedAlertTracker alert_tracker( |
| 962 IncognitoConnectability::ScopedAlertTracker alert_tracker( | 968 IncognitoConnectability::ScopedAlertTracker::ALWAYS_ALLOW); |
| 963 IncognitoConnectability::ScopedAlertTracker::ALWAYS_ALLOW); | |
| 964 | 969 |
| 965 // No alert is shown. | 970 // Extensions disabled in incognito mode are not loaded in an incognito |
| 966 EXPECT_EQ(COULD_NOT_ESTABLISH_CONNECTION_ERROR, | 971 // renderer. |
| 967 CanConnectAndSendMessagesToFrame( | 972 EXPECT_EQ(NAMESPACE_NOT_DEFINED, CanConnectAndSendMessagesToFrame( |
| 968 incognito_frame, extension.get(), NULL)); | 973 incognito_frame, extension.get(), NULL)); |
| 969 EXPECT_EQ(0, alert_tracker.GetAndResetAlertCount()); | |
| 970 } | |
| 971 | 974 |
| 972 // Allowing the extension in incognito mode is what allows connections. | 975 // Allowing the extension in incognito mode loads the extension in the |
| 973 ExtensionPrefs::Get(profile())->SetIsIncognitoEnabled(extension->id(), true); | 976 // incognito renderer, allowing it to receive connections. |
| 974 EXPECT_EQ( | 977 ChromeExtensionTestNotificationObserver observer(incognito_browser); |
| 975 OK, | 978 util::SetIsIncognitoEnabled(extension->id(), |
| 976 CanConnectAndSendMessagesToFrame(incognito_frame, extension.get(), NULL)); | 979 profile()->GetOffTheRecordProfile(), true); |
| 980 observer.WaitForExtensionLoad(); | |
| 981 EXPECT_EQ(OK, CanConnectAndSendMessagesToFrame(incognito_frame, | |
| 982 extension.get(), NULL)); | |
|
Devlin
2017/03/23 22:08:37
(Same comment here)
karandeepb
2017/04/04 03:44:15
Done.
| |
| 983 | |
| 984 // No alert is shown for extensions which support being enabled in incognito | |
| 985 // mode. | |
| 986 EXPECT_EQ(0, alert_tracker.GetAndResetAlertCount()); | |
| 977 } | 987 } |
| 978 | 988 |
| 979 // Tests a connection from an iframe within a tab which doesn't have | 989 // Tests a connection from an iframe within a tab which doesn't have |
| 980 // permission. Iframe should work. | 990 // permission. Iframe should work. |
| 981 IN_PROC_BROWSER_TEST_F(ExternallyConnectableMessagingTest, | 991 IN_PROC_BROWSER_TEST_F(ExternallyConnectableMessagingTest, |
| 982 FromIframeWithPermission) { | 992 FromIframeWithPermission) { |
| 983 InitializeTestServer(); | 993 InitializeTestServer(); |
| 984 | 994 |
| 985 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); | 995 scoped_refptr<const Extension> extension = LoadChromiumConnectableExtension(); |
| 986 | 996 |
| (...skipping 337 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1324 ASSERT_TRUE(content::ExecuteScriptAndExtractInt( | 1334 ASSERT_TRUE(content::ExecuteScriptAndExtractInt( |
| 1325 background_contents, | 1335 background_contents, |
| 1326 "window.domAutomationController.send(window.messageCount);", | 1336 "window.domAutomationController.send(window.messageCount);", |
| 1327 &message_count)); | 1337 &message_count)); |
| 1328 EXPECT_EQ(1, message_count); | 1338 EXPECT_EQ(1, message_count); |
| 1329 } | 1339 } |
| 1330 | 1340 |
| 1331 } // namespace | 1341 } // namespace |
| 1332 | 1342 |
| 1333 }; // namespace extensions | 1343 }; // namespace extensions |
| OLD | NEW |