Files
compute-runtime/shared/test/unit_test/utilities/debug_settings_reader_tests.cpp
Slawomir Milczarek 2720f2316c feature: Add capability to print debug messages with pid and timestamp
Controlled with the knob DebugMessagesBitmask (1 - pid, 2 - timestamp)

Related-To: NEO-12952

Signed-off-by: Slawomir Milczarek <slawomir.milczarek@intel.com>
2025-06-21 19:35:52 +02:00

131 lines
4.9 KiB
C++

/*
* Copyright (C) 2018-2025 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/helpers/api_specific_config.h"
#include "shared/test/common/helpers/debug_manager_state_restore.h"
#include "shared/test/common/helpers/gtest_helpers.h"
#include "shared/test/common/helpers/stream_capture.h"
#include "shared/test/common/mocks/mock_settings_reader.h"
#include "shared/test/common/test_macros/test.h"
#include "gtest/gtest.h"
#include <fstream>
#include <string>
using namespace NEO;
namespace SettingsReaderTests {
TEST(SettingsReader, WhenCreatingSettingsReaderThenReaderIsCreated) {
auto reader = std::unique_ptr<SettingsReader>(SettingsReader::create(ApiSpecificConfig::getRegistryPath()));
EXPECT_NE(nullptr, reader.get());
}
TEST(SettingsReader, GivenNoSettingsFileWhenCreatingSettingsReaderThenOsReaderIsCreated) {
ASSERT_FALSE(virtualFileExists(SettingsReader::settingsFileName));
auto fileReader = std::unique_ptr<SettingsReader>(SettingsReader::createFileReader());
EXPECT_EQ(nullptr, fileReader.get());
auto osReader = std::unique_ptr<SettingsReader>(SettingsReader::create(ApiSpecificConfig::getRegistryPath()));
EXPECT_NE(nullptr, osReader.get());
}
TEST(SettingsReader, GivenSettingsFileExistsWhenCreatingSettingsReaderThenReaderIsCreated) {
ASSERT_FALSE(virtualFileExists(SettingsReader::settingsFileName));
constexpr std::string_view data = "ProductFamilyOverride = test";
writeDataToFile(SettingsReader::settingsFileName, data);
auto reader = std::unique_ptr<SettingsReader>(MockSettingsReader::create(ApiSpecificConfig::getRegistryPath()));
EXPECT_NE(nullptr, reader.get());
std::string defaultValue("unk");
EXPECT_STREQ("test", reader->getSetting("ProductFamilyOverride", defaultValue).c_str());
removeVirtualFile(SettingsReader::settingsFileName);
}
TEST(SettingsReader, WhenCreatingFileReaderThenReaderIsCreated) {
ASSERT_FALSE(virtualFileExists(SettingsReader::settingsFileName));
char data = 0;
std::string_view emptyView(&data, 0);
writeDataToFile(SettingsReader::settingsFileName, emptyView);
auto reader = std::unique_ptr<SettingsReader>(MockSettingsReader::createFileReader());
EXPECT_NE(nullptr, reader.get());
removeVirtualFile(SettingsReader::settingsFileName);
}
TEST(SettingsReader, WhenCreatingFileReaderUseNeoFileIfNoDefault) {
ASSERT_FALSE(virtualFileExists(SettingsReader::settingsFileName));
ASSERT_FALSE(virtualFileExists(SettingsReader::neoSettingsFileName));
char data = 0;
std::string_view emptyView(&data, 0);
writeDataToFile(SettingsReader::neoSettingsFileName, emptyView);
auto reader = std::unique_ptr<SettingsReader>(MockSettingsReader::createFileReader());
EXPECT_NE(nullptr, reader.get());
removeVirtualFile(SettingsReader::neoSettingsFileName);
}
TEST(SettingsReader, WhenCreatingOsReaderThenReaderIsCreated) {
auto reader = std::unique_ptr<SettingsReader>(SettingsReader::createOsReader(false, ApiSpecificConfig::getRegistryPath()));
EXPECT_NE(nullptr, reader.get());
}
TEST(SettingsReader, GivenRegKeyWhenCreatingOsReaderThenReaderIsCreated) {
std::string regKey = ApiSpecificConfig::getRegistryPath();
auto reader = std::unique_ptr<SettingsReader>(SettingsReader::createOsReader(false, regKey));
EXPECT_NE(nullptr, reader.get());
}
TEST(SettingsReader, GivenTrueWhenPrintingDebugStringThenPrintsToOutput) {
int i = 4;
StreamCapture capture;
capture.captureStdout();
PRINT_DEBUG_STRING(true, stdout, "testing error %d", i);
std::string output = capture.getCapturedStdout();
EXPECT_STRNE(output.c_str(), "");
}
TEST(SettingsReader, GivenFalseWhenPrintingDebugStringThenNoOutput) {
int i = 4;
StreamCapture capture;
capture.captureStdout();
PRINT_DEBUG_STRING(false, stderr, "Error String %d", i);
std::string output = capture.getCapturedStdout();
EXPECT_STREQ(output.c_str(), "");
}
TEST(SettingsReader, GivenDebugMessagesBitmaskWithPidWhenPrintingDebugStringThenPrintsPidToOutput) {
DebugManagerStateRestore restorer;
NEO::debugManager.flags.DebugMessagesBitmask.set(DebugMessagesBitmask::withPid);
int i = 4;
StreamCapture capture;
capture.captureStdout();
PRINT_DEBUG_STRING(true, stdout, "debug string %d", i);
std::string output = capture.getCapturedStdout();
EXPECT_TRUE(hasSubstr(output, "[PID: "));
}
TEST(SettingsReader, GivenDebugMessagesBitmaskWithTimestampWhenPrintingDebugStringThenPrintsTimestampToOutput) {
DebugManagerStateRestore restorer;
NEO::debugManager.flags.DebugMessagesBitmask.set(DebugMessagesBitmask::withTimestamp);
int i = 4;
StreamCapture capture;
capture.captureStdout();
PRINT_DEBUG_STRING(true, stdout, "debug string %d", i);
std::string output = capture.getCapturedStdout();
std::string dateRegex = R"(\[20\d{2}-\d{2}-\d{2})";
EXPECT_TRUE(containsRegex(output, dateRegex));
}
} // namespace SettingsReaderTests