summaryrefslogtreecommitdiff
path: root/jvmfwk
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2021-07-07 16:00:12 +0200
committerStephan Bergmann <sbergman@redhat.com>2021-07-08 08:05:26 +0200
commit395ecf1ed3040b4eac6b1fc8d6b96ca426657321 (patch)
tree0e219dc1a79413d8615337a5dd110f0a0bcbc7b8 /jvmfwk
parent822f128e734f37ee4de9bf5b62640cbec140701e (diff)
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 <sbergman@redhat.com>
Diffstat (limited to 'jvmfwk')
-rw-r--r--jvmfwk/CppunitTest_jvmfwk_sunversion.mk40
-rw-r--r--jvmfwk/Module_jvmfwk.mk4
-rw-r--r--jvmfwk/plugins/sunmajor/pluginlib/sunversion.cxx110
-rw-r--r--jvmfwk/plugins/sunmajor/pluginlib/sunversion.hxx2
-rw-r--r--jvmfwk/qa/unit/sunversion.cxx128
5 files changed, 172 insertions, 112 deletions
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: */