Squashed commit of the following: commit 13ac266b79b496d62291a07f4f5f81940d217ccb Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 17:17:25 2019 +0000 test on 7.2 and 7.3, download phpcs directly from github commit 692cc7dfe165a7ecaf9dba9498c868193b749aee Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 17:10:16 2019 +0000 Drop code-coverage for now, PHP7.3 and Xdebug aren’t playing ball at the moment commit 03d262c47af79cfa0ce4937cc8e196e3b6f5877a Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 17:09:48 2019 +0000 Use an excewption when generating twitter content of a note commit e2df1e5cebebd30473787c924f495a5687145fb8 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Jan 20 17:08:48 2019 +0000 Updating dependencies commit 8008eb53854eddefaa4e302f95353c626b3062ef Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sun Nov 25 16:09:32 2018 +0000 Fix S3 URLs to use config settings commit 941864b9d6c6cb9d87b4b95385ada67f55de837c Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sat Nov 24 21:28:19 2018 +0000 Increase code-coverage in the notes unit tests commit 4a253d3c5c1854dd8ea01d975bb8e709ae697393 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Tue Nov 20 18:26:59 2018 +0000 Don’t create new notes in null note test commit 9616cd2b66bc6f26b2d3266f95cf1be894aaed99 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Tue Nov 20 18:23:05 2018 +0000 Use Laravel’s FileSystem class to better deal with files/folders in the tearDown methods commit 294f7961ec03d26cc45845632a97b2521a58f403 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Tue Nov 20 18:22:28 2018 +0000 Add more unit tests for the geocoding method commit 43328e3ce249fe8df95770f1275cab97f4ca88bc Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Tue Nov 20 18:18:36 2018 +0000 Improve the revereseGeoCode method commit 84424e1d8274bfe62bc5f0a7556e5732bf094178 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Tue Nov 20 15:03:14 2018 +0000 Test that empty notes are saved to the DB as null commit 77fd87b81323457ce6f578ed7f359ceb6b3ce6b6 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sat Oct 13 20:20:03 2018 +0100 Increase test coverage to 100% for the WebMention model commit 4b6da595dc1efc025470279e9012c2a2a90ec3ef Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sat Oct 13 18:49:33 2018 +0100 Improving test coverage commit 895061b8dd0ddf4fbc321e4f371ea148d9b3007f Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Sat Oct 13 17:19:35 2018 +0100 Improvements in Like tests and code, and WebMentions processing tests and code commit f9a8b96f2c8b1ef22e97d3dc634ee76d97c25cb5 Author: Jonny Barnes <jonny@jonnybarnes.uk> Date: Fri Oct 12 22:43:49 2018 +0100 Don’t track the coverage files in git
222 lines
5.9 KiB
PHP
222 lines
5.9 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature;
|
|
|
|
use Queue;
|
|
use Tests\TestCase;
|
|
use App\Models\Like;
|
|
use Tests\TestToken;
|
|
use GuzzleHttp\Client;
|
|
use App\Jobs\ProcessLike;
|
|
use Lcobucci\JWT\Builder;
|
|
use GuzzleHttp\HandlerStack;
|
|
use GuzzleHttp\Psr7\Response;
|
|
use GuzzleHttp\Handler\MockHandler;
|
|
use Lcobucci\JWT\Signer\Hmac\Sha256;
|
|
use Jonnybarnes\WebmentionsParser\Authorship;
|
|
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
|
|
|
class LikesTest extends TestCase
|
|
{
|
|
use DatabaseTransactions, TestToken;
|
|
|
|
public function test_likes_page()
|
|
{
|
|
$response = $this->get('/likes');
|
|
$response->assertViewIs('likes.index');
|
|
}
|
|
|
|
public function test_single_like_page()
|
|
{
|
|
$response = $this->get('/likes/1');
|
|
$response->assertViewIs('likes.show');
|
|
}
|
|
|
|
public function test_like_micropub_json_request()
|
|
{
|
|
Queue::fake();
|
|
|
|
$response = $this->withHeaders([
|
|
'Authorization' => 'Bearer ' . $this->getToken(),
|
|
])->json('POST', '/api/post', [
|
|
'type' => ['h-entry'],
|
|
'properties' => [
|
|
'like-of' => ['https://example.org/blog-post'],
|
|
],
|
|
]);
|
|
|
|
$response->assertJson(['response' => 'created']);
|
|
|
|
Queue::assertPushed(ProcessLike::class);
|
|
$this->assertDatabaseHas('likes', ['url' => 'https://example.org/blog-post']);
|
|
}
|
|
|
|
public function test_like_micropub_form_request()
|
|
{
|
|
Queue::fake();
|
|
|
|
$response = $this->withHeaders([
|
|
'Authorization' => 'Bearer ' . $this->getToken(),
|
|
])->post('/api/post', [
|
|
'h' => 'entry',
|
|
'like-of' => 'https://example.org/blog-post',
|
|
]);
|
|
|
|
$response->assertStatus(201);
|
|
|
|
Queue::assertPushed(ProcessLike::class);
|
|
$this->assertDatabaseHas('likes', ['url' => 'https://example.org/blog-post']);
|
|
}
|
|
|
|
public function test_process_like_job_with_simple_author()
|
|
{
|
|
$like = new Like();
|
|
$like->url = 'http://example.org/note/id';
|
|
$like->save();
|
|
$id = $like->id;
|
|
|
|
$job = new ProcessLike($like);
|
|
|
|
$content = <<<END
|
|
<html>
|
|
<body>
|
|
<div class="h-entry">
|
|
<div class="e-content">
|
|
A post that I like.
|
|
</div>
|
|
by <span class="p-author">Fred Bloggs</span>
|
|
</div>
|
|
</body>
|
|
</html>
|
|
END;
|
|
$mock = new MockHandler([
|
|
new Response(200, [], $content),
|
|
new Response(200, [], $content),
|
|
]);
|
|
$handler = HandlerStack::create($mock);
|
|
$client = new Client(['handler' => $handler]);
|
|
$this->app->bind(Client::class, $client);
|
|
$authorship = new Authorship();
|
|
|
|
$job->handle($client, $authorship);
|
|
|
|
$this->assertEquals('Fred Bloggs', Like::find($id)->author_name);
|
|
}
|
|
|
|
public function test_process_like_job_with_h_card()
|
|
{
|
|
$like = new Like();
|
|
$like->url = 'http://example.org/note/id';
|
|
$like->save();
|
|
$id = $like->id;
|
|
|
|
$job = new ProcessLike($like);
|
|
|
|
$content = <<<END
|
|
<html>
|
|
<body>
|
|
<div class="h-entry">
|
|
<div class="e-content">
|
|
A post that I like.
|
|
</div>
|
|
by
|
|
<div class="p-author h-card">
|
|
<span class="p-name">Fred Bloggs</span>
|
|
<a class="u-url" href="https://fredd.blog/gs"></a>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html>
|
|
END;
|
|
$mock = new MockHandler([
|
|
new Response(200, [], $content),
|
|
new Response(200, [], $content),
|
|
]);
|
|
$handler = HandlerStack::create($mock);
|
|
$client = new Client(['handler' => $handler]);
|
|
$this->app->bind(Client::class, $client);
|
|
$authorship = new Authorship();
|
|
|
|
$job->handle($client, $authorship);
|
|
|
|
$this->assertEquals('Fred Bloggs', Like::find($id)->author_name);
|
|
}
|
|
|
|
public function test_process_like_job_without_mf2()
|
|
{
|
|
$like = new Like();
|
|
$like->url = 'http://example.org/note/id';
|
|
$like->save();
|
|
$id = $like->id;
|
|
|
|
$job = new ProcessLike($like);
|
|
|
|
$content = <<<END
|
|
<html>
|
|
<body>
|
|
<div>
|
|
I liked a post
|
|
</div>
|
|
</body>
|
|
</html>
|
|
END;
|
|
$mock = new MockHandler([
|
|
new Response(200, [], $content),
|
|
new Response(200, [], $content),
|
|
]);
|
|
$handler = HandlerStack::create($mock);
|
|
$client = new Client(['handler' => $handler]);
|
|
$this->app->bind(Client::class, $client);
|
|
$authorship = new Authorship();
|
|
|
|
$job->handle($client, $authorship);
|
|
|
|
$this->assertNull(Like::find($id)->author_name);
|
|
}
|
|
|
|
public function test_process_like_that_is_tweet()
|
|
{
|
|
$like = new Like();
|
|
$like->url = 'https://twitter.com/jonnybarnes/status/1050823255123251200';
|
|
$like->save();
|
|
$id = $like->id;
|
|
|
|
$job = new ProcessLike($like);
|
|
|
|
$mock = new MockHandler([
|
|
new Response(201, [], json_encode([
|
|
'url' => 'https://twitter.com/likes/id',
|
|
])),
|
|
]);
|
|
$handler = HandlerStack::create($mock);
|
|
$client = new Client(['handler' => $handler]);
|
|
$this->app->bind(Client::class, $client);
|
|
$authorship = new Authorship();
|
|
|
|
$job->handle($client, $authorship);
|
|
|
|
$this->assertEquals('Jonny Barnes', Like::find($id)->author_name);
|
|
}
|
|
|
|
public function test_process_like_that_is_tweet_with_oembed_error()
|
|
{
|
|
$like = new Like();
|
|
$like->url = 'https://twitter.com/jonnybarnes/status/1050823255123251200';
|
|
$like->save();
|
|
$id = $like->id;
|
|
|
|
$job = new ProcessLike($like);
|
|
|
|
$mock = new MockHandler([
|
|
new Response(500),
|
|
]);
|
|
$handler = HandlerStack::create($mock);
|
|
$client = new Client(['handler' => $handler]);
|
|
$this->app->bind(Client::class, $client);
|
|
$authorship = new Authorship();
|
|
|
|
$job->handle($client, $authorship);
|
|
|
|
$this->assertEquals('Jonny Barnes', Like::find($id)->author_name);
|
|
}
|
|
}
|