mirror of
https://github.com/searxng/searxng
synced 2024-01-01 18:24:07 +00:00
fe691a0988
Preferences class was introduced in order to handle user preferences. Right now it parses cookies and the form in preferences. Also it can retrieve settings based on the name of the setting. ATTENTION Please note that engine preferences are handled differently from now on. So it introduces incompatible changes. Every user who has saved preferences should reset and save his/her settings again. This change was needed, because everytime a default disabled engine was added saved user preferences would broke. Now engine setting tracking is fixed.
156 lines
5.5 KiB
Python
156 lines
5.5 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import json
|
|
from mock import Mock
|
|
from urlparse import ParseResult
|
|
from searx import webapp
|
|
from searx.testing import SearxTestCase
|
|
|
|
|
|
class ViewsTestCase(SearxTestCase):
|
|
|
|
def setUp(self):
|
|
webapp.app.config['TESTING'] = True # to get better error messages
|
|
self.app = webapp.app.test_client()
|
|
|
|
# set some defaults
|
|
self.test_results = [
|
|
{
|
|
'content': 'first test content',
|
|
'title': 'First Test',
|
|
'url': 'http://first.test.xyz',
|
|
'engines': ['youtube', 'startpage'],
|
|
'engine': 'startpage',
|
|
'parsed_url': ParseResult(scheme='http', netloc='first.test.xyz', path='/', params='', query='', fragment=''), # noqa
|
|
}, {
|
|
'content': 'second test content',
|
|
'title': 'Second Test',
|
|
'url': 'http://second.test.xyz',
|
|
'engines': ['youtube', 'startpage'],
|
|
'engine': 'youtube',
|
|
'parsed_url': ParseResult(scheme='http', netloc='second.test.xyz', path='/', params='', query='', fragment=''), # noqa
|
|
},
|
|
]
|
|
|
|
def search_mock(search_self, *args):
|
|
search_self.result_container = Mock(get_ordered_results=lambda: self.test_results,
|
|
answers=set(),
|
|
suggestions=set(),
|
|
infoboxes=[],
|
|
results=self.test_results,
|
|
results_length=lambda: len(self.test_results))
|
|
|
|
webapp.Search.search = search_mock
|
|
|
|
def get_current_theme_name_mock(override=None):
|
|
return 'default'
|
|
|
|
webapp.get_current_theme_name = get_current_theme_name_mock
|
|
|
|
self.maxDiff = None # to see full diffs
|
|
|
|
def test_index_empty(self):
|
|
result = self.app.post('/')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn('<div class="title"><h1>searx</h1></div>', result.data)
|
|
|
|
def test_index_html(self):
|
|
result = self.app.post('/', data={'q': 'test'})
|
|
self.assertIn(
|
|
'<h3 class="result_title"><img width="14" height="14" class="favicon" src="/static/themes/default/img/icons/icon_youtube.ico" alt="youtube" /><a href="http://second.test.xyz" rel="noreferrer">Second <span class="highlight">Test</span></a></h3>', # noqa
|
|
result.data
|
|
)
|
|
self.assertIn(
|
|
'<p class="content">first <span class="highlight">test</span> content<br class="last"/></p>', # noqa
|
|
result.data
|
|
)
|
|
|
|
def test_index_json(self):
|
|
result = self.app.post('/', data={'q': 'test', 'format': 'json'})
|
|
|
|
result_dict = json.loads(result.data)
|
|
|
|
self.assertEqual('test', result_dict['query'])
|
|
self.assertEqual(
|
|
result_dict['results'][0]['content'], 'first test content')
|
|
self.assertEqual(
|
|
result_dict['results'][0]['url'], 'http://first.test.xyz')
|
|
|
|
def test_index_csv(self):
|
|
result = self.app.post('/', data={'q': 'test', 'format': 'csv'})
|
|
|
|
self.assertEqual(
|
|
'title,url,content,host,engine,score\r\n'
|
|
'First Test,http://first.test.xyz,first test content,first.test.xyz,startpage,\r\n' # noqa
|
|
'Second Test,http://second.test.xyz,second test content,second.test.xyz,youtube,\r\n', # noqa
|
|
result.data
|
|
)
|
|
|
|
def test_index_rss(self):
|
|
result = self.app.post('/', data={'q': 'test', 'format': 'rss'})
|
|
|
|
self.assertIn(
|
|
'<description>Search results for "test" - searx</description>',
|
|
result.data
|
|
)
|
|
|
|
self.assertIn(
|
|
'<opensearch:totalResults>2</opensearch:totalResults>',
|
|
result.data
|
|
)
|
|
|
|
self.assertIn(
|
|
'<title>First Test</title>',
|
|
result.data
|
|
)
|
|
|
|
self.assertIn(
|
|
'<link>http://first.test.xyz</link>',
|
|
result.data
|
|
)
|
|
|
|
self.assertIn(
|
|
'<description>first test content</description>',
|
|
result.data
|
|
)
|
|
|
|
def test_about(self):
|
|
result = self.app.get('/about')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn('<h1>About <a href="/">searx</a></h1>', result.data)
|
|
|
|
def test_preferences(self):
|
|
result = self.app.get('/preferences')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn(
|
|
'<form method="post" action="/preferences" id="search_form">',
|
|
result.data
|
|
)
|
|
self.assertIn(
|
|
'<legend>Default categories</legend>',
|
|
result.data
|
|
)
|
|
self.assertIn(
|
|
'<legend>Interface language</legend>',
|
|
result.data
|
|
)
|
|
|
|
def test_stats(self):
|
|
result = self.app.get('/stats')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn('<h2>Engine stats</h2>', result.data)
|
|
|
|
def test_robots_txt(self):
|
|
result = self.app.get('/robots.txt')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn('Allow: /', result.data)
|
|
|
|
def test_opensearch_xml(self):
|
|
result = self.app.get('/opensearch.xml')
|
|
self.assertEqual(result.status_code, 200)
|
|
self.assertIn('<Description>a privacy-respecting, hackable metasearch engine</Description>', result.data)
|
|
|
|
def test_favicon(self):
|
|
result = self.app.get('/favicon.ico')
|
|
self.assertEqual(result.status_code, 200)
|