blob: 6628663394cba9cee4dbf123127425d2a0fd8890 [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/autofill/core/browser/credit_card_save_strike_database.h"
#include <utility>
#include <vector>
#include "base/files/scoped_temp_dir.h"
#include "base/run_loop.h"
#include "base/test/metrics/histogram_tester.h"
#include "base/test/scoped_task_environment.h"
#include "base/threading/thread_task_runner_handle.h"
#include "components/autofill/core/browser/proto/strike_data.pb.h"
#include "components/autofill/core/browser/test_autofill_clock.h"
#include "components/autofill/core/browser/test_credit_card_save_strike_database.h"
#include "components/autofill/core/common/autofill_clock.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace autofill {
class CreditCardSaveStrikeDatabaseTest : public ::testing::Test {
public:
CreditCardSaveStrikeDatabaseTest()
: strike_database_(new StrikeDatabase(InitFilePath())) {}
protected:
base::HistogramTester* GetHistogramTester() { return &histogram_tester_; }
base::test::ScopedTaskEnvironment scoped_task_environment_;
TestCreditCardSaveStrikeDatabase strike_database_;
private:
static const base::FilePath InitFilePath() {
base::ScopedTempDir temp_dir_;
EXPECT_TRUE(temp_dir_.CreateUniqueTempDir());
const base::FilePath file_path =
temp_dir_.GetPath().AppendASCII("StrikeDatabaseTest");
return file_path;
}
base::HistogramTester histogram_tester_;
};
TEST_F(CreditCardSaveStrikeDatabaseTest, GetKeyForCreditCardSaveTest) {
const std::string last_four = "1234";
EXPECT_EQ("CreditCardSave__1234", strike_database_.GetKey(last_four));
}
TEST_F(CreditCardSaveStrikeDatabaseTest, MaxStrikesLimitReachedTest) {
const std::string last_four = "1234";
EXPECT_EQ(false, strike_database_.IsMaxStrikesLimitReached(last_four));
// 1st strike added for |last_four|.
strike_database_.AddStrike(last_four);
EXPECT_EQ(false, strike_database_.IsMaxStrikesLimitReached(last_four));
// 2nd strike added for |last_four|.
strike_database_.AddStrike(last_four);
EXPECT_EQ(false, strike_database_.IsMaxStrikesLimitReached(last_four));
// 3rd strike added for |last_four|.
strike_database_.AddStrike(last_four);
EXPECT_EQ(true, strike_database_.IsMaxStrikesLimitReached(last_four));
}
TEST_F(CreditCardSaveStrikeDatabaseTest,
CreditCardSaveNthStrikeAddedHistogram) {
const std::string last_four1 = "1234";
const std::string last_four2 = "9876";
// 1st strike added for |last_four1|.
strike_database_.AddStrike(last_four1);
// 2nd strike added for |last_four1|.
strike_database_.AddStrike(last_four1);
// 1st strike added for |last_four2|.
strike_database_.AddStrike(last_four2);
std::vector<base::Bucket> buckets = GetHistogramTester()->GetAllSamples(
"Autofill.StrikeDatabase.NthStrikeAdded.CreditCardSave");
// There should be two buckets, one for 1st strike, one for 2nd strike count.
ASSERT_EQ(2U, buckets.size());
// Both |last_four1| and |last_four2| have 1st strikes recorded.
EXPECT_EQ(2, buckets[0].count);
// Only |last_four1| has 2nd strike recorded.
EXPECT_EQ(1, buckets[1].count);
}
TEST_F(CreditCardSaveStrikeDatabaseTest,
AddStrikeForZeroAndNonZeroStrikesTest) {
const std::string last_four = "1234";
EXPECT_EQ(0, strike_database_.GetStrikes(last_four));
strike_database_.AddStrike(last_four);
EXPECT_EQ(1, strike_database_.GetStrikes(last_four));
strike_database_.AddStrike(last_four);
EXPECT_EQ(2, strike_database_.GetStrikes(last_four));
}
TEST_F(CreditCardSaveStrikeDatabaseTest, ClearStrikesForNonZeroStrikesTest) {
const std::string last_four = "1234";
strike_database_.AddStrike(last_four);
EXPECT_EQ(1, strike_database_.GetStrikes(last_four));
strike_database_.ClearStrikes(last_four);
EXPECT_EQ(0, strike_database_.GetStrikes(last_four));
}
TEST_F(CreditCardSaveStrikeDatabaseTest, ClearStrikesForZeroStrikesTest) {
const std::string last_four = "1234";
strike_database_.ClearStrikes(last_four);
EXPECT_EQ(0, strike_database_.GetStrikes(last_four));
}
TEST_F(CreditCardSaveStrikeDatabaseTest, RemoveExpiredStrikesTest) {
autofill::TestAutofillClock test_clock;
test_clock.SetNow(AutofillClock::Now());
const std::string last_four1 = "1234";
const std::string last_four2 = "9876";
strike_database_.AddStrike(last_four1);
// Advance clock to past the entry for |last_four1|'s expiry time.
test_clock.Advance(base::TimeDelta::FromMicroseconds(
strike_database_.GetExpiryTimeMicros() + 1));
strike_database_.AddStrike(last_four2);
strike_database_.RemoveExpiredStrikes();
// |last_four1|'s entry should have its most recent strike expire, but
// |last_four2|'s should not.
EXPECT_EQ(0, strike_database_.GetStrikes(last_four1));
EXPECT_EQ(1, strike_database_.GetStrikes(last_four2));
// Advance clock to past |last_four2|'s expiry time.
test_clock.Advance(base::TimeDelta::FromMicroseconds(
strike_database_.GetExpiryTimeMicros() + 1));
strike_database_.RemoveExpiredStrikes();
// |last_four1| and |last_four2| should have no more unexpired strikes.
EXPECT_EQ(0, strike_database_.GetStrikes(last_four1));
EXPECT_EQ(0, strike_database_.GetStrikes(last_four2));
}
} // namespace autofill