From 0d5b938a94d527dde845d693ca7a518f03b93ad9 Mon Sep 17 00:00:00 2001 From: Shish Date: Fri, 16 Feb 2024 22:20:19 +0000 Subject: [PATCH] Create CONTRIBUTING.md --- .github/CONTRIBUTING.md | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 .github/CONTRIBUTING.md diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md new file mode 100644 index 00000000..3c69c58a --- /dev/null +++ b/.github/CONTRIBUTING.md @@ -0,0 +1,38 @@ +Vibes: +====== +Generally-useful extensions are great, custom extensions and themes just for one specific DIY site +are welcome too. I (Shish) will probably only actively maintain and add features to the extensions +which I personally use, but if you submit some code of your own I will try to keep it updated and +compatible with any API changes that come along. If your code comes with unit tests, this type of +maintenance is much more likely to be successful :) + +Testing: +======== +Github Actions will be running three sets of automated tests, all of which you can run for yourself: + +- `./vendor/bin/php-cs-fixer fix` - keeping a single style for the whole project +- `./vendor/bin/phpunit --config tests/phpunit.xml` - unit testing +- `./vendor/bin/phpstan analyse --memory-limit 1G -c tests/phpstan.neon` - type checking + +The `main` branch is locked down so it can't accept pull requests that don't pass these + +Testing FAQs: +============= + +## What the heck is "Method XX::YY() return type has no value type specified in iterable type array."? + +PHP arrays are very loosely defined - they can be lists or maps, with integer or string +(or non-continuous integer) keys, with any type of object (or multiple types of object). +This isn't great for type safety, so PHPStan is a bit stricter, and requires you to +specify what type of array it is and what it contains. You can do this with PHPdoc comments, +like: + +```php +/** + * @param array $cakes -- a mapping like ["sponge" => new Cake()] + * @return array -- a list like [new Ingredient("flour"), new Ingredient("egg")] + */ +function get_ingredients(array $cakes, string $cake_name): array { + return $cakes[$cake_name]->ingredients; +} +```