diff options
Diffstat (limited to 'qadevOOo/tests/java/ifc/io/_XObjectInputStream.java')
-rw-r--r-- | qadevOOo/tests/java/ifc/io/_XObjectInputStream.java | 174 |
1 files changed, 174 insertions, 0 deletions
diff --git a/qadevOOo/tests/java/ifc/io/_XObjectInputStream.java b/qadevOOo/tests/java/ifc/io/_XObjectInputStream.java new file mode 100644 index 000000000000..6f3d94e38e92 --- /dev/null +++ b/qadevOOo/tests/java/ifc/io/_XObjectInputStream.java @@ -0,0 +1,174 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +package ifc.io; + +import lib.MultiMethodTest; +import lib.Status; +import util.ValueComparer; + +import com.sun.star.beans.Property; +import com.sun.star.beans.XPropertySet; +import com.sun.star.io.XObjectInputStream; +import com.sun.star.io.XObjectOutputStream; +import com.sun.star.io.XPersistObject; +import com.sun.star.uno.UnoRuntime; + +/** +* Testing <code>com.sun.star.io.XObjectInputStream</code> +* interface methods: +* <ul> +* <li><code>readObject()</code></li> +* </ul> <p> +* This test needs the following object relations : +* <ul> +* <li> <code>'PersistObject'</code> (of type <code>Object</code>): +* object that supports interface <code>XPersistObject</code> </li> +* <ul> <p> +* After test completion object environment has to be recreated. +* @see com.sun.star.io.XObjectInputStream +* @see com.sun.star.io.XPersistObject +*/ +public class _XObjectInputStream extends MultiMethodTest { + + public XObjectInputStream oObj = null; + private Object objRead = null ; + private Object objWrite = null ; + + /** + * Test reads perisist object from stream and compares properties + * of the object with properties of persist object obtained + * from relation <code>'PersistObject'</code> <p> + * Has <b> OK </b> status if returned value isn't null and values + * of objects properties are equal. <p> + */ + public void _readObject() { + objWrite = tEnv.getObjRelation("PersistObject") ; + if (objWrite == null) { + log.println("PersistObject not found in relations") ; + tRes.tested("readObject()", false) ; + return ; + } + + // write the object + try { + XObjectOutputStream oStream = (XObjectOutputStream) + tEnv.getObjRelation("StreamWriter"); + oStream.writeObject((XPersistObject)objWrite); + } catch(com.sun.star.io.IOException e) { + log.println("Couldn't write object to stream"); + e.printStackTrace(log); + tRes.tested("readObject()", Status.skipped(false)); + return; + } + + try { + objRead = oObj.readObject() ; + } catch(com.sun.star.io.IOException e) { + log.println("Couldn't read object from stream"); + e.printStackTrace(log); + tRes.tested("readObject()", false) ; + return ; + } + + if (objRead == null) { + log.println("No object was read.") ; + tRes.tested("readObject()", false) ; + return ; + } + + XPropertySet props1 = null ; + XPropertySet props2 = null ; + + props1 = (XPropertySet) UnoRuntime.queryInterface + (XPropertySet.class, objRead) ; + + props2 = (XPropertySet) UnoRuntime.queryInterface + (XPropertySet.class, objWrite) ; + + if (props1 == null) { + log.println("Object read doesn't implement XPropertySet") ; + tRes.tested("readObject()", false) ; + return ; + } + if (props2 == null) { + log.println("Object written doesn't implement XPropertySet") ; + tRes.tested("readObject()", false) ; + return ; + } + + tRes.tested("readObject()", + compareProperties(props1, props2)) ; + } + + protected boolean compareProperties(XPropertySet props1, + XPropertySet props2) { + + Property[] p1 = props1.getPropertySetInfo().getProperties() ; + Property[] p2 = props2.getPropertySetInfo().getProperties() ; + + if (p1.length != p2.length) { + log.println("Number of properties differs") ; + return false ; + } + + boolean result = true ; + + for (int i = 0; i < p1.length; i++) { + String propName = p1[i].Name ; + + log.print("Comparing property '" + propName + "' ...") ; + boolean res = false ; + try { + res = ValueComparer.equalValue + (props1.getPropertyValue(propName), + props2.getPropertyValue(propName)) ; + } catch (com.sun.star.beans.UnknownPropertyException e) { + log.println("Not found !") ; + } catch (com.sun.star.lang.WrappedTargetException e) { + log.println(e) ; + } + + if (res) + log.println("OK.") ; + else + log.println("Different !") ; + + result &= res ; + } + + return result ; + } + + /** + * Forces object environment recreation. + */ + public void after() { + this.disposeEnvironment() ; + } +} + |