123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- from collections import defaultdict
- import mock
- from searx.engines import bing_news
- from searx.testing import SearxTestCase
- class TestBingNewsEngine(SearxTestCase):
- def test_request(self):
- query = 'test_query'
- dicto = defaultdict(dict)
- dicto['pageno'] = 1
- dicto['language'] = 'fr_FR'
- params = bing_news.request(query, dicto)
- self.assertIn('url', params)
- self.assertIn(query, params['url'])
- self.assertIn('bing.com', params['url'])
- self.assertIn('fr', params['url'])
- self.assertIn('_FP', params['cookies'])
- self.assertIn('en', params['cookies']['_FP'])
- dicto['language'] = 'all'
- params = bing_news.request(query, dicto)
- self.assertIn('en', params['url'])
- self.assertIn('_FP', params['cookies'])
- self.assertIn('en', params['cookies']['_FP'])
- def test_response(self):
- self.assertRaises(AttributeError, bing_news.response, None)
- self.assertRaises(AttributeError, bing_news.response, [])
- self.assertRaises(AttributeError, bing_news.response, '')
- self.assertRaises(AttributeError, bing_news.response, '[]')
- response = mock.Mock(content='<html></html>')
- self.assertEqual(bing_news.response(response), [])
- response = mock.Mock(content='<html></html>')
- self.assertEqual(bing_news.response(response), [])
- html = """
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">44 minutes ago</span>
- </div>
- </div>
- </div>
- </div>
- """
- response = mock.Mock(content=html)
- results = bing_news.response(response)
- self.assertEqual(type(results), list)
- self.assertEqual(len(results), 1)
- self.assertEqual(results[0]['title'], 'Title')
- self.assertEqual(results[0]['url'], 'http://url.of.article/')
- self.assertEqual(results[0]['content'], 'Article Content')
- html = """
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">44 minutes ago</span>
- </div>
- </div>
- </div>
- </div>
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">3 hours, 44 minutes ago</span>
- </div>
- </div>
- </div>
- </div>
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">44 hours ago</span>
- </div>
- </div>
- </div>
- </div>
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">2 days ago</span>
- </div>
- </div>
- </div>
- </div>
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">27/01/2015</span>
- </div>
- </div>
- </div>
- </div>
- <div class="sn_r">
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">Il y a 3 heures</span>
- </div>
- </div>
- </div>
- </div>
- """
- response = mock.Mock(content=html)
- results = bing_news.response(response)
- self.assertEqual(type(results), list)
- self.assertEqual(len(results), 6)
- html = """
- <div class="newstitle">
- <a href="http://url.of.article/" target="_blank" h="ID=news,5022.1">
- Title
- </a>
- </div>
- <div class="sn_img">
- <a href="http://url.of.article2/" target="_blank" h="ID=news,5024.1">
- <img class="rms_img" height="80" id="emb1" src="/image.src" title="Title" width="80" />
- </a>
- </div>
- <div class="sn_txt">
- <div class="sn_oi">
- <span class="sn_snip">Article Content</span>
- <div class="sn_ST">
- <cite class="sn_src">metronews.fr</cite>
- · 
- <span class="sn_tm">44 minutes ago</span>
- </div>
- </div>
- </div>
- """
- response = mock.Mock(content=html)
- results = bing_news.response(response)
- self.assertEqual(type(results), list)
- self.assertEqual(len(results), 0)
|