1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
// **********************************************************************
//
// Copyright (c) 2003-2009 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************
public class Client
{
private static int
run(String[] args, Ice.Communicator communicator)
{
Test.MyClassPrx myClass = AllTests.allTests(communicator, false);
System.out.print("testing server shutdown... ");
System.out.flush();
myClass.shutdown();
try
{
myClass.opVoid();
throw new RuntimeException();
}
catch(Ice.LocalException ex)
{
System.out.println("ok");
}
return 0;
}
public static void
main(String[] args)
{
int status = 0;
Ice.Communicator communicator = null;
try
{
//
// In this test, we need at least two threads in the
// client side thread pool for nested AMI.
//
Ice.StringSeqHolder argsH = new Ice.StringSeqHolder(args);
Ice.InitializationData initData = new Ice.InitializationData();
initData.properties = Ice.Util.createProperties(argsH);
initData.properties.setProperty("Ice.ThreadPool.Client.Size", "2");
initData.properties.setProperty("Ice.ThreadPool.Client.SizeWarn", "0");
//
// We must set MessageSizeMax to an explicit values,
// because we run tests to check whether
// Ice.MemoryLimitException is raised as expected.
//
initData.properties.setProperty("Ice.MessageSizeMax", "100");
communicator = Ice.Util.initialize(argsH, initData);
status = run(argsH.value, communicator);
}
catch(Exception ex)
{
ex.printStackTrace();
status = 1;
}
if(communicator != null)
{
try
{
communicator.destroy();
}
catch(Ice.LocalException ex)
{
ex.printStackTrace();
status = 1;
}
}
System.gc();
System.exit(status);
}
}
|