|
7 | 7 | current_method_definition_name, current_single_word, \
|
8 | 8 | current_string_literal_attr, current_indexed_member_access_identifier, \
|
9 | 9 | current_indexed_member_access_identifier_with_index, \
|
10 |
| - current_indexed_member_access_member |
| 10 | + current_indexed_member_access_member, \ |
| 11 | + current_simple_expression, current_simple_expression_attribute |
11 | 12 |
|
12 | 13 |
|
13 | 14 | def cursor(s):
|
@@ -342,5 +343,42 @@ def test_simple(self):
|
342 | 343 | self.assertAccess('abc[def].gh |i')
|
343 | 344 | self.assertAccess('abc[def]|')
|
344 | 345 |
|
| 346 | +@unittest.skip("TODO") |
| 347 | +class TestCurrentSimpleExpression(LineTestCase): |
| 348 | + def setUp(self): |
| 349 | + self.func = current_simple_expression |
| 350 | + |
| 351 | + def test_only_dots(self): |
| 352 | + self.assertAccess('<Object>.attr1|') |
| 353 | + self.assertAccess('<Object>.|') |
| 354 | + self.assertAccess('Object|') |
| 355 | + self.assertAccess('Object|.') |
| 356 | + self.assertAccess('<Object>.|') |
| 357 | + self.assertAccess('<Object.attr1>.attr2|') |
| 358 | + self.assertAccess('<Object>.att|r1.attr2') |
| 359 | + self.assertAccess('stuff[stuff] + {123: 456} + <Object.attr1>.attr2|') |
| 360 | + self.assertAccess('stuff[asd|fg]') |
| 361 | + self.assertAccess('stuff[asdf[asd|fg]') |
| 362 | + |
| 363 | + def test_with_brackets(self): |
| 364 | + self.assertAccess('<foo[a]>.ba|r') |
| 365 | + self.assertAccess('<foo[a]>.ba|r baz[qux]xyzzy') |
| 366 | + self.assertAccess('foo[<bar[baz]>.qux|].xyzzy') |
| 367 | + self.assertAccess('<foo[bar[baz].qux]>.xyzzy|') |
| 368 | + self.assertAccess('foo[bar[baz].qux].xyzzy, <a>.b|') |
| 369 | + self.assertAccess('foo[bar[<baz>.|') |
| 370 | + self.assertAccess('foo[bar[<baz>.|] + 1].qux') |
| 371 | + |
| 372 | + def test_cases_disallowed_by_simple_eval(self): |
| 373 | + # These are allowed for now, but could be changed. |
| 374 | + # for example, function calls are not allowed in simple expressions but |
| 375 | + # seem like they'd be a pain to weed out so we catch them in the next step.""" |
| 376 | + self.assertAccess('foo().bar|') |
| 377 | + self.assertAccess('foo[bar(a, b)].baz|') |
| 378 | + self.assertAccess('foo(a, b).bar|') |
| 379 | + self.assertAccess('<(1 + 1)>.bar|') |
| 380 | + self.assertAccess('<(1 + 1 - foo.bar()[1])>.baz|') |
| 381 | + |
| 382 | + |
345 | 383 | if __name__ == '__main__':
|
346 | 384 | unittest.main()
|
0 commit comments