blob: 8bd5bf72b59f7f0fed3ebbd3a70d61c6eeca8ba0 [file] [log] [blame]
Bram Moolenaardb913952012-06-29 12:54:53 +02001Tests for various python features. vim: set ft=vim :
2
3STARTTEST
4:so small.vim
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02005:set noswapfile
Bram Moolenaar5a4c3082019-12-01 15:23:11 +01006:if !has('python3') || !has('quickfix') | e! test.ok | wq! test.out | endif
Bram Moolenaarc24c1ac2013-05-16 20:47:56 +02007:lang C
Bram Moolenaardb913952012-06-29 12:54:53 +02008:fun Test()
Bram Moolenaar841fbd22013-06-23 14:37:07 +02009:py3 import vim
Bram Moolenaar8110a092016-04-14 15:56:09 +020010:py3 cb = vim.current.buffer
Bram Moolenaardb913952012-06-29 12:54:53 +020011:let l = []
12:py3 l=vim.bindeval('l')
13:py3 f=vim.bindeval('function("strlen")')
14:" Extending List directly with different types
15:py3 l+=[1, "as'd", [1, 2, f, {'a': 1}]]
16:$put =string(l)
17:$put =string(l[-1])
18:try
19: $put =string(l[-4])
20:catch
21: $put =v:exception[:13]
22:endtry
23:" List assignment
24:py3 l[0]=0
25:$put =string(l)
26:py3 l[-2]=f
27:$put =string(l)
28:"
29:" Extending Dictionary directly with different types
30:let d = {}
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020031:fun d.f()
32: return 1
33:endfun
Bram Moolenaara9922d62013-05-30 13:01:18 +020034py3 << EOF
35d=vim.bindeval('d')
36d['1']='asd'
Bram Moolenaar2d5f38f2014-02-11 18:47:27 +010037d.update() # Must not do anything, including throwing errors
Bram Moolenaara9922d62013-05-30 13:01:18 +020038d.update(b=[1, 2, f])
39d.update((('-1', {'a': 1}),))
40d.update({'0': -1})
41dk = d.keys()
42dv = d.values()
43di = d.items()
44dk.sort(key=repr)
45dv.sort(key=repr)
46di.sort(key=repr)
47EOF
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020048:$put =py3eval('d[''f''](self={})')
Bram Moolenaara9922d62013-05-30 13:01:18 +020049:$put =py3eval('repr(dk)')
50:$put =substitute(py3eval('repr(dv)'),'0x\x\+','','g')
51:$put =substitute(py3eval('repr(di)'),'0x\x\+','','g')
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020052:for [key, Val] in sort(items(d))
53: $put =string(key) . ' : ' . string(Val)
54: unlet key Val
Bram Moolenaardb913952012-06-29 12:54:53 +020055:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +020056:py3 del dk
57:py3 del di
58:py3 del dv
Bram Moolenaardb913952012-06-29 12:54:53 +020059:"
60:" removing items with del
61:py3 del l[2]
62:$put =string(l)
63:let l = range(8)
64:py3 l=vim.bindeval('l')
65:try
66: py3 del l[:3]
67: py3 del l[1:]
68:catch
69: $put =v:exception
70:endtry
71:$put =string(l)
72:"
73:py3 del d['-1']
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020074:py3 del d['f']
Bram Moolenaara9922d62013-05-30 13:01:18 +020075:$put =string(py3eval('d.get(''b'', 1)'))
76:$put =string(py3eval('d.pop(''b'')'))
77:$put =string(py3eval('d.get(''b'', 1)'))
78:$put =string(py3eval('d.pop(''1'', 2)'))
79:$put =string(py3eval('d.pop(''1'', 2)'))
80:$put =py3eval('repr(d.has_key(''0''))')
81:$put =py3eval('repr(d.has_key(''1''))')
82:$put =py3eval('repr(''0'' in d)')
83:$put =py3eval('repr(''1'' in d)')
84:$put =py3eval('repr(list(iter(d)))')
Bram Moolenaardb913952012-06-29 12:54:53 +020085:$put =string(d)
Bram Moolenaarde71b562013-06-02 17:41:54 +020086:$put =py3eval('repr(d.popitem())')
Bram Moolenaara9922d62013-05-30 13:01:18 +020087:$put =py3eval('repr(d.get(''0''))')
88:$put =py3eval('repr(list(iter(d)))')
Bram Moolenaardb913952012-06-29 12:54:53 +020089:"
90:" removing items out of range: silently skip items that don't exist
91:let l = [0, 1, 2, 3]
92:py3 l=vim.bindeval('l')
93:" The following two ranges delete nothing as they match empty list:
94:py3 del l[2:1]
95:$put =string(l)
96:py3 del l[2:2]
97:$put =string(l)
98:py3 del l[2:3]
99:$put =string(l)
100:let l = [0, 1, 2, 3]
101:py3 l=vim.bindeval('l')
102:py3 del l[2:4]
103:$put =string(l)
104:let l = [0, 1, 2, 3]
105:py3 l=vim.bindeval('l')
106:py3 del l[2:5]
107:$put =string(l)
108:let l = [0, 1, 2, 3]
109:py3 l=vim.bindeval('l')
110:py3 del l[2:6]
111:$put =string(l)
112:let l = [0, 1, 2, 3]
113:py3 l=vim.bindeval('l')
114:" The following two ranges delete nothing as they match empty list:
115:py3 del l[-1:2]
116:$put =string(l)
117:py3 del l[-2:2]
118:$put =string(l)
119:py3 del l[-3:2]
120:$put =string(l)
121:let l = [0, 1, 2, 3]
122:py3 l=vim.bindeval('l')
123:py3 del l[-4:2]
124:$put =string(l)
125:let l = [0, 1, 2, 3]
126:py3 l=vim.bindeval('l')
127:py3 del l[-5:2]
128:$put =string(l)
129:let l = [0, 1, 2, 3]
130:py3 l=vim.bindeval('l')
131:py3 del l[-6:2]
132:$put =string(l)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100133:let l = [0, 1, 2, 3]
134:py3 l=vim.bindeval('l')
135:py3 del l[::2]
136:$put =string(l)
137:let l = [0, 1, 2, 3]
138:py3 l=vim.bindeval('l')
139:py3 del l[3:0:-2]
140:$put =string(l)
141:let l = [0, 1, 2, 3]
142:py3 l=vim.bindeval('l')
143:py3 del l[2:4:-2]
144:$put =string(l)
Bram Moolenaardb913952012-06-29 12:54:53 +0200145:"
146:" Slice assignment to a list
147:let l = [0, 1, 2, 3]
148:py3 l=vim.bindeval('l')
149:py3 l[0:0]=['a']
150:$put =string(l)
151:let l = [0, 1, 2, 3]
152:py3 l=vim.bindeval('l')
153:py3 l[1:2]=['b']
154:$put =string(l)
155:let l = [0, 1, 2, 3]
156:py3 l=vim.bindeval('l')
157:py3 l[2:4]=['c']
158:$put =string(l)
159:let l = [0, 1, 2, 3]
160:py3 l=vim.bindeval('l')
161:py3 l[4:4]=['d']
162:$put =string(l)
163:let l = [0, 1, 2, 3]
164:py3 l=vim.bindeval('l')
165:py3 l[-1:2]=['e']
166:$put =string(l)
167:let l = [0, 1, 2, 3]
168:py3 l=vim.bindeval('l')
169:py3 l[-10:2]=['f']
170:$put =string(l)
171:let l = [0, 1, 2, 3]
172:py3 l=vim.bindeval('l')
173:py3 l[2:-10]=['g']
174:$put =string(l)
175:let l = []
176:py3 l=vim.bindeval('l')
177:py3 l[0:0]=['h']
178:$put =string(l)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100179:let l = range(8)
180:py3 l=vim.bindeval('l')
181:py3 l[2:6:2] = [10, 20]
182:$put =string(l)
183:let l = range(8)
184:py3 l=vim.bindeval('l')
185:py3 l[6:2:-2] = [10, 20]
186:$put =string(l)
187:let l = range(8)
188:py3 l=vim.bindeval('l')
189:py3 l[6:2] = ()
190:$put =string(l)
191:let l = range(8)
192:py3 l=vim.bindeval('l')
193:py3 l[6:2:1] = ()
194:$put =string(l)
195:let l = range(8)
196:py3 l=vim.bindeval('l')
197:py3 l[2:2:1] = ()
198:$put =string(l)
Bram Moolenaardb913952012-06-29 12:54:53 +0200199:"
200:" Locked variables
201:let l = [0, 1, 2, 3]
202:py3 l=vim.bindeval('l')
203:lockvar! l
Bram Moolenaar8110a092016-04-14 15:56:09 +0200204py3 << EOF
205def emsg(ei):
206 return ei[0].__name__ + ':' + repr(ei[1].args)
207
208try:
209 l[2]='i'
210except vim.error:
211 cb.append('l[2] threw vim.error: ' + emsg(sys.exc_info()))
212EOF
Bram Moolenaardb913952012-06-29 12:54:53 +0200213:$put =string(l)
214:unlockvar! l
215:"
216:" Function calls
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100217py3 << EOF
218import sys
219import re
220
221py33_type_error_pattern = re.compile('^__call__\(\) takes (\d+) positional argument but (\d+) were given$')
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200222py37_exception_repr = re.compile(r'([^\(\),])(\)+)$')
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100223
224def ee(expr, g=globals(), l=locals()):
225 cb = vim.current.buffer
226 try:
227 try:
228 exec(expr, g, l)
229 except Exception as e:
230 if sys.version_info >= (3, 3) and e.__class__ is AttributeError and str(e).find('has no attribute')>=0 and not str(e).startswith("'vim."):
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200231 msg = repr((e.__class__, AttributeError(str(e)[str(e).rfind(" '") + 2:-1])))
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100232 elif sys.version_info >= (3, 3) and e.__class__ is ImportError and str(e).find('No module named \'') >= 0:
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200233 msg = repr((e.__class__, ImportError(str(e).replace("'", ''))))
Bram Moolenaarf411a3c2017-03-05 19:00:34 +0100234 elif sys.version_info >= (3, 6) and e.__class__ is ModuleNotFoundError:
235 # Python 3.6 gives ModuleNotFoundError, change it to an ImportError
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200236 msg = repr((ImportError, ImportError(str(e).replace("'", ''))))
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100237 elif sys.version_info >= (3, 3) and e.__class__ is TypeError:
238 m = py33_type_error_pattern.search(str(e))
239 if m:
240 msg = '__call__() takes exactly {0} positional argument ({1} given)'.format(m.group(1), m.group(2))
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200241 msg = repr((e.__class__, TypeError(msg)))
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100242 else:
Bram Moolenaarf411a3c2017-03-05 19:00:34 +0100243 msg = repr((e.__class__, e))
244 # Messages changed with Python 3.6, change new to old.
245 newmsg1 = """'argument must be str, bytes or bytearray, not None'"""
246 oldmsg1 = '''"Can't convert 'NoneType' object to str implicitly"'''
247 if msg.find(newmsg1) > -1:
248 msg = msg.replace(newmsg1, oldmsg1)
249 newmsg2 = """'argument must be str, bytes or bytearray, not int'"""
250 oldmsg2 = '''"Can't convert 'int' object to str implicitly"'''
251 if msg.find(newmsg2) > -1:
252 msg = msg.replace(newmsg2, oldmsg2)
Bram Moolenaar29e19512016-02-28 20:13:18 +0100253 elif sys.version_info >= (3, 5) and e.__class__ is ValueError and str(e) == 'embedded null byte':
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200254 msg = repr((TypeError, TypeError('expected bytes with no null')))
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100255 else:
Bram Moolenaarcf703fe2016-09-09 14:59:39 +0200256 msg = repr((e.__class__, e))
257 # Some Python versions say can't, others cannot.
258 if msg.find('can\'t') > -1:
259 msg = msg.replace('can\'t', 'cannot')
260 # Some Python versions use single quote, some double quote
261 if msg.find('"cannot ') > -1:
262 msg = msg.replace('"cannot ', '\'cannot ')
263 if msg.find(' attributes"') > -1:
264 msg = msg.replace(' attributes"', ' attributes\'')
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200265 if sys.version_info >= (3, 7):
266 msg = py37_exception_repr.sub(r'\1,\2', msg)
267 cb.append(expr + ':' + msg)
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100268 else:
269 cb.append(expr + ':NOT FAILED')
270 except Exception as e:
Bram Moolenaar79a494d2018-07-22 04:30:21 +0200271 msg = repr((e.__class__, e))
272 if sys.version_info >= (3, 7):
273 msg = py37_exception_repr.sub(r'\1,\2', msg)
274 cb.append(expr + '::' + msg)
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100275EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200276:fun New(...)
277: return ['NewStart']+a:000+['NewEnd']
278:endfun
279:fun DictNew(...) dict
280: return ['DictNewStart']+a:000+['DictNewEnd', self]
281:endfun
Bram Moolenaardb913952012-06-29 12:54:53 +0200282:let l=[function('New'), function('DictNew')]
283:py3 l=vim.bindeval('l')
284:py3 l.extend(list(l[0](1, 2, 3)))
285:$put =string(l)
286:py3 l.extend(list(l[1](1, 2, 3, self={'a': 'b'})))
287:$put =string(l)
288:py3 l+=[l[0].name]
289:$put =string(l)
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100290:py3 ee('l[1](1, 2, 3)')
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200291:py3 f=l[0]
Bram Moolenaardb913952012-06-29 12:54:53 +0200292:delfunction New
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100293:py3 ee('f(1, 2, 3)')
Bram Moolenaardb913952012-06-29 12:54:53 +0200294:if has('float')
295: let l=[0.0]
296: py3 l=vim.bindeval('l')
297: py3 l.extend([0.0])
298: $put =string(l)
299:else
300: $put ='[0.0, 0.0]'
301:endif
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200302:let messages=[]
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200303:delfunction DictNew
304py3 <<EOF
Bram Moolenaar29e19512016-02-28 20:13:18 +0100305import sys
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200306d=vim.bindeval('{}')
307m=vim.bindeval('messages')
Bram Moolenaara9922d62013-05-30 13:01:18 +0200308def em(expr, g=globals(), l=locals()):
309 try:
310 exec(expr, g, l)
311 except Exception as e:
Bram Moolenaar29e19512016-02-28 20:13:18 +0100312 if sys.version_info >= (3, 5) and e.__class__ is ValueError and str(e) == 'embedded null byte':
313 m.extend([TypeError.__name__])
314 else:
315 m.extend([e.__class__.__name__])
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200316
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200317em('d["abc1"]')
318em('d["abc1"]="\\0"')
319em('d["abc1"]=vim')
Bram Moolenaara9922d62013-05-30 13:01:18 +0200320em('d[""]=1')
321em('d["a\\0b"]=1')
322em('d[b"a\\0b"]=1')
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200323
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200324em('d.pop("abc1")')
Bram Moolenaarde71b562013-06-02 17:41:54 +0200325em('d.popitem()')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200326del em
327del m
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200328EOF
329:$put =messages
Bram Moolenaar66b79852012-09-21 14:00:35 +0200330:unlet messages
331:" locked and scope attributes
332:let d={} | let dl={} | lockvar dl
333:for s in split("d dl v: g:")
334: let name=tr(s, ':', 's')
335: execute 'py3 '.name.'=vim.bindeval("'.s.'")'
336: let toput=s.' : '.join(map(['locked', 'scope'], 'v:val.":".py3eval(name.".".v:val)'), ';')
337: $put =toput
338:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200339:silent! let d.abc2=1
340:silent! let dl.abc3=1
Bram Moolenaar66b79852012-09-21 14:00:35 +0200341:py3 d.locked=True
342:py3 dl.locked=False
343:silent! let d.def=1
344:silent! let dl.def=1
345:put ='d:'.string(d)
346:put ='dl:'.string(dl)
347:unlet d dl
348:
349:let l=[] | let ll=[] | lockvar ll
350:for s in split("l ll")
351: let name=tr(s, ':', 's')
352: execute 'py3 '.name.'=vim.bindeval("'.s.'")'
353: let toput=s.' : locked:'.py3eval(name.'.locked')
354: $put =toput
355:endfor
356:silent! call extend(l, [0])
357:silent! call extend(ll, [0])
358:py3 l.locked=True
359:py3 ll.locked=False
360:silent! call extend(l, [1])
361:silent! call extend(ll, [1])
362:put ='l:'.string(l)
363:put ='ll:'.string(ll)
364:unlet l ll
Bram Moolenaardb913952012-06-29 12:54:53 +0200365:"
366:" py3eval()
367:let l=py3eval('[0, 1, 2]')
368:$put =string(l)
369:let d=py3eval('{"a": "b", "c": 1, "d": ["e"]}')
370:$put =sort(items(d))
Bram Moolenaar77324fc2016-01-17 22:37:03 +0100371:let v:errmsg = ''
372:$put ='py3eval(\"None\") = ' . py3eval('None') . v:errmsg
Bram Moolenaardb913952012-06-29 12:54:53 +0200373:if has('float')
374: let f=py3eval('0.0')
375: $put =string(f)
376:else
377: $put ='0.0'
378:endif
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200379:" Invalid values:
380:for e in ['"\0"', '{"\0": 1}', 'undefined_name', 'vim']
381: try
382: let v=py3eval(e)
383: catch
384: let toput=e.":\t".v:exception[:13]
385: $put =toput
386: endtry
387:endfor
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100388:"
389:" threading
390:let l = [0]
391:py3 l=vim.bindeval('l')
Bram Moolenaardee2e312013-06-23 16:35:47 +0200392py3 <<EOF
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100393import threading
394import time
395
396class T(threading.Thread):
397 def __init__(self):
398 threading.Thread.__init__(self)
399 self.t = 0
400 self.running = True
401
402 def run(self):
403 while self.running:
404 self.t += 1
405 time.sleep(0.1)
406
407t = T()
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200408del T
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100409t.start()
410EOF
411:sleep 1
412:py3 t.running = False
413:py3 t.join()
Bram Moolenaar52f6ae12015-12-29 16:34:06 +0100414:" Check if the background thread is working. Count should be 10, but on a
415:" busy system (AppVeyor) it can be much lower.
416:py3 l[0] = t.t > 4
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200417:py3 del time
418:py3 del threading
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100419:py3 del t
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100420:$put =string(l)
421:"
422:" settrace
423:let l = []
424:py3 l=vim.bindeval('l')
Bram Moolenaardee2e312013-06-23 16:35:47 +0200425py3 <<EOF
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100426import sys
427
428def traceit(frame, event, arg):
429 global l
430 if event == "line":
431 l += [frame.f_lineno]
432 return traceit
433
434def trace_main():
435 for i in range(5):
436 pass
437EOF
438:py3 sys.settrace(traceit)
439:py3 trace_main()
Bram Moolenaardee2e312013-06-23 16:35:47 +0200440:py3 sys.settrace(None)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200441:py3 del traceit
442:py3 del trace_main
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100443:$put =string(l)
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200444:"
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100445:" Slice
446:py3 ll = vim.bindeval('[0, 1, 2, 3, 4, 5]')
447:py3 l = ll[:4]
448:$put =string(py3eval('l'))
449:py3 l = ll[2:]
450:$put =string(py3eval('l'))
451:py3 l = ll[:-4]
452:$put =string(py3eval('l'))
453:py3 l = ll[-2:]
454:$put =string(py3eval('l'))
455:py3 l = ll[2:4]
456:$put =string(py3eval('l'))
457:py3 l = ll[4:2]
458:$put =string(py3eval('l'))
459:py3 l = ll[-4:-2]
460:$put =string(py3eval('l'))
461:py3 l = ll[-2:-4]
462:$put =string(py3eval('l'))
463:py3 l = ll[:]
464:$put =string(py3eval('l'))
465:py3 l = ll[0:6]
466:$put =string(py3eval('l'))
467:py3 l = ll[-10:10]
468:$put =string(py3eval('l'))
469:py3 l = ll[4:2:-1]
470:$put =string(py3eval('l'))
471:py3 l = ll[::2]
472:$put =string(py3eval('l'))
473:py3 l = ll[4:2:1]
474:$put =string(py3eval('l'))
475:py3 del l
476:"
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200477:" Vars
478:let g:foo = 'bac'
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200479:let w:abc3 = 'def'
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200480:let b:baz = 'bar'
Bram Moolenaara4720012013-05-15 16:27:37 +0200481:let t:bar = 'jkl'
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200482:try
483: throw "Abc"
484:catch
485: put =py3eval('vim.vvars[''exception'']')
486:endtry
487:put =py3eval('vim.vars[''foo'']')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200488:put =py3eval('vim.current.window.vars[''abc3'']')
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200489:put =py3eval('vim.current.buffer.vars[''baz'']')
Bram Moolenaara4720012013-05-15 16:27:37 +0200490:put =py3eval('vim.current.tabpage.vars[''bar'']')
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200491:"
492:" Options
493:" paste: boolean, global
494:" previewheight number, global
495:" operatorfunc: string, global
496:" number: boolean, window-local
497:" numberwidth: number, window-local
498:" colorcolumn: string, window-local
499:" statusline: string, window-local/global
500:" autoindent: boolean, buffer-local
Bram Moolenaar55b8ad32013-05-17 13:38:04 +0200501:" shiftwidth: number, buffer-local
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200502:" omnifunc: string, buffer-local
503:" preserveindent: boolean, buffer-local/global
504:" path: string, buffer-local/global
505:let g:bufs=[bufnr('%')]
506:new
507:let g:bufs+=[bufnr('%')]
508:vnew
509:let g:bufs+=[bufnr('%')]
510:wincmd j
511:vnew
512:let g:bufs+=[bufnr('%')]
513:wincmd l
514:fun RecVars(opt)
515: let gval =string(eval('&g:'.a:opt))
516: let wvals=join(map(range(1, 4), 'v:val.":".string(getwinvar(v:val, "&".a:opt))'))
517: let bvals=join(map(copy(g:bufs), 'v:val.":".string(getbufvar(v:val, "&".a:opt))'))
518: put =' G: '.gval
519: put =' W: '.wvals
520: put =' B: '.wvals
521:endfun
522py3 << EOF
523def e(s, g=globals(), l=locals()):
524 try:
525 exec(s, g, l)
526 except Exception as e:
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200527 vim.command('return ' + repr(e.__class__.__name__))
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200528
529def ev(s, g=globals(), l=locals()):
530 try:
531 return eval(s, g, l)
532 except Exception as e:
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200533 vim.command('let exc=' + repr(e.__class__.__name__))
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200534 return 0
535EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200536:fun E(s)
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200537: python3 e(vim.eval('a:s'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200538:endfun
539:fun Ev(s)
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200540: let r=py3eval('ev(vim.eval("a:s"))')
541: if exists('exc')
542: throw exc
543: endif
544: return r
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200545:endfun
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200546:py3 gopts1=vim.options
547:py3 wopts1=vim.windows[2].options
548:py3 wopts2=vim.windows[0].options
549:py3 wopts3=vim.windows[1].options
550:py3 bopts1=vim.buffers[vim.bindeval("g:bufs")[2]].options
551:py3 bopts2=vim.buffers[vim.bindeval("g:bufs")[1]].options
552:py3 bopts3=vim.buffers[vim.bindeval("g:bufs")[0]].options
Bram Moolenaar1028f4d2014-01-14 16:55:00 +0100553:$put ='wopts iters equal: '.py3eval('list(wopts1) == list(wopts2)')
554:$put ='bopts iters equal: '.py3eval('list(bopts1) == list(bopts2)')
555:py3 gset=set(iter(gopts1))
556:py3 wset=set(iter(wopts1))
557:py3 bset=set(iter(bopts1))
Bram Moolenaar04188112013-06-01 20:32:12 +0200558:set path=.,..,,
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200559:let lst=[]
560:let lst+=[['paste', 1, 0, 1, 2, 1, 1, 0 ]]
561:let lst+=[['previewheight', 5, 1, 6, 'a', 0, 1, 0 ]]
562:let lst+=[['operatorfunc', 'A', 'B', 'C', 2, 0, 1, 0 ]]
563:let lst+=[['number', 0, 1, 1, 0, 1, 0, 1 ]]
564:let lst+=[['numberwidth', 2, 3, 5, -100, 0, 0, 1 ]]
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200565:let lst+=[['colorcolumn', '+1', '+2', '+3', 'abc4', 0, 0, 1 ]]
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200566:let lst+=[['statusline', '1', '2', '4', 0, 0, 1, 1 ]]
567:let lst+=[['autoindent', 0, 1, 1, 2, 1, 0, 2 ]]
Bram Moolenaar55b8ad32013-05-17 13:38:04 +0200568:let lst+=[['shiftwidth', 0, 2, 1, 3, 0, 0, 2 ]]
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200569:let lst+=[['omnifunc', 'A', 'B', 'C', 1, 0, 0, 2 ]]
570:let lst+=[['preserveindent', 0, 1, 1, 2, 1, 1, 2 ]]
571:let lst+=[['path', '.,,', ',,', '.', 0, 0, 1, 2 ]]
572:for [oname, oval1, oval2, oval3, invval, bool, global, local] in lst
573: py3 oname=vim.eval('oname')
574: py3 oval1=vim.bindeval('oval1')
575: py3 oval2=vim.bindeval('oval2')
576: py3 oval3=vim.bindeval('oval3')
577: if invval is 0 || invval is 1
578: py3 invval=bool(vim.bindeval('invval'))
579: else
580: py3 invval=vim.bindeval('invval')
581: endif
582: if bool
583: py3 oval1=bool(oval1)
584: py3 oval2=bool(oval2)
585: py3 oval3=bool(oval3)
586: endif
587: put ='>>> '.oname
Bram Moolenaar1028f4d2014-01-14 16:55:00 +0100588: $put =' g/w/b:'.py3eval('oname in gset').'/'.py3eval('oname in wset').'/'.py3eval('oname in bset')
589: $put =' g/w/b (in):'.py3eval('oname in gopts1').'/'.py3eval('oname in wopts1').'/'.py3eval('oname in bopts1')
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200590: for v in ['gopts1', 'wopts1', 'bopts1']
591: try
592: put =' p/'.v.': '.Ev('repr('.v.'['''.oname.'''])')
593: catch
594: put =' p/'.v.'! '.v:exception
595: endtry
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200596: let r=E(v.'['''.oname.''']=invval')
597: if r isnot 0
598: put =' inv: '.string(invval).'! '.r
599: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200600: for vv in (v is# 'gopts1' ? [v] : [v, v[:-2].'2', v[:-2].'3'])
601: let val=substitute(vv, '^.opts', 'oval', '')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200602: let r=E(vv.'['''.oname.''']='.val)
603: if r isnot 0
604: put =' '.vv.'! '.r
605: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200606: endfor
607: endfor
608: call RecVars(oname)
609: for v in ['wopts3', 'bopts3']
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200610: let r=E('del '.v.'["'.oname.'"]')
611: if r isnot 0
612: put =' del '.v.'! '.r
613: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200614: endfor
615: call RecVars(oname)
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200616:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200617:delfunction RecVars
618:delfunction E
619:delfunction Ev
620:py3 del ev
621:py3 del e
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200622:only
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200623:for buf in g:bufs[1:]
624: execute 'bwipeout!' buf
625:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200626:py3 del gopts1
627:py3 del wopts1
628:py3 del wopts2
629:py3 del wopts3
630:py3 del bopts1
631:py3 del bopts2
632:py3 del bopts3
633:py3 del oval1
634:py3 del oval2
635:py3 del oval3
636:py3 del oname
637:py3 del invval
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200638:"
639:" Test buffer object
640:vnew
641:put ='First line'
642:put ='Second line'
643:put ='Third line'
644:1 delete _
645:py3 b=vim.current.buffer
646:wincmd w
647:mark a
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200648:augroup BUFS
649: autocmd BufFilePost * python3 cb.append(vim.eval('expand("<abuf>")') + ':BufFilePost:' + vim.eval('bufnr("%")'))
650: autocmd BufFilePre * python3 cb.append(vim.eval('expand("<abuf>")') + ':BufFilePre:' + vim.eval('bufnr("%")'))
651:augroup END
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200652py3 << EOF
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200653# Tests BufferAppend and BufferItem
654cb.append(b[0])
655# Tests BufferSlice and BufferAssSlice
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200656cb.append('abc5') # Will be overwritten
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200657cb[-1:] = b[:-2]
658# Test BufferLength and BufferAssSlice
659cb.append('def') # Will not be overwritten
660cb[len(cb):] = b[:]
661# Test BufferAssItem and BufferMark
662cb.append('ghi') # Will be overwritten
663cb[-1] = repr((len(cb) - cb.mark('a')[0], cb.mark('a')[1]))
664# Test BufferRepr
665cb.append(repr(cb) + repr(b))
666# Modify foreign buffer
667b.append('foo')
668b[0]='bar'
669b[0:0]=['baz']
670vim.command('call append("$", getbufline(%i, 1, "$"))' % b.number)
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200671# Test assigning to name property
Bram Moolenaar04188112013-06-01 20:32:12 +0200672import os
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200673old_name = cb.name
674cb.name = 'foo'
Bram Moolenaar04188112013-06-01 20:32:12 +0200675cb.append(cb.name[-11:].replace(os.path.sep, '/'))
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200676b.name = 'bar'
Bram Moolenaar04188112013-06-01 20:32:12 +0200677cb.append(b.name[-11:].replace(os.path.sep, '/'))
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200678cb.name = old_name
Bram Moolenaar04188112013-06-01 20:32:12 +0200679cb.append(cb.name[-17:].replace(os.path.sep, '/'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200680del old_name
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200681# Test CheckBuffer
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200682for _b in vim.buffers:
683 if _b is not cb:
684 vim.command('bwipeout! ' + str(_b.number))
685del _b
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200686cb.append('valid: b:%s, cb:%s' % (repr(b.valid), repr(cb.valid)))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200687for expr in ('b[1]','b[:] = ["A", "B"]','b[:]','b.append("abc6")'):
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200688 try:
689 exec(expr)
690 except vim.error:
691 pass
692 else:
693 # Usually a SEGV here
694 # Should not happen in any case
695 cb.append('No exception for ' + expr)
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200696vim.command('cd .')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200697del b
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200698EOF
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200699:"
700:" Test vim.buffers object
701:set hidden
702:edit a
703:buffer #
704:edit b
705:buffer #
706:edit c
707:buffer #
708py3 << EOF
709# Check GCing iterator that was not fully exhausted
710i = iter(vim.buffers)
711cb.append('i:' + str(next(i)))
Bram Moolenaar038e5d42014-03-12 15:26:40 +0100712# and also check creating more than one iterator at a time
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200713i2 = iter(vim.buffers)
714cb.append('i2:' + str(next(i2)))
715cb.append('i:' + str(next(i)))
716# The following should trigger GC and not cause any problems
717del i
718del i2
719i3 = iter(vim.buffers)
720cb.append('i3:' + str(next(i3)))
721del i3
722
723prevnum = 0
724for b in vim.buffers:
725 # Check buffer order
726 if prevnum >= b.number:
727 cb.append('!!! Buffer numbers not in strictly ascending order')
728 # Check indexing: vim.buffers[number].number == number
729 cb.append(str(b.number) + ':' + repr(vim.buffers[b.number]) + '=' + repr(b))
730 prevnum = b.number
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200731del prevnum
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200732
733cb.append(str(len(vim.buffers)))
734
735bnums = list(map(lambda b: b.number, vim.buffers))[1:]
736
737# Test wiping out buffer with existing iterator
738i4 = iter(vim.buffers)
739cb.append('i4:' + str(next(i4)))
740vim.command('bwipeout! ' + str(bnums.pop(0)))
741try:
742 next(i4)
743except vim.error:
744 pass
745else:
746 cb.append('!!!! No vim.error')
747i4 = iter(vim.buffers)
748vim.command('bwipeout! ' + str(bnums.pop(-1)))
749vim.command('bwipeout! ' + str(bnums.pop(-1)))
750cb.append('i4:' + str(next(i4)))
751try:
752 next(i4)
753except StopIteration:
754 cb.append('StopIteration')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200755del i4
756del bnums
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200757EOF
Bram Moolenaara4720012013-05-15 16:27:37 +0200758:"
759:" Test vim.{tabpage,window}list and vim.{tabpage,window} objects
760:tabnew 0
761:tabnew 1
762:vnew a.1
763:tabnew 2
764:vnew a.2
765:vnew b.2
766:vnew c.2
767py3 << EOF
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200768cb.append('Number of tabs: ' + str(len(vim.tabpages)))
769cb.append('Current tab pages:')
770
Bram Moolenaara4720012013-05-15 16:27:37 +0200771def W(w):
772 if '(unknown)' in repr(w):
773 return '<window object (unknown)>'
774 else:
775 return repr(w)
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200776
777def Cursor(w, start=len(cb)):
778 if w.buffer is cb:
779 return repr((start - w.cursor[0], w.cursor[1]))
780 else:
781 return repr(w.cursor)
782
Bram Moolenaara4720012013-05-15 16:27:37 +0200783for t in vim.tabpages:
784 cb.append(' ' + repr(t) + '(' + str(t.number) + ')' + ': ' + str(len(t.windows)) + ' windows, current is ' + W(t.window))
785 cb.append(' Windows:')
786 for w in t.windows:
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200787 cb.append(' ' + W(w) + '(' + str(w.number) + ')' + ': displays buffer ' + repr(w.buffer) + '; cursor is at ' + Cursor(w))
Bram Moolenaara4720012013-05-15 16:27:37 +0200788 # Other values depend on the size of the terminal, so they are checked partly:
789 for attr in ('height', 'row', 'width', 'col'):
790 try:
791 aval = getattr(w, attr)
792 if type(aval) is not int:
793 raise TypeError
794 if aval < 0:
795 raise ValueError
796 except Exception as e:
797 cb.append('!!!!!! Error while getting attribute ' + attr + ': ' + e.__class__.__name__)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200798 del aval
799 del attr
Bram Moolenaara4720012013-05-15 16:27:37 +0200800 w.cursor = (len(w.buffer), 0)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200801del W
802del Cursor
Bram Moolenaara4720012013-05-15 16:27:37 +0200803cb.append('Number of windows in current tab page: ' + str(len(vim.windows)))
804if list(vim.windows) != list(vim.current.tabpage.windows):
805 cb.append('!!!!!! Windows differ')
806EOF
807:"
808:" Test vim.current
809py3 << EOF
810def H(o):
811 return repr(o)
812cb.append('Current tab page: ' + repr(vim.current.tabpage))
813cb.append('Current window: ' + repr(vim.current.window) + ': ' + H(vim.current.window) + ' is ' + H(vim.current.tabpage.window))
814cb.append('Current buffer: ' + repr(vim.current.buffer) + ': ' + H(vim.current.buffer) + ' is ' + H(vim.current.window.buffer)+ ' is ' + H(vim.current.tabpage.window.buffer))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200815del H
Bram Moolenaara4720012013-05-15 16:27:37 +0200816# Assigning: fails
817try:
818 vim.current.window = vim.tabpages[0].window
819except ValueError:
820 cb.append('ValueError at assigning foreign tab window')
821
822for attr in ('window', 'tabpage', 'buffer'):
823 try:
824 setattr(vim.current, attr, None)
825 except TypeError:
826 cb.append('Type error at assigning None to vim.current.' + attr)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200827del attr
Bram Moolenaara4720012013-05-15 16:27:37 +0200828
829# Assigning: success
830vim.current.tabpage = vim.tabpages[-2]
831vim.current.buffer = cb
832vim.current.window = vim.windows[0]
833vim.current.window.cursor = (len(vim.current.buffer), 0)
834cb.append('Current tab page: ' + repr(vim.current.tabpage))
835cb.append('Current window: ' + repr(vim.current.window))
836cb.append('Current buffer: ' + repr(vim.current.buffer))
837cb.append('Current line: ' + repr(vim.current.line))
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200838ws = list(vim.windows)
839ts = list(vim.tabpages)
Bram Moolenaara4720012013-05-15 16:27:37 +0200840for b in vim.buffers:
841 if b is not cb:
842 vim.command('bwipeout! ' + str(b.number))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200843del b
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200844cb.append('w.valid: ' + repr([w.valid for w in ws]))
845cb.append('t.valid: ' + repr([t.valid for t in ts]))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200846del w
847del t
848del ts
849del ws
Bram Moolenaara4720012013-05-15 16:27:37 +0200850EOF
851:tabonly!
852:only!
Bram Moolenaarcac867a2013-05-21 19:50:34 +0200853:"
854:" Test types
855py3 << EOF
856for expr, attr in (
857 ('vim.vars', 'Dictionary'),
858 ('vim.options', 'Options'),
859 ('vim.bindeval("{}")', 'Dictionary'),
860 ('vim.bindeval("[]")', 'List'),
861 ('vim.bindeval("function(\'tr\')")', 'Function'),
862 ('vim.current.buffer', 'Buffer'),
863 ('vim.current.range', 'Range'),
864 ('vim.current.window', 'Window'),
865 ('vim.current.tabpage', 'TabPage'),
866):
867 cb.append(expr + ':' + attr + ':' + repr(type(eval(expr)) is getattr(vim, attr)))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200868del expr
869del attr
Bram Moolenaarcac867a2013-05-21 19:50:34 +0200870EOF
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200871:"
Bram Moolenaardd8aca62013-05-29 22:36:10 +0200872:" Test __dir__() method
873py3 << EOF
874for name, o in (
875 ('current', vim.current),
876 ('buffer', vim.current.buffer),
877 ('window', vim.current.window),
878 ('tabpage', vim.current.tabpage),
879 ('range', vim.current.range),
880 ('dictionary', vim.bindeval('{}')),
881 ('list', vim.bindeval('[]')),
882 ('function', vim.bindeval('function("tr")')),
883 ('output', sys.stdout),
884 ):
885 cb.append(name + ':' + ','.join(dir(o)))
886del name
887del o
888EOF
889:"
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200890:" Test vim.*.__new__
Bram Moolenaara9922d62013-05-30 13:01:18 +0200891:$put =string(py3eval('vim.Dictionary({})'))
892:$put =string(py3eval('vim.Dictionary(a=1)'))
893:$put =string(py3eval('vim.Dictionary(((''a'', 1),))'))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200894:$put =string(py3eval('vim.List()'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200895:$put =string(py3eval('vim.List(iter(''abc7''))'))
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200896:$put =string(py3eval('vim.Function(''tr'')'))
Bram Moolenaar8110a092016-04-14 15:56:09 +0200897:$put =string(py3eval('vim.Function(''tr'', args=[123, 3, 4])'))
898:$put =string(py3eval('vim.Function(''tr'', args=[])'))
899:$put =string(py3eval('vim.Function(''tr'', self={})'))
900:$put =string(py3eval('vim.Function(''tr'', args=[123, 3, 4], self={})'))
Bram Moolenaar2177f9f2016-05-25 20:39:09 +0200901:$put ='auto_rebind'
902:$put =string(py3eval('vim.Function(''tr'', auto_rebind=False)'))
903:$put =string(py3eval('vim.Function(''tr'', args=[123, 3, 4], auto_rebind=False)'))
904:$put =string(py3eval('vim.Function(''tr'', args=[], auto_rebind=False)'))
905:$put =string(py3eval('vim.Function(''tr'', self={}, auto_rebind=False)'))
906:$put =string(py3eval('vim.Function(''tr'', args=[123, 3, 4], self={}, auto_rebind=False)'))
Bram Moolenaar8110a092016-04-14 15:56:09 +0200907:"
908:" Test vim.Function
909:function Args(...)
910: return a:000
911:endfunction
912:function SelfArgs(...) dict
913: return [a:000, self]
914:endfunction
915:" The following four lines should not crash
916:let Pt = function('tr', [[]], {'l': []})
917:py3 Pt = vim.bindeval('Pt')
918:unlet Pt
919:py3 del Pt
920py3 << EOF
921def ecall(out_prefix, func, *args, **kwargs):
922 line = out_prefix + ': '
923 try:
924 ret = func(*args, **kwargs)
925 except Exception:
926 line += '!exception: ' + emsg(sys.exc_info())
927 else:
928 line += '!result: ' + str(vim.Function('string')(ret), 'utf-8')
929 cb.append(line)
930a = vim.Function('Args')
931pa1 = vim.Function('Args', args=['abcArgsPA1'])
932pa2 = vim.Function('Args', args=[])
933pa3 = vim.Function('Args', args=['abcArgsPA3'], self={'abcSelfPA3': 'abcSelfPA3Val'})
934pa4 = vim.Function('Args', self={'abcSelfPA4': 'abcSelfPA4Val'})
935cb.append('a: ' + repr(a))
936cb.append('pa1: ' + repr(pa1))
937cb.append('pa2: ' + repr(pa2))
938cb.append('pa3: ' + repr(pa3))
939cb.append('pa4: ' + repr(pa4))
940sa = vim.Function('SelfArgs')
941psa1 = vim.Function('SelfArgs', args=['abcArgsPSA1'])
942psa2 = vim.Function('SelfArgs', args=[])
943psa3 = vim.Function('SelfArgs', args=['abcArgsPSA3'], self={'abcSelfPSA3': 'abcSelfPSA3Val'})
944psa4 = vim.Function('SelfArgs', self={'abcSelfPSA4': 'abcSelfPSA4Val'})
Bram Moolenaar2177f9f2016-05-25 20:39:09 +0200945psa5 = vim.Function('SelfArgs', self={'abcSelfPSA5': 'abcSelfPSA5Val'}, auto_rebind=0)
946psa6 = vim.Function('SelfArgs', args=['abcArgsPSA6'], self={'abcSelfPSA6': 'abcSelfPSA6Val'}, auto_rebind=())
947psa7 = vim.Function('SelfArgs', args=['abcArgsPSA7'], auto_rebind=[])
948psa8 = vim.Function('SelfArgs', auto_rebind=False)
949psa9 = vim.Function('SelfArgs', self={'abcSelfPSA9': 'abcSelfPSA9Val'}, auto_rebind=True)
950psaA = vim.Function('SelfArgs', args=['abcArgsPSAA'], self={'abcSelfPSAA': 'abcSelfPSAAVal'}, auto_rebind=1)
951psaB = vim.Function('SelfArgs', args=['abcArgsPSAB'], auto_rebind={'abcARPSAB': 'abcARPSABVal'})
952psaC = vim.Function('SelfArgs', auto_rebind=['abcARPSAC'])
Bram Moolenaar8110a092016-04-14 15:56:09 +0200953cb.append('sa: ' + repr(sa))
954cb.append('psa1: ' + repr(psa1))
955cb.append('psa2: ' + repr(psa2))
956cb.append('psa3: ' + repr(psa3))
957cb.append('psa4: ' + repr(psa4))
Bram Moolenaar2177f9f2016-05-25 20:39:09 +0200958cb.append('psa5: ' + repr(psa5))
959cb.append('psa6: ' + repr(psa6))
960cb.append('psa7: ' + repr(psa7))
961cb.append('psa8: ' + repr(psa8))
962cb.append('psa9: ' + repr(psa9))
963cb.append('psaA: ' + repr(psaA))
964cb.append('psaB: ' + repr(psaB))
965cb.append('psaC: ' + repr(psaC))
Bram Moolenaar8110a092016-04-14 15:56:09 +0200966
967psar = vim.Function('SelfArgs', args=[{'abcArgsPSAr': 'abcArgsPSArVal'}], self={'abcSelfPSAr': 'abcSelfPSArVal'})
968psar.args[0]['abcArgsPSAr2'] = [psar.self, psar.args[0]]
969psar.self['rec'] = psar
970psar.self['self'] = psar.self
971psar.self['args'] = psar.args
972
973try:
974 cb.append('psar: ' + repr(psar))
975except Exception:
976 cb.append('!!!!!!!! Caught exception: ' + emsg(sys.exc_info()))
977EOF
978:$put ='s(a): '.string(py3eval('a'))
979:$put ='s(pa1): '.string(py3eval('pa1'))
980:$put ='s(pa2): '.string(py3eval('pa2'))
981:$put ='s(pa3): '.string(py3eval('pa3'))
982:$put ='s(pa4): '.string(py3eval('pa4'))
983:$put ='s(sa): '.string(py3eval('sa'))
984:$put ='s(psa1): '.string(py3eval('psa1'))
985:$put ='s(psa2): '.string(py3eval('psa2'))
986:$put ='s(psa3): '.string(py3eval('psa3'))
987:$put ='s(psa4): '.string(py3eval('psa4'))
Bram Moolenaar2177f9f2016-05-25 20:39:09 +0200988:$put ='s(psa5): '.string(py3eval('psa5'))
989:$put ='s(psa6): '.string(py3eval('psa6'))
990:$put ='s(psa7): '.string(py3eval('psa7'))
991:$put ='s(psa8): '.string(py3eval('psa8'))
992:$put ='s(psa9): '.string(py3eval('psa9'))
993:$put ='s(psaA): '.string(py3eval('psaA'))
994:$put ='s(psaB): '.string(py3eval('psaB'))
995:$put ='s(psaC): '.string(py3eval('psaC'))
996:
997:for v in ['sa', 'psa1', 'psa2', 'psa3', 'psa4', 'psa5', 'psa6', 'psa7', 'psa8', 'psa9', 'psaA', 'psaB', 'psaC']
998: let d = {'f': py3eval(v)}
999: $put ='d.'.v.'(): '.string(d.f())
1000:endfor
Bram Moolenaar8110a092016-04-14 15:56:09 +02001001:
1002:py3 ecall('a()', a, )
1003:py3 ecall('pa1()', pa1, )
1004:py3 ecall('pa2()', pa2, )
1005:py3 ecall('pa3()', pa3, )
1006:py3 ecall('pa4()', pa4, )
1007:py3 ecall('sa()', sa, )
1008:py3 ecall('psa1()', psa1, )
1009:py3 ecall('psa2()', psa2, )
1010:py3 ecall('psa3()', psa3, )
1011:py3 ecall('psa4()', psa4, )
1012:
1013:py3 ecall('a(42, 43)', a, 42, 43)
1014:py3 ecall('pa1(42, 43)', pa1, 42, 43)
1015:py3 ecall('pa2(42, 43)', pa2, 42, 43)
1016:py3 ecall('pa3(42, 43)', pa3, 42, 43)
1017:py3 ecall('pa4(42, 43)', pa4, 42, 43)
1018:py3 ecall('sa(42, 43)', sa, 42, 43)
1019:py3 ecall('psa1(42, 43)', psa1, 42, 43)
1020:py3 ecall('psa2(42, 43)', psa2, 42, 43)
1021:py3 ecall('psa3(42, 43)', psa3, 42, 43)
1022:py3 ecall('psa4(42, 43)', psa4, 42, 43)
1023:
1024:py3 ecall('a(42, self={"20": 1})', a, 42, self={'20': 1})
1025:py3 ecall('pa1(42, self={"20": 1})', pa1, 42, self={'20': 1})
1026:py3 ecall('pa2(42, self={"20": 1})', pa2, 42, self={'20': 1})
1027:py3 ecall('pa3(42, self={"20": 1})', pa3, 42, self={'20': 1})
1028:py3 ecall('pa4(42, self={"20": 1})', pa4, 42, self={'20': 1})
1029:py3 ecall('sa(42, self={"20": 1})', sa, 42, self={'20': 1})
1030:py3 ecall('psa1(42, self={"20": 1})', psa1, 42, self={'20': 1})
1031:py3 ecall('psa2(42, self={"20": 1})', psa2, 42, self={'20': 1})
1032:py3 ecall('psa3(42, self={"20": 1})', psa3, 42, self={'20': 1})
1033:py3 ecall('psa4(42, self={"20": 1})', psa4, 42, self={'20': 1})
1034:
1035:py3 ecall('a(self={"20": 1})', a, self={'20': 1})
1036:py3 ecall('pa1(self={"20": 1})', pa1, self={'20': 1})
1037:py3 ecall('pa2(self={"20": 1})', pa2, self={'20': 1})
1038:py3 ecall('pa3(self={"20": 1})', pa3, self={'20': 1})
1039:py3 ecall('pa4(self={"20": 1})', pa4, self={'20': 1})
1040:py3 ecall('sa(self={"20": 1})', sa, self={'20': 1})
1041:py3 ecall('psa1(self={"20": 1})', psa1, self={'20': 1})
1042:py3 ecall('psa2(self={"20": 1})', psa2, self={'20': 1})
1043:py3 ecall('psa3(self={"20": 1})', psa3, self={'20': 1})
1044:py3 ecall('psa4(self={"20": 1})', psa4, self={'20': 1})
1045py3 << EOF
1046def s(v):
1047 if v is None:
1048 return repr(v)
1049 else:
1050 return str(vim.Function('string')(v), 'utf-8')
1051
1052cb.append('a.args: ' + s(a.args))
1053cb.append('pa1.args: ' + s(pa1.args))
1054cb.append('pa2.args: ' + s(pa2.args))
1055cb.append('pa3.args: ' + s(pa3.args))
1056cb.append('pa4.args: ' + s(pa4.args))
1057cb.append('sa.args: ' + s(sa.args))
1058cb.append('psa1.args: ' + s(psa1.args))
1059cb.append('psa2.args: ' + s(psa2.args))
1060cb.append('psa3.args: ' + s(psa3.args))
1061cb.append('psa4.args: ' + s(psa4.args))
1062
1063cb.append('a.self: ' + s(a.self))
1064cb.append('pa1.self: ' + s(pa1.self))
1065cb.append('pa2.self: ' + s(pa2.self))
1066cb.append('pa3.self: ' + s(pa3.self))
1067cb.append('pa4.self: ' + s(pa4.self))
1068cb.append('sa.self: ' + s(sa.self))
1069cb.append('psa1.self: ' + s(psa1.self))
1070cb.append('psa2.self: ' + s(psa2.self))
1071cb.append('psa3.self: ' + s(psa3.self))
1072cb.append('psa4.self: ' + s(psa4.self))
1073
1074cb.append('a.name: ' + s(a.name))
1075cb.append('pa1.name: ' + s(pa1.name))
1076cb.append('pa2.name: ' + s(pa2.name))
1077cb.append('pa3.name: ' + s(pa3.name))
1078cb.append('pa4.name: ' + s(pa4.name))
1079cb.append('sa.name: ' + s(sa.name))
1080cb.append('psa1.name: ' + s(psa1.name))
1081cb.append('psa2.name: ' + s(psa2.name))
1082cb.append('psa3.name: ' + s(psa3.name))
1083cb.append('psa4.name: ' + s(psa4.name))
1084
Bram Moolenaar2177f9f2016-05-25 20:39:09 +02001085cb.append('a.auto_rebind: ' + s(a.auto_rebind))
1086cb.append('pa1.auto_rebind: ' + s(pa1.auto_rebind))
1087cb.append('pa2.auto_rebind: ' + s(pa2.auto_rebind))
1088cb.append('pa3.auto_rebind: ' + s(pa3.auto_rebind))
1089cb.append('pa4.auto_rebind: ' + s(pa4.auto_rebind))
1090cb.append('sa.auto_rebind: ' + s(sa.auto_rebind))
1091cb.append('psa1.auto_rebind: ' + s(psa1.auto_rebind))
1092cb.append('psa2.auto_rebind: ' + s(psa2.auto_rebind))
1093cb.append('psa3.auto_rebind: ' + s(psa3.auto_rebind))
1094cb.append('psa4.auto_rebind: ' + s(psa4.auto_rebind))
1095cb.append('psa5.auto_rebind: ' + s(psa5.auto_rebind))
1096cb.append('psa6.auto_rebind: ' + s(psa6.auto_rebind))
1097cb.append('psa7.auto_rebind: ' + s(psa7.auto_rebind))
1098cb.append('psa8.auto_rebind: ' + s(psa8.auto_rebind))
1099cb.append('psa9.auto_rebind: ' + s(psa9.auto_rebind))
1100cb.append('psaA.auto_rebind: ' + s(psaA.auto_rebind))
1101cb.append('psaB.auto_rebind: ' + s(psaB.auto_rebind))
1102cb.append('psaC.auto_rebind: ' + s(psaC.auto_rebind))
1103
Bram Moolenaar8110a092016-04-14 15:56:09 +02001104del s
1105
1106del a
1107del pa1
1108del pa2
1109del pa3
1110del pa4
1111del sa
1112del psa1
1113del psa2
1114del psa3
1115del psa4
Bram Moolenaar2177f9f2016-05-25 20:39:09 +02001116del psa5
1117del psa6
1118del psa7
1119del psa8
1120del psa9
1121del psaA
1122del psaB
1123del psaC
Bram Moolenaar8110a092016-04-14 15:56:09 +02001124del psar
1125
1126del ecall
1127EOF
Bram Moolenaar01a7a722013-05-30 12:26:58 +02001128:"
1129:" Test stdout/stderr
1130:redir => messages
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001131:py3 sys.stdout.write('abc8') ; sys.stdout.write('def')
1132:py3 sys.stderr.write('abc9') ; sys.stderr.write('def')
1133:py3 sys.stdout.writelines(iter('abcA'))
1134:py3 sys.stderr.writelines(iter('abcB'))
Bram Moolenaar01a7a722013-05-30 12:26:58 +02001135:redir END
1136:$put =string(substitute(messages, '\d\+', '', 'g'))
Bram Moolenaara9922d62013-05-30 13:01:18 +02001137:" Test subclassing
Bram Moolenaar355fd9b2013-05-30 13:14:13 +02001138:fun Put(...)
1139: $put =string(a:000)
1140: return a:000
1141:endfun
Bram Moolenaara9922d62013-05-30 13:01:18 +02001142py3 << EOF
1143class DupDict(vim.Dictionary):
1144 def __setitem__(self, key, value):
1145 super(DupDict, self).__setitem__(key, value)
1146 super(DupDict, self).__setitem__('dup_' + key, value)
1147dd = DupDict()
1148dd['a'] = 'b'
Bram Moolenaar78cddbe2013-05-30 13:05:58 +02001149
1150class DupList(vim.List):
1151 def __getitem__(self, idx):
1152 return [super(DupList, self).__getitem__(idx)] * 2
1153
1154dl = DupList()
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001155dl2 = DupList(iter('abcC'))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +02001156dl.extend(dl2[0])
Bram Moolenaar355fd9b2013-05-30 13:14:13 +02001157
1158class DupFun(vim.Function):
1159 def __call__(self, arg):
1160 return super(DupFun, self).__call__(arg, arg)
1161
1162df = DupFun('Put')
Bram Moolenaara9922d62013-05-30 13:01:18 +02001163EOF
1164:$put =string(sort(keys(py3eval('dd'))))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +02001165:$put =string(py3eval('dl'))
1166:$put =string(py3eval('dl2'))
Bram Moolenaar355fd9b2013-05-30 13:14:13 +02001167:$put =string(py3eval('df(2)'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001168:$put =string(py3eval('dl') is# py3eval('dl'))
1169:$put =string(py3eval('dd') is# py3eval('dd'))
1170:$put =string(py3eval('df'))
1171:delfunction Put
1172py3 << EOF
1173del DupDict
1174del DupList
1175del DupFun
1176del dd
1177del dl
1178del dl2
1179del df
1180EOF
Bram Moolenaar01a7a722013-05-30 12:26:58 +02001181:"
Bram Moolenaarf4258302013-06-02 18:20:17 +02001182:" Test chdir
1183py3 << EOF
1184import os
1185fnamemodify = vim.Function('fnamemodify')
1186cb.append(str(fnamemodify('.', ':p:h:t')))
1187cb.append(vim.eval('@%'))
1188os.chdir('..')
Bram Moolenaar91376b62015-12-11 16:17:02 +01001189path = fnamemodify('.', ':p:h:t')
1190if path != b'src':
1191 # Running tests from a shadow directory, so move up another level
1192 # This will result in @% looking like shadow/testdir/test87.in, hence the
1193 # slicing to remove the leading path and path separator
1194 os.chdir('..')
1195 cb.append(str(fnamemodify('.', ':p:h:t')))
1196 cb.append(vim.eval('@%')[len(path)+1:].replace(os.path.sep, '/'))
1197 os.chdir(path)
1198else:
1199 cb.append(str(fnamemodify('.', ':p:h:t')))
1200 cb.append(vim.eval('@%').replace(os.path.sep, '/'))
1201del path
Bram Moolenaarf4258302013-06-02 18:20:17 +02001202os.chdir('testdir')
1203cb.append(str(fnamemodify('.', ':p:h:t')))
1204cb.append(vim.eval('@%'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001205del fnamemodify
Bram Moolenaarf4258302013-06-02 18:20:17 +02001206EOF
1207:"
Bram Moolenaar8600e402013-05-30 13:28:41 +02001208:" Test errors
1209:fun F() dict
1210:endfun
1211:fun D()
1212:endfun
1213py3 << EOF
Bram Moolenaar8600e402013-05-30 13:28:41 +02001214d = vim.Dictionary()
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001215ned = vim.Dictionary(foo='bar', baz='abcD')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001216dl = vim.Dictionary(a=1)
1217dl.locked = True
1218l = vim.List()
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001219ll = vim.List('abcE')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001220ll.locked = True
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001221nel = vim.List('abcO')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001222f = vim.Function('string')
1223fd = vim.Function('F')
1224fdel = vim.Function('D')
1225vim.command('delfunction D')
1226
1227def subexpr_test(expr, name, subexprs):
1228 cb.append('>>> Testing %s using %s' % (name, expr))
1229 for subexpr in subexprs:
1230 ee(expr % subexpr)
1231 cb.append('<<< Finished')
1232
1233def stringtochars_test(expr):
1234 return subexpr_test(expr, 'StringToChars', (
1235 '1', # Fail type checks
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001236 'b"\\0"', # Fail PyString_AsStringAndSize(object, , NULL) check
1237 '"\\0"', # Fail PyString_AsStringAndSize(bytes, , NULL) check
Bram Moolenaar8600e402013-05-30 13:28:41 +02001238 ))
1239
1240class Mapping(object):
1241 def __init__(self, d):
1242 self.d = d
1243
1244 def __getitem__(self, key):
1245 return self.d[key]
1246
1247 def keys(self):
1248 return self.d.keys()
1249
1250 def items(self):
1251 return self.d.items()
1252
1253def convertfrompyobject_test(expr, recurse=True):
1254 # pydict_to_tv
1255 stringtochars_test(expr % '{%s : 1}')
1256 if recurse:
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001257 convertfrompyobject_test(expr % '{"abcF" : %s}', False)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001258 # pymap_to_tv
1259 stringtochars_test(expr % 'Mapping({%s : 1})')
1260 if recurse:
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001261 convertfrompyobject_test(expr % 'Mapping({"abcG" : %s})', False)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001262 # pyseq_to_tv
1263 iter_test(expr)
1264 return subexpr_test(expr, 'ConvertFromPyObject', (
1265 'None', # Not conversible
Bram Moolenaar78b59572013-06-02 18:54:21 +02001266 '{b"": 1}', # Empty key not allowed
1267 '{"": 1}', # Same, but with unicode object
Bram Moolenaar8600e402013-05-30 13:28:41 +02001268 'FailingMapping()', #
1269 'FailingMappingKey()', #
Bram Moolenaardee2e312013-06-23 16:35:47 +02001270 'FailingNumber()', #
Bram Moolenaar8600e402013-05-30 13:28:41 +02001271 ))
1272
1273def convertfrompymapping_test(expr):
1274 convertfrompyobject_test(expr)
1275 return subexpr_test(expr, 'ConvertFromPyMapping', (
1276 '[]',
1277 ))
1278
1279def iter_test(expr):
1280 return subexpr_test(expr, '*Iter*', (
1281 'FailingIter()',
1282 'FailingIterNext()',
1283 ))
1284
Bram Moolenaardee2e312013-06-23 16:35:47 +02001285def number_test(expr, natural=False, unsigned=False):
1286 if natural:
1287 unsigned = True
1288 return subexpr_test(expr, 'NumberToLong', (
1289 '[]',
1290 'None',
1291 ) + (('-1',) if unsigned else ())
1292 + (('0',) if natural else ()))
1293
Bram Moolenaar8600e402013-05-30 13:28:41 +02001294class FailingTrue(object):
1295 def __bool__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001296 raise NotImplementedError('bool')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001297
1298class FailingIter(object):
1299 def __iter__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001300 raise NotImplementedError('iter')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001301
1302class FailingIterNext(object):
1303 def __iter__(self):
1304 return self
1305
1306 def __next__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001307 raise NotImplementedError('next')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001308
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001309class FailingIterNextN(object):
1310 def __init__(self, n):
1311 self.n = n
1312
1313 def __iter__(self):
1314 return self
1315
1316 def __next__(self):
1317 if self.n:
1318 self.n -= 1
1319 return 1
1320 else:
1321 raise NotImplementedError('next N')
1322
Bram Moolenaar8600e402013-05-30 13:28:41 +02001323class FailingMappingKey(object):
1324 def __getitem__(self, item):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001325 raise NotImplementedError('getitem:mappingkey')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001326
1327 def keys(self):
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001328 return list("abcH")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001329
1330class FailingMapping(object):
1331 def __getitem__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001332 raise NotImplementedError('getitem:mapping')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001333
1334 def keys(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001335 raise NotImplementedError('keys')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001336
1337class FailingList(list):
1338 def __getitem__(self, idx):
1339 if i == 2:
Bram Moolenaardee2e312013-06-23 16:35:47 +02001340 raise NotImplementedError('getitem:list')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001341 else:
1342 return super(FailingList, self).__getitem__(idx)
1343
Bram Moolenaardee2e312013-06-23 16:35:47 +02001344class NoArgsCall(object):
1345 def __call__(self):
1346 pass
1347
1348class FailingCall(object):
1349 def __call__(self, path):
1350 raise NotImplementedError('call')
1351
1352class FailingNumber(object):
1353 def __int__(self):
1354 raise NotImplementedError('int')
1355
Bram Moolenaar8600e402013-05-30 13:28:41 +02001356cb.append("> Output")
1357cb.append(">> OutputSetattr")
1358ee('del sys.stdout.softspace')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001359number_test('sys.stdout.softspace = %s', unsigned=True)
1360number_test('sys.stderr.softspace = %s', unsigned=True)
Bram Moolenaard4247472015-11-02 13:28:59 +01001361ee('assert sys.stdout.isatty()==False')
1362ee('assert sys.stdout.seekable()==False')
1363ee('sys.stdout.close()')
1364ee('sys.stdout.flush()')
1365ee('assert sys.stderr.isatty()==False')
1366ee('assert sys.stderr.seekable()==False')
1367ee('sys.stderr.close()')
1368ee('sys.stderr.flush()')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001369ee('sys.stdout.attr = None')
1370cb.append(">> OutputWrite")
Bram Moolenaard4247472015-11-02 13:28:59 +01001371ee('assert sys.stdout.writable()==True')
1372ee('assert sys.stdout.readable()==False')
1373ee('assert sys.stderr.writable()==True')
1374ee('assert sys.stderr.readable()==False')
Bram Moolenaar6d4431e2016-04-21 20:00:56 +02001375ee('assert sys.stdout.closed()==False')
1376ee('assert sys.stderr.closed()==False')
1377ee('assert sys.stdout.errors=="strict"')
1378ee('assert sys.stderr.errors=="strict"')
1379ee('assert sys.stdout.encoding==sys.stderr.encoding')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001380ee('sys.stdout.write(None)')
1381cb.append(">> OutputWriteLines")
1382ee('sys.stdout.writelines(None)')
1383ee('sys.stdout.writelines([1])')
1384iter_test('sys.stdout.writelines(%s)')
1385cb.append("> VimCommand")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001386stringtochars_test('vim.command(%s)')
1387ee('vim.command("", 2)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001388#! Not checked: vim->python exceptions translating: checked later
1389cb.append("> VimToPython")
1390#! Not checked: everything: needs errors in internal python functions
1391cb.append("> VimEval")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001392stringtochars_test('vim.eval(%s)')
1393ee('vim.eval("", FailingTrue())')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001394#! Not checked: everything: needs errors in internal python functions
1395cb.append("> VimEvalPy")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001396stringtochars_test('vim.bindeval(%s)')
1397ee('vim.eval("", 2)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001398#! Not checked: vim->python exceptions translating: checked later
1399cb.append("> VimStrwidth")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001400stringtochars_test('vim.strwidth(%s)')
1401cb.append("> VimForeachRTP")
1402ee('vim.foreach_rtp(None)')
1403ee('vim.foreach_rtp(NoArgsCall())')
1404ee('vim.foreach_rtp(FailingCall())')
1405ee('vim.foreach_rtp(int, 2)')
1406cb.append('> import')
1407old_rtp = vim.options['rtp']
Bram Moolenaar8110a092016-04-14 15:56:09 +02001408vim.options['rtp'] = os.getcwd().replace('\\', '\\\\').replace(',', '\\,')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001409ee('import xxx_no_such_module_xxx')
1410ee('import failing_import')
1411ee('import failing')
1412vim.options['rtp'] = old_rtp
1413del old_rtp
Bram Moolenaar1028f4d2014-01-14 16:55:00 +01001414cb.append("> Options")
1415cb.append(">> OptionsItem")
1416ee('vim.options["abcQ"]')
1417ee('vim.options[""]')
1418stringtochars_test('vim.options[%s]')
1419cb.append(">> OptionsContains")
1420stringtochars_test('%s in vim.options')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001421cb.append("> Dictionary")
1422cb.append(">> DictionaryConstructor")
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001423ee('vim.Dictionary("abcI")')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001424##! Not checked: py_dict_alloc failure
1425cb.append(">> DictionarySetattr")
1426ee('del d.locked')
1427ee('d.locked = FailingTrue()')
1428ee('vim.vvars.locked = False')
1429ee('d.scope = True')
1430ee('d.xxx = True')
1431cb.append(">> _DictionaryItem")
1432ee('d.get("a", 2, 3)')
1433stringtochars_test('d.get(%s)')
1434ee('d.pop("a")')
1435ee('dl.pop("a")')
Bram Moolenaarba2d7ff2013-11-04 00:34:53 +01001436cb.append(">> DictionaryContains")
1437ee('"" in d')
1438ee('0 in d')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001439cb.append(">> DictionaryIterNext")
1440ee('for i in ned: ned["a"] = 1')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001441del i
Bram Moolenaar8600e402013-05-30 13:28:41 +02001442cb.append(">> DictionaryAssItem")
1443ee('dl["b"] = 1')
1444stringtochars_test('d[%s] = 1')
1445convertfrompyobject_test('d["a"] = %s')
1446cb.append(">> DictionaryUpdate")
1447cb.append(">>> kwargs")
1448cb.append(">>> iter")
1449ee('d.update(FailingMapping())')
1450ee('d.update([FailingIterNext()])')
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001451ee('d.update([FailingIterNextN(1)])')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001452iter_test('d.update(%s)')
1453convertfrompyobject_test('d.update(%s)')
1454stringtochars_test('d.update(((%s, 0),))')
1455convertfrompyobject_test('d.update((("a", %s),))')
1456cb.append(">> DictionaryPopItem")
1457ee('d.popitem(1, 2)')
1458cb.append(">> DictionaryHasKey")
1459ee('d.has_key()')
1460cb.append("> List")
1461cb.append(">> ListConstructor")
1462ee('vim.List(1, 2)')
1463ee('vim.List(a=1)')
1464iter_test('vim.List(%s)')
1465convertfrompyobject_test('vim.List([%s])')
1466cb.append(">> ListItem")
1467ee('l[1000]')
1468cb.append(">> ListAssItem")
1469ee('ll[1] = 2')
1470ee('l[1000] = 3')
1471cb.append(">> ListAssSlice")
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001472ee('ll[1:100] = "abcJ"')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001473iter_test('l[:] = %s')
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001474ee('nel[1:10:2] = "abcK"')
1475cb.append(repr(tuple(nel)))
1476ee('nel[1:10:2] = "a"')
1477cb.append(repr(tuple(nel)))
1478ee('nel[1:1:-1] = "a"')
1479cb.append(repr(tuple(nel)))
1480ee('nel[:] = FailingIterNextN(2)')
1481cb.append(repr(tuple(nel)))
Bram Moolenaar8600e402013-05-30 13:28:41 +02001482convertfrompyobject_test('l[:] = [%s]')
1483cb.append(">> ListConcatInPlace")
1484iter_test('l.extend(%s)')
1485convertfrompyobject_test('l.extend([%s])')
1486cb.append(">> ListSetattr")
1487ee('del l.locked')
1488ee('l.locked = FailingTrue()')
1489ee('l.xxx = True')
1490cb.append("> Function")
1491cb.append(">> FunctionConstructor")
Bram Moolenaar8110a092016-04-14 15:56:09 +02001492cb.append(">>> FunctionConstructor")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001493ee('vim.Function("123")')
1494ee('vim.Function("xxx_non_existent_function_xxx")')
1495ee('vim.Function("xxx#non#existent#function#xxx")')
Bram Moolenaar8110a092016-04-14 15:56:09 +02001496ee('vim.Function("xxx_non_existent_function_xxx2", args=[])')
1497ee('vim.Function("xxx_non_existent_function_xxx3", self={})')
1498ee('vim.Function("xxx_non_existent_function_xxx4", args=[], self={})')
1499cb.append(">>> FunctionNew")
1500ee('vim.Function("tr", self="abcFuncSelf")')
1501ee('vim.Function("tr", args=427423)')
1502ee('vim.Function("tr", self="abcFuncSelf2", args="abcFuncArgs2")')
1503ee('vim.Function(self="abcFuncSelf2", args="abcFuncArgs2")')
1504ee('vim.Function("tr", "", self="abcFuncSelf2", args="abcFuncArgs2")')
1505ee('vim.Function("tr", "")')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001506cb.append(">> FunctionCall")
1507convertfrompyobject_test('f(%s)')
1508convertfrompymapping_test('fd(self=%s)')
1509cb.append("> TabPage")
1510cb.append(">> TabPageAttr")
1511ee('vim.current.tabpage.xxx')
1512cb.append("> TabList")
1513cb.append(">> TabListItem")
1514ee('vim.tabpages[1000]')
1515cb.append("> Window")
1516cb.append(">> WindowAttr")
1517ee('vim.current.window.xxx')
1518cb.append(">> WindowSetattr")
1519ee('vim.current.window.buffer = 0')
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001520ee('vim.current.window.cursor = (100000000, 100000000)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001521ee('vim.current.window.cursor = True')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001522number_test('vim.current.window.height = %s', unsigned=True)
1523number_test('vim.current.window.width = %s', unsigned=True)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001524ee('vim.current.window.xxxxxx = True')
1525cb.append("> WinList")
1526cb.append(">> WinListItem")
1527ee('vim.windows[1000]')
1528cb.append("> Buffer")
1529cb.append(">> StringToLine (indirect)")
1530ee('vim.current.buffer[0] = "\\na"')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001531ee('vim.current.buffer[0] = b"\\na"')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001532cb.append(">> SetBufferLine (indirect)")
1533ee('vim.current.buffer[0] = True')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001534cb.append(">> SetBufferLineList (indirect)")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001535ee('vim.current.buffer[:] = True')
1536ee('vim.current.buffer[:] = ["\\na", "bc"]')
1537cb.append(">> InsertBufferLines (indirect)")
1538ee('vim.current.buffer.append(None)')
1539ee('vim.current.buffer.append(["\\na", "bc"])')
1540ee('vim.current.buffer.append("\\nbc")')
1541cb.append(">> RBItem")
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001542ee('vim.current.buffer[100000000]')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001543cb.append(">> RBAsItem")
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001544ee('vim.current.buffer[100000000] = ""')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001545cb.append(">> BufferAttr")
1546ee('vim.current.buffer.xxx')
1547cb.append(">> BufferSetattr")
1548ee('vim.current.buffer.name = True')
1549ee('vim.current.buffer.xxx = True')
1550cb.append(">> BufferMark")
1551ee('vim.current.buffer.mark(0)')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001552ee('vim.current.buffer.mark("abcM")')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001553ee('vim.current.buffer.mark("!")')
1554cb.append(">> BufferRange")
1555ee('vim.current.buffer.range(1, 2, 3)')
1556cb.append("> BufMap")
1557cb.append(">> BufMapItem")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001558ee('vim.buffers[100000000]')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001559number_test('vim.buffers[%s]', natural=True)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001560cb.append("> Current")
1561cb.append(">> CurrentGetattr")
1562ee('vim.current.xxx')
1563cb.append(">> CurrentSetattr")
1564ee('vim.current.line = True')
1565ee('vim.current.buffer = True')
1566ee('vim.current.window = True')
1567ee('vim.current.tabpage = True')
1568ee('vim.current.xxx = True')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001569del d
1570del ned
1571del dl
1572del l
1573del ll
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001574del nel
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001575del f
1576del fd
1577del fdel
1578del subexpr_test
1579del stringtochars_test
1580del Mapping
1581del convertfrompyobject_test
1582del convertfrompymapping_test
1583del iter_test
Bram Moolenaardee2e312013-06-23 16:35:47 +02001584del number_test
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001585del FailingTrue
1586del FailingIter
1587del FailingIterNext
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001588del FailingIterNextN
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001589del FailingMapping
1590del FailingMappingKey
1591del FailingList
Bram Moolenaardee2e312013-06-23 16:35:47 +02001592del NoArgsCall
1593del FailingCall
1594del FailingNumber
Bram Moolenaar8600e402013-05-30 13:28:41 +02001595EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001596:delfunction F
Bram Moolenaar8600e402013-05-30 13:28:41 +02001597:"
Bram Moolenaara9f22202013-06-11 18:48:21 +02001598:" Test import
1599py3 << EOF
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001600sys.path.insert(0, os.path.join(os.getcwd(), 'python_before'))
1601sys.path.append(os.path.join(os.getcwd(), 'python_after'))
Bram Moolenaara9f22202013-06-11 18:48:21 +02001602vim.options['rtp'] = os.getcwd().replace(',', '\\,').replace('\\', '\\\\')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001603l = []
1604def callback(path):
1605 l.append(os.path.relpath(path))
1606vim.foreach_rtp(callback)
1607cb.append(repr(l))
1608del l
1609def callback(path):
1610 return os.path.relpath(path)
1611cb.append(repr(vim.foreach_rtp(callback)))
1612del callback
Bram Moolenaara9f22202013-06-11 18:48:21 +02001613from module import dir as d
1614from modulex import ddir
1615cb.append(d + ',' + ddir)
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001616import before
1617cb.append(before.dir)
1618import after
1619cb.append(after.dir)
Bram Moolenaardee2e312013-06-23 16:35:47 +02001620import topmodule as tm
1621import topmodule.submodule as tms
1622import topmodule.submodule.subsubmodule.subsubsubmodule as tmsss
Bram Moolenaar877aa002013-06-26 21:49:51 +02001623cb.append(tm.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/__init__.py'):])
1624cb.append(tms.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/submodule/__init__.py'):])
1625cb.append(tmsss.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/submodule/subsubmodule/subsubsubmodule.py'):])
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001626del before
1627del after
1628del d
1629del ddir
Bram Moolenaardee2e312013-06-23 16:35:47 +02001630del tm
1631del tms
1632del tmsss
Bram Moolenaara9f22202013-06-11 18:48:21 +02001633EOF
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001634:"
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001635:" Test exceptions
1636:fun Exe(e)
1637: execute a:e
1638:endfun
1639py3 << EOF
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001640Exe = vim.bindeval('function("Exe")')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001641ee('vim.command("throw \'abcN\'")')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001642ee('Exe("throw \'def\'")')
1643ee('vim.eval("Exe(\'throw \'\'ghi\'\'\')")')
1644ee('vim.eval("Exe(\'echoerr \'\'jkl\'\'\')")')
1645ee('vim.eval("Exe(\'xxx_non_existent_command_xxx\')")')
Bram Moolenaar9fee7d42013-11-28 17:04:43 +01001646ee('vim.eval("xxx_unknown_function_xxx()")')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001647ee('vim.bindeval("Exe(\'xxx_non_existent_command_xxx\')")')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001648del Exe
1649EOF
1650:delfunction Exe
1651:"
Bram Moolenaard6b8a522013-11-11 01:05:48 +01001652:" Regression: interrupting vim.command propagates to next vim.command
1653py3 << EOF
1654def test_keyboard_interrupt():
1655 try:
1656 vim.command('while 1 | endwhile')
1657 except KeyboardInterrupt:
1658 cb.append('Caught KeyboardInterrupt')
Bram Moolenaar8110a092016-04-14 15:56:09 +02001659 except Exception:
1660 cb.append('!!!!!!!! Caught exception: ' + emsg(sys.exc_info()))
Bram Moolenaard6b8a522013-11-11 01:05:48 +01001661 else:
1662 cb.append('!!!!!!!! No exception')
1663 try:
1664 vim.command('$ put =\'Running :put\'')
1665 except KeyboardInterrupt:
1666 cb.append('!!!!!!!! Caught KeyboardInterrupt')
Bram Moolenaar8110a092016-04-14 15:56:09 +02001667 except Exception:
1668 cb.append('!!!!!!!! Caught exception: ' + emsg(sys.exc_info()))
Bram Moolenaard6b8a522013-11-11 01:05:48 +01001669 else:
1670 cb.append('No exception')
1671EOF
1672:debuggreedy
1673:call inputsave()
1674:call feedkeys("s\ns\ns\ns\nq\n")
1675:redir => output
1676:debug silent! py3 test_keyboard_interrupt()
1677:redir END
1678:0 debuggreedy
Bram Moolenaar56f62272014-09-29 18:08:59 +02001679:call inputrestore()
Bram Moolenaard6b8a522013-11-11 01:05:48 +01001680:silent $put =output
1681:unlet output
1682:py3 del test_keyboard_interrupt
1683:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001684:" Cleanup
1685py3 << EOF
1686del cb
1687del ee
Bram Moolenaar8110a092016-04-14 15:56:09 +02001688del emsg
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001689del sys
1690del os
1691del vim
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001692EOF
Bram Moolenaardb913952012-06-29 12:54:53 +02001693:endfun
1694:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001695:fun RunTest()
1696:let checkrefs = !empty($PYTHONDUMPREFS)
1697:let start = getline(1, '$')
1698:for i in range(checkrefs ? 10 : 1)
1699: if i != 0
1700: %d _
1701: call setline(1, start)
1702: endif
1703: call Test()
1704: if i == 0
1705: let result = getline(1, '$')
1706: endif
1707:endfor
1708:if checkrefs
1709: %d _
1710: call setline(1, result)
1711:endif
1712:endfun
Bram Moolenaardb913952012-06-29 12:54:53 +02001713:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001714:call RunTest()
1715:delfunction RunTest
1716:delfunction Test
Bram Moolenaardb913952012-06-29 12:54:53 +02001717:call garbagecollect(1)
1718:"
1719:/^start:/,$wq! test.out
Bram Moolenaar8110a092016-04-14 15:56:09 +02001720:/^start:/,$w! test.out
Bram Moolenaardee2e312013-06-23 16:35:47 +02001721:" vim: et ts=4 isk-=\:
Bram Moolenaar8110a092016-04-14 15:56:09 +02001722:while getchar(0) isnot 0|endwhile
Bram Moolenaardb913952012-06-29 12:54:53 +02001723ENDTEST
1724
1725start: