1
0

NewThreadSchedulerTest.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. // Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.
  2. using System;
  3. using System.Diagnostics;
  4. using System.Reactive.Concurrency;
  5. using System.Reactive.Disposables;
  6. using System.Threading;
  7. using Microsoft.Reactive.Testing;
  8. using Microsoft.VisualStudio.TestTools.UnitTesting;
  9. namespace ReactiveTests.Tests
  10. {
  11. [TestClass]
  12. public class NewThreadSchedulerTest
  13. {
  14. [TestMethod]
  15. public void NewThread_ArgumentChecking()
  16. {
  17. ReactiveAssert.Throws<ArgumentNullException>(() => new NewThreadScheduler(null));
  18. ReactiveAssert.Throws<ArgumentNullException>(() => NewThreadScheduler.Default.Schedule<int>(42, default(Func<IScheduler, int, IDisposable>)));
  19. ReactiveAssert.Throws<ArgumentNullException>(() => NewThreadScheduler.Default.Schedule<int>(42, DateTimeOffset.Now, default(Func<IScheduler, int, IDisposable>)));
  20. ReactiveAssert.Throws<ArgumentNullException>(() => NewThreadScheduler.Default.Schedule<int>(42, TimeSpan.Zero, default(Func<IScheduler, int, IDisposable>)));
  21. ReactiveAssert.Throws<ArgumentNullException>(() => NewThreadScheduler.Default.SchedulePeriodic<int>(42, TimeSpan.FromSeconds(1), default(Func<int, int>)));
  22. ReactiveAssert.Throws<ArgumentNullException>(() => NewThreadScheduler.Default.ScheduleLongRunning<int>(42, default(Action<int, ICancelable>)));
  23. ReactiveAssert.Throws<ArgumentOutOfRangeException>(() => NewThreadScheduler.Default.SchedulePeriodic<int>(42, TimeSpan.FromSeconds(-1), _ => _));
  24. }
  25. [TestMethod]
  26. public void NewThread_Now()
  27. {
  28. var res = NewThreadScheduler.Default.Now - DateTime.Now;
  29. Assert.IsTrue(res.Seconds < 1);
  30. }
  31. [TestMethod]
  32. public void NewThread_ScheduleAction()
  33. {
  34. var id = Thread.CurrentThread.ManagedThreadId;
  35. var nt = NewThreadScheduler.Default;
  36. var evt = new ManualResetEvent(false);
  37. nt.Schedule(() => { Assert.AreNotEqual(id, Thread.CurrentThread.ManagedThreadId); evt.Set(); });
  38. evt.WaitOne();
  39. }
  40. #if !SILVERLIGHT
  41. [TestMethod]
  42. [Ignore]
  43. public void NewThread_ScheduleActionDue()
  44. {
  45. var id = Thread.CurrentThread.ManagedThreadId;
  46. var nt = NewThreadScheduler.Default;
  47. var evt = new ManualResetEvent(false);
  48. var sw = new Stopwatch();
  49. sw.Start();
  50. nt.Schedule(TimeSpan.FromSeconds(0.2), () => { sw.Stop(); Assert.AreNotEqual(id, Thread.CurrentThread.ManagedThreadId); evt.Set(); });
  51. evt.WaitOne();
  52. Assert.IsTrue(sw.ElapsedMilliseconds > 180, "due " + sw.ElapsedMilliseconds);
  53. }
  54. #endif
  55. #if !NO_PERF
  56. #if !NO_STOPWATCH
  57. [TestMethod]
  58. public void Stopwatch()
  59. {
  60. StopwatchTest.Run(NewThreadScheduler.Default);
  61. }
  62. #endif
  63. #endif
  64. [TestMethod]
  65. public void NewThread_Periodic()
  66. {
  67. var n = 0;
  68. var e = new ManualResetEvent(false);
  69. var d = NewThreadScheduler.Default.SchedulePeriodic(TimeSpan.FromMilliseconds(25), () =>
  70. {
  71. if (Interlocked.Increment(ref n) == 10)
  72. e.Set();
  73. });
  74. if (!e.WaitOne(10000))
  75. Assert.Fail();
  76. d.Dispose();
  77. }
  78. [TestMethod]
  79. public void NewThread_Periodic_NonReentrant()
  80. {
  81. var n = 0;
  82. var fail = false;
  83. var d = NewThreadScheduler.Default.SchedulePeriodic(0, TimeSpan.FromMilliseconds(50), x =>
  84. {
  85. try
  86. {
  87. if (Interlocked.Increment(ref n) > 1) // Without an AsyncLock this would fail.
  88. fail = true;
  89. Thread.Sleep(100);
  90. return x + 1;
  91. }
  92. finally
  93. {
  94. Interlocked.Decrement(ref n);
  95. }
  96. });
  97. Thread.Sleep(500);
  98. d.Dispose();
  99. Assert.IsFalse(fail);
  100. }
  101. }
  102. }