# -*-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.
"""
Adding and Removing elements from domain testcases
List of tested functions :
--------------------------
- [listDomainElements] function
- [addElement] function
- [removeElement] function
Test cases :
------------
- Testing nominal case
- Testing addElement errors
- Testing removeElement errors
"""
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"
def tearDown(self):
self.pfw.sendCmd("setTuningMode", "off")
def test_Nominal_Case(self):
"""
Testing nominal case
--------------------
Test case description :
~~~~~~~~~~~~~~~~~~~~~~~
- list and backup initial domain elements
- add a domain element
- remove a domain element
- list and check domains elements
Tested commands :
~~~~~~~~~~~~~~~~~
- [listDomainElements] function
- [addElement] function
- [removeElement] function
Expected result :
~~~~~~~~~~~~~~~~~
- all operations succeed
"""
log.D(self.test_Nominal_Case.__doc__)
# List and backup initial domain elements
log.I("Listing initial domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements_Backup = open("f_DomainElements_Backup", "w")
f_DomainElements_Backup.write(out)
f_DomainElements_Backup.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
element_nbr_init = 0
line=f_DomainElements_Backup.readline()
while line!="":
line=f_DomainElements_Backup.readline()
element_nbr_init+=1
f_DomainElements_Backup.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr_init))
# Adding a new domain element
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))
# Removing a domain element
log.I("Removing domain element %s from domain %s" % (self.elem_1_path,self.domain_name))
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)
# Checking final domain elements
log.I("Listing final domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements = open("f_DomainElements", "w")
f_DomainElements.write(out)
f_DomainElements.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements = open("f_DomainElements", "r")
element_nbr = 0
line=f_DomainElements.readline()
while line!="":
line=f_DomainElements.readline()
element_nbr+=1
f_DomainElements.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr))
log.I("Checking domain %s elements names conformity" % (self.domain_name))
f_DomainElements = open("f_DomainElements", "r")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
for line in range(element_nbr):
# initial domain elements shall not have been impacted by current test
if (line < element_nbr_init):
element_name = f_DomainElements.readline().strip('\r\n')
element_name_backup = f_DomainElements_Backup.readline().strip('\r\n')
assert element_name==element_name_backup, "ERROR : Error while modifying domain elements on domain %s" % (self.domain_name)
# last listed element shall be equal to the only one element added previously
else:
element_name = f_DomainElements.readline().strip('\r\n')
assert element_name==str(self.elem_2_path), "ERROR : Error while modifying domain elements on domain %s" % (self.domain_name)
log.I("Actual domain %s elements names conform to expected values" % (self.domain_name))
# Temporary files deletion
f_DomainElements.close()
f_DomainElements_Backup.close()
os.remove("f_DomainElements_Backup")
os.remove("f_DomainElements")
# Removing created domain element
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_addElement_Error(self):
"""
Testing addElement error
------------------------
Test case description :
~~~~~~~~~~~~~~~~~~~~~~~
- add an already existing domain element
- add a non defined domain element
Tested commands :
~~~~~~~~~~~~~~~~~
- [addElement] function
- [listDomainElements] function
Expected result :
~~~~~~~~~~~~~~~~~
- Errors correctly detected
- No side effect
"""
log.D(self.test_addElement_Error.__doc__)
# List and backup initial domain elements
log.I("Listing initial domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements_Backup = open("f_DomainElements_Backup", "w")
f_DomainElements_Backup.write(out)
f_DomainElements_Backup.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
element_nbr_init = 0
line=f_DomainElements_Backup.readline()
while line!="":
line=f_DomainElements_Backup.readline()
element_nbr_init+=1
f_DomainElements_Backup.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr_init))
# Adding a new domain element errors
log.I("Adding an already existing domain element to domain %s" % (self.domain_name))
out, err = self.pfw.sendCmd("addElement", str(self.domain_name), str(self.elem_0_path), expectSuccess=False)
assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_0_path)
assert out != "Done", "ERROR : command [addElement] - Error not detected while adding an already existing domain element to domain %s" % (self.domain_name)
log.I("Adding a non defined domain element to domain %s" % (self.domain_name))
out, err = self.pfw.sendCmd("addElement", str(self.domain_name), "Non_Defined_Element", expectSuccess=False)
assert err == None, "ERROR : command [addElement] - Error while adding new domain element %s" % (self.elem_2_path)
assert out != "Done", "ERROR : command [addElement] - Error not detected while adding a non defined domain element to domain %s" % (self.domain_name)
log.I("Error when adding elements correctly detected")
# Checking final domain elements
log.I("Listing final domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements = open("f_DomainElements", "w")
f_DomainElements.write(out)
f_DomainElements.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements = open("f_DomainElements", "r")
element_nbr = 0
line=f_DomainElements.readline()
while line!="":
line=f_DomainElements.readline()
element_nbr+=1
f_DomainElements.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr))
log.I("Checking domain %s elements names conformity" % (self.domain_name))
f_DomainElements = open("f_DomainElements", "r")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
for line in range(element_nbr):
# initial domain elements shall not have been impacted by current test
element_name = f_DomainElements.readline().strip('\r\n')
element_name_backup = f_DomainElements_Backup.readline().strip('\r\n')
assert element_name==element_name_backup, "ERROR : domain %s elements affected by addElement errors" % (self.domain_name)
log.I("Actual domain %s elements names conform to expected values" % (self.domain_name))
# Temporary files deletion
f_DomainElements.close()
f_DomainElements_Backup.close()
os.remove("f_DomainElements_Backup")
os.remove("f_DomainElements")
def test_removeElement_Error(self):
"""
Testing removeElement error
---------------------------
Test case description :
~~~~~~~~~~~~~~~~~~~~~~~
- remove a non defined domain element
- remove a domain element on a wrong domain name
Tested commands :
~~~~~~~~~~~~~~~~~
- [removeElement] function
- [listDomainElements] function
Expected result :
~~~~~~~~~~~~~~~~~
- Errors correctly detected
- No side effect
"""
log.D(self.test_removeElement_Error.__doc__)
# List and backup initial domain elements
log.I("Listing initial domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements_Backup = open("f_DomainElements_Backup", "w")
f_DomainElements_Backup.write(out)
f_DomainElements_Backup.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
element_nbr_init = 0
line=f_DomainElements_Backup.readline()
while line!="":
line=f_DomainElements_Backup.readline()
element_nbr_init+=1
f_DomainElements_Backup.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr_init))
# Error when removing domain elements
log.I("Removing a domain element from a non defined domain")
out, err = self.pfw.sendCmd("removeElement", "Wrong_Domain_Name", str(self.elem_0_path), expectSuccess=False)
assert err == None, "ERROR : command [removeElement] - Error when removing domain element %s" % (self.elem_0_path)
assert out != "Done", "ERROR : command [removeElement] - Error not detected when removing domain element %s from an undefined domain"% (self.elem_0_path)
log.I("Removing a non existent domain element from domain %s" % (self.domain_name))
out, err = self.pfw.sendCmd("removeElement", str(self.domain_name), "Wrong_Element_Name", expectSuccess=False)
assert err == None, "ERROR : command [removeElement] - Error when removing domain element %s" % (self.elem_0_path)
assert out != "Done", "ERROR : command [removeElement] - Error not detected when removing a non existent domain element from domain %s" % (self.domain_name)
log.I("Error when removing elements correctly detected")
# Checking final domain elements
log.I("Listing final domain %s elements" % (self.domain_name))
out, err = self.pfw.sendCmd("listDomainElements",str(self.domain_name))
assert err == None, "ERROR : command [listDomainElements] - Error while listing domain elements"
f_DomainElements = open("f_DomainElements", "w")
f_DomainElements.write(out)
f_DomainElements.close()
log.I("command [listDomainElements] correctly executed")
f_DomainElements = open("f_DomainElements", "r")
element_nbr = 0
line=f_DomainElements.readline()
while line!="":
line=f_DomainElements.readline()
element_nbr+=1
f_DomainElements.close()
log.I("Actual domain %s elements number is %s" % (self.domain_name,element_nbr))
log.I("Checking domain %s elements names conformity" % (self.domain_name))
f_DomainElements = open("f_DomainElements", "r")
f_DomainElements_Backup = open("f_DomainElements_Backup", "r")
for line in range(element_nbr):
# initial domain elements shall not have been impacted by current test
element_name = f_DomainElements.readline().strip('\r\n')
element_name_backup = f_DomainElements_Backup.readline().strip('\r\n')
assert element_name==element_name_backup, "ERROR : domain %s elements affected by addElement errors" % (self.domain_name)
log.I("Actual domain %s elements names conform to expected values" % (self.domain_name))
# Temporary files deletion
f_DomainElements.close()
f_DomainElements_Backup.close()
os.remove("f_DomainElements_Backup")
os.remove("f_DomainElements")