mirror of
https://github.com/dfinke/ImportExcel.git
synced 2025-12-06 00:23:20 +00:00
79 lines
2.8 KiB
PowerShell
79 lines
2.8 KiB
PowerShell
#Requires -Modules Pester
|
|
if (-not (Get-command Import-Excel -ErrorAction SilentlyContinue)) {
|
|
Import-Module $PSScriptRoot\..\ImportExcel.psd1
|
|
}
|
|
Describe "Remove Worksheet" {
|
|
Context "Remove a worksheet output" {
|
|
BeforeEach {
|
|
# Create three sheets
|
|
$data = ConvertFrom-Csv @"
|
|
Name,Age
|
|
Jane,10
|
|
John,20
|
|
"@
|
|
$xlFile1 = "TestDrive:\RemoveWorsheet1.xlsx"
|
|
Remove-Item $xlFile1 -ErrorAction SilentlyContinue
|
|
|
|
$data | Export-Excel -Path $xlFile1 -WorksheetName Target1
|
|
$data | Export-Excel -Path $xlFile1 -WorksheetName Target2
|
|
$data | Export-Excel -Path $xlFile1 -WorksheetName Target3
|
|
$data | Export-Excel -Path $xlFile1 -WorksheetName Sheet1
|
|
|
|
$xlFile2 = "TestDrive:\RemoveWorsheet2.xlsx"
|
|
Remove-Item $xlFile2 -ErrorAction SilentlyContinue
|
|
|
|
$data | Export-Excel -Path $xlFile2 -WorksheetName Target1
|
|
$data | Export-Excel -Path $xlFile2 -WorksheetName Target2
|
|
$data | Export-Excel -Path $xlFile2 -WorksheetName Target3
|
|
$data | Export-Excel -Path $xlFile2 -WorksheetName Sheet1
|
|
}
|
|
|
|
it "Should throw about the Path".PadRight(87) {
|
|
{Remove-Worksheet} | Should -Throw 'Remove-Worksheet requires the and Excel file'
|
|
}
|
|
|
|
it "Should delete Target2".PadRight(87) {
|
|
Remove-Worksheet -Path $xlFile1 -WorksheetName Target2
|
|
|
|
$actual = Get-ExcelSheetInfo -Path $xlFile1
|
|
|
|
$actual.Count | Should -Be 3
|
|
$actual[0].Name | Should -Be "Target1"
|
|
$actual[1].Name | Should -Be "Target3"
|
|
$actual[2].Name | Should -Be "Sheet1"
|
|
}
|
|
|
|
it "Should delete Sheet1".PadRight(87) {
|
|
Remove-Worksheet -Path $xlFile1
|
|
|
|
$actual = Get-ExcelSheetInfo -Path $xlFile1
|
|
|
|
$actual.Count | Should -Be 3
|
|
$actual[0].Name | Should -Be "Target1"
|
|
$actual[1].Name | Should -Be "Target2"
|
|
$actual[2].Name | Should -Be "Target3"
|
|
}
|
|
|
|
it "Should delete multiple sheets".PadRight(87) {
|
|
Remove-Worksheet -Path $xlFile1 -WorksheetName Target1, Sheet1
|
|
|
|
$actual = Get-ExcelSheetInfo -Path $xlFile1
|
|
|
|
$actual.Count | Should -Be 2
|
|
$actual[0].Name | Should -Be "Target2"
|
|
$actual[1].Name | Should -Be "Target3"
|
|
}
|
|
|
|
it "Should delete sheet from multiple workbooks".PadRight(87) {
|
|
|
|
Get-ChildItem "TestDrive:\RemoveWorsheet*.xlsx" | Remove-Worksheet
|
|
|
|
$actual = Get-ExcelSheetInfo -Path $xlFile1
|
|
|
|
$actual.Count | Should -Be 3
|
|
$actual[0].Name | Should -Be "Target1"
|
|
$actual[1].Name | Should -Be "Target2"
|
|
$actual[2].Name | Should -Be "Target3"
|
|
}
|
|
}
|
|
} |