File: FulltextTest.php

package info (click to toggle)
php-laravel-framework 11.44.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 22,184 kB
  • sloc: php: 265,914; sh: 167; javascript: 51; makefile: 46
file content (69 lines) | stat: -rw-r--r-- 2,579 bytes parent folder | download
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
<?php

namespace Illuminate\Tests\Integration\Database\MariaDb;

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Schema;
use PHPUnit\Framework\Attributes\RequiresOperatingSystem;
use PHPUnit\Framework\Attributes\RequiresPhpExtension;

#[RequiresOperatingSystem('Linux|Darwin')]
#[RequiresPhpExtension('pdo_mysql')]
class FulltextTest extends MariaDbTestCase
{
    protected function afterRefreshingDatabase()
    {
        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' => 'MariaDB Tutorial', 'body' => 'DBMS stands for DataBase ...'],
            ['title' => 'How To Use MariaDB Well', 'body' => 'After you went through a ...'],
            ['title' => 'Optimizing MariaDB', 'body' => 'In this tutorial, we show ...'],
            ['title' => '1001 MariaDB Tricks', 'body' => '1. Never run mariadbd as root. 2. ...'],
            ['title' => 'MariaDB vs. YourSQL', 'body' => 'In the following database comparison ...'],
            ['title' => 'MariaDB Security', 'body' => 'When configured properly, MariaDB ...'],
        ]);
    }

    /** @link https://mariadb.com/kb/en/full-text-index-overview/#in-natural-language-mode */
    public function testWhereFulltext()
    {
        $articles = DB::table('articles')->whereFullText(['title', 'body'], 'database')->get();

        $this->assertCount(2, $articles);
        $this->assertSame('MariaDB Tutorial', $articles[0]->title);
        $this->assertSame('MariaDB vs. YourSQL', $articles[1]->title);
    }

    /** @link https://mariadb.com/kb/en/full-text-index-overview/#in-boolean-mode */
    public function testWhereFulltextWithBooleanMode()
    {
        $articles = DB::table('articles')->whereFullText(['title', 'body'], '+MariaDB -YourSQL', ['mode' => 'boolean'])->get();

        $this->assertCount(5, $articles);
    }

    /** @link https://mariadb.com/kb/en/full-text-index-overview/#with-query-expansion */
    public function testWhereFulltextWithExpandedQuery()
    {
        $articles = DB::table('articles')->whereFullText(['title', 'body'], 'database', ['expanded' => true])->get();

        $this->assertCount(6, $articles);
    }
}