Add Event Sources Logic (ActivityPub follows) #86
1 changed files with 43 additions and 0 deletions
|
@ -9,6 +9,8 @@
|
|||
|
||||
namespace Event_Bridge_For_ActivityPub\Tests;
|
||||
|
||||
use Activitypub\Model\Blog;
|
||||
use Event_Bridge_For_ActivityPub\ActivityPub\Collection\Event_Sources;
|
||||
use GatherPress\Core\Event_Query;
|
||||
use WP_REST_Request;
|
||||
use WP_REST_Server;
|
||||
|
@ -244,4 +246,45 @@ class Test_Event_Sources extends \WP_UnitTestCase {
|
|||
|
||||
\remove_filter( 'activitypub_defer_signature_verification', '__return_true' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Test receiving "Accept" of "Follow".
|
||||
*
|
||||
*
|
||||
*/
|
||||
public function test_incoming_accept_of_follow() {
|
||||
\add_filter( 'activitypub_defer_signature_verification', '__return_true' );
|
||||
|
||||
$blog = new Blog();
|
||||
|
||||
$json = array(
|
||||
'id' => 'https://remote.example/random-id',
|
||||
'type' => 'Accept',
|
||||
'actor' => 'https://remote.example/@organizer',
|
||||
'object' => array(
|
||||
'id' => Event_Sources::compose_follow_id( $blog->get_id(), 'https://remote.example/@organizer' ),
|
||||
'type' => 'Follow',
|
||||
'to' => 'https://www.w3.org/ns/activitystreams#Public',
|
||||
'object' => 'https://remote.example/@organizer',
|
||||
),
|
||||
);
|
||||
|
||||
$event_source = \Event_Bridge_For_ActivityPub\ActivityPub\Model\Event_Source::get_by_id( 'https://remote.example/@organizer' );
|
||||
$accepted = get_post_meta( $event_source->get__id(), '_event_bridge_or_activitypub_accept_of_follow', true );
|
||||
$this->assertNotFalse( $accepted );
|
||||
|
||||
// Receive Accept.
|
||||
$request = new WP_REST_Request( 'POST', '/activitypub/1.0/users/0/inbox' );
|
||||
$request->set_header( 'Content-Type', 'application/activity+json' );
|
||||
$request->set_body( \wp_json_encode( $json ) );
|
||||
$response = \rest_do_request( $request );
|
||||
$this->assertEquals( 202, $response->get_status() );
|
||||
|
||||
|
||||
$accepted = get_post_meta( $event_source->get__id(), '_event_bridge_or_activitypub_accept_of_follow', true );
|
||||
|
||||
$this->assertNotFalse( $accepted );
|
||||
|
||||
\remove_filter( 'activitypub_defer_signature_verification', '__return_true' );
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue