Skip to content

Commit

Permalink
Merge pull request #1 from marvinlabs/develop
Browse files Browse the repository at this point in the history
Support for Laravel 6
  • Loading branch information
vpratfr authored Sep 27, 2019
2 parents 1e18eb3 + 0e80566 commit 22ce74f
Show file tree
Hide file tree
Showing 2 changed files with 88 additions and 1 deletion.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
"php": ">=7.1",
"ext-json": "*",
"guzzlehttp/guzzle": "^6.3",
"illuminate/support": "^5.5"
"illuminate/support": "^5.5|^6.0"
},
"require-dev": {
"roave/security-advisories": "dev-master",
Expand Down
87 changes: 87 additions & 0 deletions tests/Discord/GuzzleWebHookTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
<?php

namespace MarvinLabs\DiscordLogger\Tests\Discord;

use GuzzleHttp\Client;
use GuzzleHttp\Handler\MockHandler;
use GuzzleHttp\HandlerStack;
use GuzzleHttp\Middleware;
use GuzzleHttp\Psr7\Request;
use GuzzleHttp\Psr7\Response;
use MarvinLabs\DiscordLogger\Discord\GuzzleWebHook;
use MarvinLabs\DiscordLogger\Discord\Message;
use MarvinLabs\DiscordLogger\Tests\TestCase;
use function explode;
use function json_decode;

class GuzzleWebHookTest extends TestCase
{
/** @var array */
private $httpHistory;

/** @var \MarvinLabs\DiscordLogger\Contracts\DiscordWebHook */
private $discord;

protected function setUp(): void
{
parent::setUp();

$this->httpHistory = [];

$stack = HandlerStack::create(new MockHandler([new Response()]));
$stack->push(Middleware::history($this->httpHistory));
$httpClient = new Client(['handler' => $stack]);

$this->discord = new GuzzleWebHook($httpClient, 'http://example.com');
}

/** @test */
public function forms_json_request_when_no_file()
{
$this->discord->send(Message::make()->content('No files attached'));

$this->assertCount(1, $this->httpHistory);

tap($this->httpHistory[0]['request'], function (Request $request) {
$this->assertEquals('POST', $request->getMethod());
$this->assertEquals('application/json', $request->getHeader('Content-Type'));

$payload = json_decode($request->getBody()->getContents(), true);
$this->assertEquals('No files attached', $payload['content']);
});
}

/** @test */
public function forms_multipart_request_when_file_present()
{
$this->discord->send(Message::make()->content('File attached')->file('test', 'test.txt'));

$this->assertCount(1, $this->httpHistory);

tap($this->httpHistory[0]['request'], function (Request $request) {
$this->assertEquals('POST', $request->getMethod());
$this->assertStringContainsString('multipart/form-data', $request->getHeaderLine('Content-Type'));
$payload = collect(explode('--', $request->getBody()->getContents()))
->map(static function ($data) {
return explode("\r\n", $data);
})
->map(static function ($data) {
return collect($data)->reject(static function ($item) {
return empty($item);
})->toArray();
})
->map(static function ($data) {
return \array_filter(['name' => $data[1] ?? null, 'contents' => $data[4] ?? null]);
})
->reject(static function ($item) {
return empty($item);
})
->toArray();

$this->assertEquals('Content-Disposition: form-data; name="content"', $payload[1]['name']);
$this->assertEquals('Content-Disposition: form-data; name="tts"', $payload[2]['name']);
$this->assertEquals('Content-Disposition: form-data; name="file"; filename="test.txt"',
$payload[3]['name']);
});
}
}

0 comments on commit 22ce74f

Please sign in to comment.