2 ###############################################################################
3 # Copyright (c) 2000-2016 Ericsson Telecom AB
4 # All rights reserved. This program and the accompanying materials
5 # are made available under the terms of the Eclipse Public License v1.0
6 # which accompanies this distribution, and is available at
7 # http://www.eclipse.org/legal/epl-v10.html
13 ###############################################################################
17 #The goal of this script is to compare the logfile generation result for two different Titan version.
18 #If switches are not applied the original logfiles given as input will be compared with the just generated log files
19 #This is the use case in folder regression_test/logger/logtest
23 # old_logfilename.txt -if "-o" not used
24 # old_logfilename_modified.txt -if "-o" not used
26 # old_logfilename.txt -if "-o" used
27 # old_logfilename_modified.txt -if "-o" used
28 # Console_old_logfilename.txt
30 # new_logfilename_modified.txt
31 # Console_new_logfilename.txt
34 cfg_filename
="Titan_LogTest.cfg"
35 old_logfilename
="original_merged_log"
36 new_logfilename
="new_merged_log"
41 ##### FUNCTIONS #######
48 echo "Usage: $0 <options>"
50 echo " -o create old versions"
51 echo " -c [config filename] e.g.: Titan_LogTest.cfg"
52 echo " -O [Old log file name (before modification)]"
53 echo " -N [New log file name (before modification)]"
54 echo " -g generate makefiles. Mandatory if -o applied"
55 echo "Prerequisite: TTCN3_DIR set for the new ttcn3 dir"
64 if [ "$TTCN3_DIR_OLD" == "" ]
66 TTCN3_DIR_OLD
="/mnt/TTCN/Releases/TTCNv3-1.8.pl5"
68 echo "TTCN3_DIR_OLD:${TTCN3_DIR_OLD}"
70 if [ "$TTCN3_DIR" == "" ]
72 TTCN3_DIR
="/export/localhome/TCC/ethbaat/XmlTest/install"
74 TTCN3_DIR_NEW
=${TTCN3_DIR}
76 echo "TTCN3_DIR:${TTCN3_DIR}"
78 LD_LIBRARY_PATH_ORIG
=$LD_LIBRARY_PATH
80 SYSTEM_NAME
=`uname -n`
89 export USER
=$
(/usr
/ucb
/whoami
)
95 # $1: name of the cfg file
96 # $2: name of the merged log file
97 # $3: name of the merged modified log file (timestamps removed)
101 echo "Create_log called"
105 if [ "${generate_makefile}" == "1" ]
107 ttcn3_makefilegen
-fg Titan_LogTest.ttcn Titan_LogTestDefinitions.ttcn
*.cc
*.hh
111 echo "ttcn3_start Titan_LogTest $1"
112 ttcn3_start Titan_LogTest
"$1" |
tee "Console_$2"
114 #ttcn3_logmerge *.log > "$2"
115 #logmerge the order of the loglines can be different per executions
116 # therefore the logs will be appended instead of merge
117 echo "Appended logs:" > "$2"
118 list
=$
(ls Titan_LogTest
*.log |
xargs)
125 s/^.*\(EXECUTOR_COMPONENT - TTCN-3 Parallel Test Component started on\).*\( Component reference:\).*$/\1 \2/g
126 s/^.*\(PORTEVENT_UNQUALIFIED - Port internal_port is waiting for connection from\).*$/\1/g
127 s/^.*\(EXECUTOR_UNQUALIFIED - The local IP address of the control connection to\).*$/\1/g
128 s/^.*\(EXECUTOR_COMPONENT - TTCN-3 Main Test Component started on\).*$/\1/g
129 s/^.*\(EXECUTOR_RUNTIME - TTCN-3 Host Controller started on\).*$/\1/g
130 s/^.*\(EXECUTOR_UNQUALIFIED - The address of MC was set to\).*$/\1/g
131 s/^.*\(EXECUTOR_RUNTIME - MTC was created. Process id\).*$/\1/g
132 s/^.*\(Random number generator was initialized with seed\)\(.*\)$/\1/g
133 s/^.*\(Function rnd() returned\)\(.*\)$/\1/g
134 s/^.*\(PARALLEL_PTC - PTC was created. Component reference: \).*\(testcase name:\).*\(, process id:\)\(.*\)$/\1\2\3/g
135 s/^.*\(ERROR_UNQUALIFIED Titan_LogTest.ttcn\)\(.*\)\(Dynamic test case error: Assignment of an unbound integer value\).*/\1 \3/g
136 s/^.*\(TIMEROP_READ Titan_LogTest.ttcn\)\(.*\)/\1/g
137 s/^.*\(USER_UNQUALIFIED Titan_LogTest.ttcn\)\(.*\)/\1/g
138 s/^.*\(PARALLEL_PTC - PTC with component reference\)\(.*\)/\1/g
139 s/^.*\(PARALLEL_PTC - MTC finished.\)\(.*\)//g
140 s/^.*\(EXECUTOR_RUNTIME - Maximum number of open file descriptors\).*//g
143 # TODO: s/^.*\(PARALLEL_PTC - MTC finished.\)\(.*\)/\1/g should be used instead of s/^.*\(PARALLEL_PTC - MTC finished.\)\(.*\)//g
144 # TODO: s/^.*\(EXECUTOR_RUNTIME - Maximum number of open file descriptors\).*//g kiszedese
145 # This line removes the random/seldom line from the log
146 sed -e "$cmd" -e "/^$/d" < "$2" > "$3"
152 # $1: name of the cfg file
153 # $2: name of the merged log file
154 # $3: name of the merged modified log file (timestamps removed)
157 TTCN3_DIR_ORIG
=${TTCN3_DIR}
158 TTCN3_DIR
=${TTCN3_DIR_OLD}
160 PATH
=${TTCN3_DIR}/bin
:${PATH}
161 LD_LIBRARY_PATH_ORIG
=${LD_LIBRARY_PATH}
162 LD_LIBRARY_PATH
=${TTCN3_DIR}/lib
:${LD_LIBRARY_PATH}
163 export TTCN3_DIR PATH LD_LIBRARY_PATH
167 TTCN3_DIR
=${TTCN3_DIR_ORIG}
169 LD_LIBRARY_PATH
=${LD_LIBRARY_PATH_ORIG}
170 export TTCN3_DIR PATH LD_LIBRARY_PATH
175 # $1: name of the cfg file
176 # $2: name of the merged log file
177 # $3: name of the merged modified log file (timestamps removed)
180 echo ">>>>create_log_new args: $1 $2 $3"
181 TTCN3_DIR_ORIG
=${TTCN3_DIR}
182 TTCN3_DIR
=${TTCN3_DIR_NEW}
184 PATH
=${TTCN3_DIR}/bin
:${PATH}
185 LD_LIBRARY_PATH_ORIG
=${LD_LIBRARY_PATH}
186 LD_LIBRARY_PATH
=${TTCN3_DIR}/lib
:${LD_LIBRARY_PATH}
187 export TTCN3_DIR PATH LD_LIBRARY_PATH
191 TTCN3_DIR
=${TTCN3_DIR_ORIG}
193 LD_LIBRARY_PATH
=${LD_LIBRARY_PATH_ORIG}
194 export TTCN3_DIR PATH LD_LIBRARY_PATH
198 # $1: name of the old merged modified log file
199 # $2: name of the new merged modified log file
202 echo "Comparison follows"
205 echo "Comparison result is $result"
209 ####################### EOF FUNCTIONS ###################################
212 while getopts "hoc:O:N:g" o
215 h
) showUsage
; exit 1;;
217 c
) cfg_filename
=$OPTARG;;
218 O
) old_logfilename
=$OPTARG;;
219 N
) new_logfilename
=$OPTARG;;
220 g
) generate_makefile
=1;;
221 [?
]) showUsage
; exit 1;;
227 if [ "${create_old}" == "1" ]
229 echo ">>>CREATES OLD<<<"
230 create_log_old
"${cfg_filename}" "${old_logfilename}.txt" "${old_logfilename}_modified.txt"
232 echo ">>>OLD LOG NOT CREATED<<<"
233 echo ">>>${create_old}<<<"
236 create_log_new
"${cfg_filename}" "${new_logfilename}.txt" "${new_logfilename}_modified.txt"
238 compare
"${old_logfilename}_modified.txt" "${new_logfilename}_modified.txt"