Skip to content

When a mocked method throws a Throwable the call to the method is not recorded #595

@BladeMF

Description

@BladeMF

Given this code:

$this->prophesize(Publisher::class)
	->processChanges($interval)
		->shouldBeCalled()
		->willThrow(new TypeError())
		->getObjectProphecy()
	->reveal();

when the processChanges method is called, it throws the specified TypeError, but the call is not recorded.

The reason for this are that:

  1. CallCenter catches Exception, not Throwable
  2. Call class requires an ?Exception in the constructor, not Throwable.

IMO it is a perfectly valid assumption that a piece of code can cause a type error. It's not often, but it is a valid case specifically with generated code. I checked that if I just change Exception to Throwable in the two places, it works. Not sure if that breaks some other cases though.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions