Files
libreoffice/pyuno/qa/pytests/testcollections_XNameContainer.py
Kenneth Koski 4f6e3108d9 Running pep8 on pyuno unit test files
Change-Id: I5d35305386e1f520d1030776e2b7bcf7620eda04
Reviewed-on: https://gerrit.libreoffice.org/22514
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Samuel Mehrbrodt <Samuel.Mehrbrodt@cib.de>
2016-02-23 08:14:18 +00:00

117 lines
3.3 KiB
Python

#!/usr/bin/env python
#
# 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 unittest
import uno
from testcollections_base import CollectionsTestBase
from com.sun.star.beans import PropertyValue
# Tests behaviour of objects implementing XNameContainer using the new-style
# collection accessors
# The objects chosen have no special meaning, they just happen to implement the
# tested interfaces
class TestXNameContainer(CollectionsTestBase):
# Tests syntax:
# obj[key] = val # Insert by key
# For:
# 0->1 element
def test_XNameContainer_InsertName(self):
# Given
spr = self.createBlankSpreadsheet()
ranges = spr.createInstance("com.sun.star.sheet.SheetCellRanges")
newRange = spr.Sheets.getByIndex(0).getCellRangeByPosition(1, 2, 1, 2)
# When
ranges['foo'] = newRange
# Then
self.assertEqual(1, len(ranges.ElementNames))
# Tests syntax:
# obj[key] = val # Insert by key
# For:
# Invalid key
def test_XNameContainer_InsertName_Invalid(self):
# Given
spr = self.createBlankSpreadsheet()
ranges = spr.createInstance("com.sun.star.sheet.SheetCellRanges")
newRange = spr.Sheets.getByIndex(0).getCellRangeByPosition(1, 2, 1, 2)
# When / Then
with self.assertRaises(TypeError):
ranges[12.34] = newRange
# Tests syntax:
# obj[key] = val # Replace by key
def test_XNameContainer_ReplaceName(self):
# Given
spr = self.createBlankSpreadsheet()
ranges = spr.createInstance("com.sun.star.sheet.SheetCellRanges")
newRange1 = spr.Sheets.getByIndex(0).getCellRangeByPosition(1, 2, 1, 2)
newRange2 = spr.Sheets.getByIndex(0).getCellRangeByPosition(6, 6, 6, 6)
# When
ranges['foo'] = newRange1
ranges['foo'] = newRange2
# Then
self.assertEqual(1, len(ranges.ElementNames))
readRange = ranges['foo']
self.assertEqual(6, readRange.CellAddress.Column)
# Tests syntax:
# del obj[key] # Delete by key
# For:
# 1/2 elements
def test_XNameContainer_DelKey(self):
# Given
spr = self.createBlankSpreadsheet()
spr.Sheets.insertNewByName('foo', 1)
# When
del spr.Sheets['foo']
# Then
self.assertEqual(1, len(spr.Sheets))
self.assertFalse('foo' in spr.Sheets)
# Tests syntax:
# del obj[key] # Delete by key
# For:
# Missing key
def test_XNameContainer_DelKey_Missing(self):
# Given
spr = self.createBlankSpreadsheet()
# When / Then
with self.assertRaises(KeyError):
del spr.Sheets['foo']
# Tests syntax:
# del obj[key] # Delete by key
# For:
# Invalid key (float)
def test_XNameContainer_DelKey_Invalid(self):
# Given
spr = self.createBlankSpreadsheet()
# When / Then
with self.assertRaises(TypeError):
del spr.Sheets[12.34]
if __name__ == '__main__':
unittest.main()
# vim:set shiftwidth=4 softtabstop=4 expandtab: