blob: eac62436703213c5d1a3ff692a0b0c19c5b4074b [file] [log] [blame]
// Copyright 2022 The ChromiumOS Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chaps/chaps_metrics.h"
#include <type_traits>
#include <dbus/chaps/dbus-constants.h>
#include <gmock/gmock.h>
#include <gtest/gtest.h>
#include <metrics/metrics_library_mock.h>
#include "chaps/chaps.h"
#include "pkcs11/cryptoki.h"
namespace chaps {
namespace {
using ::testing::_;
using ::testing::Return;
using ::testing::StrictMock;
} // namespace
class ChapsMetricsTest : public ::testing::Test {
public:
ChapsMetricsTest() {
chaps_metrics_.set_metrics_library_for_testing(&mock_metrics_library_);
}
protected:
StrictMock<MetricsLibraryMock> mock_metrics_library_;
ChapsMetrics chaps_metrics_;
};
TEST_F(ChapsMetricsTest, ReportReinitializingTokenStatus) {
// Tests the enums to see if the parameters are correctly passed.
const ReinitializingTokenStatus statuses[]{
ReinitializingTokenStatus::kFailedToUnseal,
ReinitializingTokenStatus::kBadAuthorizationData,
ReinitializingTokenStatus::kFailedToDecryptRootKey,
ReinitializingTokenStatus::kFailedToValidate,
};
constexpr auto max_value =
static_cast<int>(ReinitializingTokenStatus::kMaxValue);
for (auto status : statuses) {
EXPECT_CALL(mock_metrics_library_,
SendEnumToUMA(kReinitializingToken, static_cast<int>(status),
max_value))
.WillOnce(Return(true));
chaps_metrics_.ReportReinitializingTokenStatus(status);
}
}
TEST_F(ChapsMetricsTest, ReportTPMAvailabilityStatus) {
// Tests the enums to see if the parameters are correctly passed.
const TPMAvailabilityStatus statuses[]{
TPMAvailabilityStatus::kTPMAvailable,
TPMAvailabilityStatus::kTPMUnavailable,
};
constexpr auto max_value = static_cast<int>(TPMAvailabilityStatus::kMaxValue);
for (auto status : statuses) {
EXPECT_CALL(
mock_metrics_library_,
SendEnumToUMA(kTPMAvailability, static_cast<int>(status), max_value))
.WillOnce(Return(true));
chaps_metrics_.ReportTPMAvailabilityStatus(status);
}
}
TEST_F(ChapsMetricsTest, ReportCrosEvent) {
EXPECT_CALL(mock_metrics_library_, SendCrosEventToUMA(kDatabaseCorrupted))
.WillOnce(Return(true));
chaps_metrics_.ReportCrosEvent(kDatabaseCorrupted);
EXPECT_CALL(mock_metrics_library_, SendCrosEventToUMA(kDatabaseRepairFailure))
.WillOnce(Return(true));
chaps_metrics_.ReportCrosEvent(kDatabaseRepairFailure);
EXPECT_CALL(mock_metrics_library_, SendCrosEventToUMA(kDatabaseCreateFailure))
.WillOnce(Return(true));
chaps_metrics_.ReportCrosEvent(kDatabaseCreateFailure);
}
TEST_F(ChapsMetricsTest, ReportChapsTokenManagerStatus) {
// Tests the enums to see if the parameters are correctly passed.
const TokenManagerStatus statuses[]{
TokenManagerStatus::kCommandSuccess,
TokenManagerStatus::kInitStage2Failed,
TokenManagerStatus::kInvalidIsolateCredential,
TokenManagerStatus::kLoadExistingToken,
TokenManagerStatus::kFailedToLoadSoftwareToken,
TokenManagerStatus::kUnknownPath,
TokenManagerStatus::kIncorrectOldAuthorizationData,
TokenManagerStatus::kFailedToChangeAuthData,
TokenManagerStatus::kFailedToWriteAuthKeyBlob,
TokenManagerStatus::kFailedToWriteAuthDataHashBlob,
TokenManagerStatus::kTokenNotInitialized,
TokenManagerStatus::kFailedToDecryptRootKey,
TokenManagerStatus::kFailedToEncryptRootKey,
TokenManagerStatus::kFailedToWriteRootKeyBlob,
};
constexpr auto max_value = static_cast<int>(TokenManagerStatus::kMaxValue);
const std::string histogram =
std::string(kChapsTokenManagerHistogramPrefix) + ".FakeCommand";
for (auto status : statuses) {
EXPECT_CALL(mock_metrics_library_,
SendEnumToUMA(histogram, static_cast<int>(status), max_value))
.WillOnce(Return(true));
chaps_metrics_.ReportChapsTokenManagerStatus("FakeCommand", status);
}
}
TEST_F(ChapsMetricsTest, ReportChapsSessionStatus) {
// Tests the min and max value to see if the parameters are correctly passed.
const int statuses[]{
static_cast<int>(CKR_OK),
static_cast<int>(CKR_WOULD_BLOCK_FOR_PRIVATE_OBJECTS),
};
const std::string histogram =
std::string(kChapsSessionHistogramPrefix) + ".FakeCommand";
for (auto status : statuses) {
EXPECT_CALL(mock_metrics_library_, SendSparseToUMA(histogram, status))
.WillOnce(Return(true));
chaps_metrics_.ReportChapsSessionStatus("FakeCommand", status);
}
}
} // namespace chaps