| /* |
| * Copyright 2017 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. |
| */ |
| |
| //#define LOG_NDEBUG 0 |
| #define LOG_TAG "audio_utils_powerlog_tests" |
| |
| #include <audio_utils/PowerLog.h> |
| |
| #include <audio_utils/clock.h> |
| #include <gtest/gtest.h> |
| #include <iostream> |
| #include <log/log.h> |
| |
| using namespace android; |
| |
| static size_t countNewLines(const std::string &s) { |
| return std::count(s.begin(), s.end(), '\n'); |
| } |
| |
| TEST(audio_utils_powerlog, basic_level_1) { |
| auto plog = std::make_unique<PowerLog>( |
| 48000 /* sampleRate */, |
| 1 /* channelCount */, |
| AUDIO_FORMAT_PCM_16_BIT, |
| 100 /* entries */, |
| 1 /* framesPerEntry */, |
| 1 /* levels */); |
| |
| // header |
| EXPECT_EQ((size_t)1, countNewLines(plog->dumpToString())); |
| |
| const int16_t zero = 0; |
| const int16_t half = 0x4000; |
| |
| plog->log(&half, 1 /* frame */, 0 /* nowNs */); |
| plog->log(&half, 1 /* frame */, 1 /* nowNs */); |
| plog->log(&half, 1 /* frame */, 2 /* nowNs */); |
| |
| // one line / signal |
| EXPECT_EQ((size_t)2, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 0 /* limitNs */, false /* logPlot */))); |
| |
| // one line / signal + logplot |
| EXPECT_EQ((size_t)20, countNewLines(plog->dumpToString())); |
| |
| plog->log(&zero, 1 /* frame */, 3 /* nowNs */); |
| // zero termination doesn't change this. |
| EXPECT_EQ((size_t)20, countNewLines(plog->dumpToString())); |
| |
| // but adding next line does. |
| plog->log(&half, 1 /* frame */, 4 /* nowNs */); |
| EXPECT_EQ((size_t)21, countNewLines(plog->dumpToString())); |
| |
| // truncating on lines (this does not include the logplot). |
| EXPECT_EQ((size_t)20, countNewLines(plog->dumpToString( |
| "" /* prefix */, 2 /* lines */))); |
| |
| // truncating on time as well. |
| EXPECT_EQ((size_t)21, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 2 /* limitNs */))); |
| // truncating on different time limit. |
| EXPECT_EQ((size_t)20, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 3 /* limitNs */))); |
| |
| // truncating on a larger line count (this doesn't include the logplot). |
| EXPECT_EQ((size_t)21, countNewLines(plog->dumpToString( |
| "" /* prefix */, 3 /* lines */, 2 /* limitNs */))); |
| |
| plog->dump(0 /* fd (stdout) */); |
| |
| // The output below depends on the local time zone. |
| // The indentation below is exact, check alignment. |
| /* |
| Signal power history: |
| 01-01 00:00:00.000: [ -6.0 -6.0 -6.0 ] sum(-1.2) |
| 01-01 00:00:00.000: [ -6.0 |
| |
| -0.0 -| | |
| -1.0 -| | |
| -2.0 -| | |
| -3.0 -| | |
| -4.0 -| | |
| -5.0 -| | |
| -6.0 -|***| |
| -7.0 -| | |
| -8.0 -| | |
| -9.0 -| | |
| -10.0 -| | |
| -11.0 -| | |
| -12.0 -| | |
| -13.0 -| | |
| |____ |
| |
| */ |
| } |
| |
| TEST(audio_utils_powerlog, basic_level_2) { |
| const uint32_t kSampleRate = 48000; |
| auto plog = std::make_unique<PowerLog>( |
| kSampleRate /* sampleRate */, |
| 1 /* channelCount */, |
| AUDIO_FORMAT_PCM_16_BIT, |
| 200 /* entries */, |
| 1 /* framesPerEntry */, |
| 2 /* levels */); |
| |
| // header |
| EXPECT_EQ((size_t)2, countNewLines(plog->dumpToString())); |
| |
| const int16_t zero = 0; |
| const int16_t half = 0x4000; |
| const std::vector<int16_t> ary(60, 0x1000); |
| |
| plog->log(&half, 1 /* frame */, 0 /* nowNs */); |
| plog->log(&half, 1 /* frame */, 1 * NANOS_PER_SECOND / kSampleRate); |
| plog->log(&half, 1 /* frame */, 2 * NANOS_PER_SECOND / kSampleRate); |
| plog->log(ary.data(), ary.size(), 30 * NANOS_PER_SECOND / kSampleRate); |
| |
| EXPECT_EQ((size_t)10, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 0 /* limitNs */, false /* logPlot */))); |
| |
| // add logplot |
| EXPECT_EQ((size_t)28, countNewLines(plog->dumpToString())); |
| |
| plog->log(&zero, 1 /* frame */, 100 * NANOS_PER_SECOND / kSampleRate); |
| // zero termination doesn't change this. |
| EXPECT_EQ((size_t)28, countNewLines(plog->dumpToString())); |
| |
| // but adding next line does. |
| plog->log(&half, 1 /* frame */, 101 * NANOS_PER_SECOND / kSampleRate); |
| EXPECT_EQ((size_t)29, countNewLines(plog->dumpToString())); |
| |
| // truncating on lines (this does not include the logplot). |
| EXPECT_EQ((size_t)22, countNewLines(plog->dumpToString( |
| "" /* prefix */, 4 /* lines */))); |
| |
| // truncating on time as well. |
| EXPECT_EQ((size_t)29, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 2 /* limitNs */))); |
| // truncating on different time limit. |
| EXPECT_EQ((size_t)29, countNewLines(plog->dumpToString( |
| "" /* prefix */, 0 /* lines */, 3 /* limitNs */))); |
| |
| // truncating on a larger line count (this doesn't include the logplot). |
| EXPECT_EQ((size_t)21, countNewLines(plog->dumpToString( |
| "" /* prefix */, 3 /* lines */, 2 /* limitNs */))); |
| |
| plog->dump(0 /* fd (stdout) */); |
| |
| // The output below depends on the local time zone. |
| // The indentation below is exact, check alignment. |
| /* |
| Signal power history (resolution: 0.4 ms): |
| 12-31 16:00:00.000: [ -14.3 -18.1 -18.1 -18.1 |
| Signal power history (resolution: 0.0 ms): |
| 12-31 16:00:00.000: [ -6.0 -6.0 -6.0 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.000: -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.000: -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.001: -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.001: -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.001: -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 -18.1 |
| 12-31 16:00:00.001: -18.1 -18.1 -18.1 ] sum(2.3) |
| 12-31 16:00:00.002: [ -6.0 |
| |
| -6.0 -|*** | |
| -7.0 -| | |
| -8.0 -| | |
| -9.0 -| | |
| -10.0 -| | |
| -11.0 -| | |
| -12.0 -| | |
| -13.0 -| | |
| -14.0 -| | |
| -15.0 -| | |
| -16.0 -| | |
| -17.0 -| | |
| -18.0 -| ************************************************************| |
| -19.0 -| | |
| |________________________________________________________________ |
| */ |
| } |
| |
| TEST(audio_utils_powerlog, c) { |
| power_log_t *power_log = power_log_create( |
| 48000 /* sample_rate */, |
| 1 /* channel_count */, |
| AUDIO_FORMAT_PCM_16_BIT, |
| 100 /* entries */, |
| 1 /* frames_per_entry */); |
| |
| // soundness test |
| const int16_t zero = 0; |
| const int16_t quarter = 0x2000; |
| |
| power_log_log(power_log, &quarter, 1 /* frame */, 0 /* now_ns */); |
| power_log_log(power_log, &zero, 1 /* frame */, 1 /* now_ns */); |
| power_log_dump(power_log, 0 /* fd */, " " /* prefix */, 0 /* lines */, 0 /* limit_ns */); |
| power_log_destroy(power_log); |
| |
| // This has a 2 character prefix offset from the previous test when dumping. |
| // The indentation below is exact, check alignment. |
| /* |
| Signal power history: |
| 12-31 16:00:00.000: [ -12.0 ] sum(-12.0) |
| */ |
| } |