mirror of
https://github.com/phpbb/phpbb.git
synced 2025-10-24 13:16:16 +02:00
160 lines
5.1 KiB
PHP
160 lines
5.1 KiB
PHP
<?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.
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* @group functional
|
|
*/
|
|
class phpbb_functional_posting_test extends phpbb_functional_test_case
|
|
{
|
|
public function test_post_new_topic()
|
|
{
|
|
$this->login();
|
|
|
|
// Test creating topic
|
|
$post = $this->create_topic(2, 'Test Topic 1', 'This is a test topic posted by the testing framework.');
|
|
|
|
$crawler = self::request('GET', "viewtopic.php?t={$post['topic_id']}&sid={$this->sid}");
|
|
$this->assertContains('This is a test topic posted by the testing framework.', $crawler->filter('html')->text());
|
|
|
|
// Test creating a reply with bbcode
|
|
$post2 = $this->create_post(2, $post['topic_id'], 'Re: Test Topic 1', 'This is a test [b]post[/b] posted by the testing framework.');
|
|
|
|
$crawler = self::request('GET', "viewtopic.php?t={$post2['topic_id']}&sid={$this->sid}");
|
|
$this->assertContains('This is a test post posted by the testing framework.', $crawler->filter('html')->text());
|
|
|
|
// Test quoting a message
|
|
$crawler = self::request('GET', "posting.php?mode=quote&f=2&t={$post2['topic_id']}&p={$post2['post_id']}&sid={$this->sid}");
|
|
$this->assertContains('This is a test post posted by the testing framework.', $crawler->filter('html')->text());
|
|
}
|
|
|
|
public function test_unsupported_characters()
|
|
{
|
|
$this->login();
|
|
|
|
$this->add_lang('posting');
|
|
|
|
self::create_post(2,
|
|
1,
|
|
'Unsupported characters',
|
|
"This is a test with these weird characters: \xF0\x9F\x88\xB3 \xF0\x9F\x9A\xB6",
|
|
array(),
|
|
'Your message contains the following unsupported characters'
|
|
);
|
|
|
|
self::create_post(2,
|
|
1,
|
|
"Unsupported: \xF0\x9F\x88\xB3 \xF0\x9F\x9A\xB6",
|
|
'This is a test with emoji characters in the topic title.',
|
|
array(),
|
|
'Your subject contains the following unsupported characters'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @testdox max_quote_depth is applied to the text populating the posting form
|
|
*/
|
|
public function test_quote_depth_form()
|
|
{
|
|
$text = '0[quote]1[quote]2[/quote]1[/quote]0';
|
|
$expected = array(
|
|
0 => '[quote="admin"]0[quote]1[quote]2[/quote]1[/quote]0[/quote]',
|
|
1 => '[quote="admin"]00[/quote]',
|
|
2 => '[quote="admin"]0[quote]11[/quote]0[/quote]',
|
|
3 => '[quote="admin"]0[quote]1[quote]2[/quote]1[/quote]0[/quote]',
|
|
);
|
|
|
|
$this->login();
|
|
$topic = $this->create_topic(2, 'Test Topic 1', 'Test topic');
|
|
$post = $this->create_post(2, $topic['topic_id'], 'Re: Test Topic 1', $text);
|
|
$quote_url = "posting.php?mode=quote&f=2&t={$post['topic_id']}&p={$post['post_id']}&sid={$this->sid}";
|
|
|
|
$this->admin_login();
|
|
foreach ($expected as $quote_depth => $expected_text)
|
|
{
|
|
$this->set_quote_depth($quote_depth);
|
|
$crawler = self::request('GET', $quote_url);
|
|
$this->assertContains($expected_text, $crawler->filter('textarea#message')->text());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @testdox max_quote_depth is applied to the submitted text
|
|
*/
|
|
public function test_quote_depth_submit()
|
|
{
|
|
$text = 'depth:0[quote]depth:1[quote]depth:2[quote]depth:3[/quote][/quote][/quote]';
|
|
$contains = array(
|
|
0 => array('depth:0', 'depth:1', 'depth:2', 'depth:3'),
|
|
1 => array('depth:0', 'depth:1'),
|
|
2 => array('depth:0', 'depth:1', 'depth:2'),
|
|
3 => array('depth:0', 'depth:1', 'depth:2', 'depth:3'),
|
|
);
|
|
$not_contains = array(
|
|
0 => array(),
|
|
1 => array('depth:2', 'depth:3'),
|
|
2 => array('depth:3'),
|
|
3 => array(),
|
|
);
|
|
|
|
$this->login();
|
|
$this->admin_login();
|
|
$topic = $this->create_topic(2, 'Test Topic 1', 'Test topic');
|
|
|
|
for ($quote_depth = 0; $quote_depth <= 2; ++$quote_depth)
|
|
{
|
|
$this->set_quote_depth($quote_depth);
|
|
|
|
$post = $this->create_post(2, $topic['topic_id'], 'Re: Test Topic 1', $text);
|
|
$url = "viewtopic.php?p={$post['post_id']}&sid={$this->sid}";
|
|
|
|
$crawler = self::request('GET', $url);
|
|
$text_content = $crawler->filter('#p' . $post['post_id'])->text();
|
|
foreach ($contains[$quote_depth] as $contains_text)
|
|
{
|
|
$this->assertContains($contains_text, $text_content);
|
|
}
|
|
foreach ($not_contains[$quote_depth] as $not_contains_text)
|
|
{
|
|
$this->assertNotContains($not_contains_text, $text_content);
|
|
}
|
|
}
|
|
}
|
|
|
|
public function test_post_poll()
|
|
{
|
|
$this->login();
|
|
|
|
$post = $this->create_topic(
|
|
2,
|
|
'[ticket/14802] Test Poll Option Spacing',
|
|
'Empty/blank lines should not be additional poll options.',
|
|
array('poll_title' => 'Poll Title', 'poll_option_text' => "\n A \nB\n\nC \n D\nE\n\n \n")
|
|
);
|
|
|
|
$crawler = self::request('GET', "viewtopic.php?t={$post['topic_id']}&sid={$this->sid}");
|
|
$this->assertEquals('Poll Title', $crawler->filter('.poll-title')->text());
|
|
$this->assertEquals(5, $crawler->filter('*[data-poll-option-id]')->count());
|
|
}
|
|
|
|
protected function set_quote_depth($depth)
|
|
{
|
|
$crawler = self::request('GET', 'adm/index.php?sid=' . $this->sid . '&i=acp_board&mode=post');
|
|
$form = $crawler->selectButton('Submit')->form();
|
|
$values = $form->getValues();
|
|
$values['config[max_quote_depth]'] = $depth;
|
|
$form->setValues($values);
|
|
$crawler = self::submit($form);
|
|
$this->assertEquals(1, $crawler->filter('.successbox')->count());
|
|
}
|
|
}
|