Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

extend check for like and repost since some people are sending that #9

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 17 additions & 22 deletions src/indieweb/comments.php
Original file line number Diff line number Diff line change
Expand Up @@ -151,31 +151,26 @@ function parse($mf, $refURL=false, $maxTextLength=150, $maxLines=2) {
}

// Check if this post is a "repost"
if($refURL && array_key_exists('repost-of', $properties)) {
collectURLs($properties['repost-of']);
if(in_array($refURL, $properties['repost-of']))
$type = 'repost';
}

// Also check for "u-repost" since some people are sending that. Probably "u-repost-of" will win out.
if($refURL && array_key_exists('repost', $properties)) {
collectURLs($properties['repost']);
if(in_array($refURL, $properties['repost']))
$type = 'repost';
}

// Check if this post is a "like-of"
if($refURL && array_key_exists('like-of', $properties)) {
collectURLs($properties['like-of']);
if(in_array($refURL, $properties['like-of']))
$type = 'like';
foreach(array('repost-of', 'u-repost-of', 'u-repost', 'repost') as $repost) {
if($refURL && array_key_exists($repost, $properties)) {
collectURLs($properties[$repost]);
if(in_array($refURL, $properties[$repost]))
$type = 'repost';
break;
}
}

// Check if this post is a "like" (Should be deprecated in the future)
if($refURL && array_key_exists('like', $properties)) {
collectURLs($properties['like']);
if(in_array($refURL, $properties['like']))
$type = 'like';
// Check if this post is a "like"
// Prefer "like-of" but also check for "u-lile-of", "u-like" and "like" (should be deprecated in the future)
foreach(array('like-of', 'u-like-of', 'u-like', 'like') as $like) {
if($refURL && array_key_exists($like, $properties)) {
collectURLs($properties[$like]);
if(in_array($refURL, $properties[$like])) {
$type = 'like';
break;
}
}
}

// From http://indiewebcamp.com/comments-presentation#How_to_display
Expand Down
76 changes: 58 additions & 18 deletions tests/BasicTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ private function buildHEntry($input, $author=false, $replyTo=true) {
'photo' => array('http://aaronparecki.com/images/aaronpk.png')
)
))
),
),
'published' => array('2014-02-16T18:48:17-0800'),
'url' => array('http://aaronparecki.com/post/1'),
)
Expand All @@ -29,7 +29,7 @@ private function buildHEntry($input, $author=false, $replyTo=true) {
$entry['properties']['in-reply-to'] = array($this->_refURL);
}
if(is_array($replyTo)) {
$entry['properties']['in-reply-to'] = array($replyTo);
$entry['properties']['in-reply-to'] = array($replyTo);
}
if(array_key_exists('content', $input)) {
if(is_string($input['content'])) {
Expand All @@ -51,8 +51,8 @@ private function buildHEntry($input, $author=false, $replyTo=true) {

public function testBasicExample() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'post summary',
'name' => 'post name',
'summary' => 'post summary',
'content' => 'this is some content'
)), $this->_refURL, 90);
$this->assertEquals(array(
Expand All @@ -71,8 +71,8 @@ public function testBasicExample() {

public function testContentTooLongSummaryIsOk() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'post summary',
'name' => 'post name',
'summary' => 'post summary',
'content' => '<p>this is some content but it is longer than 90 characters so the summary will be used instead</p>'
)), $this->_refURL, 90);
$this->assertEquals('reply', $result['type']);
Expand All @@ -81,8 +81,8 @@ public function testContentTooLongSummaryIsOk() {

public function testContentTooLongSummaryTooLong() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'in this case the post summary is also too long, so a truncated version should be displayed instead',
'name' => 'post name',
'summary' => 'in this case the post summary is also too long, so a truncated version should be displayed instead',
'content' => '<p>this is some content but it is longer than 90 characters so the summary will be used instead</p>'
)), $this->_refURL, 90);
$this->assertEquals('reply', $result['type']);
Expand All @@ -91,7 +91,7 @@ public function testContentTooLongSummaryTooLong() {

public function testContentTooLongNoSummary() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'name' => 'post name',
'content' => '<p>this is some content but it is longer than 90 characters so it will be truncated because there is no summary</p>'
)), $this->_refURL, 90);
$this->assertEquals('reply', $result['type']);
Expand Down Expand Up @@ -228,13 +228,13 @@ public function testMultiLineCommentFitsWithinLimits() {
public function testTrimMultiLineCommentHalfWayThroughThirdLine() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'content' => array(
'html' => '#HouseOfCards s2e1 was good.
'html' => '#HouseOfCards s2e1 was good.
But the best thing yesterday was getting to try a Boosted electric skateboard: <a class="auto-link" href="http://boostedboards.com/">http://boostedboards.com/</a>

Amazing. Handheld trigger remote control via Bluetooth. Forward and reverse. And I only tried it in &quot;turtle&quot; mode. In &quot;rabbit&quot; mode it can apparently do 20 miles an hour. Up hill. Jetsons-like motor sound included.

Forget about Segway, Boosted&#039;s electric skateboard feels like an object from the future dropped into the present, more in the realm of Marty&#039;s hoverboard (Back To The Future II &amp; III) and Y.T.&#039;s Smartwheels skateboard (Snow Crash).',
'value' => "#HouseOfCards s2e1 was good.
'value' => "#HouseOfCards s2e1 was good.
But the best thing yesterday was getting to try a Boosted electric skateboard: http://boostedboards.com/

Amazing. Handheld trigger remote control via Bluetooth. Forward and reverse. And I only tried it in \"turtle\" mode. In \"rabbit\" mode it can apparently do 20 miles an hour. Up hill. Jetsons-like motor sound included.
Expand All @@ -244,7 +244,7 @@ public function testTrimMultiLineCommentHalfWayThroughThirdLine() {
), false, false), $this->_refURL, 197, 3);
$this->assertEquals('mention', $result['type']);
$this->assertEquals('', $result['name']);
$this->assertEquals("#HouseOfCards s2e1 was good.
$this->assertEquals("#HouseOfCards s2e1 was good.
But the best thing yesterday was getting to try a Boosted electric skateboard: http://boostedboards.com/

Amazing. Handheld trigger remote control via Bluetooth. ...", $result['text']);
Expand Down Expand Up @@ -316,6 +316,26 @@ public function testIsLikeOf() {
$this->assertEquals('liked this post', $result['text']);
}

public function testIsULikeOf() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Liked this',
'content' => 'liked this post',
'u-like-of' => $this->_refURL
)), $this->_refURL, 200);
$this->assertEquals('like', $result['type']);
$this->assertEquals('liked this post', $result['text']);
}

public function testIsULike() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Liked this',
'content' => 'liked this post',
'u-like' => $this->_refURL
)), $this->_refURL, 200);
$this->assertEquals('like', $result['type']);
$this->assertEquals('liked this post', $result['text']);
}

public function testIsRepostOf() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Reposted this',
Expand All @@ -326,6 +346,26 @@ public function testIsRepostOf() {
$this->assertEquals('Reposted this', $result['text']);
}

public function testIsURepostOf() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Reposted this',
'content' => 'Reposted this',
'u-repost-of' => $this->_refURL
)), $this->_refURL, 200);
$this->assertEquals('repost', $result['type']);
$this->assertEquals('Reposted this', $result['text']);
}

public function testIsURepost() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Reposted this',
'content' => 'Reposted this',
'u-repost' => $this->_refURL
)), $this->_refURL, 200);
$this->assertEquals('repost', $result['type']);
$this->assertEquals('Reposted this', $result['text']);
}

public function testIsRepost() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'Reposted this',
Expand Down Expand Up @@ -366,8 +406,8 @@ public function testIsLikeOfHCite() {

public function testAuthorIsURL() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'post summary',
'name' => 'post name',
'summary' => 'post summary',
'content' => '<p>this is some content</p>'
), 'http://aaronparecki.com/'), $this->_refURL, 200);
$author = $result['author'];
Expand All @@ -379,8 +419,8 @@ public function testAuthorIsURL() {

public function testAuthorIsHCard() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'post summary',
'name' => 'post name',
'summary' => 'post summary',
'content' => '<p>this is some content</p>'
)), $this->_refURL, 200);
$author = $result['author'];
Expand All @@ -392,8 +432,8 @@ public function testAuthorIsHCard() {

public function testAuthorIsHCardWithNoPhoto() {
$result = IndieWeb\comments\parse($this->buildHEntry(array(
'name' => 'post name',
'summary' => 'post summary',
'name' => 'post name',
'summary' => 'post summary',
'content' => '<p>this is some content</p>'
), array(
'type' => array('h-card'),
Expand Down