30 lines
1.2 KiB
Markdown
30 lines
1.2 KiB
Markdown
---
|
||
title: Writing custom PHPStan rules for Drupal projects
|
||
date: 2024-09-22
|
||
permalink: daily/2024/09/22/writing-custom-phpstan-rules-for-drupal-projects
|
||
tags:
|
||
- software-development
|
||
- drupal
|
||
- php
|
||
- phpstan
|
||
cta: ~
|
||
snippet: |
|
||
I wrote a custom PHPStan rule!
|
||
drupal_planet: true
|
||
---
|
||
|
||
Today, I watched a video recording of a session by Ondřej Mirtes - the creator of PHPStan - on writing custom rules for PHPStan.
|
||
|
||
After explaining how to write them, he showed some examples of custom rules - one of which was ensuring a `Person` class couldn't be created outside of a `PersonRepository` class.
|
||
|
||
This seemed straightforward so I thought about how I could do something similar within my [Drupal automated testing email course][0] to check my Drupal code.
|
||
|
||
Similar to Ondřej's example, I wondered if I could enforce that no post nodes should be created outside of the `PostBuilder` class by searching for any code like `Node::create(['type' => 'post'])`.
|
||
|
||
I was able to get a version working quickly and have [posted it as a gist][1].
|
||
|
||
I'm sure some improvements can be made, but it was a successful experiment and something I can see me using more in the future.
|
||
|
||
[0]: {{site.url}}/atdc
|
||
[1]: https://gist.github.com/opdavies/a2f9d92cf3b67db6a64b9fca4e4e6697
|