Mercurial > hg > vamp-plugin-tester
comparison TestDefaults.cpp @ 5:6a279da6fdd7
* Add tests for default programs & parameters, etc
author | cannam |
---|---|
date | Tue, 17 Mar 2009 17:46:25 +0000 |
parents | |
children | ba3c8cc649d3 |
comparison
equal
deleted
inserted
replaced
4:d8724c5a6d83 | 5:6a279da6fdd7 |
---|---|
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ | |
2 | |
3 /* | |
4 Vamp Plugin Tester | |
5 Chris Cannam, cannam@all-day-breakfast.com | |
6 Centre for Digital Music, Queen Mary, University of London. | |
7 Copyright 2009 QMUL. | |
8 | |
9 This program loads a Vamp plugin and tests its susceptibility to a | |
10 number of common pitfalls, including handling of extremes of input | |
11 data. If you can think of any additional useful tests that are | |
12 easily added, please send them to me. | |
13 | |
14 Permission is hereby granted, free of charge, to any person | |
15 obtaining a copy of this software and associated documentation | |
16 files (the "Software"), to deal in the Software without | |
17 restriction, including without limitation the rights to use, copy, | |
18 modify, merge, publish, distribute, sublicense, and/or sell copies | |
19 of the Software, and to permit persons to whom the Software is | |
20 furnished to do so, subject to the following conditions: | |
21 | |
22 The above copyright notice and this permission notice shall be | |
23 included in all copies or substantial portions of the Software. | |
24 | |
25 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
26 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
27 MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | |
28 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR | |
29 ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF | |
30 CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | |
31 WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
32 | |
33 Except as contained in this notice, the names of the Centre for | |
34 Digital Music; Queen Mary, University of London; and Chris Cannam | |
35 shall not be used in advertising or otherwise to promote the sale, | |
36 use or other dealings in this Software without prior written | |
37 authorization. | |
38 */ | |
39 | |
40 #include "TestDefaults.h" | |
41 | |
42 #include <vamp-hostsdk/Plugin.h> | |
43 using namespace Vamp; | |
44 | |
45 #include <memory> | |
46 using namespace std; | |
47 | |
48 #include <cmath> | |
49 | |
50 Tester::TestRegistrar<TestDefaultProgram> | |
51 TestDefaultProgram::m_registrar("E1 Inconsistent default program"); | |
52 | |
53 Tester::TestRegistrar<TestDefaultParameters> | |
54 TestDefaultParameters::m_registrar("E2 Inconsistent default parameters"); | |
55 | |
56 static const size_t _step = 1000; | |
57 | |
58 Test::Results | |
59 TestDefaultProgram::test(string key) | |
60 { | |
61 Plugin::FeatureSet f[2]; | |
62 int rate = 44100; | |
63 Results r; | |
64 float **data = 0; | |
65 size_t channels = 0; | |
66 size_t count = 100; | |
67 | |
68 for (int run = 0; run < 2; ++run) { | |
69 auto_ptr<Plugin> p(load(key, rate)); | |
70 if (p->getPrograms().empty()) return r; | |
71 if (run == 1) { | |
72 p->selectProgram(p->getCurrentProgram()); | |
73 } | |
74 if (!initAdapted(p.get(), channels, _step, _step, r)) return r; | |
75 if (!data) data = createTestAudio(channels, _step, count); | |
76 for (size_t i = 0; i < count; ++i) { | |
77 float *ptr[channels]; | |
78 size_t idx = i * _step; | |
79 for (size_t c = 0; c < channels; ++c) ptr[c] = data[c] + idx; | |
80 RealTime timestamp = RealTime::frame2RealTime(idx, rate); | |
81 Plugin::FeatureSet fs = p->process(ptr, timestamp); | |
82 appendFeatures(f[run], fs); | |
83 } | |
84 Plugin::FeatureSet fs = p->getRemainingFeatures(); | |
85 appendFeatures(f[run], fs); | |
86 } | |
87 if (data) destroyTestAudio(data, channels); | |
88 | |
89 if (!(f[0] == f[1])) { | |
90 r.push_back(warning("Explicitly setting current program to its supposed current value changes the results")); | |
91 } else { | |
92 r.push_back(success()); | |
93 } | |
94 | |
95 return r; | |
96 } | |
97 | |
98 Test::Results | |
99 TestDefaultParameters::test(string key) | |
100 { | |
101 Plugin::FeatureSet f[2]; | |
102 int rate = 44100; | |
103 Results r; | |
104 float **data = 0; | |
105 size_t channels = 0; | |
106 size_t count = 100; | |
107 | |
108 for (int run = 0; run < 2; ++run) { | |
109 auto_ptr<Plugin> p(load(key, rate)); | |
110 if (p->getParameterDescriptors().empty()) return r; | |
111 if (run == 1) { | |
112 Plugin::ParameterList pl = p->getParameterDescriptors(); | |
113 for (int i = 0; i < (int)pl.size(); ++i) { | |
114 if (p->getParameter(pl[i].identifier) != pl[i].defaultValue) { | |
115 r.push_back(error("Not all parameters have their default values when queried directly after construction")); | |
116 } | |
117 p->setParameter(pl[i].identifier, pl[i].defaultValue); | |
118 } | |
119 } | |
120 if (!initAdapted(p.get(), channels, _step, _step, r)) return r; | |
121 if (!data) data = createTestAudio(channels, _step, count); | |
122 for (size_t i = 0; i < count; ++i) { | |
123 float *ptr[channels]; | |
124 size_t idx = i * _step; | |
125 for (size_t c = 0; c < channels; ++c) ptr[c] = data[c] + idx; | |
126 RealTime timestamp = RealTime::frame2RealTime(idx, rate); | |
127 Plugin::FeatureSet fs = p->process(ptr, timestamp); | |
128 appendFeatures(f[run], fs); | |
129 } | |
130 Plugin::FeatureSet fs = p->getRemainingFeatures(); | |
131 appendFeatures(f[run], fs); | |
132 } | |
133 if (data) destroyTestAudio(data, channels); | |
134 | |
135 if (!(f[0] == f[1])) { | |
136 r.push_back(warning("Explicitly setting parameters to their supposed default values changes the results")); | |
137 } else { | |
138 r.push_back(success()); | |
139 } | |
140 | |
141 return r; | |
142 } |