diff options
Diffstat (limited to 'tests/email/email_parsing_test.php')
| -rw-r--r-- | tests/email/email_parsing_test.php | 150 | 
1 files changed, 150 insertions, 0 deletions
| diff --git a/tests/email/email_parsing_test.php b/tests/email/email_parsing_test.php new file mode 100644 index 0000000000..8fdfe3035e --- /dev/null +++ b/tests/email/email_parsing_test.php @@ -0,0 +1,150 @@ +<?php +/** + * + * This file is part of the phpBB Forum Software package. + * + * @copyright (c) phpBB Limited <https://www.phpbb.com> + * @license GNU General Public License, version 2 (GPL-2.0) + * + * For full copyright and license information, please see + * the docs/CREDITS.txt file. + * + */ + +class phpbb_email_parsing_test extends phpbb_test_case +{ +	/** @var \messenger */ +	protected $messenger; + +	/** @var \ReflectionProperty */ +	protected $reflection_template_property; + +	public function setUp() +	{ +		global $phpbb_container, $config, $phpbb_root_path, $phpEx, $request, $user; + +		$phpbb_container = new phpbb_mock_container_builder; + +		$config = new \phpbb\config\config(array( +			'board_email_sig'     => '-- Thanks, The Management', +			'sitename' 			=> 'yourdomain.com', +			'default_lang'		=> 'en', +		)); +		$phpbb_container->set('config', $config); + +		$request = new phpbb_mock_request; +		$symfony_request = new \phpbb\symfony_request( +			$request +		); +		$filesystem = new \phpbb\filesystem\filesystem(); +		$phpbb_path_helper = new \phpbb\path_helper( +			$symfony_request, +			$filesystem, +			$request, +			$phpbb_root_path, +			$phpEx +		); +		$phpbb_container->set('path_helper', $phpbb_path_helper); +		$phpbb_container->set('filesystem', $filesystem); + +		$cache_path = $phpbb_root_path . 'cache/' . PHPBB_ENVIRONMENT . '/twig'; +		$phpbb_container->setParameter('core.template.cache_path', $cache_path); + +		$lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); +		$lang = new \phpbb\language\language($lang_loader); +		$user = new \phpbb\user($lang, '\phpbb\datetime'); +		$phpbb_container->set('user', $user); +		$extension_manager = new phpbb_mock_extension_manager( +			dirname(__FILE__) . '/', +			array( +				'vendor2/foo' => array( +					'ext_name' => 'vendor2/foo', +					'ext_active' => '1', +					'ext_path' => 'ext/vendor2/foo/', +				), +			) +		); +		$phpbb_container->set('ext.manager', $extension_manager); + +		$context = new \phpbb\template\context(); +		$twig_extension = new \phpbb\template\twig\extension($context, $lang); +		$phpbb_container->set('template.twig.extensions.phpbb', $twig_extension); + +		$twig_extensions_collection = new \phpbb\di\service_collection($phpbb_container); +		$twig_extensions_collection->add('template.twig.extensions.phpbb'); +		$phpbb_container->set('template.twig.extensions.collection', $twig_extensions_collection); + +		$twig = new \phpbb\template\twig\environment( +			$config, +			$filesystem, +			$phpbb_path_helper, +			$cache_path, +			null, +			new \phpbb\template\twig\loader($filesystem, ''), +			new \phpbb\event\dispatcher($phpbb_container), +			array( +				'cache'			=> false, +				'debug'			=> false, +				'auto_reload'	=> true, +				'autoescape'	=> false, +			) +		); +		$twig->addExtension($twig_extension); +		$phpbb_container->set('template.twig.lexer', new \phpbb\template\twig\lexer($twig)); + +		if (!class_exists('messenger')) +		{ +			include($phpbb_root_path . 'includes/functions_messenger.' . $phpEx); +		} + +		$this->messenger = new \messenger(); + +		$reflection = new ReflectionObject($this->messenger); +		$this->reflection_template_property = $reflection->getProperty('template'); +		$this->reflection_template_property->setAccessible(true); +	} + +	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 $config, $phpEx, $user; + +		$this->messenger->set_addresses($user->data); + +		$this->messenger->assign_vars(array( +			'EMAIL_SIG'	=> str_replace('<br />', "\n", "-- \n" . htmlspecialchars_decode($config['board_email_sig'])), +			'SITENAME'	=> htmlspecialchars_decode($config['sitename']), + +			'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", +		)); +		$this->messenger->template('newtopic_notify', $user->data['user_lang'], '', ''); + +		$reflection_template = $this->reflection_template_property->getValue($this->messenger); +		$msg = trim($reflection_template->assign_display('body')); + +		$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); +		$this->assertNotContains('U_STOP_WATCHING_FORUM', $msg); +	} +} | 
