aboutsummaryrefslogtreecommitdiffstats
path: root/tests/email
diff options
context:
space:
mode:
authorlavigor <lavigor@users.noreply.github.com>2016-06-26 14:29:45 +0300
committerlavigor <lavigor@users.noreply.github.com>2016-06-26 14:29:45 +0300
commit471a773bcf73d95c8c875070de459397292113bd (patch)
treef27f756179a9b872f90e4d1820071a0d502489c7 /tests/email
parent963a03b120ba8262a6a9125c383e7b5a374d4157 (diff)
downloadforums-471a773bcf73d95c8c875070de459397292113bd.tar
forums-471a773bcf73d95c8c875070de459397292113bd.tar.gz
forums-471a773bcf73d95c8c875070de459397292113bd.tar.bz2
forums-471a773bcf73d95c8c875070de459397292113bd.tar.xz
forums-471a773bcf73d95c8c875070de459397292113bd.zip
[ticket/14696] Fix email template test for '0' username
PHPBB3-14696
Diffstat (limited to 'tests/email')
-rw-r--r--tests/email/email_parsing_test.php39
1 files changed, 26 insertions, 13 deletions
diff --git a/tests/email/email_parsing_test.php b/tests/email/email_parsing_test.php
index 8def27c945..4f962c9c29 100644
--- a/tests/email/email_parsing_test.php
+++ b/tests/email/email_parsing_test.php
@@ -19,7 +19,7 @@ class phpbb_email_parsing_test extends phpbb_test_case
public function setUp()
{
- global $phpbb_container, $config, $phpbb_root_path, $phpEx, $request, $user;
+ global $phpbb_container, $config, $phpbb_root_path, $phpEx, $request, $user;
$phpbb_container = new phpbb_mock_container_builder;
@@ -73,7 +73,8 @@ class phpbb_email_parsing_test extends phpbb_test_case
$phpbb_container->set('ext.manager', $extension_manager, phpbb_mock_container_builder::SCOPE_PROTOTYPE);
$context = new \phpbb\template\context();
- $phpbb_container->set('template.twig.extensions.collection', array(new \phpbb\template\twig\extension($context, $user)), phpbb_mock_container_builder::SCOPE_PROTOTYPE);
+ $twig_extension = new \phpbb\template\twig\extension($context, $user);
+ $phpbb_container->set('template.twig.extensions.collection', array($twig_extension), phpbb_mock_container_builder::SCOPE_PROTOTYPE);
$twig = new \phpbb\template\twig\environment(
$config,
@@ -89,13 +90,14 @@ class phpbb_email_parsing_test extends phpbb_test_case
'autoescape' => false,
)
);
+ $twig->addExtension($twig_extension);
$phpbb_container->set('template.twig.lexer', new \phpbb\template\twig\lexer($twig), phpbb_mock_container_builder::SCOPE_PROTOTYPE);
if (!class_exists('messenger'))
{
include($phpbb_root_path . 'includes/functions_messenger.' . $phpEx);
}
-
+
$this->messenger = new \messenger();
$reflection = new ReflectionObject($this->messenger);
@@ -103,9 +105,20 @@ class phpbb_email_parsing_test extends phpbb_test_case
$this->reflection_template_property->setAccessible(true);
}
- public function test_email_parsing()
+ public function email_parsing_data()
+ {
+ return array(
+ array('Author username', 'Any forum', 'The topic title', 'Dear user'),
+ array('0', 'Any forum', 'The topic title', 'Dear user'),
+ );
+ }
+
+ /**
+ * @dataProvider email_parsing_data
+ */
+ public function test_email_parsing($author_name, $forum_name, $topic_title, $username)
{
- global $phpbb_container, $config, $phpbb_root_path, $phpEx, $user, $request;
+ global $config, $phpEx, $user;
$this->messenger->set_addresses($user->data);
@@ -113,10 +126,10 @@ class phpbb_email_parsing_test extends phpbb_test_case
'EMAIL_SIG' => str_replace('<br />', "\n", "-- \n" . htmlspecialchars_decode($config['board_email_sig'])),
'SITENAME' => htmlspecialchars_decode($config['sitename']),
- 'AUTHOR_NAME' => 'Author username',
- 'FORUM_NAME' => 'Any forum',
- 'TOPIC_TITLE' => 'The topic title',
- 'USERNAME' => 'Dear user',
+ 'AUTHOR_NAME' => $author_name,
+ 'FORUM_NAME' => $forum_name,
+ 'TOPIC_TITLE' => $topic_title,
+ 'USERNAME' => $username,
'U_FORUM' => generate_board_url() . "/viewforum.{$phpEx}?f=1",
'U_STOP_WATCHING_FORUM' => generate_board_url() . "/viewforum.{$phpEx}?uid=2&f=1&unwatch=forum",
@@ -126,10 +139,10 @@ class phpbb_email_parsing_test extends phpbb_test_case
$reflection_template = $this->reflection_template_property->getValue($this->messenger);
$msg = trim($reflection_template->assign_display('body'));
- $this->assertContains('Author username', $msg);
- $this->assertContains('Any forum', $msg);
- $this->assertContains('The topic title', $msg);
- $this->assertContains('Dear user', $msg);
+ $this->assertContains($author_name, $msg);
+ $this->assertContains($forum_name, $msg);
+ $this->assertContains($topic_title, $msg);
+ $this->assertContains($username, $msg);
$this->assertContains(htmlspecialchars_decode($config['sitename']), $msg);
$this->assertContains(str_replace('<br />', "\n", "-- \n" . htmlspecialchars_decode($config['board_email_sig'])), $msg);
$this->assertNotContains('EMAIL_SIG', $msg);