Initial load
diff --git a/test/java/io/PipedOutputStream/ClosedWrite.java b/test/java/io/PipedOutputStream/ClosedWrite.java
new file mode 100644
index 0000000..55fcb6a
--- /dev/null
+++ b/test/java/io/PipedOutputStream/ClosedWrite.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 1998 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * @test
+ * @bug 1267258
+ * @summary Check for IOException upon write on closed stream.
+ *
+ */
+
+import java.io.*;
+
+/**
+ * This class tests to see if an IOException is thrown when
+ * an attempt is made to write to a closed PipedOutputStream.
+ */
+
+public class ClosedWrite {
+
+ public static void main(String[] argv) throws Exception {
+ PipedOutputStream os = new PipedOutputStream();
+ PipedInputStream is = new PipedInputStream();
+ os.connect(is);
+ os.close();
+ try {
+ os.write(10);
+ throw new
+ RuntimeException("No IOException upon write on closed Stream");
+ } catch(IOException e) {
+ System.err.println("Test passed: IOException thrown");
+ }
+ }
+}
diff --git a/test/java/io/PipedOutputStream/DeadReader.java b/test/java/io/PipedOutputStream/DeadReader.java
new file mode 100644
index 0000000..bd03e03
--- /dev/null
+++ b/test/java/io/PipedOutputStream/DeadReader.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 1998 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * @test
+ * @bug 1267045
+ * @summary Make sure write will fail if reading
+ * end thread is dead.
+ *
+ */
+
+
+import java.io.*;
+
+public class DeadReader {
+
+ public static void main(String[] argv) throws Exception {
+ PipedOutputStream os = new PipedOutputStream();
+ PipedInputStream is = new PipedInputStream();
+ is.connect(os);
+
+ // create reader thread
+ LazyReader lr = new LazyReader(is);
+
+ os.write(new byte[1000]);
+
+ lr.start();
+ while (lr.isAlive()) {
+ Thread.sleep(100);
+ }
+
+ try{
+ os.write(27);
+ throw new Exception
+ ("Test failed: shouldn't be able to write");
+ } catch (IOException e) {
+ // test passed
+ }
+ }
+}
+
+class LazyReader extends Thread {
+ private PipedInputStream snk;
+ private int delay;
+
+ public LazyReader(PipedInputStream snk) {
+ this.snk = snk;
+ }
+
+ public void run() {
+ try {
+ snk.read();
+ } catch (Exception e) {
+ System.err.println("Test failed: unexpected exception");
+ }
+ return;
+ }
+}
diff --git a/test/java/io/PipedOutputStream/MultipleConnect.java b/test/java/io/PipedOutputStream/MultipleConnect.java
new file mode 100644
index 0000000..750ee9f
--- /dev/null
+++ b/test/java/io/PipedOutputStream/MultipleConnect.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 1998 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * @test
+ * @bug 1266814
+ * @summary Check for IOException upon multiple connects.
+ *
+ */
+
+import java.io.*;
+
+public class MultipleConnect {
+
+ public static void main(String[] argv) throws Exception {
+ PipedOutputStream os = new PipedOutputStream();
+ PipedOutputStream os2 = new PipedOutputStream();
+ PipedInputStream is = new PipedInputStream();
+ os.connect(is);
+ try {
+ is.connect(os2);
+ throw new Exception("Test failed: IOException expected");
+ } catch(IOException e) {
+ }
+ }
+}
diff --git a/test/java/io/PipedOutputStream/NotConnected.java b/test/java/io/PipedOutputStream/NotConnected.java
new file mode 100644
index 0000000..e815b0f
--- /dev/null
+++ b/test/java/io/PipedOutputStream/NotConnected.java
@@ -0,0 +1,57 @@
+/*
+ * Copyright 1998 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * @test
+ * @bug 1267038
+ * @summary Check for IOException upon read/write on unconnected stream.
+ *
+ */
+
+
+import java.io.*;
+
+public class NotConnected {
+ public static void main( String[] argv ) throws Exception {
+ PipedInputStream i = new PipedInputStream();
+ PipedOutputStream o = new PipedOutputStream();
+ boolean readPassed = false;
+ boolean writePassed = false;
+
+ try {
+ i.read();
+ } catch (IOException e) {
+ readPassed = true;
+ }
+
+ try {
+ o.write(10);
+ } catch (IOException e) {
+ writePassed = true;
+ }
+
+ if (!readPassed || !writePassed) {
+ throw new Exception("Test failed: IOException not thrown" );
+ }
+ }
+}
diff --git a/test/java/io/PipedOutputStream/WriteAfterClose.java b/test/java/io/PipedOutputStream/WriteAfterClose.java
new file mode 100644
index 0000000..7c72aa4
--- /dev/null
+++ b/test/java/io/PipedOutputStream/WriteAfterClose.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright 1998 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/* @test
+ @bug 4143704
+ @summary Test if write throws exception after reader
+ closes the pipe.
+*/
+
+
+
+import java.io.*;
+
+public class WriteAfterClose {
+ public static void main(String argv[]) throws Exception {
+ PipedInputStream in = new PipedInputStream();
+ PipedOutputStream out = new PipedOutputStream(in);
+
+ in.close();
+ try {
+ out.write('a');
+ throw new Exception("Should not allow write after close");
+ } catch (IOException e) {
+ }
+ }
+}