diff --git a/.github/workflows/ci-test.yml b/.github/workflows/ci-test.yml index 640f5ef303b..6d6af47eceb 100644 --- a/.github/workflows/ci-test.yml +++ b/.github/workflows/ci-test.yml @@ -39,6 +39,7 @@ jobs: fail-fast: false matrix: os: [ubuntu-latest, windows-latest, macOS-latest] + jvm: ['17', '21'] runs-on: ${{ matrix.os }} steps: - uses: actions/checkout@v4 @@ -46,7 +47,7 @@ jobs: uses: actions/setup-java@v4 with: distribution: temurin - java-version: ${{ env.DEV_JDK }} + java-version: ${{ matrix.jvm }} cache: 'maven' - name: Install Maven Daemon id: install-mvnd @@ -77,7 +78,7 @@ jobs: if: always() uses: actions/upload-artifact@v4 with: - name: ${{ runner.os }}-build-logs + name: ${{ runner.os }}-${{ matrix.jvm }}-build-logs retention-days: 5 path: | **/*.jfr diff --git a/exist-core/pom.xml b/exist-core/pom.xml index 9ac8220096a..85e25975bdc 100644 --- a/exist-core/pom.xml +++ b/exist-core/pom.xml @@ -1067,9 +1067,9 @@ The BaseX Team. The original license statement is also included below.]]> - org.codehaus.mojo + org.omnifaces antlr-maven-plugin - 2.2 + 2.3 org/exist/xquery/parser/XQuery.g,org/exist/xquery/parser/XQueryTree.g,org/exist/xquery/parser/DeclScanner.g,org/exist/xquery/xqdoc/parser/XQDocParser.g diff --git a/extensions/indexes/range/pom.xml b/extensions/indexes/range/pom.xml index dedd0b2ac62..62ab4ed89e8 100644 --- a/extensions/indexes/range/pom.xml +++ b/extensions/indexes/range/pom.xml @@ -24,7 +24,7 @@ --> 4.0.0 - + org.exist-db exist-parent @@ -42,8 +42,8 @@ scm:git:https://github.com/exist-db/exist.git scm:git:https://github.com/exist-db/exist.git scm:git:https://github.com/exist-db/exist.git - HEAD - + HEAD + @@ -67,7 +67,7 @@ lucene-core ${lucene.version} - + org.apache.lucene lucene-analyzers-common @@ -113,6 +113,13 @@ test + + io.github.hakky54 + logcaptor + 2.9.3 + test + + @@ -128,6 +135,26 @@ + + org.apache.maven.plugins + maven-surefire-plugin + + + org.apache.logging.log4j:log4j-slf4j-impl + org.apache.logging.log4j:log4j-slf4j2-impl + + + + + org.apache.maven.plugins + maven-failsafe-plugin + + + org.apache.logging.log4j:log4j-slf4j-impl + org.apache.logging.log4j:log4j-slf4j2-impl + + + org.apache.maven.plugins maven-dependency-plugin diff --git a/extensions/indexes/range/src/test/java/org/exist/indexing/range/RangeIndexConfigTest.java b/extensions/indexes/range/src/test/java/org/exist/indexing/range/RangeIndexConfigTest.java index 919c1f2dbb4..0b8ea43d2c8 100644 --- a/extensions/indexes/range/src/test/java/org/exist/indexing/range/RangeIndexConfigTest.java +++ b/extensions/indexes/range/src/test/java/org/exist/indexing/range/RangeIndexConfigTest.java @@ -21,25 +21,23 @@ */ package org.exist.indexing.range; +import nl.altindag.log.LogCaptor; import org.apache.logging.log4j.Logger; import org.easymock.Capture; -import org.exist.util.JDKCompatibility; import org.junit.Test; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; -import java.lang.reflect.Field; -import java.lang.reflect.Modifier; import java.util.HashMap; import java.util.Map; -import static junit.framework.TestCase.assertTrue; import static org.easymock.EasyMock.*; import static org.exist.collections.CollectionConfiguration.DEFAULT_COLLECTION_CONFIG_FILE; import static org.exist.indexing.lucene.LuceneIndexConfig.MATCH_ATTR; import static org.exist.indexing.lucene.LuceneIndexConfig.QNAME_ATTR; +import static org.junit.Assert.assertTrue; public class RangeIndexConfigTest { @@ -88,30 +86,20 @@ public void errorsHaveSourceContext() throws NoSuchFieldException, IllegalAccess replay(mockConfigNodes, mockConfigNode, mockCreates, mockCreateDocument, mockCreate, mockEmptyNodeList, mockLogger); - final Map namespaces = new HashMap<>(); namespaces.put("tei", "http://www.tei-c.org/ns/1.0"); - overrideLogger(RangeIndexConfig.class, mockLogger); - final RangeIndexConfig config = new RangeIndexConfig(mockConfigNodes, namespaces); - - assertTrue(errorMsgCapture.getValue().contains("Illegal QName: '" + badCreateQName + "'.. QName is invalid: INVALID_LOCAL_PART")); - assertTrue(errorMsgCapture.getValue().contains("(" + mockCollectionXConfUri + ")")); + LogCaptor logCaptor = LogCaptor.forClass(RangeIndexConfig.class); - verify(mockConfigNodes, mockConfigNode, mockCreates, mockCreateDocument, mockCreate, mockEmptyNodeList, mockLogger); - } - - private void overrideLogger(final Class clazz, final Logger logger) throws NoSuchFieldException, IllegalAccessException { - final Field loggerField = clazz.getDeclaredField("LOG"); + final RangeIndexConfig config = new RangeIndexConfig(mockConfigNodes, namespaces); - // allow access to private field - loggerField.setAccessible(true); + assertTrue(logCaptor.getLogs().get(0) + .contains("Illegal QName: '" + badCreateQName + "'.. QName is invalid: INVALID_LOCAL_PART")); - // remove final modifier - final Field modifiersField = JDKCompatibility.getModifiersField(); - modifiersField.setAccessible(true); - modifiersField.setInt(loggerField, loggerField.getModifiers() & ~Modifier.FINAL); + assertTrue(logCaptor.getLogs().get(0) + .contains("(" + mockCollectionXConfUri + ")")); - loggerField.set(null, logger); + verify(mockConfigNodes, mockConfigNode, mockCreates, mockCreateDocument, mockCreate, mockEmptyNodeList); } + } diff --git a/extensions/modules/simpleql/pom.xml b/extensions/modules/simpleql/pom.xml index 67030fdc0b2..4d18433a994 100644 --- a/extensions/modules/simpleql/pom.xml +++ b/extensions/modules/simpleql/pom.xml @@ -67,9 +67,9 @@ - org.codehaus.mojo + org.omnifaces antlr-maven-plugin - 2.2 + 2.3 org/exist/xquery/modules/simpleql/SimpleQLParser.g