Big Parent Class

In some application code, especially older legacy code, we can come across some classes that extend a “big parent class” - a parent class that knows and does too much:

class BigParentClass
{
    public function doesEverything()
    {
        // sets up database connections
        // writes to log files
    }
}

class ChildClass extends BigParentClass
{
    public function doesOneThing()
    {
        // but calls on BigParentClass methods
        $result = $this->doesEverything();
        // does something with $result
        return $result;
    }
}

We want to test our ChildClass and its doesOneThing method, but the problem is that it calls on BigParentClass::doesEverything(). One way to handle this would be to mock out all of the dependencies BigParentClass has and needs, and then finally actually test our doesOneThing method. It’s an awful lot of work to do that.

What we can do, is to do something… unconventional. We can create a runtime partial test double of the ChildClass itself and mock only the parent’s doesEverything() method:

$childClass = \Mockery::mock('ChildClass')->makePartial();
$childClass->shouldReceive('doesEverything')
    ->andReturn('some result from parent');

$childClass->doesOneThing(); // string("some result from parent");

With this approach we mock out only the doesEverything() method, and all the unmocked methods are called on the actual ChildClass instance.