Auto merge of #3258 - micbou:fix-candidate-insertion-adjustment, r=micbou
[READY] Fix candidate insertion adjustment PR https://github.com/Valloric/YouCompleteMe/pull/3208 changed the way completion items are built by always defining all fields and in particular the `abbr` field. This caused a regression with the `AdjustCandidateInsertionText` function because that function checks if the `abbr` field exist which is now always the case. The function should instead check if the `abbr` field is empty. I changed the order of the fields in the tests to follow the Vim documentation (`word` is defined before `abbr`) and I removed one of the tests since PR https://github.com/Valloric/YouCompleteMe/pull/3104 made it irrelevant. <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/valloric/youcompleteme/3258) <!-- Reviewable:end -->
This commit is contained in:
commit
80246aa9a2
@ -103,7 +103,7 @@ def AdjustCandidateInsertionText( candidates ):
|
||||
for candidate in candidates:
|
||||
new_candidate = candidate.copy()
|
||||
|
||||
if 'abbr' not in new_candidate:
|
||||
if not new_candidate[ 'abbr' ]:
|
||||
new_candidate[ 'abbr' ] = new_candidate[ 'word' ]
|
||||
|
||||
new_candidate[ 'word' ] = NewCandidateInsertionText(
|
||||
|
@ -56,75 +56,78 @@ def MockTextAfterCursor( text ):
|
||||
|
||||
def AdjustCandidateInsertionText_Basic_test():
|
||||
with MockTextAfterCursor( 'bar' ):
|
||||
eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_ParenInTextAfterCursor_test():
|
||||
with MockTextAfterCursor( 'bar(zoo' ):
|
||||
eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_PlusInTextAfterCursor_test():
|
||||
with MockTextAfterCursor( 'bar+zoo' ):
|
||||
eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_WhitespaceInTextAfterCursor_test():
|
||||
with MockTextAfterCursor( 'bar zoo' ):
|
||||
eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_MoreThanWordMatchingAfterCursor_test():
|
||||
with MockTextAfterCursor( 'bar.h' ):
|
||||
eq_( [ { 'abbr': 'foobar.h', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar.h' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar.h' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar.h', 'abbr': '' } ] ) )
|
||||
|
||||
with MockTextAfterCursor( 'bar(zoo' ):
|
||||
eq_( [ { 'abbr': 'foobar(zoo', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar(zoo' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar(zoo' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar(zoo', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_NotSuffix_test():
|
||||
with MockTextAfterCursor( 'bar' ):
|
||||
eq_( [ { 'abbr': 'foofoo', 'word': 'foofoo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foofoo' } ] ) )
|
||||
eq_( [ { 'word': 'foofoo', 'abbr': 'foofoo' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foofoo', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_NothingAfterCursor_test():
|
||||
with MockTextAfterCursor( '' ):
|
||||
eq_( [ { 'word': 'foofoo' },
|
||||
{ 'word': 'zobar' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foofoo' },
|
||||
{ 'word': 'zobar' } ] ) )
|
||||
eq_( [ { 'word': 'foofoo', 'abbr': '' },
|
||||
{ 'word': 'zobar', 'abbr': '' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foofoo', 'abbr': '' },
|
||||
{ 'word': 'zobar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
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( [ { 'word': 'foobar' },
|
||||
{ 'word': 'zobar' },
|
||||
{ 'word': 'qbar' },
|
||||
{ 'word': 'bar' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_DictInput_test():
|
||||
with MockTextAfterCursor( 'bar' ):
|
||||
eq_( [ { 'abbr': 'foobar', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText( [ { 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': 'foobar' },
|
||||
{ 'word': 'zo', 'abbr': 'zobar' },
|
||||
{ 'word': 'q', 'abbr': 'qbar' },
|
||||
{ 'word': '', 'abbr': 'bar' }, ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '' },
|
||||
{ 'word': 'zobar', 'abbr': '' },
|
||||
{ 'word': 'qbar', 'abbr': '' },
|
||||
{ 'word': 'bar', 'abbr': '' } ] ) )
|
||||
|
||||
|
||||
def AdjustCandidateInsertionText_DontTouchAbbr_test():
|
||||
with MockTextAfterCursor( 'bar' ):
|
||||
eq_( [ { 'abbr': '1234', 'word': 'foo' } ],
|
||||
base.AdjustCandidateInsertionText(
|
||||
[ { 'abbr': '1234', 'word': 'foobar' } ] ) )
|
||||
eq_( [ { 'word': 'foo', 'abbr': '1234' } ],
|
||||
base.AdjustCandidateInsertionText( [
|
||||
{ 'word': 'foobar', 'abbr': '1234' } ] ) )
|
||||
|
||||
|
||||
def OverlapLength_Basic_test():
|
||||
|
Loading…
Reference in New Issue
Block a user