--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/buildframework/helium/tools/logging/logging.ant.xml Thu Mar 18 15:06:42 2010 +0000
@@ -0,0 +1,443 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+============================================================================
+Name : logging.ant.xml
+Part of : Helium
+
+Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+All rights reserved.
+This component and the accompanying materials are made available
+under the terms of the License "Eclipse Public License v1.0"
+which accompanies this distribution, and is available
+at the URL "http://www.eclipse.org/legal/epl-v10.html".
+
+Initial Contributors:
+Nokia Corporation - initial contribution.
+
+Contributors:
+
+Description:
+
+============================================================================
+-->
+<!--* @package framework -->
+<project name="logging" xmlns:hlm="http://www.nokia.com/helium">
+ <description>
+ Targets related to log parsing, rendaring, upload to diamonds etc.
+ </description>
+
+
+ <!-- This is where the preparation build logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="prep.log.dir" location="${build.log.dir}/prep"/>
+ <!-- This is where the compile logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="compile.log.dir" location="${build.log.dir}/compile"/>
+ <!-- This is where the ats test logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="test.log.dir" location="${build.log.dir}/test"/>
+ <!-- This is where the archive logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="archive.log.dir" location="${build.log.dir}/archive"/>
+ <!-- This is where the roms logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="roms.log.dir" location="${build.log.dir}/roms"/>
+ <!-- This is where the post build logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="post.log.dir" location="${build.log.dir}/post"/>
+ <!-- This is where the localisation logs are stored.
+ @type string
+ @scope private
+ -->
+ <property name="localisation.log.dir" location="${build.log.dir}/localisation"/>
+
+
+ <!-- Macro to record content to a separate log file without recording in the main log. -->
+ <macrodef name="recordStartMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <attribute name="emacsmode" default="false"/>
+ <sequential>
+ <if>
+ <available file="${build.log.dir}" type="dir"/>
+ <then>
+ <hlm:record name="${build.log.dir}/@{name}" action="start" append="true" emacsmode="@{emacsmode}" loglevel="${ant.loglevel}"/>
+ </then>
+ </if>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Macro to stop recording content to a separate log file without recording in the main log. -->
+ <macrodef name="recordStopMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <sequential>
+ <if>
+ <available file="${build.log.dir}/@{name}"/>
+ <then>
+ <hlm:record name="${build.log.dir}/@{name}" action="stop" append="true"/>
+ </then>
+ </if>
+ </sequential>
+ </macrodef>
+
+
+ <!--Macro to stop recording to the main log file (if present) and record to
+ a separate log file that is filtered after logging is stopped. -->
+ <macrodef name="filterRecordStartMacro" uri="http://www.nokia.com/helium">
+ <attribute name="pattern" default=""/>
+ <attribute name="category" default=""/>
+ <sequential>
+ <hlm:record name="${build.cache.log.dir}/temp_ant_build.log" action="start" loglevel="${ant.loglevel}">
+ <hlm:recordfilter category="@{category}" regexp="@{pattern}" />
+ </hlm:record>
+ </sequential>
+ </macrodef>
+
+
+ <!--Macro to stop recording the seperate filtered log file, filter the passwords
+ and start recording in main log file -->
+ <macrodef name="filterRecordStopMacro" uri="http://www.nokia.com/helium">
+ <attribute name="log" default="${build.log}"/>
+ <attribute name="append" default="true"/>
+ <sequential>
+ <hlm:record name="${build.cache.log.dir}/temp_ant_build.log" action="stop"/>
+ <concat destfile="@{log}" append="@{append}">
+ <filelist dir="${build.cache.log.dir}" files="temp_ant_build.log"/>
+ </concat>
+ <delete file="${build.cache.log.dir}/temp_ant_build.log" failonerror="false"/>
+ <echo>End of filtering @{log} for passwords</echo>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Extract logs from text file and process error/warnings/components name etc
+ into xml file.
+ @deprecated Please consider using the metadata framework.
+ -->
+ <scriptdef name="logextract" language="jython" uri="http://www.nokia.com/helium">
+ <attribute name="file" />
+ <attribute name="outputfile" />
+ <element name="fileset" type="fileset"/>
+ <element name="logfilterset" classname="com.nokia.ant.types.LogFilterSet"/>
+ <![CDATA[
+import os.path
+import log2xml
+import java.io
+
+def convertFile(inputfile, outputfile, config):
+ if (outputfile != None):
+ print "output file not none"
+ print "output file: %s" % outputfile
+ targetfile = str(outputfile)
+ else:
+ #print "output file: %s" % outputfile
+ targetfile = "%s.xml" % inputfile
+ #print "targetFile %s" % targetfile
+ if not os.path.exists(targetfile) or \
+ (os.path.exists(targetfile) and os.path.getmtime(inputfile) > os.path.getmtime(targetfile)):
+ self.getProject().log("Converting %s..." % inputfile)
+ log2xml.convert(inputfile, targetfile, False, config)
+ else:
+ self.getProject().log("Extracted log is uptodate: %s" % inputfile)
+
+config = log2xml.DEFAULT_CONFIGURATION
+logfilterset = elements.get("logfilterset")
+if logfilterset != None and logfilterset.size() > 0:
+ # if any logfilterset are dfined then
+ # it override the default configuration
+ config = {}
+ for filtersetid in range(logfilterset.size()):
+ filterset = logfilterset.get(filtersetid)
+ if filterset.isReference():
+ filterset = filterset.getRefid().getReferencedObject(project)
+ filters = filterset.getFilters()
+ for filterid in range(filters.size()):
+ if not filters.get(filterid).getCategory() in config:
+ config[filters.get(filterid).getCategory()] = []
+ config[filters.get(filterid).getCategory()].append(str(filters.get(filterid).getRegex()))
+
+fileset = elements.get("fileset")
+outputfile = attributes.get("outputfile")
+if fileset != None and fileset.size() > 0:
+ for filesetid in range(fileset.size()):
+ dirscanner = fileset.get(filesetid).getDirectoryScanner(project)
+ for filename in dirscanner.getIncludedFiles():
+ inputfile = str(java.io.File(dirscanner.getBasedir(), str(filename)).getAbsolutePath())
+ convertFile(inputfile, outputfile, config)
+elif attributes.get("file") != None:
+ inputfile = str(java.io.File(str(attributes.get("file"))).getAbsolutePath())
+ convertFile(inputfile, outputfile, config)
+else:
+ self.log("No input specified.")
+ ]]>
+ </scriptdef>
+
+
+ <!--Macro to stop recording to the main log file (if present) and record to
+ a separate log file into a temporary location (doesn't need the build aread to work). -->
+ <macrodef name="tempRecordStartMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <sequential>
+ <mkdir dir="${build.cache.log.dir}"/>
+ <hlm:record name="${build.cache.log.dir}/@{name}" action="start" loglevel="${ant.loglevel}"/>
+ </sequential>
+ </macrodef>
+
+
+ <!--Macro to restart the main log file (if present) and stop recording to
+ a separate log file into a temporary location the file is next xml summarized
+ and potentially copied to the build area (if exists). Else those files will get copied during the
+ build area preparation. -->
+ <macrodef name="tempRecordStopMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <attribute name="phase" default=""/>
+ <attribute name="database" default="${metadata.dbfile}"/>
+ <attribute name="filterref" default="filterset.temprecord"/>
+ <sequential>
+ <mkdir dir="${build.cache.log.dir}"/>
+ <mkdir dir="${build.log.dir}"/>
+ <mkdir dir="${build.cache.log.dir}/signals"/>
+ <hlm:record name="${build.cache.log.dir}/@{name}" action="stop" loglevel="${ant.loglevel}"/>
+ <!--Temporary solution, the logextract in general
+ needs to be handled in a better way (not all logs needs to be processed,
+ logextract / counting errors could be merged and logextract should be
+ executed on a need basis and not to process for all stopmacro.-->
+ <!-- Todo: metadata: replace logextract -->
+ <hlm:metadatarecord database="@{database}">
+ <hlm:antmetadatainput>
+ <fileset casesensitive="false" file="${build.cache.log.dir}/@{name}" />
+ <metadatafilterset refid="@{filterref}" />
+ </hlm:antmetadatainput>
+ </hlm:metadatarecord>
+ <hlm:generateBuildStatus dbfile="@{database}" output-dir="${build.cache.log.dir}/signals" file="@{name}" />
+ <if>
+ <isset property="@{phase}.log.dir" />
+ <then>
+ <mkdir dir="${@{phase}.log.dir}"/>
+ <copy todir="${@{phase}.log.dir}" failonerror="false">
+ <fileset casesensitive="false" file="${build.cache.log.dir}/@{name}" />
+ </copy>
+ </then>
+ <else>
+ <copy todir="${build.log.dir}" failonerror="false">
+ <fileset casesensitive="false" file="${build.cache.log.dir}/@{name}" />
+ </copy>
+ </else>
+ </if>
+ <copy todir="${build.signal.status.dir}" failonerror="false">
+ <fileset casesensitive="false" dir="${build.cache.log.dir}/signals" />
+ </copy>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Macro to start logging to a separate log file.
+
+ This will stop logging to the main ant_build log file until stopSpecificLogMacro
+ is called. -->
+ <macrodef name="startSpecificLogMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <attribute name="regexp" default=""/>
+ <attribute name="backup" default="false"/>
+ <attribute name="phase" default=""/>
+
+ <sequential>
+ <if>
+ <isset property="@{phase}.log.dir" />
+ <then>
+ <mkdir dir="${@{phase}.log.dir}"/>
+ </then>
+ </if>
+ <mkdir dir="@{name}/.."/>
+ <hlm:record name="@{name}" action="start" loglevel="verbose" backup="@{backup}" backupProperty="backup.file.name">
+ <hlm:recordfilter category="@{phase}" regexp="@{regexp}" />
+ </hlm:record>
+ </sequential>
+ </macrodef>
+
+
+ <!--Macro to restart the main log file (if present) and stop recording to
+ a separate log file. -->
+ <macrodef name="stopSpecificLogMacro" uri="http://www.nokia.com/helium">
+ <attribute name="name"/>
+ <attribute name="phase" default=""/>
+ <sequential>
+ <hlm:record name="@{name}" action="stop" loglevel="verbose"/>
+ </sequential>
+ </macrodef>
+
+ <!-- Temp BMD macro -->
+ <macrodef name="bmdLogExtractMacro" uri="http://www.nokia.com/helium">
+ <attribute name="log"/>
+ <attribute name="metadatafilterset" default="common"/>
+ <sequential>
+ <hlm:metadatarecord database="${metadata.dbfile}">
+ <hlm:textmetadatainput>
+ <fileset casesensitive="false" file="@{log}"/>
+ <metadatafilterset refid="@{metadatafilterset}" />
+ </hlm:textmetadatainput>
+ </hlm:metadatarecord>
+ <!-- todo: check to add for usage and add genbuildstatus macro -->
+ <basename property="log.name" file="@{log}"/>
+ <fmpp sourceFile="${helium.dir}/tools/common/templates/db2xml.xml.ftl"
+ outputfile="@{log}.xml">
+ <data expandProperties="yes">
+ dbPath: ${metadata.dbfile}
+ log: ${log.name}
+ ant: antProperties()
+ </data>
+ </fmpp>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Merges all XML log files ending in ".log2.xml" in the build log directory
+ into a single summary log file. -->
+ <target name="log-merge" unless="metadata.enable">
+ <mkdir dir="${build.log.dir}"/>
+ <dependset>
+ <srcfileset dir="${build.log.dir}" includes="**/${build.id}*.log.xml"/>
+ <targetfileset file="${build.summary.file}"/>
+ </dependset>
+ <if>
+ <not>
+ <available file="${build.summary.file}"/>
+ </not>
+ <then>
+ <echo>Merging all *.log.xml files</echo>
+ <mkdir dir="${build.log.dir}/summary"/>
+ <xmltask dest="${build.summary.file}">
+ <insert path="/" >
+ <![CDATA[
+ <logSummary/>
+ ]]>
+ </insert>
+ </xmltask>
+ <for param="file">
+ <path>
+ <fileset dir="${build.log.dir}">
+ <include name="**/${build.id}*.log.xml"/>
+ </fileset>
+ <fileset dir="${temp.build.dir}">
+ <include name="**/${build.id}*.log.xml"/>
+ </fileset>
+ </path>
+ <sequential>
+ <echo>Inserting @{file} into summary.</echo>
+ <!--<xmltask source="${build.summary.file}"
+ dest="${build.summary.file}">
+ <insert path="/logSummary" file="@{file}" />
+ </xmltask>-->
+ <hlm:assertPropertySet property="build.summary.file" message="Property build.summary.file is not defined." />
+ <script language="jython" setbeans="false">
+# Temporary solution
+import log2xml
+log2xml.append_summary(project.getProperty('build.summary.file'), r'@{file}')
+ </script>
+ </sequential>
+ </for>
+ </then>
+ <else>
+ <echo>Summary XML log file does not need updating.</echo>
+ </else>
+ </if>
+ </target>
+
+
+ <!-- Outputs an HTML readable version of the summary log. -->
+ <target name="render-log-summary">
+ <if>
+ <and>
+ <available file="${build.log.dir}/${build.id}_info.log.xml"/>
+ <available file="${metadata.dbfile}"/>
+ </and>
+ <then>
+ <fmpp sourceFile="${helium.dir}/tools/common/templates/log/summary_metadata_orm.html.ftl"
+ outputfile="${build.log.dir}/${build.id}_summary.html">
+ <freemarkerLinks expandProperties="yes">
+ macro: ${helium.dir}/tools/common/templates/macro
+ </freemarkerLinks>
+ <data expandProperties="yes">
+ dbPath: ${metadata.dbfile}
+ loginfo: xml(${build.log.dir}/${build.id}_info.log.xml)
+ ant: antProperties()
+ </data>
+ </fmpp>
+ <if>
+ <not>
+ <available file="${build.log.dir}/${build.id}_summary.html"/>
+ </not>
+ <then>
+ <echo message="Error: failed to generate Summary file" />
+ </then>
+ </if>
+ </then>
+ </if>
+ </target>
+
+ <!-- Prepare email for build summary -->
+ <target name="logger-email" depends="log-merge">
+ <fmpp sourceRoot="${helium.dir}/tools/common/templates/log" includes="email.html.ftl" outputRoot="${build.log.dir}/summary"
+ replaceExtension="html.ftl, html">
+ <data expandProperties="yes">
+ doc: xml(${build.summary.file})
+ ant: antProperties()
+ </data>
+ </fmpp>
+ </target>
+
+
+ <!-- Test target to show how Diamond metadata could be rendered. -->
+ <target name="render-diamonds-data" depends="log-merge">
+ <mkdir dir="${build.log.dir}/summary/diamonds"/>
+ <fmpp sourceRoot="${helium.dir}/tools/common/templates/diamonds"
+ outputRoot="${build.log.dir}/summary/diamonds" includes="diamonds.xml.ftl"
+ replaceExtension="xml.ftl, xml">
+ <data expandProperties="yes">
+ doc: xml(${build.summary.file})
+ ant: antProperties()
+ </data>
+ </fmpp>
+ </target>
+
+
+ <!-- Render the CC dashboad summary. -->
+ <target name="render-cc-summary" depends="log-merge">
+ <mkdir dir="${build.log.dir}/summary"/>
+ <fmpp sourceFile="${helium.dir}/tools/common/templates/log/cc_summary_metadata_orm.html.ftl"
+ outputfile="${build.log.dir}/summary/${build.id}_cc_summary.html">
+ <data expandProperties="yes">
+ dbPath: ${metadata.dbfile}
+ ant: antProperties()
+ </data>
+ </fmpp>
+ </target>
+
+
+ <!-- Creates a full summary log from all the build logs. -->
+ <target name="build-log-summary" depends="render-log-summary"/>
+
+ <!-- Test target to check signal. -->
+ <target name="check-signal" />
+
+ <!-- Starting the main ant_build log -->
+ <target name="start-ant-log" >
+ <hlm:triggerlogger/>
+ </target>
+
+
+
+
+</project>
\ No newline at end of file