Chromium Code Reviews| Index: content/browser/site_instance_impl_unittest.cc |
| diff --git a/content/browser/site_instance_impl_unittest.cc b/content/browser/site_instance_impl_unittest.cc |
| index 845c274b86e51f55078d2fa4c5d0bba7220a02ed..e29a1ee54c6c460ec5f40def704d446f9756208b 100644 |
| --- a/content/browser/site_instance_impl_unittest.cc |
| +++ b/content/browser/site_instance_impl_unittest.cc |
| @@ -794,6 +794,33 @@ TEST_F(SiteInstanceTest, NoProcessPerSiteForEmptySite) { |
| DrainMessageLoop(); |
| } |
| +// Check that an URL is considered same-site with blob: and filesystem: URLs |
| +// with a matching inner origin. See https://crbug.com/726370. |
| +TEST_F(SiteInstanceTest, IsSameWebsiteForNestedURLs) { |
| + GURL foo_url("http://foo.com/"); |
| + GURL bar_url("http://bar.com/"); |
| + GURL blob_foo_url("blob:http://foo.com/uuid"); |
| + GURL blob_bar_url("blob:http://bar.com/uuid"); |
| + GURL fs_foo_url("filesystem:http://foo.com/path/"); |
| + GURL fs_bar_url("filesystem:http://bar.com/path/"); |
|
ncarter (slow)
2017/05/31 17:32:54
This test maybe ought to exercise a case with www.
alexmos
2017/05/31 23:02:26
Done. Also added a case to make sure the inner sc
|
| + |
| + EXPECT_TRUE(SiteInstance::IsSameWebSite(nullptr, foo_url, blob_foo_url)); |
| + EXPECT_TRUE(SiteInstance::IsSameWebSite(nullptr, blob_foo_url, foo_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, foo_url, blob_bar_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, blob_foo_url, bar_url)); |
| + |
| + EXPECT_TRUE(SiteInstance::IsSameWebSite(nullptr, foo_url, fs_foo_url)); |
| + EXPECT_TRUE(SiteInstance::IsSameWebSite(nullptr, fs_foo_url, foo_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, foo_url, fs_bar_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, fs_foo_url, bar_url)); |
| + |
| + EXPECT_TRUE(SiteInstance::IsSameWebSite(nullptr, blob_foo_url, fs_foo_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, blob_foo_url, fs_bar_url)); |
| + EXPECT_FALSE( |
| + SiteInstance::IsSameWebSite(nullptr, blob_foo_url, blob_bar_url)); |
| + EXPECT_FALSE(SiteInstance::IsSameWebSite(nullptr, fs_foo_url, fs_bar_url)); |
| +} |
| + |
| TEST_F(SiteInstanceTest, DefaultSubframeSiteInstance) { |
| if (AreAllSitesIsolatedForTesting()) |
| return; // --top-document-isolation is not possible. |