xmlsecurity/CppunitTest_xmlsecurity_signing.mk  |    1 
 xmlsecurity/CppunitTest_xmlsecurity_signing2.mk |   94 ++++++++++++++++++++++++
 xmlsecurity/Module_xmlsecurity.mk               |    1 
 xmlsecurity/qa/unit/signing/signing2.cxx        |   65 ++--------------
 4 files changed, 104 insertions(+), 57 deletions(-)

New commits:
commit 336602a15d481c4502e66778aec8d37727922152
Author:     Xisco Fauli <xiscofa...@libreoffice.org>
AuthorDate: Thu Dec 1 14:27:03 2022 +0100
Commit:     Xisco Fauli <xiscofa...@libreoffice.org>
CommitDate: Thu Dec 1 16:45:45 2022 +0100

    CppunitTest_xmlsecurity_signing2: inherit from UnoApiXmlTest
    
    for some reason, if xmlsecurity/qa/unit/signing/signing2.cxx
    is executed with CppunitTest_xmlsecurity_signing, it makes
    testPreserveMacroTemplateSignature10::TestBody to crash,
    which is weird. Split them in two
    
    Change-Id: If43085dac60f197205d70294ec22ddfc86990784
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/143527
    Tested-by: Jenkins
    Reviewed-by: Xisco Fauli <xiscofa...@libreoffice.org>

diff --git a/xmlsecurity/CppunitTest_xmlsecurity_signing.mk 
b/xmlsecurity/CppunitTest_xmlsecurity_signing.mk
index c3842c16872d..7339800107a7 100644
--- a/xmlsecurity/CppunitTest_xmlsecurity_signing.mk
+++ b/xmlsecurity/CppunitTest_xmlsecurity_signing.mk
@@ -13,7 +13,6 @@ $(eval $(call gb_CppunitTest_CppunitTest,xmlsecurity_signing))
 
 $(eval $(call gb_CppunitTest_add_exception_objects,xmlsecurity_signing, \
        xmlsecurity/qa/unit/signing/signing \
-       xmlsecurity/qa/unit/signing/signing2 \
 ))
 
 $(eval $(call gb_CppunitTest_use_libraries,xmlsecurity_signing, \
diff --git a/xmlsecurity/CppunitTest_xmlsecurity_signing2.mk 
b/xmlsecurity/CppunitTest_xmlsecurity_signing2.mk
new file mode 100644
index 000000000000..0cd450121979
--- /dev/null
+++ b/xmlsecurity/CppunitTest_xmlsecurity_signing2.mk
@@ -0,0 +1,94 @@
+# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
+#*************************************************************************
+#
+# This file is part of the LibreOffice project.
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+#*************************************************************************
+
+$(eval $(call gb_CppunitTest_CppunitTest,xmlsecurity_signing2))
+
+$(eval $(call gb_CppunitTest_add_exception_objects,xmlsecurity_signing2, \
+       xmlsecurity/qa/unit/signing/signing2 \
+))
+
+$(eval $(call gb_CppunitTest_use_libraries,xmlsecurity_signing2, \
+       comphelper \
+       cppuhelper \
+       cppu \
+       sal \
+       sax \
+       sfx \
+       svx \
+       subsequenttest \
+       test \
+       tl \
+       unotest \
+       utl \
+       vcl \
+       xmlsecurity \
+       xsec_xmlsec \
+))
+
+$(eval $(call gb_CppunitTest_use_externals,xmlsecurity_signing2,\
+    boost_headers \
+    libxml2 \
+))
+
+ifneq ($(OS),WNT)
+ifneq (,$(ENABLE_NSS))
+$(eval $(call gb_CppunitTest_use_externals,xmlsecurity_signing2,\
+    nssutil3 \
+))
+endif
+endif
+
+$(eval $(call gb_CppunitTest_set_include,xmlsecurity_signing2,\
+       -I$(SRCDIR)/xmlsecurity/inc \
+       $$(INCLUDE) \
+))
+
+$(eval $(call gb_CppunitTest_use_sdk_api,xmlsecurity_signing2))
+
+$(eval $(call gb_CppunitTest_use_ure,xmlsecurity_signing2))
+$(eval $(call gb_CppunitTest_use_vcl,xmlsecurity_signing2))
+
+$(eval $(call gb_CppunitTest_use_uiconfigs,xmlsecurity_signing2, \
+    svt \
+))
+
+$(eval $(call gb_CppunitTest_use_rdb,xmlsecurity_signing2,services))
+
+$(eval $(call gb_CppunitTest_use_configuration,xmlsecurity_signing2))
+
+ifeq ($(ENABLE_POPPLER),TRUE)
+$(eval $(call gb_CppunitTest_use_executable,xmlsecurity_signing2,xpdfimport))
+endif
+
+# various hacks to make unit test work on Linux more often
+ifeq ($(OS),LINUX)
+# reset the LD_LIBRARY_PATH for spawned GPG processes
+$(call gb_CppunitTest_get_target,xmlsecurity_signing2): \
+    EXTRA_ENV_VARS += \
+        LIBO_LD_PATH=$$LD_LIBRARY_PATH
+endif
+
+$(eval $(call gb_CppunitTest_use_custom_headers,xmlsecurity_signing2,\
+    officecfg/registry \
+))
+
+ifeq ($(OS),WNT)
+# Initializing DocumentSignatureManager will require gpgme-w32spawn.exe in 
workdir/LinkTarget/Executable
+$(eval $(call gb_CppunitTest_use_packages,xmlsecurity_signing2,\
+    $(call gb_Helper_optional,GPGMEPP,gpgmepp)\
+))
+endif
+
+$(eval $(call gb_CppunitTest_add_arguments,xmlsecurity_signing2, \
+    
-env:arg-env=$(gb_Helper_LIBRARY_PATH_VAR)"$$$${$(gb_Helper_LIBRARY_PATH_VAR)+=$$$$$(gb_Helper_LIBRARY_PATH_VAR)}"
 \
+))
+
+# vim: set noet sw=4 ts=4:
diff --git a/xmlsecurity/Module_xmlsecurity.mk 
b/xmlsecurity/Module_xmlsecurity.mk
index 62852c0a4d1d..2416d609d1b8 100644
--- a/xmlsecurity/Module_xmlsecurity.mk
+++ b/xmlsecurity/Module_xmlsecurity.mk
@@ -21,6 +21,7 @@ $(eval $(call gb_Module_add_slowcheck_targets,xmlsecurity,\
 
 $(eval $(call gb_Module_add_subsequentcheck_targets,xmlsecurity,\
     CppunitTest_xmlsecurity_signing \
+    CppunitTest_xmlsecurity_signing2 \
 ))
 
 $(eval $(call gb_Module_add_l10n_targets,xmlsecurity,\
diff --git a/xmlsecurity/qa/unit/signing/signing2.cxx 
b/xmlsecurity/qa/unit/signing/signing2.cxx
index b569891d1a3e..d0bb816d9ee6 100644
--- a/xmlsecurity/qa/unit/signing/signing2.cxx
+++ b/xmlsecurity/qa/unit/signing/signing2.cxx
@@ -9,9 +9,7 @@
 
 #include <sal/config.h>
 
-#include <test/bootstrapfixture.hxx>
-#include <unotest/macros_test.hxx>
-#include <test/xmltesttools.hxx>
+#include <test/unoapixml_test.hxx>
 
 #include <com/sun/star/embed/XStorage.hpp>
 #include <com/sun/star/frame/Desktop.hpp>
@@ -29,78 +27,31 @@
 
 using namespace css;
 
-namespace
-{
-constexpr OUStringLiteral DATA_DIRECTORY = 
u"/xmlsecurity/qa/unit/signing/data/";
-}
-
 /// Testsuite for the document signing feature.
-class SigningTest2 : public test::BootstrapFixture, public 
unotest::MacrosTest, public XmlTestTools
+class SigningTest2 : public UnoApiXmlTest
 {
-protected:
-    uno::Reference<lang::XComponent> mxComponent;
-    uno::Reference<xml::crypto::XSEInitializer> mxSEInitializer;
-    uno::Reference<xml::crypto::XXMLSecurityContext> mxSecurityContext;
-
 public:
     SigningTest2();
-    virtual void setUp() override;
-    virtual void tearDown() override;
     void registerNamespaces(xmlXPathContextPtr& pXmlXpathCtx) override;
 };
 
-SigningTest2::SigningTest2() {}
-
-void SigningTest2::setUp()
-{
-    test::BootstrapFixture::setUp();
-
-    // Initialize crypto after setting up the environment variables.
-    mxDesktop.set(frame::Desktop::create(mxComponentContext));
-}
-
-void SigningTest2::tearDown()
+SigningTest2::SigningTest2()
+    : UnoApiXmlTest("/xmlsecurity/qa/unit/signing/data/")
 {
-    if (mxComponent.is())
-    {
-        css::uno::Reference<css::util::XCloseable> closer(mxComponent, 
css::uno::UNO_QUERY);
-        if (closer.is())
-        {
-            closer->close(true);
-        }
-        mxComponent->dispose();
-    }
-
-    test::BootstrapFixture::tearDown();
 }
 
 /// Test if a macro signature from a ODF Database is preserved when saving
 CPPUNIT_TEST_FIXTURE(SigningTest2, testPreserveMacroSignatureODB)
 {
-    const OUString aURL(m_directories.getURLFromSrc(DATA_DIRECTORY) + 
"odb_signed_macros.odb");
-
-    // load the file
-    mxComponent = loadFromDesktop(aURL, 
"com.sun.star.sdb.OfficeDatabaseDocument");
+    loadFromURL(u"odb_signed_macros.odb");
 
     // save as ODB
-    utl::TempFileNamed aTempFileSaveAsODB;
-    aTempFileSaveAsODB.EnableKillingFile();
-    try
-    {
-        uno::Reference<frame::XStorable> xDocStorable(mxComponent, 
uno::UNO_QUERY);
-        uno::Sequence<beans::PropertyValue> 
descSaveAs(comphelper::InitPropertySequence(
-            { { "FilterName", uno::Any(OUString("StarOffice XML (Base)")) } 
}));
-        xDocStorable->storeAsURL(aTempFileSaveAsODB.GetURL(), descSaveAs);
-    }
-    catch (...)
-    {
-        CPPUNIT_FAIL("Failed to save ODB file");
-    }
+    save("StarOffice XML (Base)");
 
     // Parse the resulting XML.
     uno::Reference<embed::XStorage> xStorage
         = comphelper::OStorageHelper::GetStorageOfFormatFromURL(
-            ZIP_STORAGE_FORMAT_STRING, aTempFileSaveAsODB.GetURL(), 
embed::ElementModes::READ);
+            ZIP_STORAGE_FORMAT_STRING, maTempFile.GetURL(), 
embed::ElementModes::READ);
     CPPUNIT_ASSERT(xStorage.is());
     uno::Reference<embed::XStorage> xMetaInf
         = xStorage->openStorageElement("META-INF", embed::ElementModes::READ);
@@ -124,4 +75,6 @@ void SigningTest2::registerNamespaces(xmlXPathContextPtr& 
pXmlXpathCtx)
     xmlXPathRegisterNs(pXmlXpathCtx, BAD_CAST("xd"), 
BAD_CAST("http://uri.etsi.org/01903/v1.3.2#";));
 }
 
+CPPUNIT_PLUGIN_IMPLEMENT();
+
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */

Reply via email to