Test/MSFT_xExchOutlookAnywhere.Integration.Tests.ps1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
###NOTE: This test module requires use of credentials. The first run through of the tests will prompt for credentials from the logged on user.

Import-Module $PSScriptRoot\..\DSCResources\MSFT_xExchOutlookAnywhere\MSFT_xExchOutlookAnywhere.psm1
Import-Module $PSScriptRoot\..\Misc\xExchangeCommon.psm1 -Verbose:0
Import-Module $PSScriptRoot\xExchange.Tests.Common.psm1 -Verbose:0

#Check if Exchange is installed on this machine. If not, we can't run tests
[bool]$exchangeInstalled = IsSetupComplete

if ($exchangeInstalled)
{
    #Get required credentials to use for the test
    if ($Global:ShellCredentials -eq $null)
    {
        [PSCredential]$Global:ShellCredentials = Get-Credential -Message "Enter credentials for connecting a Remote PowerShell session to Exchange"
    }

    #Get the Server FQDN for using in URL's
    if ($Global:ServerFqdn -eq $null)
    {
        $Global:ServerFqdn = [System.Net.Dns]::GetHostByName($env:COMPUTERNAME).HostName
    }

    Describe "Test Setting Properties with xExchOutlookAnywhere" {
        $testParams = @{
            Identity =  "$($env:COMPUTERNAME)\Rpc (Default Web Site)"
            Credential = $Global:ShellCredentials
            ExtendedProtectionFlags = "Proxy","ProxyCoHosting"
            ExtendedProtectionSPNList = @()
            ExtendedProtectionTokenChecking = "Allow"
            ExternalClientAuthenticationMethod = "Ntlm"
            ExternalClientsRequireSsl = $true
            ExternalHostname = $Global:ServerFqdn
            IISAuthenticationMethods = "Basic","Ntlm","Negotiate"
            InternalClientAuthenticationMethod = "Negotiate"
            InternalHostname = $Global:ServerFqdn
            InternalClientsRequireSsl = $true
            SSLOffloading = $false      
        }

        $expectedGetResults = @{
            Identity =  "$($env:COMPUTERNAME)\Rpc (Default Web Site)"
            ExtendedProtectionTokenChecking = "Allow"
            ExternalClientAuthenticationMethod = "Ntlm"
            ExternalClientsRequireSsl = $true
            ExternalHostname = $Global:ServerFqdn
            InternalClientAuthenticationMethod = "Negotiate"
            InternalHostname = $Global:ServerFqdn
            InternalClientsRequireSsl = $true
            SSLOffloading = $false    
        }

        Test-AllTargetResourceFunctions -Params $testParams -ContextLabel "Set standard parameters" -ExpectedGetResults $expectedGetResults
        Test-ArrayContents -TestParams $testParams -DesiredArrayContents $testParams.ExtendedProtectionFlags -GetResultParameterName "ExtendedProtectionFlags" -ContextLabel "Verify ExtendedProtectionFlags" -ItLabel "ExtendedProtectionFlags should contain two values"
        Test-ArrayContents -TestParams $testParams -DesiredArrayContents $testParams.ExtendedProtectionSPNList -GetResultParameterName "ExtendedProtectionSPNList" -ContextLabel "Verify ExtendedProtectionSPNList" -ItLabel "ExtendedProtectionSPNList should be empty"
        Test-ArrayContents -TestParams $testParams -DesiredArrayContents $testParams.IISAuthenticationMethods -GetResultParameterName "IISAuthenticationMethods" -ContextLabel "Verify IISAuthenticationMethods" -ItLabel "IISAuthenticationMethods should contain three values"
    }
}
else
{
    Write-Verbose "Tests in this file require that Exchange is installed to be run."
}