diff options
author | kadertarlan <kadertarlan1@gmail.com> | 2016-01-27 01:05:44 +0200 |
---|---|---|
committer | Björn Michaelsen <bjoern.michaelsen@canonical.com> | 2016-01-27 14:33:20 +0000 |
commit | 4a377f5d37a733e30de1c545c9e90eddd9dac9c3 (patch) | |
tree | 46ff7d8021cf25333b225b447130b2a4193c46fa /sw | |
parent | 34fed415c8cddc03d3d35a4cc70565ad49ab426e (diff) |
Convert Java unit test to Python (check_named_property_values.py)
Change-Id: I70d05395b8b5ca89c6a2ebf63c1b4a7760a1559e
Reviewed-on: https://gerrit.libreoffice.org/21829
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Björn Michaelsen <bjoern.michaelsen@canonical.com>
Diffstat (limited to 'sw')
-rw-r--r-- | sw/JunitTest_sw_complex.mk | 2 | ||||
-rw-r--r-- | sw/PythonTest_sw_python.mk | 1 | ||||
-rw-r--r-- | sw/qa/complex/writer/CheckNamedPropertyValues.java | 110 | ||||
-rw-r--r-- | sw/qa/python/check_named_property_values.py | 87 |
4 files changed, 88 insertions, 112 deletions
diff --git a/sw/JunitTest_sw_complex.mk b/sw/JunitTest_sw_complex.mk index 688ef19f9bde..e0aaa974841d 100644 --- a/sw/JunitTest_sw_complex.mk +++ b/sw/JunitTest_sw_complex.mk @@ -30,7 +30,6 @@ $(eval $(call gb_JunitTest_add_sourcefiles,sw_complex,\ sw/qa/complex/indeterminateState/CheckIndeterminateState \ sw/qa/complex/writer/CheckBookmarks \ sw/qa/complex/writer/CheckIndexedPropertyValues \ - sw/qa/complex/writer/CheckNamedPropertyValues \ sw/qa/complex/writer/CheckTable \ sw/qa/complex/writer/LoadSaveTest \ sw/qa/complex/writer/TestDocument \ @@ -51,7 +50,6 @@ $(eval $(call gb_JunitTest_add_classes,sw_complex,\ complex.writer.CheckBookmarks \ complex.writer.CheckTable \ complex.writer.CheckIndexedPropertyValues \ - complex.writer.CheckNamedPropertyValues \ complex.writer.TextPortionEnumerationTest \ )) diff --git a/sw/PythonTest_sw_python.mk b/sw/PythonTest_sw_python.mk index 44d7ff4d9776..e2efba026d19 100644 --- a/sw/PythonTest_sw_python.mk +++ b/sw/PythonTest_sw_python.mk @@ -18,6 +18,7 @@ $(eval $(call gb_PythonTest_add_modules,sw_python,$(SRCDIR)/sw/qa/python,\ check_flies \ check_fields \ check_cross_references \ + check_named_property_values \ check_styles \ check_table \ get_expression \ diff --git a/sw/qa/complex/writer/CheckNamedPropertyValues.java b/sw/qa/complex/writer/CheckNamedPropertyValues.java deleted file mode 100644 index d09ebb6b2f92..000000000000 --- a/sw/qa/complex/writer/CheckNamedPropertyValues.java +++ /dev/null @@ -1,110 +0,0 @@ -/* - * 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.writer; - -import com.sun.star.beans.PropertyValue; -import com.sun.star.container.XNameContainer; -import com.sun.star.uno.UnoRuntime; -import com.sun.star.uno.Type; -import org.junit.AfterClass; -import org.junit.BeforeClass; -import org.junit.Test; -import org.openoffice.test.OfficeConnection; -import static org.junit.Assert.*; - -/** - * - */ -public class CheckNamedPropertyValues { - @Test public void checkNamedPropertyValues() - throws com.sun.star.uno.Exception - { - Object instance = connection.getComponentContext().getServiceManager(). - createInstanceWithContext( "com.sun.star.document.NamedPropertyValues", connection.getComponentContext()); - XNameContainer xCont = UnoRuntime.queryInterface(XNameContainer.class, instance); - - assertNotNull("XNameContainer was queried but returned null.", xCont); - PropertyValue[] prop1 = new PropertyValue[1]; - prop1[0] = new PropertyValue(); - prop1[0].Name = "Jupp"; - prop1[0].Value = "GoodGuy"; - - PropertyValue[] prop2 = new PropertyValue[1]; - prop2[0] = new PropertyValue(); - prop2[0].Name = "Horst"; - prop2[0].Value = "BadGuy"; - - Type t = xCont.getElementType(); - assertFalse("Initial container is not empty.", xCont.hasElements()); - - xCont.insertByName("prop1", prop1); - PropertyValue[]ret = (PropertyValue[])xCont.getByName("prop1"); - assertEquals(prop1[0].Name, ret[0].Name); - assertEquals(prop1[0].Value, ret[0].Value); - xCont.replaceByName("prop1", prop2); - ret = (PropertyValue[])xCont.getByName("prop1"); - assertEquals(prop2[0].Name, ret[0].Name); - assertEquals(prop2[0].Value, ret[0].Value); - xCont.removeByName("prop1"); - assertFalse("Could not remove PropertyValue.", xCont.hasElements()); - xCont.insertByName("prop1", prop1); - xCont.insertByName("prop2", prop2); - assertTrue("Did not insert PropertyValue.", xCont.hasElements()); - String[] names = xCont.getElementNames(); - assertEquals("Not all element names were returned.", 2, names.length); - for (int i=0; i<names.length; i++) { - assertTrue( - "Got a wrong element name", - names[i].equals("prop1") || names[i].equals("prop2")); - } - - try { - xCont.insertByName("prop2", prop1); - fail("ElementExistException was not thrown."); - } - catch(com.sun.star.container.ElementExistException e) { - } - - try { - xCont.insertByName("prop3", "Example String"); - fail("IllegalArgumentException was not thrown."); - } - catch(com.sun.star.lang.IllegalArgumentException e) { - } - - try { - xCont.removeByName("prop3"); - fail("NoSuchElementException was not thrown."); - } - catch(com.sun.star.container.NoSuchElementException e) { - } - } - - @BeforeClass public static void setUpConnection() throws Exception { - connection.setUp(); - } - - @AfterClass public static void tearDownConnection() - throws InterruptedException, com.sun.star.uno.Exception - { - connection.tearDown(); - } - - private static final OfficeConnection connection = new OfficeConnection(); -} diff --git a/sw/qa/python/check_named_property_values.py b/sw/qa/python/check_named_property_values.py new file mode 100644 index 000000000000..9d7825b392e8 --- /dev/null +++ b/sw/qa/python/check_named_property_values.py @@ -0,0 +1,87 @@ +''' + 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 . +''' + +import unittest +import unohelper +import os +import uno +from org.libreoffice.unotest import UnoInProcess +from com.sun.star.beans import PropertyValue +from com.sun.star.container import XNameContainer +from org.libreoffice.unotest import OfficeConnection + + +class CheckNamedPropertyValues(unittest.TestCase): + + @classmethod + def setUpClass(cls): + cls._uno = UnoInProcess() + cls._uno.setUp() + cls.xContext = cls._uno.getContext() + cls.xDoc = cls._uno.openEmptyWriterDoc() + + @classmethod + def tearDownClass(cls): + cls._uno.tearDown() + + + def test_checkNamedPropertyValues(self): + + xServiceManager = self.xContext.ServiceManager + xCont = xServiceManager.createInstanceWithContext('com.sun.star.document.NamedPropertyValues', self.xContext) + + p1 = PropertyValue(Name="Jupp", Value="GoodGuy") + prop1 = uno.Any("[]com.sun.star.beans.PropertyValue", (p1,)) + + p2 = PropertyValue(Name="Horst", Value="BadGuy") + prop2 = uno.Any("[]com.sun.star.beans.PropertyValue", (p2,)) + + t = xCont.getElementType() + self.assertFalse(xCont.hasElements()) #Initial container is not empty + + uno.invoke(xCont, "insertByName", ("prop1", prop1)) + ret = xCont["prop1"] + self.assertEqual(p1.Name, ret[0].Name) + self.assertEqual(p1.Value, ret[0].Value) + + uno.invoke(xCont, "replaceByName", ("prop1", prop2)) + ret = xCont["prop1"] + self.assertEqual(p2.Name, ret[0].Name) + self.assertEqual(p2.Value, ret[0].Value) + + xCont.removeByName("prop1") + self.assertFalse(xCont.hasElements()) #Could not remove PropertyValue. + uno.invoke(xCont, "insertByName", ("prop1", prop1)) + uno.invoke(xCont, "insertByName", ("prop2", prop2)) + self.assertTrue(xCont.hasElements()) #Did not insert PropertyValue + names = xCont.getElementNames() + self.assertEqual(2, len(names)) #Not all element names were returned + for i in range(len(names)): + self.assertTrue( names[i]=="prop1" or names[i]=="prop2") #Got a wrong element name + + with self.assertRaises(Exception): + uno.invoke(xCont, "insertByName", ("prop2", prop1)) + + with self.assertRaises(Exception): + uno.invoke(xCont, "insertByName",("prop3", "Example String")) + + with self.assertRaises(Exception): + xCont.removeByName("prop3") + + + |