mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 22:28:51 +00:00
[ticket/11792] Add functional test for var lang_set_ext of core.user_setup
To ensure that the new lang_set_ext variable available with the core.user_setup event works properly, a functional test was added. It overwrites the value of the 'SKIP' language key, which is assumed to remain in use for some time to come. PHPBB3-11792
This commit is contained in:
parent
953ca1785f
commit
e113b46810
3 changed files with 111 additions and 0 deletions
63
tests/functional/extension_global_lang_test.php
Normal file
63
tests/functional/extension_global_lang_test.php
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2013 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group functional
|
||||||
|
*/
|
||||||
|
class phpbb_functional_extension_global_lang_test extends phpbb_functional_test_case
|
||||||
|
{
|
||||||
|
protected $phpbb_extension_manager;
|
||||||
|
|
||||||
|
static private $helper;
|
||||||
|
|
||||||
|
static protected $fixtures = array(
|
||||||
|
'foo/bar/language/en/',
|
||||||
|
'foo/bar/event/',
|
||||||
|
);
|
||||||
|
|
||||||
|
static public function setUpBeforeClass()
|
||||||
|
{
|
||||||
|
parent::setUpBeforeClass();
|
||||||
|
|
||||||
|
self::$helper = new phpbb_test_case_helpers(self);
|
||||||
|
self::$helper->copy_ext_fixtures(dirname(__FILE__) . '/fixtures/ext/', self::$fixtures);
|
||||||
|
}
|
||||||
|
|
||||||
|
static public function tearDownAfterClass()
|
||||||
|
{
|
||||||
|
parent::tearDownAfterClass();
|
||||||
|
|
||||||
|
self::$helper->restore_original_ext_dir();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->get_db();
|
||||||
|
|
||||||
|
$this->phpbb_extension_manager = $this->get_extension_manager();
|
||||||
|
|
||||||
|
$this->purge_cache();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_load_extension_lang_globally()
|
||||||
|
{
|
||||||
|
$this->phpbb_extension_manager->enable('foo/bar');
|
||||||
|
|
||||||
|
// The board index, which should contain an overwritten translation
|
||||||
|
$crawler = self::request('GET', 'index.php');
|
||||||
|
|
||||||
|
// language from language/en/common.php
|
||||||
|
$this->assertNotContains('Skip to content', $crawler->filter('.skiplink')->text());
|
||||||
|
|
||||||
|
// language from ext/foo/bar/language/en/foo_global.php
|
||||||
|
$this->assertContains('Overwritten by foo', $crawler->filter('.skiplink')->text());
|
||||||
|
}
|
||||||
|
}
|
43
tests/functional/fixtures/ext/foo/bar/event/user_setup.php
Normal file
43
tests/functional/fixtures/ext/foo/bar/event/user_setup.php
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2013 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ignore
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (!defined('IN_PHPBB'))
|
||||||
|
{
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Event listener
|
||||||
|
*/
|
||||||
|
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||||
|
|
||||||
|
class phpbb_ext_foo_bar_event_user_setup implements EventSubscriberInterface
|
||||||
|
{
|
||||||
|
static public function getSubscribedEvents()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
'core.user_setup' => 'add_global_translations',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function add_global_translations($event)
|
||||||
|
{
|
||||||
|
$lang_set_ext = $event['lang_set_ext'];
|
||||||
|
$lang_set_ext[] = array(
|
||||||
|
'ext_name' => 'foo/bar',
|
||||||
|
'lang_set' => 'foo_global',
|
||||||
|
);
|
||||||
|
$event['lang_set_ext'] = $lang_set_ext;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
$lang = array_merge($lang, array(
|
||||||
|
'SKIP' => 'Overwritten by foo',
|
||||||
|
));
|
Loading…
Add table
Reference in a new issue