// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_CERT_MOCK_CERT_VERIFIER_H_ #define NET_CERT_MOCK_CERT_VERIFIER_H_ #include #include #include "base/callback_list.h" #include "base/observer_list.h" #include "base/scoped_observation.h" #include "net/base/completion_once_callback.h" #include "net/cert/cert_verifier.h" #include "net/cert/cert_verify_result.h" namespace net { class MockCertVerifier : public CertVerifier { public: // Creates a new MockCertVerifier. By default, any call to Verify() will // result in the cert status being flagged as CERT_STATUS_INVALID and return // an ERR_CERT_INVALID network error code. This behaviour can be overridden // by calling set_default_result() to change the default return value for // Verify() or by calling one of the AddResult*() methods to specifically // handle a certificate or certificate and host. MockCertVerifier(); ~MockCertVerifier() override; // CertVerifier implementation int Verify(const RequestParams& params, CertVerifyResult* verify_result, CompletionOnceCallback callback, std::unique_ptr* out_req, const NetLogWithSource& net_log) override; void SetConfig(const Config& config) override {} void AddObserver(Observer* observer) override; void RemoveObserver(Observer* observer) override; // Sets the default return value for Verify() for certificates/hosts that do // not have explicit results added via the AddResult*() methods. void set_default_result(int default_result) { default_result_ = default_result; } // Sets whether Verify() returns a result asynchronously. void set_async(bool async) { async_ = async; } // Adds a rule that will cause any call to Verify() for |cert| to return rv, // copying |verify_result| into the verified result. // Note: Only the primary certificate of |cert| is checked. Any intermediate // certificates will be ignored. void AddResultForCert(scoped_refptr cert, const CertVerifyResult& verify_result, int rv); // Same as AddResultForCert(), but further restricts it to only return for // hostnames that match |host_pattern|. void AddResultForCertAndHost(scoped_refptr cert, const std::string& host_pattern, const CertVerifyResult& verify_result, int rv); // Clear all existing rules. void ClearRules(); // Notify any registered observers of an OnCertVerifierChanged event. void SimulateOnCertVerifierChanged(); private: struct Rule; using RuleList = std::list; class MockRequest; friend class MockRequest; int VerifyImpl(const RequestParams& params, CertVerifyResult* verify_result); int default_result_ = ERR_CERT_INVALID; RuleList rules_; bool async_ = false; base::OnceClosureList request_list_; base::ObserverList observers_; }; // A MockCertVerifier that also records the RequestParams received for each // verification attempt. class ParamRecordingMockCertVerifier : public MockCertVerifier { public: ParamRecordingMockCertVerifier(); ~ParamRecordingMockCertVerifier() override; int Verify(const RequestParams& params, CertVerifyResult* verify_result, CompletionOnceCallback callback, std::unique_ptr* out_req, const NetLogWithSource& net_log) override; const std::vector& GetVerifyParams() const { return params_; } private: std::vector params_; }; class CertVerifierObserverCounter : public CertVerifier::Observer { public: explicit CertVerifierObserverCounter(CertVerifier* verifier); ~CertVerifierObserverCounter() override; // CertVerifier::Observer implementation: void OnCertVerifierChanged() override; unsigned change_count() const { return change_count_; } private: base::ScopedObservation obs_{this}; unsigned change_count_ = 0; }; } // namespace net #endif // NET_CERT_MOCK_CERT_VERIFIER_H_