tdf#97362 CalcRTL unittest partially migarted to python (CalcRTL.py)
java checkSpreadsheetProperties to python testSpreadsheetProperties Change-Id: Ifd342d3f47aef8a64a0421b6bb7f2a643bdc6da8 Reviewed-on: https://gerrit.libreoffice.org/38159 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Miklos Vajna <vmiklos@collabora.co.uk>
This commit is contained in:
parent
a8124c2eaf
commit
a87d79a1fa
4 changed files with 98 additions and 37 deletions
|
@ -126,6 +126,12 @@ $(eval $(call gb_Module_add_perfcheck_targets,sc,\
|
|||
CppunitTest_sc_tablesheetobj \
|
||||
))
|
||||
|
||||
ifneq ($(DISABLE_PYTHON),TRUE)
|
||||
$(eval $(call gb_Module_add_subsequentcheck_targets,sc,\
|
||||
PythonTest_sc_python \
|
||||
))
|
||||
endif
|
||||
|
||||
# screenshots
|
||||
$(eval $(call gb_Module_add_screenshot_targets,sc,\
|
||||
CppunitTest_sc_screenshots \
|
||||
|
|
16
sc/PythonTest_sc_python.mk
Normal file
16
sc/PythonTest_sc_python.mk
Normal file
|
@ -0,0 +1,16 @@
|
|||
# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
|
||||
#
|
||||
# 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/.
|
||||
#
|
||||
|
||||
$(eval $(call gb_PythonTest_PythonTest,sc_python))
|
||||
|
||||
$(eval $(call gb_PythonTest_add_modules,sc_python,$(SRCDIR)/sc/qa/python,\
|
||||
CalcRTL \
|
||||
))
|
||||
|
||||
# vim: set noet sw=4 ts=4:
|
|
@ -65,43 +65,6 @@ public class CalcRTL
|
|||
* 3. A calc document is opened and a shape inserted, afterwards the effect of changing the TableLayout to the shape is checked
|
||||
*/
|
||||
|
||||
/*
|
||||
* In this method a spreadsheet document is opened<br>
|
||||
* afterwards all properties of the Spreadsheet are checked.<br>
|
||||
* <p>
|
||||
* These are
|
||||
* <ul>
|
||||
*<li> IsVisible
|
||||
*<li> PageStyle
|
||||
*<li> TableLayout
|
||||
*</ul>
|
||||
*/
|
||||
@Test public void checkSpreadsheetProperties() {
|
||||
assertTrue("Couldn't open document", openSpreadsheetDocument());
|
||||
|
||||
XPropertySet set = UnoRuntime.queryInterface(
|
||||
XPropertySet.class, getSpreadsheet());
|
||||
|
||||
// Make sure there are at least 2 sheets, otherwise hiding a sheet won't work
|
||||
xSheetDoc.getSheets().insertNewByName("Some Sheet", (short)0);
|
||||
|
||||
assertTrue("Problems when setting property 'IsVisible'",
|
||||
changeProperty(set, "IsVisible", Boolean.FALSE));
|
||||
assertTrue("Problems when setting property 'IsVisible'",
|
||||
changeProperty(set, "IsVisible", Boolean.TRUE));
|
||||
assertTrue("Problems when setting property 'PageStyle'",
|
||||
changeProperty(set, "PageStyle", "Report"));
|
||||
assertTrue("Problems when setting property 'PageStyle'",
|
||||
changeProperty(set, "PageStyle", "Default"));
|
||||
assertTrue("Problems when setting property 'TableLayout'",
|
||||
changeProperty(set, "TableLayout",
|
||||
Short.valueOf(com.sun.star.text.WritingMode2.RL_TB)));
|
||||
assertTrue("Problems when setting property 'TableLayout'",
|
||||
changeProperty(set, "TableLayout",
|
||||
Short.valueOf(com.sun.star.text.WritingMode2.LR_TB)));
|
||||
assertTrue("Couldn't close document", closeSpreadsheetDocument());
|
||||
}
|
||||
|
||||
/*
|
||||
* In this method a spreadsheet document is opened and a shape inserted<br>
|
||||
* afterwards all calc specific properties of the Shape are checked.<br>
|
||||
|
|
76
sc/qa/python/CalcRTL.py
Normal file
76
sc/qa/python/CalcRTL.py
Normal file
|
@ -0,0 +1,76 @@
|
|||
'''
|
||||
This is 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
|
||||
from org.libreoffice.unotest import UnoInProcess
|
||||
from com.sun.star.text.WritingMode2 import RL_TB as __WritingMode2_RL_TB__
|
||||
from com.sun.star.text.WritingMode2 import LR_TB as __WritingMode2_LR_TB__
|
||||
|
||||
class CalcRTL(unittest.TestCase):
|
||||
xSheetDoc = None
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
cls._uno = UnoInProcess()
|
||||
cls._uno.setUp()
|
||||
|
||||
@classmethod
|
||||
def tearDownClass(cls):
|
||||
cls._uno.tearDown()
|
||||
|
||||
def testSpreadsheetProperties(self):
|
||||
self.assertTrue(self.openSpreadsheetDocument(), msg="Couldn't open document")
|
||||
|
||||
set= self.getSpreadsheet()
|
||||
# Make sure there are at least 2 sheets, otherwise hiding a sheet won't work
|
||||
self.xSheetDoc.getSheets().insertNewByName("Some Sheet", 0)
|
||||
|
||||
self._uno.checkProperties(set,{'IsVisible': False}, self)
|
||||
self._uno.checkProperties(set,{'IsVisible': True}, self)
|
||||
self._uno.checkProperties(set,{'PageStyle': 'Report'}, self)
|
||||
self._uno.checkProperties(set,{'PageStyle': 'Default'}, self)
|
||||
self._uno.checkProperties(set,{'TableLayout': __WritingMode2_RL_TB__}, self)
|
||||
self._uno.checkProperties(set,{'TableLayout': __WritingMode2_LR_TB__}, self)
|
||||
|
||||
self.assertTrue(self.closeSpreadsheetDocument(), msg="Couldn't close document")
|
||||
|
||||
def openSpreadsheetDocument(self):
|
||||
worked = True
|
||||
print("creating a sheetdocument")
|
||||
try:
|
||||
self.xSheetDoc = self._uno.openEmptyCalcDoc()
|
||||
except Exception:
|
||||
worked = False
|
||||
raise
|
||||
return worked
|
||||
|
||||
def closeSpreadsheetDocument(self):
|
||||
worked = True
|
||||
print(" disposing xSheetDoc ")
|
||||
try:
|
||||
self.xSheetDoc.close(0)
|
||||
except Exception:
|
||||
worked = False
|
||||
raise
|
||||
return worked
|
||||
|
||||
def getSpreadsheet(self):
|
||||
return self.xSheetDoc.getSheets().getByIndex(0)
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
Loading…
Reference in a new issue