[alsa-devel] [RFCv2][PATCH 31/38] axfer: add a unit test for vumeter calculation
Takashi Sakamoto
o-takashi at sakamocchi.jp
Tue Sep 19 02:44:11 CEST 2017
In a previous commit, vumeter is implemented. This commit adds a simple
unit test for the feature. This tests positive cases only.
Signed-off-by: Takashi Sakamoto <o-takashi at sakamocchi.jp>
---
axfer/test/Makefile.am | 14 +++--
axfer/test/vumeter-test.c | 128 ++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 139 insertions(+), 3 deletions(-)
create mode 100644 axfer/test/vumeter-test.c
diff --git a/axfer/test/Makefile.am b/axfer/test/Makefile.am
index 76a93bfc..0e48b9f2 100644
--- a/axfer/test/Makefile.am
+++ b/axfer/test/Makefile.am
@@ -1,10 +1,12 @@
TESTS = \
- container-test \
- mapper-test
+ container-test \
+ mapper-test \
+ vumeter-test
check_PROGRAMS = \
container-test \
- mapper-test
+ mapper-test \
+ vumeter-test
container_test_SOURCES = \
../container.h \
@@ -29,3 +31,9 @@ mapper_test_SOURCES = \
../mapper-multiple.c \
generator.c \
mapper-test.c
+
+vumeter_test_SOURCES = \
+ ../vumeter.h \
+ ../vumeter.c \
+ generator.c \
+ vumeter-test.c
diff --git a/axfer/test/vumeter-test.c b/axfer/test/vumeter-test.c
new file mode 100644
index 00000000..41a19b13
--- /dev/null
+++ b/axfer/test/vumeter-test.c
@@ -0,0 +1,128 @@
+/*
+ * test-vumeter.c - A unit test for Volume Unit meter.
+ *
+ * Copyright (c) 2017 Takashi Sakamoto <o-takashi at sakamocchi.jp>
+ *
+ * Licensed under the terms of the GNU General Public License, version 2.
+ */
+
+#include "../vumeter.h"
+#include "../misc.h"
+
+#include "generator.h"
+
+#include <stdlib.h>
+
+static int callback(struct test_generator *gen, snd_pcm_access_t access,
+ snd_pcm_format_t sample_format,
+ unsigned int samples_per_frame, void *frame_buffer,
+ unsigned int frame_count)
+{
+ static const enum vumeter_mode modes[] = {
+ [0] = VUMETER_MODE_MONO,
+ [1] = VUMETER_MODE_STEREO,
+ };
+ struct vumeter_context *vu = gen->private_data;
+ int i;
+ int err;
+
+ for (i = 0; i < ARRAY_SIZE(modes); ++i) {
+ int j;
+
+ memset(vu, 0, sizeof(*vu));
+ err = vumeter_context_init(vu, modes[i], access, sample_format,
+ samples_per_frame, 4000);
+ if (err < 0)
+ break;
+ assert(vu->significant_bits_per_sample >= 0);
+ assert(vu->bytes_per_sample >= 0);
+ assert(vu->samples_per_frame >= 0);
+ assert(vu->frames_per_second >= 0);
+ assert(vu->max > 0);
+ assert(vu->peaks != NULL);
+ assert(vu->ratios != NULL);
+ assert(vu->max_ratios_in_second != NULL);
+ assert(vu->printer != NULL);
+ assert(vu->calculator != NULL);
+
+ vumeter_context_prepare(vu);
+ for (j = 0; j < samples_per_frame; ++j) {
+ assert(vu->ratios[j] == 0);
+ assert(vu->max_ratios_in_second[j] == 0);
+ }
+
+ vumeter_context_calculate(vu, frame_buffer, frame_count);
+ for (j = 0; j < samples_per_frame; ++j) {
+ assert(vu->peaks[j] <= vu->max);
+ assert(vu->max_ratios_in_second[j] <= vu->max);
+ assert(vu->max_ratios_in_second[j] <= 100);
+ }
+
+ vumeter_context_destroy(vu);
+ assert(vu->ratios == NULL);
+ assert(vu->max_ratios_in_second == NULL);
+ assert(vu->peaks == NULL);
+ }
+
+ return err;
+}
+
+int main(int argc, const char *argv[])
+{
+ struct test_generator gen = {0};
+ uint64_t access_mask;
+ uint64_t sample_format_mask;
+ int err;
+
+ access_mask = (1ul << SND_PCM_ACCESS_MMAP_INTERLEAVED) |
+ (1ul << SND_PCM_ACCESS_MMAP_NONINTERLEAVED) |
+ (1ul << SND_PCM_ACCESS_RW_INTERLEAVED) |
+ (1ul << SND_PCM_ACCESS_RW_NONINTERLEAVED);
+ sample_format_mask = (1ul << SND_PCM_FORMAT_S8) |
+ (1ul << SND_PCM_FORMAT_U8) |
+ (1ul << SND_PCM_FORMAT_S16_LE) |
+ (1ul << SND_PCM_FORMAT_S16_BE) |
+ (1ul << SND_PCM_FORMAT_U16_LE) |
+ (1ul << SND_PCM_FORMAT_U16_BE) |
+ (1ul << SND_PCM_FORMAT_S24_LE) |
+ (1ul << SND_PCM_FORMAT_S24_BE) |
+ (1ul << SND_PCM_FORMAT_U24_LE) |
+ (1ul << SND_PCM_FORMAT_U24_BE) |
+ (1ul << SND_PCM_FORMAT_S32_LE) |
+ (1ul << SND_PCM_FORMAT_S32_BE) |
+ (1ul << SND_PCM_FORMAT_U32_LE) |
+ (1ul << SND_PCM_FORMAT_U32_BE) |
+ (1ul << SND_PCM_FORMAT_S24_3LE) |
+ (1ul << SND_PCM_FORMAT_S24_3BE) |
+ (1ul << SND_PCM_FORMAT_U24_3LE) |
+ (1ul << SND_PCM_FORMAT_U24_3BE) |
+ (1ul << SND_PCM_FORMAT_S24_3LE) |
+ (1ul << SND_PCM_FORMAT_S24_3BE) |
+ (1ul << SND_PCM_FORMAT_U24_3LE) |
+ (1ul << SND_PCM_FORMAT_U24_3BE) |
+ (1ul << SND_PCM_FORMAT_S20_3LE) |
+ (1ul << SND_PCM_FORMAT_S20_3BE) |
+ (1ul << SND_PCM_FORMAT_U20_3LE) |
+ (1ul << SND_PCM_FORMAT_U20_3BE) |
+ (1ul << SND_PCM_FORMAT_S18_3LE) |
+ (1ul << SND_PCM_FORMAT_S18_3BE) |
+ (1ul << SND_PCM_FORMAT_U18_3LE) |
+ (1ul << SND_PCM_FORMAT_U18_3BE);
+
+ err = generator_context_init(&gen, access_mask, sample_format_mask,
+ 1, 128, 23, 4500, 1024,
+ sizeof(struct vumeter_context));
+ if (err < 0)
+ return EXIT_FAILURE;
+
+ err = generator_context_run(&gen, callback);
+
+ generator_context_destroy(&gen);
+
+ if (err < 0) {
+ printf("%s\n", strerror(-err));
+ return EXIT_FAILURE;
+ }
+
+ return EXIT_SUCCESS;
+}
--
2.11.0
More information about the Alsa-devel
mailing list