قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-24 16:07:37 +00:00

* [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps * [Coding Style] Use camel case for method names in API plugin tests (#22145) * [Coding Style] Use camel case for method names in Core* plugin tests (#22147) * [Coding Style] Use camel case for method names in core Unit tests (#22149) * [Coding Style] Use camel case for method names in Actions and BulkTracking plugin tests (#22146) * [Coding Style] Use camel case for method names in CustomDimensions and CustomJSTracker plugin tests (#22148) * [Coding Style] Use camel case for method names in core Integration tests (#22151) * [Coding Style] Use camel case for method names in more core plugin tests (#22153) * [Coding Style] Use camel case for method names in more core plugin tests (#22157) * [Coding Style] Use camel case for method names in more core plugin tests * Update plugins/Monolog/tests/Unit/Processor/ExceptionToTextProcessorTest.php Co-authored-by: Michal Kleiner <michal@innocraft.com> --------- Co-authored-by: Michal Kleiner <michal@innocraft.com> * [Coding Style] Use camel case for method names in more core plugin tests (#22159) * [Coding Style] Use camel case for method names in remaining tests (#22160) * [Coding Style] Use camel case for method names in remaining tests * rename expected test files --------- Co-authored-by: Michal Kleiner <michal@innocraft.com>
166 خطوط
4.6 KiB
PHP
166 خطوط
4.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Matomo - free/libre analytics platform
|
|
*
|
|
* @link https://matomo.org
|
|
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
|
*/
|
|
|
|
namespace Piwik\Tests\Integration\Settings;
|
|
|
|
use Piwik\Db;
|
|
use Piwik\Piwik;
|
|
use Piwik\Settings\FieldConfig;
|
|
use Piwik\Settings\Setting;
|
|
|
|
/**
|
|
* @group PluginSettings
|
|
* @group SystemSettings
|
|
*/
|
|
class BaseSettingsTestCase extends IntegrationTestCase
|
|
{
|
|
protected $updateEventName;
|
|
|
|
public function testConstructorShouldNotEstablishADatabaseConnection()
|
|
{
|
|
Db::destroyDatabaseObject();
|
|
|
|
$this->assertNotDbConnectionCreated();
|
|
|
|
$this->createSettingsInstance();
|
|
|
|
$this->assertNotDbConnectionCreated();
|
|
}
|
|
|
|
public function testMakeSettingShouldAlsoAddTheSetting()
|
|
{
|
|
$this->assertNull($this->settings->getSetting('myName'));
|
|
|
|
$this->makeSetting('myName');
|
|
|
|
$this->assertNotNull($this->settings->getSetting('myName'));
|
|
}
|
|
|
|
public function testMakeSettingShouldFailWhenAdingSameSettingTwice()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('A setting with name "myName" does already exist for plugin "ExampleSettingsPlugin"');
|
|
|
|
$this->makeSetting('myName');
|
|
$this->makeSetting('myName');
|
|
}
|
|
|
|
public function testGetSettingCanRetrieveAspecificSetting()
|
|
{
|
|
$this->makeSetting('myName');
|
|
|
|
$this->assertSame('myName', $this->settings->getSetting('myName')->getName());
|
|
}
|
|
|
|
public function testGetSettingIsCaseSensitive()
|
|
{
|
|
$this->makeSetting('myName');
|
|
|
|
$this->assertNull($this->settings->getSetting('myname'));
|
|
}
|
|
|
|
public function testGetSettingReturnsNullWhenNoSuchSettingFound()
|
|
{
|
|
$this->assertNull($this->settings->getSetting('myName'));
|
|
}
|
|
|
|
public function testGetSettingsWritableByCurrentUserReturnsOnlySettingsThatAreWritable()
|
|
{
|
|
$this->assertSame(array(), $this->settings->getSettingsWritableByCurrentUser());
|
|
|
|
$setting1 = $this->makeSetting('myName1');
|
|
$setting1->setIsWritableByCurrentUser(true);
|
|
|
|
$setting2 = $this->makeSetting('myName2');
|
|
$setting2->setIsWritableByCurrentUser(false);
|
|
|
|
$setting3 = $this->makeSetting('myName3');
|
|
$setting3->setIsWritableByCurrentUser(true);
|
|
|
|
$expected = array(
|
|
'myName1' => $setting1,
|
|
'myName3' => $setting3
|
|
);
|
|
$this->assertSame($expected, $this->settings->getSettingsWritableByCurrentUser());
|
|
}
|
|
|
|
public function testSaveTriggersAnEvent()
|
|
{
|
|
$settings = null;
|
|
|
|
Piwik::addAction($this->updateEventName, function ($instance) use (&$settings) {
|
|
$settings = $instance;
|
|
});
|
|
|
|
$this->settings->save();
|
|
|
|
$this->assertSame($settings, $this->settings);
|
|
}
|
|
|
|
public function testGetTitleShouldDefaultToPluginName()
|
|
{
|
|
$this->assertNotEmpty($this->settings->getTitle());
|
|
$this->assertSame($this->settings->getTitle(), $this->settings->getPluginName());
|
|
}
|
|
|
|
public function testGetTitlePrefersSetTitleOverPluginName()
|
|
{
|
|
if (method_exists($this->settings, 'setTitle')) {
|
|
$this->settings->setTitle('title');
|
|
$this->assertSame('title', $this->settings->getTitle());
|
|
} else {
|
|
self::expectNotToPerformAssertions();
|
|
}
|
|
}
|
|
|
|
protected function makeSetting($name)
|
|
{
|
|
$type = FieldConfig::TYPE_STRING;
|
|
return $this->settings->makeSetting($name, $default = '', $type, function () {
|
|
});
|
|
}
|
|
|
|
public function testAddSettingShouldAddNewSetting()
|
|
{
|
|
$settingName = 'testSetting';
|
|
$setting = $this->buildSetting($settingName);
|
|
$settings = $this->createSettingsInstance();
|
|
|
|
$this->assertEmpty($settings->getSetting($settingName));
|
|
|
|
$settings->addSetting($setting);
|
|
|
|
$this->assertSame($setting, $settings->getSetting($settingName));
|
|
}
|
|
|
|
public function testAddSettingThrowsExceptionIfSameSettingAddedTwice()
|
|
{
|
|
$this->expectException(\Exception::class);
|
|
$this->expectExceptionMessage('"testSetting" does already exist');
|
|
|
|
$settingName = 'testSetting';
|
|
$setting = $this->buildSetting($settingName);
|
|
$settings = $this->createSettingsInstance();
|
|
|
|
$settings->addSetting($setting);
|
|
$settings->addSetting($setting);
|
|
}
|
|
|
|
private function buildSetting($name, $type = null, $default = '')
|
|
{
|
|
if (!isset($type)) {
|
|
$type = FieldConfig::TYPE_STRING;
|
|
}
|
|
|
|
$userSetting = new Setting($name, $default, $type, 'MyPluginName');
|
|
|
|
return $userSetting;
|
|
}
|
|
}
|