Browse Source

Google news' unit test

Cqoicebordel 10 years ago
parent
commit
b7dc1fb9d5
3 changed files with 141 additions and 2 deletions
  1. 4 2
      searx/engines/google_news.py
  2. 136 0
      searx/tests/engines/test_google_news.py
  3. 1 0
      searx/tests/test_engines.py

+ 4 - 2
searx/engines/google_news.py

@@ -20,7 +20,7 @@ language_support = True
 
 # engine dependent config
 url = 'https://ajax.googleapis.com/'
-search_url = url + 'ajax/services/search/news?v=2.0&start={offset}&rsz=large&safe=off&filter=off&{query}&hl={language}'  # noqa
+search_url = url + 'ajax/services/search/news?v=2.0&start={offset}&rsz=large&safe=off&filter=off&{query}&hl={lang}'
 
 
 # do search-request
@@ -33,7 +33,7 @@ def request(query, params):
 
     params['url'] = search_url.format(offset=offset,
                                       query=urlencode({'q': query}),
-                                      language=language)
+                                      lang=language)
 
     return params
 
@@ -52,6 +52,8 @@ def response(resp):
     for result in search_res['responseData']['results']:
         # parse publishedDate
         publishedDate = parser.parse(result['publishedDate'])
+        if 'url' not in result:
+            continue
 
         # append result
         results.append({'url': result['unescapedUrl'],

+ 136 - 0
searx/tests/engines/test_google_news.py

@@ -0,0 +1,136 @@
+from collections import defaultdict
+import mock
+from searx.engines import google_news
+from searx.testing import SearxTestCase
+
+
+class TestGoogleNewsEngine(SearxTestCase):
+
+    def test_request(self):
+        query = 'test_query'
+        dicto = defaultdict(dict)
+        dicto['pageno'] = 1
+        dicto['language'] = 'fr_FR'
+        params = google_news.request(query, dicto)
+        self.assertIn('url', params)
+        self.assertIn(query, params['url'])
+        self.assertIn('googleapis.com', params['url'])
+        self.assertIn('fr', params['url'])
+
+        dicto['language'] = 'all'
+        params = google_news.request(query, dicto)
+        self.assertIn('url', params)
+        self.assertIn('en', params['url'])
+
+    def test_response(self):
+        self.assertRaises(AttributeError, google_news.response, None)
+        self.assertRaises(AttributeError, google_news.response, [])
+        self.assertRaises(AttributeError, google_news.response, '')
+        self.assertRaises(AttributeError, google_news.response, '[]')
+
+        response = mock.Mock(text='{}')
+        self.assertEqual(google_news.response(response), [])
+
+        response = mock.Mock(text='{"data": []}')
+        self.assertEqual(google_news.response(response), [])
+
+        json = """
+        {
+        "responseData": {
+            "results": [
+            {
+                "GsearchResultClass": "GnewsSearch",
+                "clusterUrl": "http://news.google.com/news/story?ncl=d2d3t1LMDpNIj2MPPhdTT0ycN4sWM&hl=fr&ned=fr",
+                "content": "This is the content",
+                "unescapedUrl": "http://this.is.the.url",
+                "url": "http://this.is.the.url",
+                "title": "This is the title",
+                "titleNoFormatting": "This is the title",
+                "location": "",
+                "publisher": "Jeux Actu",
+                "publishedDate": "Fri, 30 Jan 2015 11:00:25 -0800",
+                "signedRedirectUrl": "http://news.google.com/",
+                "language": "fr",
+                "image": {
+                "url": "http://i.jeuxactus.com/datas/jeux/d/y/dying-light/vu/dying-light-54cc080b568fb.jpg",
+                "tbUrl": "http://t1.gstatic.com/images?q=tbn:ANd9GcSF4yYrs9Ycw23DGiOSAZ-5SEPXYwG3LNs",
+                "originalContextUrl": "http://www.jeuxactu.com/test-dying-light-sur-ps4-97208.htm",
+                "publisher": "Jeux Actu",
+                "tbWidth": 80,
+                "tbHeight": 30
+                },
+                "relatedStories": [
+                {
+                    "unescapedUrl": "http://www.jeuxvideo.com/test/415823/dying-light.htm",
+                    "url": "http%3A%2F%2Fwww.jeuxvideo.com%2Ftest%2F415823%2Fdying-light.htm",
+                    "title": "<b>Test</b> du jeu Dying Light - jeuxvideo.com",
+                    "titleNoFormatting": "Test du jeu Dying Light - jeuxvideo.com",
+                    "location": "",
+                    "publisher": "JeuxVideo.com",
+                    "publishedDate": "Fri, 30 Jan 2015 08:52:30 -0800",
+                    "signedRedirectUrl": "http://news.google.com/news/url?sa=T&",
+                    "language": "fr"
+                }
+                ]
+            }
+            ]
+        },
+        "responseDetails": null,
+        "responseStatus": 200
+        }
+        """
+        response = mock.Mock(text=json)
+        results = google_news.response(response)
+        self.assertEqual(type(results), list)
+        self.assertEqual(len(results), 1)
+        self.assertEqual(results[0]['title'], 'This is the title')
+        self.assertEqual(results[0]['url'], 'http://this.is.the.url')
+        self.assertEqual(results[0]['content'], 'This is the content')
+
+        json = """
+        {
+        "responseData": {
+            "results": [
+            {
+                "GsearchResultClass": "GnewsSearch",
+                "clusterUrl": "http://news.google.com/news/story?ncl=d2d3t1LMDpNIj2MPPhdTT0ycN4sWM&hl=fr&ned=fr",
+                "content": "This is the content",
+                "unescapedUrl": "http://this.is.the.url",
+                "title": "This is the title",
+                "titleNoFormatting": "This is the title",
+                "location": "",
+                "publisher": "Jeux Actu",
+                "publishedDate": "Fri, 30 Jan 2015 11:00:25 -0800",
+                "signedRedirectUrl": "http://news.google.com/news/",
+                "language": "fr",
+                "image": {
+                "url": "http://i.jeuxactus.com/datas/jeux/d/y/dying-light/vu/dying-light-54cc080b568fb.jpg",
+                "tbUrl": "http://t1.gstatic.com/images?q=tbn:b_6f-OSAZ-5SEPXYwG3LNs",
+                "originalContextUrl": "http://www.jeuxactu.com/test-dying-light-sur-ps4-97208.htm",
+                "publisher": "Jeux Actu",
+                "tbWidth": 80,
+                "tbHeight": 30
+                }
+            }
+            ]
+        },
+        "responseDetails": null,
+        "responseStatus": 200
+        }
+        """
+        response = mock.Mock(text=json)
+        results = google_news.response(response)
+        self.assertEqual(type(results), list)
+        self.assertEqual(len(results), 0)
+
+        json = """
+        {
+        "responseData": {},
+        "responseDetails": null,
+        "responseStatus": 200
+        }
+        """
+        response = mock.Mock(text=json)
+        results = google_news.response(response)
+        self.assertEqual(type(results), list)
+        self.assertEqual(len(results), 0)

+ 1 - 0
searx/tests/test_engines.py

@@ -10,6 +10,7 @@ from searx.tests.engines.test_dummy import *  # noqa
 from searx.tests.engines.test_flickr import *  # noqa
 from searx.tests.engines.test_github import *  # noqa
 from searx.tests.engines.test_google_images import *  # noqa
+from searx.tests.engines.test_google_news import *  # noqa
 from searx.tests.engines.test_kickass import *  # noqa
 from searx.tests.engines.test_mixcloud import *  # noqa
 from searx.tests.engines.test_searchcode_code import *  # noqa