Merge remote-tracking branch 'origin/namedtuple' into dev

This commit is contained in:
Dave Halter
2014-07-27 09:51:50 +02:00
4 changed files with 91 additions and 0 deletions

View File

@@ -0,0 +1,37 @@
"""
Tests of various stdlib related things that could not be tested
with "Black Box Tests".
"""
import pytest
from jedi import Script
from jedi._compatibility import is_py26
@pytest.mark.parametrize(['letter', 'expected'], [
('n', ['name']),
('s', ['smart']),
])
def test_namedtuple_str(letter, expected):
source = "import collections\n" + \
"Person = collections.namedtuple('Person', 'name smart')\n" + \
"dave = Person('Dave', False)\n" + \
"dave.%s" % letter
result = Script(source).completions()
completions = set(r.name for r in result)
if is_py26:
assert completions == set()
else:
assert completions == set(expected)
def test_namedtuple_list():
source = "import collections\n" + \
"Cat = collections.namedtuple('Person', ['legs', u'length', 'large'])\n" + \
"garfield = Cat(4, '85cm', True)\n" + \
"garfield.l"
result = Script(source).completions()
completions = set(r.name for r in result)
if is_py26:
assert completions == set()
else:
assert completions == set(['legs', 'length', 'large'])