|
@@ -27,116 +27,132 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
self.assertRaises(AttributeError, flickr_noapi.response, '')
|
|
|
self.assertRaises(AttributeError, flickr_noapi.response, '[]')
|
|
|
|
|
|
- response = mock.Mock(text='"search-photos-lite-models","photos":{},"totalItems":')
|
|
|
+ response = mock.Mock(text='"modelExport:{"legend":[],"main":{"search-photos-lite-models":[{"photos":{}}]}}')
|
|
|
self.assertEqual(flickr_noapi.response(response), [])
|
|
|
|
|
|
- response = mock.Mock(text='search-photos-lite-models","photos":{"data": []},"totalItems":')
|
|
|
+ response = \
|
|
|
+ mock.Mock(text='"modelExport:{"legend":[],"main":{"search-photos-lite-models":[{"photos":{"_data":[]}}]}}')
|
|
|
self.assertEqual(flickr_noapi.response(response), [])
|
|
|
|
|
|
# everthing is ok test
|
|
|
json = """
|
|
|
- "search-photos-lite-models","photos":
|
|
|
- {
|
|
|
- "_data": [
|
|
|
- {
|
|
|
- "_flickrModelRegistry": "photo-lite-models",
|
|
|
- "title": "This is the title",
|
|
|
- "username": "Owner",
|
|
|
- "pathAlias": "klink692",
|
|
|
- "realname": "Owner",
|
|
|
- "license": 0,
|
|
|
- "ownerNsid": "59729010@N00",
|
|
|
- "canComment": false,
|
|
|
- "commentCount": 14,
|
|
|
- "faveCount": 21,
|
|
|
- "id": "14001294434",
|
|
|
- "sizes": {
|
|
|
- "c": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_c.jpg",
|
|
|
- "width": 541,
|
|
|
- "height": 800,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_c.jpg",
|
|
|
- "key": "c"
|
|
|
- },
|
|
|
- "h": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_761d32237a_h.jpg",
|
|
|
- "width": 1081,
|
|
|
- "height": 1600,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_761d32237a_h.jpg",
|
|
|
- "key": "h"
|
|
|
- },
|
|
|
- "k": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_f145a2c11a_k.jpg",
|
|
|
- "width": 1383,
|
|
|
- "height": 2048,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_f145a2c11a_k.jpg",
|
|
|
- "key": "k"
|
|
|
- },
|
|
|
- "l": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_b.jpg",
|
|
|
- "width": 692,
|
|
|
- "height": 1024,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_b.jpg",
|
|
|
- "key": "l"
|
|
|
- },
|
|
|
- "m": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777.jpg",
|
|
|
- "width": 338,
|
|
|
- "height": 500,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777.jpg",
|
|
|
- "key": "m"
|
|
|
- },
|
|
|
- "n": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_n.jpg",
|
|
|
- "width": 216,
|
|
|
- "height": 320,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_n.jpg",
|
|
|
- "key": "n"
|
|
|
- },
|
|
|
- "q": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_q.jpg",
|
|
|
- "width": 150,
|
|
|
- "height": 150,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_q.jpg",
|
|
|
- "key": "q"
|
|
|
- },
|
|
|
- "s": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_m.jpg",
|
|
|
- "width": 162,
|
|
|
- "height": 240,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_m.jpg",
|
|
|
- "key": "s"
|
|
|
- },
|
|
|
- "sq": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_s.jpg",
|
|
|
- "width": 75,
|
|
|
- "height": 75,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_s.jpg",
|
|
|
- "key": "sq"
|
|
|
- },
|
|
|
- "t": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_t.jpg",
|
|
|
- "width": 68,
|
|
|
- "height": 100,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_t.jpg",
|
|
|
- "key": "t"
|
|
|
- },
|
|
|
- "z": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_z.jpg",
|
|
|
- "width": 433,
|
|
|
- "height": 640,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_z.jpg",
|
|
|
- "key": "z"
|
|
|
+ modelExport: {
|
|
|
+ "legend": [
|
|
|
+ [
|
|
|
+ "search-photos-lite-models",
|
|
|
+ "0",
|
|
|
+ "photos",
|
|
|
+ "_data",
|
|
|
+ "0"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "main": {
|
|
|
+ "search-photos-lite-models": [
|
|
|
+ {
|
|
|
+ "photos": {
|
|
|
+ "_data": [
|
|
|
+ {
|
|
|
+ "_flickrModelRegistry": "photo-lite-models",
|
|
|
+ "title": "This%20is%20the%20title",
|
|
|
+ "username": "Owner",
|
|
|
+ "pathAlias": "klink692",
|
|
|
+ "realname": "Owner",
|
|
|
+ "license": 0,
|
|
|
+ "ownerNsid": "59729010@N00",
|
|
|
+ "canComment": false,
|
|
|
+ "commentCount": 14,
|
|
|
+ "faveCount": 21,
|
|
|
+ "id": "14001294434",
|
|
|
+ "sizes": {
|
|
|
+ "c": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_c.jpg",
|
|
|
+ "width": 541,
|
|
|
+ "height": 800,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_c.jpg",
|
|
|
+ "key": "c"
|
|
|
+ },
|
|
|
+ "h": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_761d32237a_h.jpg",
|
|
|
+ "width": 1081,
|
|
|
+ "height": 1600,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_761d32237a_h.jpg",
|
|
|
+ "key": "h"
|
|
|
+ },
|
|
|
+ "k": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_f145a2c11a_k.jpg",
|
|
|
+ "width": 1383,
|
|
|
+ "height": 2048,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_f145a2c11a_k.jpg",
|
|
|
+ "key": "k"
|
|
|
+ },
|
|
|
+ "l": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_b.jpg",
|
|
|
+ "width": 692,
|
|
|
+ "height": 1024,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_b.jpg",
|
|
|
+ "key": "l"
|
|
|
+ },
|
|
|
+ "m": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777.jpg",
|
|
|
+ "width": 338,
|
|
|
+ "height": 500,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777.jpg",
|
|
|
+ "key": "m"
|
|
|
+ },
|
|
|
+ "n": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_n.jpg",
|
|
|
+ "width": 216,
|
|
|
+ "height": 320,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_n.jpg",
|
|
|
+ "key": "n"
|
|
|
+ },
|
|
|
+ "q": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_q.jpg",
|
|
|
+ "width": 150,
|
|
|
+ "height": 150,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_q.jpg",
|
|
|
+ "key": "q"
|
|
|
+ },
|
|
|
+ "s": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_m.jpg",
|
|
|
+ "width": 162,
|
|
|
+ "height": 240,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_m.jpg",
|
|
|
+ "key": "s"
|
|
|
+ },
|
|
|
+ "sq": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_s.jpg",
|
|
|
+ "width": 75,
|
|
|
+ "height": 75,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_s.jpg",
|
|
|
+ "key": "sq"
|
|
|
+ },
|
|
|
+ "t": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_t.jpg",
|
|
|
+ "width": 68,
|
|
|
+ "height": 100,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_t.jpg",
|
|
|
+ "key": "t"
|
|
|
+ },
|
|
|
+ "z": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_z.jpg",
|
|
|
+ "width": 433,
|
|
|
+ "height": 640,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_z.jpg",
|
|
|
+ "key": "z"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- ],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
"""
|
|
|
- json = json.replace('\r\n', '').replace('\n', '').replace('\r', '')
|
|
|
+ # Flickr serves search results in a json block named 'modelExport' buried inside a script tag,
|
|
|
+ # this json is served as a single line terminating with a comma.
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|
|
@@ -149,37 +165,51 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
|
|
|
# no n size, only the z size
|
|
|
json = """
|
|
|
- "search-photos-lite-models","photos":
|
|
|
- {
|
|
|
- "_data": [
|
|
|
- {
|
|
|
- "_flickrModelRegistry": "photo-lite-models",
|
|
|
- "title": "This is the title",
|
|
|
- "username": "Owner",
|
|
|
- "pathAlias": "klink692",
|
|
|
- "realname": "Owner",
|
|
|
- "license": 0,
|
|
|
- "ownerNsid": "59729010@N00",
|
|
|
- "canComment": false,
|
|
|
- "commentCount": 14,
|
|
|
- "faveCount": 21,
|
|
|
- "id": "14001294434",
|
|
|
- "sizes": {
|
|
|
- "z": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_z.jpg",
|
|
|
- "width": 433,
|
|
|
- "height": 640,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_z.jpg",
|
|
|
- "key": "z"
|
|
|
+ modelExport: {
|
|
|
+ "legend": [
|
|
|
+ [
|
|
|
+ "search-photos-lite-models",
|
|
|
+ "0",
|
|
|
+ "photos",
|
|
|
+ "_data",
|
|
|
+ "0"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "main": {
|
|
|
+ "search-photos-lite-models": [
|
|
|
+ {
|
|
|
+ "photos": {
|
|
|
+ "_data": [
|
|
|
+ {
|
|
|
+ "_flickrModelRegistry": "photo-lite-models",
|
|
|
+ "title": "This%20is%20the%20title",
|
|
|
+ "username": "Owner",
|
|
|
+ "pathAlias": "klink692",
|
|
|
+ "realname": "Owner",
|
|
|
+ "license": 0,
|
|
|
+ "ownerNsid": "59729010@N00",
|
|
|
+ "canComment": false,
|
|
|
+ "commentCount": 14,
|
|
|
+ "faveCount": 21,
|
|
|
+ "id": "14001294434",
|
|
|
+ "sizes": {
|
|
|
+ "z": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_z.jpg",
|
|
|
+ "width": 433,
|
|
|
+ "height": 640,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_z.jpg",
|
|
|
+ "key": "z"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- ],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
"""
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|
|
@@ -192,37 +222,51 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
|
|
|
# no z or n size
|
|
|
json = """
|
|
|
- "search-photos-lite-models","photos":
|
|
|
- {
|
|
|
- "_data": [
|
|
|
- {
|
|
|
- "_flickrModelRegistry": "photo-lite-models",
|
|
|
- "title": "This is the title",
|
|
|
- "username": "Owner",
|
|
|
- "pathAlias": "klink692",
|
|
|
- "realname": "Owner",
|
|
|
- "license": 0,
|
|
|
- "ownerNsid": "59729010@N00",
|
|
|
- "canComment": false,
|
|
|
- "commentCount": 14,
|
|
|
- "faveCount": 21,
|
|
|
- "id": "14001294434",
|
|
|
- "sizes": {
|
|
|
- "o": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_o.jpg",
|
|
|
- "width": 433,
|
|
|
- "height": 640,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_o.jpg",
|
|
|
- "key": "o"
|
|
|
+ modelExport: {
|
|
|
+ "legend": [
|
|
|
+ [
|
|
|
+ "search-photos-lite-models",
|
|
|
+ "0",
|
|
|
+ "photos",
|
|
|
+ "_data",
|
|
|
+ "0"
|
|
|
+ ]
|
|
|
+ ],
|
|
|
+ "main": {
|
|
|
+ "search-photos-lite-models": [
|
|
|
+ {
|
|
|
+ "photos": {
|
|
|
+ "_data": [
|
|
|
+ {
|
|
|
+ "_flickrModelRegistry": "photo-lite-models",
|
|
|
+ "title": "This%20is%20the%20title",
|
|
|
+ "username": "Owner",
|
|
|
+ "pathAlias": "klink692",
|
|
|
+ "realname": "Owner",
|
|
|
+ "license": 0,
|
|
|
+ "ownerNsid": "59729010@N00",
|
|
|
+ "canComment": false,
|
|
|
+ "commentCount": 14,
|
|
|
+ "faveCount": 21,
|
|
|
+ "id": "14001294434",
|
|
|
+ "sizes": {
|
|
|
+ "o": {
|
|
|
+ "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_o.jpg",
|
|
|
+ "width": 433,
|
|
|
+ "height": 640,
|
|
|
+ "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_o.jpg",
|
|
|
+ "key": "o"
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- ],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
"""
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|
|
@@ -235,30 +279,44 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
|
|
|
# no image test
|
|
|
json = """
|
|
|
- "search-photos-lite-models","photos":
|
|
|
- {
|
|
|
- "_data": [
|
|
|
- {
|
|
|
- "_flickrModelRegistry": "photo-lite-models",
|
|
|
- "title": "This is the title",
|
|
|
- "username": "Owner",
|
|
|
- "pathAlias": "klink692",
|
|
|
- "realname": "Owner",
|
|
|
- "license": 0,
|
|
|
- "ownerNsid": "59729010@N00",
|
|
|
- "canComment": false,
|
|
|
- "commentCount": 14,
|
|
|
- "faveCount": 21,
|
|
|
- "id": "14001294434",
|
|
|
- "sizes": {
|
|
|
- }
|
|
|
- }
|
|
|
+ modelExport: {
|
|
|
+ "legend": [
|
|
|
+ [
|
|
|
+ "search-photos-lite-models",
|
|
|
+ "0",
|
|
|
+ "photos",
|
|
|
+ "_data",
|
|
|
+ "0"
|
|
|
+ ]
|
|
|
],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
+ "main": {
|
|
|
+ "search-photos-lite-models": [
|
|
|
+ {
|
|
|
+ "photos": {
|
|
|
+ "_data": [
|
|
|
+ {
|
|
|
+ "_flickrModelRegistry": "photo-lite-models",
|
|
|
+ "title": "This is the title",
|
|
|
+ "username": "Owner",
|
|
|
+ "pathAlias": "klink692",
|
|
|
+ "realname": "Owner",
|
|
|
+ "license": 0,
|
|
|
+ "ownerNsid": "59729010@N00",
|
|
|
+ "canComment": false,
|
|
|
+ "commentCount": 14,
|
|
|
+ "faveCount": 21,
|
|
|
+ "id": "14001294434",
|
|
|
+ "sizes": {
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
"""
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|
|
@@ -266,51 +324,20 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
|
|
|
# null test
|
|
|
json = """
|
|
|
- "search-photos-models","photos":
|
|
|
- {
|
|
|
- "_data": [null],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
- """
|
|
|
- response = mock.Mock(text=json)
|
|
|
- results = flickr_noapi.response(response)
|
|
|
- self.assertEqual(type(results), list)
|
|
|
- self.assertEqual(len(results), 0)
|
|
|
-
|
|
|
- # no ownerNsid test
|
|
|
- json = """
|
|
|
- "search-photos-lite-models","photos":
|
|
|
- {
|
|
|
- "_data": [
|
|
|
- {
|
|
|
- "_flickrModelRegistry": "photo-lite-models",
|
|
|
- "title": "This is the title",
|
|
|
- "username": "Owner",
|
|
|
- "pathAlias": "klink692",
|
|
|
- "realname": "Owner",
|
|
|
- "license": 0,
|
|
|
- "canComment": false,
|
|
|
- "commentCount": 14,
|
|
|
- "faveCount": 21,
|
|
|
- "id": "14001294434",
|
|
|
- "sizes": {
|
|
|
- "o": {
|
|
|
- "displayUrl": "//farm8.staticflickr.com/7246/14001294434_410f653777_o.jpg",
|
|
|
- "width": 433,
|
|
|
- "height": 640,
|
|
|
- "url": "//c4.staticflickr.com/8/7246/14001294434_410f653777_o.jpg",
|
|
|
- "key": "o"
|
|
|
+ modelExport: {
|
|
|
+ "legend": [null],
|
|
|
+ "main": {
|
|
|
+ "search-photos-lite-models": [
|
|
|
+ {
|
|
|
+ "photos": {
|
|
|
+ "_data": [null]
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- ],
|
|
|
- "fetchedStart": true,
|
|
|
- "fetchedEnd": false,
|
|
|
- "totalItems": "4386039"
|
|
|
- },"totalItems":
|
|
|
+ ]
|
|
|
+ }
|
|
|
+ }
|
|
|
"""
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|
|
@@ -323,6 +350,7 @@ class TestFlickrNoapiEngine(SearxTestCase):
|
|
|
"link":"http:\/\/www.flickr.com\/artist\/1217","type":"artist"}
|
|
|
]}
|
|
|
"""
|
|
|
+ json = ''.join(json.split()) + ',\n'
|
|
|
response = mock.Mock(text=json)
|
|
|
results = flickr_noapi.response(response)
|
|
|
self.assertEqual(type(results), list)
|