diff --git a/src/main/java/org/jenkinsci/test/acceptance/FallbackConfig.java b/src/main/java/org/jenkinsci/test/acceptance/FallbackConfig.java index 7516347645..87bfdb4e9f 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/FallbackConfig.java +++ b/src/main/java/org/jenkinsci/test/acceptance/FallbackConfig.java @@ -18,7 +18,6 @@ import java.nio.file.Files; import java.nio.file.Path; import java.time.Duration; -import java.util.Collections; import java.util.HashMap; import java.util.Locale; import java.util.Map; @@ -107,7 +106,7 @@ private WebDriver createWebDriver(TestCleaner cleaner, TestName testName) throws setDriverPropertyIfMissing("geckodriver", GeckoDriverService.GECKO_DRIVER_EXE_PROPERTY); GeckoDriverService.Builder builder = new GeckoDriverService.Builder(); if (display != null) { - builder.withEnvironment(Collections.singletonMap("DISPLAY", display)); + builder.withEnvironment(Map.of("DISPLAY", display)); } GeckoDriverService service = builder.build(); return new FirefoxDriver(service, buildFirefoxOptions(testName)); @@ -117,7 +116,7 @@ private WebDriver createWebDriver(TestCleaner cleaner, TestName testName) throws case "chrome-container": return createContainerWebDriver(cleaner, "selenium/standalone-chrome:4.24.0", new ChromeOptions()); case "chrome": - Map prefs = new HashMap(); + Map prefs = new HashMap<>(); prefs.put(LANGUAGE_SELECTOR, "en"); ChromeOptions options = new ChromeOptions(); options.setExperimentalOption("prefs", prefs); @@ -283,7 +282,7 @@ private Proxy createSeleniumProxy(String testName) throws UnknownHostException { // if we are running maven locally but the browser elsewhere (e.g. docker) using the "127.0.0.1" // address will not work for the browser String name = System.getenv("SELENIUM_PROXY_HOSTNAME"); - InetAddress proxyAddr = null; + InetAddress proxyAddr; if (name != null) { proxyAddr = InetAddress.getByName(name); } else { diff --git a/src/main/java/org/jenkinsci/test/acceptance/Matchers.java b/src/main/java/org/jenkinsci/test/acceptance/Matchers.java index 5845dfbef3..9b4f296678 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/Matchers.java +++ b/src/main/java/org/jenkinsci/test/acceptance/Matchers.java @@ -34,7 +34,7 @@ public static Matcher hasContent(final String content) { } public static Matcher hasContent(final Pattern pattern) { - return new Matcher("Text matching %s", pattern) { + return new Matcher<>("Text matching %s", pattern) { // text captured the time matchesSafely was executed private String pageText; @@ -59,7 +59,7 @@ public void describeMismatchSafely(WebDriver item, Description mismatchDescripti * Matches that matches {@link WebDriver} when it has an element that matches to the given selector. */ public static Matcher hasElement(final By selector) { - return new Matcher("contains element that matches %s", selector) { + return new Matcher<>("contains element that matches %s", selector) { @Override public boolean matchesSafely(WebDriver item) { try { @@ -78,7 +78,7 @@ public void describeMismatchSafely(WebDriver item, Description d) { } public static Matcher hasURL(final URL url) { - return new Matcher("URL matching %s", url) { + return new Matcher<>("URL matching %s", url) { @Override public boolean matchesSafely(WebDriver item) { return item.getCurrentUrl().equals(url.toString()); @@ -95,7 +95,7 @@ public void describeMismatchSafely(WebDriver item, Description mismatchDescripti * For asserting that a {@link PageObject}'s top page has an action of the given name. */ public static Matcher hasAction(final String displayName) { - return new Matcher("contains action titled %s", displayName) { + return new Matcher<>("contains action titled %s", displayName) { @Override public boolean matchesSafely(PageObject po) { try { @@ -147,7 +147,7 @@ public static org.hamcrest.Matcher containsString(final String format, f * Matches if a string contains a portion that matches to the regular expression. */ public static Matcher containsRegexp(final Pattern re) { - return new Matcher("Matches regexp %s", re.toString()) { + return new Matcher<>("Matches regexp %s", re.toString()) { @Override public boolean matchesSafely(String item) { return re.matcher(item).find(); @@ -156,7 +156,7 @@ public boolean matchesSafely(String item) { } public static Matcher pageObjectExists() { - return new Matcher("Page object exists") { + return new Matcher<>("Page object exists") { private @CheckForNull HttpURLConnection conn; // Store for later defect localization @Override @@ -178,7 +178,7 @@ public boolean matchesSafely(PageObject item) { } public static Matcher pageObjectDoesNotExist() { - return new Matcher("Page object does not exist") { + return new Matcher<>("Page object does not exist") { private @CheckForNull HttpURLConnection conn; // Store for later defect localization @Override @@ -199,7 +199,7 @@ public boolean matchesSafely(PageObject item) { } public static Matcher hasLoggedInUser(final String user) { - return new Matcher("has logged in user %s", user) { + return new Matcher<>("has logged in user %s", user) { @Override public boolean matchesSafely(final Jenkins jenkins) { final User currentUser = jenkins.getCurrentUser(); @@ -217,7 +217,7 @@ public void describeMismatchSafely(final Jenkins item, final Description desc) { } public static Matcher loggedInAs(final String user) { - return new Matcher("has logged in user %s", user) { + return new Matcher<>("has logged in user %s", user) { @Override public boolean matchesSafely(final Login login) { final User currentUser = login.getJenkins().getCurrentUser(); @@ -235,7 +235,7 @@ public void describeMismatchSafely(final Login item, final Description desc) { } public static Matcher hasInvalidLoginInformation() { - return new Matcher("has invalid login information message") { + return new Matcher<>("has invalid login information message") { @Override public boolean matchesSafely(final Login login) { try { @@ -254,7 +254,7 @@ public void describeMismatchSafely(final Login item, final Description desc) { } public static Matcher isMemberOf(final String group) { - return new Matcher(" is member of group %s", group) { + return new Matcher<>(" is member of group %s", group) { @Override public boolean matchesSafely(final User user) { user.open(); @@ -279,7 +279,7 @@ public void describeMismatchSafely(final User item, final Description desc) { } public static Matcher fullNameIs(final String fullName) { - return new Matcher(" full name is %s", fullName) { + return new Matcher<>(" full name is %s", fullName) { @Override public boolean matchesSafely(final User user) { if (user.fullName() != null) { @@ -296,7 +296,7 @@ public void describeMismatchSafely(final User item, final Description desc) { } public static Matcher mailAddressIs(final String mail) { - return new Matcher(" mail address is %s", mail) { + return new Matcher<>(" mail address is %s", mail) { @Override public boolean matchesSafely(final User user) { if (user.mail() != null) { @@ -313,7 +313,7 @@ public void describeMismatchSafely(final User item, final Description desc) { } public static Matcher existingFile() { - return new Matcher("an existing file") { + return new Matcher<>("an existing file") { @Override public boolean matchesSafely(final File item) { return item.exists() && item.isFile(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/controller/JBossController.java b/src/main/java/org/jenkinsci/test/acceptance/controller/JBossController.java index fedf9298a3..d69023ec55 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/controller/JBossController.java +++ b/src/main/java/org/jenkinsci/test/acceptance/controller/JBossController.java @@ -11,7 +11,8 @@ import java.net.MalformedURLException; import java.net.URL; import java.nio.charset.StandardCharsets; -import org.codehaus.plexus.util.FileUtils; +import java.nio.file.Files; +import org.apache.commons.io.FileUtils; import org.jenkinsci.test.acceptance.utils.IOUtil; import org.jenkinsci.utils.process.CommandBuilder; import org.jenkinsci.utils.process.ProcessInputStream; @@ -62,8 +63,8 @@ public ProcessInputStream startProcess() throws IOException { if (context.exists()) { org.apache.commons.io.FileUtils.forceDelete(context); } - org.apache.commons.io.FileUtils.write( - context, + Files.writeString( + context.toPath(), "\n" + " \n" + "", diff --git a/src/main/java/org/jenkinsci/test/acceptance/controller/JenkinsLogWatcher.java b/src/main/java/org/jenkinsci/test/acceptance/controller/JenkinsLogWatcher.java index d859cb410c..5274589b41 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/controller/JenkinsLogWatcher.java +++ b/src/main/java/org/jenkinsci/test/acceptance/controller/JenkinsLogWatcher.java @@ -7,6 +7,7 @@ import java.io.IOException; import java.io.InputStream; import java.nio.charset.StandardCharsets; +import java.nio.file.Files; import java.util.Date; import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; @@ -14,7 +15,6 @@ import java.util.concurrent.TimeoutException; import java.util.regex.Matcher; import java.util.regex.Pattern; -import org.apache.commons.io.FileUtils; import org.apache.commons.io.input.TeeInputStream; import org.jenkinsci.test.acceptance.log.LogListenable; import org.jenkinsci.test.acceptance.log.LogListener; @@ -110,7 +110,7 @@ private String failedToLoadMessage() { msg += "\nprocess is " + (reader.isAlive() ? "alive" : "dead"); msg += "\nnow = " + new Date(); try { - msg += "\n" + FileUtils.readFileToString(logFile, StandardCharsets.UTF_8); + msg += "\n" + Files.readString(logFile.toPath(), StandardCharsets.UTF_8); } catch (IOException ignored) { // ignore } diff --git a/src/main/java/org/jenkinsci/test/acceptance/controller/LocalController.java b/src/main/java/org/jenkinsci/test/acceptance/controller/LocalController.java index 0bd4545b48..73105f020b 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/controller/LocalController.java +++ b/src/main/java/org/jenkinsci/test/acceptance/controller/LocalController.java @@ -18,8 +18,8 @@ import java.util.logging.Level; import java.util.logging.Logger; import org.apache.commons.io.FileUtils; +import org.apache.commons.lang3.StringUtils; import org.codehaus.plexus.util.Expand; -import org.codehaus.plexus.util.StringUtils; import org.jenkinsci.test.acceptance.junit.FailureDiagnostics; import org.jenkinsci.test.acceptance.log.LogListenable; import org.jenkinsci.test.acceptance.log.LogListener; @@ -148,7 +148,7 @@ public void populateJenkinsHome(byte[] _template, boolean clean) throws IOExcept } File template = File.createTempFile("template", ".dat"); try { - FileUtils.writeByteArrayToFile(template, _template); + Files.write(template.toPath(), _template); Expand expand = new Expand(); expand.setSrc(template); expand.setOverwrite(true); diff --git a/src/main/java/org/jenkinsci/test/acceptance/controller/TomcatController.java b/src/main/java/org/jenkinsci/test/acceptance/controller/TomcatController.java index 5a2cc099ac..348a01b063 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/controller/TomcatController.java +++ b/src/main/java/org/jenkinsci/test/acceptance/controller/TomcatController.java @@ -11,6 +11,7 @@ import java.net.MalformedURLException; import java.net.URL; import java.nio.charset.StandardCharsets; +import java.nio.file.Files; import org.apache.commons.io.FileUtils; import org.jenkinsci.test.acceptance.utils.IOUtil; import org.jenkinsci.utils.process.CommandBuilder; @@ -56,8 +57,8 @@ public ProcessInputStream startProcess() throws IOException { if (context.exists()) { FileUtils.forceDelete(context); } - FileUtils.write( - context, + Files.writeString( + context.toPath(), "\n" + " \n" + "", diff --git a/src/main/java/org/jenkinsci/test/acceptance/controller/WinstoneController.java b/src/main/java/org/jenkinsci/test/acceptance/controller/WinstoneController.java index 0804c95f13..b2f6c589b2 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/controller/WinstoneController.java +++ b/src/main/java/org/jenkinsci/test/acceptance/controller/WinstoneController.java @@ -8,12 +8,11 @@ import java.net.MalformedURLException; import java.net.URL; import java.nio.charset.StandardCharsets; +import java.nio.file.Files; import java.util.ArrayList; -import java.util.Arrays; import java.util.Collections; import java.util.List; import java.util.logging.Logger; -import org.apache.commons.io.FileUtils; import org.apache.commons.lang3.StringUtils; import org.jenkinsci.utils.process.CommandBuilder; import org.jenkinsci.utils.process.ProcessInputStream; @@ -37,7 +36,7 @@ protected static List envVarOpts(String jenkins_opts) { if (getenv == null) { return Collections.emptyList(); } - return Arrays.asList(getenv.split("\\s+")); + return List.of(getenv.split("\\s+")); } public void addJavaOpt(String javaOpt) { @@ -61,7 +60,7 @@ public WinstoneController(Injector i, int httpPort) { @Override protected void onReady() throws IOException { if (this.httpPort == 0 && portFile != null) { - String s = FileUtils.readFileToString(portFile, StandardCharsets.UTF_8); + String s = Files.readString(portFile.toPath(), StandardCharsets.UTF_8); try { this.httpPort = Integer.parseInt(s); } catch (NumberFormatException e) { diff --git a/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/GitLabContainer.java b/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/GitLabContainer.java index e383c69612..0b51041286 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/GitLabContainer.java +++ b/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/GitLabContainer.java @@ -89,8 +89,7 @@ public HttpResponse createRepo(String repoName, String token) throws Run .header("PRIVATE-TOKEN", token) .POST(HttpRequest.BodyPublishers.ofString("{ \"name\": \"" + repoName + "\" }")) .build(); - HttpResponse response = client.send(request, HttpResponse.BodyHandlers.ofString()); - return response; + return client.send(request, HttpResponse.BodyHandlers.ofString()); } catch (Exception e) { throw new RuntimeException(e); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/JiraContainer.java b/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/JiraContainer.java index 93a7958b8d..2278cf1f56 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/JiraContainer.java +++ b/src/main/java/org/jenkinsci/test/acceptance/docker/fixtures/JiraContainer.java @@ -12,7 +12,6 @@ import java.net.URLConnection; import java.nio.charset.StandardCharsets; import java.time.Duration; -import java.util.Arrays; import java.util.List; import javax.xml.rpc.ServiceException; import org.apache.commons.io.IOUtils; @@ -96,7 +95,7 @@ private void connect() throws IOException, ServiceException { public List getComments(String ticket) throws IOException, ServiceException { connect(); - return Arrays.asList(svc.getComments(token, ticket)); + return List.of(svc.getComments(token, ticket)); } public JiraSoapService getSvc() { diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/FailureDiagnostics.java b/src/main/java/org/jenkinsci/test/acceptance/junit/FailureDiagnostics.java index 423ee3cafe..013fabc3c8 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/FailureDiagnostics.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/FailureDiagnostics.java @@ -5,9 +5,11 @@ import java.io.FileWriter; import java.io.IOException; import java.nio.file.Files; +import java.nio.file.Path; import java.util.logging.Level; import java.util.logging.Logger; -import org.codehaus.plexus.util.FileUtils; +import java.util.stream.Stream; +import org.apache.commons.io.FileUtils; import org.jenkinsci.test.acceptance.guice.TestName; import org.jenkinsci.test.acceptance.guice.TestScope; import org.junit.rules.TestWatcher; @@ -103,8 +105,8 @@ protected void succeeded(Description description) { @Override public void failed(Throwable e, Description description) { if (dir.exists()) { - try { - Files.walk(dir.toPath()).forEach(p -> { + try (Stream stream = Files.walk(dir.toPath())) { + stream.forEach(p -> { if (Files.isRegularFile(p)) { // https://wiki.jenkins-ci.org/display/JENKINS/JUnit+Attachments+Plugin#JUnitAttachmentsPlugin-ByprintingoutthefilenameinaformatthatJenkinswillunderstand System.out.printf((JUNIT_ATTACHMENT) + "%n", p.toAbsolutePath()); diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/FilterRule.java b/src/main/java/org/jenkinsci/test/acceptance/junit/FilterRule.java index faca1510f3..c1e93afb09 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/FilterRule.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/FilterRule.java @@ -25,8 +25,8 @@ import com.google.inject.Inject; import java.lang.annotation.Annotation; -import java.util.Arrays; import java.util.HashSet; +import java.util.List; import java.util.Set; import org.jenkinsci.test.acceptance.guice.World; import org.junit.Assume; @@ -70,7 +70,7 @@ public abstract static class Filter { public abstract String whySkip(Statement base, Description description); public static Set getAnnotations(Description description, Class type) { - Set annotations = new HashSet(); + Set annotations = new HashSet<>(); annotations.add(description.getAnnotation(type)); annotations.add(description.getTestClass().getAnnotation(type)); annotations.remove(null); @@ -78,9 +78,9 @@ public static Set getAnnotations(Description descripti } public static Set getAnnotations(Description description) { - Set annotations = new HashSet(); + Set annotations = new HashSet<>(); annotations.addAll(description.getAnnotations()); - annotations.addAll(Arrays.asList(description.getTestClass().getAnnotations())); + annotations.addAll(List.of(description.getTestClass().getAnnotations())); return annotations; } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/JUnitProgressReporter.java b/src/main/java/org/jenkinsci/test/acceptance/junit/JUnitProgressReporter.java index 275b831690..d097a9358d 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/JUnitProgressReporter.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/JUnitProgressReporter.java @@ -14,7 +14,7 @@ * @author Ullrich Hafner */ public class JUnitProgressReporter extends RunListener { - private final Set results = new CopyOnWriteArraySet(); + private final Set results = new CopyOnWriteArraySet<>(); @Override public void testStarted(final Description description) throws Exception { diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/JenkinsAcceptanceTestRule.java b/src/main/java/org/jenkinsci/test/acceptance/junit/JenkinsAcceptanceTestRule.java index f87b56faab..c78c146167 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/JenkinsAcceptanceTestRule.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/JenkinsAcceptanceTestRule.java @@ -90,7 +90,7 @@ private Statement decorateWithRules(Statement body) { collectGlobalRules(rules); // Make sure Jenkins is started between -1 and 0 - rules.computeIfAbsent(0, k -> new LinkedHashSet()); + rules.computeIfAbsent(0, k -> new LinkedHashSet<>()); rules.get(0).add(jenkinsBoot(rules)); for (Set rulesGroup : rules.values()) { diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/Wait.java b/src/main/java/org/jenkinsci/test/acceptance/junit/Wait.java index 4ebbc11d13..badfee38e9 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/Wait.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/Wait.java @@ -23,12 +23,12 @@ */ package org.jenkinsci.test.acceptance.junit; -import com.google.common.base.Function; import java.time.Clock; import java.time.Duration; import java.time.Instant; import java.time.ZoneId; import java.util.concurrent.Callable; +import java.util.function.Function; import org.hamcrest.Matcher; import org.hamcrest.StringDescription; import org.jenkinsci.test.acceptance.utils.ElasticTime; @@ -117,7 +117,7 @@ public Wait withMessage(String pattern, Object... args) { // For convenience as we have quite a lot of Callables historically public Return until(final Callable isTrue) { - return super.until(new Function() { + return super.until(new Function<>() { @Override public Return apply(Subject input) { try { @@ -153,7 +153,7 @@ public String diagnose(Throwable lastException, String message) { } public Return until(final Wait.Predicate isTrue) { - Function fun = new Function() { + Function fun = new Function<>() { @Override public Return apply(Subject input) { try { @@ -183,7 +183,7 @@ public String toString() { protected RuntimeException timeoutException(String message, Throwable lastException) { if (predicate != null) { String diagnosis = predicate.diagnose(lastException, message); - if (diagnosis != null && !diagnosis.equals("")) { + if (diagnosis != null && !diagnosis.isEmpty()) { message += ". " + diagnosis; } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/WithOS.java b/src/main/java/org/jenkinsci/test/acceptance/junit/WithOS.java index c7040b4914..2d4cecb6a0 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/WithOS.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/WithOS.java @@ -8,6 +8,7 @@ import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; import java.util.Arrays; +import java.util.List; import org.apache.commons.lang3.SystemUtils; import org.jenkinsci.test.acceptance.controller.JenkinsController; import org.jenkinsci.test.acceptance.controller.LocalController; @@ -76,7 +77,7 @@ private void check(WithOS withos, Class testCase) { String errorMsg = "Test and Jenkins instance must be running on any of the following operating systems: " + Arrays.toString(withos.os()); - if (!Arrays.asList(withos.os()).contains(currentOS())) { + if (!List.of(withos.os()).contains(currentOS())) { throw new AssumptionViolatedException(errorMsg); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/junit/WithPlugins.java b/src/main/java/org/jenkinsci/test/acceptance/junit/WithPlugins.java index a629e0ffc5..1123c3c3df 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/junit/WithPlugins.java +++ b/src/main/java/org/jenkinsci/test/acceptance/junit/WithPlugins.java @@ -183,7 +183,7 @@ private void installPlugins(List install) { LOGGER.info("All required plugins already installed."); } else { LOGGER.info("Installing plugins for test: " + install); - PluginSpec[] installList = install.toArray(new PluginSpec[install.size()]); + PluginSpec[] installList = install.toArray(new PluginSpec[0]); try { //noinspection deprecation pm.installPlugins(installList); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/audit_trail/AuditTrailLogger.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/audit_trail/AuditTrailLogger.java index 71991cb066..99b3a4aac6 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/audit_trail/AuditTrailLogger.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/audit_trail/AuditTrailLogger.java @@ -84,7 +84,7 @@ public boolean hasLogged(Pattern pattern) { public List getEvents() { try { List events = new ArrayList<>(); - for (String line : (List) IOUtils.readLines(url.openStream(), StandardCharsets.UTF_8)) { + for (String line : IOUtils.readLines(url.openStream(), StandardCharsets.UTF_8)) { Matcher m = LOG_PATTERN.matcher(line); m.find(); events.add(m.group(1)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/config_file_provider/ConfigFileProvider.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/config_file_provider/ConfigFileProvider.java index 8e178a719d..d5e880b52a 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/config_file_provider/ConfigFileProvider.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/config_file_provider/ConfigFileProvider.java @@ -45,7 +45,7 @@ public ConfigFileProvider(Folder f) { public T addFile(Class type) { visit(url("selectProvider")); - WebElement radio = findCaption(type, new Finder() { + WebElement radio = findCaption(type, new Finder<>() { @Override protected WebElement find(String caption) { return outer.find(by.radioButton(caption)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/credentials/AbstractCredentialsTest.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/credentials/AbstractCredentialsTest.java index a4cb8b83f4..f758cc7540 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/credentials/AbstractCredentialsTest.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/credentials/AbstractCredentialsTest.java @@ -67,7 +67,7 @@ protected CredentialsPage createCredentialsPage(Boolean userCredentials) { } protected CredentialsPage createCredentialsPage(Boolean userCredentials, String domain) { - CredentialsPage cp = null; + CredentialsPage cp; if (userCredentials) { cp = new CredentialsPage(jenkins, domain, CREATED_USER); // Make sure we are not going to have a 404, we got some issues like that diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/ColumnsArea.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/ColumnsArea.java index da15433b83..7f115ff6f7 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/ColumnsArea.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/ColumnsArea.java @@ -1,6 +1,5 @@ package org.jenkinsci.test.acceptance.plugins.dashboard_view.controls; -import java.util.Arrays; import java.util.List; import org.jenkinsci.test.acceptance.po.Control; import org.jenkinsci.test.acceptance.po.PageAreaImpl; @@ -56,7 +55,7 @@ public void removeAll() { By xpath = By.xpath("//div[@name='columns' and not(contains(.,'" + Column.LAST_STABLE.getText() + "'))]//button[@title='Delete']"); List columns = control(form).resolve().findElements(xpath); - Arrays.stream(columns.toArray(new WebElement[columns.size()])).forEach(WebElement::click); + columns.forEach(WebElement::click); } /** diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/JobFiltersArea.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/JobFiltersArea.java index 80797c37a2..210340aa5b 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/JobFiltersArea.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/controls/JobFiltersArea.java @@ -73,7 +73,7 @@ public void setIncludeRegex(String regex) { * * @author peter-mueller */ - public static enum StatusFilter { + public enum StatusFilter { /** * Only show enabled jobs. */ diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/read/BreadCrumbs.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/read/BreadCrumbs.java index 20cfa57fa3..5ffd53edfb 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/read/BreadCrumbs.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/dashboard_view/read/BreadCrumbs.java @@ -1,6 +1,5 @@ package org.jenkinsci.test.acceptance.plugins.dashboard_view.read; -import java.util.Arrays; import java.util.List; import org.jenkinsci.test.acceptance.po.PageAreaImpl; import org.jenkinsci.test.acceptance.po.PageObject; @@ -34,6 +33,6 @@ public BreadCrumbs(PageObject context, String path) { public List getBreadCrumbs() { final WebElement webElement = find(nameCrumb); final String[] crumbs = webElement.getText().split("\n"); - return Arrays.asList(crumbs); + return List.of(crumbs); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/docker_build_step/DockerCommand.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/docker_build_step/DockerCommand.java index 1639086f48..f269d879ed 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/docker_build_step/DockerCommand.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/docker_build_step/DockerCommand.java @@ -23,7 +23,6 @@ */ package org.jenkinsci.test.acceptance.plugins.docker_build_step; -import com.google.common.base.Joiner; import org.jenkinsci.test.acceptance.po.Describable; import org.jenkinsci.test.acceptance.po.PageAreaImpl; @@ -85,7 +84,7 @@ public RemoveContainers(DockerBuildStep area) { } public RemoveContainers containerIds(String... ids) { - control("containerIds").set(Joiner.on(',').join(ids)); + control("containerIds").set(String.join(",", ids)); return this; } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitRepo.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitRepo.java index 42a29514c6..2cc66ac4ff 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitRepo.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitRepo.java @@ -22,7 +22,6 @@ import java.nio.file.Paths; import java.nio.file.attribute.PosixFilePermission; import java.util.ArrayList; -import java.util.Arrays; import java.util.HashSet; import java.util.List; import java.util.Properties; @@ -109,8 +108,7 @@ private File initDir() { Charset.defaultCharset()); Files.setPosixFilePermissions( ssh.toPath(), - new HashSet<>( - Arrays.asList(PosixFilePermission.OWNER_READ, PosixFilePermission.OWNER_EXECUTE))); + new HashSet<>(List.of(PosixFilePermission.OWNER_READ, PosixFilePermission.OWNER_EXECUTE))); } return createTempDir("git"); } catch (IOException e) { @@ -149,7 +147,7 @@ public String gitDir(File dir, Object... args) { while ((line = reader.readLine()) != null) { builder.append(line); - builder.append(System.getProperty("line.separator")); + builder.append(System.lineSeparator()); } int r = p.waitFor(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitScm.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitScm.java index 7235ed672d..52575dc8fb 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitScm.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/git/GitScm.java @@ -164,8 +164,7 @@ public GitScm customNameAndMail(String name, String email) { * @return behaviour, to access .addPath() method */ public SparseCheckoutPaths sparseCheckout() { - SparseCheckoutPaths behaviour = addBehaviour(SparseCheckoutPaths.class); - return behaviour; + return addBehaviour(SparseCheckoutPaths.class); } /** @@ -208,7 +207,7 @@ public GitScm chooseBuildStrategy(String strategy, int age, String ancestor) { StrategyToChooseBuild behaviour = addBehaviour(StrategyToChooseBuild.class); new Select(behaviour.selStrategy.resolve()).selectByVisibleText(strategy); - if (strategy == "Ancestry") { + if (strategy.equals("Ancestry")) { behaviour.numMaxAge.set(age); behaviour.txtAncestorCommit.set(ancestor); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/job_config_history/JobConfigHistory.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/job_config_history/JobConfigHistory.java index acb7d6336b..ee559ac232 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/job_config_history/JobConfigHistory.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/job_config_history/JobConfigHistory.java @@ -48,7 +48,7 @@ public List getChanges() { open(); final List rows = all(by.xpath("//table//a[text()='(RAW)']/../../*[1]")); - final ArrayList changes = new ArrayList(rows.size()); + final ArrayList changes = new ArrayList<>(rows.size()); for (WebElement row : rows) { changes.add(new Change(this, row.getText())); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/job_dsl/JobDslRemovedJobAction.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/job_dsl/JobDslRemovedJobAction.java index c76b5d217a..538039d6f0 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/job_dsl/JobDslRemovedJobAction.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/job_dsl/JobDslRemovedJobAction.java @@ -8,5 +8,5 @@ public enum JobDslRemovedJobAction { IGNORE, DISABLE, - DELETE; + DELETE } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/ldap/LdapDetails.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/ldap/LdapDetails.java index 5fa3faba10..d475b86ef5 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/ldap/LdapDetails.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/ldap/LdapDetails.java @@ -281,7 +281,7 @@ public void setEnvironmentVariables(List environmentVar public void addEnvironmentVariable(LdapEnvironmentVariable environmentVariable) { if (this.environmentVariables == null) { - this.environmentVariables = new LinkedList(); + this.environmentVariables = new LinkedList<>(); } this.environmentVariables.add(environmentVariable); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/logparser/LogParserPublisher.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/logparser/LogParserPublisher.java index e6ae9bb8e1..34de7bda59 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/logparser/LogParserPublisher.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/logparser/LogParserPublisher.java @@ -24,7 +24,6 @@ public enum RuleType { RuleType(String projecttype) { this.projecttype = projecttype; } - ; public String getProjecttype() { return projecttype; diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/maven/MavenModuleSet.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/maven/MavenModuleSet.java index 906593a326..c0b00481e7 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/maven/MavenModuleSet.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/maven/MavenModuleSet.java @@ -98,7 +98,7 @@ public T addBuildSettings(final Class type, final C * @see #getPublisher(Class) */ public T addBuildSettings(Class type) { - WebElement checkbox = findCaption(type, new Finder() { + WebElement checkbox = findCaption(type, new Finder<>() { @Override protected WebElement find(String caption) { return outer.find(by.checkbox(caption)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/mock_security_realm/MockSecurityRealm.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/mock_security_realm/MockSecurityRealm.java index ade38f2ab0..e79c9efaaa 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/mock_security_realm/MockSecurityRealm.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/mock_security_realm/MockSecurityRealm.java @@ -1,6 +1,6 @@ package org.jenkinsci.test.acceptance.plugins.mock_security_realm; -import org.codehaus.plexus.util.StringUtils; +import org.apache.commons.lang3.StringUtils; import org.jenkinsci.test.acceptance.po.Control; import org.jenkinsci.test.acceptance.po.Describable; import org.jenkinsci.test.acceptance.po.GlobalSecurityConfig; diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/ssh_slaves/SshSlaveLauncher.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/ssh_slaves/SshSlaveLauncher.java index d09495f718..496f886246 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/ssh_slaves/SshSlaveLauncher.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/ssh_slaves/SshSlaveLauncher.java @@ -143,9 +143,10 @@ public void selectCredentials(final String credentialsId) { public void setSshHostKeyVerificationStrategy(Class type) { try { - SshHostKeyVerificationStrategy strategy = type.newInstance(); + SshHostKeyVerificationStrategy strategy = + type.getDeclaredConstructor().newInstance(); hostKeyVerificationStrategy.select(strategy.id()); - } catch (InstantiationException | IllegalAccessException e) { + } catch (ReflectiveOperationException e) { throw new IllegalArgumentException(type.getName() + " is missing a default constructor.", e); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/plugins/workflow_multibranch/GithubBranchSource.java b/src/main/java/org/jenkinsci/test/acceptance/plugins/workflow_multibranch/GithubBranchSource.java index d8fc2a437c..f6d1518192 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/plugins/workflow_multibranch/GithubBranchSource.java +++ b/src/main/java/org/jenkinsci/test/acceptance/plugins/workflow_multibranch/GithubBranchSource.java @@ -46,7 +46,7 @@ public GithubBranchSource credential(final String credName) { public GithubBranchSource selectRepository(final String repoName) { waitFor().withTimeout(Duration.ofSeconds(10)).until((Callable) () -> { final Select select = new Select(repository.resolve()); - return select.getOptions().size() > 0; + return !select.getOptions().isEmpty(); }); this.repository.select(repoName); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Build.java b/src/main/java/org/jenkinsci/test/acceptance/po/Build.java index 82726f039a..465e46daff 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Build.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Build.java @@ -242,7 +242,7 @@ public Build shouldBe(final Result result) { } private Matcher resultIs(final Result expected) { - return new Matcher("Build result %s", expected) { + return new Matcher<>("Build result %s", expected) { @Override public boolean matchesSafely(Build item) { return item.getResult().equals(expected.name()); @@ -333,11 +333,10 @@ public boolean equals(Object other) { return true; } - if (!(other instanceof Build)) { + if (!(other instanceof Build rhs)) { return false; } - Build rhs = (Build) other; // There is a problem comparing jobs for equality as there is no nice // way to access its full name. The default implementation assumes that // POs are equal iff they share the same URL which is not true for jobs inside view. diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/BuildHistory.java b/src/main/java/org/jenkinsci/test/acceptance/po/BuildHistory.java index ff9703ca8b..620e37b6de 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/BuildHistory.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/BuildHistory.java @@ -1,6 +1,5 @@ package org.jenkinsci.test.acceptance.po; -import java.util.Arrays; import java.util.LinkedHashSet; import java.util.List; import java.util.Set; @@ -31,7 +30,7 @@ public Set getBuilds() { WebElement progressiveRendering = findIfNotVisible(by.xpath("//*[@tooltip='Computation in progress.']")); waitFor(progressiveRendering).until(we -> !we.isDisplayed()); - LinkedHashSet builds = new LinkedHashSet(); + LinkedHashSet builds = new LinkedHashSet<>(); for (WebElement element : all(by.xpath( "//a[@href]/span[text() = 'Console output']/.. | " + "//a[@href][img/@alt = 'Console output']"))) { String href = element.getAttribute("href"); @@ -49,8 +48,8 @@ public Set getBuilds() { } public Set getBuildsOf(Job... _jobs) { - List jobs = Arrays.asList(_jobs); - LinkedHashSet builds = new LinkedHashSet(); + List jobs = List.of(_jobs); + LinkedHashSet builds = new LinkedHashSet<>(); for (Build b : getBuilds()) { if (jobs.contains(b.job)) { builds.add(b); @@ -61,7 +60,7 @@ public Set getBuildsOf(Job... _jobs) { } public static Matcher containsBuildOf(final Job job) { - return new Matcher("Build history containing a build of %s", job) { + return new Matcher<>("Build history containing a build of %s", job) { @Override public boolean matchesSafely(BuildHistory item) { return !item.getBuildsOf(job).isEmpty(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/CapybaraPortingLayerImpl.java b/src/main/java/org/jenkinsci/test/acceptance/po/CapybaraPortingLayerImpl.java index dde844c753..44f5802a55 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/CapybaraPortingLayerImpl.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/CapybaraPortingLayerImpl.java @@ -1,13 +1,11 @@ package org.jenkinsci.test.acceptance.po; -import com.google.common.base.Joiner; import com.google.inject.Injector; import edu.umd.cs.findbugs.annotations.CheckForNull; import jakarta.inject.Inject; import java.lang.reflect.Constructor; import java.net.URL; import java.time.Duration; -import java.util.Arrays; import java.util.List; import java.util.concurrent.Callable; import java.util.function.Consumer; @@ -181,7 +179,7 @@ public void waitFor( @Override public WebElement find(final By selector) { try { - return waitFor().withTimeout(Duration.ofMillis(time.seconds(1))).until(new Callable() { + return waitFor().withTimeout(Duration.ofMillis(time.seconds(1))).until(new Callable<>() { @Override public WebElement call() { for (WebElement element : driver.findElements(selector)) { @@ -501,14 +499,14 @@ protected T newInstance(Class type, Object... args) { return type.cast(c.newInstance(args)); } - throw new AssertionError("No matching constructor found in " + type + ": " + Arrays.asList(args)); + throw new AssertionError("No matching constructor found in " + type + ": " + List.of(args)); } catch (ReflectiveOperationException e) { throw new AssertionError("Failed to invoke a constructor of " + type, e); } } protected T findCaption(Class type, Function finder) { - return findCaption(type, new Finder() { + return findCaption(type, new Finder<>() { @Override protected T find(String caption) { return finder.apply(caption); @@ -519,8 +517,8 @@ protected T find(String caption) { protected T findCaption(Class type, Finder call) { String[] captions = type.getAnnotation(Describable.class).value(); - RuntimeException cause = new NoSuchElementException( - "None of the captions exists: " + Joiner.on(", ").join(captions)); + RuntimeException cause = + new NoSuchElementException("None of the captions exists: " + String.join(", ", captions)); for (String caption : captions) { try { T out = call.find(caption); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/ContainerPageObject.java b/src/main/java/org/jenkinsci/test/acceptance/po/ContainerPageObject.java index 28c1369375..336dbda501 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/ContainerPageObject.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/ContainerPageObject.java @@ -128,11 +128,10 @@ public boolean equals(Object other) { return true; } - if (!(other instanceof ContainerPageObject)) { + if (!(other instanceof ContainerPageObject rhs)) { return false; } - ContainerPageObject rhs = (ContainerPageObject) other; return this.url.toExternalForm().equals(rhs.url.toExternalForm()); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Control.java b/src/main/java/org/jenkinsci/test/acceptance/po/Control.java index 66047e667e..a85c22f547 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Control.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Control.java @@ -211,7 +211,7 @@ public void selectDropdownMenu(String displayName) { * Given a menu button that shows a list of build steps, select the right item from the menu * to insert the said build step. */ - private final Finder findDropDownMenuItem = new Finder() { + private final Finder findDropDownMenuItem = new Finder<>() { @Override protected WebElement find(String caption) { WebElement menuButton = resolve(); @@ -222,7 +222,7 @@ protected WebElement find(String caption) { // With enough implementations registered the one we are looking for might // require scrolling in menu to become visible. This dirty hack stretch // yui menu so that all the items are visible. - executeScript("" + "YAHOO.util.Dom.batch(" + executeScript("YAHOO.util.Dom.batch(" + " document.querySelector('.yui-menu-body-scrolled')," + " function (el) {" + " el.style.height = 'auto';" @@ -245,7 +245,7 @@ public void selectDropdownMenuAlt(Class type) { elasticSleep(1000); } - private final Finder findDropDownMenuItemBySelector = new Finder() { + private final Finder findDropDownMenuItemBySelector = new Finder<>() { @Override protected WebElement find(String caption) { WebElement menuButton = resolve(); @@ -253,7 +253,7 @@ protected WebElement find(String caption) { // With enough implementations registered the one we are looking for might // require scrolling in menu to become visible. This dirty hack stretch // yui menu so that all the items are visible. - executeScript("" + "YAHOO.util.Dom.batch(" + executeScript("YAHOO.util.Dom.batch(" + " document.querySelector('.yui-menu-body-scrolled')," + " function (el) {" + " el.style.height = 'auto';" @@ -289,7 +289,7 @@ private WebElement findElement(WebElement context, By selector) { } public void select(Class describable) { - String element = findCaption(describable, new Finder() { + String element = findCaption(describable, new Finder<>() { @Override protected String find(String caption) { return Control.this.getElement(by.option(caption)) != null ? caption : null; @@ -300,7 +300,7 @@ protected String find(String caption) { } public void choose(Class describable) { - String element = findCaption(describable, new Finder() { + String element = findCaption(describable, new Finder<>() { @Override protected String find(String caption) { final By xpath = by.xpath("//input[@type = 'radio' and @value = '%s']", caption); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/FormValidation.java b/src/main/java/org/jenkinsci/test/acceptance/po/FormValidation.java index 68198be889..4f10dda5b1 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/FormValidation.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/FormValidation.java @@ -135,7 +135,7 @@ public String toString() { * When either there is no validation or empty OK was returned (there is no way to tell that apart). */ public static Matcher silent() { - return new Matcher("No form validation result should be presented") { + return new Matcher<>("No form validation result should be presented") { @Override public boolean matchesSafely(FormValidation item) { return item.getKind() == Kind.OK && item.getMessage().isEmpty(); @@ -155,7 +155,7 @@ public static Matcher reports(final Kind kind, final String mess public static Matcher reports(final Kind kind, final org.hamcrest.Matcher message) { StringDescription sd = new StringDescription(); message.describeTo(sd); - return new Matcher("Validation reporting " + kind + " with message: " + sd) { + return new Matcher<>("Validation reporting " + kind + " with message: " + sd) { @Override public boolean matchesSafely(FormValidation item) { return item.getKind() == kind && message.matches(item.getMessage()); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Jenkins.java b/src/main/java/org/jenkinsci/test/acceptance/po/Jenkins.java index f5814b9bdf..6ff40865cc 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Jenkins.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Jenkins.java @@ -2,7 +2,6 @@ import com.fasterxml.jackson.annotation.JsonIgnoreProperties; import com.fasterxml.jackson.databind.ObjectMapper; -import com.google.common.base.Function; import com.google.inject.Injector; import hudson.util.VersionNumber; import java.io.FileOutputStream; @@ -15,6 +14,7 @@ import java.util.ArrayList; import java.util.List; import java.util.Map; +import java.util.function.Function; import java.util.logging.Level; import org.apache.commons.io.IOUtils; import org.apache.commons.lang3.ObjectUtils; @@ -179,7 +179,7 @@ public void restart() { } public void waitForLoad(int seconds) { - List> ignoring = new ArrayList>(); + List> ignoring = new ArrayList<>(); ignoring.add(AssertionError.class); ignoring.add(NoSuchElementException.class); ignoring.add(WebDriverException.class); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Job.java b/src/main/java/org/jenkinsci/test/acceptance/po/Job.java index 2420b3bb25..b1c2fb28d5 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Job.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Job.java @@ -75,7 +75,7 @@ public Job(PageObject context, URL url, String name) { public T useScm(Class type) { ensureConfigPage(); - WebElement radio = findCaption(type, new Finder() { + WebElement radio = findCaption(type, new Finder<>() { @Override protected WebElement find(String caption) { return outer.find(by.radioButton(caption)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/LdapSecurityRealm.java b/src/main/java/org/jenkinsci/test/acceptance/po/LdapSecurityRealm.java index dd7be4ac8e..dfc11db415 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/LdapSecurityRealm.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/LdapSecurityRealm.java @@ -58,7 +58,7 @@ public LdapSecurityRealm(GlobalSecurityConfig context, String path) { } private T useGroupMembershipStrategy(Class type) { - WebElement radio = findCaption(type, new Finder() { + WebElement radio = findCaption(type, new Finder<>() { @Override protected WebElement find(String caption) { return getElement(by.radioButton(caption)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/PageAreaImpl.java b/src/main/java/org/jenkinsci/test/acceptance/po/PageAreaImpl.java index 839e089d70..ca3f301ad5 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/PageAreaImpl.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/PageAreaImpl.java @@ -57,7 +57,7 @@ public String getPath() { @Override public String getPath(String rel) { - if (rel.length() == 0) { + if (rel.isEmpty()) { return path; } diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/PageObject.java b/src/main/java/org/jenkinsci/test/acceptance/po/PageObject.java index 36ab3c5943..7807da0dc2 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/PageObject.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/PageObject.java @@ -1,7 +1,6 @@ package org.jenkinsci.test.acceptance.po; import com.fasterxml.jackson.databind.ObjectMapper; -import com.google.common.base.Function; import com.google.inject.Injector; import edu.umd.cs.findbugs.annotations.NonNull; import edu.umd.cs.findbugs.annotations.Nullable; @@ -12,6 +11,7 @@ import java.util.ArrayList; import java.util.Collection; import java.util.List; +import java.util.function.Function; import org.kohsuke.randname.RandomNameGenerator; import org.openqa.selenium.By; import org.openqa.selenium.TimeoutException; @@ -146,7 +146,7 @@ public Control control(By selector) { final int existingSize = existing.size(); action.run(); - return waitFor().withTimeout(Duration.ofSeconds(10)).until(new Function() { + return waitFor().withTimeout(Duration.ofSeconds(10)).until(new Function<>() { @Nullable @Override public String apply(@Nullable CapybaraPortingLayer input) { diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/PluginManager.java b/src/main/java/org/jenkinsci/test/acceptance/po/PluginManager.java index 7e95b69285..3a3eb57c1c 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/PluginManager.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/PluginManager.java @@ -8,7 +8,6 @@ import java.time.Duration; import java.time.temporal.ChronoUnit; import java.util.ArrayList; -import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -190,7 +189,7 @@ public boolean installPlugins(final PluginSpec... specs) throws UnableToResolveD return false; } List pluginToBeInstalled = - ucmd.get(jenkins).transitiveDependenciesOf(jenkins, Arrays.asList(specs)); + ucmd.get(jenkins).transitiveDependenciesOf(jenkins, List.of(specs)); for (PluginMetadata newPlugin : pluginToBeInstalled) { final String name = newPlugin.getName(); String requiredVersion = candidates.get(name); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Slave.java b/src/main/java/org/jenkinsci/test/acceptance/po/Slave.java index 23299587d0..0942b578cc 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Slave.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Slave.java @@ -64,7 +64,7 @@ public int getExecutorCount() { } public static Matcher runBuildsInOrder(final Job... jobs) { - return new Matcher("agent run build in order: %s", Joiner.on(' ').join(jobs)) { + return new Matcher<>("agent run build in order: %s", Joiner.on(' ').join(jobs)) { @Override public boolean matchesSafely(Slave slave) { slave.visit("builds"); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/ToolInstallation.java b/src/main/java/org/jenkinsci/test/acceptance/po/ToolInstallation.java index 8540d199d2..55a99d7845 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/ToolInstallation.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/ToolInstallation.java @@ -26,9 +26,9 @@ import java.io.File; import java.io.IOException; import java.nio.charset.StandardCharsets; +import java.nio.file.Files; import java.time.Duration; import java.util.concurrent.Callable; -import org.apache.commons.io.FileUtils; import org.apache.commons.lang3.SystemUtils; import org.jenkinsci.utils.process.CommandBuilder; import org.openqa.selenium.NoSuchElementException; @@ -166,7 +166,7 @@ protected String fakeHome(String binary, String homeEnvName) { final String code = String.format("#!/bin/sh\nexport %s=\nexec %s \"$@\"\n", homeEnvName, path); final File command = new File(home, "bin/" + binary); - FileUtils.writeStringToFile(command, code, StandardCharsets.UTF_8); + Files.writeString(command.toPath(), code, StandardCharsets.UTF_8); command.setExecutable(true); } else { String path = @@ -175,7 +175,7 @@ protected String fakeHome(String binary, String homeEnvName) { path = path.replaceAll("\r\n.*", ""); final String code = String.format("set %s=\r\ncall %s %%*\r\n", homeEnvName, path); final File command = new File(home, "bin/" + binary + ".cmd"); - FileUtils.writeStringToFile(command, code, StandardCharsets.UTF_8); + Files.writeString(command.toPath(), code, StandardCharsets.UTF_8); command.setExecutable(true); } return home.getAbsolutePath(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/TopLevelItem.java b/src/main/java/org/jenkinsci/test/acceptance/po/TopLevelItem.java index a10f75cca5..91b208d19d 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/TopLevelItem.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/TopLevelItem.java @@ -117,7 +117,7 @@ public boolean equals(Object other) { return true; } - if (!(other instanceof TopLevelItem)) { + if (!(other instanceof TopLevelItem rhs)) { return false; } @@ -125,7 +125,6 @@ public boolean equals(Object other) { // We use URL only as the concrete class may not be detected, e.g. when obtaining a job // from a BuildHistory // TODO: equality checking in the presence of views. - TopLevelItem rhs = (TopLevelItem) other; return url.toExternalForm().equals(rhs.url.toExternalForm()); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/UpdateCenter.java b/src/main/java/org/jenkinsci/test/acceptance/po/UpdateCenter.java index 8029b39675..85b0099226 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/UpdateCenter.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/UpdateCenter.java @@ -5,7 +5,7 @@ import com.fasterxml.jackson.databind.JsonNode; import com.google.common.collect.Iterables; import java.time.Duration; -import java.util.Arrays; +import java.util.List; import java.util.concurrent.atomic.AtomicInteger; import org.apache.commons.lang3.ArrayUtils; import org.jenkinsci.test.acceptance.Matchers; @@ -58,7 +58,7 @@ public boolean isInstalled(String pluginShortName) throws InstallationFailedExce } throw new AssertionError( - "No record of installation being attempted for " + pluginShortName + "\n" + Arrays.asList(jobs)); + "No record of installation being attempted for " + pluginShortName + "\n" + List.of(jobs)); } /** diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/User.java b/src/main/java/org/jenkinsci/test/acceptance/po/User.java index 4aed915b36..72705fda8b 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/User.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/User.java @@ -64,7 +64,7 @@ private void load() { if (property.isArray()) { for (JsonNode propertyNodes : property) { if (propertyNodes.get("address") != null - && propertyNodes.get("address").asText() != "null") { + && !propertyNodes.get("address").asText().equals("null")) { mail = propertyNodes.get("address").asText(); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/View.java b/src/main/java/org/jenkinsci/test/acceptance/po/View.java index a4073cf657..15d08a5523 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/View.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/View.java @@ -71,7 +71,7 @@ public BuildHistory getBuildHistory() { } public static Matcher containsJob(final Job needle) { - return new Matcher("Contains job " + needle.name) { + return new Matcher<>("Contains job " + needle.name) { @Override public boolean matchesSafely(View view) { for (JsonNode job : view.getJson().get("jobs")) { @@ -131,7 +131,7 @@ public boolean matchesSafely(View item) { } public static Matcher containsColumnHeaderTooltip(String tooltip) { - return new Matcher("Contains ToolTip " + tooltip) { + return new Matcher<>("Contains ToolTip " + tooltip) { @Override public boolean matchesSafely(View item) { WebElement webElement = item.getElement(By.xpath("//th[contains(@tooltip, '" + tooltip + "')]")); @@ -141,7 +141,7 @@ public boolean matchesSafely(View item) { } public static Matcher containsColumnHeader(String headerName) { - return new Matcher("Contains ToolTip " + headerName) { + return new Matcher<>("Contains ToolTip " + headerName) { @Override public boolean matchesSafely(View item) { WebElement webElement = item.getElement(By.xpath("//th/a[text() = '" + headerName + "']")); @@ -151,7 +151,7 @@ public boolean matchesSafely(View item) { } public static Matcher containsImage(String imageName) { - return new Matcher("Contains image " + imageName) { + return new Matcher<>("Contains image " + imageName) { @Override public boolean matchesSafely(View item) { WebElement webElement = item.getElement(By.xpath("//img[contains(@src, '" + imageName + "')]")); @@ -161,7 +161,7 @@ public boolean matchesSafely(View item) { } public static Matcher containsSvgWithText(String text) { - return new Matcher("Contains svg with text " + text) { + return new Matcher<>("Contains svg with text " + text) { @Override public boolean matchesSafely(View item) { WebElement webElement = item.getElement( @@ -172,7 +172,7 @@ public boolean matchesSafely(View item) { } public static Matcher containsLinkWithTooltip(String text) { - return new Matcher("Contains link with tooltip " + text) { + return new Matcher<>("Contains link with tooltip " + text) { @Override public boolean matchesSafely(View item) { WebElement webElement = item.getElement(By.cssSelector(String.format("a[tooltip='%s']", text))); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/ViewsMixIn.java b/src/main/java/org/jenkinsci/test/acceptance/po/ViewsMixIn.java index baa2f28723..8dc821faff 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/ViewsMixIn.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/ViewsMixIn.java @@ -20,7 +20,7 @@ public T create(final Class type) { public T create(final Class type, String name) { - final Finder finder = new Finder() { + final Finder finder = new Finder<>() { @Override protected WebElement find(String caption) { return outer.find(by.radioButton(caption)); diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/WizardLogin.java b/src/main/java/org/jenkinsci/test/acceptance/po/WizardLogin.java index abe786b033..b31a114a0a 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/WizardLogin.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/WizardLogin.java @@ -32,7 +32,7 @@ import java.io.File; import java.io.IOException; import java.nio.charset.StandardCharsets; -import org.apache.commons.io.FileUtils; +import java.nio.file.Files; import org.jenkinsci.test.acceptance.controller.JenkinsController; import org.jenkinsci.test.acceptance.controller.LocalController; import org.junit.Assume; @@ -90,6 +90,6 @@ public String getPassword(JenkinsController controller) throws IOException { controller, instanceOf(LocalController.class)); File passwordFile = new File(((LocalController) controller).getJenkinsHome(), "secrets/initialAdminPassword"); - return FileUtils.readFileToString(passwordFile, StandardCharsets.UTF_8).trim(); + return Files.readString(passwordFile.toPath(), StandardCharsets.UTF_8).trim(); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/WorkflowMultiBranchJob.java b/src/main/java/org/jenkinsci/test/acceptance/po/WorkflowMultiBranchJob.java index 5ae44ad8b0..4f43a5053f 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/WorkflowMultiBranchJob.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/WorkflowMultiBranchJob.java @@ -54,7 +54,7 @@ public void reIndex() { final List scanRepoNow = driver.findElements(by.xpath("//div[@class=\"task\"]//*[text()=\"Scan Repository Now\"]")); - if (scanRepoNow.size() > 0) { + if (!scanRepoNow.isEmpty()) { // JENKINS-41416 scanRepoNow.get(0).click(); } else { diff --git a/src/main/java/org/jenkinsci/test/acceptance/po/Workspace.java b/src/main/java/org/jenkinsci/test/acceptance/po/Workspace.java index 261cb78096..1994ac7f28 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/po/Workspace.java +++ b/src/main/java/org/jenkinsci/test/acceptance/po/Workspace.java @@ -37,7 +37,7 @@ public void wipeOut() { } public static Matcher workspaceContains(final String file) { - return new Matcher("%s in job workspace", file) { + return new Matcher<>("%s in job workspace", file) { @Override public boolean matchesSafely(Job job) { job.getWorkspace().open(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/recorder/TestRecorderRule.java b/src/main/java/org/jenkinsci/test/acceptance/recorder/TestRecorderRule.java index b684f58506..76e6894b10 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/recorder/TestRecorderRule.java +++ b/src/main/java/org/jenkinsci/test/acceptance/recorder/TestRecorderRule.java @@ -71,12 +71,9 @@ private void startRecording(Description des) { String videoFormatName = VideoFormatKeys.ENCODING_QUICKTIME_ANIMATION; String compressorName = VideoFormatKeys.COMPRESSOR_NAME_QUICKTIME_ANIMATION; Dimension outputDimension = gc.getBounds().getSize(); - int bitDepth = BIT_DEPTH; - float quality = QUALITY_RATIO; - int screenRate = FRAME_RATE_PER_SEC; Format outputFormatForScreenCapture = getOutputFormatForScreenCapture( - videoFormatName, compressorName, outputDimension, bitDepth, quality, screenRate); + videoFormatName, compressorName, outputDimension, BIT_DEPTH, QUALITY_RATIO, FRAME_RATE_PER_SEC); this.screenRecorder = new JUnitScreenRecorder( gc, gc.getBounds(), getFileFormat(mimeType), outputFormatForScreenCapture, null, null, diagnostics); diff --git a/src/main/java/org/jenkinsci/test/acceptance/server/JenkinsControllerPoolProcess.java b/src/main/java/org/jenkinsci/test/acceptance/server/JenkinsControllerPoolProcess.java index 7180e7a5d4..1d73c38d2f 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/server/JenkinsControllerPoolProcess.java +++ b/src/main/java/org/jenkinsci/test/acceptance/server/JenkinsControllerPoolProcess.java @@ -160,7 +160,7 @@ public void run() { */ private void processConnection(UnixSocketChannel c, JenkinsController j) { try { - try { + try (c) { try (InputStream in = ChannelStream.in(c); OutputStream out = ChannelStream.out(c)) { @@ -176,7 +176,6 @@ private void processConnection(UnixSocketChannel c, JenkinsController j) { System.out.println("done"); j.stop(); j.tearDown(); - c.close(); } } catch (IOException | InterruptedException e) { e.printStackTrace(); diff --git a/src/main/java/org/jenkinsci/test/acceptance/server/PooledJenkinsController.java b/src/main/java/org/jenkinsci/test/acceptance/server/PooledJenkinsController.java index 649849b658..f2bf61d484 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/server/PooledJenkinsController.java +++ b/src/main/java/org/jenkinsci/test/acceptance/server/PooledJenkinsController.java @@ -178,8 +178,7 @@ private InstallLogger(IJenkinsController controller, LogListener l) { @Override public Void call() throws IOException { - if (controller instanceof LogListenable) { - LogListenable ll = (LogListenable) controller; + if (controller instanceof LogListenable ll) { ll.addLogListener(l); } return null; diff --git a/src/main/java/org/jenkinsci/test/acceptance/update_center/LocalOverrideUpdateCenterMetadataDecoratorImpl.java b/src/main/java/org/jenkinsci/test/acceptance/update_center/LocalOverrideUpdateCenterMetadataDecoratorImpl.java index 88400175d2..788aa66ef6 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/update_center/LocalOverrideUpdateCenterMetadataDecoratorImpl.java +++ b/src/main/java/org/jenkinsci/test/acceptance/update_center/LocalOverrideUpdateCenterMetadataDecoratorImpl.java @@ -118,9 +118,7 @@ private boolean isPluginEnvironmentVariable(String name) { if (name.endsWith(".jpi")) { return true; } - if (name.endsWith("_JPI")) { // http://stackoverflow.com/a/36992531/12916 - return true; - } - return false; + // http://stackoverflow.com/a/36992531/12916 + return name.endsWith("_JPI"); } } diff --git a/src/main/java/org/jenkinsci/test/acceptance/update_center/MockUpdateCenter.java b/src/main/java/org/jenkinsci/test/acceptance/update_center/MockUpdateCenter.java index bb1fa8c17f..341890ad0a 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/update_center/MockUpdateCenter.java +++ b/src/main/java/org/jenkinsci/test/acceptance/update_center/MockUpdateCenter.java @@ -249,7 +249,7 @@ private void updating(JSONObject plugin, String key, Object val) throws JSONExce if (!String.valueOf(val).equals(String.valueOf(old))) { // "-1" and "size" are both string literals in the caller, // so only check their identity to prevent a fallback to checking characters which is unneeded. - if (MINUS_ONE_STRING == val && "size" == key) { + if (MINUS_ONE_STRING == val && "size".equals(key)) { LOGGER.log(Level.FINE, "for {0} updating {1} from {2} to {3}", new Object[] { plugin.getString("name"), key, old, val }); diff --git a/src/main/java/org/jenkinsci/test/acceptance/utils/IOUtil.java b/src/main/java/org/jenkinsci/test/acceptance/utils/IOUtil.java index ffac68c78b..4e114deaf3 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/utils/IOUtil.java +++ b/src/main/java/org/jenkinsci/test/acceptance/utils/IOUtil.java @@ -29,7 +29,7 @@ import java.net.HttpURLConnection; import java.net.ServerSocket; import java.net.URL; -import java.util.Arrays; +import java.util.List; import java.util.logging.Logger; public class IOUtil { @@ -54,7 +54,7 @@ public class IOUtil { } } - throw new IOException("None of the paths exist: " + Arrays.asList(candidatePaths)); + throw new IOException("None of the paths exist: " + List.of(candidatePaths)); } /** diff --git a/src/main/java/org/jenkinsci/test/acceptance/utils/SHA1Sum.java b/src/main/java/org/jenkinsci/test/acceptance/utils/SHA1Sum.java index e8f8771e35..ead6aeb8dc 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/utils/SHA1Sum.java +++ b/src/main/java/org/jenkinsci/test/acceptance/utils/SHA1Sum.java @@ -12,9 +12,9 @@ * Creates SHA1 sums of a file */ public class SHA1Sum { - private byte[] sha1 = null; - private String sha1String = null; - private File inFile = null; + private byte[] sha1; + private String sha1String; + private File inFile; public SHA1Sum(File inFile) { if (inFile.isFile()) { diff --git a/src/main/java/org/jenkinsci/test/acceptance/utils/SystemEnvironmentVariables.java b/src/main/java/org/jenkinsci/test/acceptance/utils/SystemEnvironmentVariables.java index b596c71eab..4f70643f92 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/utils/SystemEnvironmentVariables.java +++ b/src/main/java/org/jenkinsci/test/acceptance/utils/SystemEnvironmentVariables.java @@ -7,7 +7,7 @@ */ public class SystemEnvironmentVariables { - public static final String getPropertyVariableOrEnvironment(String property, String def) { + public static String getPropertyVariableOrEnvironment(String property, String def) { String propertyValue = System.getProperty(property); diff --git a/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ArtifactResolverUtil.java b/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ArtifactResolverUtil.java index b26a19fc5e..63b607a7eb 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ArtifactResolverUtil.java +++ b/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ArtifactResolverUtil.java @@ -26,7 +26,7 @@ import jakarta.inject.Inject; import java.io.File; -import java.util.Arrays; +import java.util.List; import java.util.logging.Level; import java.util.logging.Logger; import org.apache.maven.settings.Settings; @@ -100,7 +100,7 @@ public ArtifactResult resolve(DefaultArtifact artifact) { RemoteRepository repo = repoBuilder.build(); ArtifactResult r; try { - r = repoSystem.resolveArtifact(repoSystemSession, new ArtifactRequest(artifact, Arrays.asList(repo), null)); + r = repoSystem.resolveArtifact(repoSystemSession, new ArtifactRequest(artifact, List.of(repo), null)); } catch (ArtifactResolutionException e) { throw new RuntimeException("Could not resolve " + artifact + " from Maven repository", e); } diff --git a/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ConsoleTransferListener.java b/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ConsoleTransferListener.java index 96202b3940..97eaa64b4a 100644 --- a/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ConsoleTransferListener.java +++ b/src/main/java/org/jenkinsci/test/acceptance/utils/aether/ConsoleTransferListener.java @@ -28,7 +28,7 @@ public class ConsoleTransferListener extends AbstractTransferListener { private PrintStream out; - private Map downloads = new ConcurrentHashMap(); + private Map downloads = new ConcurrentHashMap<>(); private int lastLength; diff --git a/src/test/java/core/FreestyleJobTest.java b/src/test/java/core/FreestyleJobTest.java index 770504e981..b2bb1fc2e5 100644 --- a/src/test/java/core/FreestyleJobTest.java +++ b/src/test/java/core/FreestyleJobTest.java @@ -17,7 +17,8 @@ import java.net.URL; import java.nio.charset.StandardCharsets; import java.time.Duration; -import java.util.Collections; +import java.util.List; +import java.util.Map; import java.util.regex.Pattern; import org.apache.commons.io.IOUtils; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; @@ -163,7 +164,7 @@ public void buildParametrized() { j.addShellStep("echo \">$text<\""); j.save(); - Build build = j.scheduleBuild(Collections.singletonMap("text", "asdf")).waitUntilFinished(); + Build build = j.scheduleBuild(Map.of("text", "asdf")).waitUntilFinished(); assertThat(build.getConsole(), containsString(">asdf<")); } @@ -284,7 +285,7 @@ public void scheduleFromView() throws Exception { view.scheduleJob(j.name); BuildWithParameters paramPage = new BuildWithParameters(j, new URL(driver.getCurrentUrl())); - paramPage.enter(Collections.singletonList(p), Collections.singletonMap("foo", "bar")); + paramPage.enter(List.of(p), Map.of("foo", "bar")); paramPage.start(); j.build(2).waitUntilStarted().shouldSucceed(); diff --git a/src/test/java/org/jenkinsci/test/acceptance/junit/WithPluginsTest.java b/src/test/java/org/jenkinsci/test/acceptance/junit/WithPluginsTest.java index 8744340950..c504cac6c7 100644 --- a/src/test/java/org/jenkinsci/test/acceptance/junit/WithPluginsTest.java +++ b/src/test/java/org/jenkinsci/test/acceptance/junit/WithPluginsTest.java @@ -26,7 +26,6 @@ import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.equalTo; -import java.util.Arrays; import java.util.List; import org.jenkinsci.test.acceptance.update_center.PluginSpec; import org.junit.Test; @@ -38,12 +37,12 @@ public class WithPluginsTest { @Test public void combine_WithPlugins_annotations() throws Exception { // TODO test annotation harvesting and test class inheritance - List annotations = Arrays.asList( + List annotations = List.of( FakeTestClass.class.getAnnotation(WithPlugins.class), FakeTestClass.class.getMethod("test").getAnnotation(WithPlugins.class)); List actual = WithPlugins.RuleImpl.combinePlugins(annotations); - List expected = Arrays.asList( + List expected = List.of( new PluginSpec("keep"), new PluginSpec("keepv@1"), new PluginSpec( diff --git a/src/test/java/org/jenkinsci/test/acceptance/update_center/UpdateCenterMetadataTest.java b/src/test/java/org/jenkinsci/test/acceptance/update_center/UpdateCenterMetadataTest.java index 9e904d9672..331950cdad 100644 --- a/src/test/java/org/jenkinsci/test/acceptance/update_center/UpdateCenterMetadataTest.java +++ b/src/test/java/org/jenkinsci/test/acceptance/update_center/UpdateCenterMetadataTest.java @@ -7,8 +7,6 @@ import hudson.util.VersionNumber; import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; import java.util.HashMap; import java.util.List; import org.hamcrest.Matchers; @@ -20,7 +18,7 @@ */ public class UpdateCenterMetadataTest { - public static final List NO_DEPS = Collections.emptyList(); + public static final List NO_DEPS = List.of(); private Jenkins jenkins = mock(Jenkins.class); @@ -37,12 +35,7 @@ public class UpdateCenterMetadataTest { plugins.put("provider", new PluginMetadata("provider", "jenkins:provider:1", "1", "1", NO_DEPS)); plugins.put( "consumer", - new PluginMetadata( - "consumer", - "jenkins:consumer:1", - "1", - "1", - Collections.singletonList(new Dependency("provider:1")))); + new PluginMetadata("consumer", "jenkins:consumer:1", "1", "1", List.of(new Dependency("provider:1")))); plugins.put( "complex", @@ -51,10 +44,10 @@ public class UpdateCenterMetadataTest { "jenkins:complex:1", "1", "1", - Arrays.asList(new Dependency("branchb:1"), new Dependency("brancha:1")))); + List.of(new Dependency("branchb:1"), new Dependency("brancha:1")))); plugins.put( "brancha", - new PluginMetadata("brancha", "jenkins:brancha:1", "1", "1", Arrays.asList(new Dependency("depa:1")))); + new PluginMetadata("brancha", "jenkins:brancha:1", "1", "1", List.of(new Dependency("depa:1")))); plugins.put("depa", new PluginMetadata("depa", "jenkins:depa:1", "1", "1", NO_DEPS)); plugins.put( "branchb", @@ -63,7 +56,7 @@ public class UpdateCenterMetadataTest { "jenkins:branchb:1", "1", "1", - Arrays.asList(new Dependency("depb0:1"), new Dependency("depb1:1")))); + List.of(new Dependency("depb0:1"), new Dependency("depb1:1")))); plugins.put("depb0", new PluginMetadata("depb0", "jenkins:depb0:1", "1", "1", NO_DEPS)); plugins.put("depb1", new PluginMetadata("depb1", "jenkins:depb1:1", "1", "1", NO_DEPS)); } @@ -73,7 +66,7 @@ public class UpdateCenterMetadataTest { @Test public void transitiveDependenciesOfSimple() throws Exception { - assertThat(ucm.transitiveDependenciesOf(jenkins, specs()), Matchers.emptyIterable()); + assertThat(ucm.transitiveDependenciesOf(jenkins, specs()), Matchers.emptyIterable()); assertThat( ucm.transitiveDependenciesOf(jenkins, specs("standalone")), Matchers.contains(plugins.get("standalone"))); diff --git a/src/test/java/plugins/AuthorizeProjectTest.java b/src/test/java/plugins/AuthorizeProjectTest.java index 4926006490..140512788b 100644 --- a/src/test/java/plugins/AuthorizeProjectTest.java +++ b/src/test/java/plugins/AuthorizeProjectTest.java @@ -4,7 +4,6 @@ import static org.hamcrest.Matchers.containsString; import static org.hamcrest.Matchers.not; -import com.google.common.base.Joiner; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; import org.jenkinsci.test.acceptance.junit.WithPlugins; import org.jenkinsci.test.acceptance.plugins.authorize_project.ProjectDefaultBuildAccessControl; @@ -61,7 +60,7 @@ public void testProjectRunByUser() { private void setupUsers(final GlobalSecurityConfig security, final String... users) { final MockSecurityRealm realm = security.useRealm(MockSecurityRealm.class); - realm.configure(Joiner.on("\n").join(users)); + realm.configure(String.join("\n", users)); } private void authorizeUserToLaunchProject(final String user) { diff --git a/src/test/java/plugins/CompressArtifactsPluginTest.java b/src/test/java/plugins/CompressArtifactsPluginTest.java index 557f07d41d..030e02f225 100644 --- a/src/test/java/plugins/CompressArtifactsPluginTest.java +++ b/src/test/java/plugins/CompressArtifactsPluginTest.java @@ -130,7 +130,7 @@ private Build generateArtifact() { } private Matcher hasCompressedArtifacts() { - return new Matcher("Build has compressed artifacts") { + return new Matcher<>("Build has compressed artifacts") { @Override public boolean matchesSafely(Build build) { final String script = "!Jenkins.instance.rootPath.child('jobs/%s/builds/%s/archive/').exists()"; diff --git a/src/test/java/plugins/ConfigFileProviderTest.java b/src/test/java/plugins/ConfigFileProviderTest.java index aec62ee495..8778667f7a 100644 --- a/src/test/java/plugins/ConfigFileProviderTest.java +++ b/src/test/java/plugins/ConfigFileProviderTest.java @@ -174,12 +174,9 @@ public void testConfigFileProviderWithFolders() { // We want to delete the config file and re-run the job to see it fail jenkins.visit("configfiles"); - runThenHandleDialog(() -> { - driver.findElement( - by.xpath("//td[.='%s']/parent::tr/td[2]/a[1]", mvnConfig.id()) // this won't age well - ) - .click(); - }); + // this won't age well + runThenHandleDialog(() -> driver.findElement(by.xpath("//td[.='%s']/parent::tr/td[2]/a[1]", mvnConfig.id())) + .click()); jobLog = this.buildJobAndGetConsole(job, false); diff --git a/src/test/java/plugins/CredentialsBindingTest.java b/src/test/java/plugins/CredentialsBindingTest.java index a744c472d4..1a9caf6062 100644 --- a/src/test/java/plugins/CredentialsBindingTest.java +++ b/src/test/java/plugins/CredentialsBindingTest.java @@ -234,7 +234,7 @@ private void testPersonalCredentials( final WorkflowJob job = PipelineTestUtils.createPipelineJobWithScript(jenkins.jobs, jobScript); Build b = job.startBuild(); - assertBuild(b, false, String.format("Could not find credentials entry with ID \'%s\'", CRED_ID)); + assertBuild(b, false, String.format("Could not find credentials entry with ID '%s'", CRED_ID)); this.authorizeUserToLaunchProject(); @@ -245,7 +245,7 @@ private void testPersonalCredentials( private void waitForLogToBeFullyLoaded(final Build b, String text) { waitFor( driver, - new Matcher("Console log is not fully loaded") { + new Matcher<>("Console log is not fully loaded") { @Override public boolean matchesSafely(WebDriver item) { String pageText = CapybaraPortingLayerImpl.getPageContent(visit(b.getConsoleUrl())); diff --git a/src/test/java/plugins/DashboardViewPluginTest.java b/src/test/java/plugins/DashboardViewPluginTest.java index 75d98e8c0a..48a5f75694 100644 --- a/src/test/java/plugins/DashboardViewPluginTest.java +++ b/src/test/java/plugins/DashboardViewPluginTest.java @@ -9,7 +9,6 @@ import static org.junit.Assert.assertEquals; import jakarta.inject.Inject; -import java.util.Arrays; import java.util.List; import org.jenkinsci.test.acceptance.junit.WithPlugins; import org.jenkinsci.test.acceptance.plugins.dashboard_view.BuildStatisticsPortlet; @@ -231,13 +230,13 @@ public void filterByRegex() { view.open(); final List jobIDs = view.projectStatus.getJobIDs(); - assertEquals(Arrays.asList("a", "aa", "b"), jobIDs); + assertEquals(List.of("a", "aa", "b"), jobIDs); view.configure(() -> view.jobFilters.setIncludeRegex("a*")); view.open(); final List jobIDsFiltered = view.projectStatus.getJobIDs(); - assertEquals(Arrays.asList("a", "aa"), jobIDsFiltered); + assertEquals(List.of("a", "aa"), jobIDsFiltered); } @Test @@ -251,17 +250,13 @@ public void configureDashboardFilterBuildExecutors() throws Exception { FreeStyleJob job = jenkins.jobs.create(); DashboardView v = createDashboardView(); - v.configure(() -> { - v.mainArea.setFilterBuildExecutors(filterBuildExecutors); - }); + v.configure(() -> v.mainArea.setFilterBuildExecutors(filterBuildExecutors)); v.open(); final List headers = v.buildExecutorStatus.getHeaders(); assertThat(headers.size(), is(2)); - job.configure(() -> { - job.setLabelExpression("test"); - }); + job.configure(() -> job.setLabelExpression("test")); v.open(); final List headers2 = v.buildExecutorStatus.getHeaders(); @@ -273,9 +268,7 @@ public void configureDashboardFilterBuildExecutors() throws Exception { public void configureDashboardFilterOnlyActivatedJobs() { DashboardView v = createDashboardView(); BuildStatisticsPortlet stats = v.addBottomPortlet(BuildStatisticsPortlet.class); - v.configure(() -> { - v.jobFilters.setStatusFilter(JobFiltersArea.StatusFilter.ENABLED); - }); + v.configure(() -> v.jobFilters.setStatusFilter(JobFiltersArea.StatusFilter.ENABLED)); final FreeStyleJob active = createFreeStyleJob(); final FreeStyleJob disabled = createFreeStyleJob(); diff --git a/src/test/java/plugins/DisplayUrlApiTest.java b/src/test/java/plugins/DisplayUrlApiTest.java index 2b3611cdfa..f8d88a30d5 100644 --- a/src/test/java/plugins/DisplayUrlApiTest.java +++ b/src/test/java/plugins/DisplayUrlApiTest.java @@ -136,7 +136,7 @@ private void doTestRedirects() throws IOException { private String[] getURLS(String jobName) { return jenkins.runScript( - "" + "import org.jenkinsci.plugins.displayurlapi.DisplayURLProvider\n" + "import org.jenkinsci.plugins.displayurlapi.DisplayURLProvider\n" + "import org.jenkinsci.plugins.workflow.job.*\n" + "\n" + "WorkflowJob p = new WorkflowJob(Jenkins.getInstance(),\"%s\");\n" @@ -150,14 +150,10 @@ private String[] getURLS(String jobName) { } private void assertRedirect(String s) throws IOException { - CloseableHttpResponse response = null; HttpGet get = new HttpGet(s.trim()); - try { - response = (CloseableHttpResponse) client.execute(get); + try (CloseableHttpResponse response = (CloseableHttpResponse) client.execute(get)) { int responseCode = response.getStatusLine().getStatusCode(); assertEquals(String.format("URL %s is not reachable", s.trim()), 200, responseCode); - } finally { - response.close(); } } } diff --git a/src/test/java/plugins/ExternalWorkspaceManagerPluginTest.java b/src/test/java/plugins/ExternalWorkspaceManagerPluginTest.java index 5fb618a537..23e57be246 100644 --- a/src/test/java/plugins/ExternalWorkspaceManagerPluginTest.java +++ b/src/test/java/plugins/ExternalWorkspaceManagerPluginTest.java @@ -107,7 +107,7 @@ public void shareWorkspaceTwoJobsTwoNodes() { verifyExternalWorkspacesAction(upstreamJob.name, upstreamBuild); WorkflowJob downstreamJob = createWorkflowJob(String.format( - "" + "def run = selectRun '%s' \n" + "def run = selectRun '%s' \n" + "def extWorkspace = exwsAllocate selectedRun: run \n" + "node ('test') { \n" + " exws (extWorkspace) { \n" @@ -129,7 +129,7 @@ public void shareWorkspaceTwoJobsTwoNodes() { @Test public void externalWorkspaceCleanup() { WorkflowJob job = createWorkflowJob(String.format( - "" + "def extWorkspace = exwsAllocate '%s' \n" + "def extWorkspace = exwsAllocate '%s' \n" + "node ('linux') { \n" + " exws (extWorkspace) { \n" + " try { \n" diff --git a/src/test/java/plugins/GerritTriggerTest.java b/src/test/java/plugins/GerritTriggerTest.java index 979f401f8d..867517b7f4 100644 --- a/src/test/java/plugins/GerritTriggerTest.java +++ b/src/test/java/plugins/GerritTriggerTest.java @@ -42,7 +42,6 @@ import java.nio.file.Files; import java.nio.file.attribute.PosixFilePermission; import java.util.ArrayList; -import java.util.Arrays; import java.util.HashSet; import java.util.List; import java.util.logging.ConsoleHandler; @@ -51,7 +50,6 @@ import java.util.logging.SimpleFormatter; import java.util.regex.Matcher; import java.util.regex.Pattern; -import org.apache.commons.io.FileUtils; import org.apache.commons.io.IOUtils; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; import org.jenkinsci.test.acceptance.junit.TestActivation; @@ -108,7 +106,7 @@ public class GerritTriggerTest extends AbstractJUnitTest { private String gtPrivateKey; // List of changes to abandon - private List changes = new ArrayList(); + private List changes = new ArrayList<>(); private File ssh; @After @@ -152,15 +150,15 @@ public void setupSSHWrapper() throws IOException { ssh = File.createTempFile("jenkins", "ssh"); ssh.deleteOnExit(); - FileUtils.writeStringToFile( - ssh, + Files.writeString( + ssh.toPath(), "#!/bin/sh\n" + "exec ssh -o StrictHostKeyChecking=no -i " + gtPrivateKey + " \"$@\"", StandardCharsets.UTF_8); Files.setPosixFilePermissions( ssh.toPath(), - new HashSet<>(Arrays.asList(PosixFilePermission.OWNER_READ, PosixFilePermission.OWNER_EXECUTE))); + new HashSet<>(List.of(PosixFilePermission.OWNER_READ, PosixFilePermission.OWNER_EXECUTE))); - changes = new ArrayList(); + changes = new ArrayList<>(); } @BeforeClass @@ -307,9 +305,7 @@ private static String stringFrom(Process p) throws InterruptedException, IOExcep assertThat(p.waitFor(), is(equalTo(0))); StringWriter writer = new StringWriter(); IOUtils.copy(p.getInputStream(), writer, StandardCharsets.UTF_8); - String string = writer.toString() - .replaceAll(System.getProperty("line.separator"), "") - .replaceAll(" ", ""); + String string = writer.toString().replaceAll(System.lineSeparator(), "").replaceAll(" ", ""); writer.close(); return string; } diff --git a/src/test/java/plugins/GradlePluginTest.java b/src/test/java/plugins/GradlePluginTest.java index 7bcf607b0e..d2b63f825c 100644 --- a/src/test/java/plugins/GradlePluginTest.java +++ b/src/test/java/plugins/GradlePluginTest.java @@ -135,7 +135,7 @@ private Build setUpAndRunPipelineBuild(final String jenkinsFile, final String gr final WorkflowJob workflowJob = jenkins.jobs.create(WorkflowJob.class); String copyResourceStep = workflowJob.copyResourceStep(gradleScript); - String test = "" + "pipeline {\n" + String test = "pipeline {\n" + "agent any\n" + "stages {\n" + "stage ('prepare_build') {\n" diff --git a/src/test/java/plugins/JUnitPluginTest.java b/src/test/java/plugins/JUnitPluginTest.java index f863f070bd..a6435bf3cf 100644 --- a/src/test/java/plugins/JUnitPluginTest.java +++ b/src/test/java/plugins/JUnitPluginTest.java @@ -80,7 +80,7 @@ private void assertMessage(String test, String content) { // Given that there may be several tests with the same name, we assert // that at least one of the pages have the requested content final List elements = all(by.xpath("//a[text()='%s']", test)); - final List testPages = new ArrayList(elements.size()); + final List testPages = new ArrayList<>(elements.size()); for (WebElement e : elements) { testPages.add(e.getAttribute("href")); } diff --git a/src/test/java/plugins/JabberPluginTest.java b/src/test/java/plugins/JabberPluginTest.java index 46c3f55853..07396b422e 100644 --- a/src/test/java/plugins/JabberPluginTest.java +++ b/src/test/java/plugins/JabberPluginTest.java @@ -7,7 +7,7 @@ import java.io.File; import java.io.IOException; import java.nio.charset.StandardCharsets; -import org.apache.commons.io.FileUtils; +import java.nio.file.Files; import org.jenkinsci.test.acceptance.docker.DockerContainerHolder; import org.jenkinsci.test.acceptance.docker.fixtures.JabberContainer; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; @@ -64,7 +64,6 @@ public void jabber_notification_success_publishing() throws IOException, Interru ec.jabberPassword.set(jabberPasswordString); // sleep(10000); } - ; MUCConfig mc = ec.addMUCConfig(); { @@ -96,6 +95,6 @@ public void jabber_notification_success_publishing() throws IOException, Interru j.startBuild().shouldSucceed(); sleep(20000); File logfile = jabber.getLogbotLogFile(); - assertThat(FileUtils.readFileToString(logfile, StandardCharsets.UTF_8), containsString("SUCCESS")); + assertThat(Files.readString(logfile.toPath(), StandardCharsets.UTF_8), containsString("SUCCESS")); } } diff --git a/src/test/java/plugins/MatrixPluginTest.java b/src/test/java/plugins/MatrixPluginTest.java index c87cd74bc9..541f30ebc7 100644 --- a/src/test/java/plugins/MatrixPluginTest.java +++ b/src/test/java/plugins/MatrixPluginTest.java @@ -6,8 +6,8 @@ import static org.hamcrest.Matchers.not; import com.google.inject.Inject; -import java.util.Collections; import java.util.List; +import java.util.Map; import org.jenkinsci.test.acceptance.Matcher; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; import org.jenkinsci.test.acceptance.junit.Since; @@ -152,16 +152,13 @@ public void use_job_parameters_in_combination_filters() { job.addParameter(StringParameter.class).setName("condition"); job.save(); - MatrixBuild b = job.startBuild(Collections.singletonMap("condition", "false")) - .waitUntilFinished() - .as(MatrixBuild.class); + MatrixBuild b = + job.startBuild(Map.of("condition", "false")).waitUntilFinished().as(MatrixBuild.class); b.getConfiguration("run=yes").shouldExist(); b.getConfiguration("run=maybe").shouldNotExist(); b.getConfiguration("run=no").shouldNotExist(); - b = job.startBuild(Collections.singletonMap("condition", "true")) - .waitUntilFinished() - .as(MatrixBuild.class); + b = job.startBuild(Map.of("condition", "true")).waitUntilFinished().as(MatrixBuild.class); b.getConfiguration("run=yes").shouldExist(); b.getConfiguration("run=maybe").shouldExist(); b.getConfiguration("run=no").shouldNotExist(); @@ -264,7 +261,7 @@ private void rebuildCombination(MatrixProject job, String... combinations) { } private Matcher built() { - return new Matcher("Matrix run exists") { + return new Matcher<>("Matrix run exists") { @Override public boolean matchesSafely(MatrixRun item) { return item.exists(); diff --git a/src/test/java/plugins/MatrixReloadedPluginTest.java b/src/test/java/plugins/MatrixReloadedPluginTest.java index c0ec4facc4..0a298289ed 100644 --- a/src/test/java/plugins/MatrixReloadedPluginTest.java +++ b/src/test/java/plugins/MatrixReloadedPluginTest.java @@ -74,7 +74,7 @@ public void rebuild_one_combination() { } private Matcher exists() { - return new Matcher("Matrix run exists") { + return new Matcher<>("Matrix run exists") { @Override public boolean matchesSafely(MatrixRun item) { return item.exists(); diff --git a/src/test/java/plugins/NodeLabelParameterPluginTest.java b/src/test/java/plugins/NodeLabelParameterPluginTest.java index ff8ebd7761..757c84d1cc 100644 --- a/src/test/java/plugins/NodeLabelParameterPluginTest.java +++ b/src/test/java/plugins/NodeLabelParameterPluginTest.java @@ -13,8 +13,8 @@ import com.google.inject.Inject; import java.util.ArrayList; -import java.util.Collections; import java.util.List; +import java.util.Map; import java.util.Set; import org.apache.commons.lang3.SystemUtils; import org.jenkinsci.test.acceptance.Matcher; @@ -53,8 +53,7 @@ public void build_on_a_particular_slave() throws Exception { j.addParameter(NodeParameter.class).setName("slavename"); j.save(); - Build b = - j.startBuild(Collections.singletonMap("slavename", s.getName())).shouldSucceed(); + Build b = j.startBuild(Map.of("slavename", s.getName())).shouldSucceed(); assertThat(b.getNode(), is(s)); } @@ -80,8 +79,7 @@ public void build_with_preselected_node() throws Exception { assertThat(availableNodes.get(0).getText(), is("built-in")); assertThat(availableNodes.get(1).getText(), is(s.getName())); - Build b = - j.startBuild(Collections.singletonMap("slavename", s.getName())).shouldSucceed(); + Build b = j.startBuild(Map.of("slavename", s.getName())).shouldSucceed(); assertThat(s, is(b.getNode())); } @@ -96,14 +94,12 @@ public void run_on_label() throws Exception { j.addParameter(LabelParameter.class).setName("slavelabel"); j.save(); - Build b = j.startBuild(Collections.singletonMap("slavelabel", s1.getName())) - .shouldSucceed(); + Build b = j.startBuild(Map.of("slavelabel", s1.getName())).shouldSucceed(); assertThat(b.getNode(), is(s1)); - b = j.startBuild( - Collections.singletonMap("slavelabel", String.format("!%s && !%s", s1.getName(), s2.getName()))) + b = j.startBuild(Map.of("slavelabel", String.format("!%s && !%s", s1.getName(), s2.getName()))) .shouldSucceed(); - assertThat(b.getNode(), is((Node) jenkins)); + assertThat(b.getNode(), is(jenkins)); } @Test @@ -120,8 +116,7 @@ public void run_on_several_slaves() throws Exception { j.concurrentBuild.check(); j.save(); - j.startBuild(Collections.singletonMap("slavename", s1.getName() + "," + s2.getName())) - .shouldSucceed(); + j.startBuild(Map.of("slavename", s1.getName() + "," + s2.getName())).shouldSucceed(); assertThat(j.getNextBuildNumber(), is(3)); @@ -156,7 +151,7 @@ public void run_on_a_particular_offline_slave() throws Exception { assertThat(s.isOffline(), is(true)); // use scheduleBuild instead of startBuild to avoid a timeout waiting for Build being started - Build b = j.scheduleBuild(Collections.singletonMap("slavename", s.getName())); + Build b = j.scheduleBuild(Map.of("slavename", s.getName())); elasticSleep( 3000); // TODO: not the best way to wait for the scheduled job to go through the queue, but a bit of // wait is needed @@ -197,7 +192,7 @@ public void run_on_a_particular_offline_slave_with_ignore() throws Exception { assertThat(s.isOffline(), is(true)); // use scheduleBuild instead of startBuild to avoid a timeout waiting for Build being started - Build b = j.scheduleBuild(Collections.singletonMap("slavename", s.getName())); + Build b = j.scheduleBuild(Map.of("slavename", s.getName())); elasticSleep( 3000); // TODO: not the best way to wait for the scheduled job to go through the queue, but a bit of // wait is needed @@ -236,7 +231,7 @@ public void run_on_several_online_and_offline_slaves() throws Exception { assertThat(s1.isOnline(), is(true)); // select both slaves for this build - Build b = j.startBuild(Collections.singletonMap("slavename", s1.getName() + "," + s2.getName())) + Build b = j.startBuild(Map.of("slavename", s1.getName() + "," + s2.getName())) .shouldSucceed(); // ensure that the build on the online slave has been done @@ -289,7 +284,7 @@ public void pending_build_with_no_valid_node() throws Exception { assertThat(s1.isOnline(), is(true)); // select both slaves for this build - Build b = j.startBuild(Collections.singletonMap("slavename", s1.getName())); + Build b = j.startBuild(Map.of("slavename", s1.getName())); // wait for the build on slave 1 to finish b.waitUntilFinished(); @@ -298,7 +293,7 @@ public void pending_build_with_no_valid_node() throws Exception { assertThat(s1.getBuildHistory().getBuildsOf(j), contains(b)); // use scheduleBuild instead of startBuild to avoid a timeout waiting for Build being started - b = j.scheduleBuild(Collections.singletonMap("slavename", s2.getName())); + b = j.scheduleBuild(Map.of("slavename", s2.getName())); waitFor(by.href("/queue/cancelItem?id=2")); // shown in queue elasticSleep(10000); // after some time @@ -336,7 +331,7 @@ public void trigger_if_succeeds_with_failed_main_build() throws Exception { j.save(); // select both slaves for this build - Build build = j.startBuild(Collections.singletonMap("slavename", s1.getName() + "," + s2.getName())) + Build build = j.startBuild(Map.of("slavename", s1.getName() + "," + s2.getName())) .shouldFail(); // verify failed result prevents the job to be built on further nodes. @@ -393,7 +388,7 @@ public void trigger_if_succeeds_with_failed_post_build_step() throws Exception { j.save(); // select both slaves for this build - j.startBuild(Collections.singletonMap( + j.startBuild(Map.of( "slavename", slaves.get(0).getName() + "," + slaves.get(1).getName())) .shouldFail(); @@ -402,7 +397,7 @@ public void trigger_if_succeeds_with_failed_post_build_step() throws Exception { // As the nodes get random names and the selected nodes are utilized in alphabetical order // of their names, the first build will not necessarily be done on s1. Thus, it can only // be verified that the job has been built on one of the slaves. - j.startBuild(Collections.singletonMap( + j.startBuild(Map.of( "slavename", slaves.get(0).getName() + "," + slaves.get(1).getName())) .shouldFail(); @@ -447,7 +442,7 @@ public void trigger_if_succeeds_with_unstable_post_build_step() throws Exception j.save(); // select both slaves for this build - j.startBuild(Collections.singletonMap( + j.startBuild(Map.of( "slavename", slaves.get(0).getName() + "," + slaves.get(1).getName())) .shouldFail(); @@ -456,7 +451,7 @@ public void trigger_if_succeeds_with_unstable_post_build_step() throws Exception // As the nodes get random names and the selected nodes are utilized in alphabetical order // of their names, the first build will not necessarily be done on s1. Thus, it can only // be verified that the job has been built on one of the slaves. - j.startBuild(Collections.singletonMap( + j.startBuild(Map.of( "slavename", slaves.get(0).getName() + "," + slaves.get(1).getName())) .shouldFail(); @@ -503,8 +498,7 @@ public void run_on_online_slave_and_master_with_node_restriction() throws Except assertThat("Amount of selectable nodes", slaves.size(), is(2)); assertThat(slaves, containsInAnyOrder(s1.getName(), s2.getName())); - j.startBuild(Collections.singletonMap("slavename", s1.getName() + "," + s2.getName())) - .waitUntilFinished(); + j.startBuild(Map.of("slavename", s1.getName() + "," + s2.getName())).waitUntilFinished(); assertThat(s1.getBuildHistory(), containsBuildOf(j)); assertThat(s2.getBuildHistory(), containsBuildOf(j)); @@ -532,7 +526,7 @@ private void shouldBeTriggeredWithoutValidOnlineNode(Build build, String nodenam } private Matcher started() { - return new Matcher("Build has started") { + return new Matcher<>("Build has started") { @Override public boolean matchesSafely(Build build) { return build.hasStarted(); diff --git a/src/test/java/plugins/PostBuildScriptPluginTest.java b/src/test/java/plugins/PostBuildScriptPluginTest.java index 2a671af27c..723a6069c0 100644 --- a/src/test/java/plugins/PostBuildScriptPluginTest.java +++ b/src/test/java/plugins/PostBuildScriptPluginTest.java @@ -57,7 +57,7 @@ private PostBuildScript addMarkerPostBuildStep() { } private Matcher runPostBuildStep() { - return new Matcher("post build step was run") { + return new Matcher<>("post build step was run") { @Override public boolean matchesSafely(Build item) { return item.getConsole().contains("RUNNING_POST_BUILD_STEP"); diff --git a/src/test/java/plugins/SSHCredentialsTest.java b/src/test/java/plugins/SSHCredentialsTest.java index 75e6eb4e34..ae1385bffb 100644 --- a/src/test/java/plugins/SSHCredentialsTest.java +++ b/src/test/java/plugins/SSHCredentialsTest.java @@ -101,8 +101,7 @@ public void manageDomainSSHCredentialsTest() throws MalformedURLException { dp.save(); CredentialsPage cp = createCredentialsPage(false); - final SshPrivateKeyCredential credInDomain = - (SshPrivateKeyCredential) createCredentials(SshPrivateKeyCredential.class, cp, SYSTEM_SCOPE); + final SshPrivateKeyCredential credInDomain = createCredentials(SshPrivateKeyCredential.class, cp, SYSTEM_SCOPE); prepareForVerify(cp, CRED_DSCR); verifyValueForCredential(cp, credInDomain.username, CRED_USER); diff --git a/src/test/java/plugins/SupportCorePluginTest.java b/src/test/java/plugins/SupportCorePluginTest.java index a576166d8b..4158138644 100644 --- a/src/test/java/plugins/SupportCorePluginTest.java +++ b/src/test/java/plugins/SupportCorePluginTest.java @@ -26,7 +26,7 @@ import static org.junit.Assert.assertFalse; -import java.util.Collections; +import java.util.Map; import java.util.logging.Level; import org.jenkinsci.test.acceptance.junit.AbstractJUnitTest; import org.jenkinsci.test.acceptance.junit.WithPlugins; @@ -40,7 +40,7 @@ public class SupportCorePluginTest extends AbstractJUnitTest { @Issue("JENKINS-27669") @Test public void emptyLogger() throws Exception { - JenkinsLogger logger = jenkins.createLogger("test", Collections.singletonMap("", Level.ALL)); + JenkinsLogger logger = jenkins.createLogger("test", Map.of("", Level.ALL)); assertFalse(logger.isEmpty()); } }