buildframework/helium/sf/python/pythoncore/lib/pythoncorecpythontests/test_ats4.py
author wbernard
Sun, 10 Oct 2010 15:22:15 +0300
changeset 645 b8d81fa19e7d
parent 628 7c4a911dc066
permissions -rw-r--r--
helium_12.0.0-63b64366f9cf
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     1
# -*- encoding: latin-1 -*-
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     2
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     3
#============================================================================ 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     4
#Name        : test_ats4.py 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     5
#Part of     : Helium 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     6
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     7
#Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     8
#All rights reserved.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     9
#This component and the accompanying materials are made available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    10
#under the terms of the License "Eclipse Public License v1.0"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    11
#which accompanies this distribution, and is available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    12
#at the URL "http://www.eclipse.org/legal/epl-v10.html".
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    13
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    14
#Initial Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    15
#Nokia Corporation - initial contribution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    16
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    17
#Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    19
#Description:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    20
#===============================================================================
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    21
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    22
""" Testing ats4 framework. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    23
#E1101 => Mocker shows mockery
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    24
#C0302 => too many lines
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
#W0142 => used * or ** magic 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
#W0603 => used global
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    27
#R* during refactoring
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    29
from cStringIO import StringIO
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    30
from xml.etree.ElementTree import fromstring
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
from xml.etree import ElementTree as et
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
import difflib
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
import logging
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
logging.getLogger().setLevel(logging.ERROR)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
import tempfile
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
import zipfile
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
import os
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
import re
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
import subprocess
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
import fileutils
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    42
from path import path # pylint: disable=F0401
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
import amara
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    44
import mocker # pylint: disable=F0401
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
import ntpath
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
import ats3
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
import ats3.testconfigurator as atc
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
import ats3.dropgenerator as adg
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
import ats3.parsers as parser
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
TEST_PATH = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
TEST_FILES = {}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
TSRC = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
OUTPUT = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
# Shortcuts
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
E = et.Element
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
SE = et.SubElement
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
class Bunch(object):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
    """ Configuration object. Argument from constructor are converted into class attributes. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
    def __init__(self, **kwargs):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
        self.__dict__.update(kwargs)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
def equal_xml(xml1, xml2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
    """Check the equality of the given XML snippets.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
    Tag name equality:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
    >>> equal_xml('<a/>', '<a/>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
    >>> equal_xml('<a/>', '<b/>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    77
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
    Attribute equality:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
    >>> equal_xml('<a k="v"/>', '<a k="v"/>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
    >>> equal_xml('<a k="v"/>', '<a k="w"/>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
    Text content equality:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
    >>> equal_xml('<a>v</a>', '<a>v</a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    89
    >>> equal_xml('<a>v</a>', '<a>w</a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    90
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    91
    >>> equal_xml('<a>v</a>', '<a></a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    92
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
    Text content equality when whitespace differs:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
    >>> equal_xml('<a>v</a>', '<a>v </a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
    Equality of child elements:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
    >>> equal_xml('<a><b><c k="v"/></b></a>', '<a><b><c k="v"/></b></a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
    >>> equal_xml('<a><b><c k="v"/></b></a>', '<a><b><c k="w"/></b></a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
    >>> equal_xml('<a><b><c k="v"/>v</b></a>', '<a><b><c k="v"/>w</b></a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
    False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
    >>> equal_xml('<a><b><c k="v"/>v</b></a>', '<a><b><c k="v"/>v </b></a>')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
    True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
    """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
    def __init__():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
        check_instance(xml1, xml2)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
    def check_instance(xml1, xml2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
        """if xml1 and xml2 are instances, converts to strings"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
        if isinstance(xml1, basestring):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   116
            xml1 = fromstring(xml1)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   117
        if isinstance(xml2, basestring):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   118
            xml2 = fromstring(xml2)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   119
        check_tags(xml1, xml2)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   120
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   121
    def check_tags(xml1, xml2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   122
        """check xml tags and text equality"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   123
        if xml1.tag != xml2.tag:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   124
            return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   125
        if xml1.attrib != xml2.attrib:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   126
            return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   127
        if xml1.text:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   128
            if not xml2.text:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   129
                return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   130
        if xml2.text:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   131
            if not xml1.text:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   132
                return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   133
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   134
        produce_xml_children(xml1, xml2)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   135
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   136
    def produce_xml_children(xml1, xml2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   137
        """checks if xml children are of same length and are equal?"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   138
        if xml1.text and xml2.text and xml1.text.strip() != xml2.text.strip():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   139
            return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   140
        if xml1.tail is not None and xml2.tail is not None:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   141
            if xml1.tail.strip() != xml2.tail.strip():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   142
                return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   143
        elif xml1.tail != xml2.tail:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   144
            return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   145
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   146
        children1 = list(xml1.getchildren())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   147
        children2 = list(xml2.getchildren())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   148
        if len(children1) != len(children2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   149
            return False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   150
        for child1, child2 in zip(children1, children2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   151
            return equal_xml(child1, child2)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   152
    return True        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   153
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   154
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   155
def setup_module():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   156
    """ Setup test environment. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   157
    global TEST_PATH, TSRC, OUTPUT
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   158
    TEST_PATH = path(tempfile.mkdtemp())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   159
    OUTPUT = TEST_PATH.joinpath(r"output")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   160
    component = TEST_PATH
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   161
    component.joinpath("group").makedirs()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   162
    for path_parts in (("tsrc", "group", "bld.inf"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   163
                       ("tsrc", "group", "test.pkg"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   164
                       ("tsrc", "testmodules", "file1.dll"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   165
                       ("tsrc", "testmodules", "file2.dll"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   166
                       ("tsrc", "data", "file1"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   167
                       ("tsrc", "data", "file2"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   168
                       ("tsrc", "data", "file3"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   169
                       ("tsrc", "data", "mmc", "file4"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   170
                       ("tsrc", "data", "c", "file5"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   171
                       ("tsrc", "conf", "file1.cfg"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   172
                       ("tsrc", "conf", "file2.cfg"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   173
                       ("tsrc", "init", "TestFramework.ini"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   174
                       ("tsrc", "custom", "prepostaction.xml"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   175
                       ("tsrc", "custom", "postpostaction.xml"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   176
                       # These do not have to be under 'tsrc':
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   177
                       ("tsrc", "output", "images", "file1.fpsx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   178
                       ("tsrc", "output", "images", "file2.fpsx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   179
                       ("tsrc", "sis", "file1.sisx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   180
                       ("tsrc", "sis", "file2.sisx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   181
                       ("tsrc", "sis", "file3.sisx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   182
                       ("tsrc", "trace_init", "trace_activation_1.xml")):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   183
        filepath = component.joinpath(*path_parts)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   184
        if not filepath.parent.exists():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   185
            filepath.parent.makedirs()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   186
        filepath.touch()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   187
        TEST_FILES.setdefault(path_parts[1], []).append(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   188
    TSRC = component.joinpath("tsrc")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   189
    filepath = OUTPUT.joinpath("pmd", "pmd_file.pmd")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   190
    if not filepath.parent.exists():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   191
        filepath.parent.makedirs()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   192
    filepath.touch()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   193
    TEST_FILES.setdefault("pmd_file", []).append(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   194
    tracing = component.joinpath("tsrc", "trace_init")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   195
    root = E('ConfigurationFile')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   196
    confs = E("Configurations")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   197
    trace_act = SE(confs, "TraceActivation")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   198
    conf = SE(trace_act, "Configuration")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   199
    conf.set('Name', 'MCU')
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   200
    mcu = SE(conf, "MCU")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   201
    sett = SE(mcu, "settings")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   202
    SE(sett, "timestamp")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   203
    root.append(confs)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   204
    ettree = et.ElementTree(root)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   205
    doc = amara.parse(et.tostring(ettree.getroot()))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   206
    handle = open(tracing.joinpath("trace_activation_1.xml"), "w")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   207
    handle.write(doc.xml(indent="yes"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   208
    handle.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   209
#    tracing.writestr("trace_activation_1.xml", doc.xml(indent=u"yes"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   210
    group = component.joinpath("tsrc", "group")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   211
    group.joinpath("bld.inf").write_text(
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   212
        r"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   213
        PRJ_TESTMMPFILES
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   214
        stif.mmp /* xyz.mmp */ abcd.mmp
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   215
        /*xyz.mmp*/
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   216
        eunit.mmp /* xyz.mmp */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   217
        both.mmp
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   218
        ..\sub-component\group\sub-component.mmp
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   219
        """.replace('\\', os.sep))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   220
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   221
    group.joinpath("test.pkg").write_text(
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   222
        r"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   223
        ;Language - standard language definitions
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   224
        &EN
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   225
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   226
        ; standard SIS file header
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   227
        #{"BTEngTestApp"},(0x04DA27D5),1,0,0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   228
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   229
        ;Supports Series 60 v 3.0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   230
        (0x101F7961), 0, 0, 0, {"Series60ProductID"}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   231
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   232
        ;Localized Vendor Name
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   233
        %{"BTEngTestApp"}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   234
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   235
        ;Unique Vendor name
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   236
        :"Nokia"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   237
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   238
        ; Files to copy
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   239
        "\tsrc\testmodules\file1.dll"-"c:\sys\bin\file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   240
        "\tsrc\testmodules\file2.dll"-"c:\sys\bin\file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   241
        "\tsrc\data\file1"-"e:\sys\bin\file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   242
        "\tsrc\data\file2"-"e:\sys\bin\file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   243
        "\tsrc\data\file3"-"e:\sys\bin\file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   244
        "\tsrc\conf\file1.cfg"-"!:\sys\bin\file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   245
        "\tsrc\conf\file2.cfg"-"!:\sys\bin\file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   246
        "\tsrc\init\TestFramework.ini"-"!:\sys\bin\TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   247
        "\tsrc\sis\file1.sisx"-"!:\sys\bin\file1.sisx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   248
        "\tsrc\sis\file2.sisx"-"!:\sys\bin\file2.sisx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   249
        """.replace('\\', os.sep))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   250
    group.joinpath("stif.mmp").write_text("LIBRARY stiftestinterface.lib")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   251
    group.joinpath("eunit.mmp").write_text("LIBRARY eunit.lib")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   252
    group.joinpath("both.mmp").write_text("LIBRARY stiftestinterface.lib eunit.lib")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   253
    init = component.joinpath("tsrc", "init")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   254
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   255
    init.joinpath("TestFramework.ini").write_text(
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   256
        r"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   257
#     - Sets a device reset module's dll name(Reboot).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   258
#        + If Nokia specific reset module is not available or it is not correct one
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   259
#          StifHWResetStub module may use as a template for user specific reset
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   260
#          module. 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   261
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   262
[Engine_Defaults]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   263
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   264
TestReportMode= FullReport        # Possible values are: 'Empty', 'Summary', 'Environment',
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   265
                                                               'TestCases' or 'FullReport'
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   266
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   267
CreateTestReport= YES            # Possible values: YES or NO
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   268
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   269
TestReportFilePath= C:\LOGS\TestFramework\
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   270
TestReportFileName= TestReport
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   271
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   272
TestReportFormat= TXT            # Possible values: TXT or HTML
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   273
[End_Defaults]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   274
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   275
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   276
[New_Module]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   277
ModuleName= testscripter 
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   278
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   279
        """)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   280
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   281
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   282
def teardown_module():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   283
    """ Cleanup environment after testing. """    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   284
    def __init__():
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   285
        path(TEST_PATH).rmtree()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   286
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   287
# CTC related functions    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   288
def check_ctc_write(steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   289
    """Checks if CTC data is written on the CTC log"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   290
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   291
    assert step.findtext("./type") == "NonTestExecuteTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   292
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   293
    assert params[0].get("value") == "writelocal"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   294
    assert params[1].get("value") == path(r"z:\sys\bin\ctcman.exe")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   295
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   296
    assert step.findtext("./type") == "NonTestExecuteTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   297
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   298
    assert params[0].get("value") == "writefile"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   299
    assert params[1].get("value") == path(r"z:\sys\bin\ctcman.exe")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   300
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   301
def check_ctc_log(steps):
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   302
    """Fetches CTC Log"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   303
    #For the ctcdata.txt to be published on the ATS network drive
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   304
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   305
    assert step.findtext("./type") == "FileDownloadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   306
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   307
    #assert params[0].get("value") == "false"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   308
    assert params[0].get("value") == path(r"c:\data\ctc\ctcdata.txt")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   309
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   310
def check_ctc_start(steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   311
    """Checks if CTC starts in ATS"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   312
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   313
    assert step.findtext("./type") == "CreateDirTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   314
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   315
    assert params[0].get("value") == path(r"c:\data\ctc")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   316
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   317
    assert step.findtext("./type") == "NonTestExecuteTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   318
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   319
    assert params[0].get("value") == path(r"z:\sys\bin\ctcman.exe")   
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   320
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   321
def check_fetch_logs(steps, harness="STIF"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   322
    """Checks fetching log directory is created"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   323
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   324
    assert step.findtext("./type") == "FileDownloadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   325
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   326
    if harness == "STIF":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   327
        assert params[0].get("value") == path(r"c:\logs\testframework\*")  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   328
    else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   329
        assert params[0].get("value") == path(r"c:\Shared\EUnit\logs\*")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   330
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   331
def check_diamonds_action(action):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   332
    """ Testing Diamonds action. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   333
    assert action.findtext("./type") == "DiamondsAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   334
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   335
def check_send_email_action(action, reportemail):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   336
    """verifies if sening email option works"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   337
    assert action.findtext("./type") == "EmailAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   338
    params = action.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   339
    assert params[0].get("name") == "subject"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   340
    #assert params[0].get("value") == "email subject"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   341
    assert params[1].get("name") == "to"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   342
    assert params[1].get("value") == reportemail
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   343
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   344
def check_ctc_run_process_action(action):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   345
    """verifies if CTC run process action works"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   346
    #The parameters for this test are intended to execute on a windows machine
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   347
    assert action.findtext("./type") == "RunProcessAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   348
    params = action.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   349
    assert params[0].get("name") == "file"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   350
    assert params[0].get("value") == "catsctc2html/catsctc2html.exe"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   351
    assert params[1].get("name") == "parameters"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   352
    assert params[1].get("value") == r"--ctcdata_files=\\10.0.0.1\ctc_helium\1234\drop0\set0\ctcdata --monsym_files=\\10.0.0.1\ctc_helium\1234\mon_syms\1\MON.sym --diamonds_build_id=1234 --drop_id=0 --total_amount_of_drops=1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   353
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   354
def check_ats_report_action(action, filestore):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   355
    """verifies if sening ATS report option works"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   356
    assert action.findtext("./type") == "FileStoreAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   357
    params = action.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   358
    assert params[0].get("name") == "to-folder"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   359
    assert params[0].get("value") == filestore
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   360
    assert params[1].get("name") == "report-type"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   361
    assert params[1].get("value") == "ATS_REPORT"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   362
    assert params[2].get("name") == "date-format"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   363
    assert params[2].get("value") == "yyyyMMdd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   364
    assert params[3].get("name") == "time-format"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   365
    assert params[3].get("value") == "HHmmss"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   366
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   367
def check_stif_report_action(action, filestore):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   368
    """verifies if sening STIF report option works"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   369
    assert action.findtext("./type") == "FileStoreAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   370
    params = action.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   371
    assert params[0].get("name") == "to-folder"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   372
    assert params[0].get("value") == filestore
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   373
    assert params[1].get("name") == "report-type"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   374
    assert params[1].get("value") == "STIF_COMPONENT_REPORT_ALL_CASES"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   375
    assert params[2].get("name") == "run-log"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   376
    assert params[2].get("value") == "true"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   377
    assert params[3].get("name") == "date-format"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   378
    assert params[3].get("value") == "yyyyMMdd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   379
    assert params[4].get("name") == "time-format"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   380
    assert params[4].get("value") == "HHmmss"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   381
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   382
def check_log_dir(steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   383
    """ Test the log dir. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   384
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   385
    assert step.findtext("./type") == "CreateDirTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   386
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   387
def check_trace_start(steps, filestore):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   388
    """Checks if tracing is started on the ATS"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   389
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   390
    assert step.findtext("./type") == "trace-start"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   391
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   392
    assert params[0].get("value") == path(r"ATS3Drop\set0\trace_activation\trace_activation_1.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   393
    assert params[1].get("value") == "MCU"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   394
    assert params[2].get("value") == path(r"ATS3Drop\pmds\pmd_file.pmd")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   395
    assert params[3].get("value") == filestore.joinpath("traces", "set0", "tracelog.blx")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   396
    assert params[4].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   397
    assert params[5].get("value") == "yyyyMMdd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   398
    assert params[6].get("value") == "HHmmss"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   399
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   400
def check_trace_end_steps(steps, filestore):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   401
    """ Test trace end step. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   402
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   403
    assert step.findtext("./type") == "trace-stop"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   404
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   405
    assert params[0].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   406
    step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   407
    assert step.findtext("./type") == "trace-convert"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   408
    params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   409
    assert params[0].get("value") == path(r"ATS3Drop\pmds\pmd_file.pmd")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   410
    assert params[1].get("value") == filestore.joinpath("traces", "set0", "tracelog.blx")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   411
    assert params[2].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   412
    assert params[3].get("value") == "yyyyMMdd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   413
    assert params[4].get("value") == "HHmmss"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   414
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   415
class TestTestPlan(mocker.MockerTestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   416
    """Creates TestPlan mocker setup"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   417
    def __init__(self, methodName="runTest"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   418
        mocker.MockerTestCase.__init__(self, methodName)  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   419
          
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   420
    def setUp(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   421
        """ Setup TestTestPlan testsuite. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   422
        opts = Bunch(testrun_name="testrun", harness="STIF", 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   423
                     device_type="product", plan_name="ats3_test_plan",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   424
                     diamonds_build_url="", report_email="", file_store=path(), test_timeout="60",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   425
                     device_hwid="5425", trace_enabled="True", ctc_enabled="True", eunitexerunner_flags="/E S60AppEnv /R Off", 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   426
                     multiset_enabled=False, ctc_run_process_params=r"10.0.0.1#x:\ats\drop0.zip#1", monsym_files="", hti="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   427
        self.atp = ats3.Ats3TestPlan(opts)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   428
        self.config_files = TEST_FILES["conf"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   429
        self.data_files = TEST_FILES["data"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   430
        self.engine_ini_file = TEST_FILES["init"][0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   431
        self.image_files = TEST_FILES["output"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   432
        self.sis_files = TEST_FILES["sis"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   433
        self.testmodule_files = TEST_FILES["testmodules"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   434
        self.ctc_enabled = self.atp["ctc_enabled"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   435
        self.custom_dir = "CustomD"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   436
        self.eunitexerunner_flags = self.atp["eunitexerunner_flags"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   437
        if self.atp["trace_enabled"].lower() == "true":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   438
            self.trace_activation_files = TEST_FILES["trace_init"]    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   439
            self.pmd_files = TEST_FILES["pmd_file"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   440
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   441
            self.trace_activation_files = []    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   442
            self.pmd_files = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   443
        self.test_timeout = self.atp["test_timeout"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   444
        self.eunitexerunner_flags = self.atp["eunitexerunner_flags"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   445
        self.device_hwid = self.atp["device_hwid"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   446
        self.test_harness = self.atp["harness"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   447
        self.src_dst = [("" + os.sep + "tsrc" + os.sep + "testmodules" + os.sep + "file1.dll", "c:\sys\bin\file1.dll", "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   448
            ("" + os.sep + "tsrc" + os.sep + "testmodules" + os.sep + "file2.dll", "c:\sys\bin\file2.dll", "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   449
            ("" + os.sep + "tsrc" + os.sep + "data" + os.sep + "file1", "e:\sys\bin\file1", "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   450
            ("" + os.sep + "tsrc" + os.sep + "data" + os.sep + "file2", "e:\sys\bin\file2", "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   451
            ("" + os.sep + "tsrc" + os.sep + "data" + os.sep + "file3", "e:\sys\bin\file3", "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   452
            ("" + os.sep + "tsrc" + os.sep + "conf" + os.sep + "file1.cfg", "c:\sys\bin\file1.cfg", "conf"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   453
            ("" + os.sep + "tsrc" + os.sep + "conf" + os.sep + "file2.cfg", "c:\sys\bin\file2.cfg", "conf"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   454
            ("" + os.sep + "tsrc" + os.sep + "init" + os.sep + "TestFramework.ini", "c:\sys\bin\TestFramework.ini", "engine_ini"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   455
            ("" + os.sep + "tsrc" + os.sep + "sis" + os.sep + "file1.sisx", "c:\sys\bin\file1.sisx", ""),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   456
            ("" + os.sep + "tsrc" + os.sep + "sis" + os.sep + "file2.sisx", "c:\sys\bin\file2.sisx", ""),]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   457
        self.component_path = str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   458
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   459
    def test_creation(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   460
        """ Testing creation. """        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   461
        assert self.atp["testrun_name"] == "testrun"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   462
        assert self.atp["harness"] == "STIF"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   463
        assert self.atp["device_type"] == "product"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   464
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   465
    def test_insert_set(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   466
        """ Inserting a set of file. """        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   467
        self.atp.insert_set(data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   468
                           config_files=self.config_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   469
                           engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   470
                           image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   471
                           testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   472
                           test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   473
                           eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   474
                           pmd_files=self.pmd_files,                            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   475
                           trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   476
                           component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   477
        self.atp.insert_set(image_files=self.image_files,                           
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   478
                           engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   479
                           sis_files=self.sis_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   480
                           test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   481
                           eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   482
                           pmd_files=self.pmd_files,                            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   483
                           trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   484
                           component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   485
        self.atp.insert_set(data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   486
                           config_files=self.config_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   487
                           engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   488
                           image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   489
                           testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   490
                           test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   491
                           eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   492
                           src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   493
                           pmd_files=self.pmd_files,                            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   494
                           trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   495
                           component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   496
        self.atp.insert_set(engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   497
                           test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   498
                           eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   499
                           image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   500
                           test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   501
                           src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   502
                           pmd_files=self.pmd_files,                            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   503
                           trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   504
                           component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   505
        self.atp.insert_set(test_timeout=self.test_timeout,      
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   506
                           eunitexerunner_flags=self.eunitexerunner_flags,               
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   507
                           image_files=self.image_files,                        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   508
                           test_harness=self.test_harness,                      
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   509
                           src_dst=self.src_dst,                                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   510
                           pmd_files=self.pmd_files,                            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   511
                           trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   512
                           component_path=self.component_path)  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   513
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   514
        assert self.atp.sets[0] == dict(name="set0",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   515
                                       data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   516
                                       config_files=self.config_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   517
                                       engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   518
                                       image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   519
                                       testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   520
                                       test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   521
                                       eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   522
                                       test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   523
                                       src_dst=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   524
                                       pmd_files=self.pmd_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   525
                                       trace_path=self.atp.file_store.joinpath(u"§RUN_NAME§" + os.sep + u"§RUN_START_DATE§_§RUN_START_TIME§", "traces", "set0", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   526
                                       trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   527
                                       ctc_enabled=self.atp["ctc_enabled"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   528
                                       custom_dir=None,
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   529
                                       dll_files={},
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   530
                                       component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   531
        assert self.atp.sets[1] == dict(name="set1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   532
                                       image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   533
                                       engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   534
                                       sis_files=self.sis_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   535
                                       test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   536
                                       eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   537
                                       test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   538
                                       pmd_files=self.pmd_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   539
                                       trace_path=self.atp.file_store.joinpath(u"§RUN_NAME§" + os.sep + u"§RUN_START_DATE§_§RUN_START_TIME§", "traces", "set1", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   540
                                       trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   541
                                       ctc_enabled=self.atp["ctc_enabled"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   542
                                       custom_dir=None,
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   543
                                       dll_files={},
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   544
                                       component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   545
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   546
        assert self.atp.sets[2] == dict(name="set2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   547
                                       data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   548
                                       config_files=self.config_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   549
                                       engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   550
                                       image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   551
                                       testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   552
                                       test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   553
                                       eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   554
                                       test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   555
                                       src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   556
                                       pmd_files=self.pmd_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   557
                                       trace_path=self.atp.file_store.joinpath(u"§RUN_NAME§" + os.sep + u"§RUN_START_DATE§_§RUN_START_TIME§", "traces", "set2", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   558
                                       trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   559
                                       ctc_enabled=self.atp["ctc_enabled"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   560
                                       custom_dir=None,
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   561
                                       dll_files={},
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   562
                                       component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   563
        assert self.atp.sets[3] == dict(name="set3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   564
                                       data_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   565
                                       config_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   566
                                       engine_ini_file=self.engine_ini_file,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   567
                                       image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   568
                                       testmodule_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   569
                                       test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   570
                                       eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   571
                                       test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   572
                                       src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   573
                                       pmd_files=self.pmd_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   574
                                       trace_path=self.atp.file_store.joinpath(u"§RUN_NAME§" + os.sep + u"§RUN_START_DATE§_§RUN_START_TIME§", "traces", "set3", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   575
                                       trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   576
                                       ctc_enabled=self.atp["ctc_enabled"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   577
                                       custom_dir=None,
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   578
                                       dll_files={},
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   579
                                       component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   580
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   581
        assert self.atp.sets[4] == dict(name="set4",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   582
                                       data_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   583
                                       config_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   584
                                       engine_ini_file=None,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   585
                                       image_files=self.image_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   586
                                       testmodule_files=[],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   587
                                       test_timeout=self.test_timeout,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   588
                                       eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   589
                                       test_harness=self.test_harness,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   590
                                       src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   591
                                       pmd_files=self.pmd_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   592
                                       trace_path=self.atp.file_store.joinpath(u"§RUN_NAME§" + os.sep + u"§RUN_START_DATE§_§RUN_START_TIME§", "traces", "set4", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   593
                                       trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   594
                                       ctc_enabled=self.atp["ctc_enabled"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   595
                                       custom_dir=None,
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   596
                                       dll_files={},
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   597
                                       component_path=self.component_path)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   598
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   599
    def test_post_actions_email(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   600
        """ Testing the send email post-action. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   601
        assert not self.atp.post_actions
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   602
        receiver = "joe.average@example.com"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   603
        self.atp.report_email = receiver
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   604
        assert len(self.atp.post_actions) == 1
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   605
        _, items = self.atp.post_actions[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   606
        items = dict(items)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   607
        #assert action == "EmailAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   608
        assert items["to"] == receiver
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   609
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   610
    def test_post_actions_ats4_report_only(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   611
        """ Testing the ats4 report only post-action. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   612
        file_store = path("path/to/files")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   613
        self.atp.file_store = file_store
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   614
        self.atp.harness = "EUNIT"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   615
        assert len(self.atp.post_actions) == 2
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   616
        action, items = self.atp.post_actions[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   617
        items = dict(items)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   618
        assert action == "FileStoreAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   619
        assert items["report-type"] == "ATS3_REPORT"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   620
        assert items["to-folder"].startswith(file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   621
        assert items["to-folder"].endswith("ATS3_REPORT")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   622
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   623
    def test_post_actions_stif(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   624
        """ Testing STIF post-actions. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   625
        file_store = path("path/to/files")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   626
        self.atp.file_store = file_store
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   627
        assert len(self.atp.post_actions) == 2
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   628
        action, items = self.atp.post_actions[1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   629
        items = dict(items)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   630
        assert action == "FileStoreAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   631
        assert items["report-type"] == "STIF_COMPONENT_REPORT_ALL_CASES"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   632
        assert items["to-folder"].startswith(file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   633
        assert items["to-folder"].endswith("STIF_REPORT")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   634
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   635
    def test_post_actions_diamonds(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   636
        """ Testing Diamonds post-actions. """        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   637
        self.atp.diamonds_build_url = "http://diamonds.nmp.company.com/diamonds/builds/1234"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   638
        assert len(self.atp.post_actions) == 1
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   639
        action, items = self.atp.post_actions[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   640
        assert action == "DiamondsAction"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   641
        assert not items
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   642
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   643
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   644
class TestComponentParser(mocker.MockerTestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   645
    """ Testing the Ats3ComponentParser component parser. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   646
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   647
    def __init__(self, methodName="runTest"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   648
        mocker.MockerTestCase.__init__(self, methodName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   649
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   650
    def assert_paths(self, path1, path2):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   651
        """ Checking the path. Validates that path1 and path2 are instance of path and they are equals. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   652
        if not isinstance(path1, path):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   653
            path1 = path(path1)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   654
        if not isinstance(path2, path):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   655
            path2 = path(path2)            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   656
        return self.assertEqual(path1.normpath(), path2.normpath())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   657
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   658
    def setUp(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   659
        """ Setting up TestComponentParser testsuite."""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   660
        opts = Bunch(build_drive=path(TEST_PATH+os.sep), target_platform="target platform", eunitexerunner_flags="/E S60AppEnv /R Off",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   661
                     data_dir=["data"], flash_images=[], sis_files=[], test_timeout="60", harness="STIF", trace_enabled="True", specific_pkg='', hti="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   662
        self.acp = atc.Ats3ComponentParser(opts)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   663
        self.acp.tsrc_dir = TSRC
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   664
      
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   665
    def test_detect_dlls(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   666
        """ Testing dlls detection. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   667
        open(os.path.join(TEST_PATH, 'lib1.dll'), 'w').close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   668
        os.makedirs(os.path.join(TEST_PATH, 'path', 'to', 'another'))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   669
        open(os.path.join(TEST_PATH, 'path', 'to', 'another', 'library.dll'), 'w').close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   670
        open(os.path.join(TEST_PATH, 'lib2.dll'), 'w').close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   671
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   672
        # Setup mock objects.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   673
        process = self.mocker.mock()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   674
        process.communicate()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   675
        self.mocker.result(["lib1.dll\npath/to/another/library.dll\nsome/other/file.txt\nlib2.dll\nlib3.dll\n"])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   676
        obj = self.mocker.replace("subprocess.Popen")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   677
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   678
        if os.sep == '\\': 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   679
            raptor_cmd = fileutils.which("sbs.bat")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   680
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   681
            raptor_cmd = fileutils.which("sbs")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   682
        if raptor_cmd:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   683
            obj("sbs --what -c target_platform.test", shell=True, stdout=subprocess.PIPE)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   684
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   685
            obj("abld -w test build target platform", shell=True, stdout=subprocess.PIPE)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   686
        self.mocker.result(process)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   687
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   688
        self.mocker.replay()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   689
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   690
        self.assertEqual([u"lib1.dll", u"library.dll", u"lib2.dll"],
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   691
                         [dll.name for dll in self.acp.tsrc_dll_files()])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   692
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   693
    def test_harness(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   694
        """ Detect test harness."""
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
   695
        mmp_parser = parser.MmpFileParser(None)
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   696
        group = TSRC.joinpath("group")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   697
        for harness, mmp in [
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   698
            ("STIF", group / "stif.mmp"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   699
            ("EUNIT", group / "eunit.mmp"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   700
            ("STIF", group / "both.mmp"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   701
            ]:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   702
            self.assertEqual(harness, mmp_parser.get_harness(mmp))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   703
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   704
class TestXMLGeneration(mocker.MockerTestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   705
    """Unit tests for the test.xml generation."""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   706
    def __init__(self, methodName="runTest"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   707
        mocker.MockerTestCase.__init__(self, methodName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   708
        self.data_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   709
        self.config_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   710
        self.testmodule_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   711
        self.image_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   712
        self.engine_ini_file = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   713
        self.report_email = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   714
        self.file_store = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   715
        self.diamonds_build_url = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   716
        self.test_harness = None     
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   717
        self.src_dst = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   718
        self.trace_enabled = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   719
        self.pmd_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   720
        self.trace_activation_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   721
        self.ctc_enabled = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   722
        self.eunitexerunner_flags = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   723
        self.test_plan = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   724
        self.gen = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   725
        self.custom_dir = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   726
        self.diamonds_id = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   727
        self.ctc_run_process_params = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   728
        self.drop_count = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   729
        self.ctc_test_data = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   730
        self.ctc_network = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   731
        self.component_path = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   732
        self.drop_id = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   733
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   734
    def generate_xml(self, trace_enabled="False"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   735
        """ Generating the XML. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   736
        def files(*paths):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   737
            """creating tsrc path list"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   738
            return [TEST_PATH.joinpath("tsrc", tpath) for tpath in paths]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   739
        self.testmodule_files = files("testmodules/file1.dll", "testmodules/file2.dll")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   740
        self.data_files = files("data/file1", "data/file2", "data/file3")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   741
        self.config_files = files("conf/file1.cfg", "conf/file2.cfg")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   742
        self.image_files = files("output/images/file1.fpsx", "output/images/file2.fpsx")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   743
        self.engine_ini_file = files("init/TestFramework.ini")[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   744
        self.report_email = "test.receiver@company.com"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   745
        self.file_store = path(r"path/to/reports")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   746
        self.diamonds_build_url = "http://diamonds.nmp.company.com/diamonds/builds/1234"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   747
        self.test_harness = "STIF"        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   748
        self.src_dst = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   749
        self.trace_enabled = trace_enabled
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   750
        self.pmd_files = TEST_FILES["pmd_file"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   751
        self.trace_activation_files = files("trace_init/trace_activation_1.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   752
        self.ctc_enabled = "True"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   753
        self.eunitexerunner_flags = "/E S60AppEnv /R Off"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   754
        self.custom_dir = "CustomB"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   755
        self.component_path = str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   756
        self.ctc_run_process_params = r"10.0.0.1#x:\ats\drop0.zip#1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   757
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   758
        self.ctc_network = self.ctc_run_process_params.rsplit("#", 2)[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   759
        self.drop_id = re.findall(".*drop(\d*).zip.*", self.ctc_run_process_params.lower())[0] #extracting int part of drop name
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   760
        self.drop_count = self.ctc_run_process_params.rsplit("#", 1)[1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   761
        self.diamonds_id = self.diamonds_build_url.rsplit(r"/", 1)[1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   762
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   763
        self.mocker.restore()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   764
        test_plan = self.mocker.mock(count=False)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   765
        mocker.expect(test_plan["testrun_name"]).result("test")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   766
        mocker.expect(test_plan["harness"]).result("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   767
        mocker.expect(test_plan["device_type"]).result("product")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   768
        mocker.expect(test_plan["hti"]).result("True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   769
        mocker.expect(test_plan["plan_name"]).result("test plan")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   770
        mocker.expect(test_plan["diamonds_build_url"]).result(self.diamonds_build_url)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   771
        mocker.expect(test_plan["test_timeout"]).result("60")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   772
        mocker.expect(test_plan["eunitexerunner_flags"]).result("/E S60AppEnv /R Off")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   773
        mocker.expect(test_plan["device_hwid"]).result("5425")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   774
        mocker.expect(test_plan["custom_dir"]).result("custom")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   775
        mocker.expect(test_plan.custom_dir).result(path(r"self.custom_dir"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   776
        mocker.expect(test_plan["report_email"]).result(self.report_email)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   777
        mocker.expect(test_plan["ctc_run_process_params"]).result(self.ctc_run_process_params)
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   778
        mocker.expect(test_plan["report_type"]).result("")
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   779
        mocker.expect(test_plan["file_store"]).result("")
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   780
                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   781
        if self.trace_enabled.lower() == "true":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   782
            mocker.expect(test_plan["trace_enabled"]).result("True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   783
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   784
            mocker.expect(test_plan["trace_enabled"]).result("False")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   785
        if self.trace_enabled == "False":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   786
            mocker.expect(test_plan.sets).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   787
                dict(name="set0", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   788
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   789
                     engine_ini_file=self.engine_ini_file, test_harness="STIF", src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   790
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   791
                     custom_dir=self.custom_dir, component_path=self.component_path, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   792
                dict(name="set1", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   793
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   794
                     engine_ini_file=self.engine_ini_file,test_harness="STIF", src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   795
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   796
                     custom_dir=self.custom_dir, component_path=self.component_path, hti="True"),])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   797
        elif self.trace_enabled == "True":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   798
            mocker.expect(test_plan.sets).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   799
                dict(name="set0", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   800
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   801
                     engine_ini_file=self.engine_ini_file, test_harness="STIF", src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   802
                     pmd_files=self.pmd_files, trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   803
                     trace_path=self.file_store.joinpath("traces", "set0", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   804
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags, component_path=self.component_path, custom_dir=None, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   805
                dict(name="set1", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   806
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   807
                     engine_ini_file=self.engine_ini_file,test_harness="STIF", src_dst=self.src_dst,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   808
                     pmd_files=self.pmd_files, trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   809
                     trace_path=self.file_store.joinpath("traces", "set1", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   810
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags, component_path=self.component_path, custom_dir=None, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   811
            ])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   812
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   813
        ctc_file_name = "catsctc2html/catsctc2html.exe"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   814
        ctc_data_path = str(os.path.normpath(r"\\%s\ctc_helium\%s\drop0\set0\ctcdata" % (self.ctc_network, self.diamonds_id)))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   815
        mon_files = str(os.path.normpath(r"\\%s\ctc_helium\%s\mon_syms\1\MON.sym" % (self.ctc_network, self.diamonds_id)))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   816
        self.ctc_test_data = [ctc_file_name, self.ctc_network, self.drop_id, self.drop_count, self.diamonds_id, ctc_data_path, mon_files] 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   817
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   818
        mocker.expect(test_plan.post_actions).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   819
            ("RunProcessAction", (("file", ctc_file_name ),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   820
                                  ("parameters", r"--ctcdata_files=" + ctc_data_path + " --monsym_files=" + mon_files + " --diamonds_build_id=" + self.diamonds_id + " --drop_id=" + self.drop_id + " --total_amount_of_drops=" + self.drop_count ))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   821
            ("EmailAction", (("subject", "Release testing"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   822
                                 ("to", self.report_email))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   823
#            ("FileStoreAction", (("to-folder", self.file_store),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   824
#                                 ("report-type", "ATS_REPORT"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   825
#                                 ("date-format", "yyyyMMdd"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   826
#                                 ("time-format", "HHmmss"))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   827
#            ("FileStoreAction", (("to-folder", self.file_store),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   828
#                                 ("report-type", "STIF_COMPONENT_REPORT_ALL_CASES"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   829
#                                 ("run-log", "true"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   830
#                                 ("date-format", "yyyyMMdd"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   831
#                                 ("time-format", "HHmmss"))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   832
            ("DiamondsAction", ())])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   833
        self.mocker.replay()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   834
        self.test_plan = test_plan
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   835
        self.gen = adg.Ats3TemplateTestDropGenerator()
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
   836
        self.gen.output_file = 'ats4drop0.zip'
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   837
        return self.gen.generate_xml(test_plan)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   838
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   839
    def test_basic_structure(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   840
        """ Check that the overall test.xml structure is valid. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   841
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   842
        # Check basics.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   843
#        assert xml.find(".").tag == "test"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   844
#        assert xml.find("./name").text == "test"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   845
#        assert xml.find("./buildid").text == self.diamonds_build_url
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   846
#        assert xml.find("./target").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   847
#        assert xml.find("./target/device").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   848
#        harness, type_, device_hwid = xml.findall("./target/device/property")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   849
#        assert harness.get("value") == "STIF"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   850
#        assert type_.get("value") == "product"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   851
#        assert device_hwid.get("value") == "5425"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   852
#        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   853
#        # Check generation of the test plan.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   854
#        assert xml.find("./plan").get("name") == "test Plan"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   855
#        assert xml.find("./plan/session").tag 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   856
#        sets = xml.findall("./execution")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   857
#        assert len(sets) == 2
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   858
#        assert sets[0].get("name") == "set0-"+str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   859
#        assert sets[0].find("./target/device").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   860
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   861
    def test_set_structure(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   862
        """ Check that a <set> element's structure is valid. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   863
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   864
        tstset = xml.find("./execution")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   865
        assert tstset.tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   866
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   867
    def test_case_flash_elems(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   868
        """ Test case flash elems. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   869
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   870
        found = False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   871
        for case in xml.findall(".//task"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   872
            if case.find('type').text == 'FlashTask':
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   873
                found = True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   874
                flashes = case.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   875
                assert len(flashes) == len(self.image_files)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   876
                for i, flash_file in enumerate(self.image_files):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   877
                    assert flashes[i].get("name") == "image-" + str(i + 1)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   878
                    assert flashes[i].get("value") == "ATS3Drop\\images\\" + flash_file.name
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   879
        assert found
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   880
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   881
    def test_case_steps(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   882
        """ Test case steps. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   883
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   884
        steps = iter(xml.findall(".//task"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   885
        steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   886
        check_ctc_start(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   887
        check_log_dir(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   888
        self.check_install_data(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   889
        self.check_install_configuration(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   890
        self.check_install_tmodules(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   891
        self.check_install_engine_ini(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   892
        self.check_run_cases(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   893
        check_ctc_write(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   894
        check_ctc_log(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   895
        check_fetch_logs(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   896
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   897
    def check_install_data(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   898
        """ Test install data. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   899
        for filename in self.data_files:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   900
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   901
            assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   902
            params = step.findall("./parameters/parameter")            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   903
            src = params[0].get("value")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   904
            assert ntpath.basename(src) == ntpath.basename(filename)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   905
            assert ntpath.dirname(src) == "ATS3Drop\\set0\\data"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   906
            dst = params[1].get("value")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   907
            assert ntpath.basename(dst) == ntpath.basename(filename)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   908
            assert ntpath.dirname(dst) == r"e:\testing\data"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   909
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   910
    def check_install_configuration(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   911
        """ Test install configuration. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   912
        for filepath in self.config_files:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   913
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   914
            assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   915
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   916
            assert params[0].get("value") == "ATS3Drop\\set0\\conf\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   917
            assert params[1].get("value") == "e:\\testing\\conf\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   918
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   919
    def check_install_tmodules(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   920
        """ Test install tmodules. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   921
        for filepath in self.testmodule_files:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   922
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   923
            assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   924
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   925
            assert params[0].get("value") == "ATS3Drop\\set0\\testmodules\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   926
            assert params[1].get("value") == "c:\\sys\\bin\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   927
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   928
    def check_install_engine_ini(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   929
        """ Test install engine ini. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   930
        filepath = self.engine_ini_file
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   931
        step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   932
        assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   933
        params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   934
        assert params[0].get("value") == "ATS3Drop\\set0\\init\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   935
        assert params[1].get("value") == "c:\\testframework\\" + ntpath.basename(filepath)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   936
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   937
    def check_run_cases(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   938
        """ Test run cases. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   939
        step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   940
        assert step.findtext("./type") == "StifRunCasesTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   941
        params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   942
        assert params[0].get("value") == "*"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   943
        assert params[1].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   944
        assert params[2].get("value") == "c:\\testframework\\" + ntpath.basename(self.engine_ini_file)
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   945
        step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   946
        assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   947
        params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   948
        assert params[0].get("value") == "TESTSCRIPTER"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   949
        assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   950
        assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   951
        assert params[3].get("value") == r"e:\testing\conf\file1.cfg"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   952
        step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   953
        assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   954
        params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   955
        assert params[0].get("value") == "TESTSCRIPTER"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   956
        assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   957
        assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
   958
        assert params[3].get("value") == r"e:\testing\conf\file2.cfg"
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   959
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   960
    def test_steps_trace_enabled(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   961
        """ Test steps trace enabled. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   962
        xml = self.generate_xml(trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   963
        steps = iter(xml.findall(".//task"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   964
        steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   965
        check_ctc_start(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   966
        check_log_dir(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   967
        self.check_install_data(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   968
        self.check_install_configuration(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   969
        self.check_install_tmodules(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   970
        self.check_install_engine_ini(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   971
        #check_trace_start(steps, self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   972
        self.check_run_cases(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   973
        #check_trace_end_steps(steps, self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   974
        check_ctc_write(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   975
        check_ctc_log(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   976
        check_fetch_logs(steps) 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   977
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   978
    def test_post_actions(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   979
        """ Post actions are inserted into XML. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   980
        xml = self.generate_xml()        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   981
        post_actions = xml.findall(".//action")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   982
        check_ctc_run_process_action(post_actions[0])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   983
        check_send_email_action(post_actions[1], self.report_email)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   984
        #check_ats_report_action(post_actions[2], self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   985
        #check_stif_report_action(post_actions[3], self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   986
        check_diamonds_action(post_actions[2])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   987
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   988
#    def test_files(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   989
#        """ Testing files. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   990
#        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   991
#        files = iter(xml.findall("./files/file"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   992
#        assert files.next().text == r"ATS3Drop/images/file1.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   993
#        assert files.next().text == r"ATS3Drop/images/file2.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   994
#        assert files.next().text == r"ATS3Drop/set0/data/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   995
#        assert files.next().text == r"ATS3Drop/set0/data/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   996
#        assert files.next().text == r"ATS3Drop/set0/data/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   997
#        assert files.next().text == r"ATS3Drop/set0/conf/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   998
#        assert files.next().text == r"ATS3Drop/set0/conf/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   999
#        assert files.next().text == r"ATS3Drop/set0/testmodules/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1000
#        assert files.next().text == r"ATS3Drop/set0/testmodules/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1001
#        assert files.next().text == r"ATS3Drop/set0/init/TestFramework.ini"        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1002
#        assert files.next().text == r"ATS3Drop/set1/data/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1003
#        assert files.next().text == r"ATS3Drop/set1/data/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1004
#        assert files.next().text == r"ATS3Drop/set1/data/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1005
#        assert files.next().text == r"ATS3Drop/set1/conf/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1006
#        assert files.next().text == r"ATS3Drop/set1/conf/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1007
#        assert files.next().text == r"ATS3Drop/set1/testmodules/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1008
#        assert files.next().text == r"ATS3Drop/set1/testmodules/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1009
#        assert files.next().text == r"ATS3Drop/set1/init/TestFramework.ini"        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1010
#        self.assertRaises(StopIteration, files.next)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1011
#        xml = self.generate_xml(trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1012
#        files = iter(xml.findall("./files/file"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1013
#        assert files.next().text == r"ATS3Drop/images/file1.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1014
#        assert files.next().text == r"ATS3Drop/images/file2.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1015
#        assert files.next().text == r"ATS3Drop/pmds/pmd_file.pmd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1016
#        assert files.next().text == r"ATS3Drop/set0/data/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1017
#        assert files.next().text == r"ATS3Drop/set0/data/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1018
#        assert files.next().text == r"ATS3Drop/set0/data/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1019
#        assert files.next().text == r"ATS3Drop/set0/conf/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1020
#        assert files.next().text == r"ATS3Drop/set0/conf/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1021
#        assert files.next().text == r"ATS3Drop/set0/testmodules/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1022
#        assert files.next().text == r"ATS3Drop/set0/testmodules/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1023
#        assert files.next().text == r"ATS3Drop/set0/init/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1024
#        assert files.next().text == r"ATS3Drop/set0/trace_init/trace_activation_1.xml"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1025
#        assert files.next().text == r"ATS3Drop/set1/data/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1026
#        assert files.next().text == r"ATS3Drop/set1/data/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1027
#        assert files.next().text == r"ATS3Drop/set1/data/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1028
#        assert files.next().text == r"ATS3Drop/set1/conf/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1029
#        assert files.next().text == r"ATS3Drop/set1/conf/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1030
#        assert files.next().text == r"ATS3Drop/set1/testmodules/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1031
#        assert files.next().text == r"ATS3Drop/set1/testmodules/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1032
#        assert files.next().text == r"ATS3Drop/set1/init/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1033
#        assert files.next().text == r"ATS3Drop/set1/trace_init/trace_activation_1.xml"        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1034
#        self.assertRaises(StopIteration, files.next)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1035
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1036
    def test_generate_drop(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1037
        """ Manifest for ATS3Drop directory structure is generated. """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1038
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1039
        strbuffer = StringIO()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1040
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1041
        self.gen.generate_drop(self.test_plan, xml, strbuffer)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1042
        zfile = zipfile.ZipFile(strbuffer, "r")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1043
        try:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1044
            contents = sorted(path(tpath).normpath() for tpath in zfile.namelist())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1045
            expected = sorted(path(tpath).normpath()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1046
                           for tpath in [r"ATS3Drop" + os.sep + "set0" + os.sep + "conf" + os.sep + "file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1047
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "conf" + os.sep + "file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1048
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1049
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1050
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1051
                                     r"ATS3Drop" + os.sep + "images" + os.sep + "file1.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1052
                                     r"ATS3Drop" + os.sep + "images" + os.sep + "file2.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1053
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "init" + os.sep + "TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1054
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "testmodules" + os.sep + "file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1055
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "testmodules" + os.sep + "file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1056
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "conf" + os.sep + "file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1057
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "conf" + os.sep + "file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1058
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1059
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1060
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1061
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "init" + os.sep + "TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1062
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "testmodules" + os.sep + "file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1063
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "testmodules" + os.sep + "file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1064
                                     r"test.xml"])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1065
            diff = difflib.context_diff(expected, contents)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1066
            assert contents == expected, "\n".join(diff)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1067
        finally:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1068
            zfile.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1069
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1070
    def test_generate_drop_trace (self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1071
        "Manifest for ATS3Drop directory structure is generated when trace enabled."
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1072
        xml = self.generate_xml(trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1073
        strbuffer = StringIO()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1074
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1075
        self.gen.generate_drop(self.test_plan, xml, strbuffer)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1076
        zfile = zipfile.ZipFile(strbuffer, "r")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1077
        try:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1078
            contents = sorted(path(tpath).normpath() for tpath in zfile.namelist())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1079
            expected = sorted(path(tpath).normpath()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1080
                           for tpath in [r"ATS3Drop" + os.sep + "set0" + os.sep + "conf" + os.sep + "file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1081
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "conf" + os.sep + "file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1082
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1083
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1084
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "data" + os.sep + "file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1085
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "trace_init" + os.sep + "trace_activation_1.xml",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1086
                                     r"ATS3Drop" + os.sep + "images" + os.sep + "file1.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1087
                                     r"ATS3Drop" + os.sep + "images" + os.sep + "file2.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1088
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "init" + os.sep + "TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1089
                                     r"ATS3Drop" + os.sep + "pmds" + os.sep + "pmd_file.pmd",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1090
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "testmodules" + os.sep + "file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1091
                                     r"ATS3Drop" + os.sep + "set0" + os.sep + "testmodules" + os.sep + "file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1092
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "conf" + os.sep + "file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1093
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "conf" + os.sep + "file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1094
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1095
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1096
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "data" + os.sep + "file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1097
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "trace_init" + os.sep + "trace_activation_1.xml",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1098
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "init" + os.sep + "TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1099
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "testmodules" + os.sep + "file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1100
                                     r"ATS3Drop" + os.sep + "set1" + os.sep + "testmodules" + os.sep + "file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1101
                                     r"test.xml"])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1102
            diff = difflib.context_diff(expected, contents)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1103
            assert contents == expected, "\n".join(diff)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1104
        finally:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1105
            zfile.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1106
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1107
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1108
class TestXMLGenerationWithPKG(mocker.MockerTestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1109
    """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1110
    Unit tests for the test.xml generation.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1111
    """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1112
    def __init__(self, methodName="runTest"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1113
        mocker.MockerTestCase.__init__(self, methodName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1114
        self.src_dst1 = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1115
        self.data_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1116
        self.config_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1117
        self.testmodule_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1118
        self.image_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1119
        self.engine_ini_file = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1120
        self.report_email = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1121
        self.file_store = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1122
        self.diamonds_build_url = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1123
        self.trace_enabled = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1124
        self.pmd_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1125
        self.trace_activation_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1126
        self.ctc_enabled = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1127
        self.eunitexerunner_flags = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1128
        self.test_plan = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1129
        self.gen = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1130
        self.src_dst0 = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1131
        self.custom_dir = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1132
        self.custom_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1133
        self.component_path = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1134
        self.ctc_run_process_params = None
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1135
        self.ats_stf_enabled = None
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1136
        
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1137
    def generate_xml(self, harness, trace_enabled="False", tef_test_module=None, ats_stf_enabled="False"):
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1138
        """Generates XML"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1139
        def files(*paths):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1140
            """generates paths for the files"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1141
            return [TEST_PATH.joinpath("tsrc", tpath) for tpath in paths]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1142
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1143
        self.src_dst1 = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1144
        self.data_files = files("data/file1", "data/file2", "data/file3")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1145
        self.config_files = files("conf/file1.cfg", "conf/file2.cfg")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1146
        self.testmodule_files = files("testmodules/file1.dll", "testmodules/file2.dll")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1147
        self.image_files = files("output/images/file1.fpsx", "output/images/file2.fpsx")
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1148
        if tef_test_module:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1149
            TEST_PATH.joinpath(r"tsrc" + os.sep + "init" + os.sep + "TestFramework.ini").write_text(
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1150
                r"""
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1151
#     - Sets a device reset module's dll name(Reboot).
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1152
#        + If Nokia specific reset module is not available or it is not correct one
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1153
#          StifHWResetStub module may use as a template for user specific reset
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1154
#          module. 
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1155
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1156
[Engine_Defaults]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1157
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1158
TestReportMode= FullReport        # Possible values are: 'Empty', 'Summary', 'Environment',
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1159
                                                               'TestCases' or 'FullReport'
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1160
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1161
CreateTestReport= YES            # Possible values: YES or NO
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1162
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1163
TestReportFilePath= C:\LOGS\TestFramework\
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1164
TestReportFileName= TestReport
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1165
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1166
TestReportFormat= TXT            # Possible values: TXT or HTML
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1167
[End_Defaults]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1168
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1169
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1170
[New_Module]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1171
ModuleName= teftestmodule 
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1172
        
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1173
        """)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1174
        else:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1175
            TEST_PATH.joinpath(r"tsrc" + os.sep + "init" + os.sep + "TestFramework.ini").write_text(        
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1176
                r"""
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1177
#     - Sets a device reset module's dll name(Reboot).
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1178
#        + If Nokia specific reset module is not available or it is not correct one
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1179
#          StifHWResetStub module may use as a template for user specific reset
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1180
#          module. 
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1181
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1182
[Engine_Defaults]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1183
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1184
TestReportMode= FullReport        # Possible values are: 'Empty', 'Summary', 'Environment',
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1185
                                                               'TestCases' or 'FullReport'
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1186
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1187
CreateTestReport= YES            # Possible values: YES or NO
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1188
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1189
TestReportFilePath= C:\LOGS\TestFramework\
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1190
TestReportFileName= TestReport
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1191
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1192
TestReportFormat= TXT            # Possible values: TXT or HTML
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1193
[End_Defaults]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1194
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1195
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1196
[New_Module]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1197
ModuleName= testscripter
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1198
        
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1199
        """)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1200
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1201
        self.engine_ini_file = files("init/TestFramework.ini")[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1202
        self.report_email = "test.receiver@company.com"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1203
        self.file_store = path("path/to/reports")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1204
        self.diamonds_build_url = "http://diamonds.nmp.company.com/diamonds/builds/1234"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1205
        self.trace_enabled = trace_enabled
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1206
        self.pmd_files = TEST_FILES["pmd_file"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1207
        self.trace_activation_files = files("trace_init/trace_activation_1.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1208
        self.ctc_enabled = "True"
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1209
        self.ats_stf_enabled = ats_stf_enabled
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1210
        self.eunitexerunner_flags = "/E S60AppEnv /R Off"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1211
        self.custom_dir = "custom"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1212
        self.custom_files = files("custom/postpostaction.xml", "custom/prepostaction.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1213
        self.component_path = str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1214
        self.ctc_run_process_params = r"10.0.0.1#x:\ats\drop0.zip#1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1215
        self.src_dst0 = [
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1216
            (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file1.dll"), path(r"c:\sys\bin\file1.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1217
            (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file2.dll"), path(r"c:\sys\bin\file2.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1218
            (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file1"), path(r"e:\sys\bin\file1"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1219
            (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file2"), path(r"e:\sys\bin\file2"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1220
            (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file3"), path(r"e:\sys\bin\file3"), "data"),]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1221
        if harness == "STIF" or harness == "MULTI_HARNESS":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1222
            harness0 = harness1 = "STIF"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1223
            if "MULTI_HARNESS" in harness:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1224
                harness1 = "EUNIT"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1225
                self.src_dst1 = [
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1226
                    (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file1.dll"), path(r"c:\sys\bin\file1.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1227
                    (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file2.dll"), path(r"c:\sys\bin\file2.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1228
                    (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file1"), path(r"e:\sys\bin\file1"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1229
                    (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file2"), path(r"e:\sys\bin\file2"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1230
                    (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file3"), path(r"e:\sys\bin\file3"), "data"),] 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1231
            self.src_dst0 = [
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1232
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file1.dll"), path(r"c:\sys\bin\file1.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1233
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "testmodules" + os.sep + "file2.dll"), path(r"c:\sys\bin\file2.dll"), "testmodule"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1234
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file1"), path(r"e:\sys\bin\file1"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1235
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file2"), path(r"e:\sys\bin\file2"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1236
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "data" + os.sep + "file3"), path(r"e:\sys\bin\file3"), "data"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1237
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "conf" + os.sep + "file1.cfg"), path(r"c:\sys\bin\file1.cfg"), "conf"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1238
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "conf" + os.sep + "file2.cfg"), path(r"c:\sys\bin\file2.cfg"), "conf"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1239
                (TEST_PATH.joinpath(r"tsrc" + os.sep + "init" + os.sep + "TestFramework.ini"), path(r"c:\sys\bin\TestFramework.ini"), "engine_ini"),]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1240
            if "STIF" in harness:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1241
                self.src_dst1 = self.src_dst0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1242
            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1243
        elif harness == "EUNIT":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1244
            harness0 = harness1 = harness
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1245
            self.src_dst1 = self.src_dst0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1246
            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1247
        self.mocker.restore()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1248
        test_plan = self.mocker.mock(count=False)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1249
        mocker.expect(test_plan["testrun_name"]).result("test")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1250
        mocker.expect(test_plan["harness"]).result(harness)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1251
        mocker.expect(test_plan["device_type"]).result("product")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1252
        mocker.expect(test_plan["hti"]).result("True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1253
        mocker.expect(test_plan["plan_name"]).result("test plan")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1254
        mocker.expect(test_plan["diamonds_build_url"]).result(self.diamonds_build_url)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1255
        mocker.expect(test_plan["test_timeout"]).result("60")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1256
        mocker.expect(test_plan["eunitexerunner_flags"]).result("/E S60AppEnv /R Off")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1257
        mocker.expect(test_plan["eunitexerunner?flags"]).result(self.eunitexerunner_flags)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1258
        mocker.expect(test_plan["device_hwid"]).result("5425")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1259
        mocker.expect(test_plan["trace_enabled"]).result(self.trace_enabled)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1260
        mocker.expect(test_plan["ctc_enabled"]).result(self.ctc_enabled)
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1261
        mocker.expect(test_plan["ats_stf_enabled"]).result(self.ats_stf_enabled)
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1262
        mocker.expect(test_plan["custom_dir"]).result("custom1A")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1263
        mocker.expect(test_plan.custom_dir).result(path(r"self.custom_dir"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1264
        mocker.expect(test_plan["ctc_run_process_params"]).result(self.ctc_run_process_params)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1265
        mocker.expect(test_plan["report_email"]).result(self.report_email)
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1266
        mocker.expect(test_plan["report_type"]).result("")
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1267
        mocker.expect(test_plan["file_store"]).result("")
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1268
        if self.trace_enabled == "False":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1269
            mocker.expect(test_plan.sets).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1270
                dict(name="set0", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1271
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1272
                     engine_ini_file=self.engine_ini_file, test_harness=harness0,src_dst=self.src_dst0,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1273
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1274
                     custom_dir = self.custom_dir, component_path=self.component_path, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1275
                dict(name="set1", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1276
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1277
                     engine_ini_file=self.engine_ini_file, test_harness=harness1, src_dst=self.src_dst1,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1278
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1279
                     custom_dir = self.custom_dir, component_path=self.component_path, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1280
            ])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1281
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1282
            mocker.expect(test_plan.sets).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1283
                dict(name="set0", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1284
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1285
                     engine_ini_file=self.engine_ini_file, test_harness=harness0, src_dst=self.src_dst0,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1286
                     pmd_files=self.pmd_files, trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1287
                     trace_path=self.file_store.joinpath("traces", "set0", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1288
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1289
                     custom_dir = self.custom_dir, component_path=self.component_path, hti="True"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1290
                dict(name="set1", image_files=self.image_files, data_files=self.data_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1291
                     config_files=self.config_files, testmodule_files=self.testmodule_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1292
                     engine_ini_file=self.engine_ini_file, test_harness=harness1, src_dst=self.src_dst1,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1293
                     pmd_files=self.pmd_files, trace_activation_files=self.trace_activation_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1294
                     trace_path=self.file_store.joinpath("traces", "set1", "tracelog.blx"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1295
                     ctc_enabled=self.ctc_enabled, eunitexerunner_flags=self.eunitexerunner_flags,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1296
                     custom_dir = self.custom_dir, component_path=self.component_path, hti="True"),])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1297
        mocker.expect(test_plan.post_actions).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1298
            ("EmailAction", (("subject", "Release testing"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1299
                                 ("to", self.report_email))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1300
#            ("FileStoreAction", (("to-folder", self.file_store),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1301
#                                 ("report-type", "ATS_REPORT"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1302
#                                 ("date-format", "yyyyMMdd"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1303
#                                 ("time-format", "HHmmss"))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1304
#            ("FileStoreAction", (("to-folder", self.file_store),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1305
#                                 ("report-type", "STIF_COMPONENT_REPORT_ALL_CASES"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1306
#                                 ("run-log", "true"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1307
#                                 ("date-format", "yyyyMMdd"),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1308
#                                 ("time-format", "HHmmss"))),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1309
            ("DiamondsAction", ())])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1310
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1311
        self.mocker.replay()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1312
        self.test_plan = test_plan
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1313
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1314
        self.gen = adg.Ats3TemplateTestDropGenerator()
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1315
        self.gen.output_file = 'ats4drop0.zip'
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1316
        return self.gen.generate_xml(test_plan)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1317
#        for thar in test_harness:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1318
#            xml = self.generate_xml(thar)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1319
#            # Check basics.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1320
#            assert xml.find(".").tag == "test"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1321
#            assert xml.find("./name").text == "test"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1322
#            assert xml.find("./buildid").text == self.diamonds_build_url
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1323
#            assert xml.find("./target").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1324
#            assert xml.find("./target/device").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1325
#            if self.test_plan["harness"] == "MULTI_HARNESS":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1326
#                harness_1, type_1, device_hwid_1, harness_2, type_2, device_hwid_2 = xml.findall("./target/device/property")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1327
#            else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1328
#                harness_1, type_1, device_hwid_1 = xml.findall("./target/device/property")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1329
#            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1330
#            if self.test_plan["harness"] == "MULTI_HARNESS":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1331
#                assert harness_1.get("value") == "STIF"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1332
#                assert type_1.get("value") == "product"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1333
#                assert device_hwid_1.get("value") == "5425"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1334
#                assert harness_2.get("value") == "EUNIT"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1335
#                assert type_2.get("value") == "product"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1336
#                assert device_hwid_2.get("value") == "5425"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1337
#            else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1338
#                assert harness_1.get("value") == thar
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1339
#                assert type_1.get("value") == "product"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1340
#                assert device_hwid_1.get("value") == "5425"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1341
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1342
#        # Check generation of the test plan.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1343
#        assert xml.find("./plan").get("name") == "test Plan"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1344
#        assert xml.find("./plan/session").tag 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1345
#        sets = xml.findall("./execution")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1346
#        assert len(sets) == 2
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1347
#        assert sets[0].get("name") == "set0-"+str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1348
#        assert sets[0].find("./target/device").tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1349
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1350
    def test_set_structure(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1351
        """Check that a <set> element's structure is valid."""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1352
        xml = self.generate_xml("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1353
        tstset = xml.find("./execution")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1354
        assert tstset.tag
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1355
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1356
    def test_case_flash_elems(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1357
        """Checks flash target element in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1358
        xml = self.generate_xml("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1359
        found = False
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1360
        for case in xml.findall(".//task"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1361
            if case.find('type').text == 'FlashTask':
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1362
                found = True
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1363
                flashes = case.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1364
                assert len(flashes) == len(self.image_files)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1365
                for i, flash_file in enumerate(self.image_files):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1366
                    assert flashes[i].get("name") == "image-" + str(i + 1)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1367
                    assert flashes[i].get("value") == "ATS3Drop\\images\\" + flash_file.name
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1368
        assert found
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1369
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1370
    def test_case_steps(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1371
        """Checks cases in steps in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1372
        test_harness = ["STIF", "EUNIT", "MULTI_HARNESS"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1373
        for thar in test_harness:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1374
            xml = self.generate_xml(thar)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1375
            #print et.tostring(xml.getroot())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1376
            steps = iter(xml.findall(".//task"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1377
            steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1378
            check_ctc_start(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1379
            check_log_dir(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1380
            if "MULTI_HARNESS" in thar:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1381
                self.check_install_step(steps, "STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1382
                self.check_run_cases(steps, "STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1383
                check_ctc_write(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1384
                check_ctc_log(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1385
                check_fetch_logs(steps, "STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1386
                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1387
                steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1388
                check_ctc_start(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1389
                check_log_dir(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1390
                self.check_install_step(steps, "EUNIT", set_count="1")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1391
                self.check_run_cases(steps, "EUNIT")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1392
                check_ctc_write(steps)
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1393
                check_ctc_log(steps)
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1394
                check_fetch_logs(steps, "EUNIT")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1395
            else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1396
                self.check_install_step(steps, thar)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1397
                self.check_run_cases(steps, thar)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1398
                check_ctc_write(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1399
                check_ctc_log(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1400
                check_fetch_logs(steps, thar)
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1401
                
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1402
    def test_case_steps_teftestmodule(self):
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1403
        """Checks cases in steps in the test.xml file for TEFTESTMODULE"""
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1404
        test_harness = ["STIF", "EUNIT", "MULTI_HARNESS"]
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1405
        for thar in test_harness:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1406
            xml = self.generate_xml(thar, tef_test_module=True, ats_stf_enabled="True")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1407
            #print et.tostring(xml.getroot())
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1408
            steps = iter(xml.findall(".//task"))
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1409
            steps.next() # Flash images
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1410
            check_ctc_start(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1411
            check_log_dir(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1412
            if "MULTI_HARNESS" in thar:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1413
                self.check_install_step(steps, "STIF")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1414
                self.check_run_cases(steps, "STIF", tef_test_module=True, ats_stf_enabled="True")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1415
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1416
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1417
                check_fetch_logs(steps, "STIF")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1418
                
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1419
                steps.next() # Flash images
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1420
                check_ctc_start(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1421
                check_log_dir(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1422
                self.check_install_step(steps, "EUNIT", set_count="1")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1423
                self.check_run_cases(steps, "EUNIT")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1424
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1425
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1426
                check_fetch_logs(steps, "EUNIT")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1427
            else:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1428
                self.check_install_step(steps, thar)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1429
                self.check_run_cases(steps, thar, tef_test_module=True)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1430
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1431
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1432
                check_fetch_logs(steps, thar)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1433
        for thar in test_harness:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1434
            xml = self.generate_xml(thar, tef_test_module=True)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1435
            #print et.tostring(xml.getroot())
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1436
            steps = iter(xml.findall(".//task"))
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1437
            steps.next() # Flash images
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1438
            check_ctc_start(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1439
            check_log_dir(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1440
            if "MULTI_HARNESS" in thar:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1441
                self.check_install_step(steps, "STIF")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1442
                self.check_run_cases(steps, "STIF", tef_test_module=True)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1443
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1444
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1445
                check_fetch_logs(steps, "STIF")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1446
                
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1447
                steps.next() # Flash images
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1448
                check_ctc_start(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1449
                check_log_dir(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1450
                self.check_install_step(steps, "EUNIT", set_count="1")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1451
                self.check_run_cases(steps, "EUNIT")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1452
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1453
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1454
                check_fetch_logs(steps, "EUNIT")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1455
            else:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1456
                self.check_install_step(steps, thar)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1457
                self.check_run_cases(steps, thar, tef_test_module=True)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1458
                check_ctc_write(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1459
                check_ctc_log(steps)
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1460
                check_fetch_logs(steps, thar)
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1461
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1462
    def check_install_step(self, steps, harness, set_count="0"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1463
        """Checks install steps in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1464
        if harness == "MULTI_HARNESS":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1465
            dst = [self.src_dst0, self.src_dst1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1466
        else:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1467
            dst = [self.src_dst0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1468
        if set_count == "1":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1469
            dst = [self.src_dst1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1470
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1471
        for dest in dst:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1472
            for file1 in dest:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1473
                step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1474
                (drive, _) = ntpath.splitdrive(file1[1])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1475
                filename = ntpath.basename(file1[1])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1476
                letter = drive[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1477
                #if "FileUploadTask" in step.get("type"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1478
                assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1479
                params = step.findall("./parameters/parameter")            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1480
                src = params[0].get("value")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1481
                assert ntpath.basename(src) == filename
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1482
                assert ntpath.dirname(src) == "ATS3Drop\\set" + set_count + '\\' + letter + '\\' + "sys\\bin"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1483
                dst = params[1].get("value")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1484
                assert ntpath.basename(dst) == filename
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1485
                assert ntpath.dirname(dst) == drive + "\\sys\\bin"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1486
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1487
    def check_run_cases(self, steps, harness="STIF", tef_test_module=None, ats_stf_enabled="False"):
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1488
        """Checks run cases in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1489
        step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1490
        if harness == "STIF":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1491
            _ = self.engine_ini_file 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1492
            assert step.findtext("./type") == "StifRunCasesTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1493
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1494
            assert params[0].get("value") == "*"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1495
            assert params[1].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1496
            assert params[2].get("value") == "c:\\sys\\bin\\" + ntpath.basename(self.engine_ini_file)
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1497
            step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1498
            assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1499
            params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1500
            assert params[0].get("value") == "file1.dll"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1501
            assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1502
            assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1503
            step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1504
            assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1505
            params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1506
            assert params[0].get("value") == "file2.dll"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1507
            assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1508
            assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1509
            step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1510
            assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1511
            params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1512
            if tef_test_module:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1513
                assert params[0].get("value") == "teftestmodule"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1514
            else:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1515
                assert params[0].get("value") == "TESTSCRIPTER"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1516
            assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1517
            assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1518
            assert params[3].get("value") == r"c:\sys\bin\file1.cfg"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1519
            if tef_test_module  and ats_stf_enabled.lower() == "true":
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1520
                assert params[4].get("value") == r"c:\spd_logs\xml\teftestmodule.xml"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1521
            
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1522
            step = steps.next()
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1523
            assert step.findtext("./type") == "StifRunCasesTask"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1524
            params = step.findall("./parameters/parameter")
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1525
            if tef_test_module:
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1526
                assert params[0].get("value") == "teftestmodule"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1527
            else:                
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1528
                assert params[0].get("value") == "TESTSCRIPTER"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1529
            assert params[1].get("value") == "*"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1530
            assert params[2].get("value") == "60"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1531
            assert params[3].get("value") == r"c:\sys\bin\file2.cfg"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1532
            if tef_test_module  and ats_stf_enabled.lower() == "true":
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1533
                assert params[4].get("value") == r"c:\spd_logs\xml\teftestmodule.xml"
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1534
            
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1535
            
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1536
        elif harness == "EUNIT":
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1537
            _ = self.testmodule_files[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1538
            assert step.findtext("./type") == "EUnitTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1539
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1540
            assert params[0].get("value") == path(r"z:\sys\bin\EUNITEXERUNNER.EXE")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1541
            assert params[1].get("value") == path(r"c:\Shared\EUnit\logs\file1_log.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1542
            assert params[2].get("value") == "/E S60AppEnv /R Off /F file1 /l xml file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1543
            assert params[3].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1544
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1545
            _ = self.testmodule_files[1]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1546
            assert step.findtext("./type") == "EUnitTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1547
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1548
            assert params[0].get("value") == path(r"z:\sys\bin\EUNITEXERUNNER.EXE")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1549
            assert params[1].get("value") == path(r"c:\Shared\EUnit\logs\file2_log.xml")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1550
            assert params[2].get("value") == "/E S60AppEnv /R Off /F file2 /l xml file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1551
            assert params[3].get("value") == "60"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1552
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1553
    def test_steps_trace_enabled(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1554
        """checks if traing is enabled"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1555
        test_harness = ["STIF"]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1556
        for thar in test_harness:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1557
            xml = self.generate_xml(thar, trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1558
            steps = iter(xml.findall(".//task"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1559
            steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1560
            check_ctc_start(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1561
            check_log_dir(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1562
            self.check_install_step(steps, thar)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1563
            #check_trace_start(steps, self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1564
            self.check_run_cases(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1565
            #check_trace_end_steps(steps, self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1566
            check_ctc_write(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1567
            check_ctc_log(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1568
            check_fetch_logs(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1569
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1570
    def test_post_actions(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1571
        "Post actions are inserted into XML."
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1572
        xml = self.generate_xml("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1573
        post_actions = xml.findall(".//action")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1574
        check_send_email_action(post_actions[0], self.report_email)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1575
        #check_ats_report_action(post_actions[1], self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1576
        #check_stif_report_action(post_actions[2], self.file_store)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1577
        check_diamonds_action(post_actions[1])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1578
#    def test_files(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1579
#        """Tests if the files are created for mock"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1580
#        xml = self.generate_xml("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1581
#        files = iter(xml.findall("./files/file"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1582
#        assert files.next().text == r"ATS3Drop/images/file1.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1583
#        assert files.next().text == r"ATS3Drop/images/file2.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1584
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1585
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1586
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1587
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1588
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1589
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1590
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file2.cfg"        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1591
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1592
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1593
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1594
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1595
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1596
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1597
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1598
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1599
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1600
#        self.assertRaises(StopIteration, files.next)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1601
#        xml = self.generate_xml(harness="STIF", trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1602
#        files = iter(xml.findall("./files/file"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1603
#        assert files.next().text == r"ATS3Drop/images/file1.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1604
#        assert files.next().text == r"ATS3Drop/images/file2.fpsx"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1605
#        assert files.next().text == r"ATS3Drop/pmds/pmd_file.pmd"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1606
#        assert files.next().text == r"ATS3Drop/set0/trace_init/trace_activation_1.xml"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1607
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1608
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1609
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1610
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1611
#        assert files.next().text == r"ATS3Drop/set0/e/sys/bin/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1612
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1613
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1614
#        assert files.next().text == r"ATS3Drop/set0/c/sys/bin/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1615
#        assert files.next().text == r"ATS3Drop/set1/trace_init/trace_activation_1.xml"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1616
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file1.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1617
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file2.dll"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1618
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1619
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file2"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1620
#        assert files.next().text == r"ATS3Drop/set1/e/sys/bin/file3"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1621
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file1.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1622
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/file2.cfg"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1623
#        assert files.next().text == r"ATS3Drop/set1/c/sys/bin/TestFramework.ini"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1624
#
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1625
#        self.assertRaises(StopIteration, files.next)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1626
    def test_generate_drop(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1627
        """Manifest for ATS3Drop directory structure is generated."""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1628
        xml = self.generate_xml("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1629
        strbuffer = StringIO()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1630
        self.gen.generate_drop(self.test_plan, xml, strbuffer)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1631
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1632
        zfile = zipfile.ZipFile(strbuffer, "r")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1633
        try:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1634
            contents = sorted(tpath for tpath in zfile.namelist())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1635
            expected = sorted(tpath
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1636
                           for tpath in [r"ATS3Drop/set0/c/sys/bin/file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1637
                                     r"ATS3Drop/set0/c/sys/bin/file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1638
                                     r"ATS3Drop/set0/e/sys/bin/file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1639
                                     r"ATS3Drop/set0/e/sys/bin/file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1640
                                     r"ATS3Drop/set0/e/sys/bin/file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1641
                                     r"ATS3Drop/images/file1.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1642
                                     r"ATS3Drop/images/file2.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1643
                                     r"ATS3Drop/set0/c/sys/bin/TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1644
                                     r"ATS3Drop/set0/c/sys/bin/file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1645
                                     r"ATS3Drop/set0/c/sys/bin/file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1646
                                     r"ATS3Drop/set1/c/sys/bin/file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1647
                                     r"ATS3Drop/set1/c/sys/bin/file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1648
                                     r"ATS3Drop/set1/e/sys/bin/file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1649
                                     r"ATS3Drop/set1/e/sys/bin/file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1650
                                     r"ATS3Drop/set1/e/sys/bin/file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1651
                                     r"ATS3Drop/set1/c/sys/bin/TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1652
                                     r"ATS3Drop/set1/c/sys/bin/file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1653
                                     r"ATS3Drop/set1/c/sys/bin/file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1654
                                     r"test.xml"])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1655
            diff = difflib.context_diff(expected, contents)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1656
            assert contents == expected, "\n".join(diff)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1657
        finally:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1658
            zfile.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1659
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1660
    def test_generate_drop_trace_enabled(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1661
        "Manifest for ATS3Drop directory structure is generated when trace enabled."
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1662
        xml = self.generate_xml(harness="STIF", trace_enabled="True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1663
        strbuffer = StringIO()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1664
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1665
        self.gen.generate_drop(self.test_plan, xml, strbuffer)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1666
        zfile = zipfile.ZipFile(strbuffer, "r")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1667
        try:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1668
            contents = sorted(tpath for tpath in zfile.namelist())
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1669
            expected = sorted(tpath
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1670
                           for tpath in [r"ATS3Drop/set0/c/sys/bin/file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1671
                                     r"ATS3Drop/set0/c/sys/bin/file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1672
                                     r"ATS3Drop/set0/e/sys/bin/file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1673
                                     r"ATS3Drop/set0/e/sys/bin/file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1674
                                     r"ATS3Drop/set0/e/sys/bin/file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1675
                                     r"ATS3Drop/set0/trace_init/trace_activation_1.xml",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1676
                                     r"ATS3Drop/images/file1.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1677
                                     r"ATS3Drop/images/file2.fpsx",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1678
                                     r"ATS3Drop/pmds/pmd_file.pmd",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1679
                                     r"ATS3Drop/set0/c/sys/bin/TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1680
                                     r"ATS3Drop/set0/c/sys/bin/file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1681
                                     r"ATS3Drop/set0/c/sys/bin/file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1682
                                     r"ATS3Drop/set1/c/sys/bin/file1.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1683
                                     r"ATS3Drop/set1/c/sys/bin/file2.cfg",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1684
                                     r"ATS3Drop/set1/e/sys/bin/file1",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1685
                                     r"ATS3Drop/set1/e/sys/bin/file2",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1686
                                     r"ATS3Drop/set1/e/sys/bin/file3",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1687
                                     r"ATS3Drop/set1/trace_init/trace_activation_1.xml",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1688
                                     r"ATS3Drop/set1/c/sys/bin/TestFramework.ini",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1689
                                     r"ATS3Drop/set1/c/sys/bin/file1.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1690
                                     r"ATS3Drop/set1/c/sys/bin/file2.dll",
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1691
                                     r"test.xml"])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1692
            diff = difflib.context_diff(expected, contents)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1693
            assert contents == expected, "\n".join(diff)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1694
        finally:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1695
            zfile.close()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1696
            
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1697
class TestDropGenerationWithSis(mocker.MockerTestCase):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1698
    """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1699
    Unit tests for the test.xml generation with sis files.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1700
    """
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1701
    def __init__(self, methodName="runTest"):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1702
        mocker.MockerTestCase.__init__(self, methodName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1703
        self.sis_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1704
        self.image_files = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1705
        self.engine_ini_file = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1706
        self.report_email = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1707
        self.file_store = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1708
        self.diamonds_build_url = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1709
        self.harness = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1710
        self.test_plan = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1711
        self.gen = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1712
        self.src_dst = []
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1713
        self.component_path = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1714
        self.ctc_run_process_params = None
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1715
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1716
    def generate_xml(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1717
        """Geberates XML if sis files"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1718
        def files(*paths):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1719
            """generates paths for the files"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1720
            return [TEST_PATH.joinpath("tsrc", tpath) for tpath in paths]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1721
        self.sis_files = files("sis/file1.sisx", "sis/file2.sisx", "sis/file3.sisx")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1722
        self.image_files = files("output/images/file1.fpsx", "output/images/file2.fpsx")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1723
        self.engine_ini_file = files("init/TestFramework.ini")[0]
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1724
        self.report_email = "test.receiver@company.com"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1725
        self.file_store = path("path/to/reports")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1726
        self.diamonds_build_url = "http://diamonds.nmp.company.com/diamonds/builds/1234"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1727
        self.harness = "STIF"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1728
        self.component_path = str(TEST_PATH.joinpath("tsrc", "group"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1729
        self.ctc_run_process_params = r"10.0.0.1#x:\ats\drop0.zip#1"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1730
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1731
        test_plan = self.mocker.mock(count=False)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1732
        mocker.expect(test_plan["testrun_name"]).result("test")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1733
        mocker.expect(test_plan["harness"]).result("STIF")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1734
        mocker.expect(test_plan["device_type"]).result("product")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1735
        mocker.expect(test_plan["hti"]).result("True")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1736
        mocker.expect(test_plan["plan_name"]).result("test plan")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1737
        mocker.expect(test_plan["diamonds_build_url"]).result(self.diamonds_build_url)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1738
        mocker.expect(test_plan["test_timeout"]).result("60")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1739
        mocker.expect(test_plan["device_hwid"]).result("5425")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1740
        mocker.expect(test_plan["ctc_enabled"]).result("False")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1741
        mocker.expect(test_plan["trace_enabled"]).result("False")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1742
        mocker.expect(test_plan["custom_dir"]).result("CustomC")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1743
        mocker.expect(test_plan.custom_dir).result(path(r"self.custom_dir"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1744
        mocker.expect(test_plan["ctc_run_process_params"]).result(self.ctc_run_process_params)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1745
        mocker.expect(test_plan["report_email"]).result(self.report_email)
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1746
        mocker.expect(test_plan["report_type"]).result("")
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1747
        mocker.expect(test_plan["file_store"]).result("")
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1748
        mocker.expect(test_plan.sets).result([
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1749
            dict(name="set0", image_files=self.image_files, sis_files=self.sis_files,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1750
                 engine_ini_file=self.engine_ini_file, test_harness=self.harness, ctc_enabled="False", component_path=self.component_path, custom_dir=None),
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1751
             ])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1752
        mocker.expect(test_plan.post_actions).result([])
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1753
        self.mocker.replay()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1754
        self.test_plan = test_plan
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1755
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1756
        self.gen = adg.Ats3TemplateTestDropGenerator()
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1757
        self.gen.output_file = 'ats4drop0.zip'
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1758
        return self.gen.generate_xml(test_plan)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1759
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1760
    def test_case_steps(self):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1761
        """Checks cases in steps in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1762
        xml = self.generate_xml()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1763
        steps = iter(xml.findall(".//task"))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1764
        steps.next() # Flash images
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1765
        steps.next() # Stif log dir creation.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1766
        self.check_install_sis_files(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1767
        steps.next() # Install engine ini.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1768
        self.check_install_sis_to_device(steps)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1769
        steps.next() # Run cases.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1770
        steps.next() # Fetch logs.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1771
        self.assertRaises(StopIteration, steps.next)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1772
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1773
    def check_install_sis_files(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1774
        """Checks sis files install steps in the test.xml file"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1775
        for filename in self.sis_files:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1776
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1777
            assert step.findtext("./type") == "FileUploadTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1778
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1779
            # TO DO: Should sis files be specified outside of the set?
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1780
            assert params[0].get("value") == "ATS3Drop\\set0\\sis\\" + ntpath.basename(filename)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1781
            assert params[1].get("value") == "c:\\testframework\\" + ntpath.basename(filename)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1782
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1783
    def check_install_sis_to_device(self, steps):
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1784
        """Checks sis files installation on the device"""
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1785
        for filename in self.sis_files:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1786
            step = steps.next()
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1787
            assert step.findtext("./type") == "InstallSisTask"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1788
            params = step.findall("./parameters/parameter")
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
  1789
            assert params[-1].get("value") == "c:\\testframework\\" + ntpath.basename(filename)
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1790
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1791
def test_ats_sut():
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1792
    """Test SymbianUnitTest"""
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1793
    opts = Bunch(file_store='', flash_images='', diamonds_build_url='', testrun_name='', device_type='', report_email='', test_timeout='', drop_file='', config_file='', target_platform='', data_dir='', build_drive='', sis_files='', harness='', trace_enabled='', specific_pkg='', ats4_enabled='true', device_hwid='')
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1794
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1795
    test_plan = ats3.Ats3TestPlan(opts)
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1796
    component_parser = ats3.testconfigurator.Ats3ComponentParser(opts)
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1797
    
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1798
    test_plan.sets = [dict(name="set0", image_files='', test_harness='GENERIC', custom_dir=None, src_dst=[("file1.dll", r"c:\sys\bin\file1.dll", "testmodule:sut")])]
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1799
    
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1800
    generator = ats3.dropgenerator.Ats3TemplateTestDropGenerator()
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1801
    generator.output_file = 'ats4drop0.zip'
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1802
    xml = generator.generate_xml(test_plan)
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1803
    #print et.tostring(xml.getroot())
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1804
    
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1805
    steps = iter(xml.findall(".//task"))
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1806
    steps.next()
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1807
    steps.next()
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1808
    step = steps.next()
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1809
    assert step.findtext("./type") == "SymbianUnitTestTask"
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
  1810
    params = step.findall("./parameters/parameter")
645
b8d81fa19e7d helium_12.0.0-63b64366f9cf
wbernard
parents: 628
diff changeset
  1811
    assert params[1].get("value") == r"-tests=c:\sys\bin\file1.dll -noprompt"