View source
<?php
namespace Drupal\Tests\reroute_email\Functional;
use Drupal\Component\Render\FormattableMarkup;
class DefaultAddressesTest extends RerouteEmailTestBase {
public static $modules = [
'reroute_email',
'dblog',
];
public function setUp() {
$this->permissions[] = 'access site reports';
parent::setUp();
}
public function testRerouteDefaultAddress() {
$site_mail = $this
->config('system.site')
->get('mail');
$this
->assertTrue(isset($site_mail), new FormattableMarkup('Site mail is not empty: @site_mail.', [
'@site_mail' => $site_mail,
]));
$this->rerouteConfig
->set(REROUTE_EMAIL_ENABLE, TRUE)
->save();
$this
->drupalGet('admin/config/development/reroute_email');
$this
->assertFieldChecked('edit-enable', 'Email rerouting was programmatically successfully enabled.');
$this
->assertTrue($this->rerouteConfig
->get(REROUTE_EMAIL_ENABLE), 'Rerouting is enabled.');
$this
->assertFieldByName(REROUTE_EMAIL_ADDRESS, $site_mail, new FormattableMarkup('reroute_email_address default value on form is system.site.mail value: @site_mail.', [
'@site_mail' => $site_mail,
]));
$this
->assertNull($this->rerouteConfig
->get(REROUTE_EMAIL_ADDRESS), 'Reroute email destination address is not configured.');
$this
->drupalPostForm('admin/config/development/reroute_email/test', [
'to' => 'to@example.com',
], 'Send email');
$this
->assertText(t('Test email submitted for delivery from test form.'));
$this
->assert(count($this
->getMails()) === 1, 'Exactly one email captured.');
$this
->verboseEmail();
$this
->assertMail('to', $site_mail, new FormattableMarkup('Email was properly rerouted to site email address: @default_destination.', [
'@default_destination' => $site_mail,
]));
$this
->config('system.site')
->set('mail', NULL)
->save();
$this
->configureRerouteEmail(TRUE, '', '');
$this
->assertTrue($this->rerouteConfig
->get(REROUTE_EMAIL_ADDRESS) === '', 'Reroute email destination address is an empty string.');
$this
->assertTrue($this->rerouteConfig
->get(REROUTE_EMAIL_WHITELIST) === '', 'Whitelisted email address is an empty string.');
\Drupal::state()
->set('system.test_mail_collector', []);
$this
->drupalPostForm('admin/config/development/reroute_email/test', [
'to' => 'to@example.com',
], t('Send email'));
$mails = $this
->getMails();
$mail = end($mails);
$this
->assertTrue(count($mails) == 0, 'Email sending was properly aborted because rerouting email address is an empty string.');
$this
->assertPattern(t('/@message_id.*was aborted by reroute email/', [
'@message_id' => $mail['id'],
]), new FormattableMarkup('Status message displayed as expected to the user with the mail ID <em>(@message_id)</em> and a link to recent log entries.', [
'@message_id' => $mail['id'],
]));
$this
->drupalGet('admin/reports/dblog');
$dblog_link = $this
->xpath('//table[@id="admin-dblog"]/tbody/tr[contains(@class,"dblog-reroute-email")][1]/td[text()="reroute_email"]/following-sibling::td/a[contains(text(),"reroute_email")]');
$link_label = $dblog_link[0]
->getText();
$this
->assertTrue(isset($dblog_link[0]), new FormattableMarkup('Logged a message in dblog: <em>@link</em>.', [
'@link' => $link_label,
]));
$this
->clickLink($link_label);
$this
->assertPattern(t('/Aborted email sending for.*@message_id.*Detailed email data/', [
'@message_id' => $mail['id'],
]), new FormattableMarkup('The dblog entry recorded by Reroute Email contains a dump of the aborted email message <em>@message_id</em> and is formatted as expected.', [
'@message_id' => $mail['id'],
]));
}
}