942402bab8
Reviewed-by: darcy, lancea
192 lines
6.3 KiB
Java
192 lines
6.3 KiB
Java
/*
|
|
* Copyright (c) 2005, 2019, 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
|
|
* @summary it is new version of old test which was
|
|
* /src/share/test/serialization/subtest.java
|
|
* This test verifies of invocation
|
|
* annotateClass/replaceObject methods
|
|
*/
|
|
|
|
import java.io.*;
|
|
|
|
public class AnnotateClass {
|
|
public static void main (String argv[]) {
|
|
System.err.println("\nRegression test for verification " +
|
|
"of invocation annotateClass/replaceObject " +
|
|
"methods \n");
|
|
try {
|
|
FileOutputStream ostream = new FileOutputStream("subtest1.tmp");
|
|
try {
|
|
TestOutputStream p = new TestOutputStream(ostream);
|
|
p.writeObject(System.out);
|
|
p.writeObject(System.err);
|
|
p.writeObject(new PrintStream(ostream));
|
|
p.flush();
|
|
} finally {
|
|
ostream.close();
|
|
}
|
|
|
|
FileInputStream istream = new FileInputStream("subtest1.tmp");
|
|
try {
|
|
TestInputStream q = new TestInputStream(istream);
|
|
|
|
PrintStream out = (PrintStream)q.readObject();
|
|
PrintStream err = (PrintStream)q.readObject();
|
|
Object other = q.readObject();
|
|
if (out != System.out) {
|
|
System.err.println(
|
|
"\nTEST FAILED: System.out not read correctly");
|
|
throw new Error();
|
|
}
|
|
if (err != System.err) {
|
|
System.err.println(
|
|
"\nTEST FAILED: System.err not read correctly");
|
|
throw new Error();
|
|
}
|
|
if (other != null) {
|
|
System.err.println(
|
|
"\nTEST FAILED: Non-system PrintStream should have " +
|
|
"been written/read as null");
|
|
throw new Error();
|
|
}
|
|
} finally {
|
|
istream.close();
|
|
}
|
|
|
|
System.err.println("\nTEST PASSED");
|
|
} catch (Exception e) {
|
|
System.err.print("TEST FAILED: ");
|
|
e.printStackTrace();
|
|
throw new Error();
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/** ObjectOutputStream is extended to test the annotateClass()
|
|
* and replaceObject() subclassable methods.
|
|
* In annotateClass a magic string is written to the stream
|
|
* so that it can be verified in ObjectInputStream.
|
|
* replaceObject is used to subsititute a handle object for
|
|
* one of the standard PrintStreams (stdout or stderr).
|
|
*/
|
|
class TestOutputStream extends ObjectOutputStream {
|
|
/* Construct a new test stream */
|
|
TestOutputStream(OutputStream out) throws IOException {
|
|
super(out);
|
|
enableReplaceObject(true);
|
|
}
|
|
|
|
/* When any class is written, add a "magic" string
|
|
* that must be verified by the TestInputStream.
|
|
*/
|
|
protected void annotateClass(Class<?> cl) throws IOException {
|
|
this.writeUTF("magic");
|
|
}
|
|
|
|
/* For each object of type PrintStream, substitute
|
|
* a StdStream handle object that encodes which
|
|
* of the standard print streams is being written.
|
|
* Other objects are written as themselves.
|
|
*/
|
|
protected Object replaceObject(Object obj)
|
|
{
|
|
/* For PrintStreams, like stdout and stderr, encode */
|
|
if (obj instanceof PrintStream) {
|
|
return new StdStream((PrintStream)obj);
|
|
}
|
|
return obj;
|
|
}
|
|
}
|
|
|
|
/** Reverse the effects of TestOutputStream.
|
|
*/
|
|
class TestInputStream extends ObjectInputStream {
|
|
|
|
TestInputStream(InputStream in) throws IOException {
|
|
super(in);
|
|
enableResolveObject(true);
|
|
}
|
|
|
|
/** Verify that the magic string was written to the stream
|
|
* Also use the default classname->class resolution.
|
|
*/
|
|
protected Class<?> resolveClass(ObjectStreamClass classdesc)
|
|
throws ClassNotFoundException, IOException
|
|
{
|
|
try {
|
|
String s = readUTF();
|
|
if (!(s.equals("magic"))) {
|
|
System.err.println(
|
|
"\nTEST FAILED: Bad magic number");
|
|
throw new Error();
|
|
}
|
|
} catch (IOException ee) {
|
|
System.err.println(
|
|
"\nTEST FAILED: I/O Exception");
|
|
throw new Error();
|
|
}
|
|
return super.resolveClass(classdesc);
|
|
}
|
|
|
|
/** If the object in the stream is a StdStream,
|
|
* get the mapping of it to the local System printstream and
|
|
* return it.
|
|
* Other objects are returned as themselves.
|
|
*/
|
|
protected Object resolveObject(Object obj) {
|
|
if (obj instanceof StdStream) {
|
|
return ((StdStream)obj).getStream();
|
|
}
|
|
return obj;
|
|
}
|
|
}
|
|
|
|
/* A holder class to map between standard print streams (stdout, stderr)
|
|
* and a small integer.
|
|
*/
|
|
class StdStream implements java.io.Serializable {
|
|
private static final long serialVersionUID = 1L;
|
|
private int stream = 0;
|
|
|
|
public StdStream(PrintStream s) {
|
|
if (s == System.out) {
|
|
stream = 1;
|
|
} else if (s == System.err) {
|
|
stream = 2;
|
|
}
|
|
}
|
|
|
|
public PrintStream getStream() {
|
|
if (stream == 1) {
|
|
return System.out;
|
|
} else if (stream == 2) {
|
|
return System.err;
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
}
|