mirror of
https://github.com/searx/searx
synced 2025-01-22 09:00:08 +01:00
3c5883408c
Adds support for queries to the Protein Data Bank Europe (PDBe).
110 lines
3.5 KiB
Python
110 lines
3.5 KiB
Python
import mock
|
|
from collections import defaultdict
|
|
from searx.engines import pdbe
|
|
from searx.testing import SearxTestCase
|
|
|
|
|
|
class TestPdbeEngine(SearxTestCase):
|
|
def test_request(self):
|
|
query = 'test_query'
|
|
dicto = defaultdict(dict)
|
|
params = pdbe.request(query, dicto)
|
|
self.assertTrue('url' in params)
|
|
self.assertTrue('ebi.ac.uk' in params['url'])
|
|
self.assertTrue('data' in params)
|
|
self.assertTrue('q' in params['data'])
|
|
self.assertTrue(query in params['data']['q'])
|
|
self.assertTrue('wt' in params['data'])
|
|
self.assertTrue('json' in params['data']['wt'])
|
|
self.assertTrue('method' in params)
|
|
self.assertTrue(params['method'] == 'POST')
|
|
|
|
def test_response(self):
|
|
self.assertRaises(AttributeError, pdbe.response, None)
|
|
self.assertRaises(AttributeError, pdbe.response, [])
|
|
self.assertRaises(AttributeError, pdbe.response, '')
|
|
self.assertRaises(AttributeError, pdbe.response, '[]')
|
|
|
|
json = """
|
|
{
|
|
"response": {
|
|
"docs": [
|
|
{
|
|
"citation_title": "X-ray crystal structure of ferric Aplysia limacina myoglobin in different liganded states.",
|
|
"citation_year": 1993,
|
|
"entry_author_list": [
|
|
"Conti E, Moser C, Rizzi M, Mattevi A, Lionetti C, Coda A, Ascenzi P, Brunori M, Bolognesi M"
|
|
],
|
|
"journal": "J. Mol. Biol.",
|
|
"journal_page": "498-508",
|
|
"journal_volume": "233",
|
|
"pdb_id": "2fal",
|
|
"status": "REL",
|
|
"title": "X-RAY CRYSTAL STRUCTURE OF FERRIC APLYSIA LIMACINA MYOGLOBIN IN DIFFERENT LIGANDED STATES"
|
|
}
|
|
],
|
|
"numFound": 1,
|
|
"start": 0
|
|
},
|
|
"responseHeader": {
|
|
"QTime": 0,
|
|
"params": {
|
|
"q": "2fal",
|
|
"wt": "json"
|
|
},
|
|
"status": 0
|
|
}
|
|
}
|
|
"""
|
|
|
|
response = mock.Mock(text=json)
|
|
results = pdbe.response(response)
|
|
self.assertEqual(type(results), list)
|
|
self.assertEqual(len(results), 1)
|
|
self.assertEqual(results[0]['title'],
|
|
'X-RAY CRYSTAL STRUCTURE OF FERRIC APLYSIA LIMACINA MYOGLOBIN IN DIFFERENT LIGANDED STATES')
|
|
self.assertEqual(results[0]['url'], pdbe.pdbe_entry_url.format(pdb_id='2fal'))
|
|
self.assertEqual(results[0]['img_src'], pdbe.pdbe_preview_url.format(pdb_id='2fal'))
|
|
self.assertTrue('Conti E' in results[0]['content'])
|
|
self.assertTrue('X-ray crystal structure of ferric Aplysia limacina myoglobin in different liganded states.' in
|
|
results[0]['content'])
|
|
self.assertTrue('1993' in results[0]['content'])
|
|
|
|
# Testing proper handling of PDB entries marked as obsolete
|
|
json = """
|
|
{
|
|
"response": {
|
|
"docs": [
|
|
{
|
|
"citation_title": "Obsolete entry test",
|
|
"citation_year": 2016,
|
|
"entry_author_list": ["Doe J"],
|
|
"journal": "J. Obs.",
|
|
"journal_page": "1-2",
|
|
"journal_volume": "1",
|
|
"pdb_id": "xxxx",
|
|
"status": "OBS",
|
|
"title": "OBSOLETE ENTRY TEST",
|
|
"superseded_by": "yyyy"
|
|
}
|
|
],
|
|
"numFound": 1,
|
|
"start": 0
|
|
},
|
|
"responseHeader": {
|
|
"QTime": 0,
|
|
"params": {
|
|
"q": "xxxx",
|
|
"wt": "json"
|
|
},
|
|
"status": 0
|
|
}
|
|
}
|
|
"""
|
|
response = mock.Mock(text=json)
|
|
results = pdbe.response(response)
|
|
self.assertEqual(type(results), list)
|
|
self.assertEqual(len(results), 1)
|
|
self.assertEqual(results[0]['title'], 'OBSOLETE ENTRY TEST (OBSOLETE)')
|
|
self.assertTrue(results[0]['content'].startswith('<em>This entry has been superseded by'))
|