blob: 5c53b96b853c8dc0d4685a3abbf03d7fd9c7a3a6 [file] [log] [blame]
//===-- HostInfoTest.cpp --------------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "lldb/Host/HostInfo.h"
#include "TestingSupport/SubsystemRAII.h"
#include "TestingSupport/TestUtilities.h"
#include "lldb/Host/FileSystem.h"
#include "lldb/lldb-defines.h"
#include "llvm/TargetParser/Host.h"
#include "gtest/gtest.h"
using namespace lldb_private;
using namespace llvm;
namespace {
class HostInfoTest : public ::testing::Test {
SubsystemRAII<FileSystem, HostInfo> subsystems;
};
} // namespace
TEST_F(HostInfoTest, GetAugmentedArchSpec) {
// Fully specified triple should not be changed.
ArchSpec spec = HostInfo::GetAugmentedArchSpec("x86_64-pc-linux-gnu");
EXPECT_EQ(spec.GetTriple().getTriple(), "x86_64-pc-linux-gnu");
// Same goes if we specify at least one of (os, vendor, env).
spec = HostInfo::GetAugmentedArchSpec("x86_64-pc");
EXPECT_EQ(spec.GetTriple().getTriple(), "x86_64-pc");
// But if we specify only an arch, we should fill in the rest from the host.
spec = HostInfo::GetAugmentedArchSpec("x86_64");
Triple triple(sys::getDefaultTargetTriple());
EXPECT_EQ(spec.GetTriple().getArch(), Triple::x86_64);
EXPECT_EQ(spec.GetTriple().getOS(), triple.getOS());
EXPECT_EQ(spec.GetTriple().getVendor(), triple.getVendor());
EXPECT_EQ(spec.GetTriple().getEnvironment(), triple.getEnvironment());
// Test LLDB_ARCH_DEFAULT
EXPECT_EQ(HostInfo::GetAugmentedArchSpec(LLDB_ARCH_DEFAULT).GetTriple(),
HostInfo::GetArchitecture(HostInfo::eArchKindDefault).GetTriple());
EXPECT_NE(
HostInfo::GetAugmentedArchSpec("armv7k").GetTriple().getEnvironmentName(),
"unknown");
}
TEST_F(HostInfoTest, GetHostname) {
// Check non-empty string input works correctly.
std::string s("abc");
EXPECT_TRUE(HostInfo::GetHostname(s));
}
#if defined(__APPLE__)
TEST_F(HostInfoTest, GetXcodeSDK) {
auto get_sdk = [](std::string sdk, bool error = false) -> llvm::StringRef {
auto sdk_path_or_err =
HostInfo::GetSDKRoot(HostInfo::SDKOptions{XcodeSDK(std::move(sdk))});
if (!error) {
EXPECT_TRUE((bool)sdk_path_or_err);
return *sdk_path_or_err;
}
EXPECT_FALSE((bool)sdk_path_or_err);
llvm::consumeError(sdk_path_or_err.takeError());
return {};
};
EXPECT_FALSE(get_sdk("MacOSX.sdk").empty());
// These are expected to fall back to an available version.
EXPECT_FALSE(get_sdk("MacOSX9999.sdk").empty());
// This is expected to fail.
EXPECT_TRUE(get_sdk("CeciNestPasUnOS.sdk", true).empty());
}
TEST_F(HostInfoTest, FindSDKTool) {
auto find_tool = [](std::string sdk, llvm::StringRef tool,
bool error = false) -> llvm::StringRef {
auto sdk_path_or_err =
HostInfo::FindSDKTool(XcodeSDK(std::move(sdk)), tool);
if (!error) {
EXPECT_TRUE((bool)sdk_path_or_err);
return *sdk_path_or_err;
}
EXPECT_FALSE((bool)sdk_path_or_err);
llvm::consumeError(sdk_path_or_err.takeError());
return {};
};
EXPECT_FALSE(find_tool("MacOSX.sdk", "clang").empty());
EXPECT_TRUE(find_tool("MacOSX.sdk", "CeciNestPasUnOutil").empty());
}
#endif
TEST(HostInfoTestInitialization, InitTwice) {
llvm::VersionTuple Version;
{
SubsystemRAII<FileSystem, HostInfo> subsystems;
Version = HostInfo::GetOSVersion();
}
{
SubsystemRAII<FileSystem, HostInfo> subsystems;
EXPECT_EQ(Version, HostInfo::GetOSVersion());
}
}