diff options
Diffstat (limited to 'test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py')
-rwxr-xr-x | test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py | 236 |
1 files changed, 236 insertions, 0 deletions
diff --git a/test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py b/test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py new file mode 100755 index 0000000..f521ef7 --- /dev/null +++ b/test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py @@ -0,0 +1,236 @@ +# -*-coding:utf-8 -* + +# Copyright (c) 2011-2015, Intel Corporation +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without modification, +# are permitted provided that the following conditions are met: +# +# 1. Redistributions of source code must retain the above copyright notice, this +# list of conditions and the following disclaimer. +# +# 2. Redistributions in binary form must reproduce the above copyright notice, +# this list of conditions and the following disclaimer in the documentation and/or +# other materials provided with the distribution. +# +# 3. Neither the name of the copyright holder nor the names of its contributors +# may be used to endorse or promote products derived from this software without +# specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR +# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON +# ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +""" +Fixed-Point parameter type testcases - FP16_Q0.31 + +List of tested functions : +-------------------------- + - [setParameter] function + - [getParameter] function + +Initial Settings : +------------------ + FP16_Q0.31 : + - size = 32 bits + - 0 integer bits, 31 fractionnal bits + - range : [-1, 0.9999999995343387126922607421875] + +Test cases : +------------ + - FP16_Q0.31 parameter min value = -1 + - FP16_Q0.31 parameter min value out of bounds = -1.0000000001 + - FP16_Q0.31 parameter max value = 0.9999999995 + - FP16_Q0.31 parameter max value out of bounds = 1 + - FP16_Q0.31 parameter in nominal case = 0.5000000000 +""" +import commands +from Util.PfwUnitTestLib import PfwTestCase +from Util import ACTLogging +log=ACTLogging.Logger() + +# Test of type FP32_Q0.31 - range [-1,0.9999999995343387126922607421875] +class TestCases(PfwTestCase): + def setUp(self): + self.param_name = "/Test/Test/TEST_DIR/FP32_Q0.31" + self.pfw.sendCmd("setTuningMode", "on") + + def tearDown(self): + self.pfw.sendCmd("setTuningMode", "off") + + def test_Nominal_Case(self): + """ + Testing FP16_Q0.31 in nominal case = 0.500000000 + ------------------------------------------------ + Test case description : + ~~~~~~~~~~~~~~~~~~~~~~~ + - set FP16_Q0.31 parameter in nominal case = 0.500000000 + Tested commands : + ~~~~~~~~~~~~~~~~~ + - [setParameter] function + Used commands : + ~~~~~~~~~~~~~~~ + - [getParameter] function + Expected result : + ~~~~~~~~~~~~~~~~~ + - FP16_Q0.31 parameter set to 0.500000000 + - Blackboard and filesystem values checked + """ + log.D(self.test_Nominal_Case.__doc__) + log.I("FP32_Q0.31 parameter in nominal case = 0.500000000") + value = "0.5000000000" + hex_value = "0x40000000" + #Set parameter value + out, err = self.pfw.sendCmd("setParameter", self.param_name, value) + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert out == "Done", log.F("when setting parameter %s : %s" % (self.param_name, out)) + #Check parameter value on blackboard + out, err = self.pfw.sendCmd("getParameter", self.param_name, "") + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert round(float(out),10) == round(float(value),10), log.F("BLACKBOARD : Incorrect value for %s, expected: %s, found: %s" + % (self.param_name, value, out)) + #Check parameter value on filesystem + assert commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') == hex_value, log.F("FILESYSTEM : parameter update error") + log.I("test OK") + + def test_TypeMin(self): + """ + Testing FP16_Q0.31 minimal value = -1 + ------------------------------------- + Test case description : + ~~~~~~~~~~~~~~~~~~~~~~~ + - set FP16_Q0.31 parameter min value = -1 + Tested commands : + ~~~~~~~~~~~~~~~~~ + - [setParameter] function + Used commands : + ~~~~~~~~~~~~~~~ + - [getParameter] function + Expected result : + ~~~~~~~~~~~~~~~~~ + - FP16_Q0.31 parameter set to -1 + - Blackboard and filesystem values checked + """ + log.D(self.test_TypeMin.__doc__) + log.I("FP32_Q0.31 parameter min value = -1") + value = "-1" + hex_value = "0x80000000" + #Set parameter value + out, err = self.pfw.sendCmd("setParameter", self.param_name, value) + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert out == "Done", log.F("when setting parameter %s : %s" % (self.param_name, out)) + #Check parameter value on blackboard + out, err = self.pfw.sendCmd("getParameter", self.param_name, "") + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert round(float(out),10) == round(float(value),10), log.F("BLACKBOARD : Incorrect value for %s, expected: %s, found: %s" + % (self.param_name, value, out)) + #Check parameter value on filesystem + assert commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') == hex_value, log.F("FILESYSTEM : parameter update error") + log.I("test OK") + + def test_TypeMin_Overflow(self): + """ + Testing FP16_Q0.31 parameter value out of negative range + -------------------------------------------------------- + Test case description : + ~~~~~~~~~~~~~~~~~~~~~~~ + - set FP16_Q0.31 to -1.000000001 + Tested commands : + ~~~~~~~~~~~~~~~~~ + - [setParameter] function + Used commands : + ~~~~~~~~~~~~~~~ + - [getParameter] function + Expected result : + ~~~~~~~~~~~~~~~~~ + - error detected + - FP16_Q0.31 parameter not updated + - Blackboard and filesystem values checked + """ + log.D(self.test_TypeMin_Overflow.__doc__) + log.I("FP32_Q0.31 parameter min value out of bounds = -1.000000001") + value = "-1.0000000001" + param_check = commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') + #Set parameter value + out, err = self.pfw.sendCmd("setParameter", self.param_name, value) + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert out != "Done", log.F("PFW : Error not detected when setting parameter %s out of bounds" + % (self.param_name)) + #Check parameter value on filesystem + assert commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') == param_check, log.F("FILESYSTEM : Forbiden parameter change") + log.I("test OK") + + def test_TypeMax(self): + """ + Testing FP16_Q0.31 parameter maximum value + ------------------------------------------ + Test case description : + ~~~~~~~~~~~~~~~~~~~~~~~ + - set FP16_Q0.31 to 0.9999999995 + Tested commands : + ~~~~~~~~~~~~~~~~~ + - [setParameter] function + Used commands : + ~~~~~~~~~~~~~~~ + - [getParameter] function + Expected result : + ~~~~~~~~~~~~~~~~~ + - FP16_Q0.31 parameter set to 0.9999999995 + - Blackboard and filesystem values checked + """ + log.D(self.test_TypeMax.__doc__) + log.I("FP32_Q0.31 parameter max value = 0.9999999995") + value = "0.9999999995" + hex_value = "0x7fffffff" + #Set parameter value + out, err = self.pfw.sendCmd("setParameter", self.param_name, value) + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert out == "Done", log.F("when setting parameter %s : %s" % (self.param_name, out)) + #Check parameter value on blackboard + out, err = self.pfw.sendCmd("getParameter", self.param_name, "") + assert err == None, log.E("when setting parameter %s : %s" % (self.param_name, err)) + assert round(float(out),10) == round(float(value),10), log.F("BLACKBOARD : Incorrect value for %s, expected: %s, found: %s" + % (self.param_name, value, out)) + #Check parameter value on filesystem + assert commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') == hex_value, log.F("FILESYSTEM : parameter update error") + log.I("test OK") + + def test_TypeMax_Overflow(self): + """ + Testing FP16_Q0.31 parameter value out of positive range + -------------------------------------------------------- + Test case description : + ~~~~~~~~~~~~~~~~~~~~~~~ + - set FP16_Q0.31 to 1 + Tested commands : + ~~~~~~~~~~~~~~~~~ + - [setParameter] function + Used commands : + ~~~~~~~~~~~~~~~ + - [getParameter] function + Expected result : + ~~~~~~~~~~~~~~~~~ + - error detected + - FP16_Q0.31 parameter not updated + - Blackboard and filesystem values checked + """ + log.D(self.test_TypeMax_Overflow.__doc__) + log.I("FP32_Q0.31 parameter max value out of bounds = 1") + value = "1" + param_check = commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') + #Set parameter value + out, err = self.pfw.sendCmd("setParameter", self.param_name, value) + assert err == None, log.E("when setting parameter %s : %s" + % (self.param_name, err)) + assert out != "Done", log.F("PFW : Error not detected when setting parameter %s out of bounds" + % (self.param_name)) + #Check parameter value on filesystem + assert commands.getoutput('cat $PFW_FILESYSTEM/FP32_Q0.31') == param_check, log.F("FILESYSTEM : Forbiden parameter change") + log.I("test OK") |