本文整理汇总了C#中Publisher.Bind方法的典型用法代码示例。如果您正苦于以下问题:C# Publisher.Bind方法的具体用法?C# Publisher.Bind怎么用?C# Publisher.Bind使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Publisher
的用法示例。
在下文中一共展示了Publisher.Bind方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: publisher_can_bind_multiple_different_endpoints
public void publisher_can_bind_multiple_different_endpoints()
{
using (var publisher = new Publisher())
{
publisher.Bind(new RedFoxEndpoint("/path1"));
publisher.Bind(new RedFoxEndpoint("/path2"));
}
}
示例2: publishers_bind_same_endpoint_twice_fails
public void publishers_bind_same_endpoint_twice_fails()
{
using (var publisher = new Publisher())
{
var endpoint = new RedFoxEndpoint("/path");
publisher.Bind(endpoint);
Assert.Throws<InvalidOperationException>(() => publisher.Bind(endpoint));
}
}
示例3: publisher_dispose_unbinds_endpoints
public void publisher_dispose_unbinds_endpoints()
{
using (var publisher = new Publisher())
{
publisher.Bind(new RedFoxEndpoint("/path1"));
publisher.Bind(new RedFoxEndpoint("/path2"));
}
using (var publisher = new Publisher())
{
publisher.Bind(new RedFoxEndpoint("/path1"));
publisher.Bind(new RedFoxEndpoint("/path2"));
}
}
示例4: One_Publisher_One_Subscriber_Batch_Broadcast
public void One_Publisher_One_Subscriber_Batch_Broadcast()
{
using (var publisher = new Publisher())
using (var subscriber = new Subscriber())
{
var endpoint = GetEndpoint();
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
Thread.Sleep(100);
var counterSignal = new CounterSignal(NumberOfMessagesToReceive);
subscriber.MessageReceived += (s, m) => counterSignal.Increment();
var messageSent = new TestMessage();
var batch = new List<TestMessage>();
for (var i = 0; i < NumberOfMessagesToReceive; i++)
batch.Add(messageSent);
var sw = Stopwatch.StartNew();
publisher.Broadcast(batch);
Assert.IsTrue(counterSignal.Wait(TimeOut), "Timeout waiting for message");
sw.Stop();
Assert.Inconclusive("{0} elapsed reading {1} messages ({2:N0} per second)", sw.Elapsed, NumberOfMessagesToReceive, NumberOfMessagesToReceive / sw.Elapsed.TotalSeconds);
}
}
示例5: two_publishers_same_endpoint_fails
public void two_publishers_same_endpoint_fails()
{
using (var publisher1 = new Publisher())
using (var publisher2 = new Publisher())
{
var endpoint = new RedFoxEndpoint("/path");
publisher1.Bind(endpoint);
Assert.Throws<InvalidOperationException>(() => publisher2.Bind(endpoint));
}
}
示例6: Subscribe_to_Publisher_twice_on_same_endpoint
public void Subscribe_to_Publisher_twice_on_same_endpoint(RedFoxTransport transport)
{
for (var i = 0; i < 2; i++)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
var broadcastedMessage = new TestMessage { Text = "Hello" };
publisher.Broadcast(broadcastedMessage);
}
}
}
示例7: Subscribe_to_Publisher_receive_single_broadcasted_message
public void Subscribe_to_Publisher_receive_single_broadcasted_message(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
Thread.Sleep(100);
var broadcastedMessage = new TestMessage { Text = "Hello" };
publisher.Broadcast(broadcastedMessage);
Assert.AreEqual(broadcastedMessage, subscriber.TestMustReceiveMessageWithin(Timeout));
}
}
示例8: Subscribe_to_Responder_should_cause_protocol_exception
public void Subscribe_to_Responder_should_cause_protocol_exception(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var requester = new Requester())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
try
{
requester.Connect(endpoint);
}
catch (AggregateException ex)
{
throw ex.InnerExceptions.First();
}
}
}
示例9: One_Publisher_Hundred_Subscribers_Single_Broadcasts
public void One_Publisher_Hundred_Subscribers_Single_Broadcasts()
{
using (var publisher = new Publisher())
{
var endpoint = GetEndpoint();
publisher.Bind(endpoint);
var counterSignal = new CounterSignal(NumberOfMessagesToReceive);
var subscribers = Enumerable.Range(1, 100).Select(i =>
{
var sub = new Subscriber();
sub.MessageReceived += (s, m) => counterSignal.Increment();
sub.Connect(endpoint);
return sub;
}).ToList();
Thread.Sleep(100);
var messageSent = new TestMessage();
var sw = Stopwatch.StartNew();
for (var i = 0; i < NumberOfMessagesToReceive / 100; i++)
{
publisher.Broadcast(messageSent);
}
Assert.IsTrue(counterSignal.Wait(TimeOut), "Timeout waiting for message");
sw.Stop();
subscribers.ForEach(sub => sub.Dispose());
Assert.Inconclusive("{0} elapsed reading {1} messages ({2:N0} per second)", sw.Elapsed, NumberOfMessagesToReceive, NumberOfMessagesToReceive / sw.Elapsed.TotalSeconds);
}
}
示例10: using
public void one_subscriber_connects_to_one_publisher_receives_message_then_second_subscriber_connects_both_receive_message(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber1 = new TestSubscriber())
using (var subscriber2 = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
subscriber1.Connect(endpoint);
Thread.Sleep(100);
var broadcastMessage = new TestMessage { Text = "Hello" };
publisher.Broadcast(broadcastMessage);
Assert.AreEqual(broadcastMessage, subscriber1.TestMustReceiveMessageWithin(Timeout));
subscriber2.Connect(endpoint);
Thread.Sleep(100);
publisher.Broadcast(broadcastMessage);
Assert.AreEqual(broadcastMessage, subscriber1.TestMustReceiveMessageWithin(Timeout));
Assert.AreEqual(broadcastMessage, subscriber2.TestMustReceiveMessageWithin(Timeout));
}
}
示例11: Subscriber_IsDisconnected_should_be_true_when_disconnected
public void Subscriber_IsDisconnected_should_be_true_when_disconnected(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
subscriber.Disconnect();
Assert.IsTrue(subscriber.IsDisconnected);
}
}
示例12: Subscriber_Disconnect_doesnt_hang
public void Subscriber_Disconnect_doesnt_hang(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
subscriber.Disconnect(true, Timeout);
}
}
示例13: Publisher_Unbound_Subscriber_Disconnected_event_fires
public void Publisher_Unbound_Subscriber_Disconnected_event_fires(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
var eventFired = new ManualResetEventSlim();
publisher.Bind(endpoint);
subscriber.Disconnected += eventFired.Set;
subscriber.Connect(endpoint);
publisher.Unbind(endpoint);
Assert.IsTrue(eventFired.Wait(Timeout));
Assert.IsTrue(subscriber.IsDisconnected);
}
}
示例14: Subscriber_sends_message_Publisher_receives_message
public void Subscriber_sends_message_Publisher_receives_message(RedFoxTransport transport)
{
using (var publisher = new Publisher())
using (var subscriber = new TestSubscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(transport);
var eventFired = new ManualResetEventSlim();
IMessage messageReceived = null;
ISocket messageSocket = null;
publisher.MessageReceived += (s, m) =>
{
messageSocket = s;
messageReceived = m;
eventFired.Set();
};
ISocket connectedSocket = null;
publisher.ClientConnected += (s, m) => { connectedSocket = s; };
publisher.Bind(endpoint);
subscriber.Connect(endpoint);
IMessage messageSent = new TestMessage("test");
subscriber.SendMessage(messageSent);
Assert.IsTrue(eventFired.Wait(Timeout));
Assert.AreEqual(messageSent, messageReceived);
Assert.AreEqual(connectedSocket, messageSocket);
}
}
示例15: subscriber_should_ignore_ReceiveTimeout_in_socket_configuration_and_must_not_disconnect_on_timeout
public void subscriber_should_ignore_ReceiveTimeout_in_socket_configuration_and_must_not_disconnect_on_timeout()
{
using (var publisher = new Publisher())
using (var subscriber = new Subscriber())
{
var endpoint = TestHelpers.CreateEndpointForTransport(RedFoxTransport.Tcp);
var socketConfiguration = new SocketConfiguration { ReceiveTimeout = TimeSpan.FromMilliseconds(100) };
var disconnected = new ManualResetEventSlim();
publisher.ClientDisconnected += s => disconnected.Set();
publisher.Bind(endpoint);
subscriber.Connect(endpoint, socketConfiguration);
Assert.IsFalse(disconnected.Wait(TimeSpan.FromSeconds(1)));
}
}