I'm attempting to create a Mockery of CustomObject
then chain the retrieval of OtherObject
onto it using something identical to
$this->CustomObject->with('OtherObject')->get();
I can't seem to figure out how to mock this ->get()
at the end there. I'm mocking both of those models in my constructor method ['Eloquent', 'OtherObject', 'CustomObject']
. If I remove the ->get()
everything runs smoothly and my tests pass (aside from the php errors the view is then giving me, but those don't matter if the test is working correctly).
What I currently have is this:
$this->mock->shouldReceive('with')->once()->with('OtherObject');
$this->app->instance('CustomObject', $this->mock);
What should I be doing to mock this?
Edit: I have specifically attempted ->andReturn($this->mock)
which only tells me that on the mocked object there is no get method.
It looks like I have it. It seems that the previous answer and my attempts were very close. The largest issue with using these is that a method is being called on the return object. If this isn't the best way to do this, I hope someone will correct me though.
and removing `OtherObject' from the constructor method.
You must return an instance of your mock to make the next chaining call (
->get()
) to workYou can use
Mockery::self()
to define chained expectations with arguments.In some cases you may need to split it up into two mocks: