Index: snapshot/system_snapshot_mac_test.cc |
diff --git a/snapshot/system_snapshot_mac_test.cc b/snapshot/system_snapshot_mac_test.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1a548ef5786cd927f577eacb1cfd8500278a6f4f |
--- /dev/null |
+++ b/snapshot/system_snapshot_mac_test.cc |
@@ -0,0 +1,130 @@ |
+// Copyright 2014 The Crashpad Authors. All rights reserved. |
+// |
+// Licensed under the Apache License, Version 2.0 (the "License"); |
+// you may not use this file except in compliance with the License. |
+// You may obtain a copy of the License at |
+// |
+// http://www.apache.org/licenses/LICENSE-2.0 |
+// |
+// Unless required by applicable law or agreed to in writing, software |
+// distributed under the License is distributed on an "AS IS" BASIS, |
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
+// See the License for the specific language governing permissions and |
+// limitations under the License. |
+ |
+#include "snapshot/system_snapshot_mac.h" |
+ |
+#include <sys/time.h> |
+ |
+#include <string> |
+ |
+#include "build/build_config.h" |
+#include "gtest/gtest.h" |
+#include "util/mac/mac_util.h" |
+#include "util/mac/process_reader.h" |
+#include "util/test/errors.h" |
+ |
+namespace { |
+ |
+using namespace crashpad; |
+using namespace crashpad::test; |
+ |
+// SystemSnapshotMac objects would be cumbersome to construct in each test that |
+// requires one, because of the repetitive and mechanical work necessary to set |
+// up a ProcessReader and timeval, along with the checks to verify that these |
+// operations succeed. This test fixture class handles the initialization work |
+// so that individual tests don’t have to. |
+class SystemSnapshotMacTest : public testing::Test { |
+ public: |
+ SystemSnapshotMacTest() |
+ : Test(), |
+ process_reader_(), |
+ snapshot_time_(), |
+ system_snapshot_() { |
+ } |
+ |
+ const internal::SystemSnapshotMac& system_snapshot() const { |
+ return system_snapshot_; |
+ } |
+ |
+ // testing::Test: |
+ virtual void SetUp() override { |
+ ASSERT_TRUE(process_reader_.Initialize(mach_task_self())); |
+ ASSERT_EQ(0, gettimeofday(&snapshot_time_, NULL)) |
+ << ErrnoMessage("gettimeofday"); |
+ system_snapshot_.Initialize(&process_reader_, &snapshot_time_); |
+ } |
+ |
+ private: |
+ ProcessReader process_reader_; |
+ timeval snapshot_time_; |
+ internal::SystemSnapshotMac system_snapshot_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(SystemSnapshotMacTest); |
+}; |
+ |
+TEST_F(SystemSnapshotMacTest, GetCPUArchitecture) { |
+ CPUArchitecture cpu_architecture = system_snapshot().GetCPUArchitecture(); |
+ |
+#if defined(ARCH_CPU_X86) |
+ EXPECT_EQ(kCPUArchitectureX86, cpu_architecture); |
+#elif defined(ARCH_CPU_X86_64) |
+ EXPECT_EQ(kCPUArchitectureX86_64, cpu_architecture); |
+#else |
+#error port to your architecture |
+#endif |
+} |
+ |
+TEST_F(SystemSnapshotMacTest, CPUCount) { |
+ EXPECT_GE(system_snapshot().CPUCount(), 1); |
+} |
+ |
+TEST_F(SystemSnapshotMacTest, CPUVendor) { |
+ std::string cpu_vendor = system_snapshot().CPUVendor(); |
+ |
+#if defined(ARCH_CPU_X86_FAMILY) |
+ // Apple has only shipped Intel x86-family CPUs, but here’s a small nod to the |
+ // “Hackintosh” crowd. |
+ if (cpu_vendor != "GenuineIntel" && cpu_vendor != "AuthenticAMD") { |
+ FAIL() << cpu_vendor; |
+ } |
+#else |
+#error port to your architecture |
+#endif |
+} |
+ |
+#if defined(ARCH_CPU_X86_FAMILY) |
+ |
+TEST_F(SystemSnapshotMacTest, CPUX86SupportsDAZ) { |
+ // All x86-family CPUs that Apple is known to have shipped should support DAZ. |
+ EXPECT_TRUE(system_snapshot().CPUX86SupportsDAZ()); |
+} |
+ |
+#endif |
+ |
+TEST_F(SystemSnapshotMacTest, GetOperatingSystem) { |
+ EXPECT_EQ(SystemSnapshot::kOperatingSystemMacOSX, |
+ system_snapshot().GetOperatingSystem()); |
+} |
+ |
+TEST_F(SystemSnapshotMacTest, OSVersion) { |
+ int major; |
+ int minor; |
+ int bugfix; |
+ std::string build; |
+ system_snapshot().OSVersion(&major, &minor, &bugfix, &build); |
+ |
+ EXPECT_EQ(10, major); |
+ EXPECT_EQ(MacOSXMinorVersion(), minor); |
+ EXPECT_FALSE(build.empty()); |
+} |
+ |
+TEST_F(SystemSnapshotMacTest, OSVersionFull) { |
+ EXPECT_FALSE(system_snapshot().OSVersionFull().empty()); |
+} |
+ |
+TEST_F(SystemSnapshotMacTest, MachineDescription) { |
+ EXPECT_FALSE(system_snapshot().MachineDescription().empty()); |
+} |
+ |
+} // namespace |