Beispiel #1
0
 public function executeRssBox()
 {
     $fetcher = new opRssFetcher('UTF-8');
     $this->result = @$fetcher->fetch($this->gadget->getConfig('url'), true);
     if ($this->result) {
         $this->result[1] = array_slice($this->result[1], 0, 5);
     }
 }
Beispiel #2
0
$t->is(count($result), 10, '->fetch() for www.openpne.jp is returns array that contains recently 10 Atom entries');
$t->is($result[0]['title'], 'OpenPNE 3.2RC1 リリースのお知らせ', '->fetch() returns Atom entries that contains valid title');
$t->is($result[1]['title'], '', '->fetch() returns Atom entries that contains empty title');
$t->is($result[0]['body'], 'OpenPNE 開発チームの海老原です。
				本日 2009/11/30(月)、 開発版 OpenPNE 3.2RC1 をリリースしました。
				今後の OpenPNE3 のリリーススケジュール にて発表 [...]', '->fetch() returns Atom entries that contains valid body');
$t->is($result[4]['body'], '<p>開発チームの海老原です。</p>
				<p>11/23 に <a href="http://www.openpne.jp/archives/3931/">opAlbumPlugin のアップデート</a>が、 11/24 に <a href="http://www.openpne.jp/archives/3938/">opDiaryPlugin のアップデート</a>がありました。</p>
				<p>どちらも重要なバグフィックスがおこなわれたリリースのため、 OpenPNE 3.1.5 にバンドルされているプラグインも、新しく更新されたバージョンに変更しました。</p>
				<p>以下のコマンドを実行することで、更新された opAlbumPlugin と opDiaryPlugin が利用できます。<br />
				<code>./symfony openpne:migrate</code></p>', '->fetch() returns Atom entries that contains valid content');
$t->is($result[5]['body'], '', '->fetch() returns Atom entries that contains empty body');
$t->is($result[0]['link'], 'http://www.openpne.jp/archives/3988/', '->fetch() returns Atom entries that contains valid link');
$t->is($result[2]['link'], '', '->fetch() returns Atom entries that contains empty link');
$t->is($result[0]['date'], '2009-11-30 01:16:36', '->fetch() returns Atom entries that contains valid date');
$t->is($result[6]['date'], '2009-11-23 19:57:27', '->fetch() returns Atom entries that contains updated date');
$t->is($result[8]['date'], '', '->fetch() returns Atom entries that contains empty date');
$t->isa_ok($result[0]['enclosure'], 'SimplePie_Enclosure', '->fetch() returns Atom entries that contains valid enclosure');
$t->is($result[7]['enclosure'], '', '->fetch() returns Atom entries that contains empty enclosure');
$result = $mock->fetch('www.openpne.jp.feed.rss', true);
$t->is($result[0], 'OpenPNE', '->fetch() returns also RSS feed title if the second parameter is true');
$result = $mock->fetch('www.openpne.jp.feed.atom', true);
$t->is($result[0], 'OpenPNE', '->fetch() returns also Atom feed title if the second parameter is true');
$t->is($instance->fetch('http://example.com/undefined.rss'), false, '->fetch() returns false if the specified uri is 404');
$t->is($mock->fetch('www.openpne.jp.feed.empty.rss'), false, '->fetch() returns false if the specified feed does not have any entries');
$t->is($mock->fetch('www.openpne.jp.feed.empty.rss', true), false, '->fetch() returns false if the specified feed does not have any entries even if the second parameter is specified');
$t->diag('::autoDiscovery');
$url = opRssFetcher::autoDiscovery(opRssFetcherMock::calcFixtureFilePath('www.openpne.jp.html'));
$t->is($url, 'http://www.openpne.jp/feed/', '::autoDiscovery() returns a valid feed url');
$url = opRssFetcher::autoDiscovery(opRssFetcherMock::calcFixtureFilePath('www.co3k.org.html'));
$t->is($url, '', '::autoDiscovery() returns an empty string if the specified uri does not have related feeds');