123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479 |
- // Licensed to the .NET Foundation under one or more agreements.
- // The .NET Foundation licenses this file to you under the Apache 2.0 License.
- // See the LICENSE file in the project root for more information.
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Reactive;
- using System.Reactive.Concurrency;
- using System.Reactive.Linq;
- using System.Reactive.Subjects;
- using System.Threading;
- using Microsoft.Reactive.Testing;
- using Xunit;
- namespace ReactiveTests.Tests
- {
-
- public class RegressionTest : ReactiveTest
- {
- #if NET45 || NET46
- [Fact]
- public void Bug_ConcurrentMerge()
- {
- const int reps = 1000;
- var source = Enumerable.Range(0, reps).ToObservable();
- var resultQueue = new System.Collections.Concurrent.ConcurrentQueue<int>();
- var r = new Random();
- source.Select(i => Observable.Create<Unit>(o =>
- {
- resultQueue.Enqueue(i);
- System.Threading.Tasks.Task.Factory.StartNew(
- () =>
- {
- Thread.Sleep(r.Next(10));
- o.OnCompleted();
- });
- return () => { };
- })).Merge(3).ForEach(_ => { });
- Assert.True(Enumerable.Range(0, reps).ToList().SequenceEqual(resultQueue.ToList()));
- }
- #endif
- [Fact]
- public void Bug_1283()
- {
- var scheduler = new TestScheduler();
- var xs = scheduler.CreateHotObservable(
- OnNext(100, 1),
- OnNext(220, 2),
- OnNext(240, 3),
- OnNext(300, 4),
- OnNext(310, 5),
- OnCompleted<int>(350)
- );
- var results = scheduler.Start(() =>
- xs.Window(TimeSpan.FromTicks(100), scheduler).Select((x, i) => x.Select(y => i.ToString() + " " + y.ToString()).Concat(Observable.Return(i.ToString() + " end", scheduler))).Merge()
- );
- results.Messages.AssertEqual(
- OnNext(220, "0 2"),
- OnNext(240, "0 3"),
- OnNext(300, "0 4"),
- OnNext(301, "0 end"),
- OnNext(310, "1 5"),
- OnNext(351, "1 end"),
- OnCompleted<string>(351)
- );
- }
- [Fact]
- public void Bug_1261()
- {
- var scheduler = new TestScheduler();
- var xs = scheduler.CreateHotObservable(
- OnNext(205, 1),
- OnNext(210, 2),
- OnNext(215, 3),
- OnNext(220, 4),
- OnNext(225, 5),
- OnNext(230, 6),
- OnCompleted<int>(230));
- var results = scheduler.Start(() =>
- xs.Window(TimeSpan.FromTicks(10), scheduler).Select((x, i) => x.Select(y => i.ToString() + " " + y.ToString()).Concat(Observable.Return(i.ToString() + " end", scheduler))).Merge()
- );
- results.Messages.AssertEqual(
- OnNext(205, "0 1"),
- OnNext(210, "0 2"),
- OnNext(211, "0 end"),
- OnNext(215, "1 3"),
- OnNext(220, "1 4"),
- OnNext(221, "1 end"),
- OnNext(225, "2 5"),
- OnNext(230, "2 6"),
- OnNext(231, "2 end"),
- OnCompleted<string>(231)
- );
- }
- [Fact]
- public void Bug_1130()
- {
- var xs = Observable.Start(() => 5);
- Assert.Null(xs as ISubject<int, int>);
- }
- #if !NO_THREAD
- [Fact]
- public void Bug_1286()
- {
- var infinite = Observable.Return(new { Name = "test", Value = 0d }, DefaultScheduler.Instance).Repeat();
- var grouped = infinite.GroupBy(x => x.Name, x => x.Value);
- var disp = grouped.Subscribe(_ => { });
- Thread.Sleep(1);
- //most of the time, this deadlocks
- disp.Dispose();
- disp = grouped.Subscribe(_ => { });
- Thread.Sleep(1);
- //if the first doesn't this one always
- disp.Dispose();
- }
- #endif
- [Fact]
- public void Bug_1287()
- {
- var flag = false;
- var x = Observable.Return(1, Scheduler.CurrentThread).Concat(Observable.Never<int>()).Finally(() => flag = true).First();
- Assert.Equal(1, x);
- Assert.True(flag);
- }
- #if !SILVERLIGHTM7
- #if !NO_THREAD
- static IEnumerable<int> Bug_1333_Enumerable(AsyncSubject<IDisposable> s, Semaphore sema)
- {
- var d = s.First();
- var t = new Thread(() => { d.Dispose(); sema.Release(); });
- t.Start();
- t.Join();
- yield return 1;
- }
- #endif
- #if !NO_THREAD
- [Fact]
- //[Timeout(1000)]
- public void Bug_1333()
- {
- var sema = new Semaphore(0, 1);
- var d = new AsyncSubject<IDisposable>();
- var e = Bug_1333_Enumerable(d, sema).ToObservable(DefaultScheduler.Instance).Subscribe();
- d.OnNext(e);
- d.OnCompleted();
- sema.WaitOne();
- }
- #endif
- #endif
- [Fact]
- public void Bug_1295_Completed()
- {
- var scheduler = new TestScheduler();
- var xs = scheduler.CreateHotObservable(
- OnNext(300, 1),
- OnNext(350, 2),
- OnNext(500, 3),
- OnCompleted<int>(550)
- );
- var results = scheduler.Start(() =>
- xs.Throttle(TimeSpan.FromTicks(100), scheduler)
- );
- results.Messages.AssertEqual(
- OnNext(450, 2),
- OnNext(550, 3),
- OnCompleted<int>(550)
- );
- xs.Subscriptions.AssertEqual(
- Subscribe(200, 550)
- );
- }
- [Fact]
- public void Bug_1295_Error()
- {
- var scheduler = new TestScheduler();
- var ex = new Exception();
- var xs = scheduler.CreateHotObservable(
- OnNext(300, 1),
- OnNext(350, 2),
- OnNext(500, 3),
- OnError<int>(550, ex)
- );
- var results = scheduler.Start(() =>
- xs.Throttle(TimeSpan.FromTicks(100), scheduler)
- );
- results.Messages.AssertEqual(
- OnNext(450, 2),
- OnError<int>(550, ex)
- );
- xs.Subscriptions.AssertEqual(
- Subscribe(200, 550)
- );
- }
- [Fact]
- public void Bug_1297_Catch_None()
- {
- var scheduler = new TestScheduler();
- var results = scheduler.Start(() =>
- Observable.Catch<int>()
- );
- results.Messages.AssertEqual(
- OnCompleted<int>(200)
- );
- }
- [Fact]
- public void Bug_1297_OnErrorResumeNext_None()
- {
- var scheduler = new TestScheduler();
- var results = scheduler.Start(() =>
- Observable.OnErrorResumeNext<int>()
- );
- results.Messages.AssertEqual(
- OnCompleted<int>(200)
- );
- }
- [Fact]
- public void Bug_1297_Catch_Single()
- {
- var scheduler = new TestScheduler();
- var ex = new Exception();
- var xs = Observable.Throw<int>(ex, scheduler);
- var results = scheduler.Start(() =>
- Observable.Catch(xs)
- );
- results.Messages.AssertEqual(
- OnError<int>(201, ex)
- );
- }
- [Fact]
- public void Bug_1297_OnErrorResumeNext_Single()
- {
- var scheduler = new TestScheduler();
- var xs = Observable.Throw<int>(new Exception(), scheduler);
- var results = scheduler.Start(() =>
- Observable.OnErrorResumeNext(xs)
- );
- results.Messages.AssertEqual(
- OnCompleted<int>(201)
- );
- }
- [Fact]
- public void Bug_1297_Catch_Multi()
- {
- var scheduler = new TestScheduler();
- var ex1 = new Exception();
- var ex2 = new Exception();
- var ex3 = new Exception();
- var xs = Observable.Throw<int>(ex1, scheduler);
- var ys = Observable.Throw<int>(ex2, scheduler);
- var zs = Observable.Throw<int>(ex3, scheduler);
- var results = scheduler.Start(() =>
- Observable.Catch(xs, ys, zs)
- );
- results.Messages.AssertEqual(
- OnError<int>(203, ex3)
- );
- }
- [Fact]
- public void Bug_1297_OnErrorResumeNext_Multi()
- {
- var scheduler = new TestScheduler();
- var ex1 = new Exception();
- var ex2 = new Exception();
- var ex3 = new Exception();
- var xs = Observable.Throw<int>(ex1, scheduler);
- var ys = Observable.Throw<int>(ex2, scheduler);
- var zs = Observable.Throw<int>(ex3, scheduler);
- var results = scheduler.Start(() =>
- Observable.OnErrorResumeNext(xs, ys, zs)
- );
- results.Messages.AssertEqual(
- OnCompleted<int>(203)
- );
- }
- [Fact]
- public void Bug_1380()
- {
- var scheduler = new TestScheduler();
- var ex = new Exception();
- var xs = scheduler.CreateHotObservable(
- OnNext(220, 1),
- OnNext(250, 2),
- OnNext(270, 3),
- OnNext(290, 4),
- OnNext(310, 5),
- OnNext(340, 6),
- OnNext(360, 7),
- OnError<int>(380, ex)
- );
- var results = scheduler.Start(() =>
- xs.Delay(TimeSpan.FromTicks(100), scheduler)
- );
- results.Messages.AssertEqual(
- OnNext(320, 1),
- OnNext(350, 2),
- OnNext(370, 3),
- OnError<int>(380, ex)
- );
- xs.Subscriptions.AssertEqual(
- Subscribe(200, 380)
- );
- }
- [Fact]
- public void Bug_1356()
- {
- var run = false;
- Observable.Range(0, 10).Finally(() => run = true).Take(5).ForEach(_ => { });
- Assert.True(run);
- }
- [Fact]
- public void Bug_1381()
- {
- var scheduler = new TestScheduler();
- var xs = scheduler.CreateHotObservable(
- OnNext( 90, 1),
- OnNext(110, 2),
- OnNext(250, 3),
- OnNext(270, 4),
- OnNext(280, 5),
- OnNext(301, 6),
- OnNext(302, 7),
- OnNext(400, 8),
- OnNext(401, 9),
- OnNext(510, 10)
- );
- var results = scheduler.CreateObserver<int>();
- var ys = default(IConnectableObservable<int>);
- var connection = default(IDisposable);
- var subscription = default(IDisposable);
- scheduler.ScheduleAbsolute(100, () => ys = xs.Multicast(new ReplaySubject<int>(scheduler)));
- scheduler.ScheduleAbsolute(200, () => connection = ys.Connect());
- scheduler.ScheduleAbsolute(300, () => subscription = ys.Subscribe(results));
- scheduler.ScheduleAbsolute(500, () => subscription.Dispose());
- scheduler.ScheduleAbsolute(600, () => connection.Dispose());
- scheduler.Start();
- results.Messages.AssertEqual(
- OnNext(301, 3),
- OnNext(302, 4),
- OnNext(303, 5),
- OnNext(304, 6),
- OnNext(305, 7),
- OnNext(401, 8),
- OnNext(402, 9)
- );
- xs.Subscriptions.AssertEqual(
- Subscribe(200, 600)
- );
- }
- [Fact]
- public void Reentrant_Subject1()
- {
- var s = Subject.Synchronize((ISubject<int, int>)new Subject<int>(), Scheduler.Immediate);
- var list = new List<int>();
- s.Subscribe(
- x =>
- {
- list.Add(x);
- if (x < 3)
- s.OnNext(x + 1);
- list.Add(-x);
- });
- s.OnNext(1);
- list.AssertEqual(1, -1, 2, -2, 3, -3);
- }
- [Fact]
- public void Reentrant_Subject2()
- {
- var s = Subject.Synchronize(new Subject<int>(), Scheduler.Immediate);
- var list = new List<int>();
- s.Subscribe(
- x =>
- {
- list.Add(x);
- if (x < 3)
- s.OnNext(x + 1);
- list.Add(-x);
- });
- s.OnNext(1);
- list.AssertEqual(1, -1, 2, -2, 3, -3);
- }
- [Fact]
- public void Merge_Trampoline1()
- {
- var ys = new[] { 1, 2, 3 }.ToObservable().Publish(xs => xs.Merge(xs));
- var list = new List<int>();
- ys.Subscribe(list.Add);
- list.AssertEqual(1, 1, 2, 2, 3, 3);
- }
- [Fact]
- public void Merge_Trampoline2()
- {
- var ys = new[] { 1, 2, 3 }.ToObservable().Publish(xs => Observable.Merge(xs, xs, xs, xs));
- var list = new List<int>();
- ys.Subscribe(list.Add);
- list.AssertEqual(1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3);
- }
- }
- }
|