diff options
author | jennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-06 17:19:37 +0000 |
---|---|---|
committer | jennb@chromium.org <jennb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-06 17:19:37 +0000 |
commit | ae3c0b266d4a3f7f2f121589e24e76528d44f4f7 (patch) | |
tree | 85af04a19120db4a75b1ad07ca2a6e1473f1767e /webkit/appcache/appcache_unittest.cc | |
parent | ff9cfce7ec2ae06df4ac413cfde3bfd7ae503677 (diff) | |
download | chromium_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.cc | 39 |
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 |