aboutsummaryrefslogtreecommitdiffstats
path: root/test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py')
-rw-r--r--test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py250
1 files changed, 250 insertions, 0 deletions
diff --git a/test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py b/test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py
new file mode 100644
index 0000000..1b8013c
--- /dev/null
+++ b/test/functional-tests/PfwTestCase/Functions/tFunction_Sync.py
@@ -0,0 +1,250 @@
+# -*-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.
+
+"""
+synchronization functions testcases
+
+List of tested functions :
+--------------------------
+ - [getAutoSync] function
+ - [setAutoSync] function
+ - [sync] function
+
+Test cases :
+------------
+ - Testing getAutoSync nominal case
+ - Testing setAutoSync nominal case
+ - Testing sync nominal case
+ - Testing errors
+"""
+import commands, os
+import unittest
+from Util.PfwUnitTestLib import PfwTestCase
+from Util import ACTLogging
+log=ACTLogging.Logger()
+
+class TestCases(PfwTestCase):
+
+ def setUp(self):
+
+ pfw_filesystem=os.getenv("PFW_FILESYSTEM")
+
+ self.pfw.sendCmd("setTuningMode", "on")
+ self.param_name_01 = "/Test/Test/TEST_DIR/BOOL"
+ self.filesystem_01 = pfw_filesystem+"/BOOL"
+ self.param_name_02 = "/Test/Test/TEST_DIR/INT16"
+ self.filesystem_02 = pfw_filesystem+"/INT16"
+ self.param_name_03 = "/Test/Test/TEST_DIR/UINT32"
+ self.filesystem_03 = pfw_filesystem+"/UINT32"
+
+ def tearDown(self):
+ self.pfw.sendCmd("setTuningMode", "off")
+
+ def test_01_getAutoSync_Case(self):
+ """
+ Testing getAutoSync nominal case
+ ----------------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - enable autosync
+ - get autosync state
+ - disable autosync
+ - get autosync state
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [setAutoSync] function
+ - [getAutoSync] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - getAutoSync return expected state
+ """
+ log.D(self.test_01_getAutoSync_Case.__doc__)
+ value = "on"
+ log.I("Enable autosync")
+ out,err = self.pfw.sendCmd("setAutoSync", value)
+ assert err == None, log.E("When enabling autosync : %s" % (err))
+ assert out == "Done", log.F("setAutoSync - expected : Done , found : %s" % (out))
+ log.I("Check autosync state")
+ out, err = self.pfw.sendCmd("getAutoSync","")
+ assert err == None, log.E("When getting autosync state : %s" % (err))
+ assert out == value, log.F("setAutoSync - expected : %s , found : %s" % (value,out))
+ value = "off"
+ log.I("Disable autosync")
+ out,err = self.pfw.sendCmd("setAutoSync", value)
+ assert err == None, log.E("When enabling autosync : %s" % (err))
+ assert out == "Done", log.F("setAutoSync - expected : Done , found : %s" % (out))
+ log.I("Check autosync state")
+ out, err = self.pfw.sendCmd("getAutoSync","")
+ assert err == None, log.E("When getting autosync state : %s" % (err))
+ assert out == value, log.F("setAutoSync - expected : %s , found : %s" % (value,out))
+
+ def test_02_setAutoSync_Case(self):
+ """
+ Testing getAutoSync nominal case
+ -------------------------------------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - enable autosync
+ - set differents parameters
+ - check the value on the filesystem
+ - disable autosync
+ - set differents parameters
+ - check the value on the filesystem
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [setAutoSync] function
+ Used commands :
+ ~~~~~~~~~~~~~~~
+ - [getAutoSync] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - When autosync is enabled, the filesystem is automatically
+ synchronized with the blackboard.
+ """
+ log.D(self.test_02_setAutoSync_Case.__doc__)
+ #Check the initial parameter value
+ init_value_01, err = self.pfw.sendCmd("getParameter", self.param_name_01, "")
+ init_value_02, err = self.pfw.sendCmd("getParameter", self.param_name_02, "")
+ init_value_03, err = self.pfw.sendCmd("getParameter", self.param_name_03, "")
+ init_filesystem_01 = commands.getoutput("cat %s"%(self.filesystem_01))
+ init_filesystem_02 = commands.getoutput("cat %s"%(self.filesystem_02))
+ init_filesystem_03 = commands.getoutput("cat %s"%(self.filesystem_03))
+ #Implement a new value
+ if int(init_value_01)==0 :
+ new_value_01 = "1"
+ else :
+ new_value_01 = "0"
+ new_value_02 = str(int(init_value_02)+1)
+ new_value_03 = str(int(init_value_03)+1)
+ #Enable the autosync
+ value = "on"
+ log.I("Enable autosync")
+ out,err = self.pfw.sendCmd("setAutoSync", value)
+ assert err == None, log.E("When enabling autosync : %s" % (err))
+ assert out == "Done", log.F("setAutoSync - expected : Done , found : %s" % (out))
+ #Set the new parameter value
+ self.pfw.sendCmd("setParameter", self.param_name_01, new_value_01)
+ self.pfw.sendCmd("setParameter", self.param_name_02, new_value_02)
+ self.pfw.sendCmd("setParameter", self.param_name_03, new_value_03)
+ #Check the filesystem values
+ #BOOL
+ assert commands.getoutput("cat %s"%(self.filesystem_01)) != init_filesystem_01, log.F("FILESYSTEM : parameter %s update error"%self.param_name_01)
+ #INT16
+ assert commands.getoutput("cat %s"%(self.filesystem_02)) != init_filesystem_02, log.F("FILESYSTEM : parameter %s update error"%self.param_name_02)
+ #UINT32
+ assert commands.getoutput("cat %s"%(self.filesystem_03)) != init_filesystem_03, log.F("FILESYSTEM : parameter %s update error"%self.param_name_03)
+ log.I("test setAutoSync %s : OK"%(value))
+ #Enable the autosync
+ value = "off"
+ log.I("Disable autosync")
+ out,err = self.pfw.sendCmd("setAutoSync", value)
+ assert err == None, log.E("When enabling autosync : %s" % (err))
+ assert out == "Done", log.F("setAutoSync - expected : Done , found : %s" % (out))
+ #Set the new parameter value
+ self.pfw.sendCmd("setParameter", self.param_name_01, init_value_01)
+ self.pfw.sendCmd("setParameter", self.param_name_02, init_value_02)
+ self.pfw.sendCmd("setParameter", self.param_name_03, init_value_03)
+ #Check the filesystem values
+ #BOOL
+ assert commands.getoutput("cat %s"%(self.filesystem_01)) != init_filesystem_01, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_01)
+ #INT16
+ assert commands.getoutput("cat %s"%(self.filesystem_02)) != init_filesystem_02, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_02)
+ #UINT32
+ assert commands.getoutput("cat %s"%(self.filesystem_03)) != init_filesystem_03, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_03)
+ log.I("test setAutoSync %s : OK"%(value))
+
+
+ @unittest.expectedFailure
+ def test_03_Manual_Sync_Case(self):
+ """
+ Testing getAutoSync nominal case
+ -------------------------------------------------
+ Test case description :
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ - disable autosync
+ - set differents parameters
+ - check the value on the filesystem
+ - sync
+ - check the value on the filesystem
+ Tested commands :
+ ~~~~~~~~~~~~~~~~~
+ - [sync] function
+ Used commands :
+ ~~~~~~~~~~~~~~~
+ - [setAutoSync] function
+ Expected result :
+ ~~~~~~~~~~~~~~~~~
+ - sync should synchronized filessystem with blackboard
+ """
+ log.D(self.test_03_Manual_Sync_Case.__doc__)
+ #Check the initial parameter value
+ init_value_01, err = self.pfw.sendCmd("getParameter", self.param_name_01, "")
+ init_value_02, err = self.pfw.sendCmd("getParameter", self.param_name_02, "")
+ init_value_03, err = self.pfw.sendCmd("getParameter", self.param_name_03, "")
+ init_filesystem_01 = commands.getoutput("cat %s"%(self.filesystem_01))
+ init_filesystem_02 = commands.getoutput("cat %s"%(self.filesystem_02))
+ init_filesystem_03 = commands.getoutput("cat %s"%(self.filesystem_03))
+ #Implement a new value
+ if int(init_value_01)==0 :
+ new_value_01 = "1"
+ else :
+ new_value_01 = "0"
+ new_value_02 = str(int(init_value_02)+1)
+ new_value_03 = str(int(init_value_03)+1)
+ #Enable the autosync
+ value = "off"
+ log.I("Disable autosync")
+ out,err = self.pfw.sendCmd("setAutoSync", value)
+ assert err == None, log.E("When enabling autosync : %s" % (err))
+ assert out == "Done", log.F("setAutoSync - expected : Done , found : %s" % (out))
+ #Set the new parameter value
+ self.pfw.sendCmd("setParameter", self.param_name_01, new_value_01)
+ self.pfw.sendCmd("setParameter", self.param_name_02, new_value_02)
+ self.pfw.sendCmd("setParameter", self.param_name_03, new_value_03)
+ #Check the filesystem values, must not changed
+ #BOOL
+ assert commands.getoutput("cat %s"%(self.filesystem_01)) == init_filesystem_01, log.F("FILESYSTEM : parameter %s update error"%self.param_name_01)
+ #INT16
+ assert commands.getoutput("cat %s"%(self.filesystem_02)) == init_filesystem_02, log.F("FILESYSTEM : parameter %s update error"%self.param_name_02)
+ #UINT32
+ assert commands.getoutput("cat %s"%(self.filesystem_03)) == init_filesystem_03, log.F("FILESYSTEM : parameter %s update error"%self.param_name_03)
+ log.I("test setAutoSync %s : OK"%(value))
+ log.I("Sync")
+ out,err = self.pfw.sendCmd("sync", "")
+ assert err == None, log.E("When syncing : %s" % (err))
+ assert out == "Done", log.F("Sync - expected : Done , found : %s" % (out))
+ #Check the filesystem values
+ #BOOL
+ assert commands.getoutput("cat %s"%(self.filesystem_01)) != init_filesystem_01, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_01)
+ #INT16
+ assert commands.getoutput("cat %s"%(self.filesystem_02)) != init_filesystem_02, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_02)
+ #UINT32
+ assert commands.getoutput("cat %s"%(self.filesystem_03)) != init_filesystem_03, log.F("FILESYSTEM : parameter %s is updated, autosync is still enabled"%self.param_name_03)
+ log.I("test setAutoSync %s : OK"%(value))