1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/extensions/api/autofill_private/autofill_util.h"
#include <memory>
#include "base/functional/callback_forward.h"
#include "base/test/mock_callback.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "components/autofill/core/browser/data_manager/payments/test_payments_data_manager.h"
#include "components/autofill/core/browser/data_manager/test_personal_data_manager.h"
#include "components/autofill/core/browser/test_utils/autofill_test_utils.h"
#include "components/autofill/core/common/autofill_test_utils.h"
#include "components/device_reauth/mock_device_authenticator.h"
#include "content/public/test/browser_task_environment.h"
#include "content/public/test/browser_test.h"
namespace extensions::autofill_util {
namespace {
using ::testing::_;
using ::testing::Return;
using ::testing::UnorderedElementsAre;
using MockCallbackAfterSuccessfulUserAuth =
base::MockCallback<CallbackAfterSuccessfulUserAuth>;
MATCHER_P(MatchesIbanType, iban, "") {
bool is_local = iban.record_type() == autofill::Iban::RecordType::kLocalIban;
return arg.metadata->is_local == is_local;
}
class AutofillUtilTest : public InProcessBrowserTest {
public:
AutofillUtilTest() = default;
AutofillUtilTest(const AutofillUtilTest&) = delete;
AutofillUtilTest& operator=(const AutofillUtilTest&) = delete;
void SetUpOnMainThread() override {
mock_device_authenticator_ =
std::make_unique<device_reauth::MockDeviceAuthenticator>();
}
protected:
autofill::test::AutofillBrowserTestEnvironment autofill_test_environment_;
std::unique_ptr<device_reauth::MockDeviceAuthenticator>
mock_device_authenticator_;
};
IN_PROC_BROWSER_TEST_F(AutofillUtilTest, GenerateIbanList) {
autofill::TestPaymentsDataManager paydm;
paydm.SetAutofillWalletImportEnabled(true);
autofill::Iban local_iban = autofill::test::GetLocalIban();
paydm.AddIbanForTest(std::make_unique<autofill::Iban>(local_iban));
autofill::Iban server_iban = autofill::test::GetServerIban();
paydm.AddServerIban(server_iban);
IbanEntryList iban_list = GenerateIbanList(paydm);
EXPECT_THAT(iban_list, UnorderedElementsAre(MatchesIbanType(local_iban),
MatchesIbanType(server_iban)));
}
IN_PROC_BROWSER_TEST_F(AutofillUtilTest, AuthenticateUser_SuccessfulAuth) {
#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN)
base::MockCallback<base::OnceCallback<void(bool)>> mock_result_callback;
const std::u16string mock_prompt_message = u"This is a mock message";
ON_CALL(*mock_device_authenticator_, AuthenticateWithMessage)
.WillByDefault(
testing::WithArg<1>([](base::OnceCallback<void(bool)> callback) {
std::move(callback).Run(true);
}));
EXPECT_CALL(mock_result_callback, Run(true));
EXPECT_CALL(*mock_device_authenticator_,
AuthenticateWithMessage(mock_prompt_message, _));
mock_device_authenticator_->AuthenticateWithMessage(
mock_prompt_message, mock_result_callback.Get());
#endif
}
IN_PROC_BROWSER_TEST_F(AutofillUtilTest, AuthenticateUser_UnSuccessfulAuth) {
#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN)
base::MockCallback<base::OnceCallback<void(bool)>> mock_result_callback;
const std::u16string mock_prompt_message = u"This is a mock message";
ON_CALL(*mock_device_authenticator_, AuthenticateWithMessage)
.WillByDefault(
testing::WithArg<1>([](base::OnceCallback<void(bool)> callback) {
std::move(callback).Run(false);
}));
EXPECT_CALL(mock_result_callback, Run(false));
EXPECT_CALL(*mock_device_authenticator_,
AuthenticateWithMessage(mock_prompt_message, _));
mock_device_authenticator_->AuthenticateWithMessage(
mock_prompt_message, mock_result_callback.Get());
#endif
}
} // namespace
} // namespace extensions::autofill_util
|