/*
* 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
* @bug 4607272 6842687
* @summary Unit test for AsynchronousChannelGroup
* @build Restart
*/
/**
* Exercise replacement of threads in the thread pool when completion handlers
* terminate due to errors or runtime exceptions.
*/
public class Restart {
// thread group for thread pools
// keep track of the number of threads that terminate
new Thread.UncaughtExceptionHandler() {
}
};
return t;
}
};
// group with fixed thread pool
// group with custom thread pool
// give time for threads to terminate
if (actual != 200)
}
throws Exception
{
for (int i=0; i<count; i++) {
try {
} catch (IOException ignore) { }
// throw error or runtime exception
if (rand.nextBoolean()) {
throw new Error();
} else {
throw new RuntimeException();
}
}
}
});
// establish loopback connection which should cause completion
// handler to be invoked.
// wait for handler to be invoked
}
// clean-up
}
}