omni_completion_request_tests.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. # Copyright (C) 2016 YouCompleteMe contributors
  2. #
  3. # This file is part of YouCompleteMe.
  4. #
  5. # YouCompleteMe is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU General Public License as published by
  7. # the Free Software Foundation, either version 3 of the License, or
  8. # (at your option) any later version.
  9. #
  10. # YouCompleteMe is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
  17. from __future__ import unicode_literals
  18. from __future__ import print_function
  19. from __future__ import division
  20. from __future__ import absolute_import
  21. # Not installing aliases from python-future; it's unreliable and slow.
  22. from builtins import * # noqa
  23. from mock import MagicMock
  24. from nose.tools import eq_
  25. from hamcrest import assert_that, has_entries
  26. from ycm.client.omni_completion_request import OmniCompletionRequest
  27. def BuildOmnicompletionRequest( results, start_column = 1 ):
  28. omni_completer = MagicMock()
  29. omni_completer.ComputeCandidates = MagicMock( return_value = results )
  30. request_data = {
  31. 'line_num': 1,
  32. 'column_num': 1,
  33. 'start_column': start_column
  34. }
  35. request = OmniCompletionRequest( omni_completer, request_data )
  36. request.Start()
  37. return request
  38. def Done_AlwaysTrue_test():
  39. request = BuildOmnicompletionRequest( [] )
  40. eq_( request.Done(), True )
  41. def Response_FromOmniCompleter_test():
  42. results = [ { "word": "test" } ]
  43. request = BuildOmnicompletionRequest( results )
  44. eq_( request.Response(), {
  45. 'line': 1,
  46. 'column': 1,
  47. 'completion_start_column': 1,
  48. 'completions': results
  49. } )
  50. def RawResponse_ConvertedFromOmniCompleter_test():
  51. vim_results = [
  52. { "word": "WORD", "abbr": "ABBR", "menu": "MENU",
  53. "kind": "KIND", "info": "INFO" },
  54. { "word": "WORD2", "abbr": "ABBR2", "menu": "MENU2",
  55. "kind": "KIND2", "info": "INFO" },
  56. { "word": "WORD", "abbr": "ABBR", },
  57. {},
  58. ]
  59. expected_results = [
  60. has_entries( { "insertion_text": "WORD", "menu_text": "ABBR",
  61. "extra_menu_info": "MENU", "kind": [ "KIND" ],
  62. "detailed_info": "INFO" } ),
  63. has_entries( { "insertion_text": "WORD2", "menu_text": "ABBR2",
  64. "extra_menu_info": "MENU2", "kind": [ "KIND2" ],
  65. "detailed_info": "INFO" } ),
  66. has_entries( { "insertion_text": "WORD", "menu_text": "ABBR", } ),
  67. has_entries( {} ),
  68. ]
  69. request = BuildOmnicompletionRequest( vim_results )
  70. results = request.RawResponse()[ 'completions' ]
  71. eq_( len( results ), len( expected_results ) )
  72. for result, expected_result in zip( results, expected_results ):
  73. assert_that( result, expected_result )