1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 /** 23 * 24 */ 25 26 package pvt.gui; 27 28 import static org.junit.Assert.*; 29 import static org.openoffice.test.common.Testspace.*; 30 import static org.openoffice.test.vcl.Tester.*; 31 import static testlib.gui.AppTool.*; 32 import static testlib.gui.UIMap.*; 33 34 import java.awt.Rectangle; 35 import java.util.HashMap; 36 37 import org.junit.After; 38 import org.junit.AfterClass; 39 import org.junit.BeforeClass; 40 import org.junit.Rule; 41 import org.junit.Test; 42 import org.junit.rules.TestName; 43 import org.openoffice.test.OpenOffice; 44 import org.openoffice.test.common.Condition; 45 import org.openoffice.test.common.DataSheet; 46 import org.openoffice.test.common.GraphicsUtil; 47 import org.openoffice.test.common.Logger; 48 49 50 public class Benchmark { 51 @Rule 52 public Logger log = Logger.getLogger(this); 53 54 @Rule 55 public TestName testname = new TestName(); 56 57 private static DataSheet result; 58 59 private static final double INTERVAL = 0.1; 60 61 private static int repeat = 8; 62 63 private int i = 0; 64 65 public Benchmark() { 66 67 } 68 69 @BeforeClass 70 public static void beforeClass() throws Exception { 71 OpenOffice.killAll(); 72 result = new DataSheet(getFile("output/" + Benchmark.class.getName() + ".xml")); 73 result.addRow("data", "Scenario", "No", "Consumed Time", "Memory(VSZ)", "Memory(RSS)", "Handles(Windows Only)"); 74 } 75 76 @AfterClass 77 public static void afterClass() throws Exception { 78 app.stop(); 79 } 80 81 @After 82 public void after() { 83 if (i < repeat) 84 result.addRow("data", testname.getMethodName(), i, "err", "err", "err", "err", "err"); 85 } 86 87 private void addRecord(long start, long end) { 88 sleep(2); 89 HashMap<String, Object> perf = aoo.getPerfData(); 90 result.addRow("data", testname.getMethodName(), i, (end - start), perf.get("vsz"), perf.get("rss"), perf.get("handles")); 91 } 92 93 @Test 94 public void coolStartup() throws Exception { 95 app.stop(); 96 for (i = 0; i < repeat; i++) { 97 aoo.cleanUserInstallation(); 98 assertFalse("User profile exists", aoo.getUserInstallation().exists()); 99 aoo.start(); 100 long start = System.currentTimeMillis(); 101 startcenter.waitForExistence(120, INTERVAL); 102 long end = System.currentTimeMillis(); 103 addRecord(start, end); 104 app.quit(); 105 } 106 107 } 108 109 @Test 110 public void warmStartup() throws Exception { 111 // Make sure we has generated user profile 112 app.start(true); 113 app.quit(); 114 115 for (i = 0; i < repeat; i++) { 116 assertTrue("User profile exists", aoo.getUserInstallation().exists()); 117 aoo.start(); 118 long start = System.currentTimeMillis(); 119 startcenter.waitForExistence(120, INTERVAL); 120 long end = System.currentTimeMillis(); 121 addRecord(start, end); 122 app.quit(); 123 } 124 125 } 126 127 @Test 128 public void newTextDocument() { 129 app.start(true); 130 app.quit(); 131 132 for (i = 0; i < repeat; i++) { 133 app.start(); 134 startCenterWriterButton.click(0.5, 0.5); 135 long start = System.currentTimeMillis(); 136 writer.waitForExistence(60, INTERVAL); 137 long end = System.currentTimeMillis(); 138 addRecord(start, end); 139 app.quit(); 140 } 141 142 } 143 144 @Test 145 public void newSpreadsheet() { 146 app.start(true); 147 app.quit(); 148 for (i = 0; i < repeat; i++) { 149 app.start(); 150 startCenterCalcButton.click(0.5, 0.5); 151 long start = System.currentTimeMillis(); 152 calc.waitForExistence(60, INTERVAL); 153 long end = System.currentTimeMillis(); 154 addRecord(start, end); 155 app.quit(); 156 } 157 158 } 159 160 @Test 161 public void newPresentation() { 162 app.start(true); 163 app.quit(); 164 for (i = 0; i < repeat; i++) { 165 app.start(); 166 startCenterImpressButton.click(0.5, 0.5); 167 presentationWizard.click(0.9, 0.95); 168 long start = System.currentTimeMillis(); 169 impress.waitForExistence(60, INTERVAL); 170 long end = System.currentTimeMillis(); 171 addRecord(start, end); 172 app.quit(); 173 } 174 175 } 176 177 @Test 178 public void slideShow() { 179 app.start(true); 180 app.quit(); 181 182 String path = prepareData("pvt/slideshow.odp"); 183 final Rectangle rect = GraphicsUtil.getScreenRectangle(); 184 // when slide show is running, top-center area will be filled with green 185 rect.setRect(rect.getCenterX(), 2, 2, 2); 186 for (i = 0; i < repeat; i++) { 187 app.start(); 188 open(path); 189 impress.waitForExistence(60, 1); 190 sleep(2); 191 assertFalse("Slideshow control exists", slideShow.exists()); 192 assertFalse("Slideshow is not started", GraphicsUtil.isFilledWith(0xFF00FF00, rect)); 193 typeKeys("<F5>"); 194 long start = System.currentTimeMillis(); 195 new Condition() { 196 @Override 197 public boolean value() { 198 return GraphicsUtil.isFilledWith(0xFF00FF00, rect); 199 } 200 201 }.waitForTrue("", 120, INTERVAL); 202 long end = System.currentTimeMillis(); 203 addRecord(start, end); 204 slideShow.typeKeys("<esc>"); 205 sleep(2); 206 app.quit(); 207 } 208 209 } 210 211 @Test 212 public void loadFinishPlainODT() { 213 loadFinish("pvt/plain_200p.odt", "Page 1 / 23[0-9]{1}"); 214 } 215 216 @Test 217 public void loadFinishPlainDOC() { 218 loadFinish("pvt/plain_50p.doc", "Page i / 5[0-9]{1}"); 219 } 220 221 @Test 222 public void loadFinishPlainDOCX() { 223 loadFinish("pvt/plain_200p.docx", "Page 1 / 1[8-9]{1}[0-9]{1}"); 224 } 225 226 @Test 227 public void loadFinishPlainODS() { 228 loadFinish("pvt/plain_11s.ods", "Sheet 1 / 11"); 229 } 230 231 @Test 232 public void loadFinishPlainXLS() { 233 loadFinish("pvt/plain_11s.xls", "Sheet 1 / 11"); 234 } 235 236 @Test 237 public void loadFinishPlainXLSX() { 238 loadFinish("pvt/plain_11s.xlsx", "Sheet 1 / 11"); 239 } 240 241 @Test 242 public void loadFinishPlainODP() { 243 loadFinish("pvt/plain_200p.odp", "Slide 1 / 200"); 244 } 245 246 @Test 247 public void loadFinishPlainPPT() { 248 loadFinish("pvt/plain_200p.ppt", "Slide 1 / 200"); 249 } 250 251 @Test 252 public void loadFinishPlainPPTX() { 253 loadFinish("pvt/plain_200p.pptx", "Slide 1 / 200"); 254 } 255 256 @Test 257 public void loadFinishComplexDOC() { 258 loadFinish("pvt/complex_300p.doc", "Page 1 / 3[0-9]{2}"); 259 } 260 261 @Test 262 public void loadFinishComplexDOCX() { 263 loadFinish("pvt/complex_400p.docx", "Page 1 / 3[2-9]{2}"); 264 } 265 266 @Test 267 public void loadFinishComplexODT() { 268 loadFinish("pvt/complex_800p.odt", "Page 1 / 8[0-9]{2}"); 269 } 270 271 @Test 272 public void loadFinishComplexODS() { 273 loadFinish("pvt/complex_19s.ods", "Sheet 8 / 19"); 274 } 275 276 @Test 277 public void loadFinishComplexXLS() { 278 loadFinish("pvt/complex_29s.xls", "Sheet 2 / 29"); 279 } 280 281 @Test 282 public void loadFinishComplexXLSX() { 283 loadFinish("pvt/complex_29s.xlsx", "Sheet 29 / 29"); 284 } 285 286 @Test 287 public void loadFinishComplexODP() { 288 loadFinish("pvt/complex_150p.odp", "Slide 1 / 150"); 289 } 290 291 @Test 292 public void loadFinishComplexPPT() { 293 loadFinish("pvt/complex_100p.ppt", "Slide 1 / 100"); 294 } 295 296 @Test 297 public void loadFinishComplexPPTX() { 298 loadFinish("pvt/complex_100p.pptx", "Slide 1 / 100"); 299 } 300 301 public void loadFinish(String file, final String indicator) { 302 final int openIndicatorIndex = file.matches(".*\\.(odp|ppt|pptx)$") ? 4 : 0; 303 String path = prepareData(file); 304 app.stop(); 305 for (i = 0; i < repeat; i++) { 306 app.start(); 307 app.dispatch(".uno:Open"); 308 filePickerPath.setText(path); 309 sleep(1); 310 filePickerOpen.click(0.5, 0.5); 311 long start = System.currentTimeMillis(); 312 new Condition() { 313 @Override 314 public boolean value() { 315 try { 316 String text = statusBar.getItemText(openIndicatorIndex); 317 return text.matches(indicator); 318 } catch (Exception e) { 319 return false; 320 } 321 } 322 323 }.waitForTrue("", 120, INTERVAL); 324 long end = System.currentTimeMillis(); 325 addRecord(start, end); 326 discard(); 327 app.quit(); 328 } 329 330 } 331 332 @Test 333 public void savePlainODT() { 334 save("pvt/plain_200p.odt", "Page 1 / 23[0-9]{1}"); 335 } 336 337 @Test 338 public void savePlainDOC() { 339 save("pvt/plain_50p.doc", "Page i / 5[0-9]{1}"); 340 } 341 342 @Test 343 public void savePlainODS() { 344 save("pvt/plain_11s.ods", "Sheet 1 / 11"); 345 } 346 347 @Test 348 public void savePlainXLS() { 349 save("pvt/plain_11s.xls", "Sheet 1 / 11"); 350 } 351 352 @Test 353 public void savePlainODP() { 354 save("pvt/plain_200p.odp", "Slide 1 / 200"); 355 } 356 357 @Test 358 public void savePlainPPT() { 359 save("pvt/plain_200p.ppt", "Slide 1 / 200"); 360 } 361 362 @Test 363 public void saveComplexODT() { 364 save("pvt/complex_800p.odt", "Page 1 / 8[0-9]{2}"); 365 } 366 367 @Test 368 public void saveComplexDOC() { 369 save("pvt/complex_300p.doc", "Page 1 / 3[0-9]{2}"); 370 } 371 372 @Test 373 public void saveComplexODS() { 374 save("pvt/complex_19s.ods", "Sheet 8 / 19"); 375 } 376 377 @Test 378 public void saveComplexXLS() { 379 save("pvt/complex_29s.xls", "Sheet 2 / 29"); 380 } 381 382 @Test 383 public void saveComplexODP() { 384 save("pvt/complex_150p.odp", "Slide 1 / 150"); 385 } 386 387 @Test 388 public void saveComplexPPT() { 389 save("pvt/complex_100p.ppt", "Slide 1 / 100"); 390 } 391 392 public void save(String file, final String openIndicator) { 393 boolean alienFormat = file.matches(".*\\.(doc|xls|ppt|docx|xlsx|pptx)$"); 394 final int openIndicatorIndex = file.matches(".*\\.(odp|ppt|pptx)$") ? 4 : 0; 395 final int saveIndicatorIndex = file.matches(".*\\.(odt|doc|docx)$") ? 5 : file.matches(".*\\.(ods|xls|xlsx)$") ? 4 : 2; 396 app.stop(); 397 String picture = prepareData("image/red_64x64.bmp"); 398 for (i = 0; i < repeat; i++) { 399 String dir = "temp/file" + i; 400 getFile(dir).mkdirs(); 401 app.start(); 402 open(prepareData(file, dir)); 403 new Condition() { 404 @Override 405 public boolean value() { 406 try { 407 String text = statusBar.getItemText(openIndicatorIndex); 408 return text.matches(openIndicator); 409 } catch (Exception e) { 410 return false; 411 } 412 } 413 414 }.waitForTrue("", 120, 1); 415 sleep(2); 416 insertPicture(picture); 417 sleep(5); 418 assertEquals("File is modified", "*", statusBar.getItemText(saveIndicatorIndex)); 419 app.dispatch(".uno:Save"); 420 if (alienFormat) { 421 alienFormatDlg.waitForExistence(3, 1); 422 sleep(1); 423 typeKeys("<enter>"); 424 } 425 426 long start = System.currentTimeMillis(); 427 new Condition() { 428 @Override 429 public boolean value() { 430 try { 431 String text = statusBar.getItemText(saveIndicatorIndex); 432 return " ".equals(text); 433 } catch (Exception e) { 434 return false; 435 } 436 } 437 438 }.waitForTrue("", 120, INTERVAL); 439 long end = System.currentTimeMillis(); 440 addRecord(start, end); 441 close(); 442 app.stop(); 443 } 444 445 } 446 } 447