|
| 1 | +#if INTEGRATED_ASYNC |
| 2 | +using FsCheck; |
| 3 | +using FsCheck.Fluent; |
| 4 | +using FsCheck.Xunit; |
| 5 | +using Funcky.Async.Test.TestUtilities; |
| 6 | +using Funcky.Test.TestUtilities; |
| 7 | + |
| 8 | +namespace Funcky.Async.Test; |
| 9 | + |
| 10 | +public sealed class RepeatRangeTest |
| 11 | +{ |
| 12 | + [Fact] |
| 13 | + public async Task RepeatRangeIsEnumeratedLazily() |
| 14 | + { |
| 15 | + var doNotEnumerate = new FailOnEnumerateAsyncSequence<object>(); |
| 16 | + |
| 17 | + await using var repeatRange = AsyncSequence.RepeatRange(doNotEnumerate, 2); |
| 18 | + } |
| 19 | + |
| 20 | + [Fact] |
| 21 | + public async Task RepeatRangeThrowsWhenAlreadyDisposedAsync() |
| 22 | + { |
| 23 | + var repeatRange = AsyncSequence.RepeatRange(AsyncSequence.Return(1337), 5); |
| 24 | + |
| 25 | +#pragma warning disable IDISP016 // we test behaviour after Dispose |
| 26 | +#pragma warning disable IDISP017 // we test behaviour after Dispose |
| 27 | + await repeatRange.DisposeAsync(); |
| 28 | +#pragma warning restore IDISP016 |
| 29 | +#pragma warning restore IDISP017 |
| 30 | + |
| 31 | + await Assert.ThrowsAsync<ObjectDisposedException>(async () => await repeatRange.ToListAsync()); |
| 32 | + } |
| 33 | + |
| 34 | + [Fact] |
| 35 | + public async Task RepeatRangeThrowsWhenAlreadyDisposedEvenIfYouDisposeBetweenMoveNextAsync() |
| 36 | + { |
| 37 | + var list = AsyncSequence.Return(1337, 2, 5); |
| 38 | + |
| 39 | + const int repeats = 5; |
| 40 | + |
| 41 | + foreach (var i in Enumerable.Range(0, await list.CountAsync() * repeats)) |
| 42 | + { |
| 43 | + var repeatRange = AsyncSequence.RepeatRange(list, repeats); |
| 44 | + await using var enumerator = repeatRange.GetAsyncEnumerator(); |
| 45 | + |
| 46 | + Assert.True(await AsyncEnumerable.Range(0, i).AllAsync(async (_, _) => await enumerator.MoveNextAsync())); |
| 47 | + |
| 48 | +#pragma warning disable IDISP016 // we test behaviour after Dispose |
| 49 | +#pragma warning disable IDISP017 // we test behaviour after Dispose |
| 50 | + await repeatRange.DisposeAsync(); |
| 51 | +#pragma warning restore IDISP016 |
| 52 | +#pragma warning restore IDISP017 |
| 53 | + |
| 54 | + await Assert.ThrowsAnyAsync<ObjectDisposedException>(async () => await enumerator.MoveNextAsync()); |
| 55 | + } |
| 56 | + } |
| 57 | + |
| 58 | + [Property] |
| 59 | + public Property TheLengthOfTheGeneratedRepeatRangeIsCorrect(List<int> list, NonNegativeInt count) |
| 60 | + => TheLengthOfTheGeneratedRepeatRangeIsCorrectAsync(list, count.Get) |
| 61 | + .Result |
| 62 | + .ToProperty(); |
| 63 | + |
| 64 | + [Property(Skip = "Tofix")] |
| 65 | + public Property TheSequenceRepeatsTheGivenNumberOfTimes(List<int> list, NonNegativeInt count) |
| 66 | + => TheSequenceRepeatsTheGivenNumberOfTimesAsync(list.ToAsyncEnumerable(), count.Get) |
| 67 | + .Result |
| 68 | + .ToProperty(); |
| 69 | + |
| 70 | + [Fact] |
| 71 | + public async Task RepeatRangeEnumeratesUnderlyingEnumerableOnlyOnceAsync() |
| 72 | + { |
| 73 | + var sequence = Sequence.Return("Test", "Hello", "Do", "Wait"); |
| 74 | + var enumerateOnce = AsyncEnumerateOnce.Create(sequence); |
| 75 | + |
| 76 | + await using var repeatRange = AsyncSequence.RepeatRange(enumerateOnce, 3); |
| 77 | + |
| 78 | + await foreach (var dummy in repeatRange) |
| 79 | + { |
| 80 | + } |
| 81 | + } |
| 82 | + |
| 83 | + private static async Task<bool> TheLengthOfTheGeneratedRepeatRangeIsCorrectAsync(List<int> list, int count) |
| 84 | + { |
| 85 | + await using var repeatRange = AsyncSequence.RepeatRange(list.ToAsyncEnumerable(), count); |
| 86 | + |
| 87 | + var materialized = await repeatRange.ToListAsync(); |
| 88 | + |
| 89 | + return materialized.Count == list.Count * count; |
| 90 | + } |
| 91 | + |
| 92 | + private static async Task<bool> TheSequenceRepeatsTheGivenNumberOfTimesAsync(IAsyncEnumerable<int> asyncEnumerable, int count) |
| 93 | + { |
| 94 | + await using var repeatRange = AsyncSequence.RepeatRange(asyncEnumerable, count); |
| 95 | + |
| 96 | + return await repeatRange |
| 97 | + .IsSequenceRepeating(asyncEnumerable) |
| 98 | + .NTimes(count); |
| 99 | + } |
| 100 | +} |
| 101 | +#endif |
0 commit comments