blob: 79b24b00dedaae056362bc4bd391aae7b6f10364 [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 Moolenaardb913952012-06-29 12:54:53 +02006:if !has('python3') | 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 Moolenaardb913952012-06-29 12:54:53 +020010:let l = []
11:py3 l=vim.bindeval('l')
12:py3 f=vim.bindeval('function("strlen")')
13:" Extending List directly with different types
14:py3 l+=[1, "as'd", [1, 2, f, {'a': 1}]]
15:$put =string(l)
16:$put =string(l[-1])
17:try
18: $put =string(l[-4])
19:catch
20: $put =v:exception[:13]
21:endtry
22:" List assignment
23:py3 l[0]=0
24:$put =string(l)
25:py3 l[-2]=f
26:$put =string(l)
27:"
28:" Extending Dictionary directly with different types
29:let d = {}
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020030:fun d.f()
31: return 1
32:endfun
Bram Moolenaara9922d62013-05-30 13:01:18 +020033py3 << EOF
34d=vim.bindeval('d')
35d['1']='asd'
36d.update(b=[1, 2, f])
37d.update((('-1', {'a': 1}),))
38d.update({'0': -1})
39dk = d.keys()
40dv = d.values()
41di = d.items()
42dk.sort(key=repr)
43dv.sort(key=repr)
44di.sort(key=repr)
45EOF
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020046:$put =py3eval('d[''f''](self={})')
Bram Moolenaara9922d62013-05-30 13:01:18 +020047:$put =py3eval('repr(dk)')
48:$put =substitute(py3eval('repr(dv)'),'0x\x\+','','g')
49:$put =substitute(py3eval('repr(di)'),'0x\x\+','','g')
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020050:for [key, Val] in sort(items(d))
51: $put =string(key) . ' : ' . string(Val)
52: unlet key Val
Bram Moolenaardb913952012-06-29 12:54:53 +020053:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +020054:py3 del dk
55:py3 del di
56:py3 del dv
Bram Moolenaardb913952012-06-29 12:54:53 +020057:"
58:" removing items with del
59:py3 del l[2]
60:$put =string(l)
61:let l = range(8)
62:py3 l=vim.bindeval('l')
63:try
64: py3 del l[:3]
65: py3 del l[1:]
66:catch
67: $put =v:exception
68:endtry
69:$put =string(l)
70:"
71:py3 del d['-1']
Bram Moolenaar355fd9b2013-05-30 13:14:13 +020072:py3 del d['f']
Bram Moolenaara9922d62013-05-30 13:01:18 +020073:$put =string(py3eval('d.get(''b'', 1)'))
74:$put =string(py3eval('d.pop(''b'')'))
75:$put =string(py3eval('d.get(''b'', 1)'))
76:$put =string(py3eval('d.pop(''1'', 2)'))
77:$put =string(py3eval('d.pop(''1'', 2)'))
78:$put =py3eval('repr(d.has_key(''0''))')
79:$put =py3eval('repr(d.has_key(''1''))')
80:$put =py3eval('repr(''0'' in d)')
81:$put =py3eval('repr(''1'' in d)')
82:$put =py3eval('repr(list(iter(d)))')
Bram Moolenaardb913952012-06-29 12:54:53 +020083:$put =string(d)
Bram Moolenaarde71b562013-06-02 17:41:54 +020084:$put =py3eval('repr(d.popitem())')
Bram Moolenaara9922d62013-05-30 13:01:18 +020085:$put =py3eval('repr(d.get(''0''))')
86:$put =py3eval('repr(list(iter(d)))')
Bram Moolenaardb913952012-06-29 12:54:53 +020087:"
88:" removing items out of range: silently skip items that don't exist
89:let l = [0, 1, 2, 3]
90:py3 l=vim.bindeval('l')
91:" The following two ranges delete nothing as they match empty list:
92:py3 del l[2:1]
93:$put =string(l)
94:py3 del l[2:2]
95:$put =string(l)
96:py3 del l[2:3]
97:$put =string(l)
98:let l = [0, 1, 2, 3]
99:py3 l=vim.bindeval('l')
100:py3 del l[2:4]
101:$put =string(l)
102:let l = [0, 1, 2, 3]
103:py3 l=vim.bindeval('l')
104:py3 del l[2:5]
105:$put =string(l)
106:let l = [0, 1, 2, 3]
107:py3 l=vim.bindeval('l')
108:py3 del l[2:6]
109:$put =string(l)
110:let l = [0, 1, 2, 3]
111:py3 l=vim.bindeval('l')
112:" The following two ranges delete nothing as they match empty list:
113:py3 del l[-1:2]
114:$put =string(l)
115:py3 del l[-2:2]
116:$put =string(l)
117:py3 del l[-3:2]
118:$put =string(l)
119:let l = [0, 1, 2, 3]
120:py3 l=vim.bindeval('l')
121:py3 del l[-4:2]
122:$put =string(l)
123:let l = [0, 1, 2, 3]
124:py3 l=vim.bindeval('l')
125:py3 del l[-5:2]
126:$put =string(l)
127:let l = [0, 1, 2, 3]
128:py3 l=vim.bindeval('l')
129:py3 del l[-6:2]
130:$put =string(l)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100131:let l = [0, 1, 2, 3]
132:py3 l=vim.bindeval('l')
133:py3 del l[::2]
134:$put =string(l)
135:let l = [0, 1, 2, 3]
136:py3 l=vim.bindeval('l')
137:py3 del l[3:0:-2]
138:$put =string(l)
139:let l = [0, 1, 2, 3]
140:py3 l=vim.bindeval('l')
141:py3 del l[2:4:-2]
142:$put =string(l)
Bram Moolenaardb913952012-06-29 12:54:53 +0200143:"
144:" Slice assignment to a list
145:let l = [0, 1, 2, 3]
146:py3 l=vim.bindeval('l')
147:py3 l[0:0]=['a']
148:$put =string(l)
149:let l = [0, 1, 2, 3]
150:py3 l=vim.bindeval('l')
151:py3 l[1:2]=['b']
152:$put =string(l)
153:let l = [0, 1, 2, 3]
154:py3 l=vim.bindeval('l')
155:py3 l[2:4]=['c']
156:$put =string(l)
157:let l = [0, 1, 2, 3]
158:py3 l=vim.bindeval('l')
159:py3 l[4:4]=['d']
160:$put =string(l)
161:let l = [0, 1, 2, 3]
162:py3 l=vim.bindeval('l')
163:py3 l[-1:2]=['e']
164:$put =string(l)
165:let l = [0, 1, 2, 3]
166:py3 l=vim.bindeval('l')
167:py3 l[-10:2]=['f']
168:$put =string(l)
169:let l = [0, 1, 2, 3]
170:py3 l=vim.bindeval('l')
171:py3 l[2:-10]=['g']
172:$put =string(l)
173:let l = []
174:py3 l=vim.bindeval('l')
175:py3 l[0:0]=['h']
176:$put =string(l)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100177:let l = range(8)
178:py3 l=vim.bindeval('l')
179:py3 l[2:6:2] = [10, 20]
180:$put =string(l)
181:let l = range(8)
182:py3 l=vim.bindeval('l')
183:py3 l[6:2:-2] = [10, 20]
184:$put =string(l)
185:let l = range(8)
186:py3 l=vim.bindeval('l')
187:py3 l[6:2] = ()
188:$put =string(l)
189:let l = range(8)
190:py3 l=vim.bindeval('l')
191:py3 l[6:2:1] = ()
192:$put =string(l)
193:let l = range(8)
194:py3 l=vim.bindeval('l')
195:py3 l[2:2:1] = ()
196:$put =string(l)
Bram Moolenaardb913952012-06-29 12:54:53 +0200197:"
198:" Locked variables
199:let l = [0, 1, 2, 3]
200:py3 l=vim.bindeval('l')
201:lockvar! l
202:py3 l[2]='i'
203:$put =string(l)
204:unlockvar! l
205:"
206:" Function calls
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100207py3 << EOF
208import sys
209import re
210
211py33_type_error_pattern = re.compile('^__call__\(\) takes (\d+) positional argument but (\d+) were given$')
212
213def ee(expr, g=globals(), l=locals()):
214 cb = vim.current.buffer
215 try:
216 try:
217 exec(expr, g, l)
218 except Exception as e:
219 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."):
220 cb.append(expr + ':' + repr((e.__class__, AttributeError(str(e)[str(e).rfind(" '") + 2:-1]))))
221 elif sys.version_info >= (3, 3) and e.__class__ is ImportError and str(e).find('No module named \'') >= 0:
222 cb.append(expr + ':' + repr((e.__class__, ImportError(str(e).replace("'", '')))))
223 elif sys.version_info >= (3, 3) and e.__class__ is TypeError:
224 m = py33_type_error_pattern.search(str(e))
225 if m:
226 msg = '__call__() takes exactly {0} positional argument ({1} given)'.format(m.group(1), m.group(2))
227 cb.append(expr + ':' + repr((e.__class__, TypeError(msg))))
228 else:
229 cb.append(expr + ':' + repr((e.__class__, e)))
230 else:
231 cb.append(expr + ':' + repr((e.__class__, e)))
232 else:
233 cb.append(expr + ':NOT FAILED')
234 except Exception as e:
235 cb.append(expr + '::' + repr((e.__class__, e)))
236EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200237:fun New(...)
238: return ['NewStart']+a:000+['NewEnd']
239:endfun
240:fun DictNew(...) dict
241: return ['DictNewStart']+a:000+['DictNewEnd', self]
242:endfun
Bram Moolenaardb913952012-06-29 12:54:53 +0200243:let l=[function('New'), function('DictNew')]
244:py3 l=vim.bindeval('l')
245:py3 l.extend(list(l[0](1, 2, 3)))
246:$put =string(l)
247:py3 l.extend(list(l[1](1, 2, 3, self={'a': 'b'})))
248:$put =string(l)
249:py3 l+=[l[0].name]
250:$put =string(l)
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100251:py3 ee('l[1](1, 2, 3)')
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200252:py3 f=l[0]
Bram Moolenaardb913952012-06-29 12:54:53 +0200253:delfunction New
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100254:py3 ee('f(1, 2, 3)')
Bram Moolenaardb913952012-06-29 12:54:53 +0200255:if has('float')
256: let l=[0.0]
257: py3 l=vim.bindeval('l')
258: py3 l.extend([0.0])
259: $put =string(l)
260:else
261: $put ='[0.0, 0.0]'
262:endif
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200263:let messages=[]
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200264:delfunction DictNew
265py3 <<EOF
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200266d=vim.bindeval('{}')
267m=vim.bindeval('messages')
Bram Moolenaara9922d62013-05-30 13:01:18 +0200268def em(expr, g=globals(), l=locals()):
269 try:
270 exec(expr, g, l)
271 except Exception as e:
272 m.extend([e.__class__.__name__])
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200273
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200274em('d["abc1"]')
275em('d["abc1"]="\\0"')
276em('d["abc1"]=vim')
Bram Moolenaara9922d62013-05-30 13:01:18 +0200277em('d[""]=1')
278em('d["a\\0b"]=1')
279em('d[b"a\\0b"]=1')
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200280
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200281em('d.pop("abc1")')
Bram Moolenaarde71b562013-06-02 17:41:54 +0200282em('d.popitem()')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200283del em
284del m
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200285EOF
286:$put =messages
Bram Moolenaar66b79852012-09-21 14:00:35 +0200287:unlet messages
288:" locked and scope attributes
289:let d={} | let dl={} | lockvar dl
290:for s in split("d dl v: g:")
291: let name=tr(s, ':', 's')
292: execute 'py3 '.name.'=vim.bindeval("'.s.'")'
293: let toput=s.' : '.join(map(['locked', 'scope'], 'v:val.":".py3eval(name.".".v:val)'), ';')
294: $put =toput
295:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200296:silent! let d.abc2=1
297:silent! let dl.abc3=1
Bram Moolenaar66b79852012-09-21 14:00:35 +0200298:py3 d.locked=True
299:py3 dl.locked=False
300:silent! let d.def=1
301:silent! let dl.def=1
302:put ='d:'.string(d)
303:put ='dl:'.string(dl)
304:unlet d dl
305:
306:let l=[] | let ll=[] | lockvar ll
307:for s in split("l ll")
308: let name=tr(s, ':', 's')
309: execute 'py3 '.name.'=vim.bindeval("'.s.'")'
310: let toput=s.' : locked:'.py3eval(name.'.locked')
311: $put =toput
312:endfor
313:silent! call extend(l, [0])
314:silent! call extend(ll, [0])
315:py3 l.locked=True
316:py3 ll.locked=False
317:silent! call extend(l, [1])
318:silent! call extend(ll, [1])
319:put ='l:'.string(l)
320:put ='ll:'.string(ll)
321:unlet l ll
Bram Moolenaardb913952012-06-29 12:54:53 +0200322:"
323:" py3eval()
324:let l=py3eval('[0, 1, 2]')
325:$put =string(l)
326:let d=py3eval('{"a": "b", "c": 1, "d": ["e"]}')
327:$put =sort(items(d))
Bram Moolenaardb913952012-06-29 12:54:53 +0200328:if has('float')
329: let f=py3eval('0.0')
330: $put =string(f)
331:else
332: $put ='0.0'
333:endif
Bram Moolenaarc11073c2012-09-05 19:17:42 +0200334:" Invalid values:
335:for e in ['"\0"', '{"\0": 1}', 'undefined_name', 'vim']
336: try
337: let v=py3eval(e)
338: catch
339: let toput=e.":\t".v:exception[:13]
340: $put =toput
341: endtry
342:endfor
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100343:"
344:" threading
345:let l = [0]
346:py3 l=vim.bindeval('l')
Bram Moolenaardee2e312013-06-23 16:35:47 +0200347py3 <<EOF
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100348import threading
349import time
350
351class T(threading.Thread):
352 def __init__(self):
353 threading.Thread.__init__(self)
354 self.t = 0
355 self.running = True
356
357 def run(self):
358 while self.running:
359 self.t += 1
360 time.sleep(0.1)
361
362t = T()
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200363del T
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100364t.start()
365EOF
366:sleep 1
367:py3 t.running = False
368:py3 t.join()
369:py3 l[0] = t.t > 8 # check if the background thread is working
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200370:py3 del time
371:py3 del threading
Bram Moolenaar9fee7d42013-11-28 17:04:43 +0100372:py3 del t
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100373:$put =string(l)
374:"
375:" settrace
376:let l = []
377:py3 l=vim.bindeval('l')
Bram Moolenaardee2e312013-06-23 16:35:47 +0200378py3 <<EOF
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100379import sys
380
381def traceit(frame, event, arg):
382 global l
383 if event == "line":
384 l += [frame.f_lineno]
385 return traceit
386
387def trace_main():
388 for i in range(5):
389 pass
390EOF
391:py3 sys.settrace(traceit)
392:py3 trace_main()
Bram Moolenaardee2e312013-06-23 16:35:47 +0200393:py3 sys.settrace(None)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200394:py3 del traceit
395:py3 del trace_main
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100396:$put =string(l)
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200397:"
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100398:" Slice
399:py3 ll = vim.bindeval('[0, 1, 2, 3, 4, 5]')
400:py3 l = ll[:4]
401:$put =string(py3eval('l'))
402:py3 l = ll[2:]
403:$put =string(py3eval('l'))
404:py3 l = ll[:-4]
405:$put =string(py3eval('l'))
406:py3 l = ll[-2:]
407:$put =string(py3eval('l'))
408:py3 l = ll[2:4]
409:$put =string(py3eval('l'))
410:py3 l = ll[4:2]
411:$put =string(py3eval('l'))
412:py3 l = ll[-4:-2]
413:$put =string(py3eval('l'))
414:py3 l = ll[-2:-4]
415:$put =string(py3eval('l'))
416:py3 l = ll[:]
417:$put =string(py3eval('l'))
418:py3 l = ll[0:6]
419:$put =string(py3eval('l'))
420:py3 l = ll[-10:10]
421:$put =string(py3eval('l'))
422:py3 l = ll[4:2:-1]
423:$put =string(py3eval('l'))
424:py3 l = ll[::2]
425:$put =string(py3eval('l'))
426:py3 l = ll[4:2:1]
427:$put =string(py3eval('l'))
428:py3 del l
429:"
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200430:" Vars
431:let g:foo = 'bac'
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200432:let w:abc3 = 'def'
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200433:let b:baz = 'bar'
Bram Moolenaara4720012013-05-15 16:27:37 +0200434:let t:bar = 'jkl'
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200435:try
436: throw "Abc"
437:catch
438: put =py3eval('vim.vvars[''exception'']')
439:endtry
440:put =py3eval('vim.vars[''foo'']')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200441:put =py3eval('vim.current.window.vars[''abc3'']')
Bram Moolenaar230bb3f2013-04-24 14:07:45 +0200442:put =py3eval('vim.current.buffer.vars[''baz'']')
Bram Moolenaara4720012013-05-15 16:27:37 +0200443:put =py3eval('vim.current.tabpage.vars[''bar'']')
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200444:"
445:" Options
446:" paste: boolean, global
447:" previewheight number, global
448:" operatorfunc: string, global
449:" number: boolean, window-local
450:" numberwidth: number, window-local
451:" colorcolumn: string, window-local
452:" statusline: string, window-local/global
453:" autoindent: boolean, buffer-local
Bram Moolenaar55b8ad32013-05-17 13:38:04 +0200454:" shiftwidth: number, buffer-local
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200455:" omnifunc: string, buffer-local
456:" preserveindent: boolean, buffer-local/global
457:" path: string, buffer-local/global
458:let g:bufs=[bufnr('%')]
459:new
460:let g:bufs+=[bufnr('%')]
461:vnew
462:let g:bufs+=[bufnr('%')]
463:wincmd j
464:vnew
465:let g:bufs+=[bufnr('%')]
466:wincmd l
467:fun RecVars(opt)
468: let gval =string(eval('&g:'.a:opt))
469: let wvals=join(map(range(1, 4), 'v:val.":".string(getwinvar(v:val, "&".a:opt))'))
470: let bvals=join(map(copy(g:bufs), 'v:val.":".string(getbufvar(v:val, "&".a:opt))'))
471: put =' G: '.gval
472: put =' W: '.wvals
473: put =' B: '.wvals
474:endfun
475py3 << EOF
476def e(s, g=globals(), l=locals()):
477 try:
478 exec(s, g, l)
479 except Exception as e:
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200480 vim.command('return ' + repr(e.__class__.__name__))
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200481
482def ev(s, g=globals(), l=locals()):
483 try:
484 return eval(s, g, l)
485 except Exception as e:
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200486 vim.command('let exc=' + repr(e.__class__.__name__))
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200487 return 0
488EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200489:fun E(s)
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200490: python3 e(vim.eval('a:s'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200491:endfun
492:fun Ev(s)
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200493: let r=py3eval('ev(vim.eval("a:s"))')
494: if exists('exc')
495: throw exc
496: endif
497: return r
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200498:endfun
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200499:py3 gopts1=vim.options
500:py3 wopts1=vim.windows[2].options
501:py3 wopts2=vim.windows[0].options
502:py3 wopts3=vim.windows[1].options
503:py3 bopts1=vim.buffers[vim.bindeval("g:bufs")[2]].options
504:py3 bopts2=vim.buffers[vim.bindeval("g:bufs")[1]].options
505:py3 bopts3=vim.buffers[vim.bindeval("g:bufs")[0]].options
Bram Moolenaar04188112013-06-01 20:32:12 +0200506:set path=.,..,,
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200507:let lst=[]
508:let lst+=[['paste', 1, 0, 1, 2, 1, 1, 0 ]]
509:let lst+=[['previewheight', 5, 1, 6, 'a', 0, 1, 0 ]]
510:let lst+=[['operatorfunc', 'A', 'B', 'C', 2, 0, 1, 0 ]]
511:let lst+=[['number', 0, 1, 1, 0, 1, 0, 1 ]]
512:let lst+=[['numberwidth', 2, 3, 5, -100, 0, 0, 1 ]]
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200513:let lst+=[['colorcolumn', '+1', '+2', '+3', 'abc4', 0, 0, 1 ]]
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200514:let lst+=[['statusline', '1', '2', '4', 0, 0, 1, 1 ]]
515:let lst+=[['autoindent', 0, 1, 1, 2, 1, 0, 2 ]]
Bram Moolenaar55b8ad32013-05-17 13:38:04 +0200516:let lst+=[['shiftwidth', 0, 2, 1, 3, 0, 0, 2 ]]
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200517:let lst+=[['omnifunc', 'A', 'B', 'C', 1, 0, 0, 2 ]]
518:let lst+=[['preserveindent', 0, 1, 1, 2, 1, 1, 2 ]]
519:let lst+=[['path', '.,,', ',,', '.', 0, 0, 1, 2 ]]
520:for [oname, oval1, oval2, oval3, invval, bool, global, local] in lst
521: py3 oname=vim.eval('oname')
522: py3 oval1=vim.bindeval('oval1')
523: py3 oval2=vim.bindeval('oval2')
524: py3 oval3=vim.bindeval('oval3')
525: if invval is 0 || invval is 1
526: py3 invval=bool(vim.bindeval('invval'))
527: else
528: py3 invval=vim.bindeval('invval')
529: endif
530: if bool
531: py3 oval1=bool(oval1)
532: py3 oval2=bool(oval2)
533: py3 oval3=bool(oval3)
534: endif
535: put ='>>> '.oname
536: for v in ['gopts1', 'wopts1', 'bopts1']
537: try
538: put =' p/'.v.': '.Ev('repr('.v.'['''.oname.'''])')
539: catch
540: put =' p/'.v.'! '.v:exception
541: endtry
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200542: let r=E(v.'['''.oname.''']=invval')
543: if r isnot 0
544: put =' inv: '.string(invval).'! '.r
545: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200546: for vv in (v is# 'gopts1' ? [v] : [v, v[:-2].'2', v[:-2].'3'])
547: let val=substitute(vv, '^.opts', 'oval', '')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200548: let r=E(vv.'['''.oname.''']='.val)
549: if r isnot 0
550: put =' '.vv.'! '.r
551: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200552: endfor
553: endfor
554: call RecVars(oname)
555: for v in ['wopts3', 'bopts3']
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200556: let r=E('del '.v.'["'.oname.'"]')
557: if r isnot 0
558: put =' del '.v.'! '.r
559: endif
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200560: endfor
561: call RecVars(oname)
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200562:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200563:delfunction RecVars
564:delfunction E
565:delfunction Ev
566:py3 del ev
567:py3 del e
Bram Moolenaar84e0f6c2013-05-06 03:52:55 +0200568:only
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200569:for buf in g:bufs[1:]
570: execute 'bwipeout!' buf
571:endfor
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200572:py3 del gopts1
573:py3 del wopts1
574:py3 del wopts2
575:py3 del wopts3
576:py3 del bopts1
577:py3 del bopts2
578:py3 del bopts3
579:py3 del oval1
580:py3 del oval2
581:py3 del oval3
582:py3 del oname
583:py3 del invval
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200584:"
585:" Test buffer object
586:vnew
587:put ='First line'
588:put ='Second line'
589:put ='Third line'
590:1 delete _
591:py3 b=vim.current.buffer
592:wincmd w
593:mark a
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200594:augroup BUFS
595: autocmd BufFilePost * python3 cb.append(vim.eval('expand("<abuf>")') + ':BufFilePost:' + vim.eval('bufnr("%")'))
596: autocmd BufFilePre * python3 cb.append(vim.eval('expand("<abuf>")') + ':BufFilePre:' + vim.eval('bufnr("%")'))
597:augroup END
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200598py3 << EOF
599cb = vim.current.buffer
600# Tests BufferAppend and BufferItem
601cb.append(b[0])
602# Tests BufferSlice and BufferAssSlice
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200603cb.append('abc5') # Will be overwritten
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200604cb[-1:] = b[:-2]
605# Test BufferLength and BufferAssSlice
606cb.append('def') # Will not be overwritten
607cb[len(cb):] = b[:]
608# Test BufferAssItem and BufferMark
609cb.append('ghi') # Will be overwritten
610cb[-1] = repr((len(cb) - cb.mark('a')[0], cb.mark('a')[1]))
611# Test BufferRepr
612cb.append(repr(cb) + repr(b))
613# Modify foreign buffer
614b.append('foo')
615b[0]='bar'
616b[0:0]=['baz']
617vim.command('call append("$", getbufline(%i, 1, "$"))' % b.number)
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200618# Test assigning to name property
Bram Moolenaar04188112013-06-01 20:32:12 +0200619import os
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200620old_name = cb.name
621cb.name = 'foo'
Bram Moolenaar04188112013-06-01 20:32:12 +0200622cb.append(cb.name[-11:].replace(os.path.sep, '/'))
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200623b.name = 'bar'
Bram Moolenaar04188112013-06-01 20:32:12 +0200624cb.append(b.name[-11:].replace(os.path.sep, '/'))
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200625cb.name = old_name
Bram Moolenaar04188112013-06-01 20:32:12 +0200626cb.append(cb.name[-17:].replace(os.path.sep, '/'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200627del old_name
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200628# Test CheckBuffer
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200629for _b in vim.buffers:
630 if _b is not cb:
631 vim.command('bwipeout! ' + str(_b.number))
632del _b
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200633cb.append('valid: b:%s, cb:%s' % (repr(b.valid), repr(cb.valid)))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200634for expr in ('b[1]','b[:] = ["A", "B"]','b[:]','b.append("abc6")'):
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200635 try:
636 exec(expr)
637 except vim.error:
638 pass
639 else:
640 # Usually a SEGV here
641 # Should not happen in any case
642 cb.append('No exception for ' + expr)
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200643vim.command('cd .')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200644del b
Bram Moolenaarbd80f352013-05-12 21:16:23 +0200645EOF
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200646:"
647:" Test vim.buffers object
648:set hidden
649:edit a
650:buffer #
651:edit b
652:buffer #
653:edit c
654:buffer #
655py3 << EOF
656# Check GCing iterator that was not fully exhausted
657i = iter(vim.buffers)
658cb.append('i:' + str(next(i)))
659# and also check creating more then one iterator at a time
660i2 = iter(vim.buffers)
661cb.append('i2:' + str(next(i2)))
662cb.append('i:' + str(next(i)))
663# The following should trigger GC and not cause any problems
664del i
665del i2
666i3 = iter(vim.buffers)
667cb.append('i3:' + str(next(i3)))
668del i3
669
670prevnum = 0
671for b in vim.buffers:
672 # Check buffer order
673 if prevnum >= b.number:
674 cb.append('!!! Buffer numbers not in strictly ascending order')
675 # Check indexing: vim.buffers[number].number == number
676 cb.append(str(b.number) + ':' + repr(vim.buffers[b.number]) + '=' + repr(b))
677 prevnum = b.number
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200678del prevnum
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200679
680cb.append(str(len(vim.buffers)))
681
682bnums = list(map(lambda b: b.number, vim.buffers))[1:]
683
684# Test wiping out buffer with existing iterator
685i4 = iter(vim.buffers)
686cb.append('i4:' + str(next(i4)))
687vim.command('bwipeout! ' + str(bnums.pop(0)))
688try:
689 next(i4)
690except vim.error:
691 pass
692else:
693 cb.append('!!!! No vim.error')
694i4 = iter(vim.buffers)
695vim.command('bwipeout! ' + str(bnums.pop(-1)))
696vim.command('bwipeout! ' + str(bnums.pop(-1)))
697cb.append('i4:' + str(next(i4)))
698try:
699 next(i4)
700except StopIteration:
701 cb.append('StopIteration')
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200702del i4
703del bnums
Bram Moolenaarb6c589a2013-05-15 14:39:52 +0200704EOF
Bram Moolenaara4720012013-05-15 16:27:37 +0200705:"
706:" Test vim.{tabpage,window}list and vim.{tabpage,window} objects
707:tabnew 0
708:tabnew 1
709:vnew a.1
710:tabnew 2
711:vnew a.2
712:vnew b.2
713:vnew c.2
714py3 << EOF
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200715cb.append('Number of tabs: ' + str(len(vim.tabpages)))
716cb.append('Current tab pages:')
717
Bram Moolenaara4720012013-05-15 16:27:37 +0200718def W(w):
719 if '(unknown)' in repr(w):
720 return '<window object (unknown)>'
721 else:
722 return repr(w)
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200723
724def Cursor(w, start=len(cb)):
725 if w.buffer is cb:
726 return repr((start - w.cursor[0], w.cursor[1]))
727 else:
728 return repr(w.cursor)
729
Bram Moolenaara4720012013-05-15 16:27:37 +0200730for t in vim.tabpages:
731 cb.append(' ' + repr(t) + '(' + str(t.number) + ')' + ': ' + str(len(t.windows)) + ' windows, current is ' + W(t.window))
732 cb.append(' Windows:')
733 for w in t.windows:
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200734 cb.append(' ' + W(w) + '(' + str(w.number) + ')' + ': displays buffer ' + repr(w.buffer) + '; cursor is at ' + Cursor(w))
Bram Moolenaara4720012013-05-15 16:27:37 +0200735 # Other values depend on the size of the terminal, so they are checked partly:
736 for attr in ('height', 'row', 'width', 'col'):
737 try:
738 aval = getattr(w, attr)
739 if type(aval) is not int:
740 raise TypeError
741 if aval < 0:
742 raise ValueError
743 except Exception as e:
744 cb.append('!!!!!! Error while getting attribute ' + attr + ': ' + e.__class__.__name__)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200745 del aval
746 del attr
Bram Moolenaara4720012013-05-15 16:27:37 +0200747 w.cursor = (len(w.buffer), 0)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200748del W
749del Cursor
Bram Moolenaara4720012013-05-15 16:27:37 +0200750cb.append('Number of windows in current tab page: ' + str(len(vim.windows)))
751if list(vim.windows) != list(vim.current.tabpage.windows):
752 cb.append('!!!!!! Windows differ')
753EOF
754:"
755:" Test vim.current
756py3 << EOF
757def H(o):
758 return repr(o)
759cb.append('Current tab page: ' + repr(vim.current.tabpage))
760cb.append('Current window: ' + repr(vim.current.window) + ': ' + H(vim.current.window) + ' is ' + H(vim.current.tabpage.window))
761cb.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 +0200762del H
Bram Moolenaara4720012013-05-15 16:27:37 +0200763# Assigning: fails
764try:
765 vim.current.window = vim.tabpages[0].window
766except ValueError:
767 cb.append('ValueError at assigning foreign tab window')
768
769for attr in ('window', 'tabpage', 'buffer'):
770 try:
771 setattr(vim.current, attr, None)
772 except TypeError:
773 cb.append('Type error at assigning None to vim.current.' + attr)
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200774del attr
Bram Moolenaara4720012013-05-15 16:27:37 +0200775
776# Assigning: success
777vim.current.tabpage = vim.tabpages[-2]
778vim.current.buffer = cb
779vim.current.window = vim.windows[0]
780vim.current.window.cursor = (len(vim.current.buffer), 0)
781cb.append('Current tab page: ' + repr(vim.current.tabpage))
782cb.append('Current window: ' + repr(vim.current.window))
783cb.append('Current buffer: ' + repr(vim.current.buffer))
784cb.append('Current line: ' + repr(vim.current.line))
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200785ws = list(vim.windows)
786ts = list(vim.tabpages)
Bram Moolenaara4720012013-05-15 16:27:37 +0200787for b in vim.buffers:
788 if b is not cb:
789 vim.command('bwipeout! ' + str(b.number))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200790del b
Bram Moolenaar9e822c02013-05-29 22:15:30 +0200791cb.append('w.valid: ' + repr([w.valid for w in ws]))
792cb.append('t.valid: ' + repr([t.valid for t in ts]))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200793del w
794del t
795del ts
796del ws
Bram Moolenaara4720012013-05-15 16:27:37 +0200797EOF
798:tabonly!
799:only!
Bram Moolenaarcac867a2013-05-21 19:50:34 +0200800:"
801:" Test types
802py3 << EOF
803for expr, attr in (
804 ('vim.vars', 'Dictionary'),
805 ('vim.options', 'Options'),
806 ('vim.bindeval("{}")', 'Dictionary'),
807 ('vim.bindeval("[]")', 'List'),
808 ('vim.bindeval("function(\'tr\')")', 'Function'),
809 ('vim.current.buffer', 'Buffer'),
810 ('vim.current.range', 'Range'),
811 ('vim.current.window', 'Window'),
812 ('vim.current.tabpage', 'TabPage'),
813):
814 cb.append(expr + ':' + attr + ':' + repr(type(eval(expr)) is getattr(vim, attr)))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200815del expr
816del attr
Bram Moolenaarcac867a2013-05-21 19:50:34 +0200817EOF
Bram Moolenaara7b64ce2013-05-21 20:40:40 +0200818:"
Bram Moolenaardd8aca62013-05-29 22:36:10 +0200819:" Test __dir__() method
820py3 << EOF
821for name, o in (
822 ('current', vim.current),
823 ('buffer', vim.current.buffer),
824 ('window', vim.current.window),
825 ('tabpage', vim.current.tabpage),
826 ('range', vim.current.range),
827 ('dictionary', vim.bindeval('{}')),
828 ('list', vim.bindeval('[]')),
829 ('function', vim.bindeval('function("tr")')),
830 ('output', sys.stdout),
831 ):
832 cb.append(name + ':' + ','.join(dir(o)))
833del name
834del o
835EOF
836:"
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200837:" Test vim.*.__new__
Bram Moolenaara9922d62013-05-30 13:01:18 +0200838:$put =string(py3eval('vim.Dictionary({})'))
839:$put =string(py3eval('vim.Dictionary(a=1)'))
840:$put =string(py3eval('vim.Dictionary(((''a'', 1),))'))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200841:$put =string(py3eval('vim.List()'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200842:$put =string(py3eval('vim.List(iter(''abc7''))'))
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200843:$put =string(py3eval('vim.Function(''tr'')'))
Bram Moolenaar01a7a722013-05-30 12:26:58 +0200844:"
845:" Test stdout/stderr
846:redir => messages
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200847:py3 sys.stdout.write('abc8') ; sys.stdout.write('def')
848:py3 sys.stderr.write('abc9') ; sys.stderr.write('def')
849:py3 sys.stdout.writelines(iter('abcA'))
850:py3 sys.stderr.writelines(iter('abcB'))
Bram Moolenaar01a7a722013-05-30 12:26:58 +0200851:redir END
852:$put =string(substitute(messages, '\d\+', '', 'g'))
Bram Moolenaara9922d62013-05-30 13:01:18 +0200853:" Test subclassing
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200854:fun Put(...)
855: $put =string(a:000)
856: return a:000
857:endfun
Bram Moolenaara9922d62013-05-30 13:01:18 +0200858py3 << EOF
859class DupDict(vim.Dictionary):
860 def __setitem__(self, key, value):
861 super(DupDict, self).__setitem__(key, value)
862 super(DupDict, self).__setitem__('dup_' + key, value)
863dd = DupDict()
864dd['a'] = 'b'
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200865
866class DupList(vim.List):
867 def __getitem__(self, idx):
868 return [super(DupList, self).__getitem__(idx)] * 2
869
870dl = DupList()
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200871dl2 = DupList(iter('abcC'))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200872dl.extend(dl2[0])
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200873
874class DupFun(vim.Function):
875 def __call__(self, arg):
876 return super(DupFun, self).__call__(arg, arg)
877
878df = DupFun('Put')
Bram Moolenaara9922d62013-05-30 13:01:18 +0200879EOF
880:$put =string(sort(keys(py3eval('dd'))))
Bram Moolenaar78cddbe2013-05-30 13:05:58 +0200881:$put =string(py3eval('dl'))
882:$put =string(py3eval('dl2'))
Bram Moolenaar355fd9b2013-05-30 13:14:13 +0200883:$put =string(py3eval('df(2)'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200884:$put =string(py3eval('dl') is# py3eval('dl'))
885:$put =string(py3eval('dd') is# py3eval('dd'))
886:$put =string(py3eval('df'))
887:delfunction Put
888py3 << EOF
889del DupDict
890del DupList
891del DupFun
892del dd
893del dl
894del dl2
895del df
896EOF
Bram Moolenaar01a7a722013-05-30 12:26:58 +0200897:"
Bram Moolenaarf4258302013-06-02 18:20:17 +0200898:" Test chdir
899py3 << EOF
900import os
901fnamemodify = vim.Function('fnamemodify')
902cb.append(str(fnamemodify('.', ':p:h:t')))
903cb.append(vim.eval('@%'))
904os.chdir('..')
905cb.append(str(fnamemodify('.', ':p:h:t')))
906cb.append(vim.eval('@%').replace(os.path.sep, '/'))
907os.chdir('testdir')
908cb.append(str(fnamemodify('.', ':p:h:t')))
909cb.append(vim.eval('@%'))
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200910del fnamemodify
Bram Moolenaarf4258302013-06-02 18:20:17 +0200911EOF
912:"
Bram Moolenaar8600e402013-05-30 13:28:41 +0200913:" Test errors
914:fun F() dict
915:endfun
916:fun D()
917:endfun
918py3 << EOF
Bram Moolenaar8600e402013-05-30 13:28:41 +0200919d = vim.Dictionary()
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200920ned = vim.Dictionary(foo='bar', baz='abcD')
Bram Moolenaar8600e402013-05-30 13:28:41 +0200921dl = vim.Dictionary(a=1)
922dl.locked = True
923l = vim.List()
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200924ll = vim.List('abcE')
Bram Moolenaar8600e402013-05-30 13:28:41 +0200925ll.locked = True
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100926nel = vim.List('abcO')
Bram Moolenaar8600e402013-05-30 13:28:41 +0200927f = vim.Function('string')
928fd = vim.Function('F')
929fdel = vim.Function('D')
930vim.command('delfunction D')
931
932def subexpr_test(expr, name, subexprs):
933 cb.append('>>> Testing %s using %s' % (name, expr))
934 for subexpr in subexprs:
935 ee(expr % subexpr)
936 cb.append('<<< Finished')
937
938def stringtochars_test(expr):
939 return subexpr_test(expr, 'StringToChars', (
940 '1', # Fail type checks
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +0200941 'b"\\0"', # Fail PyString_AsStringAndSize(object, , NULL) check
942 '"\\0"', # Fail PyString_AsStringAndSize(bytes, , NULL) check
Bram Moolenaar8600e402013-05-30 13:28:41 +0200943 ))
944
945class Mapping(object):
946 def __init__(self, d):
947 self.d = d
948
949 def __getitem__(self, key):
950 return self.d[key]
951
952 def keys(self):
953 return self.d.keys()
954
955 def items(self):
956 return self.d.items()
957
958def convertfrompyobject_test(expr, recurse=True):
959 # pydict_to_tv
960 stringtochars_test(expr % '{%s : 1}')
961 if recurse:
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200962 convertfrompyobject_test(expr % '{"abcF" : %s}', False)
Bram Moolenaar8600e402013-05-30 13:28:41 +0200963 # pymap_to_tv
964 stringtochars_test(expr % 'Mapping({%s : 1})')
965 if recurse:
Bram Moolenaar841fbd22013-06-23 14:37:07 +0200966 convertfrompyobject_test(expr % 'Mapping({"abcG" : %s})', False)
Bram Moolenaar8600e402013-05-30 13:28:41 +0200967 # pyseq_to_tv
968 iter_test(expr)
969 return subexpr_test(expr, 'ConvertFromPyObject', (
970 'None', # Not conversible
Bram Moolenaar78b59572013-06-02 18:54:21 +0200971 '{b"": 1}', # Empty key not allowed
972 '{"": 1}', # Same, but with unicode object
Bram Moolenaar8600e402013-05-30 13:28:41 +0200973 'FailingMapping()', #
974 'FailingMappingKey()', #
Bram Moolenaardee2e312013-06-23 16:35:47 +0200975 'FailingNumber()', #
Bram Moolenaar8600e402013-05-30 13:28:41 +0200976 ))
977
978def convertfrompymapping_test(expr):
979 convertfrompyobject_test(expr)
980 return subexpr_test(expr, 'ConvertFromPyMapping', (
981 '[]',
982 ))
983
984def iter_test(expr):
985 return subexpr_test(expr, '*Iter*', (
986 'FailingIter()',
987 'FailingIterNext()',
988 ))
989
Bram Moolenaardee2e312013-06-23 16:35:47 +0200990def number_test(expr, natural=False, unsigned=False):
991 if natural:
992 unsigned = True
993 return subexpr_test(expr, 'NumberToLong', (
994 '[]',
995 'None',
996 ) + (('-1',) if unsigned else ())
997 + (('0',) if natural else ()))
998
Bram Moolenaar8600e402013-05-30 13:28:41 +0200999class FailingTrue(object):
1000 def __bool__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001001 raise NotImplementedError('bool')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001002
1003class FailingIter(object):
1004 def __iter__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001005 raise NotImplementedError('iter')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001006
1007class FailingIterNext(object):
1008 def __iter__(self):
1009 return self
1010
1011 def __next__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001012 raise NotImplementedError('next')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001013
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001014class FailingIterNextN(object):
1015 def __init__(self, n):
1016 self.n = n
1017
1018 def __iter__(self):
1019 return self
1020
1021 def __next__(self):
1022 if self.n:
1023 self.n -= 1
1024 return 1
1025 else:
1026 raise NotImplementedError('next N')
1027
Bram Moolenaar8600e402013-05-30 13:28:41 +02001028class FailingMappingKey(object):
1029 def __getitem__(self, item):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001030 raise NotImplementedError('getitem:mappingkey')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001031
1032 def keys(self):
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001033 return list("abcH")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001034
1035class FailingMapping(object):
1036 def __getitem__(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001037 raise NotImplementedError('getitem:mapping')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001038
1039 def keys(self):
Bram Moolenaardee2e312013-06-23 16:35:47 +02001040 raise NotImplementedError('keys')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001041
1042class FailingList(list):
1043 def __getitem__(self, idx):
1044 if i == 2:
Bram Moolenaardee2e312013-06-23 16:35:47 +02001045 raise NotImplementedError('getitem:list')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001046 else:
1047 return super(FailingList, self).__getitem__(idx)
1048
Bram Moolenaardee2e312013-06-23 16:35:47 +02001049class NoArgsCall(object):
1050 def __call__(self):
1051 pass
1052
1053class FailingCall(object):
1054 def __call__(self, path):
1055 raise NotImplementedError('call')
1056
1057class FailingNumber(object):
1058 def __int__(self):
1059 raise NotImplementedError('int')
1060
Bram Moolenaar8600e402013-05-30 13:28:41 +02001061cb.append("> Output")
1062cb.append(">> OutputSetattr")
1063ee('del sys.stdout.softspace')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001064number_test('sys.stdout.softspace = %s', unsigned=True)
1065number_test('sys.stderr.softspace = %s', unsigned=True)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001066ee('sys.stdout.attr = None')
1067cb.append(">> OutputWrite")
1068ee('sys.stdout.write(None)')
1069cb.append(">> OutputWriteLines")
1070ee('sys.stdout.writelines(None)')
1071ee('sys.stdout.writelines([1])')
1072iter_test('sys.stdout.writelines(%s)')
1073cb.append("> VimCommand")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001074stringtochars_test('vim.command(%s)')
1075ee('vim.command("", 2)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001076#! Not checked: vim->python exceptions translating: checked later
1077cb.append("> VimToPython")
1078#! Not checked: everything: needs errors in internal python functions
1079cb.append("> VimEval")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001080stringtochars_test('vim.eval(%s)')
1081ee('vim.eval("", FailingTrue())')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001082#! Not checked: everything: needs errors in internal python functions
1083cb.append("> VimEvalPy")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001084stringtochars_test('vim.bindeval(%s)')
1085ee('vim.eval("", 2)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001086#! Not checked: vim->python exceptions translating: checked later
1087cb.append("> VimStrwidth")
Bram Moolenaardee2e312013-06-23 16:35:47 +02001088stringtochars_test('vim.strwidth(%s)')
1089cb.append("> VimForeachRTP")
1090ee('vim.foreach_rtp(None)')
1091ee('vim.foreach_rtp(NoArgsCall())')
1092ee('vim.foreach_rtp(FailingCall())')
1093ee('vim.foreach_rtp(int, 2)')
1094cb.append('> import')
1095old_rtp = vim.options['rtp']
1096vim.options['rtp'] = os.getcwd().replace(',', '\\,').replace('\\', '\\\\')
1097ee('import xxx_no_such_module_xxx')
1098ee('import failing_import')
1099ee('import failing')
1100vim.options['rtp'] = old_rtp
1101del old_rtp
Bram Moolenaar8600e402013-05-30 13:28:41 +02001102cb.append("> Dictionary")
1103cb.append(">> DictionaryConstructor")
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001104ee('vim.Dictionary("abcI")')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001105##! Not checked: py_dict_alloc failure
1106cb.append(">> DictionarySetattr")
1107ee('del d.locked')
1108ee('d.locked = FailingTrue()')
1109ee('vim.vvars.locked = False')
1110ee('d.scope = True')
1111ee('d.xxx = True')
1112cb.append(">> _DictionaryItem")
1113ee('d.get("a", 2, 3)')
1114stringtochars_test('d.get(%s)')
1115ee('d.pop("a")')
1116ee('dl.pop("a")')
Bram Moolenaarba2d7ff2013-11-04 00:34:53 +01001117cb.append(">> DictionaryContains")
1118ee('"" in d')
1119ee('0 in d')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001120cb.append(">> DictionaryIterNext")
1121ee('for i in ned: ned["a"] = 1')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001122del i
Bram Moolenaar8600e402013-05-30 13:28:41 +02001123cb.append(">> DictionaryAssItem")
1124ee('dl["b"] = 1')
1125stringtochars_test('d[%s] = 1')
1126convertfrompyobject_test('d["a"] = %s')
1127cb.append(">> DictionaryUpdate")
1128cb.append(">>> kwargs")
1129cb.append(">>> iter")
1130ee('d.update(FailingMapping())')
1131ee('d.update([FailingIterNext()])')
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001132ee('d.update([FailingIterNextN(1)])')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001133iter_test('d.update(%s)')
1134convertfrompyobject_test('d.update(%s)')
1135stringtochars_test('d.update(((%s, 0),))')
1136convertfrompyobject_test('d.update((("a", %s),))')
1137cb.append(">> DictionaryPopItem")
1138ee('d.popitem(1, 2)')
1139cb.append(">> DictionaryHasKey")
1140ee('d.has_key()')
1141cb.append("> List")
1142cb.append(">> ListConstructor")
1143ee('vim.List(1, 2)')
1144ee('vim.List(a=1)')
1145iter_test('vim.List(%s)')
1146convertfrompyobject_test('vim.List([%s])')
1147cb.append(">> ListItem")
1148ee('l[1000]')
1149cb.append(">> ListAssItem")
1150ee('ll[1] = 2')
1151ee('l[1000] = 3')
1152cb.append(">> ListAssSlice")
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001153ee('ll[1:100] = "abcJ"')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001154iter_test('l[:] = %s')
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001155ee('nel[1:10:2] = "abcK"')
1156cb.append(repr(tuple(nel)))
1157ee('nel[1:10:2] = "a"')
1158cb.append(repr(tuple(nel)))
1159ee('nel[1:1:-1] = "a"')
1160cb.append(repr(tuple(nel)))
1161ee('nel[:] = FailingIterNextN(2)')
1162cb.append(repr(tuple(nel)))
Bram Moolenaar8600e402013-05-30 13:28:41 +02001163convertfrompyobject_test('l[:] = [%s]')
1164cb.append(">> ListConcatInPlace")
1165iter_test('l.extend(%s)')
1166convertfrompyobject_test('l.extend([%s])')
1167cb.append(">> ListSetattr")
1168ee('del l.locked')
1169ee('l.locked = FailingTrue()')
1170ee('l.xxx = True')
1171cb.append("> Function")
1172cb.append(">> FunctionConstructor")
1173ee('vim.Function("123")')
1174ee('vim.Function("xxx_non_existent_function_xxx")')
1175ee('vim.Function("xxx#non#existent#function#xxx")')
1176cb.append(">> FunctionCall")
1177convertfrompyobject_test('f(%s)')
1178convertfrompymapping_test('fd(self=%s)')
1179cb.append("> TabPage")
1180cb.append(">> TabPageAttr")
1181ee('vim.current.tabpage.xxx')
1182cb.append("> TabList")
1183cb.append(">> TabListItem")
1184ee('vim.tabpages[1000]')
1185cb.append("> Window")
1186cb.append(">> WindowAttr")
1187ee('vim.current.window.xxx')
1188cb.append(">> WindowSetattr")
1189ee('vim.current.window.buffer = 0')
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001190ee('vim.current.window.cursor = (100000000, 100000000)')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001191ee('vim.current.window.cursor = True')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001192number_test('vim.current.window.height = %s', unsigned=True)
1193number_test('vim.current.window.width = %s', unsigned=True)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001194ee('vim.current.window.xxxxxx = True')
1195cb.append("> WinList")
1196cb.append(">> WinListItem")
1197ee('vim.windows[1000]')
1198cb.append("> Buffer")
1199cb.append(">> StringToLine (indirect)")
1200ee('vim.current.buffer[0] = "\\na"')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001201ee('vim.current.buffer[0] = b"\\na"')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001202cb.append(">> SetBufferLine (indirect)")
1203ee('vim.current.buffer[0] = True')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001204cb.append(">> SetBufferLineList (indirect)")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001205ee('vim.current.buffer[:] = True')
1206ee('vim.current.buffer[:] = ["\\na", "bc"]')
1207cb.append(">> InsertBufferLines (indirect)")
1208ee('vim.current.buffer.append(None)')
1209ee('vim.current.buffer.append(["\\na", "bc"])')
1210ee('vim.current.buffer.append("\\nbc")')
1211cb.append(">> RBItem")
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001212ee('vim.current.buffer[100000000]')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001213cb.append(">> RBAsItem")
Bram Moolenaar96c7dfd2013-05-31 18:46:11 +02001214ee('vim.current.buffer[100000000] = ""')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001215cb.append(">> BufferAttr")
1216ee('vim.current.buffer.xxx')
1217cb.append(">> BufferSetattr")
1218ee('vim.current.buffer.name = True')
1219ee('vim.current.buffer.xxx = True')
1220cb.append(">> BufferMark")
1221ee('vim.current.buffer.mark(0)')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001222ee('vim.current.buffer.mark("abcM")')
Bram Moolenaar8600e402013-05-30 13:28:41 +02001223ee('vim.current.buffer.mark("!")')
1224cb.append(">> BufferRange")
1225ee('vim.current.buffer.range(1, 2, 3)')
1226cb.append("> BufMap")
1227cb.append(">> BufMapItem")
Bram Moolenaar8600e402013-05-30 13:28:41 +02001228ee('vim.buffers[100000000]')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001229number_test('vim.buffers[%s]', natural=True)
Bram Moolenaar8600e402013-05-30 13:28:41 +02001230cb.append("> Current")
1231cb.append(">> CurrentGetattr")
1232ee('vim.current.xxx')
1233cb.append(">> CurrentSetattr")
1234ee('vim.current.line = True')
1235ee('vim.current.buffer = True')
1236ee('vim.current.window = True')
1237ee('vim.current.tabpage = True')
1238ee('vim.current.xxx = True')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001239del d
1240del ned
1241del dl
1242del l
1243del ll
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001244del nel
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001245del f
1246del fd
1247del fdel
1248del subexpr_test
1249del stringtochars_test
1250del Mapping
1251del convertfrompyobject_test
1252del convertfrompymapping_test
1253del iter_test
Bram Moolenaardee2e312013-06-23 16:35:47 +02001254del number_test
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001255del FailingTrue
1256del FailingIter
1257del FailingIterNext
Bram Moolenaar063a46b2014-01-14 16:36:51 +01001258del FailingIterNextN
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001259del FailingMapping
1260del FailingMappingKey
1261del FailingList
Bram Moolenaardee2e312013-06-23 16:35:47 +02001262del NoArgsCall
1263del FailingCall
1264del FailingNumber
Bram Moolenaar8600e402013-05-30 13:28:41 +02001265EOF
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001266:delfunction F
Bram Moolenaar8600e402013-05-30 13:28:41 +02001267:"
Bram Moolenaara9f22202013-06-11 18:48:21 +02001268:" Test import
1269py3 << EOF
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001270sys.path.insert(0, os.path.join(os.getcwd(), 'python_before'))
1271sys.path.append(os.path.join(os.getcwd(), 'python_after'))
Bram Moolenaara9f22202013-06-11 18:48:21 +02001272vim.options['rtp'] = os.getcwd().replace(',', '\\,').replace('\\', '\\\\')
Bram Moolenaardee2e312013-06-23 16:35:47 +02001273l = []
1274def callback(path):
1275 l.append(os.path.relpath(path))
1276vim.foreach_rtp(callback)
1277cb.append(repr(l))
1278del l
1279def callback(path):
1280 return os.path.relpath(path)
1281cb.append(repr(vim.foreach_rtp(callback)))
1282del callback
Bram Moolenaara9f22202013-06-11 18:48:21 +02001283from module import dir as d
1284from modulex import ddir
1285cb.append(d + ',' + ddir)
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001286import before
1287cb.append(before.dir)
1288import after
1289cb.append(after.dir)
Bram Moolenaardee2e312013-06-23 16:35:47 +02001290import topmodule as tm
1291import topmodule.submodule as tms
1292import topmodule.submodule.subsubmodule.subsubsubmodule as tmsss
Bram Moolenaar877aa002013-06-26 21:49:51 +02001293cb.append(tm.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/__init__.py'):])
1294cb.append(tms.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/submodule/__init__.py'):])
1295cb.append(tmsss.__file__.replace(os.path.sep, '/')[-len('modulex/topmodule/submodule/subsubmodule/subsubsubmodule.py'):])
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001296del before
1297del after
1298del d
1299del ddir
Bram Moolenaardee2e312013-06-23 16:35:47 +02001300del tm
1301del tms
1302del tmsss
Bram Moolenaara9f22202013-06-11 18:48:21 +02001303EOF
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001304:"
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001305:" Test exceptions
1306:fun Exe(e)
1307: execute a:e
1308:endfun
1309py3 << EOF
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001310Exe = vim.bindeval('function("Exe")')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001311ee('vim.command("throw \'abcN\'")')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001312ee('Exe("throw \'def\'")')
1313ee('vim.eval("Exe(\'throw \'\'ghi\'\'\')")')
1314ee('vim.eval("Exe(\'echoerr \'\'jkl\'\'\')")')
1315ee('vim.eval("Exe(\'xxx_non_existent_command_xxx\')")')
Bram Moolenaar9fee7d42013-11-28 17:04:43 +01001316ee('vim.eval("xxx_unknown_function_xxx()")')
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001317ee('vim.bindeval("Exe(\'xxx_non_existent_command_xxx\')")')
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001318del Exe
1319EOF
1320:delfunction Exe
1321:"
Bram Moolenaard6b8a522013-11-11 01:05:48 +01001322:" Regression: interrupting vim.command propagates to next vim.command
1323py3 << EOF
1324def test_keyboard_interrupt():
1325 try:
1326 vim.command('while 1 | endwhile')
1327 except KeyboardInterrupt:
1328 cb.append('Caught KeyboardInterrupt')
1329 except Exception as e:
1330 cb.append('!!!!!!!! Caught exception: ' + repr(e))
1331 else:
1332 cb.append('!!!!!!!! No exception')
1333 try:
1334 vim.command('$ put =\'Running :put\'')
1335 except KeyboardInterrupt:
1336 cb.append('!!!!!!!! Caught KeyboardInterrupt')
1337 except Exception as e:
1338 cb.append('!!!!!!!! Caught exception: ' + repr(e))
1339 else:
1340 cb.append('No exception')
1341EOF
1342:debuggreedy
1343:call inputsave()
1344:call feedkeys("s\ns\ns\ns\nq\n")
1345:redir => output
1346:debug silent! py3 test_keyboard_interrupt()
1347:redir END
1348:0 debuggreedy
1349:silent $put =output
1350:unlet output
1351:py3 del test_keyboard_interrupt
1352:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001353:" Cleanup
1354py3 << EOF
1355del cb
1356del ee
1357del sys
1358del os
1359del vim
Bram Moolenaara7b64ce2013-05-21 20:40:40 +02001360EOF
Bram Moolenaardb913952012-06-29 12:54:53 +02001361:endfun
1362:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001363:fun RunTest()
1364:let checkrefs = !empty($PYTHONDUMPREFS)
1365:let start = getline(1, '$')
1366:for i in range(checkrefs ? 10 : 1)
1367: if i != 0
1368: %d _
1369: call setline(1, start)
1370: endif
1371: call Test()
1372: if i == 0
1373: let result = getline(1, '$')
1374: endif
1375:endfor
1376:if checkrefs
1377: %d _
1378: call setline(1, result)
1379:endif
1380:endfun
Bram Moolenaardb913952012-06-29 12:54:53 +02001381:"
Bram Moolenaar841fbd22013-06-23 14:37:07 +02001382:call RunTest()
1383:delfunction RunTest
1384:delfunction Test
Bram Moolenaardb913952012-06-29 12:54:53 +02001385:call garbagecollect(1)
1386:"
1387:/^start:/,$wq! test.out
Bram Moolenaardee2e312013-06-23 16:35:47 +02001388:" vim: et ts=4 isk-=\:
Bram Moolenaarb6c589a2013-05-15 14:39:52 +02001389:call getchar()
Bram Moolenaardb913952012-06-29 12:54:53 +02001390ENDTEST
1391
1392start: