From 60be08e234c3226ccd72c22c776a8d81a1eb3e94 Mon Sep 17 00:00:00 2001 From: Leonard Jonathan Oh Date: Mon, 20 Nov 2023 01:13:28 +0000 Subject: [PATCH] Fix (tests): Ensure interactive configuration uses default values when empty values are passed Related: #175 --- .vscode/tasks.json | 12 +++--------- ConvertOneNote2MarkDown-v2.Tests.ps1 | 15 +++++++++++++-- 2 files changed, 16 insertions(+), 11 deletions(-) diff --git a/.vscode/tasks.json b/.vscode/tasks.json index 9eb0693..4820e75 100644 --- a/.vscode/tasks.json +++ b/.vscode/tasks.json @@ -7,25 +7,19 @@ "label": "Test (pwsh)", "type": "shell", "command": "pwsh -Command test/test.ps1", - "group": { - "isDefault": true, - "kind": "test" - } + "group": "build", }, { "label": "Test (powershell)", "type": "shell", "command": "powershell -Command test/test.ps1", - "group": { - "isDefault": true, - "kind": "test" - } + "group": "build", }, { "label": "Generate config.example.ps1", "type": "shell", "command": "pwsh -Command '. ./ConvertOneNote2MarkDown-v2.ps1 -Exit; New-ConfigurationFile'", - "group": "build" + "group": "build", }, { "label": "Convert", diff --git a/ConvertOneNote2MarkDown-v2.Tests.ps1 b/ConvertOneNote2MarkDown-v2.Tests.ps1 index 0d0f16d..72d1ae7 100644 --- a/ConvertOneNote2MarkDown-v2.Tests.ps1 +++ b/ConvertOneNote2MarkDown-v2.Tests.ps1 @@ -76,10 +76,21 @@ $newlineCharacter = 1 It "Compiles configuration from interactive prompts: cast input as expected type, and fallback on default values on empty input" { $fakeUserInputs = Get-DefaultConfiguration + $fakeUserInputs['dryRun']['value'] = '' # Should fallback on default value $fakeUserInputs['notesdestpath']['value'] = 'c:\foo\bar' # Should be intact - $fakeUserInputs['targetNotebook']['value'] = $null # Should fallback on default value - $fakeUserInputs['usedocx']['value'] = '1' # Should be casted to an int + $fakeUserInputs['targetNotebook']['value'] = '' # Should fallback on default value + $fakeUserInputs['usedocx']['value'] = '0' # Should be casted to an int $fakeUserInputs['keepdocx']['value'] = $null # Should fallback on default value + $fakeUserInputs['docxNamingConvention']['value'] = '' # Should fallback on default value ... + $fakeUserInputs['prefixFolders']['value'] = '' + $fakeUserInputs['mdFileNameAndFolderNameMaxLength']['value'] = '' + $fakeUserInputs['medialocation']['value'] = '' + $fakeUserInputs['conversion']['value'] = '' + $fakeUserInputs['headerTimestampEnabled']['value'] = '' + $fakeUserInputs['keepspaces']['value'] = '' + $fakeUserInputs['keepescape']['value'] = '' + $fakeUserInputs['newlineCharacter']['value'] = '' + $fakeUserInputs['exportPdf']['value'] = '' Mock Test-Path { $false } Mock Read-Host { $typeName = [Microsoft.PowerShell.ToStringCodeMethods]::Type($config[$key]['default'].GetType())