/* * Copyright (C) 2018 The Android Open Source Project * * 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 #include #include #include #include #include #include #include "command.h" #include "get_test_data.h" #include "record_file.h" #include "test_util.h" static std::unique_ptr DebugUnwindCmd() { return CreateCommandInstance("debug-unwind"); } TEST(cmd_debug_unwind, smoke) { std::string input_data = GetTestData(PERF_DATA_NO_UNWIND); CaptureStdout capture; TemporaryFile tmp_file; ASSERT_TRUE(capture.Start()); ASSERT_TRUE(DebugUnwindCmd()->Run({"-i", input_data, "-o", tmp_file.path})); ASSERT_NE(capture.Finish().find("Unwinding sample count: 8"), std::string::npos); ASSERT_TRUE(capture.Start()); ASSERT_TRUE(DebugUnwindCmd()->Run({"-i", input_data, "-o", tmp_file.path, "--time", "1516379654300997"})); ASSERT_NE(capture.Finish().find("Unwinding sample count: 1"), std::string::npos); } TEST(cmd_debug_unwind, symfs_option) { std::string input_data = GetTestData(NATIVELIB_IN_APK_PERF_DATA); CaptureStdout capture; TemporaryFile tmp_file; ASSERT_TRUE(capture.Start()); ASSERT_TRUE(DebugUnwindCmd()->Run({"-i", input_data, "-o", tmp_file.path, "--symfs", GetTestDataDir()})); ASSERT_NE(capture.Finish().find("Unwinding sample count: 55"), std::string::npos); std::unique_ptr reader = RecordFileReader::CreateInstance(tmp_file.path); ASSERT_TRUE(reader); const std::map& features = reader->FeatureSectionDescriptors(); ASSERT_NE(features.find(PerfFileFormat::FEAT_FILE), features.end()); ASSERT_NE(features.find(PerfFileFormat::FEAT_META_INFO), features.end()); std::unordered_map info_map; ASSERT_TRUE(reader->ReadMetaInfoFeature(&info_map)); ASSERT_EQ(info_map["debug_unwind"], "true"); } TEST(cmd_debug_unwind, unwind_with_ip_zero_in_callchain) { TemporaryFile tmp_file; CaptureStdout capture; ASSERT_TRUE(capture.Start()); ASSERT_TRUE(DebugUnwindCmd()->Run({"-i", GetTestData(PERF_DATA_WITH_IP_ZERO_IN_CALLCHAIN), "-o", tmp_file.path})); ASSERT_NE(capture.Finish().find("Unwinding sample count: 1"), std::string::npos); }