aboutsummaryrefslogtreecommitdiff
path: root/vim/bundle/YouCompleteMe/python/ycm/tests/base_test.py
diff options
context:
space:
mode:
Diffstat (limited to 'vim/bundle/YouCompleteMe/python/ycm/tests/base_test.py')
m---------vim/bundle/YouCompleteMe0
-rw-r--r--vim/bundle/YouCompleteMe/python/ycm/tests/base_test.py270
2 files changed, 0 insertions, 270 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/tests/base_test.py b/vim/bundle/YouCompleteMe/python/ycm/tests/base_test.py
deleted file mode 100644
index 9d1ba27..0000000
--- a/vim/bundle/YouCompleteMe/python/ycm/tests/base_test.py
+++ /dev/null
@@ -1,270 +0,0 @@
-# coding: utf-8
-#
-# Copyright (C) 2013 Google Inc.
-#
-# 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
-
-import contextlib
-from nose.tools import eq_, ok_
-from mock import patch
-
-from ycm.test_utils import MockVimModule
-vim_mock = MockVimModule()
-from ycm import base
-
-
-@contextlib.contextmanager
-def MockCurrentFiletypes( filetypes = [''] ):
- with patch( 'ycm.vimsupport.CurrentFiletypes', return_value = filetypes ):
- yield
-
-
-@contextlib.contextmanager
-def MockCurrentColumnAndLineContents( column, line_contents ):
- with patch( 'ycm.vimsupport.CurrentColumn', return_value = column ):
- with patch( 'ycm.vimsupport.CurrentLineContents',
- return_value = line_contents ):
- yield
-
-
-@contextlib.contextmanager
-def MockTextAfterCursor( text ):
- with patch( 'ycm.vimsupport.TextAfterCursor', return_value = text ):
- yield
-
-
-def AdjustCandidateInsertionText_Basic_test():
- with MockTextAfterCursor( 'bar' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar' ] ) )
-
-
-def AdjustCandidateInsertionText_ParenInTextAfterCursor_test():
- with MockTextAfterCursor( 'bar(zoo' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar' ] ) )
-
-
-def AdjustCandidateInsertionText_PlusInTextAfterCursor_test():
- with MockTextAfterCursor( 'bar+zoo' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar' ] ) )
-
-
-def AdjustCandidateInsertionText_WhitespaceInTextAfterCursor_test():
- with MockTextAfterCursor( 'bar zoo' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar' ] ) )
-
-
-def AdjustCandidateInsertionText_MoreThanWordMatchingAfterCursor_test():
- with MockTextAfterCursor( 'bar.h' ):
- eq_( [ { 'abbr': 'foobar.h', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar.h' ] ) )
-
- with MockTextAfterCursor( 'bar(zoo' ):
- eq_( [ { 'abbr': 'foobar(zoo', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText( [ 'foobar(zoo' ] ) )
-
-
-def AdjustCandidateInsertionText_NotSuffix_test():
- with MockTextAfterCursor( 'bar' ):
- eq_( [ { 'abbr': 'foofoo', 'word': 'foofoo' } ],
- base.AdjustCandidateInsertionText( [ 'foofoo' ] ) )
-
-
-def AdjustCandidateInsertionText_NothingAfterCursor_test():
- with MockTextAfterCursor( '' ):
- eq_( [ 'foofoo',
- 'zobar' ],
- base.AdjustCandidateInsertionText( [ 'foofoo',
- 'zobar' ] ) )
-
-
-def AdjustCandidateInsertionText_MultipleStrings_test():
- with MockTextAfterCursor( 'bar' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' },
- { 'abbr': 'zobar', 'word': 'zo' },
- { 'abbr': 'qbar', 'word': 'q' },
- { 'abbr': 'bar', 'word': '' }, ],
- base.AdjustCandidateInsertionText( [ 'foobar',
- 'zobar',
- 'qbar',
- 'bar' ] ) )
-
-
-def AdjustCandidateInsertionText_DictInput_test():
- with MockTextAfterCursor( 'bar' ):
- eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText(
- [ { 'word': 'foobar' } ] ) )
-
-
-def AdjustCandidateInsertionText_DontTouchAbbr_test():
- with MockTextAfterCursor( 'bar' ):
- eq_( [ { 'abbr': '1234', 'word': 'foo' } ],
- base.AdjustCandidateInsertionText(
- [ { 'abbr': '1234', 'word': 'foobar' } ] ) )
-
-
-def OverlapLength_Basic_test():
- eq_( 3, base.OverlapLength( 'foo bar', 'bar zoo' ) )
- eq_( 3, base.OverlapLength( 'foobar', 'barzoo' ) )
-
-
-def OverlapLength_BasicWithUnicode_test():
- eq_( 3, base.OverlapLength( u'bar fäö', u'fäö bar' ) )
- eq_( 3, base.OverlapLength( u'zoofäö', u'fäözoo' ) )
-
-
-def OverlapLength_OneCharOverlap_test():
- eq_( 1, base.OverlapLength( 'foo b', 'b zoo' ) )
-
-
-def OverlapLength_SameStrings_test():
- eq_( 6, base.OverlapLength( 'foobar', 'foobar' ) )
-
-
-def OverlapLength_Substring_test():
- eq_( 6, base.OverlapLength( 'foobar', 'foobarzoo' ) )
- eq_( 6, base.OverlapLength( 'zoofoobar', 'foobar' ) )
-
-
-def OverlapLength_LongestOverlap_test():
- eq_( 7, base.OverlapLength( 'bar foo foo', 'foo foo bar' ) )
-
-
-def OverlapLength_EmptyInput_test():
- eq_( 0, base.OverlapLength( '', 'goobar' ) )
- eq_( 0, base.OverlapLength( 'foobar', '' ) )
- eq_( 0, base.OverlapLength( '', '' ) )
-
-
-def OverlapLength_NoOverlap_test():
- eq_( 0, base.OverlapLength( 'foobar', 'goobar' ) )
- eq_( 0, base.OverlapLength( 'foobar', '(^($@#$#@' ) )
- eq_( 0, base.OverlapLength( 'foo bar zoo', 'foo zoo bar' ) )
-
-
-def LastEnteredCharIsIdentifierChar_Basic_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 3, 'abc' ):
- ok_( base.LastEnteredCharIsIdentifierChar() )
-
- with MockCurrentColumnAndLineContents( 2, 'abc' ):
- ok_( base.LastEnteredCharIsIdentifierChar() )
-
- with MockCurrentColumnAndLineContents( 1, 'abc' ):
- ok_( base.LastEnteredCharIsIdentifierChar() )
-
-
-def LastEnteredCharIsIdentifierChar_FiletypeHtml_test():
- with MockCurrentFiletypes( ['html'] ):
- with MockCurrentColumnAndLineContents( 3, 'ab-' ):
- ok_( base.LastEnteredCharIsIdentifierChar() )
-
-
-def LastEnteredCharIsIdentifierChar_ColumnIsZero_test():
- with MockCurrentColumnAndLineContents( 0, 'abc' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
-
-def LastEnteredCharIsIdentifierChar_LineEmpty_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 3, '' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
- with MockCurrentColumnAndLineContents( 0, '' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
-
-def LastEnteredCharIsIdentifierChar_NotIdentChar_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 3, 'ab;' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
- with MockCurrentColumnAndLineContents( 1, ';' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
- with MockCurrentColumnAndLineContents( 3, 'ab-' ):
- ok_( not base.LastEnteredCharIsIdentifierChar() )
-
-
-def CurrentIdentifierFinished_Basic_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 3, 'ab;' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 2, 'ab;' ):
- ok_( not base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 1, 'ab;' ):
- ok_( not base.CurrentIdentifierFinished() )
-
-
-def CurrentIdentifierFinished_NothingBeforeColumn_test():
- with MockCurrentColumnAndLineContents( 0, 'ab;' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 0, '' ):
- ok_( base.CurrentIdentifierFinished() )
-
-
-def CurrentIdentifierFinished_InvalidColumn_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 5, '' ):
- ok_( not base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 5, 'abc' ):
- ok_( not base.CurrentIdentifierFinished() )
-
-
-def CurrentIdentifierFinished_InMiddleOfLine_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 4, 'bar.zoo' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 4, 'bar(zoo' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 4, 'bar-zoo' ):
- ok_( base.CurrentIdentifierFinished() )
-
-
-def CurrentIdentifierFinished_Html_test():
- with MockCurrentFiletypes( ['html'] ):
- with MockCurrentColumnAndLineContents( 4, 'bar-zoo' ):
- ok_( not base.CurrentIdentifierFinished() )
-
-
-def CurrentIdentifierFinished_WhitespaceOnly_test():
- with MockCurrentFiletypes():
- with MockCurrentColumnAndLineContents( 1, '\n' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 3, '\n ' ):
- ok_( base.CurrentIdentifierFinished() )
-
- with MockCurrentColumnAndLineContents( 3, '\t\t\t\t' ):
- ok_( base.CurrentIdentifierFinished() )