| 
									
										
										
										
											2013-05-27 21:32:03 -04:00
										 |  |  | import unittest | 
					
						
							| 
									
										
										
										
											2016-05-28 13:22:31 -04:00
										 |  |  | import idlelib.calltips as ct | 
					
						
							| 
									
										
										
										
											2014-01-26 19:55:34 -05:00
										 |  |  | import textwrap | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | import types | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  | default_tip = ct._default_callable_argspec | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Test Class TC is used in multiple get_argspec test methods | 
					
						
							|  |  |  | class TC(): | 
					
						
							|  |  |  |     'doc' | 
					
						
							|  |  |  |     tip = "(ai=None, *b)" | 
					
						
							|  |  |  |     def __init__(self, ai=None, *b): 'doc' | 
					
						
							|  |  |  |     __init__.tip = "(self, ai=None, *b)" | 
					
						
							|  |  |  |     def t1(self): 'doc' | 
					
						
							|  |  |  |     t1.tip = "(self)" | 
					
						
							|  |  |  |     def t2(self, ai, b=None): 'doc' | 
					
						
							|  |  |  |     t2.tip = "(self, ai, b=None)" | 
					
						
							|  |  |  |     def t3(self, ai, *args): 'doc' | 
					
						
							|  |  |  |     t3.tip = "(self, ai, *args)" | 
					
						
							|  |  |  |     def t4(self, *args): 'doc' | 
					
						
							|  |  |  |     t4.tip = "(self, *args)" | 
					
						
							|  |  |  |     def t5(self, ai, b=None, *args, **kw): 'doc' | 
					
						
							|  |  |  |     t5.tip = "(self, ai, b=None, *args, **kw)" | 
					
						
							|  |  |  |     def t6(no, self): 'doc' | 
					
						
							|  |  |  |     t6.tip = "(no, self)" | 
					
						
							|  |  |  |     def __call__(self, ci): 'doc' | 
					
						
							|  |  |  |     __call__.tip = "(self, ci)" | 
					
						
							|  |  |  |     # attaching .tip to wrapped methods does not work | 
					
						
							|  |  |  |     @classmethod | 
					
						
							|  |  |  |     def cm(cls, a): 'doc' | 
					
						
							|  |  |  |     @staticmethod | 
					
						
							|  |  |  |     def sm(b): 'doc' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | tc = TC() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | signature = ct.get_argspec  # 2.7 and 3.x use different functions | 
					
						
							|  |  |  | class Get_signatureTest(unittest.TestCase): | 
					
						
							| 
									
										
										
										
											2014-01-21 03:07:51 -05:00
										 |  |  |     # The signature function must return a string, even if blank. | 
					
						
							|  |  |  |     # Test a variety of objects to be sure that none cause it to raise | 
					
						
							|  |  |  |     # (quite aside from getting as correct an answer as possible). | 
					
						
							|  |  |  |     # The tests of builtins may break if inspect or the docstrings change, | 
					
						
							|  |  |  |     # but a red buildbot is better than a user crash (as has happened). | 
					
						
							|  |  |  |     # For a simple mismatch, change the expected output to the actual. | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_builtins(self): | 
					
						
							| 
									
										
										
										
											2014-01-21 03:07:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         # Python class that inherits builtin methods | 
					
						
							|  |  |  |         class List(list): "List() doc" | 
					
						
							| 
									
										
										
										
											2014-01-21 20:45:17 -05:00
										 |  |  |         # Simulate builtin with no docstring for default tip test | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         class SB:  __call__ = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def gtest(obj, out): | 
					
						
							|  |  |  |             self.assertEqual(signature(obj), out) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |         if List.__doc__ is not None: | 
					
						
							|  |  |  |             gtest(List, List.__doc__) | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         gtest(list.__new__, | 
					
						
							| 
									
										
										
										
											2014-01-28 05:00:08 -08:00
										 |  |  |                'Create and return a new object.  See help(type) for accurate signature.') | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         gtest(list.__init__, | 
					
						
							| 
									
										
										
										
											2014-01-28 05:00:08 -08:00
										 |  |  |                'Initialize self.  See help(type(self)) for accurate signature.') | 
					
						
							| 
									
										
										
										
											2017-03-11 09:19:20 +02:00
										 |  |  |         append_doc =  "Append object to the end of the list." | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         gtest(list.append, append_doc) | 
					
						
							|  |  |  |         gtest([].append, append_doc) | 
					
						
							|  |  |  |         gtest(List.append, append_doc) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         gtest(types.MethodType, "method(function, instance)") | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  |         gtest(SB(), default_tip) | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-26 19:55:34 -05:00
										 |  |  |     def test_signature_wrap(self): | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |         if textwrap.TextWrapper.__doc__ is not None: | 
					
						
							|  |  |  |             self.assertEqual(signature(textwrap.TextWrapper), '''\
 | 
					
						
							| 
									
										
										
										
											2014-01-26 19:55:34 -05:00
										 |  |  | (width=70, initial_indent='', subsequent_indent='', expand_tabs=True, | 
					
						
							|  |  |  |     replace_whitespace=True, fix_sentence_endings=False, break_long_words=True, | 
					
						
							| 
									
										
										
										
											2014-01-26 20:08:26 -05:00
										 |  |  |     drop_whitespace=True, break_on_hyphens=True, tabsize=8, *, max_lines=None, | 
					
						
							|  |  |  |     placeholder=' [...]')''')
 | 
					
						
							| 
									
										
										
										
											2014-01-26 19:55:34 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_docline_truncation(self): | 
					
						
							|  |  |  |         def f(): pass | 
					
						
							|  |  |  |         f.__doc__ = 'a'*300 | 
					
						
							|  |  |  |         self.assertEqual(signature(f), '()\n' + 'a' * (ct._MAX_COLS-3) + '...') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 20:45:17 -05:00
										 |  |  |     def test_multiline_docstring(self): | 
					
						
							|  |  |  |         # Test fewer lines than max. | 
					
						
							| 
									
										
										
										
											2017-03-11 09:19:20 +02:00
										 |  |  |         self.assertEqual(signature(range), | 
					
						
							|  |  |  |                 "range(stop) -> range object\n" | 
					
						
							|  |  |  |                 "range(start, stop[, step]) -> range object") | 
					
						
							| 
									
										
										
										
											2014-01-21 20:45:17 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-26 19:55:34 -05:00
										 |  |  |         # Test max lines | 
					
						
							|  |  |  |         self.assertEqual(signature(bytes), '''\
 | 
					
						
							|  |  |  | bytes(iterable_of_ints) -> bytes | 
					
						
							|  |  |  | bytes(string, encoding[, errors]) -> bytes | 
					
						
							|  |  |  | bytes(bytes_or_buffer) -> immutable copy of bytes_or_buffer | 
					
						
							|  |  |  | bytes(int) -> bytes object of size given by the parameter initialized with null bytes | 
					
						
							|  |  |  | bytes() -> empty bytes object''')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Test more than max lines | 
					
						
							|  |  |  |         def f(): pass | 
					
						
							|  |  |  |         f.__doc__ = 'a\n' * 15 | 
					
						
							|  |  |  |         self.assertEqual(signature(f), '()' + '\na' * ct._MAX_LINES) | 
					
						
							| 
									
										
										
										
											2014-01-21 20:45:17 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |     def test_functions(self): | 
					
						
							|  |  |  |         def t1(): 'doc' | 
					
						
							|  |  |  |         t1.tip = "()" | 
					
						
							|  |  |  |         def t2(a, b=None): 'doc' | 
					
						
							|  |  |  |         t2.tip = "(a, b=None)" | 
					
						
							|  |  |  |         def t3(a, *args): 'doc' | 
					
						
							|  |  |  |         t3.tip = "(a, *args)" | 
					
						
							|  |  |  |         def t4(*args): 'doc' | 
					
						
							|  |  |  |         t4.tip = "(*args)" | 
					
						
							|  |  |  |         def t5(a, b=None, *args, **kw): 'doc' | 
					
						
							|  |  |  |         t5.tip = "(a, b=None, *args, **kw)" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |         doc = '\ndoc' if t1.__doc__ is not None else '' | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         for func in (t1, t2, t3, t4, t5, TC): | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |             self.assertEqual(signature(func), func.tip + doc) | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_methods(self): | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |         doc = '\ndoc' if TC.__doc__ is not None else '' | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         for meth in (TC.t1, TC.t2, TC.t3, TC.t4, TC.t5, TC.t6, TC.__call__): | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |             self.assertEqual(signature(meth), meth.tip + doc) | 
					
						
							|  |  |  |         self.assertEqual(signature(TC.cm), "(a)" + doc) | 
					
						
							|  |  |  |         self.assertEqual(signature(TC.sm), "(b)" + doc) | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_bound_methods(self): | 
					
						
							|  |  |  |         # test that first parameter is correctly removed from argspec | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |         doc = '\ndoc' if TC.__doc__ is not None else '' | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         for meth, mtip  in ((tc.t1, "()"), (tc.t4, "(*args)"), (tc.t6, "(self)"), | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  |                             (tc.__call__, '(ci)'), (tc, '(ci)'), (TC.cm, "(a)"),): | 
					
						
							| 
									
										
										
										
											2015-04-04 09:47:31 +03:00
										 |  |  |             self.assertEqual(signature(meth), mtip + doc) | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-26 21:34:33 -05:00
										 |  |  |     def test_starred_parameter(self): | 
					
						
							|  |  |  |         # test that starred first parameter is *not* removed from argspec | 
					
						
							|  |  |  |         class C: | 
					
						
							|  |  |  |             def m1(*args): pass | 
					
						
							|  |  |  |             def m2(**kwds): pass | 
					
						
							|  |  |  |         c = C() | 
					
						
							|  |  |  |         for meth, mtip  in ((C.m1, '(*args)'), (c.m1, "(*args)"), | 
					
						
							|  |  |  |                                       (C.m2, "(**kwds)"), (c.m2, "(**kwds)"),): | 
					
						
							|  |  |  |             self.assertEqual(signature(meth), mtip) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  |     def test_non_ascii_name(self): | 
					
						
							|  |  |  |         # test that re works to delete a first parameter name that | 
					
						
							|  |  |  |         # includes non-ascii chars, such as various forms of A. | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         uni = "(A\u0391\u0410\u05d0\u0627\u0905\u1e00\u3042, a)" | 
					
						
							|  |  |  |         assert ct._first_param.sub('', uni) == '(a)' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_no_docstring(self): | 
					
						
							| 
									
										
										
										
											2014-01-21 20:45:17 -05:00
										 |  |  |         def nd(s): | 
					
						
							|  |  |  |             pass | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |         TC.nd = nd | 
					
						
							|  |  |  |         self.assertEqual(signature(nd), "(s)") | 
					
						
							|  |  |  |         self.assertEqual(signature(TC.nd), "(s)") | 
					
						
							|  |  |  |         self.assertEqual(signature(tc.nd), "()") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 15:36:51 -05:00
										 |  |  |     def test_attribute_exception(self): | 
					
						
							|  |  |  |         class NoCall: | 
					
						
							|  |  |  |             def __getattr__(self, name): | 
					
						
							|  |  |  |                 raise BaseException | 
					
						
							|  |  |  |         class Call(NoCall): | 
					
						
							|  |  |  |             def __call__(self, ci): | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  |         for meth, mtip  in ((NoCall, default_tip), (Call, default_tip), | 
					
						
							|  |  |  |                             (NoCall(), ''), (Call(), '(ci)')): | 
					
						
							|  |  |  |             self.assertEqual(signature(meth), mtip) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-21 00:26:21 -05:00
										 |  |  |     def test_non_callables(self): | 
					
						
							|  |  |  |         for obj in (0, 0.0, '0', b'0', [], {}): | 
					
						
							|  |  |  |             self.assertEqual(signature(obj), '') | 
					
						
							| 
									
										
										
										
											2013-05-27 21:32:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-30 01:36:48 -04:00
										 |  |  | class Get_entityTest(unittest.TestCase): | 
					
						
							| 
									
										
										
										
											2013-05-27 21:32:03 -04:00
										 |  |  |     def test_bad_entity(self): | 
					
						
							|  |  |  |         self.assertIsNone(ct.get_entity('1/0')) | 
					
						
							|  |  |  |     def test_good_entity(self): | 
					
						
							|  |  |  |         self.assertIs(ct.get_entity('int'), int) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == '__main__': | 
					
						
							|  |  |  |     unittest.main(verbosity=2, exit=False) |