| Index: net/ssl/client_cert_identity_test_util.h
|
| diff --git a/net/ssl/client_cert_identity_test_util.h b/net/ssl/client_cert_identity_test_util.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..90c09f60b714d1313d0e702596e4ea3676f663fc
|
| --- /dev/null
|
| +++ b/net/ssl/client_cert_identity_test_util.h
|
| @@ -0,0 +1,57 @@
|
| +// Copyright 2017 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.
|
| +
|
| +#ifndef NET_SSL_SSL_CLIENT_CERT_IDENTITY_TEST_UTIL_H_
|
| +#define NET_SSL_SSL_CLIENT_CERT_IDENTITY_TEST_UTIL_H_
|
| +
|
| +#include "net/ssl/client_cert_identity.h"
|
| +
|
| +namespace base {
|
| +class FilePath;
|
| +}
|
| +
|
| +namespace net {
|
| +
|
| +// Simple ClientCertIdentity implementation for testing.
|
| +// Note: this implementation of AcquirePrivateKey will always call the callback
|
| +// synchronously.
|
| +class FakeClientCertIdentity : public ClientCertIdentity {
|
| + public:
|
| + FakeClientCertIdentity(scoped_refptr<X509Certificate> cert,
|
| + scoped_refptr<SSLPrivateKey> key);
|
| + ~FakeClientCertIdentity() override;
|
| +
|
| + // Creates a FakeClientCertIdentity from a certificate file (DER or PEM) and
|
| + // private key file (unencrypted pkcs8). Returns nullptr on error.
|
| + static std::unique_ptr<FakeClientCertIdentity> CreateFromCertAndKeyFiles(
|
| + const base::FilePath& dir,
|
| + const std::string& cert_filename,
|
| + const std::string& key_filename);
|
| +
|
| + // Duplicates the FakeClientCertIdentity.
|
| + std::unique_ptr<FakeClientCertIdentity> Copy();
|
| +
|
| + // Returns the SSLPrivateKey in a more convenient way, for tests.
|
| + SSLPrivateKey* ssl_private_key() const { return key_.get(); }
|
| +
|
| + // ClientCertIdentity implementation:
|
| + void AcquirePrivateKey(
|
| + const base::Callback<void(scoped_refptr<SSLPrivateKey>)>&
|
| + private_key_callback) override;
|
| +#if defined(OS_MACOSX)
|
| + SecIdentityRef sec_identity_ref() const override;
|
| +#endif
|
| +
|
| + private:
|
| + scoped_refptr<SSLPrivateKey> key_;
|
| +};
|
| +
|
| +// Converts a CertificateList to a ClientCertIdentityList of
|
| +// FakeClientCertIdentity, with null private keys.
|
| +ClientCertIdentityList FakeClientCertIdentityListFromCertificateList(
|
| + const CertificateList& certs);
|
| +
|
| +} // namespace net
|
| +
|
| +#endif // NET_SSL_SSL_CLIENT_CERT_IDENTITY_TEST_UTIL_H_
|
|
|