summaryrefslogtreecommitdiffstats
path: root/webkit/appcache/appcache_unittest.cc
diff options
context:
space:
mode:
authorjennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-06 17:19:37 +0000
committerjennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-06 17:19:37 +0000
commitae3c0b266d4a3f7f2f121589e24e76528d44f4f7 (patch)
tree85af04a19120db4a75b1ad07ca2a6e1473f1767e /webkit/appcache/appcache_unittest.cc
parentff9cfce7ec2ae06df4ac413cfde3bfd7ae503677 (diff)
downloadchromium_src-ae3c0b266d4a3f7f2f121589e24e76528d44f4f7.zip
chromium_src-ae3c0b266d4a3f7f2f121589e24e76528d44f4f7.tar.gz
chromium_src-ae3c0b266d4a3f7f2f121589e24e76528d44f4f7.tar.bz2
Implementation of application cache update algorithm.
Does not include storage nor processing of pending master entries. TEST=verify update functionality BUG=none Review URL: http://codereview.chromium.org/201070 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28123 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/appcache/appcache_unittest.cc')
-rw-r--r--webkit/appcache/appcache_unittest.cc39
1 files changed, 38 insertions, 1 deletions
diff --git a/webkit/appcache/appcache_unittest.cc b/webkit/appcache/appcache_unittest.cc
index b5c1772..3d33358 100644
--- a/webkit/appcache/appcache_unittest.cc
+++ b/webkit/appcache/appcache_unittest.cc
@@ -46,9 +46,46 @@ TEST(AppCacheTest, AddModifyEntry) {
AppCacheEntry entry3(AppCacheEntry::EXPLICIT);
cache->AddOrModifyEntry(kUrl1, entry3);
EXPECT_EQ((AppCacheEntry::MASTER | AppCacheEntry::EXPLICIT),
- cache->GetEntry(kUrl1)->types());
+ cache->GetEntry(kUrl1)->types());
EXPECT_EQ(entry2.types(), cache->GetEntry(kUrl2)->types()); // unchanged
}
+TEST(AppCacheTest, InitializeWithManifest) {
+ AppCacheService service;
+
+ scoped_refptr<AppCache> cache = new AppCache(&service, 1234);
+ EXPECT_TRUE(cache->fallback_namespaces_.empty());
+ EXPECT_TRUE(cache->online_whitelist_namespaces_.empty());
+ EXPECT_FALSE(cache->online_whitelist_all_);
+
+ Manifest manifest;
+ manifest.explicit_urls.insert("http://one.com");
+ manifest.explicit_urls.insert("http://two.com");
+ manifest.fallback_namespaces.push_back(
+ FallbackNamespace(GURL("http://fb1.com"), GURL("http://fbone.com")));
+ manifest.online_whitelist_namespaces.push_back(GURL("http://w1.com"));
+ manifest.online_whitelist_namespaces.push_back(GURL("http://w2.com"));
+ manifest.online_whitelist_all = true;
+
+ cache->InitializeWithManifest(&manifest);
+ const std::vector<FallbackNamespace>& fallbacks =
+ cache->fallback_namespaces_;
+ size_t expected = 1;
+ EXPECT_EQ(expected, fallbacks.size());
+ EXPECT_EQ(GURL("http://fb1.com"), fallbacks[0].first);
+ EXPECT_EQ(GURL("http://fbone.com"), fallbacks[0].second);
+ const std::vector<GURL>& whitelist = cache->online_whitelist_namespaces_;
+ expected = 2;
+ EXPECT_EQ(expected, whitelist.size());
+ EXPECT_EQ(GURL("http://w1.com"), whitelist[0]);
+ EXPECT_EQ(GURL("http://w2.com"), whitelist[1]);
+ EXPECT_TRUE(cache->online_whitelist_all_);
+
+ // Ensure collections in manifest were taken over by the cache rather than
+ // copied.
+ EXPECT_TRUE(manifest.fallback_namespaces.empty());
+ EXPECT_TRUE(manifest.online_whitelist_namespaces.empty());
+}
+
} // namespace appacache