kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 1 | /* |
henrike@webrtc.org | 2660460 | 2012-02-06 23:33:54 +0000 | [diff] [blame] | 2 | * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 11 | #include "gtest/gtest.h" |
henrikg@webrtc.org | c58ef08 | 2011-11-08 08:44:17 +0000 | [diff] [blame] | 12 | #include "system_wrappers/interface/cpu_info.h" |
phoglund@webrtc.org | b15d285 | 2012-11-21 08:02:57 +0000 | [diff] [blame] | 13 | #include "system_wrappers/interface/cpu_wrapper.h" |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 14 | #include "system_wrappers/interface/event_wrapper.h" |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 15 | #include "system_wrappers/interface/scoped_ptr.h" |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 16 | #include "system_wrappers/interface/trace.h" |
kjellander@webrtc.org | c625c10 | 2011-11-29 12:11:06 +0000 | [diff] [blame] | 17 | #include "testsupport/fileutils.h" |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 18 | |
henrikg@webrtc.org | c58ef08 | 2011-11-08 08:44:17 +0000 | [diff] [blame] | 19 | using webrtc::CpuInfo; |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 20 | using webrtc::CpuWrapper; |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 21 | using webrtc::EventWrapper; |
| 22 | using webrtc::scoped_ptr; |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 23 | using webrtc::Trace; |
| 24 | |
andrew@webrtc.org | 8bd6f19 | 2012-02-15 01:47:51 +0000 | [diff] [blame] | 25 | // This test is flaky on Windows/Release. |
| 26 | // http://code.google.com/p/webrtc/issues/detail?id=290 |
| 27 | #ifdef _WIN32 |
| 28 | #define MAYBE_Usage DISABLED_Usage |
| 29 | #else |
| 30 | #define MAYBE_Usage Usage |
| 31 | #endif |
| 32 | TEST(CpuWrapperTest, MAYBE_Usage) { |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 33 | Trace::CreateTrace(); |
kjellander@webrtc.org | c625c10 | 2011-11-29 12:11:06 +0000 | [diff] [blame] | 34 | std::string trace_file = webrtc::test::OutputPath() + |
phoglund@webrtc.org | b15d285 | 2012-11-21 08:02:57 +0000 | [diff] [blame] | 35 | "cpu_wrapper_unittest.txt"; |
kjellander@webrtc.org | c625c10 | 2011-11-29 12:11:06 +0000 | [diff] [blame] | 36 | Trace::SetTraceFile(trace_file.c_str()); |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 37 | Trace::SetLevelFilter(webrtc::kTraceAll); |
henrikg@webrtc.org | c58ef08 | 2011-11-08 08:44:17 +0000 | [diff] [blame] | 38 | printf("Number of cores detected:%u\n", CpuInfo::DetectNumberOfCores()); |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 39 | scoped_ptr<CpuWrapper> cpu(CpuWrapper::CreateCpu()); |
| 40 | ASSERT_TRUE(cpu.get() != NULL); |
| 41 | scoped_ptr<EventWrapper> sleep_event(EventWrapper::Create()); |
| 42 | ASSERT_TRUE(sleep_event.get() != NULL); |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 43 | |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 44 | int num_iterations = 0; |
| 45 | WebRtc_UWord32 num_cores = 0; |
| 46 | WebRtc_UWord32* cores = NULL; |
| 47 | bool cpu_usage_available = cpu->CpuUsageMultiCore(num_cores, cores) != -1; |
| 48 | // Initializing the CPU measurements may take a couple of seconds on Windows. |
| 49 | // Since the initialization is lazy we need to wait until it is completed. |
| 50 | // Should not take more than 10000 ms. |
henrike@webrtc.org | 2660460 | 2012-02-06 23:33:54 +0000 | [diff] [blame] | 51 | while (!cpu_usage_available && (++num_iterations < 10000)) { |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 52 | if (cores != NULL) { |
henrike@webrtc.org | ce9d89d | 2011-11-19 00:14:37 +0000 | [diff] [blame] | 53 | ASSERT_GT(num_cores, 0u); |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 54 | break; |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 55 | } |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 56 | sleep_event->Wait(1); |
| 57 | cpu_usage_available = cpu->CpuUsageMultiCore(num_cores, cores) != -1; |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 58 | } |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 59 | ASSERT_TRUE(cpu_usage_available); |
| 60 | |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 61 | const WebRtc_Word32 average = cpu->CpuUsageMultiCore(num_cores, cores); |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 62 | ASSERT_TRUE(cores != NULL); |
henrike@webrtc.org | ce9d89d | 2011-11-19 00:14:37 +0000 | [diff] [blame] | 63 | EXPECT_GT(num_cores, 0u); |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 64 | EXPECT_GE(average, 0); |
| 65 | EXPECT_LE(average, 100); |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 66 | |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 67 | printf("\nNumber of cores:%d\n", num_cores); |
| 68 | printf("Average cpu:%d\n", average); |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 69 | for (WebRtc_UWord32 i = 0; i < num_cores; i++) { |
| 70 | printf("Core:%u CPU:%u \n", i, cores[i]); |
henrike@webrtc.org | 0bf2ca2 | 2011-11-29 18:21:46 +0000 | [diff] [blame] | 71 | EXPECT_GE(cores[i], 0u); |
| 72 | EXPECT_LE(cores[i], 100u); |
henrike@webrtc.org | ad98a3e | 2011-11-18 23:55:12 +0000 | [diff] [blame] | 73 | } |
| 74 | |
kjellander@webrtc.org | 177bb52 | 2011-10-31 17:10:01 +0000 | [diff] [blame] | 75 | Trace::ReturnTrace(); |
| 76 | }; |