summaryrefslogtreecommitdiff
path: root/sc/qa
diff options
context:
space:
mode:
authorKohei Yoshida <kohei.yoshida@collabora.com>2014-01-06 23:45:46 -0500
committerKohei Yoshida <kohei.yoshida@collabora.com>2014-01-07 00:51:26 -0500
commit8728f8e8705cfb6875a315aef85ec6004604e702 (patch)
treeb5f245ac9b9062e0190c63057666060247937c31 /sc/qa
parent4a7a6b46c0dc779581f271b9e6c13c365eca7ab8 (diff)
fdo#72645: Allow GETPIVOTDATA to get result from leaf node of result tree.
Change-Id: I0fc1fd069440ed6fee378fc2dfd2ed761afbdeab
Diffstat (limited to 'sc/qa')
-rw-r--r--sc/qa/unit/ucalc.hxx2
-rw-r--r--sc/qa/unit/ucalc_pivottable.cxx93
2 files changed, 95 insertions, 0 deletions
diff --git a/sc/qa/unit/ucalc.hxx b/sc/qa/unit/ucalc.hxx
index 98528f6d6734..b56c31e86063 100644
--- a/sc/qa/unit/ucalc.hxx
+++ b/sc/qa/unit/ucalc.hxx
@@ -123,6 +123,7 @@ public:
void testFuncINDIRECT();
void testFuncIFERROR();
void testFuncGETPIVOTDATA();
+ void testFuncGETPIVOTDATALeafAccess();
void testCopyAttributes();
void testCopyToDocument();
@@ -340,6 +341,7 @@ public:
CPPUNIT_TEST(testFuncINDIRECT);
CPPUNIT_TEST(testFuncIFERROR);
CPPUNIT_TEST(testFuncGETPIVOTDATA);
+ CPPUNIT_TEST(testFuncGETPIVOTDATALeafAccess);
CPPUNIT_TEST(testCopyToDocument);
CPPUNIT_TEST(testSheetsFunc);
CPPUNIT_TEST(testVolatileFunc);
diff --git a/sc/qa/unit/ucalc_pivottable.cxx b/sc/qa/unit/ucalc_pivottable.cxx
index a052adcf32e1..00e83b9f122c 100644
--- a/sc/qa/unit/ucalc_pivottable.cxx
+++ b/sc/qa/unit/ucalc_pivottable.cxx
@@ -2235,4 +2235,97 @@ void Test::testFuncGETPIVOTDATA()
m_pDoc->DeleteTab(0);
}
+void Test::testFuncGETPIVOTDATALeafAccess()
+{
+ m_pDoc->InsertTab(0, "Data");
+ m_pDoc->InsertTab(1, "Table");
+
+ // Raw data
+ const char* aData[][3] = {
+ { "Type", "Member", "Value" },
+ { "A", "Anna", "1" },
+ { "B", "Brittany", "2" },
+ { "A", "Cecilia", "3" },
+ { "B", "Donna", "4" },
+ };
+
+ ScAddress aPos(1,1,0);
+ ScRange aDataRange = insertRangeData(m_pDoc, aPos, aData, SAL_N_ELEMENTS(aData));
+ CPPUNIT_ASSERT_MESSAGE("failed to insert range data at correct position", aDataRange.aStart == aPos);
+
+ ScDPObject* pDPObj = NULL;
+
+ // Dimension definition
+ DPFieldDef aFields[] = {
+ { "Type", sheet::DataPilotFieldOrientation_ROW, 0 },
+ { "Member", sheet::DataPilotFieldOrientation_ROW, 0 },
+ { "Value", sheet::DataPilotFieldOrientation_DATA, sheet::GeneralFunction_SUM },
+ };
+
+ // Create pivot table at A1 on 2nd sheet.
+ pDPObj = createDPFromRange(m_pDoc, aDataRange, aFields, SAL_N_ELEMENTS(aFields), false);
+
+ ScDPCollection* pDPs = m_pDoc->GetDPCollection();
+ bool bSuccess = pDPs->InsertNewTable(pDPObj);
+
+ CPPUNIT_ASSERT_MESSAGE("failed to insert a new pivot table object into document.", bSuccess);
+ CPPUNIT_ASSERT_MESSAGE("there should be only one data pilot table.",
+ pDPs->GetCount() == 1);
+ pDPObj->SetName(pDPs->CreateNewName());
+ ScRange aOutRange = refresh(pDPObj);
+
+ {
+ // Expected output table content. 0 = empty cell
+ const char* aOutputCheck[][3] = {
+ { "Type", "Member", 0 },
+ { "A", "Anna", "1" },
+ { 0, "Cecilia", "3" },
+ { "B", "Brittany", "2" },
+ { 0, "Donna", "4" },
+ { "Total Result", 0, "10" },
+ };
+
+ bSuccess = checkDPTableOutput<3>(m_pDoc, aOutRange, aOutputCheck, "Pivot table refreshed");
+ CPPUNIT_ASSERT_MESSAGE("Table output check failed", bSuccess);
+ }
+
+ // Insert formulas with GETPIVOTDATA in column E, and check their results.
+
+ struct Check
+ {
+ const char* mpFormula;
+ double mfResult;
+ };
+
+ Check aChecks[] = {
+ { "=GETPIVOTDATA($A$1;\"Member[Anna]\")", 1.0 },
+ { "=GETPIVOTDATA($A$1;\"Member[Brittany]\")", 2.0 },
+ { "=GETPIVOTDATA($A$1;\"Member[Cecilia]\")", 3.0 },
+ { "=GETPIVOTDATA($A$1;\"Member[Donna]\")", 4.0 },
+ };
+
+ for (size_t i = 0; i < SAL_N_ELEMENTS(aChecks); ++i)
+ m_pDoc->SetString(ScAddress(4,i,1), OUString::createFromAscii(aChecks[i].mpFormula));
+
+ m_pDoc->CalcAll();
+
+ const sal_uInt16 nNoError = 0; // no error
+ for (size_t i = 0; i < SAL_N_ELEMENTS(aChecks); ++i)
+ {
+ sal_uInt16 nErr = m_pDoc->GetErrCode(ScAddress(4,i,1));
+ CPPUNIT_ASSERT_EQUAL(nNoError, nErr);
+ double fVal = m_pDoc->GetValue(ScAddress(4,i,1));
+ CPPUNIT_ASSERT_EQUAL(aChecks[i].mfResult, fVal);
+ }
+
+ pDPs->FreeTable(pDPObj);
+
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("There should be no more tables.", pDPs->GetCount(), static_cast<size_t>(0));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("There shouldn't be any more cache stored.",
+ pDPs->GetSheetCaches().size(), static_cast<size_t>(0));
+
+ m_pDoc->DeleteTab(1);
+ m_pDoc->DeleteTab(0);
+}
+
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */