/**************************************************************
*
* 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
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
package complex.dataPilot;
import com.sun.star.beans.Property;
import com.sun.star.beans.PropertyAttribute;
import com.sun.star.beans.PropertyChangeEvent;
import com.sun.star.beans.XPropertyChangeListener;
import com.sun.star.beans.XPropertySet;
import com.sun.star.beans.XPropertySetInfo;
import com.sun.star.beans.XVetoableChangeListener;
import com.sun.star.lang.EventObject;
import java.util.Random;
import java.util.StringTokenizer;
import lib.TestParameters;
// import share.LogWriter;
//import lib.MultiMethodTest;
import util.ValueChanger;
import util.utils;
/**
* Testing com.sun.star.beans.XPropertySet
* interface methods :
*
getPropertySetInfo()
setPropertyValue()
getPropertyValue()
addPropertyChangeListener()
removePropertyChangeListener()
addVetoableChangeListener()
removeVetoableChangeListener()
propertyChanged
flag to true.
*/
public void propertyChange(PropertyChangeEvent e) {
propertyChanged = true;
}
public void disposing (EventObject obj) {}
};
/**
* Flag that indicates veto listener was called.
*/
boolean vetoableChanged = false;
/**
* The own vetoable change listener
*/
XVetoableChangeListener VClistener = new MyVetoListener();
/**
* Listener that must be called on constrained property changing.
*/
public class MyVetoListener implements XVetoableChangeListener {
/**
* Just set vetoableChanged
flag to true.
*/
public void vetoableChange(PropertyChangeEvent e) {
vetoableChanged = true;
}
public void disposing (EventObject obj) {}
};
/**
* Properties to test
*/
PropsToTest PTT = new PropsToTest();
/**
* Structure that collects three properties of each type to test :
* Constrained, Bound and Normal.
*/
public class PropsToTest {
String constrained = null;
String bound = null;
String normal = null;
}
/**
* Constructor: gets the object to test, a logger and the test parameters
* @param xObj The test object
* @param log A log writer
* @param param The test parameters
*/
public _XPropertySet(XPropertySet xObj/*, LogWriter log*/, TestParameters param) {
oObj = xObj;
// this.log = log;
this.param = param;
}
/**
* Tests method getPropertySetInfo
. After test completed
* call {@link #getPropsToTest} method to retrieve different kinds
* of properties to test then.
* Has OK status if not null XPropertySetInfo
* object returned.
* Since getPropertySetInfo
is optional, it may return null,
* if it is not implemented. This method uses then an object relation
* PTT
(Properties To Test) to determine available properties.
* All tests for services without getPropertySetInfo
must
* provide this object relation.
*/
public boolean _getPropertySetInfo() {
XPropertySetInfo propertySetInfo = oObj.getPropertySetInfo();
if (propertySetInfo == null) {
System.out.println("getPropertySetInfo() method returned null");
String[] ptt = (String[]) param.get("PTT");
PTT.normal=ptt[0];
PTT.bound=ptt[1];
PTT.constrained=ptt[2];
} else {
getPropsToTest(propertySetInfo);
}
return true;
} // end of getPropertySetInfo()
/**
* Tests change listener which added for bound properties.
* Adds listener to bound property (if it exists), then changes
* its value and check if listener was called.
* Method tests to be successfully completed before : *
getPropertySetInfo
: in this method test
* one of bound properties is retrieved. * Has OK status if NO bound properties exist or if listener * was successfully called. */ public boolean _addPropertyChangeListener() { propertyChanged = false; boolean result = true; if ( PTT.bound.equals("none") ) { System.out.println("*** No bound properties found ***"); } else { try { oObj.addPropertyChangeListener(PTT.bound,PClistener); Object gValue = oObj.getPropertyValue(PTT.bound); oObj.setPropertyValue(PTT.bound, ValueChanger.changePValue(gValue)); } catch (com.sun.star.beans.PropertyVetoException e) { System.out.println("Exception occured while trying to change "+ "property '"+ PTT.bound+"'"); e.printStackTrace(); } catch (com.sun.star.lang.IllegalArgumentException e) { System.out.println("Exception occured while trying to change "+ "property '"+ PTT.bound+"'"); e.printStackTrace(); } catch (com.sun.star.beans.UnknownPropertyException e) { System.out.println("Exception occured while trying to change "+ "property '"+ PTT.bound+"'"); e.printStackTrace(); } catch (com.sun.star.lang.WrappedTargetException e) { System.out.println("Exception occured while trying to change "+ "property '"+ PTT.bound+"'"); e.printStackTrace(); } // end of try-catch result = propertyChanged; if (!propertyChanged) { System.out.println("propertyChangeListener wasn't called for '"+ PTT.bound+"'"); } } //endif return result; } // end of addPropertyChangeListener() /** * Tests vetoable listener which added for constrained properties. * Adds listener to constrained property (if it exists), then changes * its value and check if listener was called.
* Method tests to be successfully completed before : *
getPropertySetInfo
: in this method test
* one of constrained properties is retrieved.
* Has OK status if NO constrained properties exist or if listener
* was successfully called.
*/
public boolean _addVetoableChangeListener() {
// requiredMethod("getPropertySetInfo()");
vetoableChanged = false;
boolean result = true;
if ( PTT.constrained.equals("none") ) {
System.out.println("*** No constrained properties found ***");
} else {
try {
oObj.addVetoableChangeListener(PTT.constrained,VClistener);
Object gValue = oObj.getPropertyValue(PTT.constrained);
oObj.setPropertyValue(PTT.constrained,
ValueChanger.changePValue(gValue));
} catch (com.sun.star.beans.PropertyVetoException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} // end of try-catch
result = vetoableChanged;
if (!vetoableChanged) {
System.out.println("vetoableChangeListener wasn't called for '"+
PTT.constrained+"'");
}
} //endif
return result;
} // end of addVetoableChangeListener()
/**
* Tests setPropertyValue
method.
* Stores value before call, and compares it with value after
* call.
* Method tests to be successfully completed before : *
getPropertySetInfo
: in this method test
* one of normal properties is retrieved.
* Has OK status if NO normal properties exist or if value before
* method call is not equal to value after.
*/
public boolean _setPropertyValue() {
// requiredMethod("getPropertySetInfo()");
Object gValue = null;
Object sValue = null;
boolean result = true;
if ( PTT.normal.equals("none") ) {
System.out.println("*** No changeable properties found ***");
} else {
try {
gValue = oObj.getPropertyValue(PTT.normal);
sValue = ValueChanger.changePValue(gValue);
oObj.setPropertyValue(PTT.normal, sValue);
sValue = oObj.getPropertyValue(PTT.normal);
} catch (com.sun.star.beans.PropertyVetoException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.normal+"'");
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.normal+"'");
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.normal+"'");
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.normal+"'");
e.printStackTrace();
} // end of try-catch
result = !gValue.equals(sValue);
} //endif
return result;
} // end of setPropertyValue()
/**
* Tests getPropertyValue
method.
* Just call this method and checks for no exceptions
* Method tests to be successfully completed before : *
getPropertySetInfo
: in this method test
* one of normal properties is retrieved.
* Has OK status if NO normal properties exist or if no
* exceptions were thrown.
*/
public boolean _getPropertyValue() {
// requiredMethod("getPropertySetInfo()");
boolean result = true;
String toCheck = PTT.normal;
if ( PTT.normal.equals("none") ) {
toCheck = oObj.getPropertySetInfo().getProperties()[0].Name;
System.out.println("All properties are Read Only");
System.out.println("Using: "+toCheck);
}
try {
Object gValue = oObj.getPropertyValue(toCheck);
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occured while trying to get property '"+
PTT.normal+"'");
e.printStackTrace();
result = false;
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occured while trying to get property '"+
PTT.normal+"'");
e.printStackTrace();
result = false;
} // end of try-catch
return result;
}
/**
* Tests removePropertyChangeListener
method.
* Removes change listener, then changes bound property value
* and checks if the listener was NOT called.
* Method tests to be successfully completed before :
*
addPropertyChangeListener
: here listener
* was added.
* Has OK status if NO bound properties exist or if listener
* was not called and no exceptions arose.
*/
public boolean _removePropertyChangeListener() {
// requiredMethod("addPropertyChangeListener()");
propertyChanged = false;
boolean result = true;
if ( PTT.bound.equals("none") ) {
System.out.println("*** No bound properties found ***");
} else {
try {
propertyChanged = false;
oObj.removePropertyChangeListener(PTT.bound,PClistener);
Object gValue = oObj.getPropertyValue(PTT.bound);
oObj.setPropertyValue(PTT.bound,
ValueChanger.changePValue(gValue));
} catch (com.sun.star.beans.PropertyVetoException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.bound+"'");
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.bound+"'");
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.bound+"'");
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.bound+"'");
e.printStackTrace();
} // end of try-catch
result = !propertyChanged;
if (propertyChanged) {
System.out.println("propertyChangeListener was called after removing"+
" for '"+PTT.bound+"'");
}
} //endif
return result;
} // end of removePropertyChangeListener()
/**
* Tests removeVetoableChangeListener
method.
* Removes vetoable listener, then changes constrained property value
* and checks if the listener was NOT called.
* Method tests to be successfully completed before :
*
addPropertyChangeListener
: here vetoable listener
* was added.
* Has OK status if NO constrained properties exist or if listener
* was NOT called and no exceptions arose.
*/
public boolean _removeVetoableChangeListener() {
// requiredMethod("addVetoableChangeListener()");
vetoableChanged = false;
boolean result = true;
if ( PTT.constrained.equals("none") ) {
System.out.println("*** No constrained properties found ***");
} else {
try {
oObj.removeVetoableChangeListener(PTT.constrained,VClistener);
Object gValue = oObj.getPropertyValue(PTT.constrained);
oObj.setPropertyValue(PTT.constrained,
ValueChanger.changePValue(gValue));
} catch (com.sun.star.beans.PropertyVetoException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occured while trying to change "+
"property '"+ PTT.constrained+"'");
e.printStackTrace();
} // end of try-catch
result = !vetoableChanged;
if (vetoableChanged) {
System.out.println("vetoableChangeListener was called after "+
"removing for '"+PTT.constrained+"'");
}
} //endif
return result;
} // end of removeVetoableChangeListener()
/**
* Gets the properties being tested. Searches and stores by one
* property of each kind (Bound, Vetoable, Normal).
*/
public PropsToTest getPropsToTest(XPropertySetInfo xPSI) {
Property[] properties = xPSI.getProperties();
String bound = "";
String constrained = "";
String normal = "";
for (int i = 0; i < properties.length; i++) {
Property property = properties[i];
String name = property.Name;
System.out.println("Checking '"+name+"'");
boolean isWritable = ((property.Attributes &
PropertyAttribute.READONLY) == 0);
boolean isNotNull = ((property.Attributes &
PropertyAttribute.MAYBEVOID) == 0);
boolean isBound = ((property.Attributes &
PropertyAttribute.BOUND) != 0);
boolean isConstr = ((property.Attributes &
PropertyAttribute.CONSTRAINED) != 0);
boolean canChange = false;
if ( !isWritable ) System.out.println("Property '"+name+"' is READONLY");
if (name.endsWith("URL")) isWritable = false;
if (name.startsWith("Fill")) isWritable = false;
if (name.startsWith("Font")) isWritable = false;
if (name.startsWith("IsNumbering")) isWritable = false;
if (name.startsWith("LayerName")) isWritable = false;
if (name.startsWith("Line")) isWritable = false;
//if (name.equals("xinterfaceA") || name.equals("xtypeproviderA")
//|| name.equals("arAnyA")) isWritable=false;
if ( isWritable && isNotNull ) canChange = isChangeable(name);
if ( isWritable && isNotNull && isBound && canChange) {
bound+=name+";";
}
if ( isWritable && isNotNull && isConstr && canChange) {
constrained+=name+";";
}
if ( isWritable && isNotNull && canChange) normal+=name+";";
} // endfor
//get a random bound property
PTT.bound=getRandomString(bound);
System.out.println("Bound: "+PTT.bound);
//get a random constrained property
PTT.constrained=getRandomString(constrained);
System.out.println("Constrained: "+PTT.constrained);
//get a random normal property
PTT.normal=getRandomString(normal);
return PTT;
}
/**
* Retrieves one random property name from list (property names separated
* by ';') of property names.
*/
public String getRandomString(String str) {
String gRS = "none";
Random rnd = new Random();
if (str.equals("")) str = "none";
StringTokenizer ST=new StringTokenizer(str,";");
int nr = rnd.nextInt(ST.countTokens());
if (nr < 1) nr+=1;
for (int i=1; i