1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-24 16:07:37 +00:00
Files
matomo/tests/PHPUnit/Integration/Settings/BaseSettingsTestCase.php
Stefan Giehl d6d72d1fa7 [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps (#22144)
* [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>
2024-04-25 20:57:55 +02:00

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;
}
}