aboutsummaryrefslogtreecommitdiff
path: root/vim/bundle/YouCompleteMe/python/ycm/client/tests
diff options
context:
space:
mode:
Diffstat (limited to 'vim/bundle/YouCompleteMe/python/ycm/client/tests')
m---------vim/bundle/YouCompleteMe0
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/client/tests/__init__.py0
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/client/tests/command_request_test.py283
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/client/tests/completion_request_test.py186
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/client/tests/omni_completion_request_tests.py81
5 files changed, 0 insertions, 550 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/__init__.py b/vim/bundle/YouCompleteMe/python/ycm/client/tests/__init__.py
deleted file mode 100644
index e69de29..0000000
--- a/vim/bundle/YouCompleteMe/python/ycm/client/tests/__init__.py
+++ /dev/null
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 ]
diff --git a/vim/bundle/YouCompleteMe/python/ycm/client/tests/completion_request_test.py b/vim/bundle/YouCompleteMe/python/ycm/client/tests/completion_request_test.py
deleted file mode 100644
index acf0252..0000000
--- a/vim/bundle/YouCompleteMe/python/ycm/client/tests/completion_request_test.py
+++ /dev/null
@@ -1,186 +0,0 @@
-# Copyright (C) 2015 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 nose.tools import eq_
-from ycm.test_utils import MockVimModule
-vim_mock = MockVimModule()
-
-from .. import completion_request
-
-
-class ConvertCompletionResponseToVimDatas_test( object ):
- """ This class tests the
- completion_request._ConvertCompletionResponseToVimDatas method """
-
- def _Check( self, completion_data, expected_vim_data ):
- vim_data = completion_request.ConvertCompletionDataToVimData(
- completion_data )
-
- try:
- eq_( expected_vim_data, vim_data )
- except:
- print( "Expected:\n'{0}'\nwhen parsing:\n'{1}'\nBut found:\n'{2}'".format(
- expected_vim_data,
- completion_data,
- vim_data ) )
- raise
-
-
- def All_Fields_test( self ):
- self._Check( {
- 'insertion_text': 'INSERTION TEXT',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'detailed_info': 'DETAILED INFO',
- 'extra_data': {
- 'doc_string': 'DOC STRING',
- },
- }, {
- 'word' : 'INSERTION TEXT',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DETAILED INFO\nDOC STRING',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def Just_Detailed_Info_test( self ):
- self._Check( {
- 'insertion_text': 'INSERTION TEXT',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'detailed_info': 'DETAILED INFO',
- }, {
- 'word' : 'INSERTION TEXT',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DETAILED INFO',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def Just_Doc_String_test( self ):
- self._Check( {
- 'insertion_text': 'INSERTION TEXT',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'extra_data': {
- 'doc_string': 'DOC STRING',
- },
- }, {
- 'word' : 'INSERTION TEXT',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DOC STRING',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def Extra_Info_No_Doc_String_test( self ):
- self._Check( {
- 'insertion_text': 'INSERTION TEXT',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'extra_data': {
- },
- }, {
- 'word' : 'INSERTION TEXT',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def Extra_Info_No_Doc_String_With_Detailed_Info_test( self ):
- self._Check( {
- 'insertion_text': 'INSERTION TEXT',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'detailed_info': 'DETAILED INFO',
- 'extra_data': {
- },
- }, {
- 'word' : 'INSERTION TEXT',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DETAILED INFO',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def Empty_Insertion_Text_test( self ):
- self._Check( {
- 'insertion_text': '',
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'detailed_info': 'DETAILED INFO',
- 'extra_data': {
- 'doc_string': 'DOC STRING',
- },
- }, {
- 'word' : '',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DETAILED INFO\nDOC STRING',
- 'dup' : 1,
- 'empty': 1,
- } )
-
-
- def No_Insertion_Text_test( self ):
- self._Check( {
- 'menu_text': 'MENU TEXT',
- 'extra_menu_info': 'EXTRA MENU INFO',
- 'kind': 'K',
- 'detailed_info': 'DETAILED INFO',
- 'extra_data': {
- 'doc_string': 'DOC STRING',
- },
- }, {
- 'word' : '',
- 'abbr' : 'MENU TEXT',
- 'menu' : 'EXTRA MENU INFO',
- 'kind' : 'k',
- 'info' : 'DETAILED INFO\nDOC STRING',
- 'dup' : 1,
- 'empty': 1,
- } )
diff --git a/vim/bundle/YouCompleteMe/python/ycm/client/tests/omni_completion_request_tests.py b/vim/bundle/YouCompleteMe/python/ycm/client/tests/omni_completion_request_tests.py
deleted file mode 100644
index 02fb2e9..0000000
--- a/vim/bundle/YouCompleteMe/python/ycm/client/tests/omni_completion_request_tests.py
+++ /dev/null
@@ -1,81 +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 mock import MagicMock
-from nose.tools import eq_
-from hamcrest import assert_that, has_entries
-
-from ycm.client.omni_completion_request import OmniCompletionRequest
-
-
-def BuildOmnicompletionRequest( results ):
- omni_completer = MagicMock()
- omni_completer.ComputeCandidates = MagicMock( return_value = results )
-
- request = OmniCompletionRequest( omni_completer, None )
- request.Start()
-
- return request
-
-
-def Done_AlwaysTrue_test():
- request = BuildOmnicompletionRequest( [] )
-
- eq_( request.Done(), True )
-
-
-def Response_FromOmniCompleter_test():
- results = [ { "word": "test" } ]
- request = BuildOmnicompletionRequest( results )
-
- eq_( request.Response(), results )
-
-
-def RawResponse_ConvertedFromOmniCompleter_test():
- vim_results = [
- { "word": "WORD", "abbr": "ABBR", "menu": "MENU",
- "kind": "KIND", "info": "INFO" },
- { "word": "WORD2", "abbr": "ABBR2", "menu": "MENU2",
- "kind": "KIND2", "info": "INFO" },
- { "word": "WORD", "abbr": "ABBR", },
- { },
- ]
- expected_results = [
- has_entries( { "insertion_text": "WORD", "menu_text": "ABBR",
- "extra_menu_info": "MENU", "kind": [ "KIND" ],
- "detailed_info": "INFO" } ),
- has_entries( { "insertion_text": "WORD2", "menu_text": "ABBR2",
- "extra_menu_info": "MENU2", "kind": [ "KIND2" ],
- "detailed_info": "INFO" } ),
- has_entries( { "insertion_text": "WORD", "menu_text": "ABBR", } ),
- has_entries( { } ),
- ]
- request = BuildOmnicompletionRequest( vim_results )
-
- results = request.RawResponse()
-
- eq_( len( results ), len( expected_results ) )
- for result, expected_result in zip( results, expected_results ):
- assert_that( result, expected_result )