summaryrefslogtreecommitdiff
path: root/starmath
diff options
context:
space:
mode:
Diffstat (limited to 'starmath')
-rw-r--r--starmath/CppunitTest_starmath_export.mk26
-rw-r--r--starmath/qa/extras/mmlexport-test.cxx104
2 files changed, 40 insertions, 90 deletions
diff --git a/starmath/CppunitTest_starmath_export.mk b/starmath/CppunitTest_starmath_export.mk
index 3ea437c20aa1..442a90718352 100644
--- a/starmath/CppunitTest_starmath_export.mk
+++ b/starmath/CppunitTest_starmath_export.mk
@@ -41,6 +41,7 @@ $(eval $(call gb_CppunitTest_use_libraries,starmath_export,\
sm \
smd \
sot \
+ subsequenttest \
svl \
svt \
svx \
@@ -58,30 +59,7 @@ $(eval $(call gb_CppunitTest_use_libraries,starmath_export,\
$(eval $(call gb_CppunitTest_use_ure,starmath_export))
$(eval $(call gb_CppunitTest_use_vcl,starmath_export))
-$(eval $(call gb_CppunitTest_use_components,starmath_export,\
- configmgr/source/configmgr \
- framework/util/fwk \
- i18npool/util/i18npool \
- package/source/xstor/xstor \
- package/util/package2 \
- sfx2/util/sfx \
- starmath/util/sm \
- starmath/util/smd \
- toolkit/util/tk \
- ucb/source/core/ucb1 \
- ucb/source/ucp/file/ucpfile1 \
- unotools/util/utl \
- comphelper/util/comphelp \
- filter/source/config/cache/filterconfig1 \
- oox/util/oox \
- sax/source/expatwrap/expwrap \
- svl/source/fsstor/fsstorage \
- svl/util/svl \
- svx/util/svx \
- unoxml/source/service/unoxml \
- uui/util/uui \
- xmloff/util/xo \
-))
+$(eval $(call gb_CppunitTest_use_rdb,starmath_export,services))
$(eval $(call gb_CppunitTest_use_configuration,starmath_export))
diff --git a/starmath/qa/extras/mmlexport-test.cxx b/starmath/qa/extras/mmlexport-test.cxx
index 262ed6907b83..9eb0cae9f4f2 100644
--- a/starmath/qa/extras/mmlexport-test.cxx
+++ b/starmath/qa/extras/mmlexport-test.cxx
@@ -8,32 +8,24 @@
*/
#include <sal/config.h>
+#include <test/unoapixml_test.hxx>
-#include <o3tl/cppunittraitshelper.hxx>
-#include <test/bootstrapfixture.hxx>
-#include <test/xmltesttools.hxx>
-#include <unotools/tempfile.hxx>
-
-#include <sfx2/docfile.hxx>
-#include <sfx2/docfilt.hxx>
-#include <sfx2/sfxmodelfactory.hxx>
+#include <sfx2/sfxbasemodel.hxx>
#include <document.hxx>
#include <smdll.hxx>
#include <memory>
-namespace
-{
using namespace ::com::sun::star;
-typedef tools::SvRef<SmDocShell> SmDocShellRef;
-
-class MathMLExportTest : public test::BootstrapFixture, public XmlTestTools
+class MathMLExportTest : public UnoApiXmlTest
{
public:
- virtual void setUp() override;
- virtual void tearDown() override;
+ MathMLExportTest()
+ : UnoApiXmlTest("starmath/qa/extras/data/")
+ {
+ }
void testBlank();
void testTdf97049();
@@ -48,72 +40,49 @@ public:
protected:
virtual void registerNamespaces(xmlXPathContextPtr& pXmlXPathCtx) override;
- void checkMathVariant(bool bCapital, bool bSmall);
-
-private:
- xmlDocUniquePtr exportAndParse();
-
- SmDocShellRef mxDocShell;
+ void checkMathVariant(SmDocShell& rDocShell, bool bCapital, bool bSmall);
};
-void MathMLExportTest::setUp()
-{
- BootstrapFixture::setUp();
- SmGlobals::ensure();
- mxDocShell
- = new SmDocShell(SfxModelFlags::EMBEDDED_OBJECT | SfxModelFlags::DISABLE_EMBEDDED_SCRIPTS
- | SfxModelFlags::DISABLE_DOCUMENT_RECOVERY);
-}
-
-void MathMLExportTest::tearDown()
-{
- if (mxDocShell.is())
- mxDocShell->DoClose();
- BootstrapFixture::tearDown();
-}
-
void MathMLExportTest::registerNamespaces(xmlXPathContextPtr& pXmlXPathCtx)
{
xmlXPathRegisterNs(pXmlXPathCtx, BAD_CAST("m"), BAD_CAST("http://www.w3.org/1998/Math/MathML"));
}
-xmlDocUniquePtr MathMLExportTest::exportAndParse()
-{
- utl::TempFileNamed aTempFile;
- aTempFile.EnableKillingFile();
- SfxMedium aStoreMedium(aTempFile.GetURL(), StreamMode::STD_WRITE);
- std::shared_ptr<const SfxFilter> pExportFilter = SfxFilter::GetFilterByName(MATHML_XML);
- aStoreMedium.SetFilter(pExportFilter);
- CPPUNIT_ASSERT(mxDocShell->ConvertTo(aStoreMedium));
- aStoreMedium.Commit();
- xmlDocUniquePtr pDoc = parseXml(aTempFile);
- CPPUNIT_ASSERT(pDoc);
- return pDoc;
-}
-
void MathMLExportTest::testBlank()
{
- mxDocShell->SetText("x`y~~z");
- xmlDocUniquePtr pDoc = exportAndParse();
+ mxComponent = loadFromDesktop("private:factory/smath");
+ SfxBaseModel* pModel = dynamic_cast<SfxBaseModel*>(mxComponent.get());
+ SmDocShell* pDocShell = static_cast<SmDocShell*>(pModel->GetObjectShell());
+ pDocShell->SetText("x`y~~z");
+ save("MathML XML (Math)");
+ xmlDocUniquePtr pDoc = parseXml(maTempFile);
+ CPPUNIT_ASSERT(pDoc);
assertXPath(pDoc, "/m:math/m:semantics/m:mrow/m:mspace[1]", "width", "0.5em");
assertXPath(pDoc, "/m:math/m:semantics/m:mrow/m:mspace[2]", "width", "4em");
}
void MathMLExportTest::testTdf97049()
{
- mxDocShell->SetText("intd {{1 over x} dx}");
- xmlDocUniquePtr pDoc = exportAndParse();
+ mxComponent = loadFromDesktop("private:factory/smath");
+ SfxBaseModel* pModel = dynamic_cast<SfxBaseModel*>(mxComponent.get());
+ SmDocShell* pDocShell = static_cast<SmDocShell*>(pModel->GetObjectShell());
+ pDocShell->SetText("intd {{1 over x} dx}");
+ save("MathML XML (Math)");
+ xmlDocUniquePtr pDoc = parseXml(maTempFile);
+ CPPUNIT_ASSERT(pDoc);
assertXPath(pDoc, "/m:math/m:semantics/m:mrow/m:mo[1]", "stretchy", "true");
auto aContent = getXPathContent(pDoc, "/m:math/m:semantics/m:mrow/m:mo[1]");
CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aContent.getLength());
CPPUNIT_ASSERT_EQUAL(u'\x222B', aContent[0]);
}
-void MathMLExportTest::checkMathVariant(bool bCapital, bool bSmall)
+void MathMLExportTest::checkMathVariant(SmDocShell& rDocShell, bool bCapital, bool bSmall)
{
- mxDocShell->SetText("%GAMMA %iGAMMA {ital %GAMMA} {nitalic %iGAMMA} "
- "%gamma %igamma {ital %gamma} {nitalic %igamma}");
- xmlDocUniquePtr pDoc = exportAndParse();
+ rDocShell.SetText("%GAMMA %iGAMMA {ital %GAMMA} {nitalic %iGAMMA} "
+ "%gamma %igamma {ital %gamma} {nitalic %igamma}");
+ save("MathML XML (Math)");
+ xmlDocUniquePtr pDoc = parseXml(maTempFile);
+ CPPUNIT_ASSERT(pDoc);
if (bCapital)
assertXPathNoAttribute(pDoc, "/m:math/m:semantics/m:mrow/m:mi[1]", "mathvariant");
else
@@ -128,22 +97,25 @@ void MathMLExportTest::checkMathVariant(bool bCapital, bool bSmall)
assertXPathNoAttribute(pDoc, "/m:math/m:semantics/m:mrow/m:mstyle[3]/m:mi[1]", "mathvariant");
assertXPathNoAttribute(pDoc, "/m:math/m:semantics/m:mrow/m:mi[4]", "mathvariant");
assertXPath(pDoc, "/m:math/m:semantics/m:mrow/m:mstyle[4]/m:mi[1]", "mathvariant", "normal");
- mxDocShell->SetText("");
+ rDocShell.SetText("");
}
void MathMLExportTest::testTdf101022()
{
- checkMathVariant(false, true); // default mode 2
+ mxComponent = loadFromDesktop("private:factory/smath");
+ SfxBaseModel* pModel = dynamic_cast<SfxBaseModel*>(mxComponent.get());
+ SmDocShell* pDocShell = static_cast<SmDocShell*>(pModel->GetObjectShell());
- mxDocShell->SetGreekCharStyle(1); // mode 1
- checkMathVariant(true, true);
+ checkMathVariant(*pDocShell, false, true); // default mode 2
- mxDocShell->SetGreekCharStyle(0); // mode 0
- checkMathVariant(false, false);
+ pDocShell->SetGreekCharStyle(1); // mode 1
+ checkMathVariant(*pDocShell, true, true);
+
+ pDocShell->SetGreekCharStyle(0); // mode 0
+ checkMathVariant(*pDocShell, false, false);
}
CPPUNIT_TEST_SUITE_REGISTRATION(MathMLExportTest);
-}
CPPUNIT_PLUGIN_IMPLEMENT();