1 | <?php |
||
11 | trait MatchesSnapshots |
||
12 | { |
||
13 | public function assertMatchesSnapshot($actual, Driver $driver = null) |
||
19 | |||
20 | public function assertMatchesXmlSnapshot($actual) |
||
24 | |||
25 | public function assertMatchesJsonSnapshot($actual) |
||
29 | |||
30 | /** |
||
31 | * Determines the snapshot's id. By default, the test case's class and |
||
32 | * method names are used. |
||
33 | * |
||
34 | * @return string |
||
35 | */ |
||
36 | protected function getSnapshotId(): string |
||
40 | |||
41 | /** |
||
42 | * Determines the directory where snapshots are stored. By default a |
||
43 | * `__snapshots__` directory is created at the same level as the test |
||
44 | * class. |
||
45 | * |
||
46 | * @return string |
||
47 | */ |
||
48 | protected function getSnapshotDirectory(): string |
||
54 | |||
55 | /** |
||
56 | * Determines whether or not the snapshot should be updated instead of |
||
57 | * matched. |
||
58 | * |
||
59 | * Override this method it you want to use a different flag or mechanism |
||
60 | * than `-d --update-snapshots`. |
||
61 | * |
||
62 | * @return bool |
||
63 | */ |
||
64 | protected function shouldUpdateSnapshots(): bool |
||
68 | |||
69 | protected function createSnapshotWithDriver(Driver $driver): Snapshot |
||
77 | |||
78 | protected function doSnapShotAssertion(Snapshot $snapshot, $actual) |
||
101 | } |
||
102 |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idable
provides a methodequalsId
that in turn relies on the methodgetId()
. If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()
as an abstract method to the trait will make sure it is available.