2010-08-03 21:41:44 +01:00
|
|
|
<?php
|
2019-07-12 16:31:14 +01:00
|
|
|
// This file is part of GNU social - https://www.gnu.org/software/social
|
|
|
|
//
|
|
|
|
// GNU social is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// GNU social is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
namespace Tests\Unit;
|
|
|
|
|
|
|
|
if (!defined('INSTALLDIR')) {
|
|
|
|
define('INSTALLDIR', dirname(dirname(__DIR__)));
|
|
|
|
}
|
|
|
|
if (!defined('PUBLICDIR')) {
|
|
|
|
define('PUBLICDIR', INSTALLDIR . DIRECTORY_SEPARATOR . 'public');
|
|
|
|
}
|
|
|
|
if (!defined('GNUSOCIAL')) {
|
|
|
|
define('GNUSOCIAL', true);
|
|
|
|
}
|
|
|
|
if (!defined('STATUSNET')) { // Compatibility
|
|
|
|
define('STATUSNET', true);
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
use Activity;
|
|
|
|
use ActivityObject;
|
|
|
|
use ActivityUtils;
|
|
|
|
use ActivityVerb;
|
|
|
|
use Conversation;
|
|
|
|
use DOMDocument;
|
|
|
|
use Exception;
|
|
|
|
use Notice;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
use User;
|
|
|
|
use User_group;
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2019-08-23 13:36:02 +01:00
|
|
|
require_once INSTALLDIR . '/lib/util/common.php';
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
final class ActivityGenerationTests extends TestCase
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2020-06-24 13:08:11 +01:00
|
|
|
public static $author1 = null;
|
|
|
|
public static $author2 = null;
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
public static $targetUser1 = null;
|
|
|
|
public static $targetUser2 = null;
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
public static $targetGroup1 = null;
|
|
|
|
public static $targetGroup2 = null;
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2019-07-25 01:29:20 +01:00
|
|
|
public static function setUpBeforeClass(): void
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2013-10-21 12:20:30 +01:00
|
|
|
$authorNick1 = 'activitygenerationtestsuser' . common_random_hexstr(4);
|
|
|
|
$authorNick2 = 'activitygenerationtestsuser' . common_random_hexstr(4);
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2013-10-21 12:20:30 +01:00
|
|
|
$targetNick1 = 'activitygenerationteststarget' . common_random_hexstr(4);
|
|
|
|
$targetNick2 = 'activitygenerationteststarget' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2013-10-21 12:20:30 +01:00
|
|
|
$groupNick1 = 'activitygenerationtestsgroup' . common_random_hexstr(4);
|
|
|
|
$groupNick2 = 'activitygenerationtestsgroup' . common_random_hexstr(4);
|
2010-08-03 21:41:44 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
try {
|
2020-06-24 13:08:11 +01:00
|
|
|
self::$author1 = User::register(['nickname' => $authorNick1,
|
2019-07-12 16:31:14 +01:00
|
|
|
'email' => $authorNick1 . '@example.net',
|
2020-06-24 13:08:11 +01:00
|
|
|
'email_confirmed' => true,]);
|
2019-07-12 16:31:14 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
self::$author2 = User::register(['nickname' => $authorNick2,
|
2019-07-12 16:31:14 +01:00
|
|
|
'email' => $authorNick2 . '@example.net',
|
2020-06-24 13:08:11 +01:00
|
|
|
'email_confirmed' => true,]);
|
2019-07-12 16:31:14 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
self::$targetUser1 = User::register(['nickname' => $targetNick1,
|
2019-07-12 16:31:14 +01:00
|
|
|
'email' => $targetNick1 . '@example.net',
|
2020-06-24 13:08:11 +01:00
|
|
|
'email_confirmed' => true,]);
|
2019-07-12 16:31:14 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
self::$targetUser2 = User::register(['nickname' => $targetNick2,
|
2019-07-12 16:31:14 +01:00
|
|
|
'email' => $targetNick2 . '@example.net',
|
2020-06-24 13:08:11 +01:00
|
|
|
'email_confirmed' => true,]);
|
2019-07-12 16:31:14 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
self::$targetGroup1 = User_group::register(['nickname' => $groupNick1,
|
2019-07-12 16:31:14 +01:00
|
|
|
'userid' => self::$author1->id,
|
2020-06-24 13:08:11 +01:00
|
|
|
'aliases' => [],
|
2019-07-12 16:31:14 +01:00
|
|
|
'local' => true,
|
|
|
|
'location' => null,
|
|
|
|
'description' => null,
|
|
|
|
'fullname' => null,
|
|
|
|
'homepage' => null,
|
2020-06-24 13:08:11 +01:00
|
|
|
'mainpage' => null,]);
|
|
|
|
self::$targetGroup2 = User_group::register(['nickname' => $groupNick2,
|
2019-07-12 16:31:14 +01:00
|
|
|
'userid' => self::$author1->id,
|
2020-06-24 13:08:11 +01:00
|
|
|
'aliases' => [],
|
2019-07-12 16:31:14 +01:00
|
|
|
'local' => true,
|
|
|
|
'location' => null,
|
|
|
|
'description' => null,
|
|
|
|
'fullname' => null,
|
|
|
|
'homepage' => null,
|
2020-06-24 13:08:11 +01:00
|
|
|
'mainpage' => null,]);
|
2016-08-09 05:12:25 +01:00
|
|
|
} catch (Exception $e) {
|
2020-06-24 13:08:11 +01:00
|
|
|
static::tearDownAfterClass();
|
2019-07-12 16:31:14 +01:00
|
|
|
throw $e;
|
2016-08-09 05:12:25 +01:00
|
|
|
}
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testBasicNoticeActivity()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, false);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($notice->getUri(), ActivityUtils::childContent($element, 'id'));
|
|
|
|
static::assertSame('New note by ' . self::$author1->nickname, ActivityUtils::childContent($element, 'title'));
|
|
|
|
static::assertSame($notice->rendered, ActivityUtils::childContent($element, 'content'));
|
|
|
|
static::assertSame(strtotime($notice->created), strtotime(ActivityUtils::childContent($element, 'published')));
|
|
|
|
static::assertSame(strtotime($notice->created), strtotime(ActivityUtils::childContent($element, 'updated')));
|
|
|
|
static::assertSame(ActivityVerb::POST, ActivityUtils::childContent($element, 'verb', Activity::SPEC));
|
|
|
|
static::assertSame(ActivityObject::NOTE, ActivityUtils::childContent($element, 'object-type', Activity::SPEC));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testNamespaceFlag()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, false);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertTrue($element->hasAttribute('xmlns'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:thr'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:georss'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:activity'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:media'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:poco'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:ostatus'));
|
|
|
|
static::assertTrue($element->hasAttribute('xmlns:statusnet'));
|
2010-08-03 21:41:44 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertFalse($element->hasAttribute('xmlns'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:thr'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:georss'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:activity'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:media'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:poco'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:ostatus'));
|
|
|
|
static::assertFalse($element->hasAttribute('xmlns:statusnet'));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 22:17:36 +01:00
|
|
|
public function testSourceFlag()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2010-08-03 22:17:36 +01:00
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
// Test with no source
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, false);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$source = ActivityUtils::child($element, 'source');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNull($source);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
// Test with source
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$source = ActivityUtils::child($element, 'source');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNotNull($source);
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 22:17:36 +01:00
|
|
|
public function testSourceContent()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2010-08-03 22:17:36 +01:00
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
// make a time difference!
|
|
|
|
sleep(2);
|
|
|
|
$notice2 = $this->_fakeNotice();
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$source = ActivityUtils::child($element, 'source');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$atomUrl = common_local_url('ApiTimelineUser', ['id' => self::$author1->id, 'format' => 'atom']);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$profile = self::$author1->getProfile();
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($atomUrl, ActivityUtils::childContent($source, 'id'));
|
|
|
|
static::assertSame($atomUrl, ActivityUtils::getLink($source, 'self', 'application/atom+xml'));
|
|
|
|
static::assertSame($profile->profileurl, ActivityUtils::getPermalink($source));
|
|
|
|
static::assertSame(strtotime($notice2->created), strtotime(ActivityUtils::childContent($source, 'updated')));
|
2010-08-03 22:17:36 +01:00
|
|
|
// XXX: do we care here?
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertFalse(is_null(ActivityUtils::childContent($source, 'title')));
|
|
|
|
static::assertSame(common_config('license', 'url'), ActivityUtils::getLink($source, 'license'));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 22:17:36 +01:00
|
|
|
public function testAuthorFlag()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2010-08-03 22:17:36 +01:00
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
// Test with no author
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, false, false);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNull(ActivityUtils::child($element, 'author'));
|
|
|
|
static::assertNull(ActivityUtils::child($element, 'actor', Activity::SPEC));
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
// Test with source
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, false, true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$author = ActivityUtils::child($element, 'author');
|
2019-07-12 16:31:14 +01:00
|
|
|
$actor = ActivityUtils::child($element, 'actor', Activity::SPEC);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertFalse(is_null($author));
|
|
|
|
static::assertTrue(is_null($actor)); // <activity:actor> is obsolete, no longer added
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 23:26:19 +01:00
|
|
|
public function testAuthorContent()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2010-08-03 23:26:19 +01:00
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
// Test with author
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, false, true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$author = ActivityUtils::child($element, 'author');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame(self::$author1->getNickname(), ActivityUtils::childContent($author, 'name'));
|
|
|
|
static::assertSame(self::$author1->getUri(), ActivityUtils::childContent($author, 'uri'));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-12-30 21:21:59 +00:00
|
|
|
/**
|
|
|
|
* We no longer create <activity:actor> entries, they have merged to <atom:author>
|
|
|
|
*/
|
2010-08-03 23:49:49 +01:00
|
|
|
public function testActorContent()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
// Test with author
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry(false, false, true);
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$actor = ActivityUtils::child($element, 'actor', Activity::SPEC);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($actor, null);
|
2010-08-03 23:49:49 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 22:17:36 +01:00
|
|
|
public function testReplyLink()
|
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
$orig = $this->_fakeNotice(self::$targetUser1);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '@' . self::$targetUser1->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$reply = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null, 'reply_to' => $orig->id]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
$entry = $reply->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$irt = ActivityUtils::child($element, 'in-reply-to', 'http://purl.org/syndication/thread/1.0');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNotNull($irt);
|
|
|
|
static::assertSame($orig->getUri(), $irt->getAttribute('ref'));
|
|
|
|
static::assertSame($orig->getUrl(), $irt->getAttribute('href'));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testReplyAttention()
|
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
$orig = $this->_fakeNotice(self::$targetUser1);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '@' . self::$targetUser1->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$reply = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null, 'reply_to' => $orig->id]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
$entry = $reply->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame(self::$targetUser1->getUri(), ActivityUtils::getLink($element, 'mentioned'));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testMultipleReplyAttention()
|
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
$orig = $this->_fakeNotice(self::$targetUser1);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '@' . self::$targetUser1->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$reply = Notice::saveNew(self::$targetUser2->id, $text, 'test', ['uri' => null, 'reply_to' => $orig->id]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '@' . self::$targetUser1->nickname . ' @' . self::$targetUser2->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$reply2 = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null, 'reply_to' => $reply->id]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
$entry = $reply2->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2013-10-21 17:42:15 +01:00
|
|
|
$links = ActivityUtils::getLinks($element, 'mentioned');
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$hrefs = [];
|
2010-08-04 00:04:19 +01:00
|
|
|
|
|
|
|
foreach ($links as $link) {
|
|
|
|
$hrefs[] = $link->getAttribute('href');
|
|
|
|
}
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertTrue(in_array(self::$targetUser1->getUri(), $hrefs));
|
|
|
|
static::assertTrue(in_array(self::$targetUser2->getUri(), $hrefs));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGroupPostAttention()
|
|
|
|
{
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '!' . self::$targetGroup1->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$notice = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame(self::$targetGroup1->getUri(), ActivityUtils::getLink($element, 'mentioned'));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testMultipleGroupPostAttention()
|
|
|
|
{
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '!' . self::$targetGroup1->nickname . ' !' . self::$targetGroup2->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$notice = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null]);
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2013-10-21 17:42:15 +01:00
|
|
|
$links = ActivityUtils::getLinks($element, 'mentioned');
|
2010-08-03 22:17:36 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$hrefs = [];
|
2010-08-03 22:17:36 +01:00
|
|
|
|
|
|
|
foreach ($links as $link) {
|
|
|
|
$hrefs[] = $link->getAttribute('href');
|
|
|
|
}
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertTrue(in_array(self::$targetGroup1->getUri(), $hrefs));
|
|
|
|
static::assertTrue(in_array(self::$targetGroup2->getUri(), $hrefs));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testRepeatLink()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
$notice = $this->_fakeNotice(self::$author1);
|
|
|
|
$repeat = $notice->repeat(self::$author2->getProfile(), 'test');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $repeat->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', 'http://status.net/schema/api/1/');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNotNull($noticeInfo);
|
|
|
|
static::assertSame($notice->id, $noticeInfo->getAttribute('repeat_of'));
|
|
|
|
static::assertSame($repeat->id, $noticeInfo->getAttribute('local_id'));
|
2010-08-03 23:26:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testTag()
|
|
|
|
{
|
2013-10-21 12:20:30 +01:00
|
|
|
$tag1 = common_random_hexstr(4);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$notice = $this->_fakeNotice(self::$author1, '#' . $tag1);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$category = ActivityUtils::child($element, 'category');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNotNull($category);
|
|
|
|
static::assertSame($tag1, $category->getAttribute('term'));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 23:26:19 +01:00
|
|
|
public function testMultiTag()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2013-10-21 12:20:30 +01:00
|
|
|
$tag1 = common_random_hexstr(4);
|
|
|
|
$tag2 = common_random_hexstr(4);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$notice = $this->_fakeNotice(self::$author1, '#' . $tag1 . ' #' . $tag2);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
|
|
|
$categories = $element->getElementsByTagName('category');
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertNotNull($categories);
|
|
|
|
static::assertSame(2, $categories->length);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$terms = [];
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
for ($i = 0; $i < $categories->length; ++$i) {
|
2010-08-03 23:26:19 +01:00
|
|
|
$cat = $categories->item($i);
|
|
|
|
$terms[] = $cat->getAttribute('term');
|
|
|
|
}
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertTrue(in_array($tag1, $terms));
|
|
|
|
static::assertTrue(in_array($tag2, $terms));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGeotaggedActivity()
|
|
|
|
{
|
2020-06-24 13:08:11 +01:00
|
|
|
$notice = Notice::saveNew(self::$author1->id, common_random_hexstr(4), 'test', ['uri' => null, 'lat' => 45.5, 'lon' => -73.6]);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame('45.5000000 -73.6000000', ActivityUtils::childContent($element, 'point', 'http://www.georss.org/georss'));
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2010-08-03 22:17:36 +01:00
|
|
|
public function testNoticeInfo()
|
2010-08-03 21:41:44 +01:00
|
|
|
{
|
2010-08-03 23:26:19 +01:00
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
|
|
|
$entry = $notice->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', 'http://status.net/schema/api/1/');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($notice->id, $noticeInfo->getAttribute('local_id'));
|
|
|
|
static::assertSame($notice->source, $noticeInfo->getAttribute('source'));
|
|
|
|
static::assertSame('', $noticeInfo->getAttribute('repeat_of'));
|
|
|
|
static::assertSame('', $noticeInfo->getAttribute('repeated'));
|
2014-06-28 12:11:03 +01:00
|
|
|
// $this->assertEquals('', $noticeInfo->getAttribute('favorite'));
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame('', $noticeInfo->getAttribute('source_link'));
|
2010-08-03 23:26:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testNoticeInfoRepeatOf()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$repeat = $notice->repeat(self::$author2->getProfile(), 'test');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $repeat->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', 'http://status.net/schema/api/1/');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($notice->id, $noticeInfo->getAttribute('repeat_of'));
|
2010-08-03 23:26:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testNoticeInfoRepeated()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$repeat = $notice->repeat(self::$author2->getProfile(), 'test');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$entry = $notice->asAtomEntry(false, false, false, self::$author2->getProfile());
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', 'http://status.net/schema/api/1/');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame('true', $noticeInfo->getAttribute('repeated'));
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
$entry = $notice->asAtomEntry(false, false, false, self::$targetUser1->getProfile());
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', 'http://status.net/schema/api/1/');
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame('false', $noticeInfo->getAttribute('repeated'));
|
2010-08-03 23:26:19 +01:00
|
|
|
}
|
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
/* public function testNoticeInfoFave()
|
|
|
|
{
|
|
|
|
$notice = $this->_fakeNotice();
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$fave = Fave::addNew(self::$author2->getProfile(), $notice);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
// Should be set if user has faved
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$entry = $notice->asAtomEntry(false, false, false, self::$author2);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$element = $this->_entryToElement($entry, true);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', "http://status.net/schema/api/1/");
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$this->assertEquals('true', $noticeInfo->getAttribute('favorite'));
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
// Shouldn't be set if user has not faved
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$entry = $notice->asAtomEntry(false, false, false, self::$targetUser1);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$element = $this->_entryToElement($entry, true);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$noticeInfo = ActivityUtils::child($element, 'notice_info', "http://status.net/schema/api/1/");
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2019-07-12 16:31:14 +01:00
|
|
|
$this->assertEquals('false', $noticeInfo->getAttribute('favorite'));
|
|
|
|
}*/
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
public function testConversationLink()
|
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
$orig = $this->_fakeNotice(self::$targetUser1);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = '@' . self::$targetUser1->nickname . ' reply text ' . common_random_hexstr(4);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
$reply = Notice::saveNew(self::$author1->id, $text, 'test', ['uri' => null, 'reply_to' => $orig->id]);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
2013-08-18 12:04:58 +01:00
|
|
|
$conv = Conversation::getKV('id', $reply->conversation);
|
2010-08-03 23:26:19 +01:00
|
|
|
|
|
|
|
$entry = $reply->asAtomEntry();
|
|
|
|
|
|
|
|
$element = $this->_entryToElement($entry, true);
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
static::assertSame($conv->getUrl(), ActivityUtils::getLink($element, 'ostatus:conversation'));
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2019-07-25 01:29:20 +01:00
|
|
|
public static function tearDownAfterClass(): void
|
2010-08-03 22:17:36 +01:00
|
|
|
{
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$author1)) {
|
|
|
|
self::$author1->getProfile()->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$author2)) {
|
|
|
|
self::$author2->getProfile()->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$targetUser1)) {
|
|
|
|
self::$targetUser1->getProfile()->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$targetUser2)) {
|
|
|
|
self::$targetUser2->getProfile()->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$targetGroup1)) {
|
|
|
|
self::$targetGroup1->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
|
|
|
|
2016-08-09 05:12:25 +01:00
|
|
|
if (!is_null(self::$targetGroup2)) {
|
|
|
|
self::$targetGroup2->delete();
|
2010-08-03 22:17:36 +01:00
|
|
|
}
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private function _fakeNotice($user = null, $text = null)
|
|
|
|
{
|
|
|
|
if (empty($user)) {
|
2016-08-09 05:12:25 +01:00
|
|
|
$user = self::$author1;
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($text)) {
|
2020-06-24 13:08:11 +01:00
|
|
|
$text = 'fake-o text-o ' . common_random_hexstr(32);
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
2020-06-24 13:08:11 +01:00
|
|
|
return Notice::saveNew($user->id, $text, 'test', ['uri' => null]);
|
2010-08-03 21:41:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private function _entryToElement($entry, $namespace = false)
|
|
|
|
{
|
2019-07-12 16:31:14 +01:00
|
|
|
$xml = '<?xml version="1.0" encoding="utf-8"?>' . "\n\n";
|
2010-08-03 21:41:44 +01:00
|
|
|
$xml .= '<feed';
|
|
|
|
if ($namespace) {
|
|
|
|
$xml .= ' xmlns="http://www.w3.org/2005/Atom"';
|
|
|
|
$xml .= ' xmlns:thr="http://purl.org/syndication/thread/1.0"';
|
|
|
|
$xml .= ' xmlns:georss="http://www.georss.org/georss"';
|
|
|
|
$xml .= ' xmlns:activity="http://activitystrea.ms/spec/1.0/"';
|
|
|
|
$xml .= ' xmlns:media="http://purl.org/syndication/atommedia"';
|
|
|
|
$xml .= ' xmlns:poco="http://portablecontacts.net/spec/1.0"';
|
|
|
|
$xml .= ' xmlns:ostatus="http://ostatus.org/schema/1.0"';
|
|
|
|
$xml .= ' xmlns:statusnet="http://status.net/schema/api/1/"';
|
|
|
|
}
|
|
|
|
$xml .= '>' . "\n" . $entry . "\n" . '</feed>' . "\n";
|
2019-07-12 16:31:14 +01:00
|
|
|
$doc = new DOMDocument();
|
|
|
|
$doc->loadXML($xml);
|
2010-08-03 21:41:44 +01:00
|
|
|
$feed = $doc->documentElement;
|
|
|
|
$entries = $feed->getElementsByTagName('entry');
|
|
|
|
|
|
|
|
return $entries->item(0);
|
|
|
|
}
|
|
|
|
}
|