Cara menggunakan PHPUnit untuk ujian pangkalan data dalam pembangunan PHP

WBOY
Lepaskan: 2023-06-27 08:40:02
asal
1510 orang telah melayarinya

Dengan perkembangan pesat PHP dan aplikasi web yang semakin menjadi sebahagian daripada kehidupan harian orang ramai, membangunkan aplikasi PHP berkualiti tinggi menjadi penting. Dalam proses itu, PHPUnit telah menjadi salah satu rangka kerja ujian yang paling biasa digunakan dalam kalangan pengaturcara PHP. PHPUnit ialah rangka kerja ujian berdasarkan seni bina xUnit yang menyediakan beberapa penegasan dan alatan untuk menguji kod. Dalam artikel ini, kami akan memperkenalkan secara terperinci cara menggunakan PHPUnit untuk ujian pangkalan data.

  1. Pasang rangka kerja PHPUnit

Rangka kerja PHPUnit dibangunkan oleh Sebastian Bergmann Memandangkan ia adalah perpustakaan PHP, anda boleh memilih untuk menambah pakej PHPUnit dalam Komposer untuk pemasangan, atau anda boleh memuat turunnya dari tapak web rasmi PHPUnit. di phpunit.de Versi terkini PHPUnit.

Anda boleh memasang PHPUnit dengan menjalankan arahan berikut dalam terminal:

composer require --dev phpunit/phpunit
Salin selepas log masuk

Selepas memasang PHPUnit, anda perlu menyediakan persekitaran ujian dan menyambung ke pangkalan data.

  1. Sediakan persekitaran ujian

Dalam aplikasi PHP, pangkalan data ujian hendaklah bebas daripada pangkalan data pengeluaran. Untuk tujuan ini, fail konfigurasi berasingan boleh digunakan, seperti phpunit.xml atau phpunit.xml.dist. phpunit.xmlphpunit.xml.dist

phpunit.xml文件中,需要设置test环境以确保在测试期间使用正确的配置文件和环境变量。可以设置以下环境变量:

<php>
    <env name="APP_ENV" value="test" />
    <env name="DB_DRIVER" value="pgsql" />
    <env name="DB_HOST" value="localhost" />
    <env name="DB_DATABASE" value="phpunit_test" />
    <env name="DB_USERNAME" value="root" />
    <env name="DB_PASSWORD" value="" />
</php>
Salin selepas log masuk

将这些环境变量设置为用于测试的正确值是非常重要的,因为如果测试代码试图访问生产数据库,将会产生灾难性的影响。

  1. 配置数据库

创建以test为后缀的数据库,以便在PHPUnit测试中使用,例如phpunit_test

phpunit.xml文件中设置数据库配置信息:

<php>
    <var name="DB_DSN" value="${DB_DRIVER}:host=${DB_HOST};dbname=${DB_DATABASE}" />
    <var name="DB_USER" value="${DB_USERNAME}" />
    <var name="DB_PASSWD" value="${DB_PASSWORD}" />
</php>
Salin selepas log masuk

这些配置将与你的应用程序中的其他数据库配置共享。在PHPUnit测试时,将能够使用这些配置信息来连接测试数据库。

  1. 编写PHPUnit测试用例

在PHPUnit中,测试用例是测试代码的最小单元。它应该是一个测试类,其中包含了测试一个或多个待测函数或方法的测试用例。

为了在PHPUnit中测试数据库,需要编写数据库测试用例。以下示例说明了如何编写一个测试类以测试与数据库的连接:

<?php

use PHPUnitFrameworkTestCase;

class DatabaseTest extends TestCase
{
    public function testConnection()
    {
        $db = new PDO(getenv('DB_DSN'), getenv('DB_USER'), getenv('DB_PASSWD'));
        $this->assertInstanceOf(PDO::class, $db);
    }
}
Salin selepas log masuk

在上面的示例中,首先实例化了一个PDO对象以连接到测试数据库。接下来,使用assertInstanceOf断言方法确保返回值是一个PDO对象。

使用PHPUnit提供的各种断言方法来检查测试结果,例如assertSameassertEquals等等。 有关可用的PHPUnit断言方法的完整列表,请查看PHPUnit文档。

  1. 运行PHPUnit测试

在终端输入vendor/bin/phpunit,将运行PHPUnit测试。 或者,可以在终端输入vendor/bin/phpunit tests,其中tests

Dalam fail phpunit.xml, persekitaran test perlu disediakan untuk memastikan fail konfigurasi dan pembolehubah persekitaran yang betul digunakan semasa ujian. Pembolehubah persekitaran berikut boleh ditetapkan:

rrreee

Menetapkan pembolehubah persekitaran ini kepada nilai yang betul untuk ujian adalah sangat penting kerana ia akan memberi kesan buruk jika kod ujian cuba mengakses pangkalan data pengeluaran.

    Konfigurasikan pangkalan data

    🎜Buat pangkalan data dengan akhiran test untuk digunakan dalam ujian PHPUnit, seperti phpunit_test. 🎜🎜Tetapkan maklumat konfigurasi pangkalan data dalam fail phpunit.xml: 🎜rrreee🎜Konfigurasi ini akan dikongsi dengan konfigurasi pangkalan data lain dalam aplikasi anda. Apabila menguji PHPUnit, anda akan dapat menggunakan maklumat konfigurasi ini untuk menyambung ke pangkalan data ujian. 🎜
      🎜Menulis kes ujian PHPUnit🎜🎜🎜Dalam PHPUnit, kes ujian ialah unit terkecil kod ujian. Ia mestilah kelas ujian yang mengandungi kes ujian untuk menguji satu atau lebih fungsi atau kaedah yang sedang diuji. 🎜🎜Untuk menguji pangkalan data dalam PHPUnit, anda perlu menulis kes ujian pangkalan data. Contoh berikut menggambarkan cara untuk menulis kelas ujian untuk menguji sambungan ke pangkalan data: 🎜rrreee🎜 Dalam contoh di atas, objek PDO mula-mula digunakan untuk menyambung ke pangkalan data ujian. Seterusnya, gunakan kaedah penegasan assertInstanceOf untuk memastikan bahawa nilai pulangan ialah objek PDO. 🎜🎜Gunakan pelbagai kaedah penegasan yang disediakan oleh PHPUnit untuk menyemak keputusan ujian, seperti assertSame, assertEquals, dsb. Untuk senarai lengkap kaedah penegasan PHPUnit yang tersedia, lihat dokumentasi PHPUnit. 🎜
        🎜Jalankan ujian PHPUnit🎜🎜🎜Masukkan vendor/bin/phpunit dalam terminal dan ujian PHPUnit akan dijalankan. Sebagai alternatif, anda boleh memasukkan vendor/bin/phpunit tests dalam terminal, dengan tests ialah direktori tempat fail ujian disimpan. 🎜🎜Jika kes ujian gagal, anda perlu menyemak mesej ralat yang dicetak oleh PHPUnit dan cuba membetulkan kod tersebut. Jika kes ujian lulus, ini bermakna aplikasi PHP disediakan dengan betul dengan pangkalan data yang disambungkan dan rangka kerja ujian PHPUnit digunakan. 🎜🎜Apabila menggunakan PHPUnit untuk ujian pangkalan data, anda mesti memastikan pengasingan antara persekitaran ujian dan persekitaran pengeluaran. Juga, pastikan anda menggunakan pangkalan data ujian yang berasingan sebelum melaksanakan ujian PHPUnit. Dengan langkah di atas, PHPUnit boleh digunakan dengan berkesan untuk menyediakan ujian pangkalan data berkualiti tinggi untuk aplikasi PHP. 🎜🎜Ringkasnya, rangka kerja PHPUnit menyediakan kaedah yang sangat mudah untuk ujian unit. Dalam proses pembangunan aplikasi PHP, sangat perlu menggunakan PHPUnit untuk pengujian pangkalan data Oleh itu, perlu membiasakan diri dengan penggunaan PHPUnit dan mempunyai idea pengujian unit. 🎜

Atas ialah kandungan terperinci Cara menggunakan PHPUnit untuk ujian pangkalan data dalam pembangunan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan