قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-22 23:17:46 +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>
81 خطوط
2.1 KiB
PHP
81 خطوط
2.1 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\Updater\Migration\Db;
|
|
|
|
use Piwik\Common;
|
|
use Piwik\Db;
|
|
use Piwik\DbHelper;
|
|
use Piwik\Tests\Framework\TestCase\IntegrationTestCase;
|
|
use Piwik\Updater\Migration\Db\DropColumns;
|
|
|
|
/**
|
|
* @group Core
|
|
* @group Updater
|
|
* @group Migration
|
|
* @group DropColumns
|
|
* @group DropColumnsTest
|
|
*/
|
|
class DropColumnsTest extends IntegrationTestCase
|
|
{
|
|
private $tableName;
|
|
public function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->tableName = 'foobar';
|
|
DbHelper::createTable($this->tableName, 'barbaz VARCHAR(1), foobaz VARCHAR(1), foobaz2 VARCHAR(1)');
|
|
}
|
|
|
|
public function tearDown(): void
|
|
{
|
|
Db::exec('DROP TABLE IF EXISTS ' . Common::prefixTable($this->tableName));
|
|
parent::tearDown();
|
|
}
|
|
|
|
public function testValidAndInvalidColumnsAndDuplicateColumns()
|
|
{
|
|
$sql = $this->dropColumns(array('barbaz', 'notexstis', 'barbaz'));
|
|
|
|
$this->assertQueryWorks($sql, 'ALTER TABLE `foobar` DROP COLUMN `barbaz`;');
|
|
}
|
|
|
|
public function testOnlyInvalidColumns()
|
|
{
|
|
$sql = $this->dropColumns(array('notexstis', 'foobar1234'));
|
|
|
|
$this->assertQueryWorks($sql, '');
|
|
}
|
|
|
|
public function testOnlyOneColumn()
|
|
{
|
|
$sql = $this->dropColumns(array('foobaz'));
|
|
|
|
$this->assertQueryWorks($sql, 'ALTER TABLE `foobar` DROP COLUMN `foobaz`;');
|
|
}
|
|
|
|
public function testMultipleColumns()
|
|
{
|
|
$sql = $this->dropColumns(array('barbaz', 'notexstis', 'barbaz', 'foobaz'));
|
|
|
|
$this->assertQueryWorks($sql, 'ALTER TABLE `foobar` DROP COLUMN `barbaz`, DROP COLUMN `foobaz`;');
|
|
}
|
|
|
|
private function assertQueryWorks(DropColumns $dropColumns, $expectedQuery)
|
|
{
|
|
$this->assertSame($dropColumns->__toString(), $expectedQuery);
|
|
$this->assertNull($dropColumns->exec()); // query should be valid
|
|
}
|
|
|
|
private function dropColumns($columnNames)
|
|
{
|
|
return new DropColumns(Common::prefixTable($this->tableName), $columnNames);
|
|
}
|
|
}
|