xref: /AOO41X/main/qadevOOo/runner/convwatch/ConvWatch.java (revision ef39d40d3f5e66cf3f035b3e93783012b340500d)
1*ef39d40dSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*ef39d40dSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*ef39d40dSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*ef39d40dSAndrew Rist  * distributed with this work for additional information
6*ef39d40dSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*ef39d40dSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*ef39d40dSAndrew Rist  * "License"); you may not use this file except in compliance
9*ef39d40dSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*ef39d40dSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*ef39d40dSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*ef39d40dSAndrew Rist  * software distributed under the License is distributed on an
15*ef39d40dSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*ef39d40dSAndrew Rist  * KIND, either express or implied.  See the License for the
17*ef39d40dSAndrew Rist  * specific language governing permissions and limitations
18*ef39d40dSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*ef39d40dSAndrew Rist  *************************************************************/
21*ef39d40dSAndrew Rist 
22*ef39d40dSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir package convwatch;
25cdf0e10cSrcweir 
26cdf0e10cSrcweir import convwatch.ConvWatchException;
27cdf0e10cSrcweir import convwatch.ConvWatchCancelException;
28cdf0e10cSrcweir import convwatch.FileHelper;
29cdf0e10cSrcweir import convwatch.OfficePrint;
30cdf0e10cSrcweir import convwatch.PRNCompare;
31cdf0e10cSrcweir import convwatch.StatusHelper;
32cdf0e10cSrcweir import helper.URLHelper;
33cdf0e10cSrcweir import java.io.File;
34cdf0e10cSrcweir 
35cdf0e10cSrcweir public class ConvWatch
36cdf0e10cSrcweir {
37cdf0e10cSrcweir 
getBuildID_FromFile(String _sInfoFile)38cdf0e10cSrcweir     String getBuildID_FromFile(String _sInfoFile)
39cdf0e10cSrcweir     {
40cdf0e10cSrcweir         String sBuildID = "";
41cdf0e10cSrcweir         IniFile aIniFile = new IniFile(_sInfoFile);
42cdf0e10cSrcweir         if (aIniFile.is())
43cdf0e10cSrcweir         {
44cdf0e10cSrcweir             sBuildID = aIniFile.getValue("", "buildid");
45cdf0e10cSrcweir         }
46cdf0e10cSrcweir         return sBuildID;
47cdf0e10cSrcweir     }
48cdf0e10cSrcweir     /**
49cdf0e10cSrcweir      * Check if given document (_sAbsoluteInputFile) and it's postscript representation (_sAbsoluteReferenceFile) produce
50cdf0e10cSrcweir      * the same output like the StarOffice / OpenOffice.org which is accessable with XMultiServiceFactory.
51cdf0e10cSrcweir      * Here a simple graphically difference check is run through.
52cdf0e10cSrcweir      *
53cdf0e10cSrcweir      * Hint: In the OutputPath all needed files will create, there must
54cdf0e10cSrcweir      * be very much space. It's not possible to say how much.
55cdf0e10cSrcweir      * One page need up to 800kb as jpeg.
56cdf0e10cSrcweir      * Sample: If a document contains 2 pages, we need 2*800kb for prn
57cdf0e10cSrcweir      * output and 2*800kb for ps output and 2*800kb for it's difference
58cdf0e10cSrcweir      * output. So up to 4800kb or 4.8mb.
59cdf0e10cSrcweir      *
60cdf0e10cSrcweir      * RAM is need least 300mb. Will say, it's tested on a pc with 128mb RAM and 256mb swap.
61cdf0e10cSrcweir      *
62cdf0e10cSrcweir      * It's also absolutlly impossible to say, how much time this functions consume.
63cdf0e10cSrcweir      */
64cdf0e10cSrcweir 
createPostscriptStartCheck(GraphicalTestArguments _aGTA, String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile)65cdf0e10cSrcweir     StatusHelper[] createPostscriptStartCheck(GraphicalTestArguments _aGTA,
66cdf0e10cSrcweir                                               String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile)
67cdf0e10cSrcweir         throws ConvWatchCancelException
68cdf0e10cSrcweir         {
69cdf0e10cSrcweir //  TODO: some more checks
70cdf0e10cSrcweir 
71cdf0e10cSrcweir             if (! FileHelper.exists(_sAbsoluteInputFile))
72cdf0e10cSrcweir             {
73cdf0e10cSrcweir                 throw new ConvWatchCancelException("createPostscriptStartCheck: Input file: " + _sAbsoluteInputFile + " does not exist.");
74cdf0e10cSrcweir             }
75cdf0e10cSrcweir 
76cdf0e10cSrcweir             if (_sAbsoluteReferenceFile == null)
77cdf0e10cSrcweir             {
78cdf0e10cSrcweir                 // we assume, that the prn file is near the document
79cdf0e10cSrcweir                 String sAbsoluteInputFileNoSuffix = FileHelper.getNameNoSuffix(_sAbsoluteInputFile);
80cdf0e10cSrcweir                 _sAbsoluteReferenceFile = sAbsoluteInputFileNoSuffix + ".prn";
81cdf0e10cSrcweir             }
82cdf0e10cSrcweir 
83cdf0e10cSrcweir             String fs = System.getProperty("file.separator");
84cdf0e10cSrcweir             File aAbsoluteReferenceFile = new File(_sAbsoluteReferenceFile);
85cdf0e10cSrcweir 
86cdf0e10cSrcweir             if (aAbsoluteReferenceFile.isDirectory())
87cdf0e10cSrcweir             {
88cdf0e10cSrcweir                 String sBasename = FileHelper.getBasename(_sAbsoluteInputFile);
89cdf0e10cSrcweir                 String sNameNoSuffix = FileHelper.getNameNoSuffix(sBasename);
90cdf0e10cSrcweir                 String sAbsoluteReferenceFileInfo = _sAbsoluteReferenceFile + fs + sNameNoSuffix + ".info";
91cdf0e10cSrcweir                 _sAbsoluteReferenceFile = _sAbsoluteReferenceFile + fs + sNameNoSuffix + ".prn";
92cdf0e10cSrcweir 
93cdf0e10cSrcweir                 // Read the reference from the info file
94cdf0e10cSrcweir                 String sRefBuildID = "";
95cdf0e10cSrcweir                 if (FileHelper.exists(sAbsoluteReferenceFileInfo))
96cdf0e10cSrcweir                 {
97cdf0e10cSrcweir                     sRefBuildID = getBuildID_FromFile(sAbsoluteReferenceFileInfo);
98cdf0e10cSrcweir                 }
99cdf0e10cSrcweir                 _aGTA.setRefBuildID(sRefBuildID);
100cdf0e10cSrcweir 
101cdf0e10cSrcweir             }
102cdf0e10cSrcweir             else
103cdf0e10cSrcweir             {
104cdf0e10cSrcweir                 // java file has problems to check for directories, if the given directory doesn't exist.
105cdf0e10cSrcweir                 String sName = FileHelper.getBasename(_sAbsoluteReferenceFile);
106cdf0e10cSrcweir                 // thanks to Mircosoft, every document has a suffix, so if a name doesn't have a suffix, it must be a directory name
107cdf0e10cSrcweir                 int nIdx = sName.indexOf('.');
108cdf0e10cSrcweir                 if (nIdx == -1)
109cdf0e10cSrcweir                 {
110cdf0e10cSrcweir                     // must be a directory
111cdf0e10cSrcweir                     throw new ConvWatchCancelException("createPostscriptStartCheck: Given reference directory: '" + _sAbsoluteReferenceFile + "' does not exist.");
112cdf0e10cSrcweir                 }
113cdf0e10cSrcweir             }
114cdf0e10cSrcweir 
115cdf0e10cSrcweir 
116cdf0e10cSrcweir             boolean bAbsoluteReferenceFile = true;
117cdf0e10cSrcweir             if (! FileHelper.exists(_sAbsoluteReferenceFile))
118cdf0e10cSrcweir             {
119cdf0e10cSrcweir                 if (_aGTA.createDefaultReference())
120cdf0e10cSrcweir                 {
121cdf0e10cSrcweir                     GlobalLogWriter.get().println("Reference File doesn't exist, will create a default");
122cdf0e10cSrcweir                     bAbsoluteReferenceFile = false;
123cdf0e10cSrcweir                 }
124cdf0e10cSrcweir                 else
125cdf0e10cSrcweir                 {
126cdf0e10cSrcweir                     throw new ConvWatchCancelException("createPostscriptStartCheck: Given reference file: " + _sAbsoluteReferenceFile + " does not exist.");
127cdf0e10cSrcweir                 }
128cdf0e10cSrcweir             }
129cdf0e10cSrcweir 
130cdf0e10cSrcweir             FileHelper.makeDirectories("", _sOutputPath);
131cdf0e10cSrcweir 
132cdf0e10cSrcweir             // runner.convwatch.compare();
133cdf0e10cSrcweir 
134cdf0e10cSrcweir             String sAbsoluteInputFileURL = URLHelper.getFileURLFromSystemPath(_sAbsoluteInputFile);
135cdf0e10cSrcweir 
136cdf0e10cSrcweir             String sInputFile = FileHelper.getBasename(_sAbsoluteInputFile);
137cdf0e10cSrcweir             // System.out.println("InputFile: " + sInputFile);
138cdf0e10cSrcweir 
139cdf0e10cSrcweir             String sInputFileNoSuffix = FileHelper.getNameNoSuffix(sInputFile);
140cdf0e10cSrcweir             // System.out.println("BasenameNoSuffix: " + sInputFileNoSuffix);
141cdf0e10cSrcweir 
142cdf0e10cSrcweir 
143cdf0e10cSrcweir             String sAbsoluteOutputFile = _sOutputPath + fs + sInputFile;
144cdf0e10cSrcweir             String sAbsoluteOutputFileURL = URLHelper.getFileURLFromSystemPath(sAbsoluteOutputFile);
145cdf0e10cSrcweir 
146cdf0e10cSrcweir             String sReferenceFile = FileHelper.getBasename(_sAbsoluteReferenceFile);
147cdf0e10cSrcweir             String sReferenceFileNoSuffix = FileHelper.getNameNoSuffix(sReferenceFile);
148cdf0e10cSrcweir             String sPostScriptFile = sReferenceFileNoSuffix + ".ps";
149cdf0e10cSrcweir             // System.out.println("PostscriptFile: " + sPostScriptFile);
150cdf0e10cSrcweir 
151cdf0e10cSrcweir             String sAbsolutePrintFile = _sOutputPath + fs + sPostScriptFile;
152cdf0e10cSrcweir             String sAbsolutePrintFileURL = URLHelper.getFileURLFromSystemPath(sAbsolutePrintFile);
153cdf0e10cSrcweir 
154cdf0e10cSrcweir             // System.out.println("AbsoluteInputFileURL: " + sAbsoluteInputFileURL);
155cdf0e10cSrcweir             // System.out.println("AbsoluteOutputFileURL: " + sAbsoluteOutputFileURL);
156cdf0e10cSrcweir             // System.out.println("AbsolutePrintFileURL: " + sAbsolutePrintFileURL);
157cdf0e10cSrcweir 
158cdf0e10cSrcweir             // store and print the sAbsoluteInputFileURL file with StarOffice / OpenOffice.org
159cdf0e10cSrcweir             OfficePrint.printToFile(_aGTA, sAbsoluteInputFileURL, sAbsoluteOutputFileURL, sAbsolutePrintFileURL);
160cdf0e10cSrcweir 
161cdf0e10cSrcweir             // wait(2);
162cdf0e10cSrcweir 
163cdf0e10cSrcweir             if (! FileHelper.exists(sAbsolutePrintFile))
164cdf0e10cSrcweir             {
165cdf0e10cSrcweir                 throw new ConvWatchCancelException("createPostscriptStartCheck: Printed file " + sAbsolutePrintFile + " does not exist.");
166cdf0e10cSrcweir             }
167cdf0e10cSrcweir 
168cdf0e10cSrcweir             if (bAbsoluteReferenceFile == false)
169cdf0e10cSrcweir             {
170cdf0e10cSrcweir                 // copy AbsolutePrintFile to AbsoluteReferenceFile
171cdf0e10cSrcweir                 String sDestinationFile = sAbsolutePrintFile; // URLHelper.getSystemPathFromFileURL(...)
172cdf0e10cSrcweir                 String sSourceFile = _sAbsoluteReferenceFile;
173cdf0e10cSrcweir                 FileHelper.copy(sDestinationFile, sSourceFile);
174cdf0e10cSrcweir                 // now the fix reference of the AbsoluteReferenceFile should exist.
175cdf0e10cSrcweir                 if (! FileHelper.exists(_sAbsoluteReferenceFile))
176cdf0e10cSrcweir                 {
177cdf0e10cSrcweir                     throw new ConvWatchCancelException("createPostscriptStartCheck: Given reference file: " + _sAbsoluteReferenceFile + " does not exist, after try to copy.");
178cdf0e10cSrcweir                 }
179cdf0e10cSrcweir             }
180cdf0e10cSrcweir 
181cdf0e10cSrcweir             PRNCompare a = new PRNCompare();
182cdf0e10cSrcweir             String sInputPath = FileHelper.getPath(_sAbsoluteInputFile);
183cdf0e10cSrcweir             String sReferencePath = FileHelper.getPath(_sAbsoluteReferenceFile);
184cdf0e10cSrcweir             // String sReferenceFile = FileHelper.getBasename(sAbsoluteReferenceFile);
185cdf0e10cSrcweir 
186cdf0e10cSrcweir             // System.out.println("InputPath: " + sInputPath);
187cdf0e10cSrcweir             // System.out.println("sReferencePath: " + sReferencePath);
188cdf0e10cSrcweir             // System.out.println("sReferenceFile: " + sReferenceFile);
189cdf0e10cSrcweir 
190cdf0e10cSrcweir             a.setInputPath(     sInputPath );
191cdf0e10cSrcweir             a.setReferencePath( sReferencePath );
192cdf0e10cSrcweir             a.setOutputPath(    _sOutputPath );
193cdf0e10cSrcweir             // a.setDocFile(       "1_Gov.ppt");
194cdf0e10cSrcweir             a.setReferenceFile( sReferenceFile );
195cdf0e10cSrcweir             a.setPostScriptFile(sPostScriptFile );
196cdf0e10cSrcweir             if (_aGTA.printAllPages() == true)
197cdf0e10cSrcweir             {
198cdf0e10cSrcweir                 a.setMaxPages(9999);
199cdf0e10cSrcweir             }
200cdf0e10cSrcweir             else
201cdf0e10cSrcweir             {
202cdf0e10cSrcweir                 if (_aGTA.getMaxPages() > 0)
203cdf0e10cSrcweir                 {
204cdf0e10cSrcweir                     a.setMaxPages(_aGTA.getMaxPages());
205cdf0e10cSrcweir                 }
206cdf0e10cSrcweir                 if (_aGTA.getOnlyPages().length() != 0)
207cdf0e10cSrcweir                 {
208cdf0e10cSrcweir                     // we can't interpret the string of getOnlyPages() right without much logic, so print all pages here!
209cdf0e10cSrcweir                     a.setMaxPages(9999);
210cdf0e10cSrcweir                 }
211cdf0e10cSrcweir             }
212cdf0e10cSrcweir 
213cdf0e10cSrcweir             a.setResolutionInDPI(_aGTA.getResolutionInDPI());
214cdf0e10cSrcweir             a.setBorderMove(_aGTA.getBorderMove());
215cdf0e10cSrcweir             a.setDocumentType(_aGTA.getDocumentType());
216cdf0e10cSrcweir 
217cdf0e10cSrcweir             StatusHelper[] aList = a.compare();
218cdf0e10cSrcweir 
219cdf0e10cSrcweir             _aGTA.setBorderMove(a.getBorderMove());
220cdf0e10cSrcweir             return aList;
221cdf0e10cSrcweir         }
222cdf0e10cSrcweir 
223cdf0e10cSrcweir     // -----------------------------------------------------------------------------
224cdf0e10cSrcweir     // This creates a status for exact on document
createINIStatus(StatusHelper[] aList, String _sFilenamePrefix, String _sOutputPath, String _sAbsoluteInputFile, String _sBuildID, String _sRefBuildID)225cdf0e10cSrcweir     static boolean createINIStatus(StatusHelper[] aList, String _sFilenamePrefix, String _sOutputPath, String _sAbsoluteInputFile, String _sBuildID, String _sRefBuildID)
226cdf0e10cSrcweir         {
227cdf0e10cSrcweir             // Status
228cdf0e10cSrcweir             String fs = System.getProperty("file.separator");
229cdf0e10cSrcweir             String sBasename = FileHelper.getBasename(_sAbsoluteInputFile);
230cdf0e10cSrcweir             String sNameNoSuffix = FileHelper.getNameNoSuffix(sBasename);
231cdf0e10cSrcweir //            String sHTMLFile = _sFilenamePrefix + sNameNoSuffix + ".html";
232cdf0e10cSrcweir //            HTMLOutputter HTMLoutput = HTMLOutputter.create(_sOutputPath, sHTMLFile, "", "");
233cdf0e10cSrcweir //            HTMLoutput.header(sNameNoSuffix);
234cdf0e10cSrcweir //  TODO: version info was fine
235cdf0e10cSrcweir //            HTMLoutput.checkSection(sBasename);
236cdf0e10cSrcweir             // Status end
237cdf0e10cSrcweir 
238cdf0e10cSrcweir             String sINIFile = _sFilenamePrefix + sNameNoSuffix + ".ini";
239cdf0e10cSrcweir             INIOutputter INIoutput = INIOutputter.create(_sOutputPath, sINIFile, "", "");
240cdf0e10cSrcweir             INIoutput.createHeader();
241cdf0e10cSrcweir //  TODO: version info was fine
242cdf0e10cSrcweir 
243cdf0e10cSrcweir             INIoutput.writeSection("global");
244cdf0e10cSrcweir             INIoutput.writeValue("pages", String.valueOf(aList.length));
245cdf0e10cSrcweir             INIoutput.writeValue("buildid", _sBuildID);
246cdf0e10cSrcweir             INIoutput.writeValue("refbuildid", _sRefBuildID);
247cdf0e10cSrcweir             INIoutput.writeValue("diffdiff", "no");
248cdf0e10cSrcweir             INIoutput.writeValue("basename", sBasename);
249cdf0e10cSrcweir 
250cdf0e10cSrcweir             boolean bResultIsOk = true;          // result over all pages
251cdf0e10cSrcweir             for (int i=0;i<aList.length; i++)
252cdf0e10cSrcweir             {
253cdf0e10cSrcweir                 INIoutput.writeSection("page" + String.valueOf(i + 1));   // list start at point 0, but this is page 1 and so on... current_page = (i + 1)
254cdf0e10cSrcweir                 aList[i].printStatus();
255cdf0e10cSrcweir 
256cdf0e10cSrcweir                 boolean bCurrentResult = true;   // result over exact one page
257cdf0e10cSrcweir 
258cdf0e10cSrcweir                 int nCurrentDiffStatus = aList[i].nDiffStatus;
259cdf0e10cSrcweir 
260cdf0e10cSrcweir                 // check if the status is in a defined range
261cdf0e10cSrcweir                 if (nCurrentDiffStatus == StatusHelper.DIFF_NO_DIFFERENCES)
262cdf0e10cSrcweir                 {
263cdf0e10cSrcweir                     // ok.
264cdf0e10cSrcweir                 }
265cdf0e10cSrcweir                 else if (nCurrentDiffStatus == StatusHelper.DIFF_DIFFERENCES_FOUND && aList[i].nPercent < 5)
266cdf0e10cSrcweir                 {
267cdf0e10cSrcweir                     // ok.
268cdf0e10cSrcweir                 }
269cdf0e10cSrcweir                 else if (nCurrentDiffStatus == StatusHelper.DIFF_AFTER_MOVE_DONE_NO_PROBLEMS)
270cdf0e10cSrcweir                 {
271cdf0e10cSrcweir                     // ok.
272cdf0e10cSrcweir                 }
273cdf0e10cSrcweir                 else if (nCurrentDiffStatus == StatusHelper.DIFF_AFTER_MOVE_DONE_DIFFERENCES_FOUND && aList[i].nPercent2 < 5)
274cdf0e10cSrcweir                 {
275cdf0e10cSrcweir                     // ok.
276cdf0e10cSrcweir                 }
277cdf0e10cSrcweir                 else
278cdf0e10cSrcweir                 {
279cdf0e10cSrcweir                     // failed.
280cdf0e10cSrcweir                     bCurrentResult = false; // logic: nDiff==0 = true if there is no difference
281cdf0e10cSrcweir                 }
282cdf0e10cSrcweir 
283cdf0e10cSrcweir                 // Status
284cdf0e10cSrcweir //                HTMLoutput.checkLine(aList[i], bCurrentResult);
285cdf0e10cSrcweir                 INIoutput.checkLine(aList[i], bCurrentResult);
286cdf0e10cSrcweir                 bResultIsOk &= bCurrentResult;
287cdf0e10cSrcweir             }
288cdf0e10cSrcweir             // Status
289cdf0e10cSrcweir //            HTMLoutput.close();
290cdf0e10cSrcweir             INIoutput.close();
291cdf0e10cSrcweir             return bResultIsOk;
292cdf0e10cSrcweir         }
293cdf0e10cSrcweir 
294cdf0e10cSrcweir     // -----------------------------------------------------------------------------
295cdf0e10cSrcweir 
createINIStatus_DiffDiff(StatusHelper[] aDiffDiffList, String _sFilenamePrefix, String _sOutputPath, String _sAbsoluteInputFile, String _sBuildID)296cdf0e10cSrcweir     static void createINIStatus_DiffDiff(StatusHelper[] aDiffDiffList, String _sFilenamePrefix, String _sOutputPath, String _sAbsoluteInputFile, String _sBuildID)
297cdf0e10cSrcweir         {
298cdf0e10cSrcweir             // Status
299cdf0e10cSrcweir             String fs = System.getProperty("file.separator");
300cdf0e10cSrcweir             String sBasename = FileHelper.getBasename(_sAbsoluteInputFile);
301cdf0e10cSrcweir             String sNameNoSuffix = FileHelper.getNameNoSuffix(sBasename);
302cdf0e10cSrcweir             String sINIFile = _sFilenamePrefix + sNameNoSuffix + ".ini";
303cdf0e10cSrcweir 
304cdf0e10cSrcweir //            HTMLOutputter HTMLoutput = HTMLOutputter.create(_sOutputPath, sHTMLFile, _sFilenamePrefix, "");
305cdf0e10cSrcweir //            HTMLoutput.header(sNameNoSuffix);
306cdf0e10cSrcweir //            HTMLoutput.checkDiffDiffSection(sBasename);
307cdf0e10cSrcweir 
308cdf0e10cSrcweir             INIOutputter INIoutput = INIOutputter.create(_sOutputPath, sINIFile, _sFilenamePrefix, "");
309cdf0e10cSrcweir             INIoutput.createHeader();
310cdf0e10cSrcweir             // LLA? what if the are no values in the list? true or false;
311cdf0e10cSrcweir             INIoutput.writeSection("global");
312cdf0e10cSrcweir             INIoutput.writeValue("pages", String.valueOf(aDiffDiffList.length));
313cdf0e10cSrcweir             INIoutput.writeValue("buildid", _sBuildID);
314cdf0e10cSrcweir             INIoutput.writeValue("diffdiff", "yes");
315cdf0e10cSrcweir             INIoutput.writeValue("basename", sBasename);
316cdf0e10cSrcweir 
317cdf0e10cSrcweir             for (int i=0;i<aDiffDiffList.length; i++)
318cdf0e10cSrcweir             {
319cdf0e10cSrcweir                 INIoutput.writeSection("page" + String.valueOf(i + 1));   // list start at point 0, but this is page 1 and so on... current_page = (i + 1)
320cdf0e10cSrcweir                 boolean bCurrentResult = (aDiffDiffList[i].nDiffStatus == StatusHelper.DIFF_NO_DIFFERENCES); // logic: nDiff==0 = true if there is no difference
321cdf0e10cSrcweir 
322cdf0e10cSrcweir //                HTMLoutput.checkDiffDiffLine(aDiffDiffList[i], bCurrentResult);
323cdf0e10cSrcweir                 INIoutput.checkDiffDiffLine(aDiffDiffList[i], bCurrentResult);
324cdf0e10cSrcweir             }
325cdf0e10cSrcweir             // Status
326cdf0e10cSrcweir //            HTMLoutput.close();
327cdf0e10cSrcweir             INIoutput.close();
328cdf0e10cSrcweir         }
329cdf0e10cSrcweir 
330cdf0e10cSrcweir 
331cdf0e10cSrcweir     // -----------------------------------------------------------------------------
332cdf0e10cSrcweir 
check(GraphicalTestArguments _aGTA, String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile)333cdf0e10cSrcweir     public static boolean check(GraphicalTestArguments _aGTA,
334cdf0e10cSrcweir                              String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile)
335cdf0e10cSrcweir         throws ConvWatchCancelException, ConvWatchException
336cdf0e10cSrcweir         {
337cdf0e10cSrcweir             ConvWatch a = new ConvWatch();
338cdf0e10cSrcweir             StatusHelper[] aList = a.createPostscriptStartCheck(_aGTA, _sOutputPath, _sAbsoluteInputFile, _sAbsoluteReferenceFile);
339cdf0e10cSrcweir             DB.writeNumberOfPages(aList.length);
340cdf0e10cSrcweir 
341cdf0e10cSrcweir             boolean bResultIsOk = createINIStatus(aList, "", _sOutputPath, _sAbsoluteInputFile, _aGTA.getBuildID(), _aGTA.getRefBuildID());
342cdf0e10cSrcweir 
343cdf0e10cSrcweir             if (! bResultIsOk)
344cdf0e10cSrcweir             {
345cdf0e10cSrcweir                 // it could be that this will store in a DB, there are problems with '\'
346cdf0e10cSrcweir                 String sErrorMessage = "Graphical compare failed with file ";
347cdf0e10cSrcweir                 String sErrorFile = _sAbsoluteInputFile.replace('\\', '/');
348cdf0e10cSrcweir                 sErrorMessage = sErrorMessage + "'" + sErrorFile + "'";
349cdf0e10cSrcweir                 DB.writeErrorFile(sErrorFile);
350cdf0e10cSrcweir                 throw new ConvWatchException(sErrorMessage);
351cdf0e10cSrcweir             }
352cdf0e10cSrcweir             return bResultIsOk;
353cdf0e10cSrcweir         }
354cdf0e10cSrcweir 
355cdf0e10cSrcweir     // -----------------------------------------------------------------------------
checkDiffDiff(GraphicalTestArguments _aGTA, String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile, String _sAbsoluteDiffPath)356cdf0e10cSrcweir     public static boolean checkDiffDiff(GraphicalTestArguments _aGTA,
357cdf0e10cSrcweir                                      String _sOutputPath, String _sAbsoluteInputFile, String _sAbsoluteReferenceFile,
358cdf0e10cSrcweir                                      String _sAbsoluteDiffPath)
359cdf0e10cSrcweir         throws ConvWatchCancelException, ConvWatchException
360cdf0e10cSrcweir         {
361cdf0e10cSrcweir             ConvWatch a = new ConvWatch();
362cdf0e10cSrcweir             _aGTA.setBorderMove(TriState.FALSE);
363cdf0e10cSrcweir             StatusHelper[] aList = a.createPostscriptStartCheck(_aGTA, _sOutputPath, _sAbsoluteInputFile, _sAbsoluteReferenceFile);
364cdf0e10cSrcweir 
365cdf0e10cSrcweir             // Status
366cdf0e10cSrcweir             boolean bResultIsOk = createINIStatus(aList, "", _sOutputPath, _sAbsoluteInputFile, _aGTA.getBuildID(), _aGTA.getRefBuildID());
367cdf0e10cSrcweir 
368cdf0e10cSrcweir             StatusHelper[] aDiffDiffList = new StatusHelper[aList.length];
369cdf0e10cSrcweir 
370cdf0e10cSrcweir             String fs = System.getProperty("file.separator");
371cdf0e10cSrcweir 
372cdf0e10cSrcweir             boolean bDiffIsOk = true;
373cdf0e10cSrcweir             boolean bFoundAOldDiff = false;
374cdf0e10cSrcweir 
375cdf0e10cSrcweir             PRNCompare aCompare = new PRNCompare();
376cdf0e10cSrcweir             // LLA? what if the are no values in the list? true or false;
377cdf0e10cSrcweir             for (int i=0;i<aList.length; i++)
378cdf0e10cSrcweir             {
379cdf0e10cSrcweir                 String sOrigDiffName = aList[i].m_sDiffGfx;
380cdf0e10cSrcweir                 String sDiffBasename = FileHelper.getBasename(sOrigDiffName);
381cdf0e10cSrcweir 
382cdf0e10cSrcweir                 String sNewDiffName = _sAbsoluteDiffPath + fs + sDiffBasename;
383cdf0e10cSrcweir                 if (! FileHelper.exists(sNewDiffName))
384cdf0e10cSrcweir                 {
385cdf0e10cSrcweir                     GlobalLogWriter.get().println("checkDiffDiff: Old diff file: '" + sNewDiffName + "' does not exist." );
386cdf0e10cSrcweir                     continue;
387cdf0e10cSrcweir                 }
388cdf0e10cSrcweir                 // String sNewDiffName = _sAbsoluteDiffPath + fs + sDiffBasename;
389cdf0e10cSrcweir 
390cdf0e10cSrcweir                 // make a simple difference between these both diff files.
391cdf0e10cSrcweir                 String sSourcePath1 = FileHelper.getPath(sOrigDiffName);
392cdf0e10cSrcweir                 String sSourceFile1 = sDiffBasename;
393cdf0e10cSrcweir                 String sSourcePath2 = _sAbsoluteDiffPath;
394cdf0e10cSrcweir                 String sSourceFile2 = sDiffBasename;
395cdf0e10cSrcweir 
396cdf0e10cSrcweir                 StatusHelper aCurrentStatus = aCompare.checkDiffDiff(_sOutputPath, sSourcePath1, sSourceFile1, sSourcePath2, sSourceFile2);
397cdf0e10cSrcweir                 boolean bCurrentResult = (aCurrentStatus.nDiffStatus == StatusHelper.DIFF_NO_DIFFERENCES); // logic: nDiff==0 = true if there is no difference
398cdf0e10cSrcweir                 bDiffIsOk &= bCurrentResult;
399cdf0e10cSrcweir                 bFoundAOldDiff = true;
400cdf0e10cSrcweir 
401cdf0e10cSrcweir                 aDiffDiffList[i] = aCurrentStatus;
402cdf0e10cSrcweir             }
403cdf0e10cSrcweir 
404cdf0e10cSrcweir             createINIStatus_DiffDiff(aDiffDiffList, "DiffDiff_", _sOutputPath, _sAbsoluteInputFile, _aGTA.getBuildID());
405cdf0e10cSrcweir 
406cdf0e10cSrcweir             if (bFoundAOldDiff == false)
407cdf0e10cSrcweir             {
408cdf0e10cSrcweir                 throw new ConvWatchCancelException("No old difference file found." );
409cdf0e10cSrcweir             }
410cdf0e10cSrcweir             if (! bDiffIsOk)
411cdf0e10cSrcweir             {
412cdf0e10cSrcweir                 throw new ConvWatchException("Graphical difference compare failed with file '" + _sAbsoluteInputFile + "'");
413cdf0e10cSrcweir             }
414cdf0e10cSrcweir             return bDiffIsOk;
415cdf0e10cSrcweir         }
416cdf0e10cSrcweir 
417cdf0e10cSrcweir     // public static void main( String[] argv )
418cdf0e10cSrcweir     //     {
419cdf0e10cSrcweir     //         PRNCompare a = new PRNCompare();
420cdf0e10cSrcweir     //         a.setInputPath(     "/cws/so-cwsserv06/qadev18/SRC680/src.m47/convwatch.keep/input/msoffice/xp/PowerPoint");
421cdf0e10cSrcweir     //         a.setDocFile(       "1_Gov.ppt");
422cdf0e10cSrcweir     //         a.setReferencePath( "/cws/so-cwsserv06/qadev18/SRC680/src.m47/convwatch.keep/input/msoffice/xp/PowerPoint");
423cdf0e10cSrcweir     //         a.setReferenceFile( "1_Gov.prn" );
424cdf0e10cSrcweir     //
425cdf0e10cSrcweir     //         a.setOutputPath(    "/tmp/convwatch_java");
426cdf0e10cSrcweir     //         a.setPostScriptFile("1_Gov.ps" );
427cdf0e10cSrcweir     //     }
428cdf0e10cSrcweir }
429