blob: ee3828929f4bd1676bd147955f0ebf1bbecab126 [file] [log] [blame]
// Copyright 2015 The Chromium OS 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 "attestation/common/mock_tpm_utility.h"
using ::testing::_;
using ::testing::Invoke;
using ::testing::Return;
using ::testing::WithArgs;
namespace {
class TransformString {
public:
explicit TransformString(std::string method) : method_(method) {}
bool operator()(const std::string& in, std::string* out) {
*out = attestation::MockTpmUtility::Transform(method_, in);
return true;
}
private:
std::string method_;
};
class UntransformString {
public:
explicit UntransformString(std::string method) : method_(method) {}
bool operator()(const std::string& in, std::string* out) {
std::string suffix = "_fake_transform_" + method_;
auto position = in.find(suffix);
if (position == std::string::npos) {
return false;
}
*out = in.substr(0, position);
return true;
}
private:
std::string method_;
};
// Puts the fake identity key and binding data to |identity| to mock
// |MockTpmUtility::CreateIdentity|.
bool SetFakeIdentity(attestation::AttestationDatabase::Identity* identity) {
auto identity_binding_pb = identity->mutable_identity_binding();
auto identity_key_pb = identity->mutable_identity_key();
identity_binding_pb->set_identity_public_key_der("identity_public_key_der");
identity_binding_pb->set_identity_public_key_tpm_format(
"identity_public_key_tpm_format");
identity_binding_pb->set_identity_binding("identity_binding");
identity_binding_pb->set_pca_public_key("pca_public_key");
identity_binding_pb->set_identity_label("identity_label");
identity_key_pb->set_identity_public_key_der("identity_public_key");
identity_key_pb->set_identity_key_blob("identity_key_blob");
return true;
}
} // namespace
namespace attestation {
MockTpmUtility::MockTpmUtility() {
ON_CALL(*this, Initialize()).WillByDefault(Return(true));
#if !USE_TPM2
ON_CALL(*this, GetVersion()).WillByDefault(Return(TPM_1_2));
#else
ON_CALL(*this, GetVersion()).WillByDefault(Return(TPM_2_0));
#endif
ON_CALL(*this, IsTpmReady()).WillByDefault(Return(true));
ON_CALL(*this, ActivateIdentity(_, _, _, _)).WillByDefault(Return(true));
ON_CALL(*this, ActivateIdentityForTpm2(_, _, _, _, _, _))
.WillByDefault(Return(true));
ON_CALL(*this, CreateCertifiedKey(_, _, _, _, _, _, _, _, _))
.WillByDefault(Return(true));
ON_CALL(*this, SealToPCR0(_, _))
.WillByDefault(Invoke(TransformString("SealToPCR0")));
ON_CALL(*this, Unseal(_, _))
.WillByDefault(Invoke(UntransformString("SealToPCR0")));
ON_CALL(*this, Unbind(_, _, _))
.WillByDefault(WithArgs<1, 2>(Invoke(TransformString("Unbind"))));
ON_CALL(*this, Sign(_, _, _))
.WillByDefault(WithArgs<1, 2>(Invoke(TransformString("Sign"))));
ON_CALL(*this, GetEndorsementPublicKey(_, _)).WillByDefault(Return(true));
ON_CALL(*this, GetEndorsementCertificate(_, _)).WillByDefault(Return(true));
ON_CALL(*this, QuotePCR(_, _, _, _, _)).WillByDefault(Return(true));
ON_CALL(*this, GetNVDataSize(_, _)).WillByDefault(Return(true));
ON_CALL(*this, CertifyNV(_, _, _, _, _)).WillByDefault(Return(true));
ON_CALL(*this, ReadPCR(_, _)).WillByDefault(Return(true));
ON_CALL(*this, RemoveOwnerDependency()).WillByDefault(Return(true));
ON_CALL(*this, CreateIdentity(_, _))
.WillByDefault(WithArgs<1>(Invoke(SetFakeIdentity)));
ON_CALL(*this, GetRsuDeviceId(_)).WillByDefault(Return(true));
}
MockTpmUtility::~MockTpmUtility() {}
// static
std::string MockTpmUtility::Transform(const std::string& method,
const std::string& input) {
return input + "_fake_transform_" + method;
}
} // namespace attestation