144

Why I'm getting this PHP error?

Fatal error: Class 'PHPUnit_Framework_TestCase' not found in ...
3
  • 11
    You are not providing any information at all. Commented May 19, 2011 at 22:55
  • Run your tests via the phpunit command-line. It loads up the necessary classes. Commented May 24, 2016 at 17:05
  • You can also use the answer from the following answer stackoverflow.com/questions/42811164/… to keep your code compatible with PHPUnit 6 as well as earlier versions. Commented Jun 15, 2017 at 16:25

15 Answers 15

285

For those arriving here after updating phpunit to version 6 or greater released on 2017-02-03 (e.g. with composer), you may be getting this error because phpunit code is now namespaced (check changelog changelog ).

You will need to refactor things like \PHPUnit_Framework_TestCase to \PHPUnit\Framework\TestCase

Update 2023-03-30: updated changelog link based on comment

Sign up to request clarification or add additional context in comments.

5 Comments

Thanks, I had this problem due to Travis CI using the most recent PHPUnit version on their PHP 7 builds. My fix was to manually download an old phar and use that instead.
github.com/sebastianbergmann/phpunit/wiki/… it's on the top of the release notes, yet I missed it
Thank ye kindly, good sir. I am indeed arriving here after upgrading to version 6.
I was getting really annoyed that my tests suddenly stopped working. I did a composer update and it updated my PHPunit to 6.1. Thank You.
Here is an update link as linked file is gone in phpunit repository: (check changelog)
74

The PHPUnit documentation says used to say to include/require PHPUnit/Framework.php, as follows:

require_once ('PHPUnit/Framework/TestCase.php');

UPDATE

As of PHPUnit 3.5, there is a built-in autoloader class that will handle this for you:

require_once 'PHPUnit/Autoload.php';

Thanks to Phoenix for pointing this out!

8 Comments

PHPUnit 3.5 comes with its own autoloader that might help keep things simple: require_once 'PHPUnit/Autoload.php'
I concur that require_once('PHPUnit/Autoload.php') is the best practice.
I don't have both PHPUnit/Autoload.php and PHPUnit/Framework/TestCase.php, my folder is kind of like PHPUnit/Framework/MockObject
and now I have PHP Fatal error: require_once(): Failed opening required 'PHPUnit/Autoload.php'
see @shadi's answer for PHP 6+ stackoverflow.com/a/42561590/2883328
|
54

For higher version of phpunit such as 6.4 You must use the namespace PHPUnit\Framework\TestCase

use TestCase instead PHPUnit_Framework_TestCase

// use the following namespace
use PHPUnit\Framework\TestCase;

// extend using TestCase instead PHPUnit_Framework_TestCase
class SampleTest extends TestCase {

}

4 Comments

Excellent this worked for me as I was following an old tutorial
you just copied shadi's answer
@Adam who is shadi?
I don't know such a thing. I got same error then I explore answer by cracking the package
16

I was running PHPUnit tests on PHP5, and then, I needed to support PHP7 as well. This is what I did:

In composer.json:

"phpunit/phpunit": "~4.8|~5.7"

In my PHPUnit bootstrap file (in my case, /tests/bootstrap.php):

// PHPUnit 6 introduced a breaking change that
// removed PHPUnit_Framework_TestCase as a base class,
// and replaced it with \PHPUnit\Framework\TestCase
if (!class_exists('\PHPUnit_Framework_TestCase') && class_exists('\PHPUnit\Framework\TestCase'))
    class_alias('\PHPUnit\Framework\TestCase', '\PHPUnit_Framework_TestCase');

In other words, this will work for tests written originally for PHPUnit 4 or 5, but then needed to work on PHPUnit 6 as well.

1 Comment

this solution important if you want to not touch Civi\Test code but need compatible with latest namespace based php unit test
13

You may get this error because you namespaced the file. If so you will need to specify that PHPUnit_Framework_TestCase is in the global namespace by preceding it with a backslash:

namespace AcmeInc\MyApplication\Tests
class StackTest extends \PHPUnit_Framework_TestCase {}

I submitted a crude PR to start conversation for correcting the documentation.

1 Comment

Yes, if you did this: class YourNiceTest extends PHPUnit_Framework_TestCase just add the \ in front of the extended class, like in class YourNiceTest extends \PHPUnit_Framework_TestCase - This worked for me, using Symfony 2.8 and including the phpunit in the composer file downloaded as a local dependency with "phpunit/phpunit": "^4.8"
6

You can simply install PHPUnit to run commands (https://github.com/sebastianbergmann/phpunit/#php-archive-phar):

wget https://phar.phpunit.de/phpunit.phar
chmod +x phpunit.phar
mv phpunit.phar /usr/local/bin/phpunit

Run single test

And then run PHPunit test:

phpunit test.php

Content of test file is following:

<?php

class StackTest extends PHPUnit_Framework_TestCase
{
    protected function setUp()
    {
    }

    public function testSave()
    {

    }
}

Run test suite

Configuration of test suite: demosuite.xml. demo is directory containing all tests. Test files must be named as *_test.php (suffix).

<testsuites>
    <testsuite name="DemoTestSuite">
        <directory suffix="test.php">demo</directory>
    </testsuite>
</testsuites>

Test suite runs with following commands:

phpunit -c demosuite.xml --testsuite DemoTestSuite

2 Comments

This no longer works because latests PHPUnit no longer supports old class names such as PHPUnit_Framework_TestCase. You really have to use ... extends PHPUnit\Framework\TestCase
Just saying that I had to first mv phpunit /usr/local/bin/phpunit and then sudo chmod +x /usr/local/bin/phpunit. Setting file as executable before moving it never worked on Vagrant Ubuntu. No idea why... But in case someone is struggling with this, I hope this will help.
4

Assumption:

Phpunit (3.7) is available in the console environment.

Action:

Enter the following command in the console:

SHELL> phpunit "{{PATH TO THE FILE}}"

Comments:

You do not need to include anything in the new versions of PHPUnit unless you do not want to run in the console. For example, running tests in the browser.

Comments

1

I use ZF2 and work for me when replaced 'PHPUnit_Framework_TestCase' to '\PHPUnit\Framework\TestCase'

Comments

1

I got it working with

include("vendor/autoload.php");

at the top of my test function.

Comments

0

If you have Centos or other Linux distribution you have to install phpunit package, I did that with yum install phpunit and it worked. Maybe you can have to add a repository, but I think it has to work smooth with the default ones (I have CentOS 7)

Comments

0

It may well be that you're running WordPress core tests, and have recently upgraded your PhpUnit to version 6. If that's the case, then the recent change to namespacing in PhpUnit will have broken your code.

Fortunately, there's a patch to the core tests at https://core.trac.wordpress.org/changeset/40547 which will work around the problem. It also includes changes to travis.yml, which you may not have in your setup; if that's the case then you'll need to edit the .diff file to ignore the Travis patch.

  1. Download the "Unified Diff" patch from the bottom of https://core.trac.wordpress.org/changeset/40547
  2. Edit the patch file to remove the Travis part of the patch if you don't need that. Delete from the top of the file to just above this line:

    Index: /branches/4.7/tests/phpunit/includes/bootstrap.php
    
  3. Save the diff in the directory above your /includes/ directory - in my case this was the Wordpress directory itself

  4. Use the Unix patch tool to patch the files. You'll also need to strip the first few slashes to move from an absolute to a relative directory structure. As you can see from point 3 above, there are five slashes before the include directory, which a -p5 flag will get rid of for you.

    $ cd [WORDPRESS DIRECTORY]
    $ patch -p5 < changeset_40547.diff 
    

After I did this my tests ran correctly again.

Comments

0

NOTICE: Command php bin/console generate:doctrine:crud also create TestController in src/Tests so it can throw error when you tried to start server if you don't have UnitTests. Remove the file fix it!

Comments

0

For me, it was because I ran

$ phpunit .

instead of

$ phpunit

when I already had a configured phpunit.xml file in the working directory.

Comments

0

I am using php 5.6 on window 10 with zend 1.12 version for me adding

require_once 'PHPUnit/Autoload.php';

before

abstract class Zend_Test_PHPUnit_ControllerTestCase extends PHPUnit_Framework_TestCase

worked. We need to add this above statement in ControllerTestCase.php file

Comments

0

PHPUnit With Composer Autoloader

I am using composer and found myself battling through this issue. Neither the old style (PHPUnit_Framekwork_TestCase) or the new style (\PHPUnit\Framework\TestCase) worked for me. After reading through all the answers here and elsewhere, I found it to be quite trivial.

NOTE: PHP namespaces are case insensitive, however composer is case-sensitive...

// WRONG
class TestChild extends \PhpUnit\Framework\TestCase {

// RIGHT
class TestChild extends \PHPUnit\Framework\TestCase {

In the above example, note the change from \PhpUnit\... to \PHPUnit\....
This makes all the difference with the composer autoloader.

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.