summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/test/sheet/xcellrangedata.hxx3
-rw-r--r--qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellCursorObj.csv2
-rw-r--r--qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellRangeObj.csv2
-rw-r--r--qadevOOo/objdsc/sc/com.sun.star.comp.office.ScTableSheetObj.csv2
-rw-r--r--sc/qa/extras/sccellcursorobj.cxx12
-rw-r--r--sc/qa/extras/sctablesheetobj.cxx12
-rw-r--r--test/source/sheet/xcellrangedata.cxx45
7 files changed, 61 insertions, 17 deletions
diff --git a/include/test/sheet/xcellrangedata.hxx b/include/test/sheet/xcellrangedata.hxx
index 7af4e7d9ea0f..00aef5e8152c 100644
--- a/include/test/sheet/xcellrangedata.hxx
+++ b/include/test/sheet/xcellrangedata.hxx
@@ -18,10 +18,13 @@ namespace apitest {
class OOO_DLLPUBLIC_TEST XCellRangeData
{
public:
+ virtual css::uno::Reference< css::uno::XInterface > init() = 0;
virtual css::uno::Reference< css::uno::XInterface > getXCellRangeData() = 0;
void testGetDataArray();
void testSetDataArray();
+ void testGetDataArrayOnTableSheet();
+ void testSetDataArrayOnTableSheet();
protected:
~XCellRangeData() {}
diff --git a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellCursorObj.csv b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellCursorObj.csv
index cf6417dcdf44..74d9a7752bb9 100644
--- a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellCursorObj.csv
+++ b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellCursorObj.csv
@@ -190,8 +190,6 @@
"ScCellCursorObj";"com::sun::star::beans::XPropertySet";"removePropertyChangeListener()"
"ScCellCursorObj";"com::sun::star::beans::XPropertySet";"addVetoableChangeListener()"
"ScCellCursorObj";"com::sun::star::beans::XPropertySet";"removeVetoableChangeListener()"
-"ScCellCursorObj";"com::sun::star::sheet::XCellRangeData";"getDataArray()"
-"ScCellCursorObj";"com::sun::star::sheet::XCellRangeData";"setDataArray()"
"ScCellCursorObj";"com::sun::star::chart::XChartDataArray";"getData()"
"ScCellCursorObj";"com::sun::star::chart::XChartDataArray";"setData()"
"ScCellCursorObj";"com::sun::star::chart::XChartDataArray";"getRowDescriptions()"
diff --git a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellRangeObj.csv b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellRangeObj.csv
index 3ca844258495..581e8884dec1 100644
--- a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellRangeObj.csv
+++ b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScCellRangeObj.csv
@@ -185,8 +185,6 @@
"ScCellRangeObj";"com::sun::star::beans::XPropertySet";"removePropertyChangeListener()"
"ScCellRangeObj";"com::sun::star::beans::XPropertySet";"addVetoableChangeListener()"
"ScCellRangeObj";"com::sun::star::beans::XPropertySet";"removeVetoableChangeListener()"
-"ScCellRangeObj";"com::sun::star::sheet::XCellRangeData";"getDataArray()"
-"ScCellRangeObj";"com::sun::star::sheet::XCellRangeData";"setDataArray()"
"ScCellRangeObj";"com::sun::star::chart::XChartDataArray";"getData()"
"ScCellRangeObj";"com::sun::star::chart::XChartDataArray";"setData()"
"ScCellRangeObj";"com::sun::star::chart::XChartDataArray";"getRowDescriptions()"
diff --git a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScTableSheetObj.csv b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScTableSheetObj.csv
index 78efd29dae01..cb29417eb43b 100644
--- a/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScTableSheetObj.csv
+++ b/qadevOOo/objdsc/sc/com.sun.star.comp.office.ScTableSheetObj.csv
@@ -192,8 +192,6 @@
"ScTableSheetObj";"com::sun::star::beans::XPropertySet";"removePropertyChangeListener()"
"ScTableSheetObj";"com::sun::star::beans::XPropertySet";"addVetoableChangeListener()"
"ScTableSheetObj";"com::sun::star::beans::XPropertySet";"removeVetoableChangeListener()"
-"ScTableSheetObj";"com::sun::star::sheet::XCellRangeData";"getDataArray()"
-"ScTableSheetObj";"com::sun::star::sheet::XCellRangeData";"setDataArray()"
"ScTableSheetObj";"com::sun::star::chart::XChartDataArray";"getData()"
"ScTableSheetObj";"com::sun::star::chart::XChartDataArray";"setData()"
"ScTableSheetObj";"com::sun::star::chart::XChartDataArray";"getRowDescriptions()"
diff --git a/sc/qa/extras/sccellcursorobj.cxx b/sc/qa/extras/sccellcursorobj.cxx
index 61e564215787..eb38ea141087 100644
--- a/sc/qa/extras/sccellcursorobj.cxx
+++ b/sc/qa/extras/sccellcursorobj.cxx
@@ -12,6 +12,7 @@
#include <test/sheet/xarrayformularange.hxx>
#include <test/sheet/xcellformatrangessupplier.hxx>
#include <test/sheet/xcellrangeaddressable.hxx>
+#include <test/sheet/xcellrangedata.hxx>
#include <test/sheet/xcellrangeformula.hxx>
#include <test/sheet/xcellseries.hxx>
#include <test/sheet/xmultipleoperation.hxx>
@@ -36,6 +37,7 @@ class ScCellCursorObj : public CalcUnoApiTest, public apitest::SheetCellRange,
public apitest::XArrayFormulaRange,
public apitest::XCellFormatRangesSupplier,
public apitest::XCellRangeAddressable,
+ public apitest::XCellRangeData,
public apitest::XCellRangeFormula,
public apitest::XCellSeries,
public apitest::XMultipleOperation,
@@ -53,6 +55,7 @@ public:
virtual void setUp() override;
virtual void tearDown() override;
virtual uno::Reference< uno::XInterface > init() override;
+ virtual uno::Reference< uno::XInterface > getXCellRangeData() override;
virtual uno::Reference< uno::XInterface > getXSpreadsheet() override;
CPPUNIT_TEST_SUITE(ScCellCursorObj);
@@ -69,6 +72,10 @@ public:
// XCellRangeAddressable
CPPUNIT_TEST(testGetRangeAddress);
+ // XCellRangeData
+ CPPUNIT_TEST(testGetDataArray);
+ CPPUNIT_TEST(testSetDataArray);
+
// XCellRangeFormula
CPPUNIT_TEST(testGetSetFormulaArray);
@@ -130,6 +137,11 @@ uno::Reference< uno::XInterface > ScCellCursorObj::init()
return xCellCursor;
}
+uno::Reference< uno::XInterface > ScCellCursorObj::getXCellRangeData()
+{
+ return init();
+}
+
uno::Reference< uno::XInterface > ScCellCursorObj::getXSpreadsheet()
{
uno::Reference< sheet::XSpreadsheetDocument > xDoc(mxComponent, UNO_QUERY_THROW);
diff --git a/sc/qa/extras/sctablesheetobj.cxx b/sc/qa/extras/sctablesheetobj.cxx
index 475bf9a7b95f..8316207f605f 100644
--- a/sc/qa/extras/sctablesheetobj.cxx
+++ b/sc/qa/extras/sctablesheetobj.cxx
@@ -14,6 +14,7 @@
#include <test/sheet/xarrayformularange.hxx>
#include <test/sheet/xcellformatrangessupplier.hxx>
#include <test/sheet/xcellrangeaddressable.hxx>
+#include <test/sheet/xcellrangedata.hxx>
#include <test/sheet/xcellrangeformula.hxx>
#include <test/sheet/xcellrangemovement.hxx>
#include <test/sheet/xcellseries.hxx>
@@ -54,6 +55,7 @@ class ScTableSheetObj : public CalcUnoApiTest, public apitest::Scenario,
public apitest::XArrayFormulaRange,
public apitest::XCellFormatRangesSupplier,
public apitest::XCellRangeAddressable,
+ public apitest::XCellRangeData,
public apitest::XCellRangeFormula,
public apitest::XCellRangeMovement,
public apitest::XCellSeries,
@@ -86,6 +88,7 @@ public:
virtual OUString getFileURL() override;
virtual uno::Reference< uno::XInterface > init() override;
+ virtual uno::Reference< uno::XInterface > getXCellRangeData() override;
virtual uno::Reference< uno::XInterface > getXSpreadsheetDocument() override;
virtual uno::Reference< uno::XInterface > getXSpreadsheet() override;
virtual uno::Reference< uno::XInterface > getScenarioSpreadsheet() override;
@@ -112,6 +115,10 @@ public:
// XCellRangeAddressable
CPPUNIT_TEST(testGetRangeAddress);
+ // XCellRangeData
+ CPPUNIT_TEST(testGetDataArrayOnTableSheet);
+ CPPUNIT_TEST(testSetDataArrayOnTableSheet);
+
// XCellRangeFormula
#if 0 // disable, because it makes no sense to set an FormulaArray over the whole sheet
CPPUNIT_TEST(testGetSetFormulaArray);
@@ -245,6 +252,11 @@ uno::Reference< uno::XInterface > ScTableSheetObj::init()
return xSheet;
}
+uno::Reference< uno::XInterface > ScTableSheetObj::getXCellRangeData()
+{
+ return init();
+}
+
uno::Reference<uno::XInterface> ScTableSheetObj::getXSpreadsheetDocument()
{
uno::Reference<sheet::XSpreadsheetDocument> xDoc(mxComponent, UNO_QUERY_THROW);
diff --git a/test/source/sheet/xcellrangedata.cxx b/test/source/sheet/xcellrangedata.cxx
index acf99f2136e4..223fd5f7b32d 100644
--- a/test/source/sheet/xcellrangedata.cxx
+++ b/test/source/sheet/xcellrangedata.cxx
@@ -8,7 +8,12 @@
*/
#include <test/sheet/xcellrangedata.hxx>
+
#include <com/sun/star/sheet/XCellRangeData.hpp>
+#include <com/sun/star/uno/Any.hxx>
+#include <com/sun/star/uno/Reference.hxx>
+#include <com/sun/star/uno/RuntimeException.hpp>
+#include <com/sun/star/uno/Sequence.hxx>
#include <cppunit/extensions/HelperMacros.h>
@@ -43,17 +48,7 @@ void XCellRangeData::testSetDataArray()
aColRow.realloc(4);
setValues(aColRow, 1);
xCellRangeData->setDataArray(aColRow);
- // need to check here for correct values
-
- // set old values
- setValues(aColRow, 0);
- xCellRangeData->setDataArray(aColRow);
-}
-void XCellRangeData::testGetDataArray()
-{
- uno::Reference< sheet::XCellRangeData > xCellRangeData( getXCellRangeData(), UNO_QUERY_THROW);
- uno::Sequence< uno::Sequence < Any > > aColRow = xCellRangeData->getDataArray();
for ( sal_Int32 i = 0; i < aColRow.getLength(); ++i)
{
for ( sal_Int32 j = 0; j < aColRow[i].getLength(); ++j)
@@ -61,11 +56,39 @@ void XCellRangeData::testGetDataArray()
Any& aAny = aColRow[i][j];
double nValue = 0.0;
CPPUNIT_ASSERT( aAny >>= nValue);
- CPPUNIT_ASSERT_DOUBLES_EQUAL(static_cast<double>(i+j), nValue, 0.000001);
+ CPPUNIT_ASSERT_DOUBLES_EQUAL(static_cast<double>(i+j+1), nValue, 0.000001);
}
}
+
+ // set old values
+ setValues(aColRow, 0);
+ xCellRangeData->setDataArray(aColRow);
}
+void XCellRangeData::testGetDataArray()
+{
+ uno::Reference< sheet::XCellRangeData > xCellRangeData( getXCellRangeData(), UNO_QUERY_THROW);
+ uno::Sequence< uno::Sequence < Any > > aColRow = xCellRangeData->getDataArray();
+ CPPUNIT_ASSERT(aColRow.getLength());
+}
+
+void XCellRangeData::testGetDataArrayOnTableSheet()
+{
+ uno::Reference< sheet::XCellRangeData > xCellRangeData( getXCellRangeData(), UNO_QUERY_THROW);
+ CPPUNIT_ASSERT_THROW_MESSAGE("No RuntimeException thrown", xCellRangeData->getDataArray(),
+ css::uno::RuntimeException);
+}
+
+void XCellRangeData::testSetDataArrayOnTableSheet()
+{
+ uno::Reference< sheet::XCellRangeData > xCellRangeData( getXCellRangeData(), UNO_QUERY_THROW);
+
+ uno::Sequence< uno::Sequence < Any > > aColRow;
+ aColRow.realloc(4);
+ setValues(aColRow, 1);
+ CPPUNIT_ASSERT_THROW_MESSAGE("No RuntimeException thrown", xCellRangeData->setDataArray(aColRow),
+ css::uno::RuntimeException);
+}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */