tests/Test-DbaSqlManagementObject.Tests.ps1

<#
The below statement stays in for every test you build.
#>$CommandName=$MyInvocation.MyCommand.Name.Replace(".Tests.ps1","")Write-Host-Object"Running $PSCommandPath"-ForegroundColorCyan."$PSScriptRoot\constants.ps1"

<#
Unit test is required for any command added
#>Describe"$CommandName Unit Tests"-Tag'UnitTests'{Context"Validate parameters"{<#
The $paramCount is adjusted based on the parameters your command will have.

The $defaultParamCount is adjusted based on what type of command you are writing the test for:
- Commands that *do not* include SupportShouldProcess, set defaultParamCount = 11
- Commands that *do* include SupportShouldProcess, set defaultParamCount = 13
#>$paramCount=4$defaultParamCount=11[object[]]$params=(Get-ChildItemFunction:\Test-DbaSqlManagementObject).Parameters.Keys$knownParameters='ComputerName','Credential','VersionNumber','EnableException'it"Should contain our specific parameters"{((Compare-Object-ReferenceObject$knownParameters-DifferenceObject$params-IncludeEqual|Where-ObjectSideIndicator-eq"==").Count)|ShouldBe$paramCount}it"Should only contain $paramCount parameters"{$params.Count-$defaultParamCount|ShouldBe$paramCount}}}Describe"$CommandName Integration Tests"-Tags"IntegrationTests"{BeforeAll{$versionMajor=(Connect-DbaInstance-SqlInstance$script:instance2).VersionMajor}Context"Command actually works"{$trueResults=Test-DbaSqlManagementObject-ComputerName$script:instance2-VersionNumber$versionMajorIt"Should have correct properties"{$ExpectedProps='ComputerName,Version,Exists'.Split(',')($trueResults[0].PsObject.Properties.Name|Sort-Object)|ShouldBe($ExpectedProps|Sort-Object)}