class Howitzer::MailAdapters::Testmail

This class represents testmail.app mail adapter

Public Class Methods

find(recipient, subject, wait:) click to toggle source

Finds an email in storage @param recipient [String] an email @param subject [String] @param wait [Integer] how much time is required to wait an email @raise [EmailNotFoundError] if blank message

# File lib/howitzer/mail_adapters/testmail.rb, line 15
def self.find(recipient, subject, wait:)
  message = {}
  retryable(find_retry_params(wait)) { message = retrieve_message(recipient, subject) }
  return new(message) if message.present?

  raise Howitzer::EmailNotFoundError,
        "Message with subject '#{subject}' for recipient '#{recipient}' was not found."
end

Private Class Methods

find_retry_params(wait) click to toggle source
# File lib/howitzer/mail_adapters/testmail.rb, line 82
def self.find_retry_params(wait)
  {
    timeout: wait,
    sleep: Howitzer.mail_sleep_time,
    silent: true,
    logger: Howitzer::Log,
    on: Howitzer::EmailNotFoundError
  }
end
retrieve_message(recipient, subject) click to toggle source
# File lib/howitzer/mail_adapters/testmail.rb, line 93
def self.retrieve_message(recipient, subject)
  message = Howitzer::TestmailApi::Client.new.find_message(recipient, subject)
  raise Howitzer::EmailNotFoundError, 'Message not received yet, retry...' unless message

  message
end

Public Instance Methods

html_body() click to toggle source

@return [String] html body of the email message

# File lib/howitzer/mail_adapters/testmail.rb, line 32
def html_body
  message['html']
end
mail_from() click to toggle source

@return [String] an email address specified in ‘From` field

# File lib/howitzer/mail_adapters/testmail.rb, line 44
def mail_from
  message['from']
end
mime_part() click to toggle source

@return [Array] attachments

# File lib/howitzer/mail_adapters/testmail.rb, line 68
def mime_part
  message['attachments']
end
mime_part!() click to toggle source

@raise [NoAttachmentsError] if no attachments present @return [Array] attachments

# File lib/howitzer/mail_adapters/testmail.rb, line 75
def mime_part!
  files = mime_part
  return files if files.present?

  raise Howitzer::NoAttachmentsError, 'No attachments were found.'
end
plain_text_body() click to toggle source

@return [String] plain text body of the email message

# File lib/howitzer/mail_adapters/testmail.rb, line 26
def plain_text_body
  message['text']
end
received_time() click to toggle source

@return [String] when email was received

# File lib/howitzer/mail_adapters/testmail.rb, line 56
def received_time
  Time.parse(message['timestamp']).to_s
end
recipients() click to toggle source

@return [String] recipient emails separated with ‘, `

# File lib/howitzer/mail_adapters/testmail.rb, line 50
def recipients
  message['to'].split ', '
end
sender_email() click to toggle source

@return [String] a real sender email address

# File lib/howitzer/mail_adapters/testmail.rb, line 62
def sender_email
  message['from']
end
text() click to toggle source

@return [String] stripped text

# File lib/howitzer/mail_adapters/testmail.rb, line 38
def text
  message['text']
end