PopClient.Tests.ps1

using module .\PopClient.psm1
using module .\DummyTcpClient.psm1
using module .\Utility.psm1

Describe "PopClient" -Tags "Unit" {
  It "connect socket when Connect is called" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $pop.Connect()
    $client.logs.Count | Should be 1
    $client.logs[0] | Should be "S connected"
  }
  It "close socket when Close is called" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $pop.Close()
    $client.logs.Count | Should be 1
    $client.logs[0] | Should be "S closed"
  }
  It "execute to send command to socket and wait for response" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $cmd = "do something"
    $response = "+OK"
    $client.responses.Add($response)
    $result = $pop.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 $cmd
    $client.logs.Count | Should be 2
    $client.logs[0] | Should be "C $cmd"
    $client.logs[1] | Should be "S $response"
  }
  It "execute can skip server log" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $cmd = "do something"
    $response = "+OK"
    $client.responses.Add($response)
    $result = $pop.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 $cmd
    $client.logs.Count | Should be 1
    $client.logs[0] | Should be "C $cmd"
  }
  It "execute fail if the response is not OK" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $cmd = "do something"
    $response = "-ERR"
    $client.responses.Add($response)
    $result = $pop.ExecuteCommand($cmd)
    $result.Success | Should be $false
    $result.Payload | Should be $response
    $result.ErrorMessage | Should be 'POP should return "+" for successful command handling.'
    $client.requests.Count | Should be 1
    $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 $response"
  }
  It "O365Authenticate with token and upn" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $token = "pseudoToken"
    $upn = "user@contoso.com"
    $client.responses.Add("+")
      $success = "+OK User successfully authenticated."
      $client.responses.Add($success)
    $result = $pop.O365Authenticate($token, $upn)
    $result.Success | Should be $true
    $utility = Get-Utility
    $ot = $utility.BuildO365Token($token, $upn)
    $client.requests.Count | Should be 2
    $client.requests[0] | Should be "AUTH XOAUTH2"
      $client.requests[1] | Should be $ot
  }
  It "Login with user and pass" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $pass = "Password12#"
    $user = "user@contoso.com"
    $client.responses.Add("+")
      $success = "+OK User login successfully."
      $client.responses.Add($success)
    $result = $pop.Login($user, $pass)
    $result.Success | Should be $true
    $client.requests.Count | Should be 2
    $client.requests[0] | Should be "USER $user"
    $client.requests[1] | Should be "PASS $pass"
    $client.logs.Count | Should be 4
    $client.logs[0] | Should be "C USER $user"
    $client.logs[1] | Should be "S +"
    $client.logs[2] | Should be "C PASS ****"
    $client.logs[3] | Should be "S $success"
  }
  It "Login with user, targetMailbox and pass" {
    $client = Get-DummyTcpClient
    $pop = Get-PopClient -TcpClient $client
    $pass = "Password12#"
    $user = "user@contoso.com"
    $mailbox = "shared@contoso.com"
    $client.responses.Add("+")
      $success = "+OK User login successfully."
      $client.responses.Add($success)
    $result = $pop.Login($user, $mailbox, $pass)
    $result.Success | Should be $true
    $client.requests.Count | Should be 2
    $client.requests[0] | Should be "USER $user\$mailbox"
    $client.requests[1] | Should be "PASS $pass"
    $client.logs.Count | Should be 4
    $client.logs[0] | Should be "C USER $user\$mailbox"
    $client.logs[1] | Should be "S +"
    $client.logs[2] | Should be "C PASS ****"
    $client.logs[3] | Should be "S $success"
  }
}