قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-22 15:07:44 +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>
118 خطوط
4.3 KiB
PHP
118 خطوط
4.3 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;
|
|
|
|
use Piwik\Option;
|
|
use Piwik\Tests\Framework\TestCase\IntegrationTestCase;
|
|
use Piwik\Updater;
|
|
use Piwik\Tests\Framework\Fixture;
|
|
|
|
/**
|
|
* @group Core
|
|
*/
|
|
class UpdaterTest extends IntegrationTestCase
|
|
{
|
|
public function testDoUpdateReportsAnErrorWhenMissingFilePermissionException()
|
|
{
|
|
$updater = new Updater($pathToCoreUpdates = null, PIWIK_INCLUDE_PATH . '/tests/resources/Updater/%s/');
|
|
$updater->markComponentSuccessfullyUpdated('testpluginUpdates', '0.4');
|
|
$componentsWithUpdateFile = $updater->getComponentsWithUpdateFile(array('testpluginUpdates' => '0.5'));
|
|
|
|
$this->assertEquals(1, count($componentsWithUpdateFile));
|
|
|
|
$result = $updater->updateComponents($componentsWithUpdateFile);
|
|
|
|
$this->assertTrue(count($result['errors']) > 0, 'when an update fails because config file is not writable, we expect the updater to report a critical error');
|
|
$this->assertEquals('make sure this exception is thrown', $result['errors'][0]);
|
|
}
|
|
|
|
|
|
public function testUpdaterChecksCoreVersionAndDetectsUpdateFile()
|
|
{
|
|
$updater = new Updater(PIWIK_INCLUDE_PATH . '/tests/resources/Updater/core/');
|
|
$updater->markComponentSuccessfullyUpdated('core', '0.1');
|
|
$componentsWithUpdateFile = $updater->getComponentsWithUpdateFile(array('core' => '0.3'));
|
|
$this->assertEquals(1, count($componentsWithUpdateFile));
|
|
}
|
|
|
|
public function testUpdaterChecksGivenPluginVersionAndDetectsMultipleUpdateFileInOrder()
|
|
{
|
|
$updater = new Updater($pathToCoreUpdates = null, PIWIK_INCLUDE_PATH . '/tests/resources/Updater/%s/');
|
|
$updater->markComponentSuccessfullyUpdated('testpluginUpdates', '0.1beta');
|
|
$componentsWithUpdateFile = $updater->getComponentsWithUpdateFile(array('testpluginUpdates' => '0.1'));
|
|
|
|
$this->assertEquals(1, count($componentsWithUpdateFile));
|
|
$updateFiles = $componentsWithUpdateFile['testpluginUpdates'];
|
|
$this->assertEquals(2, count($updateFiles));
|
|
|
|
$path = PIWIK_INCLUDE_PATH . '/tests/resources/Updater/testpluginUpdates/';
|
|
$expectedInOrder = array(
|
|
$path . '0.1beta2.php' => '0.1beta2',
|
|
$path . '0.1.php' => '0.1'
|
|
);
|
|
$this->assertEquals($expectedInOrder, array_map("basename", $updateFiles));
|
|
}
|
|
|
|
public function testUpdaterChecksCoreAndPluginCheckThatCoreIsRanFirst()
|
|
{
|
|
$updater = new Updater(
|
|
PIWIK_INCLUDE_PATH . '/tests/resources/Updater/core/',
|
|
PIWIK_INCLUDE_PATH . '/tests/resources/Updater/%s/'
|
|
);
|
|
|
|
$updater->markComponentSuccessfullyUpdated('testpluginUpdates', '0.1beta');
|
|
$updater->markComponentSuccessfullyUpdated('core', '0.1');
|
|
|
|
$componentsWithUpdateFile = $updater->getComponentsWithUpdateFile(array(
|
|
'testpluginUpdates' => '0.1',
|
|
'core' => '0.3'
|
|
));
|
|
$this->assertEquals(2, count($componentsWithUpdateFile));
|
|
reset($componentsWithUpdateFile);
|
|
$this->assertEquals('core', key($componentsWithUpdateFile));
|
|
}
|
|
|
|
public function testUpdateWorksAfterPiwikIsAlreadyUpToDate()
|
|
{
|
|
self::expectNotToPerformAssertions();
|
|
|
|
$result = Fixture::updateDatabase($force = true);
|
|
if ($result === false) {
|
|
throw new \Exception("Failed to force update (nothing to update).");
|
|
}
|
|
}
|
|
|
|
public function testMarkComponentSuccessfullyUpdatedShouldCreateAnOptionEntry()
|
|
{
|
|
$updater = $this->createUpdater();
|
|
$updater->markComponentSuccessfullyUpdated('test_entry', '0.5');
|
|
|
|
$value = Option::get('version_test_entry');
|
|
$this->assertEquals('0.5', $value);
|
|
}
|
|
|
|
/**
|
|
* @depends testMarkComponentSuccessfullyUpdatedShouldCreateAnOptionEntry
|
|
*/
|
|
public function testMarkComponentSuccessfullyUninstalledShouldCreateAnOptionEntry()
|
|
{
|
|
$updater = $this->createUpdater();
|
|
$updater->markComponentSuccessfullyUninstalled('test_entry');
|
|
|
|
$value = Option::get('version_test_entry');
|
|
$this->assertFalse($value);
|
|
}
|
|
|
|
private function createUpdater()
|
|
{
|
|
return new Updater();
|
|
}
|
|
}
|