jvmfwk/CppunitTest_jvmfwk_sunversion.mk          |   40 +++++++
 jvmfwk/Module_jvmfwk.mk                          |    4 
 jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx |  110 -------------------
 jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx |    2 
 jvmfwk/qa/unit/sunversion.cxx                    |  128 +++++++++++++++++++++++
 solenv/clang-format/excludelist                  |    1 
 6 files changed, 173 insertions(+), 112 deletions(-)

New commits:
commit 395ecf1ed3040b4eac6b1fc8d6b96ca426657321
Author:     Stephan Bergmann <sberg...@redhat.com>
AuthorDate: Wed Jul 7 16:00:12 2021 +0200
Commit:     Stephan Bergmann <sberg...@redhat.com>
CommitDate: Thu Jul 8 08:05:26 2021 +0200

    Turn OSL_DEBUG_LEVEL >= 2 SelfTest into CppunitTest
    
    ...and move "10.0", "10.10", and "1.5.0_010" from badVersions[] to good
    versions[] to make the test succeed (assuming these shall indeed be 
classified
    as good by now, presumably due to changes to the SunVersion implementation 
in
    the meantime)
    
    Change-Id: Ia7cf9b0e607743a5e0534078c0221c1423f6cfb3
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/118570
    Tested-by: Jenkins
    Reviewed-by: Stephan Bergmann <sberg...@redhat.com>

diff --git a/jvmfwk/CppunitTest_jvmfwk_sunversion.mk 
b/jvmfwk/CppunitTest_jvmfwk_sunversion.mk
new file mode 100644
index 000000000000..8aa6a2c68ea2
--- /dev/null
+++ b/jvmfwk/CppunitTest_jvmfwk_sunversion.mk
@@ -0,0 +1,40 @@
+# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t; fill-column: 
100 -*-
+#
+# 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,jvmfwk_sunversion))
+
+$(eval $(call gb_CppunitTest_add_exception_objects,jvmfwk_sunversion, \
+    jvmfwk/qa/unit/sunversion \
+))
+
+$(eval $(call gb_CppunitTest_set_include,jvmfwk_sunversion, \
+    $$(INCLUDE) \
+    -I$(SRCDIR) \
+))
+
+$(eval $(call gb_CppunitTest_use_externals,jvmfwk_sunversion, \
+    libxml2 \
+))
+
+$(eval $(call gb_CppunitTest_use_libraries,jvmfwk_sunversion, \
+    sal \
+    salhelper \
+))
+
+$(eval $(call gb_CppunitTest_use_library_objects,jvmfwk_sunversion, \
+    jvmfwk \
+))
+
+ifeq ($(OS),MACOSX)
+$(eval $(call gb_CppunitTest_use_system_darwin_frameworks,jvmfwk_sunversion, \
+    Foundation \
+))
+endif
+
+# vim: set noet sw=4 ts=4:
diff --git a/jvmfwk/Module_jvmfwk.mk b/jvmfwk/Module_jvmfwk.mk
index 396ed21de8d9..802daed57005 100644
--- a/jvmfwk/Module_jvmfwk.mk
+++ b/jvmfwk/Module_jvmfwk.mk
@@ -28,6 +28,10 @@ $(eval $(call gb_Module_add_targets,jvmfwk,\
 endif
 endif
 
+$(eval $(call gb_Module_add_check_targets,jvmfwk, \
+    CppunitTest_jvmfwk_sunversion \
+))
+
 endif
 
 # vim:set noet sw=4 ts=4:
diff --git a/jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx 
b/jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx
index ded1fc5f45f5..49157f033616 100644
--- a/jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx
+++ b/jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx
@@ -22,21 +22,9 @@
 #include <osl/thread.h>
 #include <rtl/character.hxx>
 #include <string.h>
-#if OSL_DEBUG_LEVEL >= 2
-#include <osl/diagnose.h>
-#include "diagnostics.h"
-#endif
 namespace jfw_plugin  { //stoc_javadetect
 
 
-#if OSL_DEBUG_LEVEL >= 2
-class SelfTest
-{
-public:
-    SelfTest();
-} test;
-#endif
-
 SunVersion::SunVersion(std::u16string_view usVer):
     m_nUpdateSpecial(0), m_preRelease(Rel_NONE)
 {
@@ -314,104 +302,6 @@ bool SunVersion::operator == (const SunVersion& ver) const
     return bRet;
 }
 
-
-#if OSL_DEBUG_LEVEL >= 2
-SelfTest::SelfTest()
-{
-    bool bRet = true;
-
-    static char const * versions[] = {"1.4.0", "1.4.1", "1.0.0", "10.0.0", 
"10.10.0",
-                         "10.2.2", "10.10.0", "10.10.10", "111.0.999",
-                         "1.4.1_01", "9.90.99_09", "1.4.1_99",
-                         "1.4.1_00a",
-                         "1.4.1-ea", "1.4.1-beta", "1.4.1-rc1",
-                         "1.5.0_01-ea", "1.5.0_01-rc2"};
-    static char const * badVersions[] = {".4.0", "..1", "", "10.0", 
"10.10.0.", "10.10.0-", "10.10.0.",
-                            "10.2-2", "10_10.0", "10..10","10.10", "a.0.999",
-                            "1.4b.1_01", "9.90.-99_09", "1.4.1_99-",
-                            "1.4.1_00a2", "1.4.0_z01z", "1.4.1__99A",
-                            "1.4.1-1ea", "1.5.0_010", "1.5.0._01-", 
"1.5.0_01-eac"};
-    static char const * orderedVer[] = { "1.3.1-ea", "1.3.1-beta", "1.3.1-rc1",
-                            "1.3.1", "1.3.1_00a", "1.3.1_01", "1.3.1_01a",
-                            "1.3.2", "1.4.0", "1.5.0_01-ea", "2.0.0"};
-
-    int num = SAL_N_ELEMENTS (versions);
-    int numBad = SAL_N_ELEMENTS (badVersions);
-    int numOrdered = SAL_N_ELEMENTS (orderedVer);
-    //parsing test (positive)
-    for (int i = 0; i < num; i++)
-    {
-        SunVersion ver(versions[i]);
-        if ( ! ver)
-        {
-            bRet = false;
-            break;
-        }
-    }
-    OSL_ENSURE(bRet, "SunVersion selftest failed");
-    //Parsing test (negative)
-    for ( int i = 0; i < numBad; i++)
-    {
-        SunVersion ver(badVersions[i]);
-        if (ver)
-        {
-            bRet = false;
-            break;
-        }
-    }
-    OSL_ENSURE(bRet, "SunVersion selftest failed");
-
-    // Ordering test
-    bRet = true;
-    int j = 0;
-    for (int i = 0; i < numOrdered; i ++)
-    {
-        SunVersion curVer(orderedVer[i]);
-        if ( ! curVer)
-        {
-            bRet = false;
-            break;
-        }
-        for (j = 0; j < numOrdered; j++)
-        {
-            SunVersion compVer(orderedVer[j]);
-            if (i < j)
-            {
-                if ( !(curVer < compVer))
-                {
-                    bRet = false;
-                    break;
-                }
-            }
-            else if ( i == j)
-            {
-                if (! (curVer == compVer
-                       && ! (curVer > compVer)
-                       && ! (curVer < compVer)))
-                {
-                    bRet = false;
-                    break;
-                }
-            }
-            else if (i > j)
-            {
-                if ( !(curVer > compVer))
-                {
-                    bRet = false;
-                    break;
-                }
-            }
-        }
-        if ( ! bRet)
-            break;
-    }
-    if (bRet)
-        JFW_TRACE2("Testing class SunVersion succeeded.");
-    else
-        OSL_ENSURE(bRet, "[Java framework] sunjavaplugin: SunVersion self test 
failed.");
-}
-#endif
-
 }
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx 
b/jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx
index 0f351dfb0591..6d2def297d4d 100644
--- a/jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx
+++ b/jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx
@@ -28,8 +28,6 @@
 
 namespace jfw_plugin
 {
-// Define OSL_DEBUG_LEVEL >= 2 to run a test when this lib is loaded
-
 /* SunVersion is used to compare java versions based on a string, as taken
    from the registry. The strings look like "1.3", "1.3.1", "1.3.1_02" etc.
    Versions such as "1.4.1_01a" are allowed although this is not specified.
diff --git a/jvmfwk/qa/unit/sunversion.cxx b/jvmfwk/qa/unit/sunversion.cxx
new file mode 100644
index 000000000000..a717dc438b90
--- /dev/null
+++ b/jvmfwk/qa/unit/sunversion.cxx
@@ -0,0 +1,128 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; 
fill-column: 100 -*- */
+/*
+ * 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/.
+ *
+ * This file incorporates work covered by the following license notice:
+ *
+ *   Licensed to the Apache Software Foundation (ASF) under one or more
+ *   contributor license agreements. See the NOTICE file distributed
+ *   with this work for additional information regarding copyright
+ *   ownership. The ASF licenses this file to you under the Apache
+ *   License, Version 2.0 (the "License"); you may not use this file
+ *   except in compliance with the License. You may obtain a copy of
+ *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
+ */
+
+#include <sal/config.h>
+
+#include <cppunit/TestAssert.h>
+#include <cppunit/TestFixture.h>
+#include <cppunit/extensions/HelperMacros.h>
+#include <cppunit/plugin/TestPlugIn.h>
+
+#include <rtl/string.hxx>
+#include <sal/types.h>
+
+#include <jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx>
+
+namespace
+{
+class TestSunVersion : public CppUnit::TestFixture
+{
+    CPPUNIT_TEST_SUITE(TestSunVersion);
+    CPPUNIT_TEST(testSunVersion);
+    CPPUNIT_TEST_SUITE_END();
+
+    void testSunVersion();
+};
+
+void TestSunVersion::testSunVersion()
+{
+    static char const * versions[] = {"1.4.0", "1.4.1", "1.0.0", "10.0.0", 
"10.10.0",
+                         "10.2.2", "10.10.0", "10.10.10", "111.0.999",
+                         "1.4.1_01", "9.90.99_09", "1.4.1_99",
+                         "1.4.1_00a",
+                         "1.4.1-ea", "1.4.1-beta", "1.4.1-rc1",
+                         "1.5.0_01-ea", "1.5.0_01-rc2",
+                         "10.0", "10.10", "1.5.0_010"};
+    static char const * badVersions[] = {".4.0", "..1", "", "10.10.0.", 
"10.10.0-", "10.10.0.",
+                            "10.2-2", "10_10.0", "10..10", "a.0.999",
+                            "1.4b.1_01", "9.90.-99_09", "1.4.1_99-",
+                            "1.4.1_00a2", "1.4.0_z01z", "1.4.1__99A",
+                            "1.4.1-1ea", "1.5.0._01-", "1.5.0_01-eac"};
+    static char const * orderedVer[] = { "1.3.1-ea", "1.3.1-beta", "1.3.1-rc1",
+                            "1.3.1", "1.3.1_00a", "1.3.1_01", "1.3.1_01a",
+                            "1.3.2", "1.4.0", "1.5.0_01-ea", "2.0.0"};
+
+    int num = SAL_N_ELEMENTS (versions);
+    int numBad = SAL_N_ELEMENTS (badVersions);
+    int numOrdered = SAL_N_ELEMENTS (orderedVer);
+    //parsing test (positive)
+    for (int i = 0; i < num; i++)
+    {
+        jfw_plugin::SunVersion ver(versions[i]);
+        CPPUNIT_ASSERT_MESSAGE(
+            OString(OString::Concat("SunVersion(\"") + versions[i] + "\") 
good").getStr(), ver);
+    }
+    //Parsing test (negative)
+    for ( int i = 0; i < numBad; i++)
+    {
+        jfw_plugin::SunVersion ver(badVersions[i]);
+        CPPUNIT_ASSERT_MESSAGE(
+            OString(OString::Concat("SunVersion(\"") + badVersions[i] + "\") 
bad").getStr(), !ver);
+    }
+
+    // Ordering test
+    int j = 0;
+    for (int i = 0; i < numOrdered; i ++)
+    {
+        jfw_plugin::SunVersion curVer(orderedVer[i]);
+        CPPUNIT_ASSERT_MESSAGE(
+            OString(OString::Concat("SunVersion(\"") + orderedVer[i] + "\") 
good").getStr(),
+            curVer);
+        for (j = 0; j < numOrdered; j++)
+        {
+            jfw_plugin::SunVersion compVer(orderedVer[j]);
+            if (i < j)
+            {
+                CPPUNIT_ASSERT_MESSAGE(
+                    OString(OString::Concat("\"") + orderedVer[i] + "\" < \"" 
+ orderedVer[j])
+                        .getStr(),
+                    curVer < compVer);
+            }
+            else if ( i == j)
+            {
+                CPPUNIT_ASSERT_MESSAGE(
+                    OString(OString::Concat("\"") + orderedVer[i] + "\" == \"" 
+ orderedVer[j])
+                        .getStr(),
+                    curVer.operator ==(compVer));
+                CPPUNIT_ASSERT_MESSAGE(
+                    OString(OString::Concat("not \"") + orderedVer[i] + "\" > 
\"" + orderedVer[j])
+                        .getStr(),
+                    ! (curVer > compVer));
+                CPPUNIT_ASSERT_MESSAGE(
+                    OString(OString::Concat("not \"") + orderedVer[i] + "\" < 
\"" + orderedVer[j])
+                        .getStr(),
+                    ! (curVer < compVer));
+            }
+            else if (i > j)
+            {
+                CPPUNIT_ASSERT_MESSAGE(
+                    OString(OString::Concat("\"") + orderedVer[i] + "\" > \"" 
+ orderedVer[j])
+                        .getStr(),
+                    curVer > compVer);
+            }
+        }
+    }
+}
+
+CPPUNIT_TEST_SUITE_REGISTRATION(TestSunVersion);
+}
+
+CPPUNIT_PLUGIN_IMPLEMENT();
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s 
cinkeys+=0=break: */
diff --git a/solenv/clang-format/excludelist b/solenv/clang-format/excludelist
index 18f9687dd693..de0adf28e56f 100644
--- a/solenv/clang-format/excludelist
+++ b/solenv/clang-format/excludelist
@@ -6654,6 +6654,7 @@ jvmfwk/plugins/sunmajor/pluginlib/util.hxx
 jvmfwk/plugins/sunmajor/pluginlib/vendorbase.cxx
 jvmfwk/plugins/sunmajor/pluginlib/vendorlist.cxx
 jvmfwk/plugins/sunmajor/pluginlib/vendorlist.hxx
+jvmfwk/qa/unit/sunversion.cxx
 jvmfwk/source/elements.cxx
 jvmfwk/source/framework.cxx
 jvmfwk/source/framework.hxx
_______________________________________________
Libreoffice-commits mailing list
libreoffice-comm...@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits

Reply via email to