13cb3fca6SLiu Zhe /**************************************************************
23cb3fca6SLiu Zhe  *
33cb3fca6SLiu Zhe  * Licensed to the Apache Software Foundation (ASF) under one
43cb3fca6SLiu Zhe  * or more contributor license agreements.  See the NOTICE file
53cb3fca6SLiu Zhe  * distributed with this work for additional information
63cb3fca6SLiu Zhe  * regarding copyright ownership.  The ASF licenses this file
73cb3fca6SLiu Zhe  * to you under the Apache License, Version 2.0 (the
83cb3fca6SLiu Zhe  * "License"); you may not use this file except in compliance
93cb3fca6SLiu Zhe  * with the License.  You may obtain a copy of the License at
103cb3fca6SLiu Zhe  *
113cb3fca6SLiu Zhe  *   http://www.apache.org/licenses/LICENSE-2.0
123cb3fca6SLiu Zhe  *
133cb3fca6SLiu Zhe  * Unless required by applicable law or agreed to in writing,
143cb3fca6SLiu Zhe  * software distributed under the License is distributed on an
153cb3fca6SLiu Zhe  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
163cb3fca6SLiu Zhe  * KIND, either express or implied.  See the License for the
173cb3fca6SLiu Zhe  * specific language governing permissions and limitations
183cb3fca6SLiu Zhe  * under the License.
193cb3fca6SLiu Zhe  *
203cb3fca6SLiu Zhe  *************************************************************/
213cb3fca6SLiu Zhe 
223e7cc3ecSLiu Zhe package pvt.uno;
233cb3fca6SLiu Zhe 
24527dbd07SLiu Zhe import static org.openoffice.test.common.Testspace.*;
25527dbd07SLiu Zhe 
263cb3fca6SLiu Zhe import java.io.File;
273cb3fca6SLiu Zhe 
283cb3fca6SLiu Zhe import org.junit.After;
293cb3fca6SLiu Zhe import org.junit.AfterClass;
303cb3fca6SLiu Zhe import org.junit.Before;
313cb3fca6SLiu Zhe import org.junit.BeforeClass;
323cb3fca6SLiu Zhe import org.junit.Rule;
333cb3fca6SLiu Zhe import org.junit.Test;
343cb3fca6SLiu Zhe import org.junit.runner.RunWith;
353cb3fca6SLiu Zhe import org.openoffice.test.OpenOffice;
36329fd865SLiu Zhe import org.openoffice.test.common.DataSheet;
37527dbd07SLiu Zhe import org.openoffice.test.common.FileProvider;
38*8fd475f4SLinyi Li import org.openoffice.test.common.SystemUtil;
394481f6d8SLinyi Li import org.openoffice.test.common.Testspace;
40527dbd07SLiu Zhe import org.openoffice.test.common.FileProvider.FileFilter;
415f863819SLiu Zhe import org.openoffice.test.common.FileProvider.FileRepeat;
42527dbd07SLiu Zhe import org.openoffice.test.common.FileProvider.FileRepos;
433cb3fca6SLiu Zhe import org.openoffice.test.common.FileUtil;
443cb3fca6SLiu Zhe import org.openoffice.test.common.Logger;
453cb3fca6SLiu Zhe import org.openoffice.test.uno.UnoApp;
463cb3fca6SLiu Zhe 
473cb3fca6SLiu Zhe import com.sun.star.beans.PropertyValue;
483cb3fca6SLiu Zhe import com.sun.star.document.MacroExecMode;
493cb3fca6SLiu Zhe import com.sun.star.lang.XComponent;
503cb3fca6SLiu Zhe import com.sun.star.uno.UnoRuntime;
513cb3fca6SLiu Zhe import com.sun.star.util.XCloseable;
523cb3fca6SLiu Zhe 
533cb3fca6SLiu Zhe 
54527dbd07SLiu Zhe @RunWith(FileProvider.class)
553cb3fca6SLiu Zhe public class Conversion {
56527dbd07SLiu Zhe 
57f4092fc8SLiu Zhe 	@Rule
58f4092fc8SLiu Zhe 	public Logger log = Logger.getLogger(this);
59f4092fc8SLiu Zhe 
60527dbd07SLiu Zhe 	@FileRepos
619b5f68a3SLiu Zhe 	public static String repos = System.getProperty("conversion.repos", getDataPath("conversion_pvt"));
62527dbd07SLiu Zhe 	@FileFilter
63329fd865SLiu Zhe 	public static String filter = System.getProperty("conversion.filter",
64329fd865SLiu Zhe 			  "-f .*(doc|dot|odt|ott)$ writer_pdf_Export pdf "
65329fd865SLiu Zhe 			+ "-f .*(xls|xlt|ods|ots)$ calc_pdf_Export pdf "
66329fd865SLiu Zhe 			+ "-f .*(ppt|ppt|odp|otp)$ impress_pdf_Export pdf "
67329fd865SLiu Zhe 			+ "-f .*(doc|dot|docx|docm|dotx|dotm)$ writer8 odt "
68329fd865SLiu Zhe 			+ "-f .*(xls|xlt|xlsx|xltx|xlsm|xltm)$ calc8 ods "
69329fd865SLiu Zhe 			+ "-f .*(ppt|pot|pptx|pptm|potm|potx)$ impress8 odp "
70329fd865SLiu Zhe 			+ "-f .*(odt|ott)$ 'MS Word 97' doc "
71329fd865SLiu Zhe 			+ "-f .*(ods|ots)$ 'MS Excel 97' xls "
72329fd865SLiu Zhe 			+ "-f .*(odp|otp)$ 'MS PowerPoint 97' ppt");
733cb3fca6SLiu Zhe 
745f863819SLiu Zhe 	@FileRepeat
759dae0b27SLinyi Li 	public static int repeat = Integer.parseInt(System.getProperty("conversion.repeat", "8"));
765f863819SLiu Zhe 
779b5f68a3SLiu Zhe 	public static String clean = System.getProperty("conversion.clean", "file");
784481f6d8SLinyi Li 
794481f6d8SLinyi Li 	public static int nLevelInfo = Integer.parseInt(System.getProperty("conversion.limitationcheck", "0"));	// Level info: starts from 1, 0 means no need for limitation check
809b5f68a3SLiu Zhe 
81*8fd475f4SLinyi Li 	public static int nSleep = Integer.parseInt(System.getProperty("conversion.sleep", "3000"));	// Sleep before loadComponentFromURL and storeToURL
82*8fd475f4SLinyi Li 
83329fd865SLiu Zhe 	private static OpenOffice aoo = new OpenOffice();
84527dbd07SLiu Zhe 
85329fd865SLiu Zhe 	private static UnoApp app = null;
86329fd865SLiu Zhe 
87329fd865SLiu Zhe 	private static DataSheet result;
883cb3fca6SLiu Zhe 
895f863819SLiu Zhe 	private static int counter = 0;
905f863819SLiu Zhe 
913cb3fca6SLiu Zhe 	@BeforeClass
923cb3fca6SLiu Zhe 	public static void beforeClass() throws Exception {
93329fd865SLiu Zhe 		aoo.setUnoUrl(OpenOffice.DEFAULT_UNO_URL);
94*8fd475f4SLinyi Li 		aoo.addArgs("-invisible", "-conversionmode", "-hidemenu", "-nofirststartwizard");
95329fd865SLiu Zhe 	    app = new UnoApp(aoo);
964481f6d8SLinyi Li 	    Testspace.prepareDataFile("limit_cfg.ini", aoo.getHome().toString()+"/program");	// Move limitation check file to installation dir
979edf8282SLiu Zhe 		result = new DataSheet(getFile("output/pvt_uno_conversion.xml"));
98*8fd475f4SLinyi Li 		result.addRow("data", "File","Scenario","File Size","No","Time Consumed After Closing","Time Consumed After Saving","Time Consumed After Loading");
993cb3fca6SLiu Zhe 	}
1003cb3fca6SLiu Zhe 
1013cb3fca6SLiu Zhe 	@AfterClass
1023cb3fca6SLiu Zhe 	public static void afterClass() throws Exception {
103f4092fc8SLiu Zhe 		app.close();
1043cb3fca6SLiu Zhe 	}
1053cb3fca6SLiu Zhe 
106527dbd07SLiu Zhe 	private String sourcePath = null;
107527dbd07SLiu Zhe 	private String targetFilterName = null;
108527dbd07SLiu Zhe 	private String targetExtName = null;
109527dbd07SLiu Zhe 
1103cb3fca6SLiu Zhe 	private File sourceFile = null;
1113cb3fca6SLiu Zhe 	private File targetFile = null;
1123cb3fca6SLiu Zhe 	private String sourceFileUrl = null;
1133cb3fca6SLiu Zhe 	private String targetFileUrl = null;
114527dbd07SLiu Zhe 
115f4092fc8SLiu Zhe 	private String scenario = null;
116f4092fc8SLiu Zhe 	private String sourceFileId = null;
1173cb3fca6SLiu Zhe 	private long loadTime = -1;
1183cb3fca6SLiu Zhe 	private long saveTime = -1;
1193cb3fca6SLiu Zhe 	private long closeTime = -1;
1203cb3fca6SLiu Zhe 
121527dbd07SLiu Zhe 	public Conversion(String sourcePath, String targetFilterName, String targetExtName) {
1223cb3fca6SLiu Zhe 		super();
123527dbd07SLiu Zhe 		this.sourcePath = sourcePath;
1243cb3fca6SLiu Zhe 		this.targetFilterName = targetFilterName;
125527dbd07SLiu Zhe 		this.targetExtName = targetExtName;
1265f863819SLiu Zhe 		counter++;
127f4092fc8SLiu Zhe 	}
128f4092fc8SLiu Zhe 
129f4092fc8SLiu Zhe 	@Before
130f4092fc8SLiu Zhe 	public void before() throws Exception {
1319b5f68a3SLiu Zhe 		sourceFile = new File(sourcePath);
132527dbd07SLiu Zhe 		sourceFileUrl = FileUtil.getUrl(this.sourceFile);
133527dbd07SLiu Zhe 		targetFile = getFile("classtemp/" + sourceFile.getName()+ "." + targetExtName);
134527dbd07SLiu Zhe 		targetFileUrl = FileUtil.getUrl(this.targetFile);
135527dbd07SLiu Zhe 
136527dbd07SLiu Zhe 		scenario = FileUtil.getFileExtName(sourceFile.getName()).toLowerCase() + " to " + FileUtil.getFileExtName(targetFile.getName()).toLowerCase();
1379b5f68a3SLiu Zhe 		String pathSource = sourceFile.getCanonicalPath().replace("\\", "/");
1389b5f68a3SLiu Zhe 		String pathRepos = new File(repos).getCanonicalPath().replace("\\", "/") + "/";
1399b5f68a3SLiu Zhe 		sourceFileId = pathSource.replace(pathRepos, "");
140f4092fc8SLiu Zhe 		log.info("Start [File: " + sourceFileId + "] [Size: " + (sourceFile.length() / 1024) + "KB] [Scenario: " + scenario + "]");
141f4092fc8SLiu Zhe 		app.start();
142f4092fc8SLiu Zhe 	}
143f4092fc8SLiu Zhe 
144f4092fc8SLiu Zhe 	@After
145f4092fc8SLiu Zhe 	public void after() throws Exception{
146*8fd475f4SLinyi Li 		result.addRow("data", sourceFileId, scenario, sourceFile.length(), counter % repeat , closeTime, saveTime, loadTime);
147f4092fc8SLiu Zhe 		log.info("Result [After Closing: " + closeTime + "] [After Saving: " + saveTime + "] [After Loading: " + loadTime + "]");
1489b5f68a3SLiu Zhe 		if (closeTime < 0) {
1499b5f68a3SLiu Zhe 			app.close();
1509b5f68a3SLiu Zhe 		} else if ("file".equalsIgnoreCase(clean) && counter % repeat == 0) {
151f4092fc8SLiu Zhe 			app.close();
152f4092fc8SLiu Zhe 		}
1533cb3fca6SLiu Zhe 	}
1549b5f68a3SLiu Zhe 
1553cb3fca6SLiu Zhe 	private PropertyValue propertyValue(String name, Object value) {
1563cb3fca6SLiu Zhe 		PropertyValue p = new PropertyValue();
1573cb3fca6SLiu Zhe 		p.Name = name;
1583cb3fca6SLiu Zhe 		p.Value= value;
1593cb3fca6SLiu Zhe 		return p;
1603cb3fca6SLiu Zhe 	}
1613cb3fca6SLiu Zhe 
162527dbd07SLiu Zhe 	@Test(timeout=10 * 60000)
1633cb3fca6SLiu Zhe 	public void testConversion() throws Exception {
164*8fd475f4SLinyi Li 		try {
165*8fd475f4SLinyi Li 			// convert
166*8fd475f4SLinyi Li 			SystemUtil.sleep(nSleep);	// Sleep before loadComponentFromURL
167*8fd475f4SLinyi Li 			long start = System.currentTimeMillis();
168*8fd475f4SLinyi Li 			XComponent doc = app.loadDocumentFromURL(sourceFileUrl,
169*8fd475f4SLinyi Li 					propertyValue("Hidden", true),
170*8fd475f4SLinyi Li 					propertyValue("ReadOnly", true),
171*8fd475f4SLinyi Li 					propertyValue("AsyncMode", false),
172*8fd475f4SLinyi Li 					propertyValue("MacroExecutionMode", MacroExecMode.NEVER_EXECUTE),
173*8fd475f4SLinyi Li 					propertyValue("LimitationCheckLevel", nLevelInfo));
174*8fd475f4SLinyi Li 
175*8fd475f4SLinyi Li 			loadTime = System.currentTimeMillis() - start;
176*8fd475f4SLinyi Li 
177*8fd475f4SLinyi Li 			SystemUtil.sleep(nSleep);	// Sleep before storeToURL
178*8fd475f4SLinyi Li 			app.saveDocumentToURL(doc, targetFileUrl,
179*8fd475f4SLinyi Li 					propertyValue( "FilterName", targetFilterName),
180*8fd475f4SLinyi Li 					propertyValue( "Overwrite", true));
181*8fd475f4SLinyi Li 			saveTime = System.currentTimeMillis() - start - nSleep;
182*8fd475f4SLinyi Li 			XCloseable xCloseable = (XCloseable) UnoRuntime.queryInterface(XCloseable.class, doc);
183*8fd475f4SLinyi Li 			xCloseable.close(true);
184*8fd475f4SLinyi Li 			closeTime = System.currentTimeMillis() - start - nSleep;
185*8fd475f4SLinyi Li 		} catch (com.sun.star.task.ErrorCodeIOException e){
186*8fd475f4SLinyi Li 			int errCode = e.ErrCode;
187*8fd475f4SLinyi Li 			if( 296 == errCode ) {
188*8fd475f4SLinyi Li 				loadTime = -2;
189*8fd475f4SLinyi Li 				saveTime = -2;
190*8fd475f4SLinyi Li 				closeTime = -2;
191*8fd475f4SLinyi Li 			}
192*8fd475f4SLinyi Li 
193*8fd475f4SLinyi Li 			throw e;
194*8fd475f4SLinyi Li 		}
1953cb3fca6SLiu Zhe 	}
1963cb3fca6SLiu Zhe }
197