aboutsummaryrefslogtreecommitdiff
path: root/vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py
diff options
context:
space:
mode:
Diffstat (limited to 'vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py')
m---------vim/bundle/YouCompleteMe0
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py283
2 files changed, 0 insertions, 283 deletions
diff --git a/vim/bundle/YouCompleteMe b/vim/bundle/YouCompleteMe
new file mode 160000
+Subproject 0de1c0c9bb13ce82172b472c676035cd47cf6a6
diff --git a/vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py b/vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py
deleted file mode 100644
index dfc55e0..0000000
--- a/vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py
+++ /dev/null
@@ -1,283 +0,0 @@
-# Copyright (C) 2016 YouCompleteMe Contributors
-#
-# This file is part of YouCompleteMe.
-#
-# YouCompleteMe is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# YouCompleteMe is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
-
-from __future__ import unicode_literals
-from __future__ import print_function
-from __future__ import division
-from __future__ import absolute_import
-from future import standard_library
-standard_library.install_aliases()
-from builtins import * # noqa
-
-from ycm.test_utils import ExtendedMock, MockVimModule
-MockVimModule()
-
-import json
-from mock import patch, call
-from nose.tools import ok_
-from ycm.client.command_request import CommandRequest
-
-
-class GoToResponse_QuickFix_test( object ):
- """This class tests the generation of QuickFix lists for GoTo responses which
- return multiple locations, such as the Python completer and JavaScript
- completer. It mostly proves that we use 1-based indexing for the column
- number."""
-
- def setUp( self ):
- self._request = CommandRequest( [ 'GoToTest' ] )
-
-
- def tearDown( self ):
- self._request = None
-
-
- def GoTo_EmptyList_test( self ):
- self._CheckGoToList( [], [] )
-
-
- def GoTo_SingleItem_List_test( self ):
- self._CheckGoToList( [ {
- 'filepath': 'dummy_file',
- 'line_num': 10,
- 'column_num': 1,
- 'description': 'this is some text',
- } ], [ {
- 'filename': 'dummy_file',
- 'text': 'this is some text',
- 'lnum': 10,
- 'col': 1
- } ] )
-
-
- def GoTo_MultiItem_List_test( self ):
- self._CheckGoToList( [ {
- 'filepath': 'dummy_file',
- 'line_num': 10,
- 'column_num': 1,
- 'description': 'this is some other text',
- }, {
- 'filepath': 'dummy_file2',
- 'line_num': 1,
- 'column_num': 21,
- 'description': 'this is some text',
- } ], [ {
- 'filename': 'dummy_file',
- 'text': 'this is some other text',
- 'lnum': 10,
- 'col': 1
- }, {
- 'filename': 'dummy_file2',
- 'text': 'this is some text',
- 'lnum': 1,
- 'col': 21
- } ] )
-
-
- @patch( 'ycm.vimsupport.VariableExists', return_value = True )
- @patch( 'ycm.vimsupport.SetFittingHeightForCurrentWindow' )
- @patch( 'vim.command', new_callable = ExtendedMock )
- @patch( 'vim.eval', new_callable = ExtendedMock )
- def _CheckGoToList( self,
- completer_response,
- expected_qf_list,
- vim_eval,
- vim_command,
- set_fitting_height,
- variable_exists ):
- self._request._response = completer_response
-
- self._request.RunPostCommandActionsIfNeeded()
-
- vim_eval.assert_has_exact_calls( [
- call( 'setqflist( {0} )'.format( json.dumps( expected_qf_list ) ) )
- ] )
- vim_command.assert_has_exact_calls( [
- call( 'botright copen' ),
- call( 'au WinLeave <buffer> q' ),
- call( 'doautocmd User YcmQuickFixOpened' )
- ] )
- set_fitting_height.assert_called_once_with()
-
-
-class Response_Detection_test( object ):
-
- def BasicResponse_test( self ):
- def _BasicResponseTest( command, response ):
- with patch( 'vim.command' ) as vim_command:
- request = CommandRequest( [ command ] )
- request._response = response
- request.RunPostCommandActionsIfNeeded()
- vim_command.assert_called_with( "echom '{0}'".format( response ) )
-
- tests = [
- [ 'AnythingYouLike', True ],
- [ 'GoToEvenWorks', 10 ],
- [ 'FixItWorks', 'String!' ],
- [ 'and8434fd andy garbag!', 10.3 ],
- ]
-
- for test in tests:
- yield _BasicResponseTest, test[ 0 ], test[ 1 ]
-
-
- def FixIt_Response_Empty_test( self ):
- # Ensures we recognise and handle fixit responses which indicate that there
- # are no fixits available
- def EmptyFixItTest( command ):
- with patch( 'ycm.vimsupport.ReplaceChunks' ) as replace_chunks:
- with patch( 'ycm.vimsupport.EchoText' ) as echo_text:
- request = CommandRequest( [ command ] )
- request._response = {
- 'fixits': []
- }
- request.RunPostCommandActionsIfNeeded()
-
- echo_text.assert_called_with( 'No fixits found for current line' )
- replace_chunks.assert_not_called()
-
- for test in [ 'FixIt', 'Refactor', 'GoToHell', 'any_old_garbade!!!21' ]:
- yield EmptyFixItTest, test
-
-
- def FixIt_Response_test( self ):
- # Ensures we recognise and handle fixit responses with some dummy chunk data
- def FixItTest( command, response, chunks ):
- with patch( 'ycm.vimsupport.ReplaceChunks' ) as replace_chunks:
- with patch( 'ycm.vimsupport.EchoText' ) as echo_text:
- request = CommandRequest( [ command ] )
- request._response = response
- request.RunPostCommandActionsIfNeeded()
-
- replace_chunks.assert_called_with( chunks )
- echo_text.assert_not_called()
-
- basic_fixit = {
- 'fixits': [ {
- 'chunks': [ {
- 'dummy chunk contents': True
- } ]
- } ]
- }
- basic_fixit_chunks = basic_fixit[ 'fixits' ][ 0 ][ 'chunks' ]
-
- multi_fixit = {
- 'fixits': [ {
- 'chunks': [ {
- 'dummy chunk contents': True
- } ]
- }, {
- 'additional fixits are ignored currently': True
- } ]
- }
- multi_fixit_first_chunks = multi_fixit[ 'fixits' ][ 0 ][ 'chunks' ]
-
- tests = [
- [ 'AnythingYouLike', basic_fixit, basic_fixit_chunks ],
- [ 'GoToEvenWorks', basic_fixit, basic_fixit_chunks ],
- [ 'FixItWorks', basic_fixit, basic_fixit_chunks ],
- [ 'and8434fd andy garbag!', basic_fixit, basic_fixit_chunks ],
- [ 'additional fixits ignored', multi_fixit, multi_fixit_first_chunks ],
- ]
-
- for test in tests:
- yield FixItTest, test[ 0 ], test[ 1 ], test[ 2 ]
-
-
- def Message_Response_test( self ):
- # Ensures we correctly recognise and handle responses with a message to show
- # to the user
-
- def MessageTest( command, message ):
- with patch( 'ycm.vimsupport.EchoText' ) as echo_text:
- request = CommandRequest( [ command ] )
- request._response = { 'message': message }
- request.RunPostCommandActionsIfNeeded()
- echo_text.assert_called_with( message )
-
- tests = [
- [ '___________', 'This is a message' ],
- [ '', 'this is also a message' ],
- [ 'GetType', 'std::string' ],
- ]
-
- for test in tests:
- yield MessageTest, test[ 0 ], test[ 1 ]
-
-
- def Detailed_Info_test( self ):
- # Ensures we correctly detect and handle detailed_info responses which are
- # used to display information in the preview window
-
- def DetailedInfoTest( command, info ):
- with patch( 'ycm.vimsupport.WriteToPreviewWindow' ) as write_to_preview:
- request = CommandRequest( [ command ] )
- request._response = { 'detailed_info': info }
- request.RunPostCommandActionsIfNeeded()
- write_to_preview.assert_called_with( info )
-
- tests = [
- [ '___________', 'This is a message' ],
- [ '', 'this is also a message' ],
- [ 'GetDoc', 'std::string\netc\netc' ],
- ]
-
- for test in tests:
- yield DetailedInfoTest, test[ 0 ], test[ 1 ]
-
-
- def GoTo_Single_test( self ):
- # Ensures we handle any unknown type of response as a GoTo response
-
- def GoToTest( command, response ):
- with patch( 'ycm.vimsupport.JumpToLocation' ) as jump_to_location:
- request = CommandRequest( [ command ] )
- request._response = response
- request.RunPostCommandActionsIfNeeded()
- jump_to_location.assert_called_with(
- response[ 'filepath' ],
- response[ 'line_num' ],
- response[ 'column_num' ] )
-
- def GoToListTest( command, response ):
- # Note: the detail of these called are tested by
- # GoToResponse_QuickFix_test, so here we just check that the right call is
- # made
- with patch( 'ycm.vimsupport.SetQuickFixList' ) as set_qf_list:
- request = CommandRequest( [ command ] )
- request._response = response
- request.RunPostCommandActionsIfNeeded()
- ok_( set_qf_list.called )
-
- basic_goto = {
- 'filepath': 'test',
- 'line_num': 10,
- 'column_num': 100,
- }
-
- tests = [
- [ GoToTest, 'AnythingYouLike', basic_goto ],
- [ GoToTest, 'GoTo', basic_goto ],
- [ GoToTest, 'FindAThing', basic_goto ],
- [ GoToTest, 'FixItGoto', basic_goto ],
- [ GoToListTest, 'AnythingYouLike', [ basic_goto ] ],
- [ GoToListTest, 'GoTo', [] ],
- [ GoToListTest, 'FixItGoto', [ basic_goto, basic_goto ] ],
- ]
-
- for test in tests:
- yield test[ 0 ], test[ 1 ], test[ 2 ]