|
|
@ -0,0 +1,89 @@ |
|
|
|
from unittest.mock import patch |
|
|
|
from requests.models import Response |
|
|
|
|
|
|
|
from searx.testing import SearxTestCase |
|
|
|
|
|
|
|
import searx.poolrequests |
|
|
|
from searx.poolrequests import get_proxy_cycles, get_proxies |
|
|
|
|
|
|
|
|
|
|
|
CONFIG = {'http': ['http://localhost:9090', 'http://localhost:9092'], |
|
|
|
'https': ['http://localhost:9091', 'http://localhost:9093']} |
|
|
|
|
|
|
|
|
|
|
|
class TestProxy(SearxTestCase): |
|
|
|
|
|
|
|
def test_noconfig(self): |
|
|
|
cycles = get_proxy_cycles(None) |
|
|
|
self.assertIsNone(cycles) |
|
|
|
|
|
|
|
cycles = get_proxy_cycles(False) |
|
|
|
self.assertIsNone(cycles) |
|
|
|
|
|
|
|
def test_oldconfig(self): |
|
|
|
config = { |
|
|
|
'http': 'http://localhost:9090', |
|
|
|
'https': 'http://localhost:9091', |
|
|
|
} |
|
|
|
cycles = get_proxy_cycles(config) |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
|
|
|
|
def test_one_proxy(self): |
|
|
|
config = { |
|
|
|
'http': ['http://localhost:9090'], |
|
|
|
'https': ['http://localhost:9091'], |
|
|
|
} |
|
|
|
cycles = get_proxy_cycles(config) |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
|
|
|
|
def test_multiple_proxies(self): |
|
|
|
cycles = get_proxy_cycles(CONFIG) |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9092') |
|
|
|
self.assertEqual(next(cycles['http']), 'http://localhost:9090') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9093') |
|
|
|
self.assertEqual(next(cycles['https']), 'http://localhost:9091') |
|
|
|
|
|
|
|
def test_getproxies_none(self): |
|
|
|
self.assertIsNone(get_proxies(None)) |
|
|
|
|
|
|
|
def test_getproxies_config(self): |
|
|
|
cycles = get_proxy_cycles(CONFIG) |
|
|
|
self.assertEqual(get_proxies(cycles), { |
|
|
|
'http': 'http://localhost:9090', |
|
|
|
'https': 'http://localhost:9091' |
|
|
|
}) |
|
|
|
self.assertEqual(get_proxies(cycles), { |
|
|
|
'http': 'http://localhost:9092', |
|
|
|
'https': 'http://localhost:9093' |
|
|
|
}) |
|
|
|
|
|
|
|
@patch('searx.poolrequests.get_global_proxies') |
|
|
|
def test_request(self, mock_get_global_proxies): |
|
|
|
method = 'GET' |
|
|
|
url = 'http://localhost' |
|
|
|
custom_proxies = { |
|
|
|
'https': 'http://localhost:1080' |
|
|
|
} |
|
|
|
global_proxies = { |
|
|
|
'http': 'http://localhost:9092', |
|
|
|
'https': 'http://localhost:9093' |
|
|
|
} |
|
|
|
mock_get_global_proxies.return_value = global_proxies |
|
|
|
|
|
|
|
# check the global proxies usage |
|
|
|
with patch.object(searx.poolrequests.SessionSinglePool, 'request', return_value=Response()) as mock_method: |
|
|
|
searx.poolrequests.request(method, url) |
|
|
|
mock_method.assert_called_once_with(method=method, url=url, proxies=global_proxies) |
|
|
|
|
|
|
|
# check if the proxies parameter overrides the global proxies |
|
|
|
with patch.object(searx.poolrequests.SessionSinglePool, 'request', return_value=Response()) as mock_method: |
|
|
|
searx.poolrequests.request(method, url, proxies=custom_proxies) |
|
|
|
mock_method.assert_called_once_with(method=method, url=url, proxies=custom_proxies) |