summaryrefslogtreecommitdiffstats
path: root/test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py')
-rw-r--r--test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py294
1 files changed, 294 insertions, 0 deletions
diff --git a/test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py b/test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py
new file mode 100644
index 0000000..1544cae
--- /dev/null
+++ b/test/functional-tests/PfwTestCase/Domains/tDomain_Elements_Sequences.py
@@ -0,0 +1,294 @@
+# -*-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.
+
+"""
+Element Sequence testcases
+
+List of tested functions :
+--------------------------
+ - [setElementSequence] function
+ - [getElementSequence] function
+
+Test cases :
+------------
+ - Testing setElementSequence errors
+ - Testing getElementSequence errors
+ - Testing nominal case
+"""
+import os
+from Util.PfwUnitTestLib import PfwTestCase
+from Util import ACTLogging
+log=ACTLogging.Logger()
+
+class TestCases(PfwTestCase):
+ def setUp(self):
+ self.pfw.sendCmd("setTuningMode", "on")
+ self.domain_name = "Domain_0"
+ self.elem_0_path = "/Test/Test/TEST_DIR"
+ self.elem_1_path = "/Test/Test/TEST_DOMAIN_0"
+ self.elem_2_path = "/Test/Test/TEST_DOMAIN_1"
+ self.configuration = "Conf_0"
+
+ def tearDown(self):
+ self.pfw.sendCmd("setTuningMode", "off")
+
+ def test_Nominal_Case(self):
+ """
+ Testing nominal case
+ --------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - set a new sequences order for a selected configuration
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [setElementSequence] function
+ - [getElementSequence] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - all operations succeed
+ - new sequences order conform to expected order
+ """
+ log.D(self.test_Nominal_Case.__doc__)
+
+ # Adding new domain elements
+ log.I("Working on domain %s" % (self.domain_name))
+ log.I("Adding a new domain element to domain %s" % (self.domain_name))
+ out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ log.I("Adding a new domain element to domain %s" % (self.domain_name))
+ out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_2_path))
+ assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_2_path)
+ assert out == "Done", "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_2_path)
+ log.I("New domain elements %s and %s added to domain %s" % (self.elem_1_path, self.elem_2_path, self.domain_name))
+
+ # Getting elements sequence from selected configuration
+ log.I("Getting elements sequence from configuration %s" % (self.configuration))
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ log.I("Listing elements sequence for configuration %s correctly executed :\n%s" % (self.configuration, out))
+
+ # Setting new elements sequence order for selected configuration
+ log.I("Setting new elements sequence order for configuration %s" % (self.configuration))
+ out, err = self.pfw.sendCmd("setElementSequence", self.domain_name, self.configuration, self.elem_2_path, self.elem_0_path, self.elem_1_path)
+ assert err == None, "ERROR : command [setElementSequence] - Error while setting new elements sequence for configuration %s" % (self.configuration)
+ assert out == "Done", "ERROR : command [setElementSequence] - Error while setting new elements sequence for configuration %s" % (self.configuration)
+ log.I("Setting new elements sequence for configuration %s correctly executed")
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ log.I("New elements sequence for configuration %s :\n%s" % (self.configuration, out))
+
+ # Checking new elements sequence order conformity for selected configuration
+ log.I("Checking new elements sequence order for configuration")
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "w")
+ f_ConfigElementsOrder.write(out)
+ f_ConfigElementsOrder.close()
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "r")
+ element_name = f_ConfigElementsOrder.readline().strip('\n')
+ assert element_name==self.elem_2_path, "ERROR : Error while modifying configuration %s elements order on domain %s" % (self.configuration)
+ element_name = f_ConfigElementsOrder.readline().strip('\n')
+ assert element_name==self.elem_0_path, "ERROR : Error while modifying configuration %s elements order on domain %s" % (self.configuration)
+ element_name = f_ConfigElementsOrder.readline().strip('\n')
+ assert element_name==self.elem_1_path, "ERROR : Error while modifying configuration %s elements order on domain %s" % (self.configuration)
+ log.I("New elements sequence order conform to expected order for configuration %s" % (self.configuration))
+ # Closing and removing temp file
+ f_ConfigElementsOrder.close()
+ os.remove("f_ConfigElementsOrder")
+ # Removing created domain element
+ out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+ out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), str(self.elem_2_path))
+ assert err == None, "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_2_path)
+ assert out == "Done", "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_2_path)
+
+ def test_setElementSequence_errors(self):
+ """
+ Testing setElementSequence_errors
+ ---------------------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - Setting an element not belonging to configuration
+ - Setting undefined element in sequence order
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [setElementSequence] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - all errors correctly detected
+ - no impact on initial sequences order
+ """
+ log.D(self.test_setElementSequence_errors.__doc__)
+
+ # Adding a new domain element
+ log.I("Working on domain %s" % (self.domain_name))
+ log.I("Adding a new domain element to domain %s" % (self.domain_name))
+ out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ log.I("New domain element %s added to domain %s" % (self.elem_1_path, self.domain_name))
+
+ # Getting elements sequence from selected configuration
+ log.I("Getting elements sequence from configuration %s" % (self.configuration))
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ log.I("Listing elements sequence for configuration %s correctly executed :\n%s" % (self.configuration, out))
+
+ # Elements sequence backup
+ f_ConfigElementsOrder_Backup = open("f_ConfigElementsOrder_Backup", "w")
+ f_ConfigElementsOrder_Backup.write(out)
+ f_ConfigElementsOrder_Backup.close()
+
+ # Setting an element not belonging to configuration in sequence order
+ log.I("Setting an element not belonging to configuration %s in sequence order" % (self.configuration))
+ out, err = self.pfw.sendCmd("setElementSequence", self.domain_name, self.configuration, self.elem_2_path, self.elem_0_path, self.elem_1_path)
+ assert err == None, "ERROR : command [setElementSequence] - Error while setting elements sequence for configuration %s" % (self.configuration)
+ assert out != "Done", "ERROR : command [setElementSequence] - Error not detected when setting an element not belonging to configuration"
+
+ # Setting undefined element in sequence order for selected configuration
+ log.I("Setting undefined element in sequence order for configuration %s" % (self.configuration))
+ out, err = self.pfw.sendCmd("setElementSequence", self.domain_name, self.configuration, "Wrong_Element_Name", self.elem_0_path, self.elem_1_path)
+ assert err == None, "ERROR : command [setElementSequence] - Error while setting elements sequence for configuration %s" % (self.configuration)
+ assert out != "Done", "ERROR : command [getElementSequence] - Error not detected when setting an undefined element to configuration"
+
+ # Getting elements sequence from selected configuration for checking purpose
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ # Elements sequence backup
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "w")
+ f_ConfigElementsOrder.write(out)
+ f_ConfigElementsOrder.close()
+
+ # Checking new elements sequence order conformity for selected configuration
+ log.I("Checking new elements sequence order for configuration")
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "r")
+ f_ConfigElementsOrder_Backup = open("f_ConfigElementsOrder_Backup", "r")
+ new_element_name = f_ConfigElementsOrder.readline().strip('\n')
+ element_name = f_ConfigElementsOrder_Backup.readline().strip('\n')
+ assert element_name==new_element_name, "ERROR : setElementSequence errors have affected elements order on domain %s" % (self.configuration)
+ new_element_name = f_ConfigElementsOrder.readline().strip('\n')
+ element_name = f_ConfigElementsOrder_Backup.readline().strip('\n')
+ assert element_name==new_element_name, "ERROR : setElementSequence errors have affected elements order on domain %s" % (self.configuration)
+ log.I("Elements sequence order not affected by setElementSequence errors")
+
+ # Closing and removing temp file
+ f_ConfigElementsOrder.close()
+ f_ConfigElementsOrder_Backup.close()
+ os.remove("f_ConfigElementsOrder")
+ os.remove("f_ConfigElementsOrder_Backup")
+ # Removing created domain element
+ out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+
+ def test_getElementSequence_errors(self):
+ """
+ Testing getElementSequence_errors
+ ---------------------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - Getting an element sequence on a wrong domain name
+ - Getting an element sequence on a wrong configuration name
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [getElementSequence] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - all errors correctly detected
+ - no impact on initial sequences order
+ """
+ log.D(self.test_getElementSequence_errors.__doc__)
+
+ # Adding new domain elements
+ log.I("Adding a new domain element to domain %s" % (self.domain_name))
+ out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_1_path)
+ log.I("Adding a new domain element to domain %s" % (self.domain_name))
+ out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_2_path))
+ assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_2_path)
+ assert out == "Done", "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_2_path)
+ log.I("New domain elements %s and %s added to domain %s" % (self.elem_1_path, self.elem_2_path, self.domain_name))
+
+ # Getting elements sequence from selected configuration
+ log.I("Getting elements sequence from configuration %s" % (self.configuration))
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ log.I("Listing elements sequence for configuration %s correctly executed :\n%s" % (self.configuration, out))
+
+ # Elements sequence backup
+ f_ConfigElementsOrder_Backup = open("f_ConfigElementsOrder_Backup", "w")
+ f_ConfigElementsOrder_Backup.write(out)
+ f_ConfigElementsOrder_Backup.close()
+
+ # Getting an element sequence on a wrong domain name
+ log.I("Getting an element sequence on a wrong domain name")
+ out, err = self.pfw.sendCmd("getElementSequence", "Wrong_Domain_Name", self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error when getting elements sequence for configuration %s" % (self.configuration)
+ assert out != "Done", "ERROR : command [getElementSequence] - Error not detected when getting elements sequence for a wrong domain name"
+
+ # Getting an element sequence on a wrong configuration name
+ log.I("Getting an element sequence on a wrong configuration name")
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, "Wrong_Configuration_Name")
+ assert err == None, "ERROR : command [getElementSequence] - Error when getting elements sequence on a wrong configuration name"
+ assert out != "Done", "ERROR : command [getElementSequence] - Error not detected when getting elements sequence on a wrong configuration name"
+
+ # Getting elements sequence from selected configuration for checking purpose
+ out, err = self.pfw.sendCmd("getElementSequence", self.domain_name, self.configuration)
+ assert err == None, "ERROR : command [getElementSequence] - Error while listing elements sequence for configuration %s" % (self.configuration)
+ # Elements sequence backup
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "w")
+ f_ConfigElementsOrder.write(out)
+ f_ConfigElementsOrder.close()
+
+ # Checking new elements sequence order conformity for selected configuration
+ log.I("Checking new elements sequence order for configuration")
+ f_ConfigElementsOrder = open("f_ConfigElementsOrder", "r")
+ f_ConfigElementsOrder_Backup = open("f_ConfigElementsOrder_Backup", "r")
+ new_element_name = f_ConfigElementsOrder.readline().strip('\n')
+ element_name = f_ConfigElementsOrder_Backup.readline().strip('\n')
+ assert element_name==new_element_name, "ERROR : getElementSequence errors have affected elements order on domain %s" % (self.configuration)
+ new_element_name = f_ConfigElementsOrder.readline().strip('\n')
+ element_name = f_ConfigElementsOrder_Backup.readline().strip('\n')
+ assert element_name==new_element_name, "ERROR : getElementSequence errors have affected elements order on domain %s" % (self.configuration)
+ log.I("Elements sequence order not affected by getElementSequence errors")
+
+ # Closing and removing temp file
+ f_ConfigElementsOrder.close()
+ f_ConfigElementsOrder_Backup.close()
+ os.remove("f_ConfigElementsOrder")
+ os.remove("f_ConfigElementsOrder_Backup")
+ # Removing created domain element
+ out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), str(self.elem_1_path))
+ assert err == None, "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+ assert out == "Done", "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_1_path)
+ out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), str(self.elem_2_path))
+ assert err == None, "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_2_path)
+ assert out == "Done", "ERROR : command [removeElement] - Error while removing domain element %s" % (self.elem_2_path)