summaryrefslogtreecommitdiffstats
path: root/test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py')
-rwxr-xr-xtest/functional-tests/PfwTestCase/Types/tFP32_Q0_31.py236
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")