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