# Adding assertions Psalm has four docblock annotations that allow you to specify that a function verifies facts about variables and properties: - `@psalm-assert` (used when throwing an exception) - `@psalm-assert-if-true`/`@psalm-assert-if-false` (used when returning a `bool`) - `@psalm-if-this-is` (used when calling a method) A list of acceptable assertions [can be found here](assertion_syntax.md). ## Examples If you have a class that verified its input is an array of strings, you can make that clear to Psalm: ```php isValid(); } /** * @psalm-assert-if-false B $a */ function isInvalidB(A $a) : bool { return !$a instanceof B || !$a->isValid(); } function takesA(A $a) : void { if (isValidB($a)) { $a->bar(); } if (isInvalidB($a)) { // do something } else { $a->bar(); } $a->bar(); //error } ``` As well as getting Psalm to understand that the given data must be a certain type, you can also show that a variable must be not null: ```php exception * @psalm-assert-if-true Exception $this->getException() */ public function hasException(): bool { return $this->exception !== null; } public function getException(): ?Exception { return $this->exception; } public function foo(): void { if( $this->hasException() ) { // Psalm now knows that $this->exception is an instance of Exception echo $this->exception->getMessage(); } } } $result = new Result; if( $result->hasException() ) { // Psalm now knows that $result->getException() will return an instance of Exception echo $result->getException()->getMessage(); } ``` Please note that the example above only works if you enable [method call memoization](https://psalm.dev/docs/running_psalm/configuration/#memoizemethodcallresults) in the config file or annotate the class as [immutable](https://psalm.dev/docs/annotating_code/supported_annotations/#psalm-immutable). You can also make sure, when calling a method, that its object has some specific template arguments: ```php data = $data; } /** * @psalm-if-this-is a */ public function test(): void { } } $i = new a(123); $i->test(); $i = new a("test"); // IfThisIsMismatch - Class is not a as required by psalm-if-this-is $i->test(); ```