/*
* 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 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 util.ValueChanger;
import util.utils;
/**
* Testing < code > com . sun . star . beans . XPropertySet < / code >
* interface methods :
* < ul >
* < li > < code > getPropertySetInfo ( ) < / code > < / li >
* < li > < code > setPropertyValue ( ) < / code > < / li >
* < li > < code > getPropertyValue ( ) < / code > < / li >
* < li > < code > addPropertyChangeListener ( ) < / code > < / li >
* < li > < code > removePropertyChangeListener ( ) < / code > < / li >
* < li > < code > addVetoableChangeListener ( ) < / code > < / li >
* < li > < code > removeVetoableChangeListener ( ) < / code > < / li >
* < / ul >
* @ see com . sun . star . beans . XPropertySet
*/
public class _XPropertySet {
/**
* The object that is tested .
*/
private final XPropertySet oObj;
/**
* The test parameters
*/
private final TestParameters param;
/**
* Flag that indicates change listener was called .
*/
private boolean propertyChanged = false ;
/**
* The own property change listener
*/
private final XPropertyChangeListener PClistener = new MyChangeListener();
/**
* Listener that must be called on bound property changing .
*/
private class MyChangeListener implements XPropertyChangeListener {
/**
* Just set < code > propertyChanged < / code > flag to true .
*/
public void propertyChange(PropertyChangeEvent e) {
propertyChanged = true ;
}
public void disposing (EventObject obj) {}
}
/**
* Flag that indicates veto listener was called .
*/
private boolean vetoableChanged = false ;
/**
* The own vetoable change listener
*/
private final XVetoableChangeListener VClistener = new MyVetoListener();
/**
* Listener that must be called on constrained property changing .
*/
private class MyVetoListener implements XVetoableChangeListener {
/**
* Just set < code > vetoableChanged < / code > flag to true .
*/
public void vetoableChange(PropertyChangeEvent e) {
vetoableChanged = true ;
}
public void disposing (EventObject obj) {}
}
/**
* Properties to test
*/
private final PropsToTest PTT = new PropsToTest();
/**
* Structure that collects three properties of each type to test :
* Constrained , Bound and Normal .
*/
private class PropsToTest {
private String constrained = null ;
private String bound = null ;
String normal = null ;
}
/**
* Constructor : gets the object to test , a logger and the test parameters
* @ param xObj The test object
* @ param param The test parameters
*/
public _XPropertySet(XPropertySet xObj/*, LogWriter log*/, TestParameters param) {
oObj = xObj;
// this.log = log;
this .param = param;
}
/**
* Tests method < code > getPropertySetInfo < / code > . After test completed
* call { @ link # getPropsToTest } method to retrieve different kinds
* of properties to test then . < p >
* Has OK status if not null < code > XPropertySetInfo < / code >
* object returned . < p >
* Since < code > getPropertySetInfo < / code > is optional , it may return null ,
* if it is not implemented . This method uses then an object relation
* < code > PTT < / code > ( Properties To Test ) to determine available properties .
* All tests for services without < code > getPropertySetInfo < / code > 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 . < p >
* Method tests to be successfully completed before :
* < ul >
* < li > < code > getPropertySetInfo < / code > : in this method test
* one of bound properties is retrieved . < / li >
* < / ul > < p >
* 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 occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred 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 . < p >
* Method tests to be successfully completed before :
* < ul >
* < li > < code > getPropertySetInfo < / code > : in this method test
* one of constrained properties is retrieved . < / li >
* < / ul > < p >
* Has OK status if NO constrained properties exist or if listener
* was successfully called .
*/
public boolean _addVetoableChangeListener() {
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 occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred 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 < code > setPropertyValue < / code > method .
* Stores value before call , and compares it with value after
* call . < p >
* Method tests to be successfully completed before :
* < ul >
* < li > < code > getPropertySetInfo < / code > : in this method test
* one of normal properties is retrieved . < / li >
* < / ul > < p >
* Has OK status if NO normal properties exist or if value before
* method call is not equal to value after .
*/
public boolean _setPropertyValue() {
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 occurred while trying to change " +
"property '" + PTT.normal+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.normal+"'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.normal+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.normal+"'" );
e.printStackTrace();
} // end of try-catch
result = !gValue.equals(sValue);
} //endif
return result;
} // end of setPropertyValue()
/**
* Tests < code > getPropertyValue < / code > method .
* Just call this method and checks for no exceptions < p >
* Method tests to be successfully completed before :
* < ul >
* < li > < code > getPropertySetInfo < / code > : in this method test
* one of normal properties is retrieved . < / li >
* < / ul > < p >
* Has OK status if NO normal properties exist or if no
* exceptions were thrown .
*/
public boolean _getPropertyValue() {
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 {
oObj.getPropertyValue(toCheck);
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to get property '" +
PTT.normal+"'" );
e.printStackTrace();
result = false ;
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred while trying to get property '" +
PTT.normal+"'" );
e.printStackTrace();
result = false ;
} // end of try-catch
return result;
}
/**
* Tests < code > removePropertyChangeListener < / code > method .
* Removes change listener , then changes bound property value
* and checks if the listener was NOT called .
* Method tests to be successfully completed before :
* < ul >
* < li > < code > addPropertyChangeListener < / code > : here listener
* was added . < / li >
* < / ul > < p >
* Has OK status if NO bound properties exist or if listener
* was not called and no exceptions arose .
*/
public boolean _removePropertyChangeListener() {
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 occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.bound+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred 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 < code > removeVetoableChangeListener < / code > method .
* Removes vetoable listener , then changes constrained property value
* and checks if the listener was NOT called .
* Method tests to be successfully completed before :
* < ul >
* < li > < code > addPropertyChangeListener < / code > : here vetoable listener
* was added . < / li >
* < / ul > < p >
* Has OK status if NO constrained properties exist or if listener
* was NOT called and no exceptions arose .
*/
public boolean _removeVetoableChangeListener() {
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 occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("Exception occurred while trying to change " +
"property '" + PTT.constrained+"'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("Exception occurred 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 ) .
*/
private 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 ( 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 .
*/
private 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<nr+1 ; i++) gRS = ST.nextToken();
return gRS;
}
private boolean isChangeable(String name) {
boolean hasChanged = false ;
try {
Object getProp = oObj.getPropertyValue(name);
System.out.println("Getting: " +getProp);
Object setValue = null ;
if (getProp != null ) {
if (!utils.isVoid(getProp))
setValue = ValueChanger.changePValue(getProp);
else System.out.println("Property '" +name+
"' is void but MAYBEVOID isn't set" );
} else System.out.println("Property '" +name+"'is null and can't be changed" );
if (name.equals("LineStyle" )) setValue = null ;
if (setValue != null ) {
oObj.setPropertyValue(name, setValue);
System.out.println("Setting to :" +setValue);
hasChanged = (! getProp.equals(oObj.getPropertyValue(name)));
} else System.out.println("Couldn't change Property '" +name+"'" );
} catch (com.sun.star.beans.PropertyVetoException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
} catch (com.sun.star.lang.IllegalArgumentException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
} catch (com.sun.star.beans.UnknownPropertyException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
} catch (com.sun.star.lang.WrappedTargetException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
} catch (com.sun.star.uno.RuntimeException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
} catch (java.lang.ArrayIndexOutOfBoundsException e) {
System.out.println("'" + name + "' throws exception '" + e + "'" );
e.printStackTrace();
}
return hasChanged;
}
} // finish class _XPropertySet
Messung V0.5 in Prozent C=94 H=95 G=94
¤ Dauer der Verarbeitung: 0.27 Sekunden
(vorverarbeitet am 2026-06-10)
¤
*© Formatika GbR, Deutschland