diff -r 9374c207cfee -r 9dcc6e7393f7 doc/api/python/integration.quality-pysrc.html
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/doc/api/python/integration.quality-pysrc.html Fri Sep 11 15:39:31 2009 +0100
@@ -0,0 +1,888 @@
+
+
+
+
+ integration.quality
+
+
+
+
+
+
+
+
+
+
+ 1
+ 2
+ 3
+ 4
+ 5
+ 6
+ 7
+ 8
+ 9
+ 10
+ 11
+ 12
+ 13
+ 14
+ 15
+ 16
+ 17
+ 18
+ 19
+ 20 """
+ 21 Symbian log based analyser.
+ 22
+ 23 * Internal export parser
+ 24 * Duplicate generation parser (relying on abld -what)
+ 25
+ 26 Policy validation.
+ 27 """
+ 28
+ 29 import symbian . log
+ 30 import re
+ 31 import os
+ 32 import sys
+ 33 import csv
+ 34 import fileutils
+ 35 import pathaddition . match
+ 36 import logging
+ 37
+ 38
+ 39 _logger = logging . getLogger ( "integration.quality" )
+ 40
+
42 """ This class extends the Symbian log parser class and implement
+
43 an "abld -what" analyser which detects file generated/exported inside
+
44 the source tree.
+
45 """
+
47 """The constructor """
+
48 symbian . log . Parser . __init__ ( self , _file )
+
49 self . __match_what = re . compile ( "abld(\.bat)?(\s+.*)*\s+-w(hat)?" , re . I )
+
50 self . internalexports = { }
+
51
+
52 - def task ( self , name , _cmd , _dir , content ) :
+
53 """ Analyse task log. """
+
54 if self . __match_what . match ( _cmd ) != None :
+
55 for line in content . splitlines ( ) :
+
56 if line . startswith ( os . path . sep ) \
+
57 and not os . path . normpath ( line . strip ( ) . lower ( ) ) . startswith ( os . path . sep + "epoc32" + os . path . sep ) \
+
58 and os . path . splitext ( line . strip ( ) . lower ( ) ) [ 1 ] != '' :
+
59 if name not in self . internalexports :
+
60 self . internalexports [ name ] = [ ]
+
61 self . internalexports [ name ] . append ( line )
+
62
+ 63
+
65 """ This class extends the Symbian log parser class and implement
+
66 an "abld -what" analyser which sort the generated files by component.
+
67 """
+
69 """The constructor """
+
70 symbian . log . Parser . __init__ ( self , _file )
+
71 self . __match_what = re . compile ( r"abld(\.bat)?(\s+.*)*\s+-w(hat)?" , re . I )
+
72 self . __match_cmaker_what = re . compile ( r"cmaker(\.cmd)?(\s+.*)*\s+ACTION=what" , re . I )
+
73 self . files_per_component = { }
+
74 self . components_per_file = { }
+
75
+
76 - def task ( self , name , _cmd , _dir , content ) :
+
77 """ Analyse task log. """
+
78 if _cmd != None and self . __match_what . match ( _cmd ) != None :
+
79 for line in content . splitlines ( ) :
+
80 line = line . strip ( )
+
81 if not os . path . normpath ( line ) . startswith ( os . path . sep ) :
+
82 continue
+
83
+
84 if line . lower ( ) not in self . components_per_file :
+
85 self . components_per_file [ line . lower ( ) ] = [ ]
+
86 if name not in self . components_per_file [ line . lower ( ) ] :
+
87 self . components_per_file [ line . lower ( ) ] . append ( name )
+
88
+
89
+
90 if name not in self . files_per_component :
+
91 self . files_per_component [ name ] = [ ]
+
92 self . files_per_component [ name ] . append ( line )
+
93 elif _cmd != None and self . __match_cmaker_what . match ( _cmd ) != None :
+
94 for line in content . splitlines ( ) :
+
95 line = line . strip ( )
+
96 if not line . startswith ( '"' ) :
+
97 continue
+
98 if not line . endswith ( '"' ) :
+
99 continue
+
100 line = os . path . normpath ( line . strip ( '"' ) ) . lower ( )
+
101
+
102 if line not in self . components_per_file :
+
103 self . components_per_file [ line ] = [ ]
+
104 if name not in self . components_per_file [ line ] :
+
105 self . components_per_file [ line ] . append ( name )
+
106
+
107
+
108 if name not in self . files_per_component :
+
109 self . files_per_component [ name ] = [ ]
+
110 self . files_per_component [ name ] . append ( line )
+
111
+112
+
114 """ Validate policy files on a hierarchy. """
+
115 - def __init__ ( self , policyfiles = None , csvfile = None , ignoreroot = False ) :
+
116 """The constructor """
+
117 if policyfiles is None :
+
118 policyfiles = [ 'distribution.policy.s60' ]
+
119 self . _policyfiles = policyfiles
+
120 self . _ids = None
+
121 self . _ignoreroot = ignoreroot
+
122
+
124 """ Load the icds from the CSV file.
+
125 report format by generating array: ['unknownstatus', value, description]
+
126 """
+
127 self . _ids = { }
+
128 reader = csv . reader ( open ( csvfile , "rU" ) )
+
129 for row in reader :
+
130 if re . match ( r"^\s*\d+\s*$" , row [ 0 ] ) :
+
131 self . _ids [ row [ 0 ] ] = row
+
132 if row [ 1 ] . lower ( ) != "yes" and row [ 1 ] . lower ( ) != "no" and row [ 1 ] . lower ( ) != "bin" :
+
133 yield [ "unknownstatus" , row [ 0 ] , row [ 2 ] ]
+
134
+
135 - def validate_content ( self , filename ) :
+
136 """ Validating the policy file content. If it cannot be decoded,
+
137 it reports an 'invalidencoding'.
+
138 Case 'notinidlist': value is not defined under the id list.
+
139 """
+
140 value = None
+
141 try :
+
142 value = fileutils . read_policy_content ( filename )
+
143 except Exception :
+
144 yield [ "invalidencoding" , filename , None ]
+
145 if value is not None :
+
146 if self . _ids != None :
+
147 if value not in self . _ids :
+
148 yield [ "notinidlist" , filename , value ]
+
149
+
151 """ find the policy file under path using filenames under the list. """
+
152 for filename in self . _policyfiles :
+
153 if sys . platform != 'win32' :
+
154 for f in os . listdir ( path ) :
+
155 if f . lower ( ) == filename . lower ( ) :
+
156 return os . path . join ( path , f )
+
157 if os . path . exists ( os . path . join ( path , filename ) ) :
+
158 return os . path . join ( path , filename )
+
159 return None
+
160
+
162 """ Return a list couple [errortype, location, policy].
+
163 errortype: missing, invalidencoding, notinidlist .
+
164 missing: location is a directory.
+
165 otherwise the doggie policy file.
+
166 """
+
167 path = os . path . normpath ( path )
+
168 for dirpath , _ , _ in os . walk ( path ) :
+
169
+
170 if dirpath == path and self . _ignoreroot :
+
171 continue
+
172
+
173 if pathaddition . match . ant_match ( dirpath , "**/.svn/**" ) :
+
174 continue
+
175
+
176 if pathaddition . match . ant_match ( dirpath , "**/j2me/**" ) :
+
177 continue
+
178 filename = self . find_policy ( dirpath )
+
179 if filename != None :
+
180 for result in self . validate_content ( filename ) :
+
181 yield result
+
182 else :
+
183 yield [ 'missing' , dirpath , None ]
+
184
+
+
+
+
+
+
+
+
+
+