1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 14:51:06 +01:00

Update Mail test adapter for the newer adapter API and make all tests pass

Summary: Depends on D19956. Ref T920. Move the TestAdapter to the new API and adjust a couple of tests for the changes.

Test Plan: All tests now pass.

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T920

Differential Revision: https://secure.phabricator.com/D19957
This commit is contained in:
epriestley 2019-01-04 12:23:52 -08:00
parent a8657e6ab6
commit bc97a7d755
4 changed files with 123 additions and 104 deletions

View file

@ -10,114 +10,124 @@ final class PhabricatorMailTestAdapter
const ADAPTERTYPE = 'test';
private $guts = array();
private $config = array();
private $supportsMessageID;
private $failPermanently;
private $failTemporarily;
public function setSupportsMessageID($support) {
$this->supportsMessageID = $support;
return $this;
}
public function setFailPermanently($fail) {
$this->failPermanently = true;
return $this;
}
public function setFailTemporarily($fail) {
$this->failTemporarily = true;
return $this;
}
public function getSupportedMessageTypes() {
return array(
PhabricatorMailEmailMessage::MESSAGETYPE,
);
}
protected function validateOptions(array $options) {
PhutilTypeSpec::checkMap(
$options,
array());
PhutilTypeSpec::checkMap($options, array());
}
public function newDefaultOptions() {
return array();
}
public function prepareForSend(array $config = array()) {
$this->config = $config;
}
public function setFrom($email, $name = '') {
$this->guts['from'] = $email;
$this->guts['from-name'] = $name;
return $this;
}
public function addReplyTo($email, $name = '') {
if (empty($this->guts['reply-to'])) {
$this->guts['reply-to'] = array();
}
$this->guts['reply-to'][] = array(
'email' => $email,
'name' => $name,
);
return $this;
}
public function addTos(array $emails) {
foreach ($emails as $email) {
$this->guts['tos'][] = $email;
}
return $this;
}
public function addCCs(array $emails) {
foreach ($emails as $email) {
$this->guts['ccs'][] = $email;
}
return $this;
}
public function addAttachment($data, $filename, $mimetype) {
$this->guts['attachments'][] = array(
'data' => $data,
'filename' => $filename,
'mimetype' => $mimetype,
);
return $this;
}
public function addHeader($header_name, $header_value) {
$this->guts['headers'][] = array($header_name, $header_value);
return $this;
}
public function setBody($body) {
$this->guts['body'] = $body;
return $this;
}
public function setHTMLBody($html_body) {
$this->guts['html-body'] = $html_body;
return $this;
}
public function setSubject($subject) {
$this->guts['subject'] = $subject;
return $this;
}
public function supportsMessageIDHeader() {
return idx($this->config, 'supportsMessageIDHeader', true);
}
public function send() {
if (!empty($this->guts['fail-permanently'])) {
throw new PhabricatorMetaMTAPermanentFailureException(
pht('Unit Test (Permanent)'));
}
if (!empty($this->guts['fail-temporarily'])) {
throw new Exception(
pht('Unit Test (Temporary)'));
}
$this->guts['did-send'] = true;
return true;
return $this->supportsMessageID;
}
public function getGuts() {
return $this->guts;
}
public function setFailPermanently($fail) {
$this->guts['fail-permanently'] = $fail;
return $this;
public function sendMessage(PhabricatorMailExternalMessage $message) {
if ($this->failPermanently) {
throw new PhabricatorMetaMTAPermanentFailureException(
pht('Unit Test (Permanent)'));
}
if ($this->failTemporarily) {
throw new Exception(
pht('Unit Test (Temporary)'));
}
$guts = array();
$from = $message->getFromAddress();
$guts['from'] = (string)$from;
$reply_to = $message->getReplyToAddress();
if ($reply_to) {
$guts['reply-to'] = (string)$reply_to;
}
$to_addresses = $message->getToAddresses();
$to = array();
foreach ($to_addresses as $address) {
$to[] = (string)$address;
}
$guts['tos'] = $to;
$cc_addresses = $message->getCCAddresses();
$cc = array();
foreach ($cc_addresses as $address) {
$cc[] = (string)$address;
}
$guts['ccs'] = $cc;
$subject = $message->getSubject();
if (strlen($subject)) {
$guts['subject'] = $subject;
}
$headers = $message->getHeaders();
$header_list = array();
foreach ($headers as $header) {
$header_list[] = array(
$header->getName(),
$header->getValue(),
);
}
$guts['headers'] = $header_list;
$text_body = $message->getTextBody();
if (strlen($text_body)) {
$guts['body'] = $text_body;
}
$html_body = $message->getHTMLBody();
if (strlen($html_body)) {
$guts['html-body'] = $html_body;
}
$attachments = $message->getAttachments();
$file_list = array();
foreach ($attachments as $attachment) {
$file_list[] = array(
'data' => $attachment->getData(),
'filename' => $attachment->getFilename(),
'mimetype' => $attachment->getMimeType(),
);
}
$guts['attachments'] = $file_list;
$guts['did-send'] = true;
$this->guts = $guts;
}
public function setFailTemporarily($fail) {
$this->guts['fail-temporarily'] = $fail;
return $this;
}
public function getBody() {
return idx($this->guts, 'body');
@ -127,4 +137,5 @@ final class PhabricatorMailTestAdapter
return idx($this->guts, 'html-body');
}
}

View file

@ -42,10 +42,10 @@ final class PhabricatorMailReceiverTestCase extends PhabricatorTestCase {
}
public function testReservedAddresses() {
$default_address = id(new PhabricatorMetaMTAMail())
$default_address = id(new PhabricatorMailEmailEngine())
->newDefaultEmailAddress();
$void_address = id(new PhabricatorMetaMTAMail())
$void_address = id(new PhabricatorMailEmailEngine())
->newVoidEmailAddress();
$map = array(

View file

@ -182,21 +182,29 @@ final class PhabricatorMetaMTAMailTestCase extends PhabricatorTestCase {
$supports_message_id,
$is_first_mail) {
$user = $this->generateNewTestUser();
$phid = $user->getPHID();
$mailer = new PhabricatorMailTestAdapter();
$mailer->prepareForSend(
array(
'supportsMessageIDHeader' => $supports_message_id,
));
$mailer->setSupportsMessageID($supports_message_id);
$thread_id = '<somethread-12345@somedomain.tld>';
$thread_id = 'somethread-12345';
$mail = new PhabricatorMetaMTAMail();
$mail->setThreadID($thread_id, $is_first_mail);
$mail->sendWithMailers(array($mailer));
$mail = id(new PhabricatorMetaMTAMail())
->setThreadID($thread_id, $is_first_mail)
->addTos(array($phid))
->sendWithMailers(array($mailer));
$guts = $mailer->getGuts();
$dict = ipull($guts['headers'], 1, 0);
$headers = idx($guts, 'headers', array());
$dict = array();
foreach ($headers as $header) {
list($name, $value) = $header;
$dict[$name] = $value;
}
if ($is_first_mail && $supports_message_id) {
$expect_message_id = true;

View file

@ -93,13 +93,13 @@ final class PhabricatorMailUtil
return true;
}
$default_address = id(new PhabricatorMetaMTAMail())
$default_address = id(new PhabricatorMailEmailEngine())
->newDefaultEmailAddress();
if (self::matchAddresses($address, $default_address)) {
return true;
}
$void_address = id(new PhabricatorMetaMTAMail())
$void_address = id(new PhabricatorMailEmailEngine())
->newVoidEmailAddress();
if (self::matchAddresses($address, $void_address)) {
return true;