Skip to content

Instantly share code, notes, and snippets.

@anaisbetts
Created October 5, 2011 04:16
Show Gist options
  • Select an option

  • Save anaisbetts/1263618 to your computer and use it in GitHub Desktop.

Select an option

Save anaisbetts/1263618 to your computer and use it in GitHub Desktop.
namespace GitHub.Tests.Helpers
{
public class ZeroMqRxFixture
{
[Test]
public void ClientServerSmokeTest()
{
string socketAddr = "tcp://localhost:19999";
var server = ZeroMQHost<string>.Create(() =>
{
var socket1 = new Socket(SocketType.REP);
socket1.Bind(socketAddr);
return new[] {socket1};
});
server.SubscribeToSocket(socketAddr)
.Subscribe(x => x.Response.OnNext("***" + x.Value));
var client = ZeroMQHost<string>.Create(() =>
{
var socket2 = new Socket(SocketType.REQ);
socket2.Connect(socketAddr);
return new[] {socket2};
});
string result = null;
IObserver<string> sender = client.SenderForSocket(socketAddr);
client.SubscribeToSocket(socketAddr)
.Subscribe(x => result = x.Value);
sender.OnNext("Hello");
int retries = 10;
while(retries-- > 10 && result == null)
{
Thread.Sleep(1000);
}
Assert.AreEqual("***Hello", result);
}
}
}
@TravisTheTechie
Copy link

Is there a reason not to use a ManualResetEvent instead of sleeping the thread on your own?

client.SubscribeToSocket(socketAddr).Subscribe(x => { result = x.Value; mre.Set(); });

mre.WaitOne(TimeSpan.FromSecond(10));

Assert.AreEqual(...)

Does that feel like cleaner/less work or is it just me?

@anaisbetts
Copy link
Author

anaisbetts commented Oct 5, 2011 via email

@TravisTheTechie
Copy link

Just make sure you dispose of the ManualResetEvent, they leak handles.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment