[Libreoffice-commits] .: sc/inc sc/qa
Libreoffice Gerrit user
logerrit at kemper.freedesktop.org
Fri Jan 4 12:29:14 PST 2013
sc/inc/document.hxx | 2 -
sc/qa/unit/data/ods/row-height-import.ods |binary
sc/qa/unit/subsequent_filters-test.cxx | 56 ++++++++++++++++++++++++++++++
3 files changed, 57 insertions(+), 1 deletion(-)
New commits:
commit 4a11267d8140143dce0bdb51791f5e703187a7e9
Author: Kohei Yoshida <kohei.yoshida at gmail.com>
Date: Fri Jan 4 15:28:49 2013 -0500
New ods test document to check the import of row height values.
Test disabled as it currently fails.
Change-Id: I33ea3c95357fd7fdb9deaba30372567cfb69ebd6
diff --git a/sc/inc/document.hxx b/sc/inc/document.hxx
index 41afbf2..5b5a472 100644
--- a/sc/inc/document.hxx
+++ b/sc/inc/document.hxx
@@ -1357,7 +1357,7 @@ public:
SCROW LastNonFilteredRow(SCROW nStartRow, SCROW nEndRow, SCTAB nTab);
SCROW CountNonFilteredRows(SCROW nStartRow, SCROW nEndRow, SCTAB nTab);
- bool IsManualRowHeight(SCROW nRow, SCTAB nTab) const;
+ SC_DLLPUBLIC bool IsManualRowHeight(SCROW nRow, SCTAB nTab) const;
/**
* Write all column row flags to table's flag data, because not all column
diff --git a/sc/qa/unit/data/ods/row-height-import.ods b/sc/qa/unit/data/ods/row-height-import.ods
new file mode 100644
index 0000000..2deb104
Binary files /dev/null and b/sc/qa/unit/data/ods/row-height-import.ods differ
diff --git a/sc/qa/unit/subsequent_filters-test.cxx b/sc/qa/unit/subsequent_filters-test.cxx
index d31bd8d..c283508 100644
--- a/sc/qa/unit/subsequent_filters-test.cxx
+++ b/sc/qa/unit/subsequent_filters-test.cxx
@@ -169,6 +169,8 @@ public:
void testPivotTableBasicODS();
+ void testRowHeight();
+
CPPUNIT_TEST_SUITE(ScFiltersTest);
CPPUNIT_TEST(testRangeNameXLS);
CPPUNIT_TEST(testRangeNameXLSX);
@@ -210,6 +212,7 @@ public:
CPPUNIT_TEST(testCellAnchoredShapesODS);
CPPUNIT_TEST(testPivotTableBasicODS);
+// CPPUNIT_TEST(testRowHeight);
//disable testPassword on MacOSX due to problems with libsqlite3
//also crashes on DragonFly due to problems with nss/nspr headers
@@ -1569,6 +1572,59 @@ void ScFiltersTest::testPivotTableBasicODS()
xDocSh->DoClose();
}
+void ScFiltersTest::testRowHeight()
+{
+ OUString aFileNameBase("row-height-import.");
+ OUString aFileExt = OUString::createFromAscii(aFileFormats[ODS].pName);
+ OUString aFilterName = OUString::createFromAscii(aFileFormats[ODS].pFilterName);
+ OUString aFilterType = OUString::createFromAscii(aFileFormats[ODS].pTypeName);
+
+ rtl::OUString aFileName;
+ createFileURL(aFileNameBase, aFileExt, aFileName);
+
+ unsigned int nFormatType = aFileFormats[ODS].nFormatType;
+ unsigned int nClipboardId = nFormatType ? SFX_FILTER_IMPORT | SFX_FILTER_USESOPTIONS : 0;
+ ScDocShellRef xDocSh = load(aFilterName, aFileName, rtl::OUString(), aFilterType,
+ nFormatType, nClipboardId, SOFFICE_FILEFORMAT_CURRENT);
+
+ SCTAB nTab = 0;
+ SCROW nRow = 0;
+ ScDocument* pDoc = xDocSh->GetDocument();
+
+ // The first 3 rows have manual heights.
+ int nHeight = pDoc->GetRowHeight(nRow, nTab, false);
+ bool bManual = pDoc->IsManualRowHeight(nRow, nTab);
+ CPPUNIT_ASSERT_EQUAL(600, nHeight);
+ CPPUNIT_ASSERT_MESSAGE("this row should have a manual row height.", bManual);
+ nHeight = pDoc->GetRowHeight(++nRow, nTab, false);
+ bManual = pDoc->IsManualRowHeight(nRow, nTab);
+ CPPUNIT_ASSERT_EQUAL(1200, nHeight);
+ CPPUNIT_ASSERT_MESSAGE("this row should have a manual row height.", bManual);
+ nHeight = pDoc->GetRowHeight(++nRow, nTab, false);
+ bManual = pDoc->IsManualRowHeight(nRow, nTab);
+ CPPUNIT_ASSERT_EQUAL(1800, nHeight);
+ CPPUNIT_ASSERT_MESSAGE("this row should have a manual row height.", bManual);
+
+ // This one should have an automatic row height.
+ bManual = pDoc->IsManualRowHeight(++nRow, nTab);
+ CPPUNIT_ASSERT_MESSAGE("Row should have an automatic height.", !bManual);
+
+ // Followed by a row with manual height.
+ nHeight = pDoc->GetRowHeight(++nRow, nTab, false);
+ bManual = pDoc->IsManualRowHeight(nRow, nTab);
+ CPPUNIT_ASSERT_EQUAL(2400, nHeight);
+ CPPUNIT_ASSERT_MESSAGE("this row should have a manual row height.", bManual);
+
+ // And all the rest should have automatic heights.
+ bManual = pDoc->IsManualRowHeight(++nRow, nTab);
+ CPPUNIT_ASSERT_MESSAGE("Row should have an automatic height.", !bManual);
+
+ bManual = pDoc->IsManualRowHeight(MAXROW, nTab);
+ CPPUNIT_ASSERT_MESSAGE("Row should have an automatic height.", !bManual);
+
+ xDocSh->DoClose();
+}
+
namespace {
void testColorScaleFormat_Impl(const rtl::OUString& rFilePath, const ScConditionalFormat* pFormat)
More information about the Libreoffice-commits
mailing list