使用 PHPUnit 在 Laravel 中進行測試的綜合指南

WBOY
發布: 2024-07-29 06:56:53
原創
696 人瀏覽過

Laravel 測試簡介

測試是軟體開發的關鍵方面,可確保您的應用程式能如預期運作。 Laravel 透過 PHPUnit(一種流行的 PHP 測試框架)提供了一個強大的開箱即用的測試套件。本指南將引導您在 Laravel 中設定和執行測試,解釋單元測試和功能測試之間的差異,並提供各種測試場景的範例。

資料夾結構:單元測試與功能測試

在 Laravel 中,測試通常被組織到兩個主要目錄中:Unit 和 Feature。

單元測試:這些測試旨在測試應用程式的小型、獨立部分,例如單一方法或類別。它們通常位於測試/單元目錄中。每個測試函數都應以單字 test 開頭。

範例:

public function testExampleFunction() {
    $this->assertTrue(true);
}
登入後複製

功能測試:這些測試處理更複雜的交互,通常測試多個組件一起工作。它們位於測試/功能目錄中。功能測試通常涉及發出 HTTP 請求和檢查回應。

在 Laravel 中執行測試

要在 Laravel 應用程式中執行所有測試,請使用以下命令:

./vendor/bin/phpunit
登入後複製
登入後複製

配置測試環境

在執行測試之前,配置測試環境非常重要。修改 phpunit.xml 檔案以設定用於測試的環境變數。例如,要使用 SQLite 記憶體資料庫進行更快的測試:

<php>
    <env name="APP_ENV" value="testing"></env>
    <env name="APP_MAINTENANCE_DRIVER" value="file"></env>
    <env name="BCRYPT_ROUNDS" value="4"></env>
    <env name="CACHE_STORE" value="array"></env>
    <env name="DB_CONNECTION" value="sqlite"></env>
    <env name="DB_DATABASE" value=":memory:"></env>
    <env name="MAIL_MAILER" value="array"></env>
    <env name="PULSE_ENABLED" value="false"></env>
    <env name="QUEUE_CONNECTION" value="sync"></env>
    <env name="SESSION_DRIVER" value="array"></env>
    <env name="TELESCOPE_ENABLED" value="false"></env>
</php>
登入後複製

啟用 SQLite 作為測試環境後,清除設定快取:

php artisan config:clear

登入後複製

*範例:測試設定檔路由是否存在且正常運作
*

為設定檔路由建立測試:

php artisan make:test ProfileTest
登入後複製

新增測試方法來檢查個人資料頁面是否顯示特定文字:

public function testProfilePage(){
    $response = $this->get('/profile');
    $response->assertSeeText('Your Profile');
}
登入後複製

測試資料庫交互

設定測試資料庫

在測試資料庫互動之前,在 config/database.php 中建立一個測試資料庫配置:

'mysqltesting' => [
    'driver' => 'mysql',
    'url' => env('DB_URL'),
    'host' => env('DB_HOST', '127.0.0.1'),
    'port' => env('DB_PORT', '3306'),
    'database' => 'laravel_testing',
    'username' => env('DB_USERNAME', 'root'),
    'password' => env('DB_PASSWORD', ''),
    'unix_socket' => env('DB_SOCKET', ''),
    'charset' => 'utf8mb4',
    'collation' => 'utf8mb4_unicode_ci',
    'prefix' => '',
    'prefix_indexes' => true,
    'strict' => true,
    'engine' => null,
    'options' => extension_loaded('pdo_mysql') ? array_filter([
        PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
    ]) : [],
],
登入後複製

執行資料庫測試

執行 PHPUnit 命令以確保測試資料庫已建立並正常運作:

./vendor/bin/phpunit
登入後複製
登入後複製

使用 PHPUnit 在 Laravel 中進行測試的綜合指南

範例:測試用戶註冊

建立使用者註冊測試:

php artisan make:test UserTest

登入後複製

新增測試方法來驗證可以建立使用者並將其儲存到資料庫:

public function test_registration(): void
{
    $user = new User();
    $user->name = 'Test User';
    $user->email = 'email@example.com';
    $user->password = bcrypt('password');

    $user->save();

    $this->assertDatabaseHas('users', ['email' => 'email@example.com']);
}
登入後複製

測試商店操作

在 PostTest 類別中建立儲存操作的測試:

public function testPostStoreValid()
{
    $data = [
        'title'=> 'Test Post',
        'slug' => 'test-post',
        'content' => 'Content of the post',
        'active' => true,
    ];

    $this->post('/posts', $data)
         ->assertStatus(302)
         ->assertSessionHas('status');

    $this->assertEquals(session('status'), 'Post was created!');
}
登入後複製

故障測試

加入測試方法來檢查驗證錯誤:

public function testPostFail()
{
    $data = [
        'title'=> '',
        'content' => '',
    ];

    $this->post('/posts', $data)
         ->assertStatus(302)
         ->assertSessionHas('errors');

    $messages = session('errors')->getMessages();

    $this->assertEquals($messages['title'][0], 'The title must be at least 4 characters.');
    $this->assertEquals($messages['title'][1], 'The title field is required.');
    $this->assertEquals($messages['content'][0], 'The content field is required.');
}
登入後複製

*測試更新操作
*

新增更新貼文的測試方法:

public function testPostUpdate()
{
    $post = new Post();

    $post->title = "Initial Title";
    $post->slug = Str::slug($post->title, '-');
    $post->content = "Initial content";
    $post->active = true;

    $post->save();

    $this->assertDatabaseHas('posts', $post->toArray());

    $data = [
        'title' => 'Updated Title',
        'slug' => 'updated-title',
        'content' => 'Updated content',
        'active' => false,
    ];

    $this->put("/posts/{$post->id}", $data)
         ->assertStatus(302)
         ->assertSessionHas('status');

    $this->assertDatabaseHas('posts', ['title' => $data['title']]);
    $this->assertDatabaseMissing('posts', ['title' => $post->title]);
}
登入後複製

測試刪除操作

新增刪除貼文的測驗方法:

public function testPostDelete()
{
    $post = new Post();

    $post->title = "Title to delete";
    $post->slug = Str::slug($post->title, '-');
    $post->content = "Content to delete";
    $post->active = true;

    $post->save();

    $this->assertDatabaseHas('posts', $post->toArray());

    $this->delete("/posts/{$post->id}")
         ->assertStatus(302)
         ->assertSessionHas('status');

    $this->assertDatabaseMissing('posts', $post->toArray());
}
登入後複製

**

使用 PHPUnit 執行特定測試

**

要執行特定的測試方法或類別,請使用 PHPUnit 的 --filter 選項。以下是一些例子:

運行特定的測試方法

./vendor/bin/phpunit --filter PostTest::testPostDelete
登入後複製

運行特定類別中的所有測試

./vendor/bin/phpunit --filter PostTest
登入後複製

在特定檔案中執行測試

./vendor/bin/phpunit tests/Feature/PostTest.php
登入後複製

詳細輸出

要獲得更詳細的輸出,請新增 -v 選項:

./vendor/bin/phpunit --filter PostTest::testPostDelete -v
登入後複製

以上是使用 PHPUnit 在 Laravel 中進行測試的綜合指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!