Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/browser/safe_browsing/safe_browsing_store.h" | 5 #include "chrome/browser/safe_browsing/safe_browsing_store.h" |
| 6 | 6 |
| 7 #include "testing/gtest/include/gtest/gtest.h" | 7 #include "testing/gtest/include/gtest/gtest.h" |
| 8 | 8 |
| 9 namespace { | 9 namespace { |
| 10 | 10 |
| (...skipping 289 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 300 | 300 |
| 301 TEST(SafeBrowsingStoreTest, Y2K38) { | 301 TEST(SafeBrowsingStoreTest, Y2K38) { |
| 302 const base::Time now = base::Time::Now(); | 302 const base::Time now = base::Time::Now(); |
| 303 const base::Time future = now + base::TimeDelta::FromDays(3*365); | 303 const base::Time future = now + base::TimeDelta::FromDays(3*365); |
| 304 | 304 |
| 305 // TODO: Fix file format before 2035. | 305 // TODO: Fix file format before 2035. |
| 306 EXPECT_GT(static_cast<int32>(future.ToTimeT()), 0) | 306 EXPECT_GT(static_cast<int32>(future.ToTimeT()), 0) |
| 307 << " (int32)time_t is running out."; | 307 << " (int32)time_t is running out."; |
| 308 } | 308 } |
| 309 | 309 |
| 310 // Test that prefixes which were injected from full hashes are being removed. | |
| 311 // This was a mistake in earlier versions of the code. | |
| 312 TEST(SafeBrowsingStoreTest, KnockoutPrefixVolunteers) { | |
| 313 const base::Time kNow = base::Time::Now(); | |
| 314 | |
| 315 // Construct some full hashes which share prefix with another. | |
| 316 const SBFullHash kHash1mod1 = ModifyHashAfterPrefix(kHash1, 1); | |
| 317 const SBFullHash kHash2mod1 = ModifyHashAfterPrefix(kHash2, 1); | |
| 318 | |
| 319 SBAddPrefixes add_prefixes; | |
| 320 std::vector<SBAddFullHash> add_hashes; | |
| 321 SBSubPrefixes sub_prefixes; | |
| 322 std::vector<SBSubFullHash> sub_hashes; | |
| 323 | |
| 324 // An add with prefix and a couple hashes from the same prefix. | |
| 325 add_prefixes.push_back(SBAddPrefix(kAddChunk1, kHash1.prefix)); | |
| 326 add_hashes.push_back(SBAddFullHash(kAddChunk1, kNow, kHash1)); | |
| 327 add_hashes.push_back(SBAddFullHash(kAddChunk1, kNow, kHash1mod1)); | |
| 328 | |
| 329 // Sub with a prefix and a couple hashes from the same prefix. | |
| 330 sub_prefixes.push_back(SBSubPrefix(kSubChunk1, kAddChunk1, kHash2.prefix)); | |
| 331 sub_hashes.push_back(SBSubFullHash(kSubChunk1, kAddChunk1, kHash2)); | |
| 332 sub_hashes.push_back(SBSubFullHash(kSubChunk1, kAddChunk1, kHash2mod1)); | |
| 333 | |
| 334 // An add with no corresponding sub. Both items should be retained. | |
|
mattm
2014/05/02 01:41:09
These comments are a little confusing since none o
Scott Hess - ex-Googler
2014/05/05 22:41:32
Sorry, these were copied and pasted from other tes
| |
| 335 add_hashes.push_back(SBAddFullHash(kAddChunk1, kNow, kHash3)); | |
| 336 add_prefixes.push_back(SBAddPrefix(kAddChunk1, kHash4.prefix)); | |
| 337 | |
| 338 // A sub with no corresponding add. Both items should be retained. | |
| 339 sub_hashes.push_back(SBSubFullHash(kSubChunk1, kAddChunk1, kHash5)); | |
| 340 sub_prefixes.push_back(SBSubPrefix(kSubChunk1, kAddChunk1, kHash6.prefix)); | |
| 341 | |
| 342 const base::hash_set<int32> no_deletions; | |
| 343 ProcessHelper(&add_prefixes, &sub_prefixes, &add_hashes, &sub_hashes, | |
| 344 no_deletions, no_deletions); | |
| 345 | |
| 346 ASSERT_EQ(1U, add_prefixes.size()); | |
| 347 EXPECT_EQ(kAddChunk1, add_prefixes[0].chunk_id); | |
| 348 EXPECT_EQ(kHash4.prefix, add_prefixes[0].prefix); | |
| 349 | |
| 350 ASSERT_EQ(3U, add_hashes.size()); | |
| 351 EXPECT_EQ(kAddChunk1, add_hashes[0].chunk_id); | |
| 352 EXPECT_TRUE(SBFullHashEqual(kHash1mod1, add_hashes[0].full_hash)); | |
| 353 EXPECT_EQ(kAddChunk1, add_hashes[1].chunk_id); | |
| 354 EXPECT_TRUE(SBFullHashEqual(kHash1, add_hashes[1].full_hash)); | |
| 355 EXPECT_EQ(kAddChunk1, add_hashes[2].chunk_id); | |
| 356 EXPECT_TRUE(SBFullHashEqual(kHash3, add_hashes[2].full_hash)); | |
| 357 | |
| 358 ASSERT_EQ(1U, sub_prefixes.size()); | |
| 359 EXPECT_EQ(kSubChunk1, sub_prefixes[0].chunk_id); | |
| 360 EXPECT_EQ(kAddChunk1, sub_prefixes[0].add_chunk_id); | |
| 361 EXPECT_EQ(kHash6.prefix, sub_prefixes[0].add_prefix); | |
| 362 | |
| 363 ASSERT_EQ(3U, sub_hashes.size()); | |
| 364 EXPECT_EQ(kSubChunk1, sub_hashes[0].chunk_id); | |
| 365 EXPECT_EQ(kAddChunk1, sub_hashes[0].add_chunk_id); | |
| 366 EXPECT_TRUE(SBFullHashEqual(kHash5, sub_hashes[0].full_hash)); | |
| 367 EXPECT_EQ(kSubChunk1, sub_hashes[1].chunk_id); | |
| 368 EXPECT_EQ(kAddChunk1, sub_hashes[1].add_chunk_id); | |
| 369 EXPECT_TRUE(SBFullHashEqual(kHash2mod1, sub_hashes[1].full_hash)); | |
| 370 EXPECT_EQ(kSubChunk1, sub_hashes[2].chunk_id); | |
| 371 EXPECT_EQ(kAddChunk1, sub_hashes[2].add_chunk_id); | |
| 372 EXPECT_TRUE(SBFullHashEqual(kHash2, sub_hashes[2].full_hash)); | |
| 373 } | |
| 374 | |
| 310 } // namespace | 375 } // namespace |
| OLD | NEW |