ImapClient.Tests.ps1
using module .\ImapClient.psm1 using module .\DummyTcpClient.psm1 using module .\Utility.psm1 Describe "ImapClient" -Tags "Unit" { It "update tag number on each call" { $client = [DummyTcpClient]::new() $imap = Get-ImapClient -TcpClient $client $tag = $imap.getTagText() $tag | Should be "0000" $response = "0001 OK" $client.responses.Add($response) $imap.ExecuteCommand("dummy") $tag = $imap.getTagText() $tag | Should be "0001" } It "connect socket when Connect is called" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $imap.Connect() $client.logs.Count | Should be 1 $client.logs[0] | Should be "S connected" } It "close socket when Close is called" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $imap.Close() $client.logs.Count | Should be 1 $client.logs[0] | Should be "S closed" } It "execute can skip server log" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $cmd = "do something" $response = "0001 OK" $client.responses.Add($response) $result = $imap.ExecuteCommand($cmd, $false) $result.Success | Should be $true $result.Payload | Should be $response $result.ErrorMessage | Should be "" $client.requests.Count | Should be 1 $client.requests[0] | Should be "0001 $cmd" $client.logs.Count | Should be 1 $client.logs[0] | Should be "C 0001 $cmd" } It "execute to send command to socket and wait for response" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $cmd = "do something" $response = "0001 OK" $client.responses.Add($response) $result = $imap.ExecuteCommand($cmd) $result.Success | Should be $true $result.Payload | Should be $response $result.ErrorMessage | Should be "" $client.requests.Count | Should be 1 $client.requests[0] | Should be "0001 $cmd" $client.logs.Count | Should be 2 $client.logs[0] | Should be "C 0001 $cmd" $client.logs[1] | Should be "S $response" } It "execute fail if the response is not OK" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $cmd = "do something" $response = "0001 No" $client.responses.Add($response) $result = $imap.ExecuteCommand($cmd) $result.Success | Should be $false $result.Payload | Should be $response $result.ErrorMessage | Should be 'IMAP should return "OK" for successful command handling.' $client.requests.Count | Should be 1 $client.requests[0] | Should be "0001 $cmd" $client.logs.Count | Should be 2 $client.logs[0] | Should be "C 0001 $cmd" $client.logs[1] | Should be "S $response" } It "save file by call append command" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $hint = "+ Ready for additional command text." $client.responses.Add($hint) $res = "0001 OK [APPENDUID 17 25] APPEND completed." $client.responses.Add($res) $msg = "A pseudo mail" $result = $imap.SaveEmail("drafts", $msg) $result.Success | Should be $true $result.Payload | Should be $res $result.ErrorMessage | Should be "" $client.requests.Count | Should be 2 $cmd = "0001 APPEND drafts {" + $msg.Length + "}" $client.requests[0] | Should be $cmd $client.requests[1] | Should be $msg $client.logs.Count | Should be 4 $client.logs[0] | Should be "C $cmd" $client.logs[1] | Should be "S $hint" $client.logs[2] | Should be "C $msg" $client.logs[3] | Should be "S $res" } It "fail to save file if return unexpected result" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $hint = "+ Not ready" $client.responses.Add($hint) $res = "0001 OK [APPENDUID 17 25] APPEND completed." $client.responses.Add($res) $msg = "A pseudo mail" $result = $imap.SaveEmail("drafts", $msg) $result.Success | Should be $false $result.Payload | Should be $hint $result.ErrorMessage | Should be 'IMAP should return "+ Ready for additional command text." for append command.' $client.requests.Count | Should be 1 $cmd = "0001 APPEND drafts {" + $msg.Length + "}" $client.requests[0] | Should be $cmd $client.logs.Count | Should be 2 $client.logs[0] | Should be "C $cmd" $client.logs[1] | Should be "S $hint" } It "O365Authenticate with token and upn" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $token = "pseudoToken" $upn = "user@contoso.com" $success = "0001 OK AUTHENTICATE completed." $client.responses.Add($success) $result = $imap.O365Authenticate($token, $upn) $result.Success | Should be $true $utility = Get-Utility $ot = $utility.BuildO365Token($token, $upn) $cmd = "0001 AUTHENTICATE XOAUTH2 $ot" $client.requests.Count | Should be 1 $client.requests[0] | Should be $cmd } It "Login with user and pass" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $pass = "Password12#" $user = "user@contoso.com" $success = "0001 OK Login completed." $client.responses.Add($success) $result = $imap.Login($user, $pass) $result.Success | Should be $true $cmd = "0001 LOGIN $user $pass" $client.requests.Count | Should be 1 $client.requests[0] | Should be $cmd $client.logs.Count | Should be 2 $client.logs[0] | Should be "C 0001 LOGIN $user ****" $client.logs[1] | Should be "S $success" } It "Login with user, targetMailbox and pass" { $client = Get-DummyTcpClient $imap = Get-ImapClient -TcpClient $client $pass = "Password12#" $user = "user@contoso.com" $mailbox = "shared@contoso.com" $success = "0001 OK Login completed." $client.responses.Add($success) $result = $imap.Login($user, $mailbox, $pass) $result.Success | Should be $true $cmd = "0001 LOGIN $user\$mailbox $pass" $client.requests.Count | Should be 1 $client.requests[0] | Should be $cmd $client.logs.Count | Should be 2 $client.logs[0] | Should be "C 0001 LOGIN $user\$mailbox ****" $client.logs[1] | Should be "S $success" } } |