


PHPUnit starts from scratch (1): starting from its installation configuration
It’s a new year again. I was thinking about what to write in 2016. What would be a better start? Then I have been struggling between PHPUnit and design patterns. In the end, I decided to start the new year with PHPUnit.
PHPUnit is also new knowledge for me. When I used Laravel before, I only briefly learned about it and never really practiced it. I always thought that I was going to spend a month studying such a cool thing. As a result... the installation took me half a day, and the rest was nothing.
I would like to add here that my environment is as follows:
xampp (php5.6) + win7
There are pitfalls in the installation, please be careful
Why did it take me half a day to install? Alas, it’s all tears. If I don’t learn my lesson, I’ll find some expired documents and it won’t work. Finally, I found the answer I wanted in the official documentation. The official website has already made it very clear, but I will say it again here, why? Make up the word count! Hehe, of course I won't be so shameless, mainly because xampp has installed phpunit by itself (very old version, so it needs to be reinstalled). I will focus on how to overwrite its own phpunit.
I’m being lazy here and just screenshot the content from the official website.
The following are the key points:
The official website says to configure environment variables here, everyone must be careful. To give my own example, I installed xampp in D:xampp and configured the php location of xampp in the environment variables. So if I configure the newly downloaded phpunit in this directory, when using phpunit, I still use the one that comes with xampp. So remember to configure your newly downloaded phpunit before xampp.
After completing the above operations, please open Command (Win+R) and enter: phpunit –version. If you see the following effect, it means you have completed the installation:
Test's test
Now you need to try our phpunit. I will post the code directly here first, and I will explain why at the beginning of the next article.
For the sake of simplicity here, I wrote the classes that need to be tested and the test cases in a file. Definitely don't do this during use.
<code><span><?php </span><span>/** *<span> @author</span>: helei *<span> @createTime</span>: 2016-01-15 09:45 *<span> @description</span>: */</span><span><span>class</span><span>TryClass</span> {</span><span>public</span><span><span>function</span><span>getValue</span><span>()</span> {</span><span>return</span><span>1</span>; } } <span><span>class</span><span>TryTest</span><span>extends</span><span>PHPUnit_Framework_TestCase</span> {</span><span>public</span><span><span>function</span><span>testValue</span><span>()</span> {</span><span>$try</span> = <span>new</span> TryClass(); <span>$this</span>->assertEquals(<span>1</span>, <span>$try</span>->getValue()); } }</span></code>
Then go to the directory where the file is located and run phpunit:
This picture shows the correct situation. You can try changing the value to other values.
Oh, I also need to mention here that the problem with the PHPUnit_Framework_TestCase class is that after installing phpunit, this class will not exist. You need to install the phpunit libary through composer. The content of the composer.json file is as follows:
<code>{ "<span>require</span>" : <span>{ }</span>, "<span>require-dev</span>" : <span>{ "<span>phpunit/phpunit</span>": <span><span>"5.1"</span></span>} </span>}</code>
Even if we have completed the phpunit today, it may not be detailed enough, but if you use more hands-on work, it should not be a problem.
I originally wanted to release it on New Year's Day, but since I just changed my job at the end of the year, and when I first arrived at the new company, I had to release a major version, so I worked overtime and finally completed the development task yesterday. Today I take this opportunity to write the beginning of 2016, and then casually talk about my study plan for 2016. I write it here to remind myself not to forget it.
2016 Learning Plan
For my following learning plan, I will adopt a blog-driven approach, that is, to learn a skill, I will complete the blog content of the corresponding skill, firstly, to deepen the learning level, secondly, to encourage everyone, and thirdly. Come... forget it, I won't come. Anyway, I will write it after I learn it. Corrections to incorrect addresses are welcome.
- Plan 1: PHPUnit learning, this plan has started, and I will try to complete all the blog content in February (in fact, all the learning has been completed).
- Plan 2: I have always looked at design patterns before, but only in theory. This time I plan to write about design patterns based on practice and my own understanding. All codes will eventually be put on github, and of course each blog will also have relevant code.
- Plan 3: We need to take a look at the implementation process of laravel. It has always been an application before. This time we plan to go deep into the framework and take a look at the implementation of its framework code.
- Plan 4: Well, learn a new language, GO. Because I have used Qiniu's service, it feels really good, and it is all implemented in GO language, so I plan to learn it myself, which can be regarded as a supplement.
The words have been released. If 2016 is not completed, it will be a slap in the face. Would I let myself be slapped in the face? Who knows! Hahaha
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });The above introduces PHPUnit from scratch (1): starting from its installation and configuration, including aspects of the content, I hope it will be helpful to friends who are interested in PHP tutorials.

PHPisusedforsendingemailsduetoitsintegrationwithservermailservicesandexternalSMTPproviders,automatingnotificationsandmarketingcampaigns.1)SetupyourPHPenvironmentwithawebserverandPHP,ensuringthemailfunctionisenabled.2)UseabasicscriptwithPHP'smailfunct

The best way to send emails is to use the PHPMailer library. 1) Using the mail() function is simple but unreliable, which may cause emails to enter spam or cannot be delivered. 2) PHPMailer provides better control and reliability, and supports HTML mail, attachments and SMTP authentication. 3) Make sure SMTP settings are configured correctly and encryption (such as STARTTLS or SSL/TLS) is used to enhance security. 4) For large amounts of emails, consider using a mail queue system to optimize performance.

CustomheadersandadvancedfeaturesinPHPemailenhancefunctionalityandreliability.1)Customheadersaddmetadatafortrackingandcategorization.2)HTMLemailsallowformattingandinteractivity.3)AttachmentscanbesentusinglibrarieslikePHPMailer.4)SMTPauthenticationimpr

Sending mail using PHP and SMTP can be achieved through the PHPMailer library. 1) Install and configure PHPMailer, 2) Set SMTP server details, 3) Define the email content, 4) Send emails and handle errors. Use this method to ensure the reliability and security of emails.

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

The reason for using Dependency Injection (DI) is that it promotes loose coupling, testability, and maintainability of the code. 1) Use constructor to inject dependencies, 2) Avoid using service locators, 3) Use dependency injection containers to manage dependencies, 4) Improve testability through injecting dependencies, 5) Avoid over-injection dependencies, 6) Consider the impact of DI on performance.

PHPperformancetuningiscrucialbecauseitenhancesspeedandefficiency,whicharevitalforwebapplications.1)CachingwithAPCureducesdatabaseloadandimprovesresponsetimes.2)Optimizingdatabasequeriesbyselectingnecessarycolumnsandusingindexingspeedsupdataretrieval.

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Notepad++7.3.1
Easy-to-use and free code editor

WebStorm Mac version
Useful JavaScript development tools
