Jadual Kandungan
Kesimpulan
Soalan Lazim Mengenai Pengejaran dan Ujian Kebergantungan (FAQ)
Apa itu ejekan dan mengapa penting dalam ujian PHP?
Bagaimana untuk memasang dan menyiapkan penghinaan dalam projek PHP saya?
bagaimana membuat objek mengejek menggunakan ejekan?
Bagaimana untuk menentukan jangkaan dalam ejekan?
Apakah perbezaan antara simulasi dan stub dalam ejekan?
Bagaimana menggunakan ejekan untuk menguji kaedah peribadi?
Bagaimana menangani parameter pembina dalam ejekan?
Bagaimana menggunakan ejekan untuk mensimulasikan kaedah statik?
Bagaimana untuk mengesahkan bahawa semua jangkaan dipenuhi dalam ejekan?
Bagaimana menangani pengecualian dalam ejekan?
Rumah pembangunan bahagian belakang tutorial php Mengejutkan Dependensi Ujian Anda Dengan Penghinaan

Mengejutkan Dependensi Ujian Anda Dengan Penghinaan

Feb 20, 2025 am 09:07 AM

Mock your Test Dependencies with Mockery

Walaupun tidak semua orang melakukan ini, menguji permohonan anda adalah salah satu bahagian yang paling asas menjadi pemaju. Ujian unit adalah ujian yang paling biasa. Dengan ujian unit, anda boleh menyemak sama ada kelas berjalan seperti yang anda harapkan. Kadang-kadang, anda menggunakan perkhidmatan pihak ketiga dalam aplikasi anda, dan sukar untuk menubuhkan segala-galanya untuk ujian unit. Ini adalah ketika simulasi dimainkan.

mata utama

    Mocking adalah proses membuat pengganti objek sebenar dalam ujian unit, yang sangat berguna apabila menguji aplikasi yang sangat bergantung pada suntikan ketergantungan.
  • Mockery adalah sebuah perpustakaan yang dicipta oleh Pádraic Brady yang boleh digunakan untuk mengejek objek dalam ujian unit, memberikan alternatif kepada keupayaan mengejek lalai phpunit.
  • ejekan membolehkan pemaju untuk menentukan jangkaan untuk bilangan panggilan kaedah, parameter yang akan diterima, dan nilai -nilai yang akan dikembalikan, menjadikannya alat yang kuat untuk mengasingkan kebergantungan dalam ujian unit.
  • Walaupun phpunit sudah dapat mengejek objek, ejekan memberikan fleksibiliti dan kemudahan yang lebih besar bagi pemaju yang ingin memastikan ujian unit mereka tidak terjejas oleh kelas lain.
Apakah simulasi?

Mengejar objek tidak lebih daripada membuat objek pengganti yang menggantikan objek sebenar dalam ujian unit. Jika permohonan anda sangat bergantung kepada suntikan pergantungan, mengejek adalah cara yang baik.

Mungkin ada beberapa sebab untuk mengejek objek:

    Adalah lebih baik untuk mengasingkan kelas apabila melakukan ujian unit. Anda tidak mahu kelas atau perkhidmatan lain mengganggu ujian unit anda.
  1. Objek belum wujud. Anda boleh membuat ujian terlebih dahulu dan kemudian membina objek akhir.
  2. Objek mock biasanya lebih cepat daripada menyediakan keseluruhan pangkalan data untuk ujian.
anda mungkin menggunakan phpunit semasa menjalankan ujian unit. PHPUnit dilengkapi dengan beberapa ciri simulasi lalai seperti yang ditunjukkan dalam dokumentasi. Anda boleh membaca lebih lanjut mengenai simulasi dan keupayaan simulasi PHPUnit dalam artikel ini yang ditulis oleh Jeune Asuncion.

Dalam artikel ini, kita akan menyelam ke dalam ejekan perpustakaan yang dicipta oleh Pádraic Brady. Kami akan membuat kelas suhu yang akan menyuntik perkhidmatan cuaca yang tidak wujud sekarang.

Tetapan

mari kita mulakan dengan menubuhkan projek. Kami bermula dengan fail komposer.json yang mengandungi kandungan berikut. Ini akan memastikan kami mempunyai ejekan dan phpunit.

<code>{
    "name": "sitepoint/weather",
    "license": "MIT",
    "type": "project",
    "require": {
        "php": ">=5.3.3"
    },
    "autoload": {
        "psr-0": { "": "src/" }
    },
    "require-dev": {
        "phpunit/phpunit": "4.1.*",
        "mockery/mockery": "0.9.*"
    }
}</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
kami juga membuat fail konfigurasi phpUnit yang dipanggil phpunit.xml

<phpunit>
    <testsuite name="SitePoint Weather">
        <directory>./tests</directory>
    </testsuite>
    <listeners>
        <listener class="\Mockery\Adapter\Phpunit\TestListener"
                  file="vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php"/>
    </listeners>
</phpunit>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Adalah penting untuk menentukan pendengar ini. Sekiranya tidak ada pendengar, jika kaedah

, once() dan twice() digunakan dengan tidak betul, tiada kesilapan akan dibangkitkan. Ini akan diterangkan secara terperinci kemudian. times()

Saya juga membuat 2 direktori. Direktori SRC digunakan untuk memegang kelas saya, dan direktori ujian digunakan untuk menyimpan ujian kami. Dalam direktori SRC, saya mencipta laluan SitePointweather.

kita mula -mula membuat WeatherServiceInterface. Perkhidmatan cuaca yang tidak wujud akan melaksanakan antara muka ini. Dalam kes ini kita hanya menyediakan satu kaedah yang akan memberi kita suhu Celsius.

<code>{
    "name": "sitepoint/weather",
    "license": "MIT",
    "type": "project",
    "require": {
        "php": ">=5.3.3"
    },
    "autoload": {
        "psr-0": { "": "src/" }
    },
    "require-dev": {
        "phpunit/phpunit": "4.1.*",
        "mockery/mockery": "0.9.*"
    }
}</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Oleh itu, kita mempunyai perkhidmatan yang memberikan kita suhu Celsius. Saya mahu mendapatkan Fahrenheit. Untuk melakukan ini, saya mencipta kelas baru yang dipanggil TemperatureService. Perkhidmatan ini akan menyuntik perkhidmatan cuaca. Di samping itu, kami juga menentukan kaedah yang menukarkan Celsius kepada Fahrenheit.

<phpunit>
    <testsuite name="SitePoint Weather">
        <directory>./tests</directory>
    </testsuite>
    <listeners>
        <listener class="\Mockery\Adapter\Phpunit\TestListener"
                  file="vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php"/>
    </listeners>
</phpunit>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Buat Ujian Unit

Kami bersedia untuk menubuhkan ujian unit. Kami membuat kelas temperatureServicetest dalam direktori ujian. Dalam kelas ini kita membuat kaedah

yang akan menguji kaedah Fahrenheit kami. testGetTempFahrenheit()

Langkah pertama yang perlu dilakukan dalam kaedah ini adalah untuk membuat objek Suhu Suhu baru. Sama seperti kita melakukan ini, pembina kita akan meminta objek yang melaksanakan WeatherServiceInterface. Oleh kerana kita tidak mempunyai objek seperti itu (kita tidak mahu sama ada), kita akan menggunakan ejekan untuk membuat objek mengejek untuk kita. Mari lihat bagaimana kaedahnya selepas selesai.

namespace SitePoint\Weather;

interface WeatherServiceInterface
{
    /**
     * 返回摄氏温度
     *
     * @return float
     */
    public function getTempCelsius();
}
Salin selepas log masuk
kita mula -mula membuat objek mengejek. Kami memberitahu penghinaan yang objek (atau antara muka) kami mahu mengejek. Langkah kedua adalah untuk menerangkan kaedah yang akan dipanggil pada objek mock ini. Dalam kaedah

, kami menentukan nama kaedah yang akan dipanggil. shouldReceive()

Kami mentakrifkan bilangan kali kaedah ini akan dipanggil. Kita boleh menggunakan

, once() dan twice(). Dalam kes ini, kami mengharapkan ia dipanggil hanya sekali. Jika tidak dipanggil atau panggilan berlebihan dipanggil, ujian unit akan gagal. times(X)

Akhirnya, kita menentukan nilai yang akan dikembalikan dalam kaedah

. Dalam kes ini, kami kembali 25. Mockery juga mempunyai kaedah pulangan seperti andReturn(), andReturnNull() dan andReturnSelf(). Jika itulah yang anda harapkan, penghinaan boleh membuang pengecualian juga. andReturnUndefined()

Kami kini mempunyai objek mengejek yang boleh membuat objek suhu kami dan mengujinya seperti biasa. 25 darjah Celsius adalah 77 darjah Fahrenheit, jadi kami periksa sama ada kami menerima 77 dari kaedah

kami. getTempFahrenheit()

Jika anda menjalankan

dalam direktori root anda, anda akan mendapat cahaya hijau dari phpunit, menunjukkan bahawa semuanya sempurna. vendor/bin/phpunit tests/

Penggunaan lanjutan

Contoh di atas agak mudah. Tiada parameter, hanya panggilan mudah. Mari buat perkara lebih rumit.

Katakan perkhidmatan cuaca kami juga mempunyai cara untuk mendapatkan suhu pada waktu yang tepat. Kami menambah kaedah berikut untuk WeatherServiceInterface semasa kami.

namespace SitePoint\Weather;

class TemperatureService
{
    /**
     * @var WeatherServiceInterace $weatherService 保存天气服务
     */
    private $weatherService;

    /**
     * 构造函数。
     *
     * @param WeatherServiceInterface $weatherService
     */
    public function __construct(WeatherServiceInterface $weatherService) {
        $this->weatherService = $weatherService;
    }

    /**
     * 获取当前华氏温度
     *
     * @return float
     */
    public function getTempFahrenheit() {
        return ($this->weatherService->getTempCelsius() * 1.8000) + 32;
    }
}
Salin selepas log masuk
Kami ingin tahu apa suhu purata antara jam 0:00 dan 6:00 petang. Untuk melakukan ini, kami membuat kaedah baru dalam suhu untuk mengira suhu purata. Untuk melakukan ini, kami mengambil 7 suhu dari Weatherservice dan mengira purata.

<code>{
    "name": "sitepoint/weather",
    "license": "MIT",
    "type": "project",
    "require": {
        "php": ">=5.3.3"
    },
    "autoload": {
        "psr-0": { "": "src/" }
    },
    "require-dev": {
        "phpunit/phpunit": "4.1.*",
        "mockery/mockery": "0.9.*"
    }
}</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Mari kita lihat kaedah ujian kami.

<phpunit>
    <testsuite name="SitePoint Weather">
        <directory>./tests</directory>
    </testsuite>
    <listeners>
        <listener class="\Mockery\Adapter\Phpunit\TestListener"
                  file="vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php"/>
    </listeners>
</phpunit>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Kami mensimulasikan antara muka sekali lagi dan menentukan kaedah yang akan dipanggil. Seterusnya, kami menentukan bilangan kali kaedah ini akan dipanggil. Kami menggunakan once() dalam contoh sebelumnya, dan sekarang kami menggunakan times(7) untuk menunjukkan bahawa kami mengharapkan kaedah ini dipanggil 7 kali. Jika kaedah itu tidak dipanggil tepat 7 kali, ujian akan gagal. Jika anda tidak menentukan pendengar dalam fail konfigurasi phpUnit.xml, anda tidak akan menerima pemberitahuan mengenai perkara ini.

Seterusnya, kami menentukan kaedah with(). Dalam kaedah with, anda boleh menentukan parameter yang anda harapkan. Dalam kes ini, kami mengharapkan 7 jam yang berbeza.

Akhirnya, kita mempunyai kaedah andReturn(). Dalam kes ini, kami menunjukkan 7 nilai pulangan. Jika anda menentukan nilai pulangan yang lebih sedikit, nilai pulangan yang tersedia terakhir akan diulang setiap kali.

Sudah tentu, ejekan boleh berbuat lebih banyak. Untuk panduan dan dokumentasi lengkap, saya cadangkan anda menyemak halaman GitHub.

Jika anda berminat dengan kod projek di atas, anda boleh menyemak halaman GitHub ini.

Kesimpulan

Menggunakan phpunit, anda sudah boleh mengejek objek. Walau bagaimanapun, anda juga boleh menggunakan penghinaan seperti yang dijelaskan dalam contoh di atas. Jika anda menguji unit kelas anda dan anda tidak mahu kelas lain mempengaruhi ujian anda, ejekan dapat membantu anda dengan mudah. Jika anda benar -benar mahu melakukan ujian berfungsi, lebih baik untuk melihat sama ada anda boleh mengintegrasikan ujian sebenar. Adakah anda sedang menggunakan simulasi phpunit dan mempertimbangkan untuk beralih ke penghinaan? Adakah anda ingin melihat lebih banyak contoh ejekan yang lebih besar dalam jawatan berikutnya? Tolong beritahu saya dalam komen di bawah.

Soalan Lazim Mengenai Pengejaran dan Ujian Kebergantungan (FAQ)

Apa itu ejekan dan mengapa penting dalam ujian PHP?

Mockery adalah rangka kerja objek php mock yang kuat dan fleksibel untuk ujian unit. Ia direka sebagai alternatif langsung kepada fungsi objek mock phpunit. Penghinaan membolehkan pemaju mengasingkan kod yang diuji dan membuat ujian stand-in yang mensimulasikan tingkah laku objek kompleks. Ini penting dalam ujian unit kerana ia memastikan bahawa kod yang diuji tidak bergantung kepada faktor luaran atau keadaan.

Bagaimana untuk memasang dan menyiapkan penghinaan dalam projek PHP saya?

Untuk memasang penghinaan, anda perlu mempunyai komposer, pengurus pergantungan PHP. Anda boleh memasang penghinaan dengan menjalankan arahan composer require --dev mockery/mockery. Selepas pemasangan, anda boleh menyediakan penghinaan dalam fail ujian dengan memanggil Mockery::close() dalam kaedah Test Tearown untuk membersihkan objek mengejek.

bagaimana membuat objek mengejek menggunakan ejekan?

Mewujudkan objek mengejek dalam ejekan adalah mudah. Anda boleh menggunakan kaedah mock() untuk membuat objek mengejek. Sebagai contoh, $mock = Mockery::mock('MyClass'); akan membuat objek mengejek untuk MyClass.

Bagaimana untuk menentukan jangkaan dalam ejekan?

Dalam penghinaan, anda menentukan jangkaan dengan menghubungkan kaedah untuk mengejek objek. Sebagai contoh, $mock->shouldReceive('myMethod')->once()->andReturn('mocked value'); kod ini memberitahu penghinaan yang mengharapkan "mymethod" dipanggil sekali dan harus kembali "nilai mengejek".

Apakah perbezaan antara simulasi dan stub dalam ejekan?

Dalam ejekan, mengejek adalah objek di mana kita boleh menetapkan yang dikehendaki, sementara stub adalah objek mengejek yang mempunyai respons pra-program. Apabila tindak balas adalah satu -satunya perkara yang penting, stub biasanya digunakan, dan apabila menguji interaksi itu sendiri, mengejek digunakan.

Bagaimana menggunakan ejekan untuk menguji kaedah peribadi?

Tidak disyorkan untuk menguji kaedah peribadi secara langsung kerana ia melanggar prinsip enkapsulasi. Walau bagaimanapun, jika anda mahu, anda boleh menggunakan kaedah shouldAllowMockingProtectedMethods() dalam penghinaan untuk membolehkan kaedah yang dilindungi dan peribadi yang dihina.

Bagaimana menangani parameter pembina dalam ejekan?

Jika kelas yang anda mahu mensimulasikan mempunyai pembina dengan argumen, anda boleh lulus sebagai array ke kaedah mock(). Sebagai contoh, $mock = Mockery::mock('MyClass', [$arg1, $arg2]); akan lulus $ Arg1 dan $ Arg2 kepada pembina MyClass.

Bagaimana menggunakan ejekan untuk mensimulasikan kaedah statik?

Mockery menyediakan kaedah untuk mensimulasikan kaedah statik menggunakan prefix alias:. Sebagai contoh, $mock = Mockery::mock('alias:MyClass'); akan membuat objek mengejek yang boleh digunakan untuk menetapkan tetapan yang dikehendaki kaedah statik MyClass.

Bagaimana untuk mengesahkan bahawa semua jangkaan dipenuhi dalam ejekan?

anda boleh menggunakan kaedah Mockery::close() dalam kaedah pembongkaran ujian untuk mengesahkan bahawa semua jangkaan telah dipenuhi. Jika apa -apa jangkaan tidak dipenuhi, ejekan akan membuang pengecualian.

Bagaimana menangani pengecualian dalam ejekan?

anda boleh menggunakan kaedah andThrow() untuk menubuhkan objek mengejek untuk membuang pengecualian. Sebagai contoh, $mock->shouldReceive('myMethod')->andThrow(new Exception); akan membuang pengecualian apabila "mymethod" dipanggil.

Atas ialah kandungan terperinci Mengejutkan Dependensi Ujian Anda Dengan Penghinaan. 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!

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)

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Apr 06, 2025 am 12:02 AM

Sesi rampasan boleh dicapai melalui langkah -langkah berikut: 1. Dapatkan ID Sesi, 2. Gunakan ID Sesi, 3. Simpan sesi aktif. Kaedah untuk mengelakkan rampasan sesi dalam PHP termasuk: 1. Gunakan fungsi Sesi_Regenerate_ID () untuk menjana semula ID Sesi, 2. Data sesi stor melalui pangkalan data, 3.

Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Apr 03, 2025 am 12:04 AM

Penerapan prinsip pepejal dalam pembangunan PHP termasuk: 1. Prinsip Tanggungjawab Tunggal (SRP): Setiap kelas bertanggungjawab untuk hanya satu fungsi. 2. Prinsip Terbuka dan Tutup (OCP): Perubahan dicapai melalui lanjutan dan bukannya pengubahsuaian. 3. Prinsip Penggantian Lisch (LSP): Subkelas boleh menggantikan kelas asas tanpa menjejaskan ketepatan program. 4. Prinsip Pengasingan Antara Muka (ISP): Gunakan antara muka halus untuk mengelakkan kebergantungan dan kaedah yang tidak digunakan. 5. Prinsip Inversi Ketergantungan (DIP): Modul peringkat tinggi dan rendah bergantung kepada abstraksi dan dilaksanakan melalui suntikan ketergantungan.

Bagaimana cara debug mod CLI dalam phpstorm? Bagaimana cara debug mod CLI dalam phpstorm? Apr 01, 2025 pm 02:57 PM

Bagaimana cara debug mod CLI dalam phpstorm? Semasa membangun dengan PHPStorm, kadang -kadang kita perlu debug PHP dalam mod Interface Line Command (CLI) ...

Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Mar 31, 2025 pm 11:54 PM

Bagaimana untuk menetapkan keizinan UnixSocket secara automatik selepas sistem dimulakan semula. Setiap kali sistem dimulakan semula, kita perlu melaksanakan perintah berikut untuk mengubahsuai keizinan UnixSocket: sudo ...

Terangkan pengikatan statik lewat dalam php (statik: :). Terangkan pengikatan statik lewat dalam php (statik: :). Apr 03, 2025 am 12:04 AM

Mengikat statik (statik: :) Melaksanakan pengikatan statik lewat (LSB) dalam PHP, yang membolehkan kelas panggilan dirujuk dalam konteks statik dan bukannya menentukan kelas. 1) Proses parsing dilakukan pada masa runtime, 2) Cari kelas panggilan dalam hubungan warisan, 3) ia boleh membawa overhead prestasi.

Ciri -ciri Keselamatan Rangka Kerja: Melindungi Kelemahan. Ciri -ciri Keselamatan Rangka Kerja: Melindungi Kelemahan. Mar 28, 2025 pm 05:11 PM

Artikel membincangkan ciri -ciri keselamatan penting dalam rangka kerja untuk melindungi daripada kelemahan, termasuk pengesahan input, pengesahan, dan kemas kini tetap.

See all articles