// Tags: JDK1.1
// Copyright (C) 2005 Daniel Bonniot <bonniot@users.sf.net>
// This file is part of Mauve.
// Mauve is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2, or (at your option)
// any later version.
// Mauve 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 for more details.
// You should have received a copy of the GNU General Public License
// along with Mauve; see the file COPYING. If not, write to
// the Free Software Foundation, 59 Temple Place - Suite 330,
// Boston, MA 02111-1307, USA. */
package gnu.testlet.java.io.Serializable;
import gnu.testlet.TestHarness;
import gnu.testlet.Testlet;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
/**
* Check when a parent readResolve() method should be used for subclasses.
*
* Here is the rationale for this test, based on Sun's javadoc for
* java.io.Serializable:
*
* First, readResolve must be declared with:
* ANY-ACCESS-MODIFIER Object readResolve() throws ObjectStreamException;
* Thus, a non-private readResolve is OK.
*
* Second, the rules for invoking readResolve (as for writeReplace) are that
* it must be called if it would be accessible from the class of the object
* being deserialized. So, a non-private readSolve method in the parent must
* be called, but a private one should not be.
*/
public class ParentReadResolve implements Testlet {
public void test(TestHarness harness)
{
try {
ByteArrayOutputStream outb = new ByteArrayOutputStream();
ObjectOutputStream outs = new ObjectOutputStream(outb);
outs.writeObject(MySingleton.instance);
outs.writeObject(new MyFoo());
byte[] store = outb.toByteArray();
ByteArrayInputStream inb = new ByteArrayInputStream(store);
ObjectInputStream ins = new ObjectInputStream(inb);
MySingleton x = (MySingleton) ins.readObject();
harness.check(x == MySingleton.instance);
MyFoo foo = (MyFoo) ins.readObject();
harness.check(! foo.resolved);
}
catch (Throwable e) {
harness.debug(e);
}
}
//// Singleton/MySingleton with a non-private readResolve ////
static abstract class Singleton implements java.io.Serializable
{
abstract Singleton getInstance();
/** NOTE: this readResolve is not private.
*/
Object readResolve() {
return getInstance();
}
}
static class MySingleton extends Singleton
{
static final MySingleton instance = new MySingleton();
Singleton getInstance() { return instance; }
}
//// Foo/MyFoo with a private readResolve ////
static abstract class Foo implements java.io.Serializable
{
boolean resolved = false;
/** NOTE: this readResolve is private.
*/
private Object readResolve() {
resolved = true;
return this;
}
}
static class MyFoo extends Foo
{
}
}