Show More
@@ -20,9 +20,6 b'' | |||
|
20 | 20 | |
|
21 | 21 | import mock |
|
22 | 22 | import pytest |
|
23 | import rhodecode.lib.vcs.client as client | |
|
24 | from rhodecode.lib.middleware.error_handling import ( | |
|
25 | PylonsErrorHandlingMiddleware) | |
|
26 | 23 | |
|
27 | 24 | |
|
28 | 25 | @pytest.mark.usefixtures('autologin_user', 'app') |
@@ -34,13 +31,26 b' def test_vcs_available_returns_summary_p' | |||
|
34 | 31 | |
|
35 | 32 | |
|
36 | 33 | @pytest.mark.usefixtures('autologin_user', 'app') |
|
37 | def test_vcs_unavailable_returns_vcs_error_page(app, backend): | |
|
34 | def test_vcs_unavailable_returns_vcs_error_page(app, backend, app_settings): | |
|
35 | import rhodecode | |
|
36 | from rhodecode.lib.vcs.exceptions import VCSCommunicationError | |
|
37 | ||
|
38 | # Depending on the used VCSServer protocol we have to patch a different | |
|
39 | # RemoteRepo class to raise an exception. For the test it doesn't matter | |
|
40 | # if http or pyro4 is used, it just requires the exception to be raised. | |
|
41 | vcs_protocol = app_settings['vcs.server.protocol'] | |
|
42 | if vcs_protocol == 'http': | |
|
43 | from rhodecode.lib.vcs.client_http import RemoteRepo | |
|
44 | elif vcs_protocol == 'pyro4': | |
|
45 | from rhodecode.lib.vcs.client import RemoteRepo | |
|
46 | else: | |
|
47 | pytest.fail('Unknown VCS server protocol: "{}"'.format(vcs_protocol)) | |
|
48 | ||
|
38 | 49 | url = '/{repo_name}'.format(repo_name=backend.repo.repo_name) |
|
39 | 50 | |
|
40 |
# Pat |
|
|
41 | # call to the vcsserver. | |
|
42 | with mock.patch.object(client, '_get_proxy_method') as p: | |
|
43 | p.side_effect = client.exceptions.PyroVCSCommunicationError() | |
|
51 | # Patch remote repo to raise an exception instead of making a RPC. | |
|
52 | with mock.patch.object(RemoteRepo, '__getattr__') as remote_mock: | |
|
53 | remote_mock.side_effect = VCSCommunicationError() | |
|
44 | 54 | # Patch pylons error handling middleware to not re-raise exceptions. |
|
45 | 55 | with mock.patch.object(PylonsErrorHandlingMiddleware, 'reraise') as r: |
|
46 | 56 | r.return_value = False |
General Comments 0
You need to be logged in to leave comments.
Login now