From f35bf26814ecfe50cd06bceb87000a66df47d765 Mon Sep 17 00:00:00 2001 From: Basil Crow Date: Fri, 11 Aug 2023 14:27:29 -0700 Subject: [PATCH] [JENKINS-71810] Token Macro tests fail on Java 21 (#191) --- .../impl/ChangesSinceLastBuildMacroTest.java | 10 +++++----- .../ChangesSinceLastSuccessfulBuildMacroTest.java | 12 +++++++----- .../impl/ChangesSinceLastUnstableBuildMacroTest.java | 12 +++++++----- 3 files changed, 19 insertions(+), 15 deletions(-) diff --git a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastBuildMacroTest.java b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastBuildMacroTest.java index 36eaa55..00f58bb 100644 --- a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastBuildMacroTest.java +++ b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastBuildMacroTest.java @@ -21,9 +21,9 @@ import java.util.Map; import java.util.TimeZone; -import static junit.framework.Assert.assertEquals; -import static junit.framework.Assert.assertTrue; -import static org.mockito.ArgumentMatchers.anyInt; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.matchesPattern; +import static org.junit.Assert.assertEquals; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; @@ -74,8 +74,8 @@ public void testShouldPrintDate() String content = changesSinceLastBuildMacro.evaluate(currentBuild, listener, ChangesSinceLastBuildMacro.MACRO_NAME); - // Java 9 changed the SHORT date format... https://www.oracle.com/technetwork/java/javase/9-relnote-issues-3704069.html#JDK-8008577 - assertTrue(content.matches("Oct 21, 2013,? 7:39:00 PM")); + // Java 21 changed the SHORT date format... https://bugs.openjdk.org/browse/JDK-8225245 + assertThat(content, matchesPattern("Oct 21, 2013, 7:39:00\\hPM")); } @Test diff --git a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastSuccessfulBuildMacroTest.java b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastSuccessfulBuildMacroTest.java index 9ff7104..c7007fb 100644 --- a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastSuccessfulBuildMacroTest.java +++ b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastSuccessfulBuildMacroTest.java @@ -19,8 +19,10 @@ import java.util.Locale; import java.util.Map; import java.util.TimeZone; -import static junit.framework.Assert.assertEquals; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.matchesPattern; +import static org.junit.Assert.assertEquals; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; @@ -148,10 +150,10 @@ public void testShouldPrintDate() String contentStr = content.evaluate(currentBuild, listener, ChangesSinceLastSuccessfulBuildMacro.MACRO_NAME); - // Date format changed in Java 9, so we have to accomodate the potential additional comma - // See https://www.oracle.com/technetwork/java/javase/9-relnote-issues-3704069.html#JDK-8008577 - Assert.assertTrue(contentStr.matches( - "Changes for Build #41\n" + "Oct 21, 2013,? 7:39:00 PM\n" + "Changes for Build #42\n" + "Oct 21, 2013,? 7:39:00 PM\n")); + // Date format changed in Java 21, so we have to accomodate the potential narrow no-break space + // See https://bugs.openjdk.org/browse/JDK-8225245 + assertThat(contentStr, matchesPattern( + "Changes for Build #41\n" + "Oct 21, 2013, 7:39:00\\hPM\n" + "Changes for Build #42\n" + "Oct 21, 2013, 7:39:00\\hPM\n")); } @Test diff --git a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastUnstableBuildMacroTest.java b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastUnstableBuildMacroTest.java index eb18ad6..619b446 100644 --- a/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastUnstableBuildMacroTest.java +++ b/src/test/java/org/jenkinsci/plugins/tokenmacro/impl/ChangesSinceLastUnstableBuildMacroTest.java @@ -24,7 +24,9 @@ import java.util.Map; import java.util.TimeZone; -import static junit.framework.Assert.assertEquals; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.matchesPattern; +import static org.junit.Assert.assertEquals; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; @@ -151,10 +153,10 @@ public void testShouldPrintDate() String contentStr = content.evaluate(currentBuild, listener, ChangesSinceLastUnstableBuildMacro.MACRO_NAME); - // Date format changed in Java 9, so we have to accomodate the potential additional comma - // See https://www.oracle.com/technetwork/java/javase/9-relnote-issues-3704069.html#JDK-8008577 - Assert.assertTrue(contentStr.matches( - "Changes for Build #41\n" + "Oct 21, 2013,? 7:39:00 PM\n" + "Changes for Build #42\n" + "Oct 21, 2013,? 7:39:00 PM\n")); + // Date format changed in Java 21, so we have to accomodate the potential narrow no-break space + // See https://bugs.openjdk.org/browse/JDK-8225245 + assertThat(contentStr, matchesPattern( + "Changes for Build #41\n" + "Oct 21, 2013, 7:39:00\\hPM\n" + "Changes for Build #42\n" + "Oct 21, 2013, 7:39:00\\hPM\n")); } @Test