/*************************************************
*
* = FILENAME
* LoggerTest.java
*
*@author Everett Anderson
*
*************************************************/
package tests.netsvcs.Logger;
import JACE.SOCK_SAP.*;
import java.io.*;
import java.net.*;
import JACE.OS.*;
import netsvcs.Logger.LogRecord;
/**
*
*
DESCRIPTION
*
*
* This is a simple test log client very similar to the direct_logging client of
* C++ ACE. The logging service should correctly receive messages from both
* the C++ and Java version.
*
*
* @see netsvcs.Logger.ServerLoggingAcceptor, netsvcs.Logger.LogRecord
*/
public class LoggerTest {
/** Command line: []
*
* Creates a "hello world" log message and sends it to the server logging service.
* If no command line arguments are given, it uses ACE.DEFAULT_SERVER_PORT, and the
* current machine for the service location.
*
*/
public static void main(String args[])
{
if (args.length < 1) {
System.err.println("Use: LoggerTest []");
System.exit(0);
}
// Set the port
int port = args.length > 1 ? (new Integer(args[1])).intValue() : ACE.DEFAULT_SERVER_PORT;
SOCKStream cli_stream = new SOCKStream();
INETAddr remote_addr;
String host;
// Try to find the host
try {
host = args[0];
remote_addr = new INETAddr(port, host);
} catch (UnknownHostException uhe) {
ACE.ERROR("UnknownHostException " + uhe);
return;
}
System.out.println("Connecting to " + host + " on port " + port);
SOCKConnector con = new SOCKConnector();
try {
// Connect to the service
con.connect(cli_stream, remote_addr);
} catch (SocketException se) {
ACE.ERROR("Socket Exception " + se);
return;
} catch (IOException ie) {
ACE.ERROR("IOException " + ie);
return;
}
// Send a message with priority 4, the current time,
// and 0 for the process ID.
LogRecord record = new LogRecord(4,
System.currentTimeMillis(),
0);
// Set the text of the message
record.msgData("hello world");
try {
// Get a transmission system from the socket
OutputStream os = cli_stream.socket().getOutputStream();
DataOutputStream dos = new DataOutputStream(os);
// Send it
record.streamOutTo(dos);
// Close the socket
cli_stream.close();
} catch (IOException ie) {
ACE.ERROR("IOException, loop: " + ie);
return;
}
}
};