/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* 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
* This test verifies of invocation
* annotateClass/replaceObject methods
*/
public class AnnotateClass {
"of invocation annotateClass/replaceObject " +
"methods \n");
try {
try {
p.flush();
} finally {
}
try {
"\nTEST FAILED: System.out not read correctly");
throw new Error();
}
"\nTEST FAILED: System.err not read correctly");
throw new Error();
}
"\nTEST FAILED: Non-system PrintStream should have " +
throw new Error();
}
} finally {
}
} catch (Exception e) {
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).
*/
/* Construct a new test stream */
super(out);
enableReplaceObject(true);
}
/* When any class is written, add a "magic" string
* that must be verified by the TestInputStream.
*/
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.
*/
throws IOException
{
/* For PrintStreams, like stdout and stderr, encode */
if (obj instanceof PrintStream) {
}
return obj;
}
}
/** Reverse the effects of TestOutputStream.
*/
super(in);
enableResolveObject(true);
}
/** Verify that the magic string was written to the stream
* Also use the default classname->class resolution.
*/
throws ClassNotFoundException, IOException
{
try {
if (!(s.equals("magic"))) {
"\nTEST FAILED: Bad magic number");
throw new Error();
}
} catch (IOException ee) {
"\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.
*/
}
return obj;
}
}
/* A holder class to map between standard print streams (stdout, stderr)
* and a small integer.
*/
stream = 1;
stream = 2;
}
}
if (stream == 1) {
} else if (stream == 2) {
} else {
return null;
}
}
}