Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PHPStan lvl 4 & Fix/issue 233 followup #257

Merged
merged 44 commits into from
Sep 30, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
0ffbca1
Add failing test
SanderMuller Aug 28, 2024
99ae3c0
reduce fatal error to phpstan failure
SanderMuller Aug 28, 2024
5f1132b
WIP
SanderMuller Aug 29, 2024
52a13dc
wip
SanderMuller Aug 29, 2024
90ea5fc
wip
SanderMuller Aug 29, 2024
9c5957a
Followup of fix/issue-233
SanderMuller Aug 29, 2024
d4c6fd3
phpstan lvl 3
SanderMuller Aug 29, 2024
6f07063
level 4
SanderMuller Aug 29, 2024
96d8f7e
Merge branch 'main' into fix/issue-233-followup
SanderMuller Aug 29, 2024
b4642ec
resolve merge conflicts
SanderMuller Aug 29, 2024
f2d51a9
Update HasOfDescendantsRelationships.php
SanderMuller Aug 29, 2024
c5d65e0
Resolve error
staudenmeir Aug 29, 2024
63749db
Fix Singlestore getExpressionGrammar
SanderMuller Aug 30, 2024
8fe6aae
Update BuildsAdjacencyListQueries.php
SanderMuller Aug 30, 2024
d5c585f
Use inheritDoc where possible
SanderMuller Sep 4, 2024
b77d671
Resolve @phpstan-ignore return.phpDocType
SanderMuller Sep 4, 2024
edd14cf
add phpstan/phpstan-phpunit
SanderMuller Sep 4, 2024
156dd5e
Lock phpstan/phpstan to 1.11.1 for now
SanderMuller Sep 4, 2024
9111f06
Merge branch 'main' into fix/issue-233-followup
staudenmeir Sep 7, 2024
04e23fb
wip
SanderMuller Sep 9, 2024
3e7b50b
WIP
SanderMuller Sep 9, 2024
25bc3c2
wip
SanderMuller Sep 9, 2024
60550bd
Update HasRecursiveRelationshipScopes.php
SanderMuller Sep 9, 2024
e6ae2f3
Update IsOfDescendantsRelation.php
SanderMuller Sep 9, 2024
6db83a8
Update composer.json
SanderMuller Sep 9, 2024
7c2d568
Refactoring
staudenmeir Sep 11, 2024
44b2389
Merge branch 'main' into fix/issue-233-followup
SanderMuller Sep 13, 2024
402f62d
Use native return types without docblock
SanderMuller Sep 13, 2024
816f8c3
Apply review feedback
SanderMuller Sep 13, 2024
863b045
Restore phpdoc
SanderMuller Sep 13, 2024
487ecd0
Remove "tests" path
staudenmeir Sep 23, 2024
e99b860
Increase PHPStan level
staudenmeir Sep 23, 2024
15e238f
Update return types
staudenmeir Sep 23, 2024
c332549
Merge branch 'main' into fix/issue-233-followup
staudenmeir Sep 29, 2024
e90dbf3
Refactoring
staudenmeir Sep 29, 2024
265a8b7
Adjust to interface changes
staudenmeir Sep 29, 2024
3513905
Remove mixin
staudenmeir Sep 29, 2024
491801a
Remove "tests" path
staudenmeir Sep 29, 2024
809f806
Improve types
staudenmeir Sep 29, 2024
b38e7c8
Revert breaking changes
staudenmeir Sep 29, 2024
485076c
Formatting
staudenmeir Sep 29, 2024
b8fb6fc
Add type checks
staudenmeir Sep 30, 2024
1178425
Add type checks
staudenmeir Sep 30, 2024
1b70a20
Formatting
staudenmeir Sep 30, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/.docker export-ignore
/.github export-ignore
/tests export-ignore
/types export-ignore
.gitattributes export-ignore
.gitignore export-ignore
docker-compose.ci.yml export-ignore
Expand Down
1 change: 1 addition & 0 deletions .github/CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,5 @@ We accept contributions via Pull Requests on [GitHub](https://github.com/stauden
docker compose run --rm php8.3 composer install
docker compose run --rm php8.3 vendor/bin/phpunit
docker compose run --rm php8.3 vendor/bin/phpstan analyse --memory-limit=-1
docker compose run --rm php8.3 vendor/bin/phpstan analyse --configuration=phpstan.types.neon.dist --memory-limit=-1
```
4 changes: 4 additions & 0 deletions .github/workflows/static-analysis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,3 +31,7 @@ jobs:
run: |
docker compose -f docker-compose.yml -f docker-compose.ci.yml run --rm php${{ matrix.php }} \
vendor/bin/phpstan analyse --error-format=github --memory-limit=-1
- name: Analyse types
run: |
docker compose -f docker-compose.yml -f docker-compose.ci.yml run --rm php${{ matrix.php }} \
vendor/bin/phpstan analyse --configuration=phpstan.types.neon.dist --error-format=github --memory-limit=-1
1 change: 0 additions & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
"larastan/larastan": "^2.0",
"mockery/mockery": "^1.5.1",
"orchestra/testbench": "^9.0",
"phpstan/phpstan-mockery": "^1.1",
"phpunit/phpunit": "^11.0",
"singlestoredb/singlestoredb-laravel": "^1.5.4",
"staudenmeir/eloquent-has-many-deep": "^1.20"
Expand Down
4 changes: 1 addition & 3 deletions phpstan.neon.dist
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
includes:
- ./vendor/larastan/larastan/extension.neon
- ./vendor/phpstan/phpstan-mockery/extension.neon
parameters:
level: 2
level: 5
paths:
- src
- tests
ignoreErrors:
- '#Unsafe usage of new static\(\).#'
- '#Access to an undefined property Illuminate\\Database\\Eloquent\\Model::\$laravel_through_key#'
Expand Down
6 changes: 6 additions & 0 deletions phpstan.types.neon.dist
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
includes:
- ./vendor/larastan/larastan/extension.neon
parameters:
level: 9
paths:
- types
2 changes: 1 addition & 1 deletion src/Eloquent/Builder.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
/**
* @template TModel of \Illuminate\Database\Eloquent\Model
*
* @extends Base<TModel>
* @extends \Illuminate\Database\Eloquent\Builder<TModel>
*/
class Builder extends Base
{
Expand Down
2 changes: 1 addition & 1 deletion src/Eloquent/Collection.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ class Collection extends Base
* Generate a nested tree.
*
* @param string $childrenRelation
* @return static<int, TModel>
* @return static
*/
public function toTree($childrenRelation = 'children')
{
Expand Down
3 changes: 0 additions & 3 deletions src/Eloquent/Graph/Collection.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,6 @@ class Collection extends Base
{
/**
* Generate a nested tree.
*
* @param string $childrenRelation
* @return $this<int, TModel>
*/
public function toTree(string $childrenRelation = 'children'): static
{
Expand Down
47 changes: 9 additions & 38 deletions src/Eloquent/Relations/BelongsToManyOfDescendants.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,8 @@ class BelongsToManyOfDescendants extends BelongsToMany
* Create a new belongs to many of descendants relationship instance.
*
* @param \Illuminate\Database\Eloquent\Builder<TRelatedModel> $query
* @param \Illuminate\Database\Eloquent\Model $parent
* @param string $table
* @param TRelatedModel $parent
SanderMuller marked this conversation as resolved.
Show resolved Hide resolved
* @param class-string<TRelatedModel>|string $table
* @param string $foreignPivotKey
* @param string $relatedPivotKey
* @param string $parentKey
Expand All @@ -46,24 +46,15 @@ public function __construct(
parent::__construct($query, $parent, $table, $foreignPivotKey, $relatedPivotKey, $parentKey, $relatedKey);
}

/**
* Set the base constraints on the relation query.
*
* @return void
*/
/** @inheritDoc */
public function addConstraints()
{
$this->performJoin();

$this->baseAddConstraints();
}

/**
* Set the where clause on the recursive expression query.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @return void
*/
/** @inheritDoc */
protected function addExpressionWhereConstraints(Builder $query)
{
$column = $this->andSelf ? $this->parent->getLocalKeyName() : $this->parent->getParentKeyName();
Expand All @@ -75,31 +66,19 @@ protected function addExpressionWhereConstraints(Builder $query)
);
}

/**
* Get the local key name for an eager load of the relation.
*
* @return string
*/
/** @inheritDoc */
public function getEagerLoadingLocalKeyName()
{
return $this->parentKey;
}

/**
* Get the foreign key name for an eager load of the relation.
*
* @return string
*/
/** @inheritDoc */
public function getEagerLoadingForeignKeyName()
{
return $this->foreignPivotKey;
}

/**
* Get the accessor for an eager load of the relation.
*
* @return string|null
*/
/** @inheritDoc */
public function getEagerLoadingAccessor()
{
return $this->accessor;
Expand All @@ -120,21 +99,13 @@ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery,
return $this->baseGetRelationExistenceQuery($query, $parentQuery, $columns);
}

/**
* Get the local key name for the recursion expression.
*
* @return string
*/
/** @inheritDoc */
public function getExpressionLocalKeyName()
{
return $this->parentKey;
}

/**
* Get the foreign key name for the recursion expression.
*
* @return string
*/
/** @inheritDoc */
public function getExpressionForeignKeyName()
{
return $this->foreignPivotKey;
Expand Down
13 changes: 3 additions & 10 deletions src/Eloquent/Relations/Bloodline.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@ class Bloodline extends Descendants
/**
* Create a new bloodline relationship instance.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param \Illuminate\Database\Eloquent\Model $parent
* @param \Illuminate\Database\Eloquent\Builder<TRelatedModel> $query
* @param TRelatedModel $parent
* @param string $foreignKey
* @param string $localKey
* @return void
Expand All @@ -26,14 +26,7 @@ public function __construct(Builder $query, Model $parent, $foreignKey, $localKe
parent::__construct($query, $parent, $foreignKey, $localKey, true);
}

/**
* Add a recursive expression to the query.
*
* @param callable $constraint
* @param \Illuminate\Database\Eloquent\Builder|null $query
* @param string|null $from
* @return \Illuminate\Database\Eloquent\Builder
*/
/** @inheritDoc */
protected function addExpression(callable $constraint, ?Builder $query = null, $from = null)
{
$query = $query ?: $this->query;
Expand Down
56 changes: 7 additions & 49 deletions src/Eloquent/Relations/Descendants.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,7 @@ class Descendants extends HasMany implements ConcatenableRelation
buildDictionary as baseBuildDictionary;
}

/**
* Set the base constraints on the relation query.
*
* @return void
*/
/** @inheritDoc */
public function addConstraints()
{
if (static::$constraints) {
Expand All @@ -44,12 +40,7 @@ public function addConstraints()
}
}

/**
* Set the constraints for an eager load of the relation.
*
* @param array $models
* @return void
*/
/** @inheritDoc */
public function addEagerConstraints(array $models)
{
$whereIn = $this->whereInMethod($this->parent, $this->localKey);
Expand All @@ -65,14 +56,7 @@ public function addEagerConstraints(array $models)
$this->addExpression($constraint);
}

/**
* Match the eagerly loaded results to their parents.
*
* @param array $models
* @param \Illuminate\Database\Eloquent\Collection $results
* @param string $relation
* @return array
*/
/** @inheritDoc */
public function match(array $models, Collection $results, $relation)
{
$dictionary = $this->buildDictionary($results);
Expand All @@ -90,12 +74,7 @@ public function match(array $models, Collection $results, $relation)
return $models;
}

/**
* Build model dictionary.
*
* @param \Illuminate\Database\Eloquent\Collection $results
* @return array
*/
/** @inheritDoc */
protected function buildDictionary(Collection $results)
{
if ($this->andSelf) {
Expand All @@ -117,14 +96,7 @@ protected function buildDictionary(Collection $results)
})->all();
}

/**
* Add the constraints for a relationship query.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param \Illuminate\Database\Eloquent\Builder $parentQuery
* @param array|mixed $columns
* @return \Illuminate\Database\Eloquent\Builder
*/
/** @inheritDoc */
public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
{
if ($query->getQuery()->from === $parentQuery->getQuery()->from) {
Expand All @@ -146,14 +118,7 @@ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery,
return $this->addExpression($constraint, $query->select($columns));
}

/**
* Add the constraints for a relationship query on the same table.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param \Illuminate\Database\Eloquent\Builder $parentQuery
* @param array|mixed $columns
* @return \Illuminate\Database\Eloquent\Builder
*/
/** @inheritDoc */
public function getRelationExistenceQueryForSelfRelation(Builder $query, Builder $parentQuery, $columns = ['*'])
{
if ($columns instanceof Expression) {
Expand Down Expand Up @@ -181,14 +146,7 @@ public function getRelationExistenceQueryForSelfRelation(Builder $query, Builder
return $this->addExpression($constraint, $query->select($columns), $from);
}

/**
* Add a recursive expression to the query.
*
* @param callable $constraint
* @param \Illuminate\Database\Eloquent\Builder|null $query
* @param string|null $from
* @return \Illuminate\Database\Eloquent\Builder
*/
/** @inheritDoc */
protected function addExpression(callable $constraint, ?Builder $query = null, $from = null)
{
$query = $query ?: $this->query;
Expand Down
26 changes: 5 additions & 21 deletions src/Eloquent/Relations/Graph/Ancestors.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,11 +22,7 @@ class Ancestors extends BelongsToMany implements ConcatenableRelation
buildDictionary as baseBuildDictionary;
}

/**
* Set the base constraints on the relation query.
*
* @return void
*/
/** @inheritDoc */
public function addConstraints()
{
if (static::$constraints) {
Expand All @@ -44,12 +40,7 @@ public function addConstraints()
}
}

/**
* Set the constraints for an eager load of the relation.
*
* @param array $models
* @return void
*/
/** @inheritDoc */
public function addEagerConstraints(array $models)
{
$column = $this->andSelf ? $this->getQualifiedParentKeyName() : $this->getQualifiedRelatedPivotKeyName();
Expand All @@ -60,8 +51,8 @@ public function addEagerConstraints(array $models)
/**
* Build model dictionary.
*
* @param \Illuminate\Database\Eloquent\Collection $results
* @return array
* @param \Illuminate\Database\Eloquent\Collection<array-key, \Illuminate\Database\Eloquent\Model> $results
* @return array<string, \Illuminate\Database\Eloquent\Model[]>
*/
SanderMuller marked this conversation as resolved.
Show resolved Hide resolved
protected function buildDictionary(Collection $results)
{
Expand Down Expand Up @@ -94,14 +85,7 @@ protected function buildDictionary(Collection $results)
return $dictionary;
}

/**
* Add the constraints for a relationship query.
*
* @param \Illuminate\Database\Eloquent\Builder $query
* @param \Illuminate\Database\Eloquent\Builder $parentQuery
* @param array|mixed $columns
* @return \Illuminate\Database\Eloquent\Builder
*/
/** @inheritDoc */
public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
{
if ($query->getQuery()->from === $parentQuery->getQuery()->from) {
Expand Down
Loading