| Index: base/sys_info_unittest.cc
|
| diff --git a/base/sys_info_unittest.cc b/base/sys_info_unittest.cc
|
| index c3b85077071a8ead6a263947fc109e374516a761..e80884b9b20ffb3b050cab7cfef093500a7cadb9 100644
|
| --- a/base/sys_info_unittest.cc
|
| +++ b/base/sys_info_unittest.cc
|
| @@ -6,6 +6,7 @@
|
|
|
| #include "base/environment.h"
|
| #include "base/files/file_util.h"
|
| +#include "base/process/process_metrics.h"
|
| #include "base/sys_info.h"
|
| #include "base/threading/platform_thread.h"
|
| #include "base/time/time.h"
|
| @@ -13,36 +14,61 @@
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| #include "testing/platform_test.h"
|
|
|
| -typedef PlatformTest SysInfoTest;
|
| -using base::FilePath;
|
| +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(base::SysInfo::NumberOfProcessors(), 1);
|
| + 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(base::SysInfo::AmountOfPhysicalMemory(), 0);
|
| - EXPECT_GT(base::SysInfo::AmountOfPhysicalMemoryMB(), 0);
|
| + EXPECT_GT(SysInfo::AmountOfPhysicalMemory(), 0);
|
| + EXPECT_GT(SysInfo::AmountOfPhysicalMemoryMB(), 0);
|
| // The maxmimal amount of virtual memory can be zero which means unlimited.
|
| - EXPECT_GE(base::SysInfo::AmountOfVirtualMemory(), 0);
|
| + EXPECT_GE(SysInfo::AmountOfVirtualMemory(), 0);
|
| }
|
|
|
| +#if defined(OS_LINUX) || defined(OS_ANDROID)
|
| +TEST_F(SysInfoTest, 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<int64_t>(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<int64_t>(info.free) * 1024);
|
| + EXPECT_LT(amount / 1024, info.total);
|
| +}
|
| +#endif // defined(OS_LINUX) || defined(OS_ANDROID)
|
| +
|
| TEST_F(SysInfoTest, AmountOfFreeDiskSpace) {
|
| // We aren't actually testing that it's correct, just that it's sane.
|
| FilePath tmp_path;
|
| - ASSERT_TRUE(base::GetTempDir(&tmp_path));
|
| - EXPECT_GE(base::SysInfo::AmountOfFreeDiskSpace(tmp_path), 0)
|
| - << tmp_path.value();
|
| + ASSERT_TRUE(GetTempDir(&tmp_path));
|
| + EXPECT_GE(SysInfo::AmountOfFreeDiskSpace(tmp_path), 0) << tmp_path.value();
|
| }
|
|
|
| TEST_F(SysInfoTest, AmountOfTotalDiskSpace) {
|
| // We aren't actually testing that it's correct, just that it's sane.
|
| FilePath tmp_path;
|
| - ASSERT_TRUE(base::GetTempDir(&tmp_path));
|
| - EXPECT_GT(base::SysInfo::AmountOfTotalDiskSpace(tmp_path), 0)
|
| - << tmp_path.value();
|
| + ASSERT_TRUE(GetTempDir(&tmp_path));
|
| + EXPECT_GT(SysInfo::AmountOfTotalDiskSpace(tmp_path), 0) << tmp_path.value();
|
| }
|
|
|
| #if defined(OS_WIN) || defined(OS_MACOSX)
|
| @@ -50,9 +76,9 @@ TEST_F(SysInfoTest, OperatingSystemVersionNumbers) {
|
| int32_t os_major_version = -1;
|
| int32_t os_minor_version = -1;
|
| int32_t os_bugfix_version = -1;
|
| - base::SysInfo::OperatingSystemVersionNumbers(&os_major_version,
|
| - &os_minor_version,
|
| - &os_bugfix_version);
|
| + 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);
|
| @@ -60,18 +86,18 @@ TEST_F(SysInfoTest, OperatingSystemVersionNumbers) {
|
| #endif
|
|
|
| TEST_F(SysInfoTest, Uptime) {
|
| - base::TimeDelta up_time_1 = base::SysInfo::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.
|
| - base::PlatformThread::Sleep(base::TimeDelta::FromMilliseconds(20));
|
| - base::TimeDelta up_time_2 = base::SysInfo::Uptime();
|
| + 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) && !defined(OS_IOS)
|
| TEST_F(SysInfoTest, HardwareModelName) {
|
| - std::string hardware_model = base::SysInfo::HardwareModelName();
|
| + std::string hardware_model = SysInfo::HardwareModelName();
|
| EXPECT_FALSE(hardware_model.empty());
|
| }
|
| #endif
|
| @@ -85,10 +111,10 @@ TEST_F(SysInfoTest, GoogleChromeOSVersionNumbers) {
|
| const char kLsbRelease[] =
|
| "FOO=1234123.34.5\n"
|
| "CHROMEOS_RELEASE_VERSION=1.2.3.4\n";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, base::Time());
|
| - base::SysInfo::OperatingSystemVersionNumbers(&os_major_version,
|
| - &os_minor_version,
|
| - &os_bugfix_version);
|
| + 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);
|
| @@ -101,10 +127,10 @@ TEST_F(SysInfoTest, GoogleChromeOSVersionNumbersFirst) {
|
| const char kLsbRelease[] =
|
| "CHROMEOS_RELEASE_VERSION=1.2.3.4\n"
|
| "FOO=1234123.34.5\n";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, base::Time());
|
| - base::SysInfo::OperatingSystemVersionNumbers(&os_major_version,
|
| - &os_minor_version,
|
| - &os_bugfix_version);
|
| + 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);
|
| @@ -115,10 +141,10 @@ TEST_F(SysInfoTest, GoogleChromeOSNoVersionNumbers) {
|
| int32_t os_minor_version = -1;
|
| int32_t os_bugfix_version = -1;
|
| const char kLsbRelease[] = "FOO=1234123.34.5\n";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, base::Time());
|
| - base::SysInfo::OperatingSystemVersionNumbers(&os_major_version,
|
| - &os_minor_version,
|
| - &os_bugfix_version);
|
| + 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);
|
| @@ -127,43 +153,45 @@ TEST_F(SysInfoTest, GoogleChromeOSNoVersionNumbers) {
|
| 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 base::Time lsb_release_time(base::Time::FromDoubleT(12345.6));
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease, lsb_release_time);
|
| - base::Time parsed_lsb_release_time = base::SysInfo::GetLsbReleaseTime();
|
| + 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) {
|
| - base::SysInfo::SetChromeOSVersionInfoForTest("", base::Time());
|
| - EXPECT_FALSE(base::SysInfo::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";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease1, base::Time());
|
| - EXPECT_FALSE(base::SysInfo::IsRunningOnChromeOS());
|
| + 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";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease2, base::Time());
|
| - EXPECT_TRUE(base::SysInfo::IsRunningOnChromeOS());
|
| + SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease2, Time());
|
| + EXPECT_TRUE(SysInfo::IsRunningOnChromeOS());
|
|
|
| const char kLsbRelease3[] =
|
| "CHROMEOS_RELEASE_NAME=Chromium OS\n";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease3, base::Time());
|
| - EXPECT_TRUE(base::SysInfo::IsRunningOnChromeOS());
|
| + SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease3, Time());
|
| + EXPECT_TRUE(SysInfo::IsRunningOnChromeOS());
|
| }
|
|
|
| TEST_F(SysInfoTest, GetStrippedReleaseBoard) {
|
| const char* kLsbRelease1 = "CHROMEOS_RELEASE_BOARD=Glimmer\n";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease1, base::Time());
|
| - EXPECT_EQ("glimmer", base::SysInfo::GetStrippedReleaseBoard());
|
| + SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease1, Time());
|
| + EXPECT_EQ("glimmer", SysInfo::GetStrippedReleaseBoard());
|
|
|
| const char* kLsbRelease2 = "CHROMEOS_RELEASE_BOARD=glimmer-signed-mp-v4keys";
|
| - base::SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease2, base::Time());
|
| - EXPECT_EQ("glimmer", base::SysInfo::GetStrippedReleaseBoard());
|
| + SysInfo::SetChromeOSVersionInfoForTest(kLsbRelease2, Time());
|
| + EXPECT_EQ("glimmer", SysInfo::GetStrippedReleaseBoard());
|
| }
|
|
|
| #endif // OS_CHROMEOS
|
| +
|
| +} // namespace base
|
|
|