AutomationIoC.PowerShell
                             
                            
                                3.0.0-beta1
                            
                        
                    dotnet add package AutomationIoC.PowerShell --version 3.0.0-beta1
NuGet\Install-Package AutomationIoC.PowerShell -Version 3.0.0-beta1
<PackageReference Include="AutomationIoC.PowerShell" Version="3.0.0-beta1" />
<PackageVersion Include="AutomationIoC.PowerShell" Version="3.0.0-beta1" />
<PackageReference Include="AutomationIoC.PowerShell" />
paket add AutomationIoC.PowerShell --version 3.0.0-beta1
#r "nuget: AutomationIoC.PowerShell, 3.0.0-beta1"
#:package AutomationIoC.PowerShell@3.0.0-beta1
#addin nuget:?package=AutomationIoC.PowerShell&version=3.0.0-beta1&prerelease
#tool nuget:?package=AutomationIoC.PowerShell&version=3.0.0-beta1&prerelease
AutomationIoC.PowerShell
PowerShell PSCmdlet SDK utilities for Automation framework development
NuGet Packages
| Package | Description | 
|---|---|
| AutomationIoC.PowerShell | PowerShell PSCmdlet SDK utilities for Automation framework development | 
Documentation
Please visit the AutomationIoC Documentation Site for installation, getting started, and API documentation.
Samples
Please visit and/or download our AutomationIoC.PowerShell Sample Solution to get a more in-depth view of usage.
Requirements
- PowerShell 7.3 or greater
Installation
.NET CLI
dotnet add package AutomationIoC.PowerShell
Development
Add the following to your .csproj file
<PropertyGroup>
    <CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies>
</PropertyGroup>
Add a Startup class
public class Startup : AutomationStartup
{
    // Add any configuration sources or data needed
    public override void Configure(HostBuilderContext hostBuilderContext, IConfigurationBuilder configurationBuilder)
    {
        // AutomationEnvironment class allows retrieving global PowerShell
        // variables during service configuration.
        var environment =
            AutomationEnvironment.GetVariable<string>("AppEnvironment");
        var appSettings = new Dictionary<string, string>()
        {
            ["TestOptionsConfig:TestProperty"] = "This is an example",
            ["AppEnvironment"] = environment
        };
        configurationBuilder.AddInMemoryCollection(appSettings);
    }
    // Configure services/lifetimes
    public override void ConfigureServices(HostBuilderContext hostBuilderContext, IServiceCollection services)
    {
        services.Configure<TestOptions>(Configuration.GetSection("TestOptionsConfig"));
        services.AddTransient<ITestDependencyOne, TestDependencyOne>();
        services.AddTransient<ITestDependencyTwo, TestDependencyTwo>();
        // ...
        // other services, client, etc.
    }
}
Add a PowerShell Command with Dependencies Injected
Synchronous process example
[Cmdlet(VerbsLifecycle.Submit, "Data")]
public class SubmitData : AutomationShell<Startup>
{
    [Parameter(Mandatory = true)]
    public string Id { get; set; }
    [AutomationDependency]
    protected ITestDependencyOne TestDependencyOne { get; set; }
    [AutomationDependency]
    protected ITestDependencyTwo testDependencyTwo { get; set; }
    [AutomationDependency]
    private ILogger<RequestCard> logger { get; set; }
    protected override void ProcessRecord()
    {
        base.ProcessRecord();
        TestDependencyOne.PushTestId(Id);
        TestData testData = testDependencyTwo.GetTestData(Id);
        logger.LogInformation("Auto Generated Data: {Id} - {Name}", Id, testData.Name);
        WriteObject(testData);
    }
}
Asynchronous process example
[Cmdlet(VerbsLifecycle.Submit, "DataAsync")]
public class SubmitDataAsync : AutomationShellAsync<Startup>
{
    [Parameter(Mandatory = true)]
    public string Id { get; set; }
    [AutomationDependency]
    protected ITestDependencyOne TestDependencyOne { get; set; }
    [AutomationDependency]
    protected ITestDependencyTwo testDependencyTwo { get; set; }
    [AutomationDependency]
    private ILogger<RequestCard> logger { get; set; }
    protected override async Task ProcessRecordAsync()
    {
        await TestDependencyOne.PushTestIdAsync(Id);
        TestData testData = await testDependencyTwo.GetTestDataAsync(Id);
        logger.LogInformation("Auto Generated Data: {Id} - {Name}", Id, testData.Name);
        WriteObject(testData);
    }
}
Execution
In PowerShell terminal run the following:
Import-Module <path-to-your-dll>/<your-assembly>.dll -V
You should see your custom commands listed in the verbose output (signaled by -v).
Now you are ready to run your own custom commands!
The following example is based on command name from above:
Submit-Data -id "ThisIsATestId"
See Project - launch.json for a sample on launching your module through VS Code
Resources
- Related Packages
| Package | Description | 
|---|---|
| AutomationIoC.Runtime | Runtime services for AutomationIoC framework | 
| AutomationIoC.CommandLine | Dependency Injection Framework for C# Console Applications | 
| AutomationIoC.PowerShell.Tools | Development tools for running/testing PSCmdlets built with Automation framework | 
| Product | Versions 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 is compatible. 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 is compatible. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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. | 
- 
                                                    .NETStandard 2.1- AutomationIoC.Runtime (>= 3.0.0-beta1)
- PowerShellStandard.Library (>= 5.1.1)
 
- 
                                                    net8.0- AutomationIoC.Runtime (>= 3.0.0-beta1)
- PowerShellStandard.Library (>= 5.1.1)
 
- 
                                                    net9.0- AutomationIoC.Runtime (>= 3.0.0-beta1)
- PowerShellStandard.Library (>= 5.1.1)
 
NuGet packages (1)
Showing the top 1 NuGet packages that depend on AutomationIoC.PowerShell:
| Package | Downloads | 
|---|---|
| AutomationIoC.PowerShell.Tools Development tools for running/testing PSCmdlets built with Automation framework | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 3.0.0-beta1 | 103 | 7/31/2025 | 
| 3.0.0-alpha2 | 292 | 7/26/2025 | 
| 3.0.0-alpha1 | 361 | 7/25/2025 |