Temppus.BatchedAsyncEnumerable 1.0.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package Temppus.BatchedAsyncEnumerable --version 1.0.1                
NuGet\Install-Package Temppus.BatchedAsyncEnumerable -Version 1.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Temppus.BatchedAsyncEnumerable" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Temppus.BatchedAsyncEnumerable --version 1.0.1                
#r "nuget: Temppus.BatchedAsyncEnumerable, 1.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Temppus.BatchedAsyncEnumerable as a Cake Addin
#addin nuget:?package=Temppus.BatchedAsyncEnumerable&version=1.0.1

// Install Temppus.BatchedAsyncEnumerable as a Cake Tool
#tool nuget:?package=Temppus.BatchedAsyncEnumerable&version=1.0.1                

BatchedAsyncEnumerable

Extension method that will transform IAsyncEnumerable<T> to IAsyncEnumerable<T[]> allowing for efficient asynchronous batch processing with one line of code.

Nuget available here.

Motivation:

The IAsyncEnumerable<T> type is powerful, but using it comes with many pitfalls. Creating a batching method for this type revealed more gotchas than expected, given the nature of the async and yield combination. These issues are extremely hard to debug and must be handled carefully to avoid shooting yourself in the foot.

Example usage:


           await foreach (var batch in SomeAsyncEnumerable()
                              .ToBatchedAsyncEnumerable(batchSize: batchSize,
                              batchTimeout: TimeSpan.FromMilliseconds(500),
                              cancellationToken))
           {
               // process your batch
           }

How it works

Given example (Test_Example_Batch_Usage) where we set batchSize to 5 and batchTimeout to 500ms we can see the output od processing.

Start
15:14:49.3935344 - Reading underlying item 1
15:14:49.4089621 - Reading underlying item 2
15:14:49.4244730 - Reading underlying item 3
15:14:49.4399959 - Reading underlying item 4
15:14:49.4554766 - Reading underlying item 5
15:14:49.4567448 - Processing batch of size 5 for 1 second simulated
15:14:49.4709696 - Reading underlying item 6
15:14:49.4865186 - Reading underlying item 7
15:14:49.5017162 - Reading underlying item 8
15:14:49.5169993 - Reading underlying item 9
15:14:49.5326119 - Reading underlying item 10
15:14:49.5481148 - Reading underlying item 11
15:14:50.4572927 - Batch of 5 processed
15:14:50.4578585 - Processing batch of size 5 for 1 second simulated
15:14:50.4723612 - Reading underlying item 12
15:14:51.4594741 - Batch of 5 processed
15:14:51.4596284 - Processing batch of size 2 for 1 second simulated
15:14:52.4623563 - Batch of 2 processed
Done

YOu can see that while we are processing batch next items are being enumerated asynchronously from underlying enumerable to achieve better throughput. Batch will be yielded either when specified batchSize is reached or if batchTimeout elapsed.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.3 119 9/29/2024
1.0.2 91 9/29/2024
1.0.1 92 9/29/2024
1.0.0 91 9/29/2024

Fixed README link.