package org.jacorb.test.notification;
import org.junit.Assert;
import org.omg.CORBA.BooleanHolder;
import org.omg.CORBA.IntHolder;
import org.omg.CORBA.ORB;
import org.omg.CosEventChannelAdmin.AlreadyConnected;
import org.omg.CosEventComm.Disconnected;
import org.omg.CosNotification.EventType;
import org.omg.CosNotification.StructuredEvent;
import org.omg.CosNotifyChannelAdmin.AdminLimitExceeded;
import org.omg.CosNotifyChannelAdmin.ClientType;
import org.omg.CosNotifyChannelAdmin.ConsumerAdmin;
import org.omg.CosNotifyChannelAdmin.EventChannel;
import org.omg.CosNotifyChannelAdmin.ProxyType;
import org.omg.CosNotifyChannelAdmin.SequenceProxyPullSupplier;
import org.omg.CosNotifyChannelAdmin.SequenceProxyPullSupplierHelper;
import org.omg.CosNotifyComm.SequencePullConsumerHelper;
import org.omg.CosNotifyComm.SequencePullConsumerOperations;
import org.omg.CosNotifyComm.SequencePullConsumerPOATie;
class SequencePullReceiver extends Thread implements SequencePullConsumerOperations,
TestClientOperations
{
StructuredEvent[] event_ = null;
boolean connected_;
SequenceProxyPullSupplier pullSupplier_;
boolean received_;
long TIMEOUT = 1000;
boolean error_;
ORB orb_;
public SequencePullReceiver(ORB orb)
{
super();
orb_ = orb;
}
public boolean isConnected()
{
return connected_;
}
public void connect(EventChannel channel, boolean useOrSemantic) throws AdminLimitExceeded,
AlreadyConnected
{
SequencePullConsumerPOATie _receiverTie = new SequencePullConsumerPOATie(this);
ConsumerAdmin _consumerAdmin = channel.default_consumer_admin();
IntHolder _proxyId = new IntHolder();
pullSupplier_ = SequenceProxyPullSupplierHelper.narrow(_consumerAdmin
.obtain_notification_pull_supplier(ClientType.SEQUENCE_EVENT, _proxyId));
Assert.assertEquals(ProxyType._PULL_SEQUENCE, pullSupplier_.MyType().value());
pullSupplier_.connect_sequence_pull_consumer(SequencePullConsumerHelper.narrow(_receiverTie
._this(orb_)));
connected_ = true;
}
public boolean isEventHandled()
{
return event_ != null;
}
public boolean isError()
{
return false;
}
public void run()
{
BooleanHolder _success = new BooleanHolder();
_success.value = false;
try
{
event_ = pullSupplier_.pull_structured_events(1);
} catch (Disconnected d)
{
d.printStackTrace();
error_ = true;
}
}
public void push_structured_events(StructuredEvent[] event)
{
event_ = event;
synchronized (this)
{
notifyAll();
}
}
public void disconnect_sequence_pull_consumer()
{
connected_ = false;
}
public void offer_change(EventType[] e1, EventType[] e2)
{
// ignored
}
public void shutdown()
{
// mySupplier_.d
}
}