mirror of
https://github.com/PostgreSQL-For-Wordpress/postgresql-for-wordpress.git
synced 2026-01-25 16:02:19 +01:00
34 lines
1.2 KiB
PHP
34 lines
1.2 KiB
PHP
<?php declare(strict_types=1);
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
if (!defined('ABSPATH')) {
|
|
define('ABSPATH', __DIR__ . "/../");
|
|
}
|
|
|
|
if (!defined('WPINC')) {
|
|
define('WPINC', 'wp-includes');
|
|
}
|
|
|
|
require_once __DIR__ . "/../pg4wp/db.php";
|
|
|
|
final class rewriteTest extends TestCase
|
|
{
|
|
public function test_it_can_rewrite_users_admin_query()
|
|
{
|
|
|
|
$sql = 'SELECT COUNT(NULLIF(`meta_value` LIKE \'%"administrator"%\', false)), COUNT(NULLIF(`meta_value` = \'a:0:{}\', false)), COUNT(*) FROM wp_usermeta INNER JOIN wp_users ON user_id = ID WHERE meta_key = \'wp_capabilities\'';
|
|
$expected = 'SELECT COUNT(NULLIF(meta_value ILIKE \'%"administrator"%\', false)) AS count0, COUNT(NULLIF(meta_value = \'a:0:{}\', false)) AS count1, COUNT(*) FROM wp_usermeta INNER JOIN wp_users ON user_id = "ID" WHERE meta_key = \'wp_capabilities\'';
|
|
$postgresql = pg4wp_rewrite($sql);
|
|
$this->assertSame($postgresql, $expected);
|
|
}
|
|
|
|
|
|
public function test_it_adds_group_by()
|
|
{
|
|
|
|
$sql = 'SELECT COUNT(id), username FROM users';
|
|
$expected = 'SELECT COUNT(id) AS count0, username FROM users GROUP BY username';
|
|
$postgresql = pg4wp_rewrite($sql);
|
|
$this->assertSame($postgresql, $expected);
|
|
}
|
|
} |