Test-Expression
SYNOPSIS
Test a PowerShell expression over a period of time.
SYNTAX
Interval (Default)
Test-Expression [-Expression] <ScriptBlock> [-ArgumentList <Object[]>] [-Count <Int32>] [-Interval <Double>]
[-IncludeExpression] [-AsJob] [<CommonParameters>]
Random
Test-Expression [-Expression] <ScriptBlock> [-ArgumentList <Object[]>] [-Count <Int32>] -RandomMinimum <Double>
-RandomMaximum <Double> [-IncludeExpression] [-AsJob] [<CommonParameters>]
DESCRIPTION
This command will test a PowerShell expression or scriptblock for a specified number of times and calculate the average runtime, in milliseconds, over all the tests. The output will also show the median and trimmed values.
The median is calculated by sorting the values in ascending order and selecting the value in the center of the array. If the array has an even number of elements then the median is the average of the two values in the center. The trimmed value will toss out the lowest and highest values and average the remaining values. This may be the most accurate indication as it will eliminate any small values which might come from caching and any large values which may come a temporary shortage of resources. You will only get a value if you run more than 1 test.
EXAMPLES
Example 1
PS C:\> $cred = Get-credential globomantics\administrator
PS C:\> $c = "chi-dc01","chi-dc04"
PS C:\> Test-Expression {
param ([string[]]$computer,$cred)
get-wmiobject win32_logicaldisk -computername $computer -credential $cred
} -argumentList $c,$cred
Tests : 1
TestInterval : 0.5
AverageMS : 1990.6779
MinimumMS : 1990.6779
MaximumMS : 1990.6779
MedianMS : 1990.6779
TrimmedMS :
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
Test a command once passing an argument to the scriptblock. There is no TrimmedMS value because there was only one test.
Example 2
PS C:\> $sb = {1..1000 | Foreach-Object {$_*2}}
PS C:\> Test-Expression $sb -count 10 -interval 2
Tests : 10
TestInterval : 2
AverageMS : 72.78199
MinimumMS : 29.4449
MaximumMS : 110.6553
MedianMS : 90.3509
TrimmedMS : 73.4649625
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
PS C:\> $sb2 = { foreach ($i in (1..1000)) {$_*2}}
PS C:\> Test-Expression $sb2 -Count 10 -interval 2
Tests : 10
TestInterval : 2
AverageMS : 6.40283
MinimumMS : 0.7466
MaximumMS : 22.968
MedianMS : 2.781
TrimmedMS : 5.0392125
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
These examples are testing two different approaches that yield the same results over a span of 10 test runs, pausing for 2 seconds between each test. The values for Average, Minimum, and Maximum are in milliseconds.
Example 3
PS C:\> Test-Expression {
Param([string]$computer)
Get-Service bits,wuauserv,winrm -computername $computer
} -count 5 -IncludeExpression -argumentList chi-hvr2
Tests : 5
TestInterval : 500
AverageMS : 15.53376
MinimumMS : 11.6745
MaximumMS : 24.9331
MedianMS : 13.8928
TrimmedMS : 13.6870666666667
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
Expression : Param([string]$computer) get-service bits,wuauserv,winrm -com...
Arguments : {chi-hvr2}
Include the tested expression in the output.
Example 4
PS C:\> $j=Test-Expression { get-eventlog -list } -count 10 -Interval 5 -AsJob
PS C:\> $j | Receive-Job -keep
Tests : 10
TestInterval : 5
AverageMS : 2.80256
MinimumMS : 0.7967
MaximumMS : 14.911
MedianMS : 1.4469
TrimmedMS : 1.5397375
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
RunspaceId : f30eb879-fe8f-4ad0-8d70-d4c8b6b4eccc
Run the test as a background job. When the job is complete, get the results.
Example 5
PS C:\>{1..1000} | Test-Expression -count 10 -RandomMinimum 1 -RandomMaximum 10
Tests : 10
TestInterval : Random
AverageMS : 0.63899
MinimumMS : 0.2253
MaximumMS : 3.9062
MedianMS : 0.24475
TrimmedMS : 0.2823
PSVersion : 5.1.19041.1
OS : Microsoft Windows 10 Pro
Pipe a scriptblock to be tested.
PARAMETERS
-ArgumentList
An array of parameters to pass to the test scriptblock. Arguments are positional. If passing an array for a value enter with @().
Type: System.Object[]
Parameter Sets: (All)
Aliases:
Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False
-AsJob
Run the tests as a background job.
Type: System.Management.Automation.SwitchParameter
Parameter Sets: (All)
Aliases:
Required: False
Position: Named
Default value: False
Accept pipeline input: False
Accept wildcard characters: False
-Count
The number of times to test the scriptblock.
Type: System.Int32
Parameter Sets: (All)
Aliases:
Required: False
Position: Named
Default value: 1
Accept pipeline input: True (ByPropertyName)
Accept wildcard characters: False
-Expression
The scriptblock you want to test.
Type: System.Management.Automation.ScriptBlock
Parameter Sets: (All)
Aliases: sb
Required: True
Position: 0
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False
-IncludeExpression
Include the test scriptblock in the output.
Type: System.Management.Automation.SwitchParameter
Parameter Sets: (All)
Aliases: ie
Required: False
Position: Named
Default value: False
Accept pipeline input: True (ByPropertyName)
Accept wildcard characters: False
-Interval
How much time to sleep in seconds between each test. The maximum value is 60. You may want to use a sleep interval to mitigate possible caching effects.
Type: System.Double
Parameter Sets: Interval
Aliases: sleep
Required: False
Position: Named
Default value: 0.5
Accept pipeline input: True (ByPropertyName)
Accept wildcard characters: False
-RandomMaximum
You can also specify a random interval by providing random minimum and maximum values in seconds.
Type: System.Double
Parameter Sets: Random
Aliases: max
Required: True
Position: Named
Default value: 0
Accept pipeline input: False
Accept wildcard characters: False
-RandomMinimum
You can also specify a random interval by providing random minimum and maximum values in seconds.
Type: System.Double
Parameter Sets: Random
Aliases: min
Required: True
Position: Named
Default value: 0
Accept pipeline input: False
Accept wildcard characters: False
CommonParameters
This cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.
INPUTS
scriptblock
OUTPUTS
TestResult
NOTES
Learn more about PowerShell: http://jdhitsolutions.com/blog/essential-powershell-resources/ This command was first described at https://github.com/jdhitsolutions/Test-Expression/blob/master/docs/Test-Expression.md)