Skip to content
This repository was archived by the owner on Jul 31, 2018. It is now read-only.

Commit 5b5465f

Browse files
author
maxiloc
committed
Merge pull request #52 from Nikita240/trait-search
Do a deep search when checking for traits
2 parents 5d176ce + adeaf86 commit 5b5465f

File tree

4 files changed

+47
-2
lines changed

4 files changed

+47
-2
lines changed

src/ModelHelper.php

Lines changed: 23 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -19,9 +19,30 @@ private function getIndexName(Model $model)
1919
return $model->getTable();
2020
}
2121

22-
private function hasAlgoliaTrait(Model $model)
22+
private function hasAlgoliaTrait(Model $class, $autoload = false)
2323
{
24-
return (isset(class_uses($model)['AlgoliaSearch\Laravel\AlgoliaEloquentTrait']));
24+
$traits = [];
25+
26+
// Get traits of all parent classes
27+
do {
28+
$traits = array_merge(class_uses($class, $autoload), $traits);
29+
} while ($class = get_parent_class($class));
30+
31+
// Get traits of all parent traits
32+
$traitsToSearch = $traits;
33+
while (!empty($traitsToSearch)) {
34+
$newTraits = class_uses(array_pop($traitsToSearch), $autoload);
35+
$traits = array_merge($newTraits, $traits);
36+
$traitsToSearch = array_merge($newTraits, $traitsToSearch);
37+
};
38+
39+
foreach ($traits as $trait => $same) {
40+
$traits = array_merge(class_uses($trait, $autoload), $traits);
41+
}
42+
43+
$traits = array_unique($traits);
44+
45+
return (isset($traits['AlgoliaSearch\Laravel\AlgoliaEloquentTrait']));
2546
}
2647

2748
public function isAutoIndex(Model $model)

tests/ModelHelperTest.php

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
use AlgoliaSearch\Tests\Models\Model3;
88
use AlgoliaSearch\Tests\Models\Model4;
99
use AlgoliaSearch\Tests\Models\Model5;
10+
use AlgoliaSearch\Tests\Models\Model7;
1011
use Orchestra\Testbench\TestCase;
1112

1213
class ModelHelperTest extends TestCase
@@ -27,10 +28,12 @@ public function testAutoIndexAndAutoDelete()
2728
$this->assertEquals(true, $this->modelHelper->isAutoIndex(new Model1()));
2829
$this->assertEquals(false, $this->modelHelper->isAutoIndex(new Model2()));
2930
$this->assertEquals(false, $this->modelHelper->isAutoIndex(new Model3()));
31+
$this->assertEquals(true, $this->modelHelper->isAutoIndex(new Model7()));
3032

3133
$this->assertEquals(true, $this->modelHelper->isAutoDelete(new Model1()));
3234
$this->assertEquals(false, $this->modelHelper->isAutoDelete(new Model2()));
3335
$this->assertEquals(false, $this->modelHelper->isAutoDelete(new Model3()));
36+
$this->assertEquals(true, $this->modelHelper->isAutoDelete(new Model7()));
3437
}
3538

3639
public function testGetKey()

tests/Models/Model7.php

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
<?php
2+
3+
namespace AlgoliaSearch\Tests\Models;
4+
5+
use AlgoliaSearch\Tests\Traits\Trait1;
6+
use Illuminate\Database\Eloquent\Model;
7+
8+
class Model7 extends Model
9+
{
10+
use Trait1;
11+
}

tests/Traits/Trait1.php

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
<?php
2+
3+
namespace AlgoliaSearch\Tests\Traits;
4+
5+
use AlgoliaSearch\Laravel\AlgoliaEloquentTrait;
6+
7+
trait Trait1
8+
{
9+
use AlgoliaEloquentTrait;
10+
}

0 commit comments

Comments
 (0)