]> git.mxchange.org Git - friendica.git/blob - tests/DiceHttpMockHandlerTrait.php
Issue 11470: Check for removed account
[friendica.git] / tests / DiceHttpMockHandlerTrait.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2010-2022, the Friendica project
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Test;
23
24 use Dice\Dice;
25 use Friendica\DI;
26 use Friendica\Network\HTTPClient\Factory\HttpClient;
27 use Friendica\Network\HTTPClient\Capability\ICanSendHttpRequests;
28 use GuzzleHttp\HandlerStack;
29
30 /**
31  * This class injects a mockable handler into the IHTTPClient dependency per Dice
32  */
33 trait DiceHttpMockHandlerTrait
34 {
35         /**
36          * Handler for mocking requests anywhere for testing purpose
37          *
38          * @var HandlerStack
39          */
40         protected $httpRequestHandler;
41
42         protected function setupHttpMockHandler(): void
43         {
44                 if (!empty($this->httpRequestHandler) && $this->httpRequestHandler instanceof HandlerStack) {
45                         return;
46                 }
47
48                 $this->httpRequestHandler = HandlerStack::create();
49
50                 $dice = DI::getDice();
51                 // addRule() clones the current instance and returns a new one, so no concurrency problems :-)
52                 $newDice = $dice->addRule(ICanSendHttpRequests::class, [
53                         'instanceOf' => HttpClient::class,
54                         'call'       => [
55                                 ['createClient', [$this->httpRequestHandler], Dice::CHAIN_CALL],
56                         ],
57                 ]);
58
59                 DI::init($newDice);
60         }
61
62         protected function tearDown(): void
63         {
64                 \Mockery::close();
65
66                 parent::tearDown();
67         }
68 }