@@ 14-118 (lines=105) @@ | ||
11 | use Generator; |
|
12 | use Mockery\MockInterface; |
|
13 | ||
14 | final class IndexCreateCommandTest extends TestCase |
|
15 | { |
|
16 | public function testCreateIndexMustSucceed(): void |
|
17 | { |
|
18 | $this->mock(Client::class, function (MockInterface $mock) { |
|
19 | $mock->shouldReceive('indices') |
|
20 | ->times(2) |
|
21 | ->andReturn( |
|
22 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
23 | $mock->shouldReceive('exists') |
|
24 | ->andReturn(false); |
|
25 | ||
26 | $mock->shouldReceive('create') |
|
27 | ->once() |
|
28 | ->andReturn([]); |
|
29 | }) |
|
30 | ); |
|
31 | }); |
|
32 | ||
33 | $this->artisan('laravel-elasticsearch:utils:index-create', |
|
34 | ['index-name' => 'valid_index_name'] |
|
35 | )->assertExitCode(0) |
|
36 | ->expectsOutput('Index valid_index_name created.'); |
|
37 | } |
|
38 | ||
39 | public function testCreateIndexMustFail(): void |
|
40 | { |
|
41 | $this->mock(Client::class, function (MockInterface $mock) { |
|
42 | $mock->shouldReceive('indices') |
|
43 | ->times(2) |
|
44 | ->andReturn( |
|
45 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
46 | $mock->shouldReceive('exists') |
|
47 | ->andReturn(false); |
|
48 | ||
49 | $mock->shouldReceive('create') |
|
50 | ->once() |
|
51 | ->andThrow( |
|
52 | new Exception('index already exists test exception') |
|
53 | ); |
|
54 | }) |
|
55 | ); |
|
56 | }); |
|
57 | ||
58 | $this->artisan('laravel-elasticsearch:utils:index-create', |
|
59 | ['index-name' => 'valid_index_name'] |
|
60 | )->assertExitCode(1) |
|
61 | ->expectsOutput('Error creating index valid_index_name, exception message: index already exists test exception.'); |
|
62 | } |
|
63 | ||
64 | public function testCreateIndexMustFailBecauseIndexAlreadyExists(): void |
|
65 | { |
|
66 | $this->mock(Client::class, function (MockInterface $mock) { |
|
67 | $mock->shouldReceive('indices') |
|
68 | ->once() |
|
69 | ->andReturn( |
|
70 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
71 | $mock->shouldReceive('exists') |
|
72 | ->andReturn(true); |
|
73 | ||
74 | $mock->shouldNotReceive('create'); |
|
75 | }) |
|
76 | ); |
|
77 | }); |
|
78 | ||
79 | $this->artisan('laravel-elasticsearch:utils:index-create', |
|
80 | ['index-name' => 'valid_index_name'] |
|
81 | )->assertExitCode(1) |
|
82 | ->expectsOutput('Index valid_index_name already exists and cannot be created.'); |
|
83 | } |
|
84 | ||
85 | /** |
|
86 | * @dataProvider invalidIndexNameDataProvider |
|
87 | */ |
|
88 | public function testArgumentIndexNameIsInValid($invalidIndexName): void |
|
89 | { |
|
90 | $this->artisan('laravel-elasticsearch:utils:index-create', |
|
91 | ['index-name' => $invalidIndexName] |
|
92 | )->assertExitCode(1) |
|
93 | ->expectsOutput('Argument index-name must be a non empty string.'); |
|
94 | } |
|
95 | ||
96 | public function invalidIndexNameDataProvider(): Generator |
|
97 | { |
|
98 | yield [ |
|
99 | null |
|
100 | ]; |
|
101 | ||
102 | yield [ |
|
103 | '' |
|
104 | ]; |
|
105 | ||
106 | yield [ |
|
107 | true |
|
108 | ]; |
|
109 | ||
110 | yield [ |
|
111 | 1 |
|
112 | ]; |
|
113 | ||
114 | yield [ |
|
115 | [] |
|
116 | ]; |
|
117 | } |
|
118 | } |
|
119 |
@@ 14-118 (lines=105) @@ | ||
11 | use Generator; |
|
12 | use Mockery\MockInterface; |
|
13 | ||
14 | final class IndexDeleteCommandTest extends TestCase |
|
15 | { |
|
16 | public function testIndexDeleteMustSucceed(): void |
|
17 | { |
|
18 | $this->mock(Client::class, function (MockInterface $mock) { |
|
19 | $mock->shouldReceive('indices') |
|
20 | ->times(2) |
|
21 | ->andReturn( |
|
22 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
23 | $mock->shouldReceive('exists') |
|
24 | ->andReturn(true); |
|
25 | ||
26 | $mock->shouldReceive('delete') |
|
27 | ->once() |
|
28 | ->andReturn([]); |
|
29 | }) |
|
30 | ); |
|
31 | }); |
|
32 | ||
33 | $this->artisan('laravel-elasticsearch:utils:index-delete', |
|
34 | ['index-name' => 'valid_index_name'] |
|
35 | )->assertExitCode(0) |
|
36 | ->expectsOutput('Index valid_index_name deleted.'); |
|
37 | } |
|
38 | ||
39 | public function testIndexDeleteMustFail(): void |
|
40 | { |
|
41 | $this->mock(Client::class, function (MockInterface $mock) { |
|
42 | $mock->shouldReceive('indices') |
|
43 | ->times(2) |
|
44 | ->andReturn( |
|
45 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
46 | $mock->shouldReceive('exists') |
|
47 | ->andReturn(true); |
|
48 | ||
49 | $mock->shouldReceive('delete') |
|
50 | ->once() |
|
51 | ->andThrow( |
|
52 | new Exception('error creating index test exception') |
|
53 | ); |
|
54 | }) |
|
55 | ); |
|
56 | }); |
|
57 | ||
58 | $this->artisan('laravel-elasticsearch:utils:index-delete', |
|
59 | ['index-name' => 'valid_index_name'] |
|
60 | )->assertExitCode(1) |
|
61 | ->expectsOutput('Error deleting index valid_index_name, exception message: error creating index test exception.'); |
|
62 | } |
|
63 | ||
64 | public function testIndexDeleteMustFailBecauseIndexDoesntExists(): void |
|
65 | { |
|
66 | $this->mock(Client::class, function (MockInterface $mock) { |
|
67 | $mock->shouldReceive('indices') |
|
68 | ->once() |
|
69 | ->andReturn( |
|
70 | $this->mock(IndicesNamespace::class, function (MockInterface $mock) { |
|
71 | $mock->shouldReceive('exists') |
|
72 | ->andReturn(false); |
|
73 | ||
74 | $mock->shouldNotReceive('create'); |
|
75 | }) |
|
76 | ); |
|
77 | }); |
|
78 | ||
79 | $this->artisan('laravel-elasticsearch:utils:index-delete', |
|
80 | ['index-name' => 'valid_index_name'] |
|
81 | )->assertExitCode(1) |
|
82 | ->expectsOutput('Index valid_index_name doesn\'t exists and cannot be deleted.'); |
|
83 | } |
|
84 | ||
85 | /** |
|
86 | * @dataProvider invalidIndexNameDataProvider |
|
87 | */ |
|
88 | public function testArgumentIndexNameIsInValid($invalidIndexName): void |
|
89 | { |
|
90 | $this->artisan('laravel-elasticsearch:utils:index-delete', |
|
91 | ['index-name' => $invalidIndexName] |
|
92 | )->assertExitCode(1) |
|
93 | ->expectsOutput('Argument index-name must be a non empty string.'); |
|
94 | } |
|
95 | ||
96 | public function invalidIndexNameDataProvider(): Generator |
|
97 | { |
|
98 | yield [ |
|
99 | null |
|
100 | ]; |
|
101 | ||
102 | yield [ |
|
103 | '' |
|
104 | ]; |
|
105 | ||
106 | yield [ |
|
107 | true |
|
108 | ]; |
|
109 | ||
110 | yield [ |
|
111 | 1 |
|
112 | ]; |
|
113 | ||
114 | yield [ |
|
115 | [] |
|
116 | ]; |
|
117 | } |
|
118 | } |
|
119 |