1
0
Fork 0
libreoffice/sw/qa/python/check_table.py
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

661 lines
29 KiB
Python

#! /usr/bin/env python
# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*-
#
# 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/.
#
import math
import unittest
from org.libreoffice.unotest import UnoInProcess
from com.sun.star.beans import PropertyValue
from com.sun.star.uno import RuntimeException
from com.sun.star.table import BorderLine
from com.sun.star.table import BorderLine2
from com.sun.star.table.BorderLineStyle import (DOUBLE, SOLID, EMBOSSED,
THICKTHIN_LARGEGAP, DASHED, DOTTED)
from com.sun.star.lang import Locale
class CheckTable(unittest.TestCase):
def _fill_table(self, xTable):
for x in range(3):
for y in range(3):
xTable[y, x].String = 'Cell %d %d' % (x, y)
def _check_table(self, xTable):
for x in range(3):
for y in range(3):
self.assertEqual('Cell %d %d' % (x, y), xTable[y, x].String)
@classmethod
def setUpClass(cls):
cls._uno = UnoInProcess()
cls._uno.setUp()
cls.OOLineVeryThin = 18
@classmethod
def tearDownClass(cls):
cls._uno.tearDown()
def __test_borderAsserts(self, xBorderLine, line_valid):
self.assertTrue(line_valid)
self.assertEqual(0, xBorderLine.InnerLineWidth)
self.assertEqual(self.OOLineVeryThin, xBorderLine.OuterLineWidth)
self.assertEqual(0, xBorderLine.LineDistance)
self.assertEqual(0, xBorderLine.Color)
def __test_borderAssertsWithLineStyle(self, xBorderLine, line_valid):
self.__test_borderAsserts(xBorderLine, line_valid)
self.assertEqual(self.OOLineVeryThin, xBorderLine.LineWidth)
self.assertEqual(SOLID, xBorderLine.LineStyle)
def __test_borderDistance(self, border):
self.assertTrue(border.IsDistanceValid)
self.assertEqual(97, border.Distance)
def test_tableborder(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
# insert table
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(3, 3)
xText = xDoc.getText()
xCursor = xText.createTextCursor()
xText.insertTextContent(xCursor, xTable, False)
border_distances = xTable.TableBorderDistances
self.assertEqual(97, border_distances.TopDistance)
self.assertEqual(97, border_distances.BottomDistance)
self.assertEqual(97, border_distances.LeftDistance)
self.assertEqual(97, border_distances.RightDistance)
self.assertEqual(True, border_distances.IsTopDistanceValid)
self.assertEqual(True, border_distances.IsBottomDistanceValid)
self.assertEqual(True, border_distances.IsLeftDistanceValid)
self.assertEqual(True, border_distances.IsRightDistanceValid)
border = xTable.getPropertyValue("TableBorder")
self.__test_borderAsserts(border.TopLine, border.IsTopLineValid)
self.__test_borderAsserts(border.BottomLine, border.IsBottomLineValid)
self.__test_borderAsserts(border.LeftLine, border.IsLeftLineValid)
self.__test_borderAsserts(border.RightLine, border.IsRightLineValid)
self.__test_borderAsserts(border.HorizontalLine, border.IsHorizontalLineValid)
self.__test_borderAsserts(border.VerticalLine, border.IsVerticalLineValid)
self.__test_borderDistance(border)
# set border
border.TopLine = BorderLine(0, 11, 19, 19)
border.BottomLine = BorderLine(0xFF, 00, 11, 00)
border.HorizontalLine = BorderLine(0xFF00, 00, 90, 00)
xTable.setPropertyValue("TableBorder", border)
# read set border
border = xTable.getPropertyValue("TableBorder")
self.assertTrue(border.IsTopLineValid)
self.assertEqual(11, border.TopLine.InnerLineWidth)
self.assertEqual(19, border.TopLine.OuterLineWidth)
self.assertEqual(19, border.TopLine.LineDistance)
self.assertEqual(0, border.TopLine.Color)
self.assertTrue(border.IsBottomLineValid)
self.assertEqual(0, border.BottomLine.InnerLineWidth)
self.assertEqual(11, border.BottomLine.OuterLineWidth)
self.assertEqual(0, border.BottomLine.LineDistance)
self.assertEqual(0xFF, border.BottomLine.Color)
self.__test_borderAsserts(border.LeftLine, border.IsLeftLineValid)
self.__test_borderAsserts(border.RightLine, border.IsRightLineValid)
self.assertTrue(border.IsHorizontalLineValid)
self.assertEqual(0, border.HorizontalLine.InnerLineWidth)
self.assertEqual(90, border.HorizontalLine.OuterLineWidth)
self.assertEqual(0, border.HorizontalLine.LineDistance)
self.assertEqual(0xFF00, border.HorizontalLine.Color)
self.__test_borderAsserts(border.VerticalLine, border.IsVerticalLineValid)
self.__test_borderDistance(border)
border2 = xTable.getPropertyValue("TableBorder2")
self.assertTrue(border2.IsTopLineValid)
self.assertEqual(11, border2.TopLine.InnerLineWidth)
self.assertEqual(19, border2.TopLine.OuterLineWidth)
self.assertEqual(19, border2.TopLine.LineDistance)
self.assertEqual(0, border2.TopLine.Color)
self.assertEqual(DOUBLE, border2.TopLine.LineStyle)
self.assertEqual(49, border2.TopLine.LineWidth)
self.assertTrue(border2.IsBottomLineValid)
self.assertEqual(0, border2.BottomLine.InnerLineWidth)
self.assertEqual(11, border2.BottomLine.OuterLineWidth)
self.assertEqual(0, border2.BottomLine.LineDistance)
self.assertEqual(0xFF, border2.BottomLine.Color)
self.assertEqual(SOLID, border2.BottomLine.LineStyle)
self.assertEqual(11, border2.BottomLine.LineWidth)
self.__test_borderAssertsWithLineStyle(border2.LeftLine, border2.IsLeftLineValid)
self.__test_borderAssertsWithLineStyle(border2.RightLine, border2.IsRightLineValid)
self.assertTrue(border2.IsHorizontalLineValid)
self.assertEqual(0, border2.HorizontalLine.InnerLineWidth)
self.assertEqual(90, border2.HorizontalLine.OuterLineWidth)
self.assertEqual(0, border2.HorizontalLine.LineDistance)
self.assertEqual(0xFF00, border2.HorizontalLine.Color)
self.assertEqual(SOLID, border2.HorizontalLine.LineStyle)
self.assertEqual(90, border2.HorizontalLine.LineWidth)
self.__test_borderAssertsWithLineStyle(border2.VerticalLine, border2.IsVerticalLineValid)
self.__test_borderDistance(border2)
# set border2
border2.RightLine = BorderLine2(0, 0, 0, 0, THICKTHIN_LARGEGAP, 120)
border2.LeftLine = BorderLine2(0, 0, 0, 0, EMBOSSED, 90)
border2.VerticalLine = BorderLine2(0xFF, 0, 90, 0, DOTTED, 0)
border2.HorizontalLine = BorderLine2(0xFF00, 0, 0, 0, DASHED, 11)
xTable.setPropertyValue("TableBorder2", border2)
# read set border2
border2 = xTable.getPropertyValue("TableBorder2")
self.assertTrue(border2.IsTopLineValid)
self.assertEqual(11, border2.TopLine.InnerLineWidth)
self.assertEqual(19, border2.TopLine.OuterLineWidth)
self.assertEqual(19, border2.TopLine.LineDistance)
self.assertEqual(0, border2.TopLine.Color)
self.assertEqual(DOUBLE, border2.TopLine.LineStyle)
self.assertEqual(49, border2.TopLine.LineWidth)
self.assertTrue(border2.IsBottomLineValid)
self.assertEqual(0, border2.BottomLine.InnerLineWidth)
self.assertEqual(11, border2.BottomLine.OuterLineWidth)
self.assertEqual(0, border2.BottomLine.LineDistance)
self.assertEqual(0xFF, border2.BottomLine.Color)
self.assertEqual(SOLID, border2.BottomLine.LineStyle)
self.assertEqual(11, border2.BottomLine.LineWidth)
self.assertTrue(border2.IsLeftLineValid)
self.assertEqual(23, border2.LeftLine.InnerLineWidth)
self.assertEqual(23, border2.LeftLine.OuterLineWidth)
self.assertEqual(46, border2.LeftLine.LineDistance)
self.assertEqual(0, border2.LeftLine.Color)
self.assertEqual(EMBOSSED, border2.LeftLine.LineStyle)
self.assertEqual(90, border2.LeftLine.LineWidth)
self.assertTrue(border2.IsRightLineValid)
self.assertEqual(53, border2.RightLine.InnerLineWidth)
self.assertEqual(26, border2.RightLine.OuterLineWidth)
self.assertEqual(41, border2.RightLine.LineDistance)
self.assertEqual(0, border2.RightLine.Color)
self.assertEqual(THICKTHIN_LARGEGAP, border2.RightLine.LineStyle)
self.assertEqual(120, border2.RightLine.LineWidth)
self.assertTrue(border2.IsHorizontalLineValid)
self.assertEqual(0, border2.HorizontalLine.InnerLineWidth)
self.assertEqual(11, border2.HorizontalLine.OuterLineWidth)
self.assertEqual(0, border2.HorizontalLine.LineDistance)
self.assertEqual(0xFF00, border2.HorizontalLine.Color)
self.assertEqual(DASHED, border2.HorizontalLine.LineStyle)
self.assertEqual(11, border2.HorizontalLine.LineWidth)
self.assertTrue(border2.IsVerticalLineValid)
self.assertEqual(0, border2.VerticalLine.InnerLineWidth)
self.assertEqual(90, border2.VerticalLine.OuterLineWidth)
self.assertEqual(0, border2.VerticalLine.LineDistance)
self.assertEqual(0xFF, border2.VerticalLine.Color)
self.assertEqual(DOTTED, border2.VerticalLine.LineStyle)
self.assertEqual(90, border2.VerticalLine.LineWidth)
self.__test_borderDistance(border2)
# close document
xDoc.dispose()
def test_fdo58242(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
# insert table
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(3, 3)
xText = xDoc.getText()
xCursor = xText.createTextCursor()
xText.insertTextContent(xCursor, xTable, False)
# get anchor
xAnchor = xTable.getAnchor()
# check all properties on the anchor - shouldn't crash despite
# pointing to a non-SwTextNode
xPropsInfo = xAnchor.getPropertySetInfo()
for i in xPropsInfo.getProperties():
try:
xAnchor.getPropertyValue(i.Name)
except RuntimeException:
pass
# close document
xDoc.dispose()
def test_descriptions(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
# insert table
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(3, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
self.assertEqual(3, xTable.Rows.Count)
self.assertEqual(3, xTable.Columns.Count)
xTable.TableName = "foo"
self.assertEqual("foo", xTable.TableName)
xTable.TableTemplateName = "bar"
self.assertEqual("bar", xTable.TableTemplateName)
# fill table
self._fill_table(xTable)
self._check_table(xTable)
# check without labels first
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
self.assertEqual(0, len(xTable.RowDescriptions))
self.assertEqual(0, len(xTable.ColumnDescriptions))
self.RowDescriptions = ('foo', 'bar', 'baz') # no labels, thus noop
self.ColumnDescriptions = ('foo', 'bar', 'baz') # no labels, thus noop
self._check_table(xTable)
# now check with labels
xTable.ChartColumnAsLabel = True
xTable.ChartRowAsLabel = True
self.assertEqual(2, len(xTable.RowDescriptions))
self.assertEqual('Cell 0 1', xTable.RowDescriptions[0])
self.assertEqual('Cell 0 2', xTable.RowDescriptions[1])
self.assertEqual(2, len(xTable.ColumnDescriptions))
self.assertEqual('Cell 1 0', xTable.ColumnDescriptions[0])
self.assertEqual('Cell 2 0', xTable.ColumnDescriptions[1])
with self.assertRaises(Exception):
xTable.RowDescriptions = ('foo',) # too short
with self.assertRaises(Exception):
xTable.ColumnDescriptions = ('foo',) # too short
self._check_table(xTable)
xTable.RowDescriptions = ('fooRow', 'bazRow')
xTable.ColumnDescriptions = ('fooColumn', 'bazColumn')
self.assertEqual('fooRow', xTable[1, 0].String)
self.assertEqual('bazRow', xTable[2, 0].String)
self.assertEqual('fooColumn', xTable[0, 1].String)
self.assertEqual('bazColumn', xTable[0, 2].String)
xTable[1, 0].String = 'Cell 0 1' # reset changes values ...
xTable[2, 0].String = 'Cell 0 2'
xTable[0, 1].String = 'Cell 1 0'
xTable[0, 2].String = 'Cell 2 0'
self._check_table(xTable) # ... to ensure the rest was untouched
# check disconnected table excepts, but doesn't crash
xTable2 = xDoc.createInstance("com.sun.star.text.TextTable")
xTable2.initialize(3, 3)
with self.assertRaises(Exception):
xTable2.RowDescriptions
with self.assertRaises(Exception):
xTable2.ColumnDescriptions
xDoc.dispose()
def test_getset_data(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
# insert table
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(4, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
# roundtrip
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12))
self.assertEqual(xTable.Data, ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12)))
# missing row
with self.assertRaises(Exception):
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9))
# missing column
with self.assertRaises(Exception):
xTable.Data = ((1, 2), (4, 5), (7, 8), (10, 11))
# with labels
xTable.ChartColumnAsLabel = True
xTable.ChartRowAsLabel = True
self.assertEqual(xTable.Data, ((5, 6), (8, 9), (11, 12)))
xTable.Data = ((55, 66), (88, 99), (1111, 1212))
xTable.ChartColumnAsLabel = True
xTable.ChartRowAsLabel = False
self.assertEqual(xTable.Data, ((2, 3), (55, 66), (88, 99), (1111, 1212)))
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = True
self.assertEqual(xTable.Data, ((4, 55, 66), (7, 88, 99), (10, 1111, 1212)))
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
self.assertEqual(xTable.Data, ((1, 2, 3), (4, 55, 66), (7, 88, 99), (10, 1111, 1212)))
xDoc.dispose()
def test_remove_colrow(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(4, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12))
xRows = xTable.Rows
self.assertEqual(xRows.ImplementationName, 'SwXTableRows')
self.assertTrue(xRows.supportsService('com.sun.star.text.TableRows'))
self.assertFalse(xRows.supportsService('foo'))
self.assertIn('com.sun.star.text.TableRows', xRows.SupportedServiceNames)
self.assertNotIn('foo', xRows.SupportedServiceNames)
xRows.removeByIndex(1, 2)
self.assertEqual(xTable.Data, ((1, 2, 3), (10, 11, 12)))
xCols = xTable.Columns
self.assertEqual(xCols.ImplementationName, 'SwXTableColumns')
self.assertTrue(xCols.supportsService('com.sun.star.text.TableColumns'))
self.assertFalse(xCols.supportsService('foo'))
self.assertIn('com.sun.star.text.TableColumns', xCols.SupportedServiceNames)
self.assertNotIn('foo', xCols.SupportedServiceNames)
xCols.removeByIndex(1, 1)
self.assertEqual(xTable.Data, ((1, 3), (10, 12)))
xDoc.dispose()
def test_insert_colrow(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(4, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12))
xRows = xTable.Rows
xRows.insertByIndex(1, 2)
self.assertEqual(xTable.Data[0], (1, 2, 3))
self.assertEqual(xTable.Data[3], (4, 5, 6))
self.assertEqual(xTable.Data[4], (7, 8, 9))
self.assertEqual(xTable.Data[5], (10, 11, 12))
for x in range(3):
self.assertTrue(math.isnan(xTable.Data[1][x]))
self.assertTrue(math.isnan(xTable.Data[2][x]))
xCols = xTable.Columns
xCols.insertByIndex(1, 1)
self.assertEqual(xTable.Data[0][0], 1)
self.assertTrue(math.isnan(xTable.Data[0][1]))
self.assertEqual(xTable.Data[0][2], 2)
self.assertEqual(xTable.Data[0][3], 3)
self.assertEqual(xTable.Data[3][0], 4)
self.assertTrue(math.isnan(xTable.Data[3][1]))
self.assertEqual(xTable.Data[3][2], 5)
self.assertEqual(xTable.Data[3][3], 6)
self.assertEqual(xTable.Data[4][0], 7)
self.assertTrue(math.isnan(xTable.Data[4][1]))
self.assertEqual(xTable.Data[4][2], 8)
self.assertEqual(xTable.Data[4][3], 9)
self.assertEqual(xTable.Data[5][0], 10)
self.assertTrue(math.isnan(xTable.Data[5][1]))
self.assertEqual(xTable.Data[5][2], 11)
self.assertEqual(xTable.Data[5][3], 12)
for x in range(4):
self.assertTrue(math.isnan(xTable.Data[1][x]))
self.assertTrue(math.isnan(xTable.Data[2][x]))
xDoc.dispose()
def test_chartdataprovider(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(4, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12))
self.assertTrue(xTable.Name == 'Table1')
self.assertIn('com.sun.star.text.GenericTextDocument', xDoc.SupportedServiceNames)
xChartdataprovider = xDoc.createInstance('com.sun.star.chart2.data.DataProvider')
self.assertEqual(xChartdataprovider.ImplementationName, 'SwChartDataProvider')
self.assertTrue(xChartdataprovider.supportsService('com.sun.star.chart2.data.DataProvider'))
self.assertFalse(xChartdataprovider.supportsService('foo'))
self.assertIn('com.sun.star.chart2.data.DataProvider', xChartdataprovider.SupportedServiceNames)
pv = PropertyValue()
pv.Name = 'CellRangeRepresentation'
pv.Value = 'Table1.A1:C2'
xDataSource = xChartdataprovider.createDataSource((pv,))
self.assertEqual(len(xDataSource.DataSequences), 3)
expected_values = ((1, 4), (2, 5), (3, 6))
expected_cellrange = ('A1:A2', 'B1:B2', 'C1:C2')
for col in range(3):
xSeq = xDataSource.DataSequences[col].Values
self.assertEqual(xSeq.ImplementationName, 'SwChartDataSequence')
self.assertTrue(xSeq.supportsService('com.sun.star.chart2.data.DataSequence'))
self.assertFalse(xSeq.supportsService('foo'))
self.assertIn('com.sun.star.chart2.data.DataSequence', xSeq.SupportedServiceNames)
self.assertEqual(xSeq.SourceRangeRepresentation, 'Table1.%s' % expected_cellrange[col])
self.assertEqual(xSeq.Data, expected_values[col])
self.assertEqual(xSeq.NumericalData, expected_values[col])
self.assertEqual([int(txtval) for txtval in xSeq.TextualData],
[val for val in expected_values[col]])
xSeq.Role = "One xSeq to rule them all"
self.assertEqual("One xSeq to rule them all", xSeq.Role)
xSeqClone = xSeq.createClone()
self.assertEqual(xSeq.Role, xSeqClone.Role)
xDoc.dispose()
def test_tdf32082(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xDocFrame = xDoc.CurrentController.Frame
xContext = CheckTable._uno.getContext()
xServiceManager = xContext.ServiceManager
xDispatcher = xServiceManager.createInstanceWithContext('com.sun.star.frame.DispatchHelper',
xContext)
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(1, 1)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
# Setup numberformat for the cell
xNumberFormats = xDoc.NumberFormats
xLocale = Locale('en', 'US', '')
format_string = '#,##0.00 [$€-407];[RED]-#,##0.00 [$€-407]'
key = xNumberFormats.queryKey(format_string, xLocale, True)
if key == -1:
key = xNumberFormats.addNew(format_string, xLocale)
# Apply the format on the first cell
xTable[0, 0].NumberFormat = key
xDispatcher.executeDispatch(xDocFrame, '.uno:GoToStartOfDoc', '', 0, ())
xDispatcher.executeDispatch(xDocFrame, '.uno:InsertText', '', 0,
(PropertyValue('Text', 0, '3', 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:JumpToNextCell', '', 0, ())
# Check that the formatting we set up is not destroyed
self.assertEqual(xTable[0, 0].getString(), '3.00 €')
self.assertEqual(xTable[0, 0].getValue(), 3)
# Verify that it works with number recognition turned on as well
xDispatcher.executeDispatch(xDocFrame, '.uno:TableNumberRecognition', '', 0,
(PropertyValue('TableNumberRecognition', 0, True, 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:InsertText', '', 0,
(PropertyValue('Text', 0, '4', 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:JumpToNextCell', '', 0, ())
self.assertEqual(xTable[1, 0].getString(), '4.00 €')
self.assertEqual(xTable[1, 0].getValue(), 4)
xDoc.dispose()
def test_numberRecognition(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xDocFrame = xDoc.CurrentController.Frame
xContext = CheckTable._uno.getContext()
xServiceManager = xContext.ServiceManager
xDispatcher = xServiceManager.createInstanceWithContext('com.sun.star.frame.DispatchHelper',
xContext)
xTable = xDoc.createInstance('com.sun.star.text.TextTable')
xTable.initialize(2, 1)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xDispatcher.executeDispatch(xDocFrame, '.uno:GoToStartOfDoc', '', 0, ())
xDispatcher.executeDispatch(xDocFrame, '.uno:InsertText', '', 0,
(PropertyValue('Text', 0, '2015-10-30', 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:JumpToNextCell', '', 0, ())
# Without number recognition 2015-10-30 should not be interpreted as a date
self.assertEqual(xTable[0, 0].getString(), '2015-10-30')
self.assertEqual(xTable[0, 0].getValue(), 0)
# Activate number recognition
xDispatcher.executeDispatch(xDocFrame, '.uno:TableNumberRecognition', '', 0,
(PropertyValue('TableNumberRecognition', 0, True, 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:InsertText', '', 0,
(PropertyValue('Text', 0, '2015-10-30', 0),))
xDispatcher.executeDispatch(xDocFrame, '.uno:JumpToNextCell', '', 0, ())
# With number recognition it should now be a date, confirm by checking
# the string and value of the cell.
self.assertEqual(xTable[1, 0].getString(), '2015-10-30')
self.assertEqual(xTable[1, 0].getValue(), 42307.0)
xDoc.dispose()
def test_tableTemplate(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(1, 1)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, True)
# should return programmatic name, even though UI name was set.
xTable.setPropertyValue("TableTemplateName", "Default Table Style")
self.assertEqual(xTable.getPropertyValue("TableTemplateName"), "Default Style")
xTable.setPropertyValue("TableTemplateName", "Default")
self.assertEqual(xTable.getPropertyValue("TableTemplateName"), "Default")
xTable.setPropertyValue("TableTemplateName", "other_style")
self.assertEqual(xTable.getPropertyValue("TableTemplateName"), "other_style")
xTable.setPropertyValue("TableTemplateName", "")
self.assertEqual(xTable.getPropertyValue("TableTemplateName"), "")
xDoc.dispose()
def test_unoNames(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(3, 3)
xText = xDoc.getText()
xCursor = xText.createTextCursor()
xText.insertTextContent(xCursor, xTable, False)
self.assertEqual("SwXTextTable", xTable.ImplementationName)
self.assertEqual(("com.sun.star.document.LinkTarget",
"com.sun.star.text.TextTable",
"com.sun.star.text.TextContent",
"com.sun.star.text.TextSortable"), xTable.SupportedServiceNames)
self.assertEqual(b'', xTable.ImplementationId.value)
xCell = xTable[1, 1]
self.assertEqual("SwXCell", xCell.ImplementationName)
self.assertEqual(("com.sun.star.text.CellProperties",), xCell.SupportedServiceNames)
self.assertEqual(b'', xCell.ImplementationId.value)
xRow = xTable.Rows[0]
self.assertEqual("SwXTextTableRow", xRow.ImplementationName)
self.assertEqual(("com.sun.star.text.TextTableRow",), xRow.SupportedServiceNames)
self.assertEqual(b'', xRow.ImplementationId.value)
xTableCursor = xTable.createCursorByCellName("A1")
self.assertEqual("SwXTextTableCursor", xTableCursor.ImplementationName)
self.assertEqual(("com.sun.star.text.TextTableCursor",), xTableCursor.SupportedServiceNames)
self.assertEqual(b'', xTableCursor.ImplementationId.value)
xDoc.dispose()
def test_xmlRangeConversions(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(4, 3)
xCursor = xDoc.Text.createTextCursor()
xDoc.Text.insertTextContent(xCursor, xTable, False)
xTable.ChartColumnAsLabel = False
xTable.ChartRowAsLabel = False
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12))
xChartDataProvider = xDoc.createInstance('com.sun.star.chart2.data.DataProvider')
self.assertEqual('', xChartDataProvider.convertRangeToXML(''))
self.assertEqual('', xChartDataProvider.convertRangeFromXML(''))
self.assertEqual('.A1;.A1', xChartDataProvider.convertRangeFromXML('<some xml>'))
xml = xChartDataProvider.convertRangeToXML('Table1.A1:C3')
self.assertEqual("Table1.$A$1:.$C$3", xml)
xCellRangeString = xChartDataProvider.convertRangeFromXML("Table1.$A$1:.$C$3")
self.assertEqual("Table1.A1:C3", xCellRangeString)
xDoc.dispose()
def test_splitRangeHorizontal(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(2, 2)
xText = xDoc.getText()
xCursor = xText.createTextCursor()
xText.insertTextContent(xCursor, xTable, False)
xTable.Data = ((1, 2), (3, 4))
xCursor = xTable.createCursorByCellName("A1")
xCursor.splitRange(2, True)
self.assertEqual(len(xTable.Data), 4)
self.assertEqual(xTable.Data[0], (float(1), float(2)))
self.assertEqual(xTable.Data[3], (float(3), float(4)))
self.assertTrue(math.isnan(xTable.Data[1][0]))
self.assertTrue(math.isnan(xTable.Data[1][1]))
self.assertTrue(math.isnan(xTable.Data[2][0]))
self.assertTrue(math.isnan(xTable.Data[2][1]))
xDoc.dispose()
def test_mergeRangeHorizontal(self):
xDoc = CheckTable._uno.openEmptyWriterDoc()
xTable = xDoc.createInstance("com.sun.star.text.TextTable")
xTable.initialize(3, 3)
xText = xDoc.getText()
xCursor = xText.createTextCursor()
xText.insertTextContent(xCursor, xTable, False)
xTable.Data = ((1, 2, 3), (4, 5, 6), (7, 8, 9))
xCursor = xTable.createCursorByCellName("A1")
xCursor.goDown(1, True)
xCursor.mergeRange()
self.assertEqual(len(xTable.Data), 3)
self.assertEqual(xTable.Data[0], (float(1), float(2), float(3)))
self.assertTrue(math.isnan(xTable.Data[1][0]))
self.assertEqual(xTable.Data[1][1], float(5))
self.assertEqual(xTable.Data[1][2], float(6))
self.assertEqual(xTable.Data[2], (float(7), float(8), float(9)))
xDoc.dispose()
if __name__ == '__main__':
unittest.main()
# vim: set shiftwidth=4 softtabstop=4 expandtab: