tests/Remove-DbaDatabase.Tests.ps1

Write-Host -Object "Running $PSCommandpath" -ForegroundColor Cyan
Describe "Remove-DbaDatabase Integration Tests" -Tags "Integrationtests" {
    Context "Should not munge system databases unless explicitly told to." {
        $script:sql2008 = "localhost\sql2008r2sp2"
        $dbs = @( "master", "model", "tempdb", "msdb" )
        
        It "Should not attempt to remove system databases." {                        
            foreach ($db in $dbs) { 
                $db1 = Get-DbaDatabase -SqlInstance $script:sql2008 -Database $db
                Remove-DbaDatabase -SqlInstance $script:sql2008 -Database $db
                $db2 = Get-DbaDatabase -SqlInstance $script:sql2008 -Database $db
                $db2.Name | Should Be $db1.Name
            } 
        }

        It "Should not take system databases offline or change their status." {
            foreach ($db in $dbs) { 
                $db1 = Get-DbaDatabase -SqlInstance $script:sql2008 -Database $db
                Remove-DbaDatabase -SqlInstance $script:sql2008 -Database $db 
                $db2 = Get-DbaDatabase -SqlInstance $script:sql2008 -Database $db                
                $db2.Status | Should Be $db1.Status
                $db2.IsAccessible | Should Be $db1.IsAccessible                
            } 
        }
    }
    Context "Should remove user databases and return useful errors if it cannot." {
        It "Should remove a non system database." {
            Remove-DbaDatabase -SqlInstance $script:sql2008 -Database singlerestore
            Restore-DbaDatabase -SqlInstance $script:sql2008 -Path C:\github\appveyor-lab\singlerestore\singlerestore.bak
            (Get-DbaDatabase -SqlInstance $script:sql2008 -Database singlerestore).IsAccessible | Should Be $true
            Remove-DbaDatabase -SqlInstance $script:sql2008 -Database singlerestore
            Get-DbaDatabase -SqlInstance $script:sql2008 -Database singlerestore | Should Be $null
        }
    }
}