mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-22 20:14:43 +02:00
8248231: deserializeLambda created with wrong encoding if platform encoding not UTF-8
Reviewed-by: vromero
This commit is contained in:
parent
1d5ec8f363
commit
d42f541dc3
3 changed files with 180 additions and 2 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2020, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -2425,7 +2425,8 @@ public class LambdaToMethod extends TreeTranslator {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void append(byte[] ba) {
|
protected void append(byte[] ba) {
|
||||||
sb.append(new String(ba));
|
Name name = names.fromUtf(ba);
|
||||||
|
sb.append(name.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,92 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020, 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 8248231
|
||||||
|
* @summary Test to verify lambda serialization uses the correct UTF-8 encoding
|
||||||
|
* @library /test/lib
|
||||||
|
* @build jdk.test.lib.JDKToolFinder
|
||||||
|
* jdk.test.lib.process.ProcessTools
|
||||||
|
* @run testng LambdaFileEncodingSerialization
|
||||||
|
*/
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
import static org.testng.Assert.assertTrue;
|
||||||
|
|
||||||
|
import jdk.test.lib.JDKToolFinder;
|
||||||
|
import jdk.test.lib.process.ProcessTools;
|
||||||
|
|
||||||
|
public class LambdaFileEncodingSerialization {
|
||||||
|
|
||||||
|
private static final String TEST_NAME = "TestLambdaFileEncodingSerialization";
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public static void testDeserializeLambdaEncoding() throws Throwable {
|
||||||
|
|
||||||
|
String javac = JDKToolFinder.getTestJDKTool("javac");
|
||||||
|
String java = JDKToolFinder.getTestJDKTool("java");
|
||||||
|
|
||||||
|
String srcDir = System.getProperty("test.src");
|
||||||
|
|
||||||
|
// Compile <TEST_NAME>.java using ISO-8859-1 encoding
|
||||||
|
String opts = "-J-Dfile.encoding=ISO-8859-1 -cp . -d .";
|
||||||
|
String file = srcDir + File.separator + TEST_NAME + ".java";
|
||||||
|
int exitCode = runCmd(javac, opts, file);
|
||||||
|
assertTrue(exitCode == 0, "Command " + javac + " " + opts + " " + file + " , failed exitCode = "+exitCode);
|
||||||
|
|
||||||
|
// Execute TEST_NAME containing the re-serialized lambda
|
||||||
|
opts = "-cp .";
|
||||||
|
file = TEST_NAME;
|
||||||
|
exitCode = runCmd(java, opts, file);
|
||||||
|
assertTrue(exitCode == 0, "Command " + java + " " + opts + " " + file + " , failed exitCode = "+exitCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Run a command
|
||||||
|
private static int runCmd(String prog, String options, String file) throws Throwable {
|
||||||
|
|
||||||
|
List<String> argList = new ArrayList<String>();
|
||||||
|
argList.add(prog);
|
||||||
|
argList.addAll(Arrays.asList(options.split(" ")));
|
||||||
|
argList.add(file);
|
||||||
|
|
||||||
|
ProcessBuilder pb = new ProcessBuilder(argList);
|
||||||
|
Map<String, String> env = pb.environment();
|
||||||
|
env.put("LC_ALL", "en_US.UTF-8"); // Ensure locale supports the test requirements, lambda with a UTF char
|
||||||
|
|
||||||
|
int exitCode = ProcessTools.executeCommand(pb).outputTo(System.out)
|
||||||
|
.errorTo(System.err)
|
||||||
|
.getExitValue();
|
||||||
|
return exitCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,85 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020, 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.ObjectInputStream;
|
||||||
|
import java.io.ObjectOutputStream;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.nio.charset.*;
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Testcase for verifying deserializeLambda containing a non-ASCII mappable char
|
||||||
|
* is correctly handled as UTF-8
|
||||||
|
*/
|
||||||
|
public class TestLambdaFileEncodingSerialization {
|
||||||
|
public static class ABCâ implements Serializable {
|
||||||
|
public String msg;
|
||||||
|
public ABCâ() {
|
||||||
|
msg = "Hello world";
|
||||||
|
}
|
||||||
|
public static Callable<ABCâ> getHello() {
|
||||||
|
return (Callable<ABCâ> & Serializable) () -> {
|
||||||
|
return new ABCâ();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Re-serialize the object containing the lambda
|
||||||
|
private static <T> T reserialize(T o) throws IOException {
|
||||||
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
|
ObjectOutputStream oos = new ObjectOutputStream(baos);
|
||||||
|
|
||||||
|
oos.writeObject(o);
|
||||||
|
|
||||||
|
oos.close();
|
||||||
|
|
||||||
|
ObjectInputStream iis = new ObjectInputStream(new ByteArrayInputStream(baos.toByteArray()));
|
||||||
|
|
||||||
|
try {
|
||||||
|
o = (T)iis.readObject();
|
||||||
|
} catch (ClassNotFoundException e) {
|
||||||
|
throw new IOException(e);
|
||||||
|
}
|
||||||
|
iis.close();
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String args[]) throws Exception{
|
||||||
|
System.out.println("Default charset = "+Charset.defaultCharset());
|
||||||
|
|
||||||
|
// Construct class containing suitable UTF-8 char
|
||||||
|
Callable<ABCâ> foo = ABCâ.getHello();
|
||||||
|
ABCâ hello = new ABCâ();
|
||||||
|
|
||||||
|
// re-serialize hello
|
||||||
|
ABCâ rh = reserialize(hello);
|
||||||
|
System.out.println(rh.msg);
|
||||||
|
|
||||||
|
// re-serialize foo and call()
|
||||||
|
reserialize(foo).call();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue