Lesson 4 - PHPUnit DataProvider and BestPractices

PHP Testing PHPUnit DataProvider and BestPractices

In the previous lesson, PHP Testing - Finishing Unit Tests, we covered a class representing a simple calculator with unit tests. We gained an overview of assert methods and learned to test exceptions. Today, in PHPUnit, we're going to learn to use another annotation to help us follow the DRY principle and we'll mention the best practices for testing in PHP.


We already know the @expectedException annotation that allows us to test that a given test triggered a given exception. In our tests, we'll often encounter a situation that we write a test and want to run the same test on different data to see that different inputs will pass. Creating methods for each input, that would have the same body and differ only in data, would be a violation of the DRY principle (Don't Repeat Yourself).

To show this example in practice, let's consider our calculator has a sin() method, which accepts an angle in radians and returns the value of the sine function for that angle. The method implementation in the calculator could be as follows (remember this is an example of a class method that we're going to test here, so we can feel free to just call the already existing PHP function):

public function sine($angle)
        return sin($angle);

In the tests, it'd be a good idea to test some extreme values, values of right angles, negative values, zero... you know :)

Consider we want to test the method using degrees and not radians. We'll do that to need to call some extra methods or even use other objects (dependencies) to get the output:


...End of the preview...

Premium article

Premium article

ict.social is a large database made up of manuals and tutorials, whose main goal is to provide high-quality IT education to everyone. We started out in the Czech republic, where we display roughly a million articles per month and receive plenty of gratitude from our users. Thanks to our successful establishment, we are now bringing these articles to the rest of the world.

Although we are trying to keep our content free of charge, maintaining the site is a huge effort for everyone involved. Therefore, some content (exercises and more advanced material) costs network points. Don't worry, they're really cheap :)

Article description

Requested article covers this content:

In the tutorial, we'll learn to use the @dataProvider annotation, test private and protected methods, and mention best practices for PHP testing.

Buy just this article

To access the article, you need 24 points
Currently, you have 0 points
You gain 24 points for adding an article to the site, or for $2.16

Buying this article gives you unlimited access to it forever. You will learn some more and help us keep giving our site maintenance which helps you and others get better futures. It's a win-win.

This article is licensed :Premium III, by buying this article, you agree with the terms of use.

You gain points by supporting our network. This is done by sending a helpful amount of money to support the site, or by creating content for the network.

You can get points immediately using:

Credit card SMS Wire transfer
Credit card SMS Wire transfer


Article has been written for you by David Capka
The author is a programmer, who likes web technologies and being the lead/chief article writer at ICT.social. He shares his knowledge with the community and is always looking to improve. He believes that anyone can do what they set their mind to.
Unicorn College The author learned IT at the Unicorn College - a prestigious college providing education on IT and economics.
All articles in this section
Testing in PHP
Activities (2)