/*
* Copyright 2008 The WebRTC Project Authors. All rights reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include <stdio.h>
#include "webrtc/base/linux.h"
#include "webrtc/base/fileutils.h"
#include "webrtc/base/logging.h"
#include "webrtc/base/gunit.h"
namespace rtc {
// These tests running on ARM are fairly specific to the output of the tegra2
// ARM processor, and so may fail on other ARM-based systems.
TEST(ProcCpuInfo, GetProcInfo) {
ProcCpuInfo proc_info;
EXPECT_TRUE(proc_info.LoadFromSystem());
int out_cpus = 0;
EXPECT_TRUE(proc_info.GetNumCpus(&out_cpus));
LOG(LS_INFO) << "GetNumCpus: " << out_cpus;
EXPECT_GT(out_cpus, 0);
int out_cpus_phys = 0;
EXPECT_TRUE(proc_info.GetNumPhysicalCpus(&out_cpus_phys));
LOG(LS_INFO) << "GetNumPhysicalCpus: " << out_cpus_phys;
EXPECT_GT(out_cpus_phys, 0);
EXPECT_LE(out_cpus_phys, out_cpus);
int out_family = 0;
EXPECT_TRUE(proc_info.GetCpuFamily(&out_family));
LOG(LS_INFO) << "cpu family: " << out_family;
EXPECT_GE(out_family, 4);
#if defined(__arm__)
std::string out_processor;
EXPECT_TRUE(proc_info.GetSectionStringValue(0, "Processor", &out_processor));
LOG(LS_INFO) << "Processor: " << out_processor;
EXPECT_NE(std::string::npos, out_processor.find("ARM"));
// Most other info, such as model, stepping, vendor, etc.
// is missing on ARM systems.
#else
int out_model = 0;
EXPECT_TRUE(proc_info.GetSectionIntValue(0, "model", &out_model));
LOG(LS_INFO) << "model: " << out_model;
int out_stepping = 0;
EXPECT_TRUE(proc_info.GetSectionIntValue(0, "stepping", &out_stepping));
LOG(LS_INFO) << "stepping: " << out_stepping;
int out_processor = 0;
EXPECT_TRUE(proc_info.GetSectionIntValue(0, "processor", &out_processor));
LOG(LS_INFO) << "processor: " << out_processor;
EXPECT_EQ(0, out_processor);
std::string out_str;
EXPECT_TRUE(proc_info.GetSectionStringValue(0, "vendor_id", &out_str));
LOG(LS_INFO) << "vendor_id: " << out_str;
EXPECT_FALSE(out_str.empty());
#endif
}
TEST(ConfigParser, ParseConfig) {
ConfigParser parser;
MemoryStream *test_stream = new MemoryStream(
"Key1: Value1\n"
"Key2\t: Value2\n"
"Key3:Value3\n"
"\n"
"Key1:Value1\n");
ConfigParser::MapVector key_val_pairs;
parser.Attach(test_stream);
EXPECT_EQ(true, parser.Parse(&key_val_pairs));
EXPECT_EQ(2U, key_val_pairs.size());
EXPECT_EQ("Value1", key_val_pairs[0]["Key1"]);
EXPECT_EQ("Value2", key_val_pairs[0]["Key2"]);
EXPECT_EQ("Value3", key_val_pairs[0]["Key3"]);
EXPECT_EQ("Value1", key_val_pairs[1]["Key1"]);
key_val_pairs.clear();
EXPECT_EQ(true, parser.Open("/proc/cpuinfo"));
EXPECT_EQ(true, parser.Parse(&key_val_pairs));
}
#if !defined(WEBRTC_CHROMIUM_BUILDs)
TEST(ReadLinuxLsbRelease, ReturnsSomething) {
std::string str = ReadLinuxLsbRelease();
// ChromeOS don't have lsb_release
// EXPECT_FALSE(str.empty());
}
#endif
TEST(ReadLinuxUname, ReturnsSomething) {
std::string str = ReadLinuxUname();
EXPECT_FALSE(str.empty());
}
} // namespace rtc