Petabridge.Cmd.Testing 1.0.0

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Petabridge.Cmd.Testing --version 1.0.0                
NuGet\Install-Package Petabridge.Cmd.Testing -Version 1.0.0                
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="Petabridge.Cmd.Testing" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Petabridge.Cmd.Testing --version 1.0.0                
#r "nuget: Petabridge.Cmd.Testing, 1.0.0"                
#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 Petabridge.Cmd.Testing as a Cake Addin
#addin nuget:?package=Petabridge.Cmd.Testing&version=1.0.0

// Install Petabridge.Cmd.Testing as a Cake Tool
#tool nuget:?package=Petabridge.Cmd.Testing&version=1.0.0                

Integration testing tools for validating custom Petabridge.Cmd commands.

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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  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 (3)

Showing the top 3 NuGet packages that depend on Petabridge.Cmd.Testing:

Package Downloads
FAkka.Shared

Package Description

FAkka.Server.Linux

Package Description

FAkka.Shared.Linux

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.4.3 152 6/17/2024
1.4.2 89 6/11/2024
1.4.1 130 3/18/2024
1.4.0 156 1/12/2024
1.3.3 120 1/10/2024
1.3.2 218 7/18/2023
1.3.1 230 5/4/2023
1.3.0 1,184 3/3/2023
1.3.0-beta1 127 3/1/2023
1.2.2 309 1/19/2023
1.2.1 341 12/19/2022
1.2.0 345 11/18/2022
1.1.4 178 7/17/2023
1.1.3 435 10/20/2022
1.1.2 442 9/28/2022
1.1.1 486 9/23/2022
1.1.0 473 6/9/2022
1.0.2 406 11/16/2021
1.0.1 462 8/3/2021
1.0.0 411 7/26/2021
0.8.5 410 5/3/2021
0.8.4 394 4/30/2021
0.8.3 413 3/18/2021
0.8.2 463 11/24/2020
0.8.1 476 11/16/2020
0.8.0 601 3/11/2020
0.8.0-rc2 344 3/10/2020
0.8.0-rc1 357 3/3/2020
0.7.1 554 3/3/2020
0.7.0 627 10/3/2019
0.6.3 717 7/30/2019
0.6.2 609 6/19/2019
0.6.1 679 5/19/2019
0.6.0 655 5/9/2019
0.5.0 665 3/6/2019
0.4.1 764 12/7/2018
0.4.0 798 11/27/2018
0.3.3 1,155 2/27/2018
0.3.2 1,090 12/20/2017
0.3.1 1,027 9/19/2017
0.3.0 979 9/14/2017
0.2.2 991 6/25/2017
0.2.1 972 6/6/2017
0.2.0 991 5/21/2017
0.1.2 996 4/25/2017
0.1.1 966 4/21/2017
0.1.0 959 4/19/2017

Petabridge.Cmd v1.0.0 is a major release of Petabridge.Cmd that doesn't include any breaking changes for older clients.
Programmatic `IPbmClient` Support**
It is now possible to invoke Petabridge.Cmd programmatically, as of Petabridge.Cmd 1.0.0 - and this can be done in one of two ways:
1. In-process, inside the same Akka.NET `ActorSystem` that is running the `PetabridgeCmd` host;
2. Remotely, from an external process that connects to the `PetabridgeCmd` host using the same TCP port used by the `pbm` CLI clients.
We've added [extensive documentation to the Petabridge.Cmd website which documents how to use these new `IPbmClient` implementations](https://cmd.petabridge.com/articles/clients/index.html#ipbmclient-programmatic-client), but we've also included a small example here:
```csharp
// <configureHost>
// create a Petabridge.Cmd host from our ActorSystem
// host is configured to run on port 11555 via HOCON
var pbmHost = PetabridgeCmd.Get(Sys);
// start the host
pbmHost.Start();
// </configureHost>
// <clientActorSystem>
// create client ActorSystem
using ActorSystem clientSystem = ActorSystem.Create("ClientSystem");
// grab copy of the PetabridgeCmdClient extension (Petabridge.Cmd.Common NuGet package)
var clientExt = PetabridgeCmdClient.Get(clientSystem);
// create IpEndPoint or DnsEndPoint for contacting remote host
// either one of these would work
var ip = new IPEndPoint(IPAddress.Loopback, 11555);
var dns = new DnsEndPoint("localhost", 11555);
// start a new IPbmClient attached to one of these EndPoints
// by default this operation will time out in 5 seconds.
// you can extend that by passing in a custom CancellationToken
IPbmClient remoteClient = await clientExt.StartRemoteClient(ip);
// </clientActorSystem>
// <runClient>
// invoke a "log peek" command, just like you would on CLI
CommandSession session = await remoteClient.ExecuteTextCommandAsync("log peek");
// grab a hold of the Akka.Streams materializer from ActorSystem
var materializer = Sys.Materializer();
// pipe the Akka.Streams Source<CommandResponse> to a Sink<CommandResponse>
// in this case, we're just going to send everything to a TestActor.
//
// This Akka.Streams "graph" can be materialized into a Task, which will
// complete once the stream is marked as complete by the Petabridge.Cmd host.
var completionTask = session.Stream.RunForeach(rsp =>
{
TestActor.Tell(rsp);
}, materializer);
// a client can also cancel the stream using the KillSwitch included
// inside the CommandSession object
session.KillSwitch.Shutdown();
// once either of those two events occur, the Task returned earlier
// will be complete
await completionTask;
// and we can validate that the TestActor received at least one CommandResponse
var response = ExpectMsg<CommandResponse>();
// </runClient>
```
Multiple Concurrent Client Sessions**
Another major architectural change we've introduced to Petabridge.Cmd in order to support programmatic clients is the notion of multiple client-facing sessions all originating from the same connection. Petabridge.Cmd now effectively supports command multi-plexing on the server and client side.
In effect, a single `IPbmClient` can now run multiple streaming commands at once - such as `log tail`, `cluster tail`, and `remote tail`, all over the same TCP connection.
This is a minor breaking change to some command palettes - all of the official Petabridge ones will be updated shortly to support this, but user-defined `CommandPalette`s may also need to be updated in order to support this. We will update our "[Creating Custom Commands](https://cmd.petabridge.com/articles/commands/custom-commands.html)" documentation shortly to help developers implement these changes successfully - the changes required are minor.