/* * 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.reflection; import com.sun.star.reflection.XIdlClass; import com.sun.star.reflection.XIdlReflection; import com.sun.star.uno.TypeClass; import lib.MultiMethodTest; /** * Testing com.sun.star.reflection.XIdlReflection * interface methods : *

* @see com.sun.star.reflection.XIdlReflection */ public class _XIdlReflection extends MultiMethodTest{ public XIdlReflection oObj = null; protected static final String typeName = "com.sun.star.container.XNameAccess"; /** * Test calls the method and checks returned interface * com.sun.star.container.XNameAccess: gets the name and the * type and checks it.

* Has OK status if returned name is equal to the name of the * interface that was passed as parameter in the method call and if returned * type is equal to com.sun.star.uno.TypeClass.INTERFACE.

*/ public void _forName() { boolean result = true; XIdlClass cls = oObj.forName(typeName); if (cls != null) { log.println("Class name: " + cls.getName()); result &= cls.getTypeClass() == TypeClass.INTERFACE; result &= typeName.equals(cls.getName()); } else { log.println("Method returned null"); result = false; } tRes.tested("forName()", result); } /** * Test creates the instance of com.sun.star.io.Pipe, * calls the method using this instance as parameter and checks returned * value.

* Has OK status if the instance was created successfully, if * returned value isn't null and no exceptions were thrown.

*/ public void _getType() { Object obj = null; try { obj = tParam.getMSF(). createInstance("com.sun.star.io.Pipe") ; } catch (com.sun.star.uno.Exception e) { log.println("Can't create object"); tRes.tested("getType()", false); return; } if (obj == null) { log.println("Object wasn't created !"); tRes.tested("getType()", false); } XIdlClass cls = oObj.getType(obj); if (cls != null) { log.println("The name is " + cls.getName()); } tRes.tested("getType()", cls != null); } }