218 lines
7.8 KiB
Java
218 lines
7.8 KiB
Java
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
|
|
package ifc.frame;
|
|
|
|
import lib.MultiMethodTest;
|
|
|
|
import com.sun.star.frame.XController;
|
|
import com.sun.star.frame.XFrame;
|
|
import com.sun.star.frame.XModel;
|
|
import com.sun.star.util.XModifiable;
|
|
|
|
|
|
/**
|
|
* Testing <code>com.sun.star.frame.XController</code>
|
|
* interface methods:
|
|
* <ul>
|
|
* <li><code> getFrame() </code></li>
|
|
* <li><code> attachFrame() </code></li>
|
|
* <li><code> getModel() </code></li>
|
|
* <li><code> attachModel() </code></li>
|
|
* <li><code> getViewData() </code></li>
|
|
* <li><code> restoreViewData() </code></li>
|
|
* <li><code> suspend() </code></li>
|
|
* </ul><p>
|
|
* This test needs the following object relations :
|
|
* <ul>
|
|
* <li> <code>'Frame'</code> (of type <code>XFrame</code>):
|
|
* any other frame, used for tests</li>
|
|
* <li> <code>'FirstModel'</code> (of type <code>XModel</code>):
|
|
* model of a controller tested</li>
|
|
* <li> <code>'SecondModel'</code> (of type <code>XModel</code>):
|
|
* other model, used for tests </li>
|
|
* <li> <code>'HasViewData'</code> (of type <code>Boolean</code>):
|
|
* (optional relation) if it exists, so controller has no view data</li>
|
|
* <li> <code>'SecondController'</code> (of type <code>XController</code>):
|
|
* other controller, used for tests </li>
|
|
* </ul> <p>
|
|
* Test is <b> NOT </b> multithread compliant. <p>
|
|
* @see com.sun.star.frame.XController
|
|
*/
|
|
public class _XController extends MultiMethodTest {
|
|
public XController oObj = null;
|
|
public XModel firstModel = null;
|
|
public XModel secondModel = null;
|
|
public XFrame frame = null;
|
|
public Object ViewData = null;
|
|
|
|
/**
|
|
* Test calls the method. <p>
|
|
* Has <b> OK </b> status if the method returns object, that's equal to
|
|
* previously obtained object relation 'Frame'.
|
|
* The following method tests are to be completed successfully before:
|
|
* <ul>
|
|
* <li> <code> attachFrame() </code> : attaches frame obtained object
|
|
* relation 'Frame' </li>
|
|
* </ul>
|
|
*/
|
|
public void _getFrame() {
|
|
requiredMethod("attachFrame()");
|
|
XFrame getting = oObj.getFrame();
|
|
boolean eq = getting.equals(frame);
|
|
if ( !eq ) {
|
|
log.println("Getting: " + getting.toString());
|
|
log.println("Expected: " + frame.toString());
|
|
}
|
|
tRes.tested("getFrame()", eq);
|
|
}
|
|
|
|
/**
|
|
* After obtaining a corresponding object relation test calls the method.
|
|
* Has <b> OK </b> status if no exceptions were thrown. <p>
|
|
*/
|
|
public void _attachFrame() {
|
|
frame = (XFrame) tEnv.getObjRelation("Frame");
|
|
oObj.attachFrame(frame);
|
|
tRes.tested("attachFrame()", true);
|
|
}
|
|
|
|
/**
|
|
* At first object relation 'FirstModel' is gotten. Then test calls the
|
|
* method. <p>
|
|
* Has <b> OK </b> status if string representation of an object, returned by
|
|
* the method is equal to string representation of corresponding object
|
|
* relation.
|
|
*/
|
|
public void _getModel() {
|
|
firstModel = (XModel) tEnv.getObjRelation("FirstModel");
|
|
XModel getting = oObj.getModel();
|
|
String out1 = "";
|
|
String out2 = "";
|
|
if ( (firstModel == null) ) out1="none";
|
|
else out1 = firstModel.toString();
|
|
if ( (getting == null) ) out2="none"; else out2 = getting.toString();
|
|
boolean eq = out1.equals(out2);
|
|
if ( !eq ) {
|
|
log.println("Getting: " + out2);
|
|
log.println("Expected: " + out1);
|
|
}
|
|
tRes.tested("getModel()", eq);
|
|
}
|
|
|
|
/**
|
|
* At first, we obtain an object relation 'SecondModel'. Then test calls
|
|
* the method and check result. <p>
|
|
* Has <b> OK </b> status if method returns true and attached model is
|
|
* equal to a model 'SecondModel' obtained before.
|
|
* <p>
|
|
* The following method tests are to be completed successfully before :
|
|
* <ul>
|
|
* <li> <code> getModel() </code> : returns model (XModel) of the
|
|
* XController object</li>
|
|
* </ul>
|
|
*/
|
|
public void _attachModel() {
|
|
boolean result = false;
|
|
|
|
requiredMethod("getModel()");
|
|
secondModel = (XModel) tEnv.getObjRelation("SecondModel");
|
|
XModel gotBefore = oObj.getModel();
|
|
boolean attached = oObj.attachModel(secondModel);
|
|
XModel gotAfter = oObj.getModel();
|
|
if ( attached ) {
|
|
if ( ! gotBefore.equals(gotAfter) ) {
|
|
if ( gotAfter.equals(secondModel) ) {
|
|
result = true;
|
|
} else {
|
|
log.println("Attached and gotten models are not equal");
|
|
log.println("Getting: " + gotAfter.toString());
|
|
log.println("Expected: " + secondModel.toString());
|
|
}
|
|
} else {
|
|
log.println("method did not change model");
|
|
}
|
|
} else {
|
|
result=true;
|
|
log.println("attachModel() returns false");
|
|
log.println("as expected, see #82938");
|
|
}
|
|
tRes.tested("attachModel()", result);
|
|
boolean bResult = oObj.attachModel(firstModel);
|
|
log.println("attachModel() --> " + bResult);
|
|
}
|
|
|
|
/**
|
|
* At first gotten object relation 'HasViewData' is checked. Then if
|
|
* 'HasViewData' is null, test calls the method. <p>
|
|
* Has <b> OK </b> status if obtained object relation is not null, or if
|
|
* the method does not return null.
|
|
*/
|
|
public void _getViewData() {
|
|
if (tEnv.getObjRelation("HasViewData") != null) {
|
|
log.println("This Object has no View Data");
|
|
tRes.tested("getViewData()", true);
|
|
return;
|
|
}
|
|
ViewData = oObj.getViewData();
|
|
tRes.tested( "getViewData()", ViewData != null );
|
|
}
|
|
|
|
/**
|
|
* If obtained object relation 'HasViewData' is null, test calls the method.
|
|
* <p>Has <b> OK </b> status if obtained object relation is not null, or
|
|
* if no exceptions were thrown while method call.<p>
|
|
* The following method tests are to be completed successfully before :
|
|
* <ul>
|
|
* <li> <code> getViewData() </code> : gets view data of an object. </li>
|
|
* </ul>
|
|
*/
|
|
public void _restoreViewData() {
|
|
requiredMethod("getViewData()");
|
|
if (tEnv.getObjRelation("HasViewData") != null) {
|
|
log.println("This Object has no View Data");
|
|
tRes.tested("restoreViewData()", true);
|
|
return;
|
|
}
|
|
oObj.restoreViewData(ViewData);
|
|
tRes.tested( "restoreViewData()", true );
|
|
}
|
|
|
|
/**
|
|
* Has <b> OK </b> status if the method returns true.<p>
|
|
* The following method tests are to be completed successfully before :
|
|
* <ul>
|
|
* <li> <code> restoreViewData() </code> : restores view status of an
|
|
* object </li>
|
|
* </ul>
|
|
*/
|
|
public void _suspend() {
|
|
requiredMethod("restoreViewData()");
|
|
XModifiable modify = (XModifiable) tEnv.getObjRelation("Modifiable");
|
|
if (modify != null) {
|
|
try {
|
|
modify.setModified(false);
|
|
} catch (com.sun.star.beans.PropertyVetoException pve) {
|
|
log.println("PropertyVetoException, couldn't change Modify flag");
|
|
}
|
|
}
|
|
tRes.tested( "suspend()", oObj.suspend(true) );
|
|
}
|
|
|
|
}
|
|
|