Source code for gssa.comparator.comparator
# This file is part of the Go-Smart Simulation Architecture (GSSA).
# Go-Smart is an EU-FP7 project, funded by the European Commission.
#
# Copyright (C) 2013-  NUMA Engineering Ltd. (see AUTHORS file)
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
from lxml import etree as ET
from .parse import gssa_xml_to_definition
# This class sets up two SimulationDefinitions and instructs one to compare
# against the other
[docs]class Comparator:
    left_text = None
    right_text = None
    def __init__(self, left_text, right_text):
        # ElementTree can still only handle byte-strings
        self.left = ET.fromstring(bytes(left_text, 'utf-8'))
        self.right = ET.fromstring(bytes(right_text, 'utf-8'))
[docs]    def diff(self):
        # We must construct SimulationDefinitions for both sides
        # As we have a clear Left and Right, based on the initializing
        # arguments, we name them accordingly in the output
        left_structure = self.__analyse(self.left, "Left")
        right_structure = self.__analyse(self.right, "Right")
        # The left definition runs a comparison against the right
        return left_structure.diff(right_structure) 
[docs]    def equal(self):
        return self.diff() == [] 
    def __analyse(self, root, label):
        # In theory, we might want to something extra here, based on additional
        # parameters or settings, but for now we just return the parsed XML as a
        # SimulationDefinition
        return gssa_xml_to_definition(root, label)