diff options
author | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2015-05-16 07:02:02 +0200 |
---|---|---|
committer | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2015-05-16 07:26:40 +0200 |
commit | 883c81033fea0d9adb5c31b345908859b9f18db9 (patch) | |
tree | 08ff95fee56c8047ad314a922f6dbdcd1ff65b87 | |
parent | c02f3174f7e5e6ed32379d727d4a362420a01d56 (diff) |
add test for new icon sets during XLSX import
Change-Id: I923aff04f8349aa25b49fd2eba6c29bfd579b4a7
-rw-r--r-- | sc/qa/unit/data/xlsx/complex_icon_set.xlsx | bin | 0 -> 9189 bytes | |||
-rw-r--r-- | sc/qa/unit/subsequent_filters-test.cxx | 31 |
2 files changed, 31 insertions, 0 deletions
diff --git a/sc/qa/unit/data/xlsx/complex_icon_set.xlsx b/sc/qa/unit/data/xlsx/complex_icon_set.xlsx Binary files differnew file mode 100644 index 000000000000..32f1e52f6944 --- /dev/null +++ b/sc/qa/unit/data/xlsx/complex_icon_set.xlsx diff --git a/sc/qa/unit/subsequent_filters-test.cxx b/sc/qa/unit/subsequent_filters-test.cxx index 849ac9f3f300..dab0033fd146 100644 --- a/sc/qa/unit/subsequent_filters-test.cxx +++ b/sc/qa/unit/subsequent_filters-test.cxx @@ -136,6 +136,7 @@ public: void testNewCondFormatXLSX(); void testCondFormatThemeColorXLSX(); void testCondFormatThemeColor2XLSX(); // negative bar color and axis color + void testComplexIconSetsXLSX(); void testLiteralInFormulaXLS(); @@ -244,6 +245,7 @@ public: CPPUNIT_TEST(testNewCondFormatXLSX); CPPUNIT_TEST(testCondFormatThemeColorXLSX); CPPUNIT_TEST(testCondFormatThemeColor2XLSX); + CPPUNIT_TEST(testComplexIconSetsXLSX); CPPUNIT_TEST(testLiteralInFormulaXLS); CPPUNIT_TEST(testNumberFormatHTML); @@ -2406,6 +2408,35 @@ void ScFiltersTest::testCondFormatThemeColor2XLSX() CPPUNIT_ASSERT_EQUAL(Color(197, 90, 17), pDataBarFormatData->maAxisColor); } +namespace { + +void testComplexIconSetsXLSX_Impl(ScDocument& rDoc, SCCOL nCol, ScIconSetType eType) +{ + ScConditionalFormat* pFormat = rDoc.GetCondFormat(nCol, 1, 0); + CPPUNIT_ASSERT(pFormat); + CPPUNIT_ASSERT_EQUAL(size_t(1), pFormat->size()); + const ScFormatEntry* pEntry = pFormat->GetEntry(0); + CPPUNIT_ASSERT(pEntry); + CPPUNIT_ASSERT_EQUAL(condformat::ICONSET, pEntry->GetType()); + const ScIconSetFormat* pIconSet = static_cast<const ScIconSetFormat*>(pEntry); + CPPUNIT_ASSERT_EQUAL(eType, pIconSet->GetIconSetData()->eIconSetType); +} + +} + +void ScFiltersTest::testComplexIconSetsXLSX() +{ + ScDocShellRef xDocSh = ScBootstrapFixture::loadDoc( "complex_icon_set.", XLSX ); + + CPPUNIT_ASSERT_MESSAGE("Failed to load complex_icon_set.xlsx", xDocSh.Is()); + + ScDocument& rDoc = xDocSh->GetDocument(); + CPPUNIT_ASSERT_EQUAL(size_t(3), rDoc.GetCondFormList(0)->size()); + testComplexIconSetsXLSX_Impl(rDoc, 1, IconSet_3Triangles); + testComplexIconSetsXLSX_Impl(rDoc, 3, IconSet_3Stars); + testComplexIconSetsXLSX_Impl(rDoc, 5, IconSet_5Boxes); +} + void ScFiltersTest::testLiteralInFormulaXLS() { ScDocShellRef xDocSh = loadDoc("shared-string/literal-in-formula.", XLS); |