


Bagaimana saya menulis ujian unit untuk kod php menggunakan phpunit?
Jun 22, 2025 am 12:56 AMPasang phpunit dan konfigurasikan persekitaran projek; 2. Buat struktur direktori ujian dan sesuai dengan kod sumber; 3. Tulis kes ujian bebas dan sahkan keputusan menggunakan pernyataan; 4. Mengasingkan kebergantungan luaran dengan objek mengejek; 5. Ujian menjalankan kerap untuk memastikan kualiti kod. Pertama, pasangkan phpUnit melalui komposer dan konfigurasikan fail phpunit.xml. Kemudian buat direktori ujian untuk menyimpan kelas ujian. Setiap kelas ujian mewarisi ujian dan menulis kaedah pada permulaan ujian untuk ujian. Gunakan menegaskan seperti AssertEquals untuk mengesahkan ketepatan logik. Gunakan CreateMock untuk mensimulasikan tingkah laku untuk kebergantungan luaran. Akhirnya, laksanakan perintah vendor/bin/phpunit secara teratur untuk menjalankan ujian dan mengintegrasikannya ke dalam proses CI untuk meningkatkan kestabilan kod.
Anda hanya mula menulisnya - sebaik sahaja anda telah membuat phpunit, ia adalah tentang memecahkan kod anda ke dalam kepingan yang boleh diuji kecil dan memeriksa mereka berkelakuan seperti yang diharapkan. Kuncinya adalah untuk memberi tumpuan kepada satu perkara pada satu masa, terus ujian mudah dan cepat, dan pastikan mereka gagal sebelum mereka lulus (jadi anda tahu mereka sebenarnya menguji sesuatu).
Sediakan phpunit dalam projek anda
Sebelum menulis ujian, anda perlu dipasang phpunit. Kebanyakan projek PHP moden menggunakan komposer, jadi jalankan:
Komposer memerlukan -PHPUNIT/PHPUNIT
Kemudian buat fail phpunit.xml
dalam root projek anda. Versi asas mungkin kelihatan seperti ini:
<phpunit bootstrap = "vendor/autoload.php"> <Stestsuites> <testSuite name = "suite ujian saya"> <sirum> ujian </direktori> </testsuite> </testsuites> </phpUnit>
Ini memberitahu PHPUNIT di mana untuk mencari fail ujian anda dan bagaimana untuk autoload kelas anda.
Jika anda menggunakan rangka kerja seperti Laravel atau Symfony, mereka sering datang dengan PHPUnit yang sudah dikonfigurasi-jadi semakan semula sebelum ditubuhkan secara manual.
Struktur ujian anda dengan betul
Buat folder tests
dalam projek anda, dan di dalamnya, cermin struktur kod sumber anda. Sebagai contoh, jika anda mempunyai kelas dalam src/Calculator.php
, letakkan ujiannya dalam tests/CalculatorTest.php
.
Kelas ujian phpunit harus melanjutkan PHPUnit\Framework\TestCase
. Setiap kaedah awam bermula dengan test
akan dianggap sebagai kes ujian berasingan.
Inilah ujian asas yang kelihatan seperti:
Gunakan phpunit \ rangka kerja \ testcase; kelas calculatortest memanjangkan ujian { TestAddition Fungsi Awam () { $ calculator = kalkulator baru (); $ hasil = $ calculator-> tambah (2, 3); $ this-> AssertEquals (5, $ hasil); } }
- Gunakan
$this->assertEquals()
untuk memeriksa nilai yang diharapkan. - Anda juga boleh menggunakan
$this->assertTrue()
,$this->assertNull()
, dan lain-lain, bergantung kepada apa yang anda uji.
Cuba tulis ujian yang bebas - satu ujian gagal tidak boleh menyebabkan orang lain gagal juga.
Ketergantungan mengejek untuk memastikan ujian terfokus
Apabila kelas anda menggunakan perkhidmatan luaran (seperti pangkalan data atau API), anda tidak mahu ujian anda memukul sistem sebenar setiap kali. Di situlah mengejek masuk.
PHPUnit mempunyai sokongan terbina dalam untuk membuat objek mengejek. Inilah contoh:
Fungsi awam TestFetchDataFromapi () { $ mockapi = $ this-> createMock (Apiclient :: class); // Beritahu mock untuk mengembalikan nilai tertentu apabila getData () dipanggil $ mockapi-> kaedah ('getData')-> willreturn (['id' => 1]); $ perkhidmatan = DataService baru ($ mockapi); $ data = $ service-> fetchAndProcess (); $ this-> AssertEquals (1, $ data ['id']); }
Beberapa petua:
- Hanya mengejek apa yang anda perlukan - jangan keterlaluan.
- Elakkan mengejek terlalu banyak kaedah; Itu biasanya bermaksud kelas anda terlalu banyak.
- Jika anda mendapati diri anda perlu menguji kaedah peribadi, pertimbangkan refactoring - ujian unit harus memberi tumpuan kepada tingkah laku awam.
Lari ujian anda dengan kerap
Sebaik sahaja ujian anda ditulis, jalankannya dengan kerap menggunakan:
vendor/bin/phpunit
Ini membantu menangkap regresi awal. Anda juga boleh mengintegrasikan phpunit ke dalam cangkuk git atau saluran paip CI (seperti tindakan GitHub atau Gitlab CI) untuk mengautomasikannya.
Sekiranya ujian gagal, baca output dengan teliti - PHPUnit biasanya memberitahu anda dengan tepat apa yang salah dan garis yang perlu diperbaiki.
Itu pada dasarnya. Ujian unit menulis dengan PHPUnit tidak rumit, tetapi ia mengambil disiplin. Mulakan kecil, uji logik teras terlebih dahulu, dan bina dari sana.
Atas ialah kandungan terperinci Bagaimana saya menulis ujian unit untuk kod php menggunakan phpunit?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Langkah-langkah untuk antara muka ujian unit dan kelas abstrak dalam Java: Buat kelas ujian untuk antara muka. Buat kelas olok-olok untuk melaksanakan kaedah antara muka. Gunakan perpustakaan Mockito untuk mengejek kaedah antara muka dan menulis kaedah ujian. Kelas abstrak mencipta kelas ujian. Buat subkelas bagi kelas abstrak. Tulis kaedah ujian untuk menguji ketepatan kelas abstrak.

Analisis alat ujian unit PHP: PHPUnit: sesuai untuk projek besar, menyediakan fungsi yang komprehensif dan mudah dipasang, tetapi mungkin bertele-tele dan perlahan. PHPUnitWrapper: sesuai untuk projek kecil, mudah digunakan, dioptimumkan untuk Lumen/Laravel, tetapi mempunyai fungsi terhad, tidak menyediakan analisis liputan kod dan mempunyai sokongan komuniti terhad.

Dalam ujian unit fungsi Go, terdapat dua strategi utama untuk pengendalian ralat: 1. Wakilkan ralat sebagai nilai khusus jenis ralat, yang digunakan untuk menegaskan nilai yang dijangkakan 2. Gunakan saluran untuk menghantar ralat kepada fungsi ujian; yang sesuai untuk menguji kod serentak. Dalam kes praktikal, strategi nilai ralat digunakan untuk memastikan fungsi mengembalikan 0 untuk input negatif.

Ujian prestasi menilai prestasi aplikasi di bawah beban yang berbeza, manakala ujian unit mengesahkan ketepatan satu unit kod. Ujian prestasi memfokuskan pada mengukur masa tindak balas dan daya pemprosesan, manakala ujian unit memfokuskan pada output fungsi dan liputan kod. Ujian prestasi mensimulasikan persekitaran dunia sebenar dengan beban tinggi dan serentak, manakala ujian unit dijalankan di bawah beban rendah dan keadaan bersiri. Matlamat ujian prestasi adalah untuk mengenal pasti kesesakan prestasi dan mengoptimumkan aplikasi, manakala matlamat ujian unit adalah untuk memastikan ketepatan dan keteguhan kod.

Ujian dipacu jadual memudahkan penulisan kes ujian dalam ujian unit Go dengan mentakrifkan input dan output yang dijangka melalui jadual. Sintaks termasuk: 1. Tentukan kepingan yang mengandungi struktur kes ujian 2. Gelung melalui kepingan dan bandingkan keputusan dengan output yang dijangkakan. Dalam kes sebenar, ujian dipacu jadual telah dilakukan pada fungsi menukar rentetan kepada huruf besar, dan gotest digunakan untuk menjalankan ujian dan keputusan lulus telah dicetak.

Cara menggunakan Gomega untuk penegasan dalam ujian unit Golang Dalam ujian unit Golang, Gomega ialah perpustakaan penegasan yang popular dan berkuasa yang menyediakan kaedah penegasan yang kaya supaya pembangun boleh mengesahkan keputusan ujian dengan mudah. Pasang Gomegagoget-ugithub.com/onsi/gomega Menggunakan Gomega untuk penegasan Berikut ialah beberapa contoh biasa menggunakan Gomega untuk penegasan: 1. Import penegasan kesamaan "github.com/onsi/gomega" funcTest_MyFunction(t*testing.T){

Adalah penting untuk mereka bentuk kes ujian unit yang berkesan, mematuhi prinsip berikut: atom, ringkas, boleh berulang dan tidak jelas. Langkah-langkahnya termasuk: menentukan kod yang akan diuji, mengenal pasti senario ujian, mencipta penegasan dan menulis kaedah ujian. Kes praktikal menunjukkan penciptaan kes ujian untuk fungsi max(), menekankan kepentingan senario dan penegasan ujian tertentu. Dengan mengikuti prinsip dan langkah ini, anda boleh meningkatkan kualiti dan kestabilan kod.

Cara meningkatkan liputan kod dalam ujian unit PHP: Gunakan pilihan --coverage-html PHPUnit untuk menjana laporan liputan. Gunakan kaedah setAccessible untuk mengatasi kaedah dan sifat peribadi. Gunakan penegasan untuk mengatasi syarat Boolean. Dapatkan cerapan liputan kod tambahan dengan alat semakan kod.
