Rumah pembangunan bahagian belakang tutorial php PHP: Patutkah saya mengejek atau perlu pergi?

PHP: Patutkah saya mengejek atau perlu pergi?

Dec 11, 2024 am 10:36 AM

PHP: Should I mock or should I go?

Mengejek secara ringkas

Olok-olok bertujuan untuk menguji tingkah laku objek sebenar.

Ia mensimulasikan kebergantungan, jadi anda tidak perlu memanggil sumber luaran yang boleh melambatkan ujian unit dengan ketara.

Anda boleh menentukan jangkaan dan mengesahkannya.

Sebagai contoh, anda boleh memastikan bahawa kaedah dipanggil bilangan kali tertentu dan/atau dengan parameter tertentu:

use PHPUnit\Framework\TestCase;

class MyTest extends TestCase
{
    public function testMockExample(): void
    {
        $depencencyMock = $this->createMock(MyDependency::class);

        $dependencyMock->expects($this->exactly(2))
              ->method('someMethod')
              ->with('some parameter');

        $classToTest = new ClassToTest($dependencyMock);
   }
}
Salin selepas log masuk
Salin selepas log masuk

Kembalikan nilai

willReturn() memastikan keserasian dengan jenis pulangan:

// In code
class MyClass {
    public function getNum(): int {
    }
}

// In tests
$myClassMock = $this->createMock(MyClass::class);
$myClassMock->expects($this->once())
            ->method('getNum')
            ->willReturn(2);
Salin selepas log masuk

Anda juga boleh menggunakan willReturnCallback jika anda ingin menguji tingkah laku dinamik berdasarkan parameter input.

Amalan buruk yang perlu dielakkan

Memandangkan ejekan hanya meniru tingkah laku sebenar, mudah untuk terlepas maksud. Jom bincang amalan buruk biasa:

Mengembalikan nilai tanpa jangkaan

❌ Jangan buat begitu:

$colorServiceMock = $this->createMock(ColorService::class);
$colorServiceMock->method('hexToName')
     ->willReturn('red');

$color = (new MyClass($colorServiceMock))->getColorName('ff0000');
Salin selepas log masuk

✅ Sebaliknya, tambahkan beberapa jangkaan:

$colorServiceMock->expects($this->once())
     ->method('hexToName')
     ->with('00f00')
     ->willReturn('green');

$color = (new MyClass($colorServiceMock))->getColorName('00f00');
Salin selepas log masuk

Ingat ejekan bertujuan untuk mengesahkan interaksi.

Mengejek objek sebenar dan bukannya antara muka

Mari kita uji MyClass yang melaksanakan SomeInterface.

❌ Jangan buat begitu:

$myclassMock = $this->createMock(MyClass::class);
Salin selepas log masuk

✅ Sebaliknya, ejek antara muka:

$myclassMock = $this->createMock(SomeInterface::class);
Salin selepas log masuk

Ejekan memberi tumpuan kepada tingkah laku. Antara muka biasanya tidak berubah, kerana anda sepatutnya mengubah suai pelaksanaan, bukan kontrak.

Ujian mengejek

Tomas Votruba menerangkan masalah ini dengan indah: 5 Cara untuk Mengeluarkan Nilai daripada Ujian Terlalu Banyak

Menggunakan ejekan untuk menutup amalan reka bentuk yang buruk

Mudah untuk mengabaikan gandingan yang ketat antara komponen:

$productRepositoryMock = $this->createMock(ProductRepository::class);
$invoiceRepositoryMock = $this->createMock(InvoiceRepository::class);
$emailServiceMock = $this->createMock(EmailService::class);

$overComplexService = new OverComplexService($productRepositoryMock, $invoiceRepositoryMock, $emailServiceMock);
Salin selepas log masuk

Contoh di atas memecahkan pemisahan kebimbangan, dan ejekan mengekalkan amalan buruk itu.

Bergantung pada ejekan semata-mata

Mocks ialah alat yang berkuasa, tetapi ujian unit tidak mencukupi. Anda memerlukan pelbagai jenis ujian lain (cth, penyepaduan, e2e).

Bagaimana untuk mengesan penggunaan ejekan yang tidak baik

Selain amalan buruk, terdapat tanda-tanda lain yang boleh menunjukkan bahawa ejekan disalahgunakan atau digunakan secara berlebihan dalam projek:

  • ujian tidak menggambarkan senario dunia sebenar, mengabaikan isu kritikal dalam pengeluaran
  • terdapat pasangan yang ketat antara ujian dan pelaksanaan, mengakibatkan kemas kini yang kerap bagi olok-olok yang berkaitan
  • ujian adalah terlalu kompleks, menjadikannya lebih sukar untuk dibaca dan diselenggara

Olok-olok dan rintisan

Martin Fowler menulis siaran hebat yang menerangkan sebab Mocks Aren't Stubs.

Mari lihat situasi konkrit di mana anda mungkin menggunakannya:

Bila hendak menggunakan olok-olok

Berikut ialah beberapa kes ujian di mana ejekan lebih masuk akal:

  • anda perlu menguji cara kelas anda berinteraksi dengan kebergantungannya
  • anda perlu menyemak urutan kompleks di mana kaedah tertentu dipanggil beberapa kali dengan parameter yang berbeza

Bila hendak menggunakan stub

Anda boleh membuat stub dengan PHPUnit dengan mudah:

use PHPUnit\Framework\TestCase;

class MyTest extends TestCase
{
    public function testMockExample(): void
    {
        $depencencyMock = $this->createMock(MyDependency::class);

        $dependencyMock->expects($this->exactly(2))
              ->method('someMethod')
              ->with('some parameter');

        $classToTest = new ClassToTest($dependencyMock);
   }
}
Salin selepas log masuk
Salin selepas log masuk

Berikut ialah beberapa kes ujian yang mana stub lebih masuk akal:

  • anda mahu menguji output atau keadaan kod anda tanpa perlu mengesahkan interaksi
  • anda perlu menguji beberapa pengiraan tanpa perlu berinteraksi dengan pangkalan data sebenar

Ringkasnya, stub bukan bertujuan untuk memeriksa kelakuan objek sebenar tetapi menyatakan.

Penalaan halus

Tujuan utama ujian unit adalah untuk memastikan setiap unit/komponen berfungsi seperti yang diharapkan, tetapi anda perlu mengekalkan ujian tersebut sebagai tambahan kepada kod sebenar.

Stub boleh memudahkan persediaan ujian dan sangat cekap untuk senario mudah yang anda tidak perlu menjejaki panggilan kaedah dan interaksi.

Ia boleh menghalang kerumitan yang tidak perlu dengan memastikan beberapa ujian anda fokus.

Bungkus

Mocks boleh menjejaki panggilan kaedah dan parameternya.

Jangan lupa untuk mengembalikan nilai yang mewakili tingkah laku sebenar. Jika tidak, anda mungkin mengalami rasa selamat yang palsu.

Mock harus digunakan dengan berhati-hati untuk mengelakkan kerumitan yang tidak perlu untuk penyelenggaraan.

Atas ialah kandungan terperinci PHP: Patutkah saya mengejek atau perlu pergi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1672
14
Tutorial PHP
1277
29
Tutorial C#
1257
24
Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1? Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1? Apr 17, 2025 am 12:06 AM

Dalam php, kata laluan_hash dan kata laluan 1) password_hash menjana hash yang mengandungi nilai garam untuk meningkatkan keselamatan. 2) Kata Laluan_verify Sahkan kata laluan dan pastikan keselamatan dengan membandingkan nilai hash. 3) MD5 dan SHA1 terdedah dan kekurangan nilai garam, dan tidak sesuai untuk keselamatan kata laluan moden.

Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan? Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan? Apr 17, 2025 am 12:25 AM

Jenis PHP meminta untuk meningkatkan kualiti kod dan kebolehbacaan. 1) Petua Jenis Skalar: Oleh kerana Php7.0, jenis data asas dibenarkan untuk ditentukan dalam parameter fungsi, seperti INT, Float, dan lain -lain. 2) Return Type Prompt: Pastikan konsistensi jenis nilai pulangan fungsi. 3) Jenis Kesatuan Prompt: Oleh kerana Php8.0, pelbagai jenis dibenarkan untuk ditentukan dalam parameter fungsi atau nilai pulangan. 4) Prompt jenis yang boleh dibatalkan: membolehkan untuk memasukkan nilai null dan mengendalikan fungsi yang boleh mengembalikan nilai null.

PHP dan Python: Paradigma yang berbeza dijelaskan PHP dan Python: Paradigma yang berbeza dijelaskan Apr 18, 2025 am 12:26 AM

PHP terutamanya pengaturcaraan prosedur, tetapi juga menyokong pengaturcaraan berorientasikan objek (OOP); Python menyokong pelbagai paradigma, termasuk pengaturcaraan OOP, fungsional dan prosedur. PHP sesuai untuk pembangunan web, dan Python sesuai untuk pelbagai aplikasi seperti analisis data dan pembelajaran mesin.

PHP dan Python: Contoh dan perbandingan kod PHP dan Python: Contoh dan perbandingan kod Apr 15, 2025 am 12:07 AM

PHP dan Python mempunyai kelebihan dan kekurangan mereka sendiri, dan pilihannya bergantung kepada keperluan projek dan keutamaan peribadi. 1.PHP sesuai untuk pembangunan pesat dan penyelenggaraan aplikasi web berskala besar. 2. Python menguasai bidang sains data dan pembelajaran mesin.

Bagaimana anda menghalang suntikan SQL di PHP? (Penyataan yang disediakan, PDO) Bagaimana anda menghalang suntikan SQL di PHP? (Penyataan yang disediakan, PDO) Apr 15, 2025 am 12:15 AM

Menggunakan penyataan preprocessing dan PDO dalam PHP secara berkesan dapat mencegah serangan suntikan SQL. 1) Gunakan PDO untuk menyambung ke pangkalan data dan tetapkan mod ralat. 2) Buat kenyataan pra -proses melalui kaedah menyediakan dan lulus data menggunakan ruang letak dan laksanakan kaedah. 3) Hasil pertanyaan proses dan pastikan keselamatan dan prestasi kod.

PHP: Pengendalian pangkalan data dan logik sisi pelayan PHP: Pengendalian pangkalan data dan logik sisi pelayan Apr 15, 2025 am 12:15 AM

PHP menggunakan sambungan MySQLI dan PDO untuk berinteraksi dalam operasi pangkalan data dan pemprosesan logik sisi pelayan, dan memproses logik sisi pelayan melalui fungsi seperti pengurusan sesi. 1) Gunakan MySQLI atau PDO untuk menyambung ke pangkalan data dan laksanakan pertanyaan SQL. 2) Mengendalikan permintaan HTTP dan status pengguna melalui pengurusan sesi dan fungsi lain. 3) Gunakan urus niaga untuk memastikan atomik operasi pangkalan data. 4) Mencegah suntikan SQL, gunakan pengendalian pengecualian dan sambungan penutup untuk debugging. 5) Mengoptimumkan prestasi melalui pengindeksan dan cache, tulis kod yang sangat mudah dibaca dan lakukan pengendalian ralat.

Tujuan PHP: Membina Laman Web Dinamik Tujuan PHP: Membina Laman Web Dinamik Apr 15, 2025 am 12:18 AM

PHP digunakan untuk membina laman web dinamik, dan fungsi terasnya termasuk: 1. Menjana kandungan dinamik dan menghasilkan laman web secara real time dengan menyambung dengan pangkalan data; 2. Proses Interaksi Pengguna dan Penyerahan Bentuk, Sahkan Input dan Menanggapi Operasi; 3. Menguruskan sesi dan pengesahan pengguna untuk memberikan pengalaman yang diperibadikan; 4. Mengoptimumkan prestasi dan ikuti amalan terbaik untuk meningkatkan kecekapan dan keselamatan laman web.

Memilih antara php dan python: panduan Memilih antara php dan python: panduan Apr 18, 2025 am 12:24 AM

PHP sesuai untuk pembangunan web dan prototaip pesat, dan Python sesuai untuk sains data dan pembelajaran mesin. 1.Php digunakan untuk pembangunan web dinamik, dengan sintaks mudah dan sesuai untuk pembangunan pesat. 2. Python mempunyai sintaks ringkas, sesuai untuk pelbagai bidang, dan mempunyai ekosistem perpustakaan yang kuat.

See all articles