1*c33452fbSAndroid Build Coastguard Worker /* 2*c33452fbSAndroid Build Coastguard Worker * Copyright (c) 2015, Intel Corporation 3*c33452fbSAndroid Build Coastguard Worker * All rights reserved. 4*c33452fbSAndroid Build Coastguard Worker * 5*c33452fbSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without modification, 6*c33452fbSAndroid Build Coastguard Worker * are permitted provided that the following conditions are met: 7*c33452fbSAndroid Build Coastguard Worker * 8*c33452fbSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright notice, this 9*c33452fbSAndroid Build Coastguard Worker * list of conditions and the following disclaimer. 10*c33452fbSAndroid Build Coastguard Worker * 11*c33452fbSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright notice, 12*c33452fbSAndroid Build Coastguard Worker * this list of conditions and the following disclaimer in the documentation and/or 13*c33452fbSAndroid Build Coastguard Worker * other materials provided with the distribution. 14*c33452fbSAndroid Build Coastguard Worker * 15*c33452fbSAndroid Build Coastguard Worker * 3. Neither the name of the copyright holder nor the names of its contributors 16*c33452fbSAndroid Build Coastguard Worker * may be used to endorse or promote products derived from this software without 17*c33452fbSAndroid Build Coastguard Worker * specific prior written permission. 18*c33452fbSAndroid Build Coastguard Worker * 19*c33452fbSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 20*c33452fbSAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 21*c33452fbSAndroid Build Coastguard Worker * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 22*c33452fbSAndroid Build Coastguard Worker * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR 23*c33452fbSAndroid Build Coastguard Worker * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 24*c33452fbSAndroid Build Coastguard Worker * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 25*c33452fbSAndroid Build Coastguard Worker * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON 26*c33452fbSAndroid Build Coastguard Worker * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27*c33452fbSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 28*c33452fbSAndroid Build Coastguard Worker * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29*c33452fbSAndroid Build Coastguard Worker */ 30*c33452fbSAndroid Build Coastguard Worker 31*c33452fbSAndroid Build Coastguard Worker #include "Config.hpp" 32*c33452fbSAndroid Build Coastguard Worker #include "ParameterFramework.hpp" 33*c33452fbSAndroid Build Coastguard Worker #include "ElementHandle.hpp" 34*c33452fbSAndroid Build Coastguard Worker #include "Test.hpp" 35*c33452fbSAndroid Build Coastguard Worker #include "BinaryCopy.hpp" 36*c33452fbSAndroid Build Coastguard Worker 37*c33452fbSAndroid Build Coastguard Worker #include <catch.hpp> 38*c33452fbSAndroid Build Coastguard Worker 39*c33452fbSAndroid Build Coastguard Worker #include <string> 40*c33452fbSAndroid Build Coastguard Worker 41*c33452fbSAndroid Build Coastguard Worker using std::string; 42*c33452fbSAndroid Build Coastguard Worker 43*c33452fbSAndroid Build Coastguard Worker namespace parameterFramework 44*c33452fbSAndroid Build Coastguard Worker { 45*c33452fbSAndroid Build Coastguard Worker 46*c33452fbSAndroid Build Coastguard Worker const auto validInstances = Config{&Config::instances, 47*c33452fbSAndroid Build Coastguard Worker // Size is fixed at 32 and as such is optional */ 48*c33452fbSAndroid Build Coastguard Worker R"(<FloatingPointParameter Name="Empty"/> 49*c33452fbSAndroid Build Coastguard Worker <FloatingPointParameter Name="trivial" Size="32"/> 50*c33452fbSAndroid Build Coastguard Worker <FloatingPointParameter Name="nominal" Size="32" Min="-50.4" Max="12.2"/> 51*c33452fbSAndroid Build Coastguard Worker <FloatingPointParameter Name="defaultMin" Size="32" Max="12.2"/> 52*c33452fbSAndroid Build Coastguard Worker <FloatingPointParameter Name="defaultMax" Size="32" Min="-50.4"/>)"}; 53*c33452fbSAndroid Build Coastguard Worker const auto &invalidParameters = 54*c33452fbSAndroid Build Coastguard Worker Tests<string>{{"invalid Size(64)", "<FloatingPointParameter Name='error' Size='64'/>"}, 55*c33452fbSAndroid Build Coastguard Worker {"invalid Size(16)", "<FloatingPointParameter Name='error' Size='16'/>"}, 56*c33452fbSAndroid Build Coastguard Worker {"minimum > maximum", "<FloatingPointParameter Name='error' Min='1' Max='0'/>"}}; 57*c33452fbSAndroid Build Coastguard Worker 58*c33452fbSAndroid Build Coastguard Worker struct FloatsPF : public ParameterFramework 59*c33452fbSAndroid Build Coastguard Worker { FloatsPFparameterFramework::FloatsPF60*c33452fbSAndroid Build Coastguard Worker FloatsPF() : ParameterFramework{std::move(validInstances)} {} 61*c33452fbSAndroid Build Coastguard Worker }; 62*c33452fbSAndroid Build Coastguard Worker 63*c33452fbSAndroid Build Coastguard Worker SCENARIO_METHOD(LazyPF, "Invalid floating points XML structure", "[floating point]") 64*c33452fbSAndroid Build Coastguard Worker { 65*c33452fbSAndroid Build Coastguard Worker for (auto &vec : invalidParameters) { 66*c33452fbSAndroid Build Coastguard Worker GIVEN ("intentional error: " + vec.title) { 67*c33452fbSAndroid Build Coastguard Worker create(Config{&Config::instances, vec.payload}); 68*c33452fbSAndroid Build Coastguard Worker THEN ("Start should fail") { 69*c33452fbSAndroid Build Coastguard Worker CHECK_THROWS_AS(mPf->start(), Exception); 70*c33452fbSAndroid Build Coastguard Worker } 71*c33452fbSAndroid Build Coastguard Worker } 72*c33452fbSAndroid Build Coastguard Worker } 73*c33452fbSAndroid Build Coastguard Worker } 74*c33452fbSAndroid Build Coastguard Worker 75*c33452fbSAndroid Build Coastguard Worker SCENARIO_METHOD(FloatsPF, "Floating points", "[floating points]") 76*c33452fbSAndroid Build Coastguard Worker { 77*c33452fbSAndroid Build Coastguard Worker GIVEN ("A valid XML structure file") { 78*c33452fbSAndroid Build Coastguard Worker THEN ("Start should succeed") { 79*c33452fbSAndroid Build Coastguard Worker CHECK_NOTHROW(start()); 80*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(setTuningMode(true)); 81*c33452fbSAndroid Build Coastguard Worker string path = "/test/test/nominal"; 82*c33452fbSAndroid Build Coastguard Worker 83*c33452fbSAndroid Build Coastguard Worker AND_THEN ("Set/Get a floating point parameter in real value space") { 84*c33452fbSAndroid Build Coastguard Worker 85*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<string>{ 86*c33452fbSAndroid Build Coastguard Worker {"(too high)", "12.3"}, 87*c33452fbSAndroid Build Coastguard Worker {"(too low)", "-50.5"}, 88*c33452fbSAndroid Build Coastguard Worker {"(not a number)", "foobar"}, 89*c33452fbSAndroid Build Coastguard Worker }) { 90*c33452fbSAndroid Build Coastguard Worker GIVEN ("Invalid value " + vec.title) { 91*c33452fbSAndroid Build Coastguard Worker CHECK_THROWS_AS(setParameter(path, vec.payload), Exception); 92*c33452fbSAndroid Build Coastguard Worker } 93*c33452fbSAndroid Build Coastguard Worker } 94*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<string>{ 95*c33452fbSAndroid Build Coastguard Worker {"(upper limit)", "12.2"}, 96*c33452fbSAndroid Build Coastguard Worker {"(lower limit)", "-50.4"}, 97*c33452fbSAndroid Build Coastguard Worker {"(inside range)", "0"}, 98*c33452fbSAndroid Build Coastguard Worker }) { 99*c33452fbSAndroid Build Coastguard Worker GIVEN ("A valid value " + vec.title) { 100*c33452fbSAndroid Build Coastguard Worker CHECK_NOTHROW(setParameter(path, vec.payload)); 101*c33452fbSAndroid Build Coastguard Worker string getValueBack; 102*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(getParameter(path, getValueBack)); 103*c33452fbSAndroid Build Coastguard Worker CHECK(getValueBack == vec.payload); 104*c33452fbSAndroid Build Coastguard Worker } 105*c33452fbSAndroid Build Coastguard Worker } 106*c33452fbSAndroid Build Coastguard Worker } 107*c33452fbSAndroid Build Coastguard Worker 108*c33452fbSAndroid Build Coastguard Worker AND_THEN ("Set/Get a floating point parameter in raw value space") { 109*c33452fbSAndroid Build Coastguard Worker const float tooHigh = 12.3f; 110*c33452fbSAndroid Build Coastguard Worker const float tooLow = -50.5f; 111*c33452fbSAndroid Build Coastguard Worker const float nan = std::numeric_limits<float>::quiet_NaN(); 112*c33452fbSAndroid Build Coastguard Worker const float inf = std::numeric_limits<float>::infinity(); 113*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(setRawValueSpace(true)); 114*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<string>{ 115*c33452fbSAndroid Build Coastguard Worker {"(too high, as decimal)", 116*c33452fbSAndroid Build Coastguard Worker std::to_string(::utility::binaryCopy<uint32_t>(tooHigh))}, 117*c33452fbSAndroid Build Coastguard Worker {"(too low, as decimal)", 118*c33452fbSAndroid Build Coastguard Worker std::to_string(::utility::binaryCopy<uint32_t>(tooLow))}, 119*c33452fbSAndroid Build Coastguard Worker {"(meaningless)", "foobar"}, 120*c33452fbSAndroid Build Coastguard Worker {"(infinity)", std::to_string(::utility::binaryCopy<uint32_t>(inf))}, 121*c33452fbSAndroid Build Coastguard Worker {"(NaN)", std::to_string(::utility::binaryCopy<uint32_t>(nan))}, 122*c33452fbSAndroid Build Coastguard Worker }) { 123*c33452fbSAndroid Build Coastguard Worker GIVEN ("Invalid value " + vec.title) { 124*c33452fbSAndroid Build Coastguard Worker CHECK_THROWS_AS(setParameter(path, vec.payload), Exception); 125*c33452fbSAndroid Build Coastguard Worker } 126*c33452fbSAndroid Build Coastguard Worker } 127*c33452fbSAndroid Build Coastguard Worker const float upper = 12.2f; 128*c33452fbSAndroid Build Coastguard Worker const float lower = -50.4f; 129*c33452fbSAndroid Build Coastguard Worker const float zero = 0.0f; 130*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<string>{ 131*c33452fbSAndroid Build Coastguard Worker {"(upper limit, as decimal)", 132*c33452fbSAndroid Build Coastguard Worker std::to_string(::utility::binaryCopy<uint32_t>(upper))}, 133*c33452fbSAndroid Build Coastguard Worker {"(lower limit, as decimal)", 134*c33452fbSAndroid Build Coastguard Worker std::to_string(::utility::binaryCopy<uint32_t>(lower))}, 135*c33452fbSAndroid Build Coastguard Worker {"(inside range, as decimal)", 136*c33452fbSAndroid Build Coastguard Worker std::to_string(::utility::binaryCopy<uint32_t>(zero))}, 137*c33452fbSAndroid Build Coastguard Worker }) { 138*c33452fbSAndroid Build Coastguard Worker GIVEN ("A valid value " + vec.title) { 139*c33452fbSAndroid Build Coastguard Worker CHECK_NOTHROW(setParameter(path, vec.payload)); 140*c33452fbSAndroid Build Coastguard Worker string getValueBack; 141*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(getParameter(path, getValueBack)); 142*c33452fbSAndroid Build Coastguard Worker CHECK(getValueBack == vec.payload); 143*c33452fbSAndroid Build Coastguard Worker } 144*c33452fbSAndroid Build Coastguard Worker } 145*c33452fbSAndroid Build Coastguard Worker } 146*c33452fbSAndroid Build Coastguard Worker 147*c33452fbSAndroid Build Coastguard Worker AND_THEN ("Set/Get floating point parameter handle") { 148*c33452fbSAndroid Build Coastguard Worker ElementHandle handle{*this, path}; 149*c33452fbSAndroid Build Coastguard Worker /** @FIXME: 'set' operations on a ParameterHandle are silently 150*c33452fbSAndroid Build Coastguard Worker * ignored in tuning mode. Does it make sense ? */ 151*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(setTuningMode(false)); 152*c33452fbSAndroid Build Coastguard Worker 153*c33452fbSAndroid Build Coastguard Worker /* warning: even though the API below takes a double as 154*c33452fbSAndroid Build Coastguard Worker * argument, we need to define the test vector as floats in 155*c33452fbSAndroid Build Coastguard Worker * order to prevent rounding issues */ 156*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<float>{ 157*c33452fbSAndroid Build Coastguard Worker {"(upper limit)", 12.2f}, 158*c33452fbSAndroid Build Coastguard Worker {"(lower limit)", -50.4f}, 159*c33452fbSAndroid Build Coastguard Worker {"(inside range)", 0.0f}, 160*c33452fbSAndroid Build Coastguard Worker }) { 161*c33452fbSAndroid Build Coastguard Worker GIVEN ("A valid value " + vec.title) { 162*c33452fbSAndroid Build Coastguard Worker CHECK_NOTHROW(handle.setAsDouble(vec.payload)); 163*c33452fbSAndroid Build Coastguard Worker double getValueBack; 164*c33452fbSAndroid Build Coastguard Worker REQUIRE_NOTHROW(handle.getAsDouble(getValueBack)); 165*c33452fbSAndroid Build Coastguard Worker CHECK(getValueBack == vec.payload); 166*c33452fbSAndroid Build Coastguard Worker } 167*c33452fbSAndroid Build Coastguard Worker } 168*c33452fbSAndroid Build Coastguard Worker for (auto &vec : Tests<float>{ 169*c33452fbSAndroid Build Coastguard Worker {"(too high)", 12.3f}, {"(too low)", -50.5f}, 170*c33452fbSAndroid Build Coastguard Worker }) { 171*c33452fbSAndroid Build Coastguard Worker GIVEN ("An invalid value " + vec.title) { 172*c33452fbSAndroid Build Coastguard Worker CHECK_THROWS_AS(handle.setAsDouble(vec.payload), Exception); 173*c33452fbSAndroid Build Coastguard Worker } 174*c33452fbSAndroid Build Coastguard Worker } 175*c33452fbSAndroid Build Coastguard Worker } 176*c33452fbSAndroid Build Coastguard Worker } 177*c33452fbSAndroid Build Coastguard Worker } 178*c33452fbSAndroid Build Coastguard Worker } 179*c33452fbSAndroid Build Coastguard Worker } // namespace parameterFramework 180