From b41bd21eec30bb96d9f0279fca4b9de7e05beff9 Mon Sep 17 00:00:00 2001 From: Andrey Nazarov Date: Thu, 22 Jun 2017 10:53:21 -0700 Subject: [PATCH] 8181105: Nashorn file descriptor leak Reviewed-by: jlaskey, hannesw, sundar --- .../jdk/nashorn/internal/runtime/Source.java | 10 ++++++---- .../test/framework/AbstractScriptRunnable.java | 4 ++-- .../internal/test/framework/ScriptRunnable.java | 17 ++++++++++------- 3 files changed, 18 insertions(+), 13 deletions(-) diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java index f118bcd2283..6444b1cb2a9 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/Source.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -339,9 +339,11 @@ public final class Source implements Loggable { protected void loadMeta() throws IOException { if (length == 0 && lastModified == 0) { final URLConnection c = url.openConnection(); - length = c.getContentLength(); - lastModified = c.getLastModified(); - debug("loaded metadata for ", url); + try (InputStream in = c.getInputStream()) { + length = c.getContentLength(); + lastModified = c.getLastModified(); + debug("loaded metadata for ", url); + } } } } diff --git a/nashorn/test/src/jdk/nashorn/internal/test/framework/AbstractScriptRunnable.java b/nashorn/test/src/jdk/nashorn/internal/test/framework/AbstractScriptRunnable.java index 4e59f0fdf60..1019abdfcd0 100644 --- a/nashorn/test/src/jdk/nashorn/internal/test/framework/AbstractScriptRunnable.java +++ b/nashorn/test/src/jdk/nashorn/internal/test/framework/AbstractScriptRunnable.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -199,7 +199,7 @@ public abstract class AbstractScriptRunnable { try { return getEvaluator().run(out, err, args); } catch (final IOException e) { - throw new UnsupportedOperationException("I/O error in initializing shell - cannot redirect output to file"); + throw new UnsupportedOperationException("I/O error in initializing shell - cannot redirect output to file", e); } } diff --git a/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java b/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java index e52d2a66373..21a760983e0 100644 --- a/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java +++ b/nashorn/test/src/jdk/nashorn/internal/test/framework/ScriptRunnable.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -118,9 +118,10 @@ public final class ScriptRunnable extends AbstractScriptRunnable implements ITes if (errors != 0 || checkCompilerMsg) { if (expectCompileFailure || checkCompilerMsg) { - final PrintStream outputDest = new PrintStream(new FileOutputStream(errorFileName)); - TestHelper.dumpFile(outputDest, new StringReader(new String(err.toByteArray()))); - outputDest.println("--"); + try (PrintStream outputDest = new PrintStream(new FileOutputStream(errorFileName))) { + TestHelper.dumpFile(outputDest, new StringReader(new String(err.toByteArray()))); + outputDest.println("--"); + } } else { log(new String(err.toByteArray())); } @@ -224,7 +225,6 @@ public final class ScriptRunnable extends AbstractScriptRunnable implements ITes BufferedReader expected; if (expectedFile.exists()) { - expected = new BufferedReader(new InputStreamReader(new FileInputStream(expectedFileName0))); // copy expected file overwriting existing file and preserving last // modified time of source try { @@ -235,11 +235,14 @@ public final class ScriptRunnable extends AbstractScriptRunnable implements ITes } catch (final IOException ex) { fail("failed to copy expected " + expectedFileName + " to " + copyExpectedFileName + ": " + ex.getMessage()); } + expected = new BufferedReader(new InputStreamReader(new FileInputStream(expectedFileName0))); } else { expected = new BufferedReader(new StringReader("")); } - final BufferedReader actual = new BufferedReader(new InputStreamReader(new FileInputStream(outputFileName0))); - compare(actual, expected, compareCompilerMsg); + try (BufferedReader actual = new BufferedReader(new InputStreamReader(new FileInputStream(outputFileName0))); + BufferedReader expected0 = expected){ + compare(actual, expected0, compareCompilerMsg); + } } }