7a55bf98b2
This change moves powershell to .NET Core 2.0. Major changes are: 1. PowerShell assemblies are now targeting `netcoreapp2.0`. We are using `microsoft.netcore.app-2.0.0-preview1-001913-00`, which is from dotnet-core build 4/4/17. We cannot target `netstandard2.0` because the packages `System.Reflection.Emit` and `System.Reflection.Emit.Lightweight`, which are needed for powershell class, cannot be referenced when targeting `netstandard2.0`. 2. Refactor code to remove most CLR stub types and extension types. 3. Update build scripts to enable CI builds. The `-cache` section is specified to depend on `appveyor.yml`, so the cache will be invalidated if `appveyor.yml` is changed. 4. Ship `netcoreapp` reference assemblies with powershell to fix the issues in `Add-Type` (#2764). By default `Add-Type` will reference all those reference assemblies when compiling C# code. If `-ReferenceAssembly` is specified, then we search reference assemblies first, then the framework runtime assemblies, and lastly the loaded assemblies (possibly a third-party one that was already loaded). 5. `dotnet publish` generates executable on Unix platforms, but doesn't set "x" permission and thus it cannot execute. Currently, the "x" permission is set in the build script, `dotnet/cli` issue [#6286](https://github.com/dotnet/cli/issues/6286) is tracking this. 6. Replace the use of some APIs with the ones that take `SecureString`. 7. osx.10.12 is required to update to `netcoreapp2.0` because `dotnet-cli` 2.0.0-preview only works on osx.10.12. 8. Add dependency to `System.ValueTuple` to work around a ambiguous type identity issue in coreclr. The issue is tracked by `dotnet/corefx` [#17797](https://github.com/dotnet/corefx/issues/17797). When moving to newer version of `netcoreapp2.0`, we need to verify if this dependency is still needed.
94 lines
3.9 KiB
PowerShell
94 lines
3.9 KiB
PowerShell
Describe "Import-Csv DRT Unit Tests" -Tags "CI" {
|
|
BeforeAll {
|
|
$fileToGenerate = Join-Path $TestDrive -ChildPath "importCSVTest.csv"
|
|
$psObject = [pscustomobject]@{ "First" = "1"; "Second" = "2" }
|
|
}
|
|
|
|
It "Test import-csv with a delimiter parameter" {
|
|
$delimiter = ';'
|
|
$psObject | Export-Csv -Path $fileToGenerate -Delimiter $delimiter
|
|
$returnObject = Import-Csv -Path $fileToGenerate -Delimiter $delimiter
|
|
$returnObject.First | Should Be 1
|
|
$returnObject.Second | Should Be 2
|
|
}
|
|
|
|
It "Test import-csv with UseCulture parameter" {
|
|
$psObject | Export-Csv -Path $fileToGenerate -UseCulture
|
|
$returnObject = Import-Csv -Path $fileToGenerate -UseCulture
|
|
$returnObject.First | Should Be 1
|
|
$returnObject.Second | Should Be 2
|
|
}
|
|
}
|
|
|
|
Describe "Import-Csv File Format Tests" -Tags "CI" {
|
|
BeforeAll {
|
|
# The file is w/o header
|
|
$TestImportCsv_NoHeader = Join-Path -Path (Join-Path $PSScriptRoot -ChildPath assets) -ChildPath TestImportCsv_NoHeader.csv
|
|
# The file is with header
|
|
$TestImportCsv_WithHeader = Join-Path -Path (Join-Path $PSScriptRoot -ChildPath assets) -ChildPath TestImportCsv_WithHeader.csv
|
|
# The file is W3C Extended Log File Format
|
|
$TestImportCsv_W3C_ELF = Join-Path -Path (Join-Path $PSScriptRoot -ChildPath assets) -ChildPath TestImportCsv_W3C_ELF.csv
|
|
|
|
$testCSVfiles = $TestImportCsv_NoHeader, $TestImportCsv_WithHeader, $TestImportCsv_W3C_ELF
|
|
$orginalHeader = "Column1","Column2","Column 3"
|
|
$customHeader = "test1","test2","test3"
|
|
}
|
|
# Test set is the same for all file formats
|
|
foreach ($testCsv in $testCSVfiles) {
|
|
$FileName = (dir $testCsv).Name
|
|
Context "Next test file: $FileName" {
|
|
BeforeAll {
|
|
$CustomHeaderParams = @{Header = $customHeader; Delimiter = ","}
|
|
if ($FileName -eq "TestImportCsv_NoHeader.csv") {
|
|
# The file does not have header
|
|
# (w/o Delimiter here we get throw (bug?))
|
|
$HeaderParams = @{Header = $orginalHeader; Delimiter = ","}
|
|
} else {
|
|
# The files have header
|
|
$HeaderParams = @{Delimiter = ","}
|
|
}
|
|
|
|
}
|
|
|
|
It "Should be able to import all fields" {
|
|
$actual = Import-Csv -Path $testCsv @HeaderParams
|
|
$actualfields = $actual[0].psobject.Properties.Name
|
|
$actualfields | Should Be $orginalHeader
|
|
}
|
|
|
|
It "Should be able to import all fields with custom header" {
|
|
$actual = Import-Csv -Path $testCsv @CustomHeaderParams
|
|
$actualfields = $actual[0].psobject.Properties.Name
|
|
$actualfields | Should Be $customHeader
|
|
}
|
|
|
|
It "Should be able to import correct values" {
|
|
$actual = Import-Csv -Path $testCsv @HeaderParams
|
|
$actual.count | Should Be 4
|
|
$actual[0].'Column1' | Should Be "data1"
|
|
$actual[0].'Column2' | Should Be "1"
|
|
$actual[0].'Column 3' | Should Be "A"
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
Describe "Import-Csv #Type Tests" -Tags "CI" {
|
|
BeforeAll {
|
|
$testfile = Join-Path $TestDrive -ChildPath "testfile.csv"
|
|
Remove-Item -Path $testfile -Force -ErrorAction SilentlyContinue
|
|
$processlist = (Get-Process)[0..1]
|
|
$processlist | Export-Csv -Path $testfile -Force
|
|
# Import-Csv add "CSV:" before actual type
|
|
$expectedProcessType = "CSV:System.Diagnostics.Process"
|
|
}
|
|
|
|
It "Test import-csv import Object" {
|
|
$importObjectList = Import-Csv -Path $testfile
|
|
$processlist.Count | Should Be $importObjectList.Count
|
|
|
|
$importType = $importObjectList[0].psobject.TypeNames[0]
|
|
$importType | Should Be $expectedProcessType
|
|
}
|
|
}
|