Skip to content

Commit

Permalink
Merge pull request #31 from JimmyLoveSiren/master
Browse files Browse the repository at this point in the history
Fix #30 and add unit test
  • Loading branch information
neuecc authored Sep 20, 2019
2 parents d6a7dd9 + 85eeeb3 commit 50ba93f
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 0 deletions.
34 changes: 34 additions & 0 deletions Assets/Tests/AsyncTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -395,6 +395,40 @@ IEnumerator ChildCoroutineEnumerator()
yield return new WaitForSeconds(3);
}

[UnityTest]
public IEnumerator ToObservable() => UniTask.ToCoroutine(async () =>
{
var completedTaskObserver = new ToObservableObserver<AsyncUnit>();
completedTaskObserver.OnNextCalled.Should().BeFalse();
completedTaskObserver.OnCompletedCalled.Should().BeFalse();
completedTaskObserver.OnErrorCalled.Should().BeFalse();
UniTask.CompletedTask.ToObservable().Subscribe(completedTaskObserver);
completedTaskObserver.OnNextCalled.Should().BeTrue();
completedTaskObserver.OnCompletedCalled.Should().BeTrue();
completedTaskObserver.OnErrorCalled.Should().BeFalse();

var delayFrameTaskObserver = new ToObservableObserver<int>();
UniTask.DelayFrame(1).ToObservable().Subscribe(delayFrameTaskObserver);
delayFrameTaskObserver.OnNextCalled.Should().BeFalse();
delayFrameTaskObserver.OnCompletedCalled.Should().BeFalse();
delayFrameTaskObserver.OnErrorCalled.Should().BeFalse();
await UniTask.DelayFrame(1);
delayFrameTaskObserver.OnNextCalled.Should().BeTrue();
delayFrameTaskObserver.OnCompletedCalled.Should().BeTrue();
delayFrameTaskObserver.OnErrorCalled.Should().BeFalse();
});

class ToObservableObserver<T> : IObserver<T>
{
public bool OnNextCalled { get; private set; }
public bool OnCompletedCalled { get; private set; }
public bool OnErrorCalled { get; private set; }

public void OnNext(T value) => OnNextCalled = true;
public void OnCompleted() => OnCompletedCalled = true;
public void OnError(Exception error) => OnErrorCalled = true;
}

#endif
#endif
}
Expand Down
1 change: 1 addition & 0 deletions Assets/UniRx.Async/UniTaskObservableExtensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,7 @@ public ReturnObservable(T value)
public IDisposable Subscribe(IObserver<T> observer)
{
observer.OnNext(value);
observer.OnCompleted();
return EmptyDisposable.Instance;
}
}
Expand Down

0 comments on commit 50ba93f

Please sign in to comment.