1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
|
// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.
using System;
using System.Reactive.Concurrency;
using System.Threading;
#if NUNIT
using NUnit.Framework;
using TestClassAttribute = NUnit.Framework.TestFixtureAttribute;
using TestMethodAttribute = NUnit.Framework.TestAttribute;
using TestInitializeAttribute = NUnit.Framework.SetUpAttribute;
#else
using Microsoft.VisualStudio.TestTools.UnitTesting;
#endif
namespace ReactiveTests.Tests
{
[TestClass]
public class ConcurrencyTest
{
[TestMethod]
public void CurrentScheduler_EnsureTrampoline()
{
const int concurrency = 100;
var passed = true;
var s = new Semaphore(0, int.MaxValue);
var e = new ManualResetEvent(false);
for (var i = 0; i < concurrency; ++i)
NewThreadScheduler.Default.Schedule(() =>
{
e.WaitOne();
try
{
if (Scheduler.CurrentThread.ScheduleRequired)
Scheduler.CurrentThread.Schedule(() => { });
else
new Action(() => { })();
}
catch (NullReferenceException)
{
passed = false;
}
finally
{
s.Release();
}
});
e.Set();
for (var i = 0; i < concurrency; ++i)
s.WaitOne();
Assert.IsTrue(passed);
}
[TestMethod]
public void CurrentScheduler_Schedule()
{
const int concurrency = 100;
var passed = true;
var s = new Semaphore(0, int.MaxValue);
var e = new ManualResetEvent(false);
for (var i = 0; i < concurrency; ++i)
NewThreadScheduler.Default.Schedule(() =>
{
e.WaitOne();
try
{
if (Scheduler.CurrentThread.ScheduleRequired)
Scheduler.CurrentThread.Schedule(() => { });
else
new Action(() => { })();
}
catch (NullReferenceException)
{
passed = false;
}
finally
{
s.Release();
}
});
e.Set();
for (var i = 0; i < concurrency; ++i)
s.WaitOne();
Assert.IsTrue(passed);
}
}
}
|