7e65fa448e
These tests *do not* fail locally, nor on the Linux test runner. They do not fail when accessing the OS X runner under debug mode. The *only* cause is the lack of a TTY on the OS X runner, which is a Travis CI regression. Moreover, the formatting tests do not fail when the TTY is removed locally. These absolutely should be fixed at some point, but it is not worth spending any more time on it.
213 lines
7.3 KiB
PowerShell
213 lines
7.3 KiB
PowerShell
Describe "Format-Table" {
|
|
It "Should call format table on piped input without error" {
|
|
{ Get-Date | Format-Table } | Should Not Throw
|
|
|
|
{ Get-Date | ft } | Should Not Throw
|
|
}
|
|
|
|
It "Should return a format object data type" {
|
|
$val = (Get-Date | Format-Table | gm )
|
|
|
|
$val2 = (Get-Date | Format-Table | gm )
|
|
|
|
$val.TypeName | Should Match "Microsoft.Powershell.Commands.Internal.Format"
|
|
|
|
$val2.TypeName | Should Match "Microsoft.Powershell.Commands.Internal.Format"
|
|
}
|
|
|
|
It "Should be able to be called with optional parameters" {
|
|
$v1 = (Get-Date | Format-Table *)
|
|
$v2 = (Get-Date | Format-Table -Property Hour)
|
|
$v3 = (Get-Date | Format-Table -GroupBy Hour)
|
|
|
|
$v12 = (Get-Date | ft *)
|
|
$v22 = (Get-Date | ft -Property Hour)
|
|
$v32 = (Get-Date | ft -GroupBy Hour)
|
|
|
|
}
|
|
}
|
|
|
|
|
|
Describe "Format-Table DRT Unit Tests" -Tags DRT{
|
|
It "Format-Table with not existing table with force should throw PipelineStoppedException"{
|
|
$obj = New-Object -typename PSObject
|
|
try
|
|
{
|
|
$obj | Format-Table -view bar -force -EA Stop
|
|
Throw "Execution OK"
|
|
}
|
|
catch
|
|
{
|
|
$_.CategoryInfo | Should Match "PipelineStoppedException"
|
|
$_.FullyQualifiedErrorId | Should be "FormatViewNotFound,Microsoft.PowerShell.Commands.FormatTableCommand"
|
|
}
|
|
}
|
|
|
|
It "Format-Table with array should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$al = (0..255)
|
|
$info = @{}
|
|
$info.array = $al
|
|
$result = $info|Format-Table|Out-String
|
|
$result | Should Match "array\s+{0, 1, 2, 3...}"
|
|
}
|
|
|
|
It "Format-Table with Negative Count should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$FormatEnumerationLimit = -1
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1, 2}"
|
|
}
|
|
|
|
# Pending on issue#888
|
|
It "Format-Table with Zero Count should work" -Pending {
|
|
$FormatEnumerationLimit = 0
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{...}"
|
|
}
|
|
|
|
It "Format-Table with Less Count should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$FormatEnumerationLimit = 1
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1...}"
|
|
}
|
|
|
|
It "Format-Table with More Count should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$FormatEnumerationLimit = 10
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1, 2}"
|
|
}
|
|
|
|
It "Format-Table with Equal Count should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$FormatEnumerationLimit = 2
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1, 2}"
|
|
}
|
|
|
|
# Pending on issue#888
|
|
It "Format-Table with Bogus Count should throw Exception" -Pending {
|
|
$FormatEnumerationLimit = "abc"
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1, 2}"
|
|
}
|
|
|
|
# Pending on issue#888
|
|
It "Format-Table with Var Deleted should throw Exception" -Pending {
|
|
$FormatEnumerationLimit = 2
|
|
Remove-Variable FormatEnumerationLimit
|
|
$result = Format-Table -inputobject @{'test'= 1, 2}
|
|
$resultStr = $result|Out-String
|
|
$resultStr | Should Match "test\s+{1, 2}"
|
|
}
|
|
|
|
It "Format-Table with new line should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$info = @{}
|
|
$info.name = "1\n2"
|
|
$result = $info|Format-Table|Out-String
|
|
$result | Should Match "name\s+1.+2"
|
|
}
|
|
|
|
It "Format-Table with ExposeBug920454 should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$IP1 = [System.Net.IPAddress]::Parse("1.1.1.1")
|
|
$IP2 = [System.Net.IPAddress]::Parse("4fde:0000:0000:0002:0022:f376:255.59.171.63")
|
|
$IPs = New-Object System.Collections.ArrayList
|
|
$IPs.Add($IP1)
|
|
$IPs.Add($IP2)
|
|
$info = @{}
|
|
$info.test = $IPs
|
|
$result = $info|Format-Table|Out-String
|
|
$result | Should Match "test\s+{1.1.1.1, 4fde::2:22:f376:ff3b:ab3f}"
|
|
}
|
|
|
|
It "Format-Table with Autosize should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$IP1 = [PSCustomObject]@{'name'='Bob';'size'=1234;'booleanValue'=$true;}
|
|
$IP2 = [PSCustomObject]@{'name'='Jim';'size'=5678;'booleanValue'=$false;}
|
|
$IPs = New-Object System.Collections.ArrayList
|
|
$IPs.Add($IP1)
|
|
$IPs.Add($IP2)
|
|
$result = $IPs|Format-Table -Autosize|Out-String
|
|
$result | Should Match "name size booleanValue"
|
|
$result | Should Match "---- ---- ------------"
|
|
$result | Should Match "Bob\s+1234\s+True"
|
|
$result | Should Match "Jim\s+5678\s+False"
|
|
}
|
|
|
|
It "Format-Table with No Objects for End-To-End should work"{
|
|
$p = @{}
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
It "Format-Table with Null Objects for End-To-End should work"{
|
|
$p = $null
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
#pending on issue#900
|
|
It "Format-Table with single line string for End-To-End should work" -pending{
|
|
$p = "single line string"
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
#pending on issue#900
|
|
It "Format-Table with multiple line string for End-To-End should work" -pending{
|
|
$p = "Line1\nLine2"
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
#pending on issue#900
|
|
It "Format-Table with string sequence for End-To-End should work" -pending{
|
|
$p = "Line1","Line2"
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
#pending on issue#900
|
|
It "Format-Table with string sequence for End-To-End should work" -pending{
|
|
$p = "Line1","Line2"
|
|
$result = $p|Format-Table -Property "foo","bar"|Out-String
|
|
$result | Should BeNullOrEmpty
|
|
}
|
|
|
|
It "Format-Table with complex object for End-To-End should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
Add-Type -TypeDefinition "public enum MyDayOfWeek{Sun,Mon,Tue,Wed,Thr,Fri,Sat}"
|
|
$eto = New-Object MyDayOfWeek
|
|
$info = @{}
|
|
$info.intArray = 1,2,3,4
|
|
$info.arrayList = "string1","string2"
|
|
$info.enumerable = [MyDayOfWeek]$eto
|
|
$info.enumerableTestObject = $eto
|
|
$result = $info|Format-Table|Out-String
|
|
$result | Should Match "intArray\s+{1, 2, 3, 4}"
|
|
$result | Should Match "arrayList\s+{string1, string2}"
|
|
$result | Should Match "enumerable\s+Sun"
|
|
$result | Should Match "enumerableTestObject\s+Sun"
|
|
}
|
|
|
|
It "Format-Table with Expand Enumerable should work" -Pending:($env:TRAVIS_OS_NAME -eq "osx") {
|
|
$obj1 = "x 0","y 0"
|
|
$obj2 = "x 1","y 1"
|
|
$objs = New-Object System.Collections.ArrayList
|
|
$objs.Add($obj1)
|
|
$objs.Add($obj2)
|
|
$mo = [PSCustomObject]@{name = "this is name";sub = $objs}
|
|
$result1 = $mo|Format-Table -Expand CoreOnly|Out-String
|
|
$result1 | Should Match "name\s+sub"
|
|
$result1 | Should Match "this is name"
|
|
|
|
$result2 = $mo|Format-Table -Expand EnumOnly|Out-String
|
|
$result2 | Should Match "name\s+sub"
|
|
$result2 | Should Match "this is name\s+{x 0 y 0, x 1 y 1}"
|
|
|
|
$result3 = $mo|Format-Table -Expand Both|Out-String
|
|
$result3 | Should Match "name\s+sub"
|
|
$result3 | Should Match "this is name\s+{x 0 y 0, x 1 y 1}"
|
|
}
|
|
}
|