本文整理汇总了C#中QueueClient.Enqueue方法的典型用法代码示例。如果您正苦于以下问题:C# QueueClient.Enqueue方法的具体用法?C# QueueClient.Enqueue怎么用?C# QueueClient.Enqueue使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类QueueClient
的用法示例。
在下文中一共展示了QueueClient.Enqueue方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: TestHostUnreachableResponseTime
public void TestHostUnreachableResponseTime()
{
RedisServer.Kill();
var stopWatch = new Stopwatch();
try
{
using (var client = new QueueClient())
{
var homemadeTask = new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
};
stopWatch.Start();
client.Enqueue(homemadeTask);
stopWatch.Stop();
}
}
catch (Exception exception)
{
Console.WriteLine("Elapsed time: {0} ms", stopWatch.ElapsedMilliseconds);
Console.WriteLine(exception.ToString());
RedisServer.Start();
Assert.Pass();
}
}
示例2: TestCachingCreatesAFile
public void TestCachingCreatesAFile()
{
using (var client = new QueueClient())
{
var homemadeTask = new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
};
client.Enqueue(homemadeTask);
var retrievedTask = client.Reserve("TestQueue");
Assert.That(File.Exists("redisCache.bin"));
client.Fail(string.Empty);
client.RemoveTask(client.AllTasks("TestQueue")[0]);
}
}
示例3: TestCanEnqueueTaskInRedisAndReadItBack
public void TestCanEnqueueTaskInRedisAndReadItBack()
{
using(var client = new QueueClient())
{
var homemadeTask = new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
};
client.Enqueue(homemadeTask);
var retrievedTask = client.Reserve("TestQueue");
Assert.AreEqual(retrievedTask.Parameters, homemadeTask.Parameters);
Assert.AreEqual(retrievedTask.Queue, homemadeTask.Queue);
client.Fail(string.Empty);
client.RemoveTask(client.AllTasks("TestQueue")[0]);
}
}
示例4: TestHostDifferentPort
public void TestHostDifferentPort()
{
var stopWatch = new Stopwatch();
try
{
using (var client = new QueueClient("localhost", 6377, false))
{
var homemadeTask = new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
};
stopWatch.Start();
client.Enqueue(homemadeTask);
stopWatch.Stop();
}
}
catch (Exception exception)
{
Console.WriteLine("Elapsed time: {0} ms", stopWatch.ElapsedMilliseconds);
Console.WriteLine(exception.ToString());
Assert.Pass();
}
}
示例5: TestModifyTaskOnCollectionThenAssertModificationDoesNotWork
public void TestModifyTaskOnCollectionThenAssertModificationDoesNotWork()
{
using (var client = new QueueClient())
{
// first enqueue a simple task.
client.Enqueue(new TaskMessage
{
Parameters = "Test Params",
Queue = "TestQueue"
});
// now modify the task from within the collection.
client.PendingTasks("TestQueue")[0].Parameters = "Test Params 2";
}
// Dispose of the previous client to ensure modifications dont persist in its memory.
using (var client = new QueueClient())
{
// using a new client, read the task again.
var task = client.PendingTasks("TestQueue")[0];
Assert.AreEqual(task.Parameters, "Test Params");
client.RemoveTask(client.AllTasks("TestQueue")[0]);
}
}
示例6: TestCantReserveMultipleTasksAtOnce
public void TestCantReserveMultipleTasksAtOnce()
{
using (var client = new QueueClient())
{
client.Enqueue(new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
});
client.Enqueue(new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
});
client.Reserve("TestQueue");
Assert.Throws<TaskAlreadyReservedException>(() => client.Reserve("TestQueue"));
client.Fail(string.Empty);
client.RemoveTask(client.AllTasks("TestQueue")[0]);
client.RemoveTask(client.AllTasks("TestQueue")[0]);
}
}
示例7: TestCantEnqueueWithoutSettingAQueueInTheTaskMessage
public void TestCantEnqueueWithoutSettingAQueueInTheTaskMessage()
{
using (var client = new QueueClient())
Assert.Throws<NoQueueSpecifiedException>(
() => client.Enqueue(new TaskMessage { Parameters = "Test" }));
}
示例8: TestThrowsExceptionOnRedisDeath
public void TestThrowsExceptionOnRedisDeath()
{
var client = new QueueClient();
RedisServer.Kill();
Assert.Throws<IOException>(() => client.Enqueue(new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
}));
RedisServer.Start();
}
示例9: TestEnqueueAndDelete100Tasks
public void TestEnqueueAndDelete100Tasks()
{
var client = new QueueClient();
for (var i = 0; i < 100; i++)
{
client.Enqueue(new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
});
}
Assert.AreEqual(client.AllTasks("TestQueue").Count, 100);
var deletedTasks = 0;
while (client.AllTasks("TestQueue").Count > 0)
{
client.RemoveTask(client.AllTasks("TestQueue")[0]);
deletedTasks++;
}
Assert.AreEqual(deletedTasks, 100);
}
示例10: TestCachingCanPreserveTask
public void TestCachingCanPreserveTask()
{
using (var client = new QueueClient())
{
var homemadeTask = new TaskMessage
{
Parameters = "params",
Queue = "TestQueue"
};
client.Enqueue(homemadeTask);
var retrievedTask = client.Reserve("TestQueue");
}
using (var client = new QueueClient())
{
Assert.That(client.CurrentTask != null);
client.Fail(string.Empty);
client.RemoveTask(client.AllTasks("TestQueue")[0]);
}
}
示例11: TestWriteLatencyForDifferentPayloads
public void TestWriteLatencyForDifferentPayloads()
{
var stopWatch = new Stopwatch();
using (var client = new QueueClient())
{
// Small message
var homemadeTask = new TaskMessage
{
Parameters = RandomString(1024),
Queue = "TestQueue"
};
stopWatch.Start();
client.Enqueue(homemadeTask);
stopWatch.Stop();
Console.WriteLine("1K Message write latency (no network included): {0} ms", stopWatch.ElapsedMilliseconds);
// Medium message
homemadeTask = new TaskMessage
{
Parameters = RandomString(1024 * 10),
Queue = "TestQueue"
};
stopWatch.Start();
client.Enqueue(homemadeTask);
stopWatch.Stop();
Console.WriteLine("10K Message write latency (no network included): {0} ms", stopWatch.ElapsedMilliseconds);
// Large message
homemadeTask = new TaskMessage
{
Parameters = RandomString(1024 * 100),
Queue = "TestQueue"
};
stopWatch.Start();
client.Enqueue(homemadeTask);
stopWatch.Stop();
Console.WriteLine("100K Message write latency (no network included): {0} ms", stopWatch.ElapsedMilliseconds);
}
}