about_Jojoba.help.txt
TOPIC
about_Jojoba SHORT DESCRIPTION Jojoba wraps function internals to run their pipeline inputs in parallel and output in a test format which can be understood by users, other scripts, and PowerShell. It does this by providing a simple template to follow with a few optional keywords. It's useful for fast, simple, and reliable testing and operational validation of large server environments. LONG DESCRIPTION Jojoba can only be used within functions. Those functions need: * A string type pipeline input with a name or alias of InputObject. Don't use an array. * A ValueFromRemainingArguments argument of any name. Switches intended for Jojoba will use the -Jojoba prefix. * Start-Jojoba {} wrapping all code in the process block. * Publish-Jojoba in the end block. Any additional function parameters not sent through the pipeline will be serialized to strings and so should be limited to simple types: ints, strings, string arrays, bools, and switches. EXAMPLE This is the smallest acceptable function. function Test-Template { [CmdletBinding()] param ( [Parameter(Mandatory, ValueFromPipeline)] [string] $InputObject, [Parameter(ValueFromRemainingArguments)] $Jojoba ) begin { } process { Start-Jojoba { } } end { Publish-Jojoba } } EXAMPLE Here is a more complex function. function Test-Computer { [CmdletBinding()] param ( [Parameter(Mandatory, ValueFromPipeline, ValueFromPipelineByPropertyName)] [Alias("InputObject")] [string] $ComputerName, [switch] $VirtualMachine, [int] $RetryCount, [Parameter(ValueFromRemainingArguments)] $RemainingArguments ) begin { } process { Start-Jojoba { # ... if ($VirtualMachine) { Write-JojobaSkip "Test doesn't support virtual machines" } } } end { Publish-Jojoba } } LINKS https://github.com/codykonior/Jojoba |