// Copyright (c) 2012 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. #include #include "base/environment.h" #include "base/files/file_util.h" #include "base/process/process_metrics.h" #include "base/strings/string_number_conversions.h" #include "base/strings/string_split.h" #include "base/sys_info.h" #include "base/threading/platform_thread.h" #include "base/time/time.h" #include "build/build_config.h" #include "testing/gtest/include/gtest/gtest.h" #include "testing/platform_test.h" namespace base { using SysInfoTest = PlatformTest; TEST_F(SysInfoTest, NumProcs) { // We aren't actually testing that it's correct, just that it's sane. EXPECT_GE(SysInfo::NumberOfProcessors(), 1); } TEST_F(SysInfoTest, AmountOfMem) { // We aren't actually testing that it's correct, just that it's sane. EXPECT_GT(SysInfo::AmountOfPhysicalMemory(), 0); EXPECT_GT(SysInfo::AmountOfPhysicalMemoryMB(), 0); // The maxmimal amount of virtual memory can be zero which means unlimited. EXPECT_GE(SysInfo::AmountOfVirtualMemory(), 0); } #if defined(OS_LINUX) || defined(OS_ANDROID) #if defined(OS_LINUX) #define MAYBE_AmountOfAvailablePhysicalMemory \ DISABLED_AmountOfAvailablePhysicalMemory #else #define MAYBE_AmountOfAvailablePhysicalMemory AmountOfAvailablePhysicalMemory #endif // defined(OS_LINUX) TEST_F(SysInfoTest, MAYBE_AmountOfAvailablePhysicalMemory) { // Note: info is in _K_bytes. SystemMemoryInfoKB info; ASSERT_TRUE(GetSystemMemoryInfo(&info)); EXPECT_GT(info.free, 0); if (info.available != 0) { // If there is MemAvailable from kernel. EXPECT_LT(info.available, info.total); const int64_t amount = SysInfo::AmountOfAvailablePhysicalMemory(info); // We aren't actually testing that it's correct, just that it's sane. EXPECT_GT(amount, static_cast(info.free) * 1024); EXPECT_LT(amount / 1024, info.available); // Simulate as if there is no MemAvailable. info.available = 0; } // There is no MemAvailable. Check the fallback logic. const int64_t amount = SysInfo::AmountOfAvailablePhysicalMemory(info); // We aren't actually testing that it's correct, just that it's sane. EXPECT_GT(amount, static_cast(info.free) * 1024); EXPECT_LT(amount / 1024, info.total); } #endif // defined(OS_LINUX) || defined(OS_ANDROID) #if defined(OS_FUCHSIA) // TODO(crbug.com/851734): Implementation depends on statvfs, which is not // implemented on Fuchsia #define MAYBE_AmountOfFreeDiskSpace DISABLED_AmountOfFreeDiskSpace #else #define MAYBE_AmountOfFreeDiskSpace AmountOfFreeDiskSpace #endif TEST_F(SysInfoTest, MAYBE_AmountOfFreeDiskSpace) { // We aren't actually testing that it's correct, just that it's sane. FilePath tmp_path; ASSERT_TRUE(GetTempDir(&tmp_path)); EXPECT_GE(SysInfo::AmountOfFreeDiskSpace(tmp_path), 0) << tmp_path.value(); } #if defined(OS_FUCHSIA) // TODO(crbug.com/851734): Implementation depends on statvfs, which is not // implemented on Fuchsia #define MAYBE_AmountOfTotalDiskSpace DISABLED_AmountOfTotalDiskSpace #else #define MAYBE_AmountOfTotalDiskSpace AmountOfTotalDiskSpace #endif TEST_F(SysInfoTest, MAYBE_AmountOfTotalDiskSpace) { // We aren't actually testing that it's correct, just that it's sane. FilePath tmp_path; ASSERT_TRUE(GetTempDir(&tmp_path)); EXPECT_GT(SysInfo::AmountOfTotalDiskSpace(tmp_path), 0) << tmp_path.value(); } #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_LINUX) TEST_F(SysInfoTest, OperatingSystemVersionNumbers) { int32_t os_major_version = -1; int32_t os_minor_version = -1; int32_t os_bugfix_version = -1; SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version, &os_bugfix_version); EXPECT_GT(os_major_version, -1); EXPECT_GT(os_minor_version, -1); EXPECT_GT(os_bugfix_version, -1); } #endif TEST_F(SysInfoTest, Uptime) { TimeDelta up_time_1 = SysInfo::Uptime(); // UpTime() is implemented internally using TimeTicks::Now(), which documents // system resolution as being 1-15ms. Sleep a little longer than that. PlatformThread::Sleep(TimeDelta::FromMilliseconds(20)); TimeDelta up_time_2 = SysInfo::Uptime(); EXPECT_GT(up_time_1.InMicroseconds(), 0); EXPECT_GT(up_time_2.InMicroseconds(), up_time_1.InMicroseconds()); } #if defined(OS_MACOSX) TEST_F(SysInfoTest, HardwareModelNameFormatMacAndiOS) { std::string hardware_model = SysInfo::HardwareModelName(); ASSERT_FALSE(hardware_model.empty()); // Check that the model is of the expected format "Foo,Bar" where "Bar" is // a number. std::vector pieces = SplitStringPiece(hardware_model, ",", KEEP_WHITESPACE, SPLIT_WANT_ALL); ASSERT_EQ(2u, pieces.size()) << hardware_model; int value; EXPECT_TRUE(StringToInt(pieces[1], &value)) << hardware_model; } #endif #if defined(OS_CHROMEOS) TEST_F(SysInfoTest, GoogleChromeOSVersionNumbers) { int32_t os_major_version = -1; int32_t os_minor_version = -1; int32_t os_bugfix_version = -1; const char kLsbRelease[] = "FOO=1234123.34.5\n" "CHROMEOS_RELEASE_VERSION=1.2.3.4\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, Time()); SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version, &os_bugfix_version); EXPECT_EQ(1, os_major_version); EXPECT_EQ(2, os_minor_version); EXPECT_EQ(3, os_bugfix_version); } TEST_F(SysInfoTest, GoogleChromeOSVersionNumbersFirst) { int32_t os_major_version = -1; int32_t os_minor_version = -1; int32_t os_bugfix_version = -1; const char kLsbRelease[] = "CHROMEOS_RELEASE_VERSION=1.2.3.4\n" "FOO=1234123.34.5\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, Time()); SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version, &os_bugfix_version); EXPECT_EQ(1, os_major_version); EXPECT_EQ(2, os_minor_version); EXPECT_EQ(3, os_bugfix_version); } TEST_F(SysInfoTest, GoogleChromeOSNoVersionNumbers) { int32_t os_major_version = -1; int32_t os_minor_version = -1; int32_t os_bugfix_version = -1; const char kLsbRelease[] = "FOO=1234123.34.5\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, Time()); SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version, &os_bugfix_version); EXPECT_EQ(0, os_major_version); EXPECT_EQ(0, os_minor_version); EXPECT_EQ(0, os_bugfix_version); } TEST_F(SysInfoTest, GoogleChromeOSLsbReleaseTime) { const char kLsbRelease[] = "CHROMEOS_RELEASE_VERSION=1.2.3.4"; // Use a fake time that can be safely displayed as a string. const Time lsb_release_time(Time::FromDoubleT(12345.6)); SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, lsb_release_time); Time parsed_lsb_release_time = SysInfo::GetLsbReleaseTime(); EXPECT_DOUBLE_EQ(lsb_release_time.ToDoubleT(), parsed_lsb_release_time.ToDoubleT()); } TEST_F(SysInfoTest, IsRunningOnChromeOS) { SysInfo::SetChromeOSVersionInfoForTest("", Time()); EXPECT_FALSE(SysInfo::IsRunningOnChromeOS()); const char kLsbRelease1[] = "CHROMEOS_RELEASE_NAME=Non Chrome OS\n" "CHROMEOS_RELEASE_VERSION=1.2.3.4\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease1, Time()); EXPECT_FALSE(SysInfo::IsRunningOnChromeOS()); const char kLsbRelease2[] = "CHROMEOS_RELEASE_NAME=Chrome OS\n" "CHROMEOS_RELEASE_VERSION=1.2.3.4\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease2, Time()); EXPECT_TRUE(SysInfo::IsRunningOnChromeOS()); const char kLsbRelease3[] = "CHROMEOS_RELEASE_NAME=Chromium OS\n"; SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease3, Time()); EXPECT_TRUE(SysInfo::IsRunningOnChromeOS()); } #endif // OS_CHROMEOS } // namespace base