1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
<?php
namespace Illuminate\Tests\Integration\Database\Postgres;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;
/**
* @requires extension pdo_pgsql
* @requires OS Linux|Darwin
*/
class FulltextTest extends PostgresTestCase
{
protected function defineDatabaseMigrationsAfterDatabaseRefreshed()
{
Schema::create('articles', function (Blueprint $table) {
$table->id('id');
$table->string('title', 200);
$table->text('body');
$table->fulltext(['title', 'body']);
});
}
protected function destroyDatabaseMigrations()
{
Schema::drop('articles');
}
protected function setUp(): void
{
parent::setUp();
DB::table('articles')->insert([
['title' => 'PostgreSQL Tutorial', 'body' => 'DBMS stands for DataBase ...'],
['title' => 'How To Use PostgreSQL Well', 'body' => 'After you went through a ...'],
['title' => 'Optimizing PostgreSQL', 'body' => 'In this tutorial, we show ...'],
['title' => '1001 PostgreSQL Tricks', 'body' => '1. Never run mysqld as root. 2. ...'],
['title' => 'PostgreSQL vs. YourSQL', 'body' => 'In the following database comparison ...'],
['title' => 'PostgreSQL Security', 'body' => 'When configured properly, PostgreSQL ...'],
]);
}
public function testWhereFulltext()
{
$articles = DB::table('articles')->whereFulltext(['title', 'body'], 'database')->orderBy('id')->get();
$this->assertCount(2, $articles);
$this->assertSame('PostgreSQL Tutorial', $articles[0]->title);
$this->assertSame('PostgreSQL vs. YourSQL', $articles[1]->title);
}
public function testWhereFulltextWithWebsearch()
{
$articles = DB::table('articles')->whereFulltext(['title', 'body'], '+PostgreSQL -YourSQL', ['mode' => 'websearch'])->get();
$this->assertCount(5, $articles);
}
public function testWhereFulltextWithPlain()
{
$articles = DB::table('articles')->whereFulltext(['title', 'body'], 'PostgreSQL tutorial', ['mode' => 'plain'])->get();
$this->assertCount(2, $articles);
}
public function testWhereFulltextWithPhrase()
{
$articles = DB::table('articles')->whereFulltext(['title', 'body'], 'PostgreSQL tutorial', ['mode' => 'phrase'])->get();
$this->assertCount(1, $articles);
}
}
|