| Index: net/disk_cache/backend_unittest.cc
|
| diff --git a/net/disk_cache/backend_unittest.cc b/net/disk_cache/backend_unittest.cc
|
| index 4f4a442aa1ee95e2be79a8a6a78b4628e03e996b..c3f2cfaf54c87962de6d08489335391214ddceec 100644
|
| --- a/net/disk_cache/backend_unittest.cc
|
| +++ b/net/disk_cache/backend_unittest.cc
|
| @@ -3473,4 +3473,22 @@ TEST_F(DiskCacheBackendTest, SimpleCacheEnumerationCorruption) {
|
| EXPECT_TRUE(keys_to_match.empty());
|
| }
|
|
|
| +// Tests that enumerations don't leak memory when the backend is destructed
|
| +// mid-enumeration.
|
| +TEST_F(DiskCacheBackendTest, SimpleCacheEnumerationDestruction) {
|
| + SetSimpleCacheMode();
|
| + InitCache();
|
| + std::set<std::string> key_pool;
|
| + ASSERT_TRUE(CreateSetOfRandomEntries(&key_pool));
|
| +
|
| + void* iter = NULL;
|
| + disk_cache::Entry* entry = NULL;
|
| + ASSERT_EQ(net::OK, OpenNextEntry(&iter, &entry));
|
| + EXPECT_TRUE(entry);
|
| + disk_cache::ScopedEntryPtr entry_closer(entry);
|
| +
|
| + cache_.reset();
|
| + // This test passes if we don't leak memory.
|
| +}
|
| +
|
| #endif // defined(OS_POSIX)
|
|
|