123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269 |
- " Tests for autocommands
- source shared.vim
- source check.vim
- source term_util.vim
- source screendump.vim
- source vim9.vim
- source load.vim
- func s:cleanup_buffers() abort
- for bnr in range(1, bufnr('$'))
- if bufloaded(bnr) && bufnr('%') != bnr
- execute 'bd! ' . bnr
- endif
- endfor
- endfunc
- func CleanUpTestAuGroup()
- augroup testing
- au!
- augroup END
- augroup! testing
- endfunc
- func Test_vim_did_enter()
- call assert_false(v:vim_did_enter)
- " This script will never reach the main loop, can't check if v:vim_did_enter
- " becomes one.
- endfunc
- " Test for the CursorHold autocmd
- func Test_CursorHold_autocmd()
- CheckRunVimInTerminal
- call writefile(['one', 'two', 'three'], 'XoneTwoThree', 'D')
- let before =<< trim END
- set updatetime=10
- au CursorHold * call writefile([line('.')], 'XCHoutput', 'a')
- END
- call writefile(before, 'XCHinit', 'D')
- let buf = RunVimInTerminal('-S XCHinit XoneTwoThree', {})
- call term_sendkeys(buf, "G")
- call term_wait(buf, 50)
- call term_sendkeys(buf, "gg")
- call term_wait(buf)
- call WaitForAssert({-> assert_equal(['1'], readfile('XCHoutput')[-1:-1])})
- call term_sendkeys(buf, "j")
- call term_wait(buf)
- call WaitForAssert({-> assert_equal(['1', '2'], readfile('XCHoutput')[-2:-1])})
- call term_sendkeys(buf, "j")
- call term_wait(buf)
- call WaitForAssert({-> assert_equal(['1', '2', '3'], readfile('XCHoutput')[-3:-1])})
- call StopVimInTerminal(buf)
- call delete('XCHoutput')
- endfunc
- if has('timers')
- func ExitInsertMode(id)
- call feedkeys("\<Esc>")
- endfunc
- func Test_cursorhold_insert()
- " depends on timing
- let g:test_is_flaky = 1
- " Need to move the cursor.
- call feedkeys("ggG", "xt")
- let g:triggered = 0
- au CursorHoldI * let g:triggered += 1
- set updatetime=20
- call timer_start(LoadAdjust(200), 'ExitInsertMode')
- call feedkeys('a', 'x!')
- call assert_equal(1, g:triggered)
- unlet g:triggered
- au! CursorHoldI
- set updatetime&
- endfunc
- func Test_cursorhold_insert_with_timer_interrupt()
- CheckFeature job
- " Need to move the cursor.
- call feedkeys("ggG", "xt")
- " Confirm the timer invoked in exit_cb of the job doesn't disturb
- " CursorHoldI event.
- let g:triggered = 0
- au CursorHoldI * let g:triggered += 1
- set updatetime=100
- call job_start(has('win32') ? 'cmd /D /c echo:' : 'echo',
- \ {'exit_cb': {-> timer_start(200, 'ExitInsertMode')}})
- call feedkeys('a', 'x!')
- call assert_equal(1, g:triggered)
- unlet g:triggered
- au! CursorHoldI
- set updatetime&
- endfunc
- func Test_cursorhold_insert_ctrl_x()
- let g:triggered = 0
- au CursorHoldI * let g:triggered += 1
- set updatetime=20
- call timer_start(LoadAdjust(100), 'ExitInsertMode')
- " CursorHoldI does not trigger after CTRL-X
- call feedkeys("a\<C-X>", 'x!')
- call assert_equal(0, g:triggered)
- unlet g:triggered
- au! CursorHoldI
- set updatetime&
- endfunc
- func Test_cursorhold_insert_ctrl_g_U()
- au CursorHoldI * :
- set updatetime=20
- new
- call timer_start(100, { -> feedkeys("\<Left>foo\<Esc>", 't') })
- call feedkeys("i()\<C-g>U", 'tx!')
- sleep 200m
- call assert_equal('(foo)', getline(1))
- undo
- call assert_equal('', getline(1))
- bwipe!
- au! CursorHoldI
- set updatetime&
- endfunc
- func Test_OptionSet_modeline()
- CheckFunction test_override
- call test_override('starting', 1)
- au! OptionSet
- augroup set_tabstop
- au OptionSet tabstop call timer_start(1, {-> execute("echo 'Handler called'", "")})
- augroup END
- call writefile(['vim: set ts=7 sw=5 :', 'something'], 'XoptionsetModeline', 'D')
- set modeline
- let v:errmsg = ''
- call assert_fails('split XoptionsetModeline', 'E12:')
- call assert_equal(7, &ts)
- call assert_equal('', v:errmsg)
- augroup set_tabstop
- au!
- augroup END
- bwipe!
- set ts&
- call test_override('starting', 0)
- endfunc
- endif "has('timers')
- func Test_bufunload()
- augroup test_bufunload_group
- autocmd!
- autocmd BufUnload * call add(s:li, "bufunload")
- autocmd BufDelete * call add(s:li, "bufdelete")
- autocmd BufWipeout * call add(s:li, "bufwipeout")
- augroup END
- let s:li = []
- new
- setlocal bufhidden=
- bunload
- call assert_equal(["bufunload", "bufdelete"], s:li)
- let s:li = []
- new
- setlocal bufhidden=delete
- bunload
- call assert_equal(["bufunload", "bufdelete"], s:li)
- let s:li = []
- new
- setlocal bufhidden=unload
- bwipeout
- call assert_equal(["bufunload", "bufdelete", "bufwipeout"], s:li)
- au! test_bufunload_group
- augroup! test_bufunload_group
- endfunc
- " SEGV occurs in older versions. (At least 7.4.2005 or older)
- func Test_autocmd_bufunload_with_tabnext()
- tabedit
- tabfirst
- augroup test_autocmd_bufunload_with_tabnext_group
- autocmd!
- autocmd BufUnload <buffer> tabnext
- augroup END
- quit
- call assert_equal(2, tabpagenr('$'))
- autocmd! test_autocmd_bufunload_with_tabnext_group
- augroup! test_autocmd_bufunload_with_tabnext_group
- tablast
- quit
- endfunc
- func Test_argdelete_in_next()
- au BufNew,BufEnter,BufLeave,BufWinEnter * argdel
- call assert_fails('next a b', 'E1156:')
- au! BufNew,BufEnter,BufLeave,BufWinEnter *
- endfunc
- func Test_autocmd_bufwinleave_with_tabfirst()
- tabedit
- augroup sample
- autocmd!
- autocmd BufWinLeave <buffer> tabfirst
- augroup END
- call setline(1, ['a', 'b', 'c'])
- edit! a.txt
- tabclose
- endfunc
- " SEGV occurs in older versions. (At least 7.4.2321 or older)
- func Test_autocmd_bufunload_avoiding_SEGV_01()
- split aa.txt
- let lastbuf = bufnr('$')
- augroup test_autocmd_bufunload
- autocmd!
- exe 'autocmd BufUnload <buffer> ' . (lastbuf + 1) . 'bwipeout!'
- augroup END
- call assert_fails('edit bb.txt', 'E937:')
- autocmd! test_autocmd_bufunload
- augroup! test_autocmd_bufunload
- bwipe! aa.txt
- bwipe! bb.txt
- endfunc
- " SEGV occurs in older versions. (At least 7.4.2321 or older)
- func Test_autocmd_bufunload_avoiding_SEGV_02()
- setlocal buftype=nowrite
- let lastbuf = bufnr('$')
- augroup test_autocmd_bufunload
- autocmd!
- exe 'autocmd BufUnload <buffer> ' . (lastbuf + 1) . 'bwipeout!'
- augroup END
- normal! i1
- call assert_fails('edit a.txt', 'E517:')
- autocmd! test_autocmd_bufunload
- augroup! test_autocmd_bufunload
- bwipe! a.txt
- endfunc
- func Test_autocmd_dummy_wipeout()
- " prepare files
- call writefile([''], 'Xdummywipetest1.txt', 'D')
- call writefile([''], 'Xdummywipetest2.txt', 'D')
- augroup test_bufunload_group
- autocmd!
- autocmd BufUnload * call add(s:li, "bufunload")
- autocmd BufDelete * call add(s:li, "bufdelete")
- autocmd BufWipeout * call add(s:li, "bufwipeout")
- augroup END
- let s:li = []
- split Xdummywipetest1.txt
- silent! vimgrep /notmatched/ Xdummywipetest*
- call assert_equal(["bufunload", "bufwipeout"], s:li)
- bwipeout
- au! test_bufunload_group
- augroup! test_bufunload_group
- endfunc
- func Test_win_tab_autocmd()
- let g:record = []
- augroup testing
- au WinNew * call add(g:record, 'WinNew')
- au WinClosed * call add(g:record, 'WinClosed')
- au WinEnter * call add(g:record, 'WinEnter')
- au WinLeave * call add(g:record, 'WinLeave')
- au TabNew * call add(g:record, 'TabNew')
- au TabClosed * call add(g:record, 'TabClosed')
- au TabEnter * call add(g:record, 'TabEnter')
- au TabLeave * call add(g:record, 'TabLeave')
- augroup END
- split
- tabnew
- close
- close
- call assert_equal([
- \ 'WinLeave', 'WinNew', 'WinEnter',
- \ 'WinLeave', 'TabLeave', 'WinNew', 'WinEnter', 'TabNew', 'TabEnter',
- \ 'WinLeave', 'TabLeave', 'WinClosed', 'TabClosed', 'WinEnter', 'TabEnter',
- \ 'WinLeave', 'WinClosed', 'WinEnter'
- \ ], g:record)
- let g:record = []
- tabnew somefile
- tabnext
- bwipe somefile
- call assert_equal([
- \ 'WinLeave', 'TabLeave', 'WinNew', 'WinEnter', 'TabNew', 'TabEnter',
- \ 'WinLeave', 'TabLeave', 'WinEnter', 'TabEnter',
- \ 'WinClosed', 'TabClosed'
- \ ], g:record)
- augroup testing
- au!
- augroup END
- unlet g:record
- endfunc
- func Test_WinResized()
- CheckRunVimInTerminal
- let lines =<< trim END
- set scrolloff=0
- call setline(1, ['111', '222'])
- vnew
- call setline(1, ['aaa', 'bbb'])
- new
- call setline(1, ['foo', 'bar'])
- let g:resized = 0
- au WinResized * let g:resized += 1
- func WriteResizedEvent()
- call writefile([json_encode(v:event)], 'XresizeEvent')
- endfunc
- au WinResized * call WriteResizedEvent()
- END
- call writefile(lines, 'Xtest_winresized', 'D')
- let buf = RunVimInTerminal('-S Xtest_winresized', {'rows': 10})
- " redraw now to avoid a redraw after the :echo command
- call term_sendkeys(buf, ":redraw!\<CR>")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:resized\<CR>")
- call WaitForAssert({-> assert_match('^0$', term_getline(buf, 10))}, 1000)
- " increase window height, two windows will be reported
- call term_sendkeys(buf, "\<C-W>+")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:resized\<CR>")
- call WaitForAssert({-> assert_match('^1$', term_getline(buf, 10))}, 1000)
- let event = readfile('XresizeEvent')[0]->json_decode()
- call assert_equal({
- \ 'windows': [1002, 1001],
- \ }, event)
- " increase window width, three windows will be reported
- call term_sendkeys(buf, "\<C-W>>")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:resized\<CR>")
- call WaitForAssert({-> assert_match('^2$', term_getline(buf, 10))}, 1000)
- let event = readfile('XresizeEvent')[0]->json_decode()
- call assert_equal({
- \ 'windows': [1002, 1001, 1000],
- \ }, event)
- call delete('XresizeEvent')
- call StopVimInTerminal(buf)
- endfunc
- func Test_WinScrolled()
- CheckRunVimInTerminal
- let lines =<< trim END
- set nowrap scrolloff=0
- for ii in range(1, 18)
- call setline(ii, repeat(nr2char(96 + ii), ii * 2))
- endfor
- let win_id = win_getid()
- let g:matched = v:false
- func WriteScrollEvent()
- call writefile([json_encode(v:event)], 'XscrollEvent')
- endfunc
- execute 'au WinScrolled' win_id 'let g:matched = v:true'
- let g:scrolled = 0
- au WinScrolled * let g:scrolled += 1
- au WinScrolled * let g:amatch = str2nr(expand('<amatch>'))
- au WinScrolled * let g:afile = str2nr(expand('<afile>'))
- au WinScrolled * call WriteScrollEvent()
- END
- call writefile(lines, 'Xtest_winscrolled', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled', {'rows': 6})
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^0 ', term_getline(buf, 6))}, 1000)
- " Scroll left/right in Normal mode.
- call term_sendkeys(buf, "zlzh:echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^2 ', term_getline(buf, 6))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 1, 'topline': 0, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': -1, 'topline': 0, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- " Scroll up/down in Normal mode.
- call term_sendkeys(buf, "\<c-e>\<c-y>:echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^4 ', term_getline(buf, 6))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': -1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- " Scroll up/down in Insert mode.
- call term_sendkeys(buf, "Mi\<c-x>\<c-e>\<Esc>i\<c-x>\<c-y>\<Esc>")
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^6 ', term_getline(buf, 6))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': -1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- " Scroll the window horizontally to focus the last letter of the third line
- " containing only six characters. Moving to the previous and shorter lines
- " should trigger another autocommand as Vim has to make them visible.
- call term_sendkeys(buf, "5zl2k")
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^8 ', term_getline(buf, 6))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 5, 'topline': 0, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': -5, 'topline': 0, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- " Ensure the command was triggered for the specified window ID.
- call term_sendkeys(buf, ":echo g:matched\<CR>")
- call WaitForAssert({-> assert_match('^v:true ', term_getline(buf, 6))}, 1000)
- " Ensure the expansion of <amatch> and <afile> matches the window ID.
- call term_sendkeys(buf, ":echo g:amatch == win_id && g:afile == win_id\<CR>")
- call WaitForAssert({-> assert_match('^v:true ', term_getline(buf, 6))}, 1000)
- call delete('XscrollEvent')
- call StopVimInTerminal(buf)
- endfunc
- func Test_WinScrolled_mouse()
- CheckRunVimInTerminal
- let lines =<< trim END
- set nowrap scrolloff=0
- set mouse=a term=xterm ttymouse=sgr mousetime=200 clipboard=
- call setline(1, ['foo']->repeat(32))
- split
- let g:scrolled = 0
- au WinScrolled * let g:scrolled += 1
- END
- call writefile(lines, 'Xtest_winscrolled_mouse', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_mouse', {'rows': 10})
- " With the upper split focused, send a scroll-down event to the unfocused one.
- call test_setmouse(7, 1)
- call term_sendkeys(buf, "\<ScrollWheelDown>")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^1', term_getline(buf, 10))}, 1000)
- " Again, but this time while we're in insert mode.
- call term_sendkeys(buf, "i\<ScrollWheelDown>\<Esc>")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^2', term_getline(buf, 10))}, 1000)
- call StopVimInTerminal(buf)
- endfunc
- func Test_WinScrolled_close_curwin()
- CheckRunVimInTerminal
- let lines =<< trim END
- set nowrap scrolloff=0
- call setline(1, ['aaa', 'bbb'])
- vsplit
- au WinScrolled * close
- au VimLeave * call writefile(['123456'], 'Xtestout')
- END
- call writefile(lines, 'Xtest_winscrolled_close_curwin', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_close_curwin', {'rows': 6})
- " This was using freed memory
- call term_sendkeys(buf, "\<C-E>")
- call TermWait(buf)
- call StopVimInTerminal(buf)
- " check the startup script finished to the end
- call assert_equal(['123456'], readfile('Xtestout'))
- call delete('Xtestout')
- endfunc
- func Test_WinScrolled_once_only()
- CheckRunVimInTerminal
- let lines =<< trim END
- set cmdheight=2
- call setline(1, ['aaa', 'bbb'])
- let trigger_count = 0
- func ShowInfo(id)
- echo g:trigger_count g:winid winlayout()
- endfunc
- vsplit
- split
- " use a timer to show the info after a redraw
- au WinScrolled * let trigger_count += 1 | let winid = expand('<amatch>') | call timer_start(100, 'ShowInfo')
- wincmd j
- wincmd l
- END
- call writefile(lines, 'Xtest_winscrolled_once', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_once', #{rows: 10, cols: 60, statusoff: 2})
- call term_sendkeys(buf, "\<C-E>")
- call VerifyScreenDump(buf, 'Test_winscrolled_once_only_1', {})
- call StopVimInTerminal(buf)
- endfunc
- " Check that WinScrolled is not triggered immediately when defined and there
- " are split windows.
- func Test_WinScrolled_not_when_defined()
- CheckRunVimInTerminal
- let lines =<< trim END
- call setline(1, ['aaa', 'bbb'])
- echo 'nothing happened'
- func ShowTriggered(id)
- echo 'triggered'
- endfunc
- END
- call writefile(lines, 'Xtest_winscrolled_not', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_not', #{rows: 10, cols: 60, statusoff: 2})
- call term_sendkeys(buf, ":split\<CR>")
- call TermWait(buf)
- " use a timer to show the message after redrawing
- call term_sendkeys(buf, ":au WinScrolled * call timer_start(100, 'ShowTriggered')\<CR>")
- call VerifyScreenDump(buf, 'Test_winscrolled_not_when_defined_1', {})
- call term_sendkeys(buf, "\<C-E>")
- call VerifyScreenDump(buf, 'Test_winscrolled_not_when_defined_2', {})
- call StopVimInTerminal(buf)
- endfunc
- func Test_WinScrolled_long_wrapped()
- CheckRunVimInTerminal
- let lines =<< trim END
- set scrolloff=0
- let height = winheight(0)
- let width = winwidth(0)
- let g:scrolled = 0
- au WinScrolled * let g:scrolled += 1
- call setline(1, repeat('foo', height * width))
- call cursor(1, height * width)
- END
- call writefile(lines, 'Xtest_winscrolled_long_wrapped', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_long_wrapped', {'rows': 6})
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^0 ', term_getline(buf, 6))}, 1000)
- call term_sendkeys(buf, 'gj')
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^1 ', term_getline(buf, 6))}, 1000)
- call term_sendkeys(buf, '0')
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^2 ', term_getline(buf, 6))}, 1000)
- call term_sendkeys(buf, '$')
- call term_sendkeys(buf, ":echo g:scrolled\<CR>")
- call WaitForAssert({-> assert_match('^3 ', term_getline(buf, 6))}, 1000)
- call StopVimInTerminal(buf)
- endfunc
- func Test_WinScrolled_diff()
- CheckRunVimInTerminal
- let lines =<< trim END
- set diffopt+=foldcolumn:0
- call setline(1, ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i'])
- vnew
- call setline(1, ['d', 'e', 'f', 'g', 'h', 'i'])
- windo diffthis
- func WriteScrollEvent()
- call writefile([json_encode(v:event)], 'XscrollEvent')
- endfunc
- au WinScrolled * call WriteScrollEvent()
- END
- call writefile(lines, 'Xtest_winscrolled_diff', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_diff', {'rows': 8})
- call term_sendkeys(buf, "\<C-E>")
- call WaitForAssert({-> assert_match('^d', term_getline(buf, 3))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 1, 'topfill': 1, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': 1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1001': {'leftcol': 0, 'topline': 0, 'topfill': -1, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- call term_sendkeys(buf, "2\<C-E>")
- call WaitForAssert({-> assert_match('^f', term_getline(buf, 3))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 2, 'topfill': 2, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': 2, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1001': {'leftcol': 0, 'topline': 0, 'topfill': -2, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- call term_sendkeys(buf, "\<C-E>")
- call WaitForAssert({-> assert_match('^g', term_getline(buf, 3))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 2, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': 1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1001': {'leftcol': 0, 'topline': 1, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- call term_sendkeys(buf, "2\<C-Y>")
- call WaitForAssert({-> assert_match('^e', term_getline(buf, 3))}, 1000)
- let event = readfile('XscrollEvent')[0]->json_decode()
- call assert_equal({
- \ 'all': {'leftcol': 0, 'topline': 3, 'topfill': 1, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1000': {'leftcol': 0, 'topline': -2, 'topfill': 0, 'width': 0, 'height': 0, 'skipcol': 0},
- \ '1001': {'leftcol': 0, 'topline': -1, 'topfill': 1, 'width': 0, 'height': 0, 'skipcol': 0}
- \ }, event)
- call StopVimInTerminal(buf)
- call delete('XscrollEvent')
- endfunc
- func Test_WinClosed()
- " Test that the pattern is matched against the closed window's ID, and both
- " <amatch> and <afile> are set to it.
- new
- let winid = win_getid()
- let g:matched = v:false
- augroup test-WinClosed
- autocmd!
- execute 'autocmd WinClosed' winid 'let g:matched = v:true'
- autocmd WinClosed * let g:amatch = str2nr(expand('<amatch>'))
- autocmd WinClosed * let g:afile = str2nr(expand('<afile>'))
- augroup END
- close
- call assert_true(g:matched)
- call assert_equal(winid, g:amatch)
- call assert_equal(winid, g:afile)
- " Test that WinClosed is non-recursive.
- new
- new
- call assert_equal(3, winnr('$'))
- let g:triggered = 0
- augroup test-WinClosed
- autocmd!
- autocmd WinClosed * let g:triggered += 1
- autocmd WinClosed * 2 wincmd c
- augroup END
- close
- call assert_equal(1, winnr('$'))
- call assert_equal(1, g:triggered)
- autocmd! test-WinClosed
- augroup! test-WinClosed
- unlet g:matched
- unlet g:amatch
- unlet g:afile
- unlet g:triggered
- endfunc
- func Test_WinClosed_throws()
- vnew
- let bnr = bufnr()
- call assert_equal(1, bufloaded(bnr))
- augroup test-WinClosed
- autocmd WinClosed * throw 'foo'
- augroup END
- try
- close
- catch /.*/
- endtry
- call assert_equal(0, bufloaded(bnr))
- autocmd! test-WinClosed
- augroup! test-WinClosed
- endfunc
- func Test_WinClosed_throws_with_tabs()
- tabnew
- let bnr = bufnr()
- call assert_equal(1, bufloaded(bnr))
- augroup test-WinClosed
- autocmd WinClosed * throw 'foo'
- augroup END
- try
- close
- catch /.*/
- endtry
- call assert_equal(0, bufloaded(bnr))
- autocmd! test-WinClosed
- augroup! test-WinClosed
- endfunc
- " This used to trigger WinClosed twice for the same window, and the window's
- " buffer was NULL in the second autocommand.
- func Test_WinClosed_switch_tab()
- edit Xa
- split Xb
- split Xc
- tab split
- new
- augroup test-WinClosed
- autocmd WinClosed * tabprev | bwipe!
- augroup END
- close
- " Check that the tabline has been fully removed
- call assert_equal([1, 1], win_screenpos(0))
- autocmd! test-WinClosed
- augroup! test-WinClosed
- %bwipe!
- endfunc
- " This used to trigger WinClosed twice for the same window, and the window's
- " buffer was NULL in the second autocommand.
- func Test_WinClosed_BufUnload_close_other()
- tabnew
- let g:tab = tabpagenr()
- let g:buf = bufnr()
- new
- setlocal bufhidden=wipe
- augroup test-WinClosed
- autocmd BufUnload * ++once exe g:buf .. 'bwipe!'
- autocmd WinClosed * call tabpagebuflist(g:tab)
- augroup END
- close
- unlet g:tab
- unlet g:buf
- autocmd! test-WinClosed
- augroup! test-WinClosed
- %bwipe!
- endfunc
- func s:AddAnAutocmd()
- augroup vimBarTest
- au BufReadCmd * echo 'hello'
- augroup END
- call assert_equal(3, len(split(execute('au vimBarTest'), "\n")))
- endfunc
- func Test_early_bar()
- " test that a bar is recognized before the {event}
- call s:AddAnAutocmd()
- augroup vimBarTest | au! | let done = 77 | augroup END
- call assert_equal(1, len(split(execute('au vimBarTest'), "\n")))
- call assert_equal(77, done)
- call s:AddAnAutocmd()
- augroup vimBarTest| au!| let done = 88 | augroup END
- call assert_equal(1, len(split(execute('au vimBarTest'), "\n")))
- call assert_equal(88, done)
- " test that a bar is recognized after the {event}
- call s:AddAnAutocmd()
- augroup vimBarTest| au!BufReadCmd| let done = 99 | augroup END
- call assert_equal(1, len(split(execute('au vimBarTest'), "\n")))
- call assert_equal(99, done)
- " test that a bar is recognized after the {group}
- call s:AddAnAutocmd()
- au! vimBarTest|echo 'hello'
- call assert_equal(1, len(split(execute('au vimBarTest'), "\n")))
- endfunc
- func RemoveGroup()
- autocmd! StartOK
- augroup! StartOK
- endfunc
- func Test_augroup_warning()
- augroup TheWarning
- au VimEnter * echo 'entering'
- augroup END
- call assert_match("TheWarning.*VimEnter", execute('au VimEnter'))
- redir => res
- augroup! TheWarning
- redir END
- call assert_match("W19:", res)
- call assert_match("-Deleted-.*VimEnter", execute('au VimEnter'))
- " check "Another" does not take the pace of the deleted entry
- augroup Another
- augroup END
- call assert_match("-Deleted-.*VimEnter", execute('au VimEnter'))
- augroup! Another
- " no warning for postpone aucmd delete
- augroup StartOK
- au VimEnter * call RemoveGroup()
- augroup END
- call assert_match("StartOK.*VimEnter", execute('au VimEnter'))
- redir => res
- doautocmd VimEnter
- redir END
- call assert_notmatch("W19:", res)
- au! VimEnter
- call assert_fails('augroup!', 'E471:')
- endfunc
- func Test_BufReadCmdHelp()
- " This used to cause access to free memory
- au BufReadCmd * e +h
- help
- au! BufReadCmd
- endfunc
- func Test_BufReadCmdHelpJump()
- " This used to cause access to free memory
- au BufReadCmd * e +h{
- " } to fix highlighting
- call assert_fails('help', 'E434:')
- au! BufReadCmd
- endfunc
- " BufReadCmd is triggered for a "nofile" buffer. Check all values.
- func Test_BufReadCmdNofile()
- for val in ['nofile',
- \ 'nowrite',
- \ 'acwrite',
- \ 'quickfix',
- \ 'help',
- "\ 'terminal',
- \ 'prompt',
- "\ 'popup',
- \ ]
- new somefile
- exe 'set buftype=' .. val
- au BufReadCmd somefile call setline(1, 'triggered')
- edit
- call assert_equal('triggered', getline(1))
- au! BufReadCmd
- bwipe!
- endfor
- endfunc
- func Test_augroup_deleted()
- " This caused a crash before E936 was introduced
- augroup x
- call assert_fails('augroup! x', 'E936:')
- au VimEnter * echo
- augroup end
- augroup! x
- call assert_match("-Deleted-.*VimEnter", execute('au VimEnter'))
- au! VimEnter
- endfunc
- " Tests for autocommands on :close command.
- " This used to be in test13.
- func Test_three_windows()
- " Clean up buffers, because in some cases this function fails.
- call s:cleanup_buffers()
- " Write three files and open them, each in a window.
- " Then go to next window, with autocommand that deletes the previous one.
- " Do this twice, writing the file.
- e! Xtestje1
- call setline(1, 'testje1')
- w
- sp Xtestje2
- call setline(1, 'testje2')
- w
- sp Xtestje3
- call setline(1, 'testje3')
- w
- wincmd w
- au WinLeave Xtestje2 bwipe
- wincmd w
- call assert_equal('Xtestje1', expand('%'))
- au WinLeave Xtestje1 bwipe Xtestje3
- close
- call assert_equal('Xtestje1', expand('%'))
- " Test deleting the buffer on a Unload event. If this goes wrong there
- " will be the ATTENTION prompt.
- e Xtestje1
- au!
- au! BufUnload Xtestje1 bwipe
- call assert_fails('e Xtestje3', 'E937:')
- call assert_equal('Xtestje3', expand('%'))
- e Xtestje2
- sp Xtestje1
- call assert_fails('e', 'E937:')
- call assert_equal('Xtestje1', expand('%'))
- " Test changing buffers in a BufWipeout autocommand. If this goes wrong
- " there are ml_line errors and/or a Crash.
- au!
- only
- e Xanother
- e Xtestje1
- bwipe Xtestje2
- bwipe Xtestje3
- au BufWipeout Xtestje1 buf Xtestje1
- bwipe
- call assert_equal('Xanother', expand('%'))
- only
- help
- wincmd w
- 1quit
- call assert_equal('Xanother', expand('%'))
- au!
- enew
- call delete('Xtestje1')
- call delete('Xtestje2')
- call delete('Xtestje3')
- endfunc
- func Test_BufEnter()
- au! BufEnter
- au Bufenter * let val = val . '+'
- let g:val = ''
- split NewFile
- call assert_equal('+', g:val)
- bwipe!
- call assert_equal('++', g:val)
- " Also get BufEnter when editing a directory
- call mkdir('Xbufenterdir', 'D')
- split Xbufenterdir
- call assert_equal('+++', g:val)
- " On MS-Windows we can't edit the directory, make sure we wipe the right
- " buffer.
- bwipe! Xbufenterdir
- au! BufEnter
- " Editing a "nofile" buffer doesn't read the file but does trigger BufEnter
- " for historic reasons. Also test other 'buftype' values.
- for val in ['nofile',
- \ 'nowrite',
- \ 'acwrite',
- \ 'quickfix',
- \ 'help',
- "\ 'terminal',
- \ 'prompt',
- "\ 'popup',
- \ ]
- new somefile
- exe 'set buftype=' .. val
- au BufEnter somefile call setline(1, 'some text')
- edit
- call assert_equal('some text', getline(1))
- bwipe!
- au! BufEnter
- endfor
- endfunc
- " Closing a window might cause an endless loop
- " E814 for older Vims
- func Test_autocmd_bufwipe_in_SessLoadPost()
- edit Xtest
- tabnew
- file Xsomething
- set noswapfile
- mksession!
- let content =<< trim [CODE]
- set nocp noswapfile
- let v:swapchoice = "e"
- augroup test_autocmd_sessionload
- autocmd!
- autocmd SessionLoadPost * exe bufnr("Xsomething") . "bw!"
- augroup END
- func WriteErrors()
- call writefile([execute("messages")], "XerrorsBwipe")
- endfunc
- au VimLeave * call WriteErrors()
- [CODE]
- call writefile(content, 'Xvimrc', 'D')
- call system(GetVimCommand('Xvimrc') .. ' --headless --noplugins -S Session.vim -c cq')
- sleep 100m
- let errors = join(readfile('XerrorsBwipe'))
- call assert_match('E814:', errors)
- set swapfile
- for file in ['Session.vim', 'XerrorsBwipe']
- call delete(file)
- endfor
- endfunc
- " Using :blast and :ball for many events caused a crash, because b_nwindows was
- " not incremented correctly.
- func Test_autocmd_blast_badd()
- let content =<< trim [CODE]
- au BufNew,BufAdd,BufWinEnter,BufEnter,BufLeave,BufWinLeave,BufUnload,VimEnter foo* blast
- edit foo1
- au BufNew,BufAdd,BufWinEnter,BufEnter,BufLeave,BufWinLeave,BufUnload,VimEnter foo* ball
- edit foo2
- call writefile(['OK'], 'XerrorsBlast')
- qall
- [CODE]
- call writefile(content, 'XblastBall', 'D')
- call system(GetVimCommand() .. ' --clean -S XblastBall')
- sleep 100m
- call assert_match('OK', readfile('XerrorsBlast')->join())
- call delete('XerrorsBlast')
- endfunc
- " SEGV occurs in older versions.
- func Test_autocmd_bufwipe_in_SessLoadPost2()
- tabnew
- set noswapfile
- mksession!
- let content =<< trim [CODE]
- set nocp noswapfile
- function! DeleteInactiveBufs()
- tabfirst
- let tabblist = []
- for i in range(1, tabpagenr(''$''))
- call extend(tabblist, tabpagebuflist(i))
- endfor
- for b in range(1, bufnr(''$''))
- if bufexists(b) && buflisted(b) && (index(tabblist, b) == -1 || bufname(b) =~# ''^$'')
- exec ''bwipeout '' . b
- endif
- endfor
- echomsg "SessionLoadPost DONE"
- endfunction
- au SessionLoadPost * call DeleteInactiveBufs()
- func WriteErrors()
- call writefile([execute("messages")], "XerrorsPost")
- endfunc
- au VimLeave * call WriteErrors()
- [CODE]
- call writefile(content, 'Xvimrc', 'D')
- call system(GetVimCommand('Xvimrc') .. ' --headless --noplugins -S Session.vim -c cq')
- sleep 100m
- let errors = join(readfile('XerrorsPost'))
- " This probably only ever matches on unix.
- call assert_notmatch('Caught deadly signal SEGV', errors)
- call assert_match('SessionLoadPost DONE', errors)
- set swapfile
- for file in ['Session.vim', 'XerrorsPost']
- call delete(file)
- endfor
- endfunc
- func Test_empty_doau()
- doau \|
- endfunc
- func s:AutoCommandOptionSet(match)
- let template = "Option: <%s>, OldVal: <%s>, OldValLocal: <%s>, OldValGlobal: <%s>, NewVal: <%s>, Scope: <%s>, Command: <%s>\n"
- let item = remove(g:options, 0)
- let expected = printf(template, item[0], item[1], item[2], item[3], item[4], item[5], item[6])
- let actual = printf(template, a:match, v:option_old, v:option_oldlocal, v:option_oldglobal, v:option_new, v:option_type, v:option_command)
- let g:opt = [expected, actual]
- "call assert_equal(expected, actual)
- endfunc
- func Test_OptionSet()
- CheckFunction test_override
- CheckOption autochdir
- call test_override('starting', 1)
- set nocp
- au OptionSet * :call s:AutoCommandOptionSet(expand("<amatch>"))
- " 1: Setting number option"
- let g:options = [['number', 0, 0, 0, 1, 'global', 'set']]
- set nu
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 2: Setting local number option"
- let g:options = [['number', 1, 1, '', 0, 'local', 'setlocal']]
- setlocal nonu
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 3: Setting global number option"
- let g:options = [['number', 1, '', 1, 0, 'global', 'setglobal']]
- setglobal nonu
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 4: Setting local autoindent option"
- let g:options = [['autoindent', 0, 0, '', 1, 'local', 'setlocal']]
- setlocal ai
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 5: Setting global autoindent option"
- let g:options = [['autoindent', 0, '', 0, 1, 'global', 'setglobal']]
- setglobal ai
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 6: Setting global autoindent option"
- let g:options = [['autoindent', 1, 1, 1, 0, 'global', 'set']]
- set ai!
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 6a: Setting global autoindent option"
- let g:options = [['autoindent', 1, 1, 0, 0, 'global', 'set']]
- noa setlocal ai
- noa setglobal noai
- set ai!
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " Should not print anything, use :noa
- " 7: don't trigger OptionSet"
- let g:options = [['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid']]
- noa set nonu
- call assert_equal([['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid']], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 8: Setting several global list and number option"
- let g:options = [['list', 0, 0, 0, 1, 'global', 'set'], ['number', 0, 0, 0, 1, 'global', 'set']]
- set list nu
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 9: don't trigger OptionSet"
- let g:options = [['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid'], ['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid']]
- noa set nolist nonu
- call assert_equal([['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid'], ['invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid', 'invalid']], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 10: Setting global acd"
- let g:options = [['autochdir', 0, 0, '', 1, 'local', 'setlocal']]
- setlocal acd
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 11: Setting global autoread (also sets local value)"
- let g:options = [['autoread', 0, 0, 0, 1, 'global', 'set']]
- set ar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 12: Setting local autoread"
- let g:options = [['autoread', 1, 1, '', 1, 'local', 'setlocal']]
- setlocal ar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 13: Setting global autoread"
- let g:options = [['autoread', 1, '', 1, 0, 'global', 'setglobal']]
- setglobal invar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 14: Setting option backspace through :let"
- let g:options = [['backspace', 'indent,eol,start', 'indent,eol,start', 'indent,eol,start', '', 'global', 'set']]
- let &bs = ''
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 15: Setting option backspace through setbufvar()"
- let g:options = [['backup', 0, 0, '', 1, 'local', 'setlocal']]
- " try twice, first time, shouldn't trigger because option name is invalid,
- " second time, it should trigger
- let bnum = bufnr('%')
- call assert_fails("call setbufvar(bnum, '&l:bk', 1)", 'E355:')
- " should trigger, use correct option name
- call setbufvar(bnum, '&backup', 1)
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 16: Setting number option using setwinvar"
- let g:options = [['number', 0, 0, '', 1, 'local', 'setlocal']]
- call setwinvar(0, '&number', 1)
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 17: Setting key option, shouldn't trigger"
- let g:options = [['key', 'invalid', 'invalid1', 'invalid2', 'invalid3', 'invalid4', 'invalid5']]
- setlocal key=blah
- setlocal key=
- call assert_equal([['key', 'invalid', 'invalid1', 'invalid2', 'invalid3', 'invalid4', 'invalid5']], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 18a: Setting string global option"
- let oldval = &backupext
- let g:options = [['backupext', oldval, oldval, oldval, 'foo', 'global', 'set']]
- set backupext=foo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 18b: Resetting string global option"
- let g:options = [['backupext', 'foo', 'foo', 'foo', oldval, 'global', 'set']]
- set backupext&
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 18c: Setting global string global option"
- let g:options = [['backupext', oldval, '', oldval, 'bar', 'global', 'setglobal']]
- setglobal backupext=bar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 18d: Setting local string global option"
- " As this is a global option this sets the global value even though
- " :setlocal is used!
- noa set backupext& " Reset global and local value (without triggering autocmd)
- let g:options = [['backupext', oldval, oldval, '', 'baz', 'local', 'setlocal']]
- setlocal backupext=baz
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 18e: Setting again string global option"
- noa setglobal backupext=ext_global " Reset global and local value (without triggering autocmd)
- noa setlocal backupext=ext_local " Sets the global(!) value!
- let g:options = [['backupext', 'ext_local', 'ext_local', 'ext_local', 'fuu', 'global', 'set']]
- set backupext=fuu
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19a: Setting string global-local (to buffer) option"
- let oldval = &tags
- let g:options = [['tags', oldval, oldval, oldval, 'tagpath', 'global', 'set']]
- set tags=tagpath
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19b: Resetting string global-local (to buffer) option"
- let g:options = [['tags', 'tagpath', 'tagpath', 'tagpath', oldval, 'global', 'set']]
- set tags&
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19c: Setting global string global-local (to buffer) option "
- let g:options = [['tags', oldval, '', oldval, 'tagpath1', 'global', 'setglobal']]
- setglobal tags=tagpath1
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19d: Setting local string global-local (to buffer) option"
- let g:options = [['tags', 'tagpath1', 'tagpath1', '', 'tagpath2', 'local', 'setlocal']]
- setlocal tags=tagpath2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19e: Setting again string global-local (to buffer) option"
- " Note: v:option_old is the old global value for global-local string options
- " but the old local value for all other kinds of options.
- noa setglobal tags=tag_global " Reset global and local value (without triggering autocmd)
- noa setlocal tags=tag_local
- let g:options = [['tags', 'tag_global', 'tag_local', 'tag_global', 'tagpath', 'global', 'set']]
- set tags=tagpath
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 19f: Setting string global-local (to buffer) option to an empty string"
- " Note: v:option_old is the old global value for global-local string options
- " but the old local value for all other kinds of options.
- noa set tags=tag_global " Reset global and local value (without triggering autocmd)
- noa setlocal tags= " empty string
- let g:options = [['tags', 'tag_global', '', 'tag_global', 'tagpath', 'global', 'set']]
- set tags=tagpath
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 20a: Setting string local (to buffer) option"
- let oldval = &spelllang
- let g:options = [['spelllang', oldval, oldval, oldval, 'elvish,klingon', 'global', 'set']]
- set spelllang=elvish,klingon
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 20b: Resetting string local (to buffer) option"
- let g:options = [['spelllang', 'elvish,klingon', 'elvish,klingon', 'elvish,klingon', oldval, 'global', 'set']]
- set spelllang&
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 20c: Setting global string local (to buffer) option"
- let g:options = [['spelllang', oldval, '', oldval, 'elvish', 'global', 'setglobal']]
- setglobal spelllang=elvish
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 20d: Setting local string local (to buffer) option"
- noa set spelllang& " Reset global and local value (without triggering autocmd)
- let g:options = [['spelllang', oldval, oldval, '', 'klingon', 'local', 'setlocal']]
- setlocal spelllang=klingon
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 20e: Setting again string local (to buffer) option"
- " Note: v:option_old is the old global value for global-local string options
- " but the old local value for all other kinds of options.
- noa setglobal spelllang=spellglobal " Reset global and local value (without triggering autocmd)
- noa setlocal spelllang=spelllocal
- let g:options = [['spelllang', 'spelllocal', 'spelllocal', 'spellglobal', 'foo', 'global', 'set']]
- set spelllang=foo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 21a: Setting string global-local (to window) option"
- let oldval = &statusline
- let g:options = [['statusline', oldval, oldval, oldval, 'foo', 'global', 'set']]
- set statusline=foo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 21b: Resetting string global-local (to window) option"
- " Note: v:option_old is the old global value for global-local string options
- " but the old local value for all other kinds of options.
- let g:options = [['statusline', 'foo', 'foo', 'foo', oldval, 'global', 'set']]
- set statusline&
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 21c: Setting global string global-local (to window) option"
- let g:options = [['statusline', oldval, '', oldval, 'bar', 'global', 'setglobal']]
- setglobal statusline=bar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 21d: Setting local string global-local (to window) option"
- noa set statusline& " Reset global and local value (without triggering autocmd)
- let g:options = [['statusline', oldval, oldval, '', 'baz', 'local', 'setlocal']]
- setlocal statusline=baz
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 21e: Setting again string global-local (to window) option"
- " Note: v:option_old is the old global value for global-local string options
- " but the old local value for all other kinds of options.
- noa setglobal statusline=bar " Reset global and local value (without triggering autocmd)
- noa setlocal statusline=baz
- let g:options = [['statusline', 'bar', 'baz', 'bar', 'foo', 'global', 'set']]
- set statusline=foo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 22a: Setting string local (to window) option"
- let oldval = &foldignore
- let g:options = [['foldignore', oldval, oldval, oldval, 'fo', 'global', 'set']]
- set foldignore=fo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 22b: Resetting string local (to window) option"
- let g:options = [['foldignore', 'fo', 'fo', 'fo', oldval, 'global', 'set']]
- set foldignore&
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 22c: Setting global string local (to window) option"
- let g:options = [['foldignore', oldval, '', oldval, 'bar', 'global', 'setglobal']]
- setglobal foldignore=bar
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 22d: Setting local string local (to window) option"
- noa set foldignore& " Reset global and local value (without triggering autocmd)
- let g:options = [['foldignore', oldval, oldval, '', 'baz', 'local', 'setlocal']]
- setlocal foldignore=baz
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 22e: Setting again string local (to window) option"
- noa setglobal foldignore=glob " Reset global and local value (without triggering autocmd)
- noa setlocal foldignore=loc
- let g:options = [['foldignore', 'loc', 'loc', 'glob', 'fo', 'global', 'set']]
- set foldignore=fo
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 23a: Setting global number global option"
- noa setglobal cmdheight=8 " Reset global and local value (without triggering autocmd)
- noa setlocal cmdheight=1 " Sets the global(!) value!
- let g:options = [['cmdheight', '1', '', '1', '2', 'global', 'setglobal']]
- setglobal cmdheight=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 23b: Setting local number global option"
- noa setglobal cmdheight=8 " Reset global and local value (without triggering autocmd)
- noa setlocal cmdheight=1 " Sets the global(!) value!
- let g:options = [['cmdheight', '1', '1', '', '2', 'local', 'setlocal']]
- setlocal cmdheight=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 23c: Setting again number global option"
- noa setglobal cmdheight=8 " Reset global and local value (without triggering autocmd)
- noa setlocal cmdheight=1 " Sets the global(!) value!
- let g:options = [['cmdheight', '1', '1', '1', '2', 'global', 'set']]
- set cmdheight=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 23d: Setting again number global option"
- noa set cmdheight=8 " Reset global and local value (without triggering autocmd)
- let g:options = [['cmdheight', '8', '8', '8', '2', 'global', 'set']]
- set cmdheight=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 24a: Setting global number global-local (to buffer) option"
- noa setglobal undolevels=8 " Reset global and local value (without triggering autocmd)
- noa setlocal undolevels=1
- let g:options = [['undolevels', '8', '', '8', '2', 'global', 'setglobal']]
- setglobal undolevels=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 24b: Setting local number global-local (to buffer) option"
- noa setglobal undolevels=8 " Reset global and local value (without triggering autocmd)
- noa setlocal undolevels=1
- let g:options = [['undolevels', '1', '1', '', '2', 'local', 'setlocal']]
- setlocal undolevels=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 24c: Setting again number global-local (to buffer) option"
- noa setglobal undolevels=8 " Reset global and local value (without triggering autocmd)
- noa setlocal undolevels=1
- let g:options = [['undolevels', '1', '1', '8', '2', 'global', 'set']]
- set undolevels=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 24d: Setting again global number global-local (to buffer) option"
- noa set undolevels=8 " Reset global and local value (without triggering autocmd)
- let g:options = [['undolevels', '8', '8', '8', '2', 'global', 'set']]
- set undolevels=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 25a: Setting global number local (to buffer) option"
- noa setglobal wrapmargin=8 " Reset global and local value (without triggering autocmd)
- noa setlocal wrapmargin=1
- let g:options = [['wrapmargin', '8', '', '8', '2', 'global', 'setglobal']]
- setglobal wrapmargin=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 25b: Setting local number local (to buffer) option"
- noa setglobal wrapmargin=8 " Reset global and local value (without triggering autocmd)
- noa setlocal wrapmargin=1
- let g:options = [['wrapmargin', '1', '1', '', '2', 'local', 'setlocal']]
- setlocal wrapmargin=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 25c: Setting again number local (to buffer) option"
- noa setglobal wrapmargin=8 " Reset global and local value (without triggering autocmd)
- noa setlocal wrapmargin=1
- let g:options = [['wrapmargin', '1', '1', '8', '2', 'global', 'set']]
- set wrapmargin=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 25d: Setting again global number local (to buffer) option"
- noa set wrapmargin=8 " Reset global and local value (without triggering autocmd)
- let g:options = [['wrapmargin', '8', '8', '8', '2', 'global', 'set']]
- set wrapmargin=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 26: Setting number global-local (to window) option.
- " Such option does currently not exist.
- " 27a: Setting global number local (to window) option"
- noa setglobal foldcolumn=8 " Reset global and local value (without triggering autocmd)
- noa setlocal foldcolumn=1
- let g:options = [['foldcolumn', '8', '', '8', '2', 'global', 'setglobal']]
- setglobal foldcolumn=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 27b: Setting local number local (to window) option"
- noa setglobal foldcolumn=8 " Reset global and local value (without triggering autocmd)
- noa setlocal foldcolumn=1
- let g:options = [['foldcolumn', '1', '1', '', '2', 'local', 'setlocal']]
- setlocal foldcolumn=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 27c: Setting again number local (to window) option"
- noa setglobal foldcolumn=8 " Reset global and local value (without triggering autocmd)
- noa setlocal foldcolumn=1
- let g:options = [['foldcolumn', '1', '1', '8', '2', 'global', 'set']]
- set foldcolumn=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 27d: Setting again global number local (to window) option"
- noa set foldcolumn=8 " Reset global and local value (without triggering autocmd)
- let g:options = [['foldcolumn', '8', '8', '8', '2', 'global', 'set']]
- set foldcolumn=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 28a: Setting global boolean global option"
- noa setglobal nowrapscan " Reset global and local value (without triggering autocmd)
- noa setlocal wrapscan " Sets the global(!) value!
- let g:options = [['wrapscan', '1', '', '1', '0', 'global', 'setglobal']]
- setglobal nowrapscan
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 28b: Setting local boolean global option"
- noa setglobal nowrapscan " Reset global and local value (without triggering autocmd)
- noa setlocal wrapscan " Sets the global(!) value!
- let g:options = [['wrapscan', '1', '1', '', '0', 'local', 'setlocal']]
- setlocal nowrapscan
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 28c: Setting again boolean global option"
- noa setglobal nowrapscan " Reset global and local value (without triggering autocmd)
- noa setlocal wrapscan " Sets the global(!) value!
- let g:options = [['wrapscan', '1', '1', '1', '0', 'global', 'set']]
- set nowrapscan
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 28d: Setting again global boolean global option"
- noa set nowrapscan " Reset global and local value (without triggering autocmd)
- let g:options = [['wrapscan', '0', '0', '0', '1', 'global', 'set']]
- set wrapscan
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 29a: Setting global boolean global-local (to buffer) option"
- noa setglobal noautoread " Reset global and local value (without triggering autocmd)
- noa setlocal autoread
- let g:options = [['autoread', '0', '', '0', '1', 'global', 'setglobal']]
- setglobal autoread
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 29b: Setting local boolean global-local (to buffer) option"
- noa setglobal noautoread " Reset global and local value (without triggering autocmd)
- noa setlocal autoread
- let g:options = [['autoread', '1', '1', '', '0', 'local', 'setlocal']]
- setlocal noautoread
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 29c: Setting again boolean global-local (to buffer) option"
- noa setglobal noautoread " Reset global and local value (without triggering autocmd)
- noa setlocal autoread
- let g:options = [['autoread', '1', '1', '0', '1', 'global', 'set']]
- set autoread
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 29d: Setting again global boolean global-local (to buffer) option"
- noa set noautoread " Reset global and local value (without triggering autocmd)
- let g:options = [['autoread', '0', '0', '0', '1', 'global', 'set']]
- set autoread
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 30a: Setting global boolean local (to buffer) option"
- noa setglobal nocindent " Reset global and local value (without triggering autocmd)
- noa setlocal cindent
- let g:options = [['cindent', '0', '', '0', '1', 'global', 'setglobal']]
- setglobal cindent
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 30b: Setting local boolean local (to buffer) option"
- noa setglobal nocindent " Reset global and local value (without triggering autocmd)
- noa setlocal cindent
- let g:options = [['cindent', '1', '1', '', '0', 'local', 'setlocal']]
- setlocal nocindent
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 30c: Setting again boolean local (to buffer) option"
- noa setglobal nocindent " Reset global and local value (without triggering autocmd)
- noa setlocal cindent
- let g:options = [['cindent', '1', '1', '0', '1', 'global', 'set']]
- set cindent
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 30d: Setting again global boolean local (to buffer) option"
- noa set nocindent " Reset global and local value (without triggering autocmd)
- let g:options = [['cindent', '0', '0', '0', '1', 'global', 'set']]
- set cindent
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 31: Setting boolean global-local (to window) option
- " Currently no such option exists.
- " 32a: Setting global boolean local (to window) option"
- noa setglobal nocursorcolumn " Reset global and local value (without triggering autocmd)
- noa setlocal cursorcolumn
- let g:options = [['cursorcolumn', '0', '', '0', '1', 'global', 'setglobal']]
- setglobal cursorcolumn
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 32b: Setting local boolean local (to window) option"
- noa setglobal nocursorcolumn " Reset global and local value (without triggering autocmd)
- noa setlocal cursorcolumn
- let g:options = [['cursorcolumn', '1', '1', '', '0', 'local', 'setlocal']]
- setlocal nocursorcolumn
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 32c: Setting again boolean local (to window) option"
- noa setglobal nocursorcolumn " Reset global and local value (without triggering autocmd)
- noa setlocal cursorcolumn
- let g:options = [['cursorcolumn', '1', '1', '0', '1', 'global', 'set']]
- set cursorcolumn
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 32d: Setting again global boolean local (to window) option"
- noa set nocursorcolumn " Reset global and local value (without triggering autocmd)
- let g:options = [['cursorcolumn', '0', '0', '0', '1', 'global', 'set']]
- set cursorcolumn
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " 33: Test autocommands when an option value is converted internally.
- noa set backspace=1 " Reset global and local value (without triggering autocmd)
- let g:options = [['backspace', 'indent,eol', 'indent,eol', 'indent,eol', '2', 'global', 'set']]
- set backspace=2
- call assert_equal([], g:options)
- call assert_equal(g:opt[0], g:opt[1])
- " Cleanup
- au! OptionSet
- " set tags&
- for opt in ['nu', 'ai', 'acd', 'ar', 'bs', 'backup', 'cul', 'cp', 'backupext', 'tags', 'spelllang', 'statusline', 'foldignore', 'cmdheight', 'undolevels', 'wrapmargin', 'foldcolumn', 'wrapscan', 'autoread', 'cindent', 'cursorcolumn']
- exe printf(":set %s&vim", opt)
- endfor
- call test_override('starting', 0)
- delfunc! AutoCommandOptionSet
- endfunc
- func Test_OptionSet_diffmode()
- CheckFunction test_override
- call test_override('starting', 1)
- " 18: Changing an option when entering diff mode
- new
- au OptionSet diff :let &l:cul = v:option_new
- call setline(1, ['buffer 1', 'line2', 'line3', 'line4'])
- call assert_equal(0, &l:cul)
- diffthis
- call assert_equal(1, &l:cul)
- vnew
- call setline(1, ['buffer 2', 'line 2', 'line 3', 'line4'])
- call assert_equal(0, &l:cul)
- diffthis
- call assert_equal(1, &l:cul)
- diffoff
- call assert_equal(0, &l:cul)
- call assert_equal(1, getwinvar(2, '&l:cul'))
- bw!
- call assert_equal(1, &l:cul)
- diffoff!
- call assert_equal(0, &l:cul)
- call assert_equal(0, getwinvar(1, '&l:cul'))
- bw!
- " Cleanup
- au! OptionSet
- call test_override('starting', 0)
- endfunc
- func Test_OptionSet_diffmode_close()
- CheckFunction test_override
- call test_override('starting', 1)
- " 19: Try to close the current window when entering diff mode
- " should not segfault
- new
- au OptionSet diff close
- call setline(1, ['buffer 1', 'line2', 'line3', 'line4'])
- call assert_fails(':diffthis', 'E788')
- call assert_equal(1, &diff)
- vnew
- call setline(1, ['buffer 2', 'line 2', 'line 3', 'line4'])
- call assert_fails(':diffthis', 'E788')
- call assert_equal(1, &diff)
- set diffopt-=closeoff
- bw!
- call assert_fails(':diffoff!', 'E788')
- bw!
- " Cleanup
- au! OptionSet
- call test_override('starting', 0)
- "delfunc! AutoCommandOptionSet
- endfunc
- " Test for Bufleave autocommand that deletes the buffer we are about to edit.
- func Test_BufleaveWithDelete()
- new | edit XbufLeave1
- augroup test_bufleavewithdelete
- autocmd!
- autocmd BufLeave XbufLeave1 bwipe XbufLeave2
- augroup END
- call assert_fails('edit XbufLeave2', 'E143:')
- call assert_equal('XbufLeave1', bufname('%'))
- autocmd! test_bufleavewithdelete BufLeave XbufLeave1
- augroup! test_bufleavewithdelete
- new
- bwipe! XbufLeave1
- endfunc
- " Test for autocommand that changes the buffer list, when doing ":ball".
- func Test_Acmd_BufAll()
- enew!
- %bwipe!
- call writefile(['Test file Xxx1'], 'Xxx1', 'D')
- call writefile(['Test file Xxx2'], 'Xxx2', 'D')
- call writefile(['Test file Xxx3'], 'Xxx3', 'D')
- " Add three files to the buffer list
- split Xxx1
- close
- split Xxx2
- close
- split Xxx3
- close
- " Wipe the buffer when the buffer is opened
- au BufReadPost Xxx2 bwipe
- call append(0, 'Test file Xxx4')
- ball
- call assert_equal(2, winnr('$'))
- call assert_equal('Xxx1', bufname(winbufnr(winnr('$'))))
- wincmd t
- au! BufReadPost
- %bwipe!
- enew! | only
- endfunc
- " Test for autocommand that changes current buffer on BufEnter event.
- " Check if modelines are interpreted for the correct buffer.
- func Test_Acmd_BufEnter()
- %bwipe!
- call writefile(['start of test file Xxx1',
- \ "\<Tab>this is a test",
- \ 'end of test file Xxx1'], 'Xxx1', 'D')
- call writefile(['start of test file Xxx2',
- \ 'vim: set noai :',
- \ "\<Tab>this is a test",
- \ 'end of test file Xxx2'], 'Xxx2', 'D')
- au BufEnter Xxx2 brew
- set ai modeline modelines=3
- edit Xxx1
- " edit Xxx2, autocmd will do :brew
- edit Xxx2
- exe "normal G?this is a\<CR>"
- " Append text with autoindent to this file
- normal othis should be auto-indented
- call assert_equal("\<Tab>this should be auto-indented", getline('.'))
- call assert_equal(3, line('.'))
- " Remove autocmd and edit Xxx2 again
- au! BufEnter Xxx2
- buf! Xxx2
- exe "normal G?this is a\<CR>"
- " append text without autoindent to Xxx
- normal othis should be in column 1
- call assert_equal("this should be in column 1", getline('.'))
- call assert_equal(4, line('.'))
- %bwipe!
- set ai&vim modeline&vim modelines&vim
- endfunc
- " Test for issue #57
- " do not move cursor on <c-o> when autoindent is set
- func Test_ai_CTRL_O()
- enew!
- set ai
- let save_fo = &fo
- set fo+=r
- exe "normal o# abcdef\<Esc>2hi\<CR>\<C-O>d0\<Esc>"
- exe "normal o# abcdef\<Esc>2hi\<C-O>d0\<Esc>"
- call assert_equal(['# abc', 'def', 'def'], getline(2, 4))
- set ai&vim
- let &fo = save_fo
- enew!
- endfunc
- " Test for autocommand that deletes the current buffer on BufLeave event.
- " Also test deleting the last buffer, should give a new, empty buffer.
- func Test_BufLeave_Wipe()
- %bwipe!
- let content = ['start of test file Xxx',
- \ 'this is a test',
- \ 'end of test file Xxx']
- call writefile(content, 'Xxx1', 'D')
- call writefile(content, 'Xxx2', 'D')
- au BufLeave Xxx2 bwipe
- edit Xxx1
- split Xxx2
- " delete buffer Xxx2, we should be back to Xxx1
- bwipe
- call assert_equal('Xxx1', bufname('%'))
- call assert_equal(1, winnr('$'))
- " Create an alternate buffer
- %write! test.out
- call assert_equal('test.out', bufname('#'))
- " delete alternate buffer
- bwipe test.out
- call assert_equal('Xxx1', bufname('%'))
- call assert_equal('', bufname('#'))
- au BufLeave Xxx1 bwipe
- " delete current buffer, get an empty one
- bwipe!
- call assert_equal(1, line('$'))
- call assert_equal('', bufname('%'))
- let g:bufinfo = getbufinfo()
- call assert_equal(1, len(g:bufinfo))
- call delete('test.out')
- %bwipe
- au! BufLeave
- " check that bufinfo doesn't contain a pointer to freed memory
- call test_garbagecollect_now()
- endfunc
- func Test_QuitPre()
- edit Xfoo
- let winid = win_getid(winnr())
- split Xbar
- au! QuitPre * let g:afile = expand('<afile>')
- " Close the other window, <afile> should be correct.
- exe win_id2win(winid) . 'q'
- call assert_equal('Xfoo', g:afile)
-
- unlet g:afile
- bwipe Xfoo
- bwipe Xbar
- endfunc
- func Test_Cmdline()
- au! CmdlineChanged : let g:text = getcmdline()
- let g:text = 0
- call feedkeys(":echom 'hello'\<CR>", 'xt')
- call assert_equal("echom 'hello'", g:text)
- au! CmdlineChanged
- au! CmdlineChanged : let g:entered = expand('<afile>')
- let g:entered = 0
- call feedkeys(":echom 'hello'\<CR>", 'xt')
- call assert_equal(':', g:entered)
- au! CmdlineChanged
- autocmd CmdlineChanged : let g:log += [getcmdline()]
- let g:log = []
- cnoremap <F1> <Cmd>call setcmdline('ls')<CR>
- call feedkeys(":\<F1>", 'xt')
- call assert_equal(['ls'], g:log)
- cunmap <F1>
- let g:log = []
- call feedkeys(":sign \<Tab>\<Tab>\<C-N>\<C-P>\<S-Tab>\<S-Tab>\<Esc>", 'xt')
- call assert_equal([
- \ 's',
- \ 'si',
- \ 'sig',
- \ 'sign',
- \ 'sign ',
- \ 'sign define',
- \ 'sign jump',
- \ 'sign list',
- \ 'sign jump',
- \ 'sign define',
- \ 'sign ',
- \ ], g:log)
- let g:log = []
- set wildmenu wildoptions+=pum
- call feedkeys(":sign \<S-Tab>\<PageUp>\<kPageUp>\<kPageDown>\<PageDown>\<Esc>", 'xt')
- call assert_equal([
- \ 's',
- \ 'si',
- \ 'sig',
- \ 'sign',
- \ 'sign ',
- \ 'sign unplace',
- \ 'sign jump',
- \ 'sign define',
- \ 'sign undefine',
- \ 'sign unplace',
- \ ], g:log)
- set wildmenu& wildoptions&
- let g:log = []
- let @r = 'abc'
- call feedkeys(":0\<C-R>r1\<C-R>\<C-O>r2\<C-R>\<C-R>r3\<Esc>", 'xt')
- call assert_equal([
- \ '0',
- \ '0a',
- \ '0ab',
- \ '0abc',
- \ '0abc1',
- \ '0abc1abc',
- \ '0abc1abc2',
- \ '0abc1abc2abc',
- \ '0abc1abc2abc3',
- \ ], g:log)
- unlet g:log
- au! CmdlineChanged
- au! CmdlineEnter : let g:entered = expand('<afile>')
- au! CmdlineLeave : let g:left = expand('<afile>')
- let g:entered = 0
- let g:left = 0
- call feedkeys(":echo 'hello'\<CR>", 'xt')
- call assert_equal(':', g:entered)
- call assert_equal(':', g:left)
- au! CmdlineEnter
- au! CmdlineLeave
- let save_shellslash = &shellslash
- " Nvim doesn't allow setting value of a hidden option to non-default value
- if exists('+shellslash')
- set noshellslash
- endif
- au! CmdlineEnter / let g:entered = expand('<afile>')
- au! CmdlineLeave / let g:left = expand('<afile>')
- let g:entered = 0
- let g:left = 0
- new
- call setline(1, 'hello')
- call feedkeys("/hello\<CR>", 'xt')
- call assert_equal('/', g:entered)
- call assert_equal('/', g:left)
- bwipe!
- au! CmdlineEnter
- au! CmdlineLeave
- let &shellslash = save_shellslash
- au! CursorMovedC : let g:pos += [getcmdpos()]
- let g:pos = []
- call feedkeys(":foo bar baz\<C-W>\<C-W>\<C-W>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 9, 5, 1], g:pos)
- let g:pos = []
- call feedkeys(":hello\<C-B>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 1], g:pos)
- let g:pos = []
- call feedkeys(":hello\<C-U>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 1], g:pos)
- let g:pos = []
- call feedkeys(":hello\<Left>\<C-R>=''\<CR>\<Left>\<Right>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 5, 4, 5], g:pos)
- let g:pos = []
- call feedkeys(":12345678\<C-R>=setcmdpos(3)??''\<CR>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 3], g:pos)
- let g:pos = []
- call feedkeys(":12345678\<C-R>=setcmdpos(3)??''\<CR>\<Left>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 7, 8, 9, 3, 2], g:pos)
- au! CursorMovedC
- " setcmdpos() is no-op inside an autocommand
- au! CursorMovedC : let g:pos += [getcmdpos()] | call setcmdpos(1)
- let g:pos = []
- call feedkeys(":hello\<Left>\<Left>\<Esc>", 'xt')
- call assert_equal([2, 3, 4, 5, 6, 5, 4], g:pos)
- au! CursorMovedC
- unlet g:entered
- unlet g:left
- unlet g:pos
- endfunc
- " Test for BufWritePre autocommand that deletes or unloads the buffer.
- func Test_BufWritePre()
- %bwipe
- au BufWritePre Xxx1 bunload
- au BufWritePre Xxx2 bwipe
- call writefile(['start of Xxx1', 'test', 'end of Xxx1'], 'Xxx1', 'D')
- call writefile(['start of Xxx2', 'test', 'end of Xxx2'], 'Xxx2', 'D')
- edit Xtest
- e! Xxx2
- bdel Xtest
- e Xxx1
- " write it, will unload it and give an error msg
- call assert_fails('w', 'E203:')
- call assert_equal('Xxx2', bufname('%'))
- edit Xtest
- e! Xxx2
- bwipe Xtest
- " write it, will delete the buffer and give an error msg
- call assert_fails('w', 'E203:')
- call assert_equal('Xxx1', bufname('%'))
- au! BufWritePre
- endfunc
- " Test for BufUnload autocommand that unloads all the other buffers
- func Test_bufunload_all()
- let g:test_is_flaky = 1
- call writefile(['Test file Xxx1'], 'Xxx1', 'D')
- call writefile(['Test file Xxx2'], 'Xxx2', 'D')
- let content =<< trim [CODE]
- func UnloadAllBufs()
- let i = 1
- while i <= bufnr('$')
- if i != bufnr('%') && bufloaded(i)
- exe i . 'bunload'
- endif
- let i += 1
- endwhile
- endfunc
- au BufUnload * call UnloadAllBufs()
- au VimLeave * call writefile(['Test Finished'], 'Xout')
- set nohidden
- edit Xxx1
- split Xxx2
- q
- [CODE]
- call writefile(content, 'Xbunloadtest', 'D')
- call delete('Xout')
- call system(GetVimCommandClean() .. ' -N --headless -S Xbunloadtest')
- call assert_true(filereadable('Xout'))
- call delete('Xout')
- endfunc
- " Some tests for buffer-local autocommands
- func Test_buflocal_autocmd()
- let g:bname = ''
- edit xx
- au BufLeave <buffer> let g:bname = expand("%")
- " here, autocommand for xx should trigger.
- " but autocommand shall not apply to buffer named <buffer>.
- edit somefile
- call assert_equal('xx', g:bname)
- let g:bname = ''
- " here, autocommand shall be auto-deleted
- bwipe xx
- " autocmd should not trigger
- edit xx
- call assert_equal('', g:bname)
- " autocmd should not trigger
- edit somefile
- call assert_equal('', g:bname)
- enew
- unlet g:bname
- endfunc
- " Test for "*Cmd" autocommands
- func Test_Cmd_Autocmds()
- call writefile(['start of Xxx', "\tabc2", 'end of Xxx'], 'Xxx', 'D')
- enew!
- au BufReadCmd XtestA 0r Xxx|$del
- edit XtestA " will read text of Xxd instead
- call assert_equal('start of Xxx', getline(1))
- au BufWriteCmd XtestA call append(line("$"), "write")
- write " will append a line to the file
- call assert_equal('write', getline('$'))
- call assert_fails('read XtestA', 'E484') " should not read anything
- call assert_equal('write', getline(4))
- " now we have:
- " 1 start of Xxx
- " 2 abc2
- " 3 end of Xxx
- " 4 write
- au FileReadCmd XtestB '[r Xxx
- 2r XtestB " will read Xxx below line 2 instead
- call assert_equal('start of Xxx', getline(3))
- " now we have:
- " 1 start of Xxx
- " 2 abc2
- " 3 start of Xxx
- " 4 abc2
- " 5 end of Xxx
- " 6 end of Xxx
- " 7 write
- au FileWriteCmd XtestC '[,']copy $
- normal 4GA1
- 4,5w XtestC " will copy lines 4 and 5 to the end
- call assert_equal("\tabc21", getline(8))
- call assert_fails('r XtestC', 'E484') " should not read anything
- call assert_equal("end of Xxx", getline(9))
- " now we have:
- " 1 start of Xxx
- " 2 abc2
- " 3 start of Xxx
- " 4 abc21
- " 5 end of Xxx
- " 6 end of Xxx
- " 7 write
- " 8 abc21
- " 9 end of Xxx
- let g:lines = []
- au FileAppendCmd XtestD call extend(g:lines, getline(line("'["), line("']")))
- w >>XtestD " will add lines to 'lines'
- call assert_equal(9, len(g:lines))
- call assert_fails('$r XtestD', 'E484') " should not read anything
- call assert_equal(9, line('$'))
- call assert_equal('end of Xxx', getline('$'))
- au BufReadCmd XtestE 0r Xxx|$del
- sp XtestE " split window with test.out
- call assert_equal('end of Xxx', getline(3))
- let g:lines = []
- exe "normal 2Goasdf\<Esc>\<C-W>\<C-W>"
- au BufWriteCmd XtestE call extend(g:lines, getline(0, '$'))
- wall " will write other window to 'lines'
- call assert_equal(4, len(g:lines), g:lines)
- call assert_equal("asdf", g:lines[2])
- au! BufReadCmd
- au! BufWriteCmd
- au! FileReadCmd
- au! FileWriteCmd
- au! FileAppendCmd
- %bwipe!
- enew!
- endfunc
- func s:ReadFile()
- setl noswapfile nomodified
- let filename = resolve(expand("<afile>:p"))
- execute 'read' fnameescape(filename)
- 1d_
- exe 'file' fnameescape(filename)
- setl buftype=acwrite
- endfunc
- func s:WriteFile()
- let filename = resolve(expand("<afile>:p"))
- setl buftype=
- noautocmd execute 'write' fnameescape(filename)
- setl buftype=acwrite
- setl nomodified
- endfunc
- func Test_BufReadCmd()
- autocmd BufReadCmd *.test call s:ReadFile()
- autocmd BufWriteCmd *.test call s:WriteFile()
- call writefile(['one', 'two', 'three'], 'Xcmd.test', 'D')
- edit Xcmd.test
- call assert_match('Xcmd.test" line 1 of 3', execute('file'))
- normal! Gofour
- write
- call assert_equal(['one', 'two', 'three', 'four'], readfile('Xcmd.test'))
- bwipe!
- au! BufReadCmd
- au! BufWriteCmd
- endfunc
- func Test_BufWriteCmd()
- autocmd BufWriteCmd Xbufwritecmd let g:written = 1
- new
- file Xbufwritecmd
- set buftype=acwrite
- call mkdir('Xbufwritecmd', 'D')
- write
- " BufWriteCmd should be triggered even if a directory has the same name
- call assert_equal(1, g:written)
- unlet g:written
- au! BufWriteCmd
- bwipe!
- endfunc
- func SetChangeMarks(start, end)
- exe a:start .. 'mark ['
- exe a:end .. 'mark ]'
- endfunc
- " Verify the effects of autocmds on '[ and ']
- func Test_change_mark_in_autocmds()
- edit! Xtest
- call feedkeys("ia\<CR>b\<CR>c\<CR>d\<C-g>u\<Esc>", 'xtn')
- call SetChangeMarks(2, 3)
- write
- call assert_equal([1, 4], [line("'["), line("']")])
- call SetChangeMarks(2, 3)
- au BufWritePre * call assert_equal([1, 4], [line("'["), line("']")])
- write
- au! BufWritePre
- if has('unix')
- write XtestFilter
- write >> XtestFilter
- call SetChangeMarks(2, 3)
- " Marks are set to the entire range of the write
- au FilterWritePre * call assert_equal([1, 4], [line("'["), line("']")])
- " '[ is adjusted to just before the line that will receive the filtered
- " data
- au FilterReadPre * call assert_equal([4, 4], [line("'["), line("']")])
- " The filtered data is read into the buffer, and the source lines are
- " still present, so the range is after the source lines
- au FilterReadPost * call assert_equal([5, 12], [line("'["), line("']")])
- %!cat XtestFilter
- " After the filtered data is read, the original lines are deleted
- call assert_equal([1, 8], [line("'["), line("']")])
- au! FilterWritePre,FilterReadPre,FilterReadPost
- undo
- call SetChangeMarks(1, 4)
- au FilterWritePre * call assert_equal([2, 3], [line("'["), line("']")])
- au FilterReadPre * call assert_equal([3, 3], [line("'["), line("']")])
- au FilterReadPost * call assert_equal([4, 11], [line("'["), line("']")])
- 2,3!cat XtestFilter
- call assert_equal([2, 9], [line("'["), line("']")])
- au! FilterWritePre,FilterReadPre,FilterReadPost
- undo
- call delete('XtestFilter')
- endif
- call SetChangeMarks(1, 4)
- au FileWritePre * call assert_equal([2, 3], [line("'["), line("']")])
- 2,3write Xtest2
- au! FileWritePre
- call SetChangeMarks(2, 3)
- au FileAppendPre * call assert_equal([1, 4], [line("'["), line("']")])
- write >> Xtest2
- au! FileAppendPre
- call SetChangeMarks(1, 4)
- au FileAppendPre * call assert_equal([2, 3], [line("'["), line("']")])
- 2,3write >> Xtest2
- au! FileAppendPre
- call SetChangeMarks(1, 1)
- au FileReadPre * call assert_equal([3, 1], [line("'["), line("']")])
- au FileReadPost * call assert_equal([4, 11], [line("'["), line("']")])
- 3read Xtest2
- au! FileReadPre,FileReadPost
- undo
- call SetChangeMarks(4, 4)
- " When the line is 0, it's adjusted to 1
- au FileReadPre * call assert_equal([1, 4], [line("'["), line("']")])
- au FileReadPost * call assert_equal([1, 8], [line("'["), line("']")])
- 0read Xtest2
- au! FileReadPre,FileReadPost
- undo
- call SetChangeMarks(4, 4)
- " When the line is 0, it's adjusted to 1
- au FileReadPre * call assert_equal([1, 4], [line("'["), line("']")])
- au FileReadPost * call assert_equal([2, 9], [line("'["), line("']")])
- 1read Xtest2
- au! FileReadPre,FileReadPost
- undo
- bwipe!
- call delete('Xtest')
- call delete('Xtest2')
- endfunc
- func Test_Filter_noshelltemp()
- CheckExecutable cat
- enew!
- call setline(1, ['a', 'b', 'c', 'd'])
- let shelltemp = &shelltemp
- set shelltemp
- let g:filter_au = 0
- au FilterWritePre * let g:filter_au += 1
- au FilterReadPre * let g:filter_au += 1
- au FilterReadPost * let g:filter_au += 1
- %!cat
- call assert_equal(3, g:filter_au)
- if has('filterpipe')
- set noshelltemp
- let g:filter_au = 0
- au FilterWritePre * let g:filter_au += 1
- au FilterReadPre * let g:filter_au += 1
- au FilterReadPost * let g:filter_au += 1
- %!cat
- call assert_equal(0, g:filter_au)
- endif
- au! FilterWritePre,FilterReadPre,FilterReadPost
- let &shelltemp = shelltemp
- bwipe!
- endfunc
- func Test_TextYankPost()
- enew!
- call setline(1, ['foo'])
- let g:event = []
- au TextYankPost * let g:event = copy(v:event)
- call assert_equal({}, v:event)
- call assert_fails('let v:event = {}', 'E46:')
- call assert_fails('let v:event.mykey = 0', 'E742:')
- norm "ayiw
- call assert_equal(
- \{'regcontents': ['foo'], 'inclusive': v:true, 'regname': 'a', 'operator': 'y', 'visual': v:false, 'regtype': 'v'},
- \g:event)
- norm y_
- call assert_equal(
- \{'regcontents': ['foo'], 'inclusive': v:false, 'regname': '', 'operator': 'y', 'visual': v:false, 'regtype': 'V'},
- \g:event)
- norm Vy
- call assert_equal(
- \{'regcontents': ['foo'], 'inclusive': v:true, 'regname': '', 'operator': 'y', 'visual': v:true, 'regtype': 'V'},
- \g:event)
- call feedkeys("\<C-V>y", 'x')
- call assert_equal(
- \{'regcontents': ['f'], 'inclusive': v:true, 'regname': '', 'operator': 'y', 'visual': v:true, 'regtype': "\x161"},
- \g:event)
- norm "xciwbar
- call assert_equal(
- \{'regcontents': ['foo'], 'inclusive': v:true, 'regname': 'x', 'operator': 'c', 'visual': v:false, 'regtype': 'v'},
- \g:event)
- norm "bdiw
- call assert_equal(
- \{'regcontents': ['bar'], 'inclusive': v:true, 'regname': 'b', 'operator': 'd', 'visual': v:false, 'regtype': 'v'},
- \g:event)
- call assert_equal({}, v:event)
- au! TextYankPost
- unlet g:event
- bwipe!
- endfunc
- func Test_autocommand_all_events()
- call assert_fails('au * * bwipe', 'E1155:')
- call assert_fails('au * x bwipe', 'E1155:')
- call assert_fails('au! * x bwipe', 'E1155:')
- endfunc
- func Test_autocmd_user()
- au User MyEvent let s:res = [expand("<afile>"), expand("<amatch>")]
- doautocmd User MyEvent
- call assert_equal(['MyEvent', 'MyEvent'], s:res)
- au! User
- unlet s:res
- endfunc
- function s:Before_test_dirchanged()
- augroup test_dirchanged
- autocmd!
- augroup END
- let s:li = []
- let s:dir_this = getcwd()
- let s:dir_foo = s:dir_this . '/Xfoo'
- call mkdir(s:dir_foo)
- let s:dir_bar = s:dir_this . '/Xbar'
- call mkdir(s:dir_bar)
- endfunc
- function s:After_test_dirchanged()
- call chdir(s:dir_this)
- call delete(s:dir_foo, 'd')
- call delete(s:dir_bar, 'd')
- augroup test_dirchanged
- autocmd!
- augroup END
- endfunc
- function Test_dirchanged_global()
- call s:Before_test_dirchanged()
- autocmd test_dirchanged DirChangedPre global call add(s:li, expand("<amatch>") .. " pre cd " .. v:event.directory)
- autocmd test_dirchanged DirChanged global call add(s:li, "cd:")
- autocmd test_dirchanged DirChanged global call add(s:li, expand("<afile>"))
- call chdir(s:dir_foo)
- let expected = ["global pre cd " .. s:dir_foo, "cd:", s:dir_foo]
- call assert_equal(expected, s:li)
- call chdir(s:dir_foo)
- call assert_equal(expected, s:li)
- exe 'lcd ' .. fnameescape(s:dir_bar)
- call assert_equal(expected, s:li)
- exe 'cd ' .. s:dir_foo
- exe 'cd ' .. s:dir_bar
- autocmd! test_dirchanged DirChanged global let g:result = expand("<afile>")
- cd -
- call assert_equal(s:dir_foo, substitute(g:result, '\\', '/', 'g'))
- call s:After_test_dirchanged()
- endfunc
- function Test_dirchanged_local()
- call s:Before_test_dirchanged()
- autocmd test_dirchanged DirChanged window call add(s:li, "lcd:")
- autocmd test_dirchanged DirChanged window call add(s:li, expand("<afile>"))
- call chdir(s:dir_foo)
- call assert_equal([], s:li)
- exe 'lcd ' .. fnameescape(s:dir_bar)
- call assert_equal(["lcd:", s:dir_bar], s:li)
- exe 'lcd ' .. fnameescape(s:dir_bar)
- call assert_equal(["lcd:", s:dir_bar], s:li)
- call s:After_test_dirchanged()
- endfunc
- function Test_dirchanged_auto()
- CheckFunction test_autochdir
- CheckOption autochdir
- call s:Before_test_dirchanged()
- call test_autochdir()
- autocmd test_dirchanged DirChangedPre auto call add(s:li, "pre cd " .. v:event.directory)
- autocmd test_dirchanged DirChanged auto call add(s:li, "auto:")
- autocmd test_dirchanged DirChanged auto call add(s:li, expand("<afile>"))
- set acd
- cd ..
- call assert_equal([], s:li)
- exe 'edit ' . s:dir_foo . '/Xautofile'
- call assert_equal(s:dir_foo, getcwd())
- let expected = ["pre cd " .. s:dir_foo, "auto:", s:dir_foo]
- call assert_equal(expected, s:li)
- set noacd
- bwipe!
- call s:After_test_dirchanged()
- endfunc
- " Test TextChangedI and TextChangedP
- func Test_ChangedP()
- throw 'Skipped: use test/functional/autocmd/textchanged_spec.lua'
- new
- call setline(1, ['foo', 'bar', 'foobar'])
- call test_override("char_avail", 1)
- set complete=. completeopt=menuone
- func! TextChangedAutocmd(char)
- let g:autocmd .= a:char
- endfunc
- " TextChanged will not be triggered, only check that it isn't.
- au! TextChanged <buffer> :call TextChangedAutocmd('N')
- au! TextChangedI <buffer> :call TextChangedAutocmd('I')
- au! TextChangedP <buffer> :call TextChangedAutocmd('P')
- call cursor(3, 1)
- let g:autocmd = ''
- call feedkeys("o\<esc>", 'tnix')
- call assert_equal('I', g:autocmd)
- let g:autocmd = ''
- call feedkeys("Sf", 'tnix')
- call assert_equal('II', g:autocmd)
- let g:autocmd = ''
- call feedkeys("Sf\<C-N>", 'tnix')
- call assert_equal('IIP', g:autocmd)
- let g:autocmd = ''
- call feedkeys("Sf\<C-N>\<C-N>", 'tnix')
- call assert_equal('IIPP', g:autocmd)
- let g:autocmd = ''
- call feedkeys("Sf\<C-N>\<C-N>\<C-N>", 'tnix')
- call assert_equal('IIPPP', g:autocmd)
- let g:autocmd = ''
- call feedkeys("Sf\<C-N>\<C-N>\<C-N>\<C-N>", 'tnix')
- call assert_equal('IIPPPP', g:autocmd)
- call assert_equal(['foo', 'bar', 'foobar', 'foo'], getline(1, '$'))
- " TODO: how should it handle completeopt=noinsert,noselect?
- " CleanUp
- call test_override("char_avail", 0)
- au! TextChanged
- au! TextChangedI
- au! TextChangedP
- delfu TextChangedAutocmd
- unlet! g:autocmd
- set complete&vim completeopt&vim
- bw!
- endfunc
- let g:setline_handled = v:false
- func SetLineOne()
- if !g:setline_handled
- call setline(1, "(x)")
- let g:setline_handled = v:true
- endif
- endfunc
- func Test_TextChangedI_with_setline()
- throw 'Skipped: use test/functional/autocmd/textchanged_spec.lua'
- new
- call test_override('char_avail', 1)
- autocmd TextChangedI <buffer> call SetLineOne()
- call feedkeys("i(\<CR>\<Esc>", 'tx')
- call assert_equal('(', getline(1))
- call assert_equal('x)', getline(2))
- undo
- call assert_equal('', getline(1))
- call assert_equal('', getline(2))
- call test_override('char_avail', 0)
- bwipe!
- endfunc
- func Test_TextChanged_with_norm()
- " For unknown reason this fails on MS-Windows
- CheckNotMSWindows
- CheckFeature terminal
- let buf = term_start([GetVimProg(), '--clean', '-c', 'set noswapfile'], {'term_rows': 3})
- call assert_equal('running', term_getstatus(buf))
- call term_sendkeys(buf, ":let g:a=0\<cr>")
- call term_wait(buf, 50)
- call term_sendkeys(buf, ":au! TextChanged * :let g:a+=1\<cr>")
- call term_wait(buf, 50)
- call term_sendkeys(buf, ":norm! ia\<cr>")
- call term_wait(buf, 50)
- call term_sendkeys(buf, ":echo g:a\<cr>")
- call term_wait(buf, 50)
- call WaitForAssert({-> assert_match('^1.*$', term_getline(buf, 3))})
- bwipe!
- endfunc
- func Test_Changed_FirstTime()
- CheckFeature terminal
- CheckNotGui
- " Starting a terminal to run Vim is always considered flaky.
- let g:test_is_flaky = 1
- " Prepare file for TextChanged event.
- call writefile([''], 'Xchanged.txt', 'D')
- let buf = term_start([GetVimProg(), '--clean', '-c', 'set noswapfile'], {'term_rows': 3})
- call assert_equal('running', term_getstatus(buf))
- " Wait for the ruler (in the status line) to be shown.
- " In ConPTY, there is additional character which is drawn up to the width of
- " the screen.
- if has('conpty')
- call WaitForAssert({-> assert_match('\<All.*$', term_getline(buf, 3))})
- else
- call WaitForAssert({-> assert_match('\<All$', term_getline(buf, 3))})
- endif
- " It's only adding autocmd, so that no event occurs.
- call term_sendkeys(buf, ":au! TextChanged <buffer> call writefile(['No'], 'Xchanged.txt')\<cr>")
- call term_sendkeys(buf, "\<C-\\>\<C-N>:qa!\<cr>")
- call WaitForAssert({-> assert_equal('finished', term_getstatus(buf))})
- call assert_equal([''], readfile('Xchanged.txt'))
- " clean up
- bwipe!
- endfunc
- func Test_autocmd_nested()
- let g:did_nested = 0
- augroup Testing
- au WinNew * edit somefile
- au BufNew * let g:did_nested = 1
- augroup END
- split
- call assert_equal(0, g:did_nested)
- close
- bwipe! somefile
- " old nested argument still works
- augroup Testing
- au!
- au WinNew * nested edit somefile
- au BufNew * let g:did_nested = 1
- augroup END
- split
- call assert_equal(1, g:did_nested)
- close
- bwipe! somefile
- " New ++nested argument works
- augroup Testing
- au!
- au WinNew * ++nested edit somefile
- au BufNew * let g:did_nested = 1
- augroup END
- split
- call assert_equal(1, g:did_nested)
- close
- bwipe! somefile
- augroup Testing
- au!
- augroup END
- call assert_fails('au WinNew * ++nested ++nested echo bad', 'E983:')
- call assert_fails('au WinNew * nested nested echo bad', 'E983:')
- endfunc
- func Test_autocmd_nested_cursor_invalid()
- set laststatus=0
- copen
- cclose
- call setline(1, ['foo', 'bar', 'baz'])
- 3
- augroup nested_inv
- autocmd User foo ++nested copen
- autocmd BufAdd * let &laststatus = 2 - &laststatus
- augroup END
- doautocmd User foo
- augroup nested_inv
- au!
- augroup END
- set laststatus&
- cclose
- bwipe!
- endfunc
- func Test_autocmd_nested_keeps_cursor_pos()
- enew
- call setline(1, 'foo')
- autocmd User foo ++nested normal! $a
- autocmd InsertLeave * :
- doautocmd User foo
- call assert_equal([0, 1, 3, 0], getpos('.'))
- bwipe!
- endfunc
- func Test_autocmd_nested_switch_window()
- " run this in a separate Vim so that SafeState works
- CheckRunVimInTerminal
- let lines =<< trim END
- vim9script
- ['()']->writefile('Xautofile')
- autocmd VimEnter * ++nested edit Xautofile | split
- autocmd BufReadPost * autocmd SafeState * ++once foldclosed('.')
- autocmd WinEnter * matchadd('ErrorMsg', 'pat')
- END
- call writefile(lines, 'Xautoscript', 'D')
- let buf = RunVimInTerminal('-S Xautoscript', {'rows': 10})
- call VerifyScreenDump(buf, 'Test_autocmd_nested_switch', {})
- call StopVimInTerminal(buf)
- call delete('Xautofile')
- endfunc
- func Test_autocmd_once()
- " Without ++once WinNew triggers twice
- let g:did_split = 0
- augroup Testing
- au WinNew * let g:did_split += 1
- augroup END
- split
- split
- call assert_equal(2, g:did_split)
- call assert_true(exists('#WinNew'))
- close
- close
- " With ++once WinNew triggers once
- let g:did_split = 0
- augroup Testing
- au!
- au WinNew * ++once let g:did_split += 1
- augroup END
- split
- split
- call assert_equal(1, g:did_split)
- call assert_false(exists('#WinNew'))
- close
- close
- call assert_fails('au WinNew * ++once ++once echo bad', 'E983:')
- endfunc
- func Test_autocmd_bufreadpre()
- new
- let b:bufreadpre = 1
- call append(0, range(100))
- w! XAutocmdBufReadPre.txt
- autocmd BufReadPre <buffer> :let b:bufreadpre += 1
- norm! 50gg
- sp
- norm! 100gg
- wincmd p
- let g:wsv1 = winsaveview()
- wincmd p
- let g:wsv2 = winsaveview()
- " triggers BufReadPre, should not move the cursor in either window
- " The topline may change one line in a large window.
- edit
- call assert_inrange(g:wsv2.topline - 1, g:wsv2.topline + 1, winsaveview().topline)
- call assert_equal(g:wsv2.lnum, winsaveview().lnum)
- call assert_equal(2, b:bufreadpre)
- wincmd p
- call assert_equal(g:wsv1.topline, winsaveview().topline)
- call assert_equal(g:wsv1.lnum, winsaveview().lnum)
- call assert_equal(2, b:bufreadpre)
- " Now set the cursor position in an BufReadPre autocommand
- " (even though the position will be invalid, this should make Vim reset the
- " cursor position in the other window.
- wincmd p
- 1 " set cpo+=g
- " won't do anything, but try to set the cursor on an invalid lnum
- autocmd BufReadPre <buffer> :norm! 70gg
- " triggers BufReadPre, should not move the cursor in either window
- e
- call assert_equal(1, winsaveview().topline)
- call assert_equal(1, winsaveview().lnum)
- call assert_equal(3, b:bufreadpre)
- wincmd p
- call assert_equal(g:wsv1.topline, winsaveview().topline)
- call assert_equal(g:wsv1.lnum, winsaveview().lnum)
- call assert_equal(3, b:bufreadpre)
- close
- close
- call delete('XAutocmdBufReadPre.txt')
- set cpo-=g
- endfunc
- " FileChangedShell tested in test_filechanged.vim
- " Tests for the following autocommands:
- " - FileWritePre writing a compressed file
- " - FileReadPost reading a compressed file
- " - BufNewFile reading a file template
- " - BufReadPre decompressing the file to be read
- " - FilterReadPre substituting characters in the temp file
- " - FilterReadPost substituting characters after filtering
- " - FileReadPre set options for decompression
- " - FileReadPost decompress the file
- func Test_ReadWrite_Autocmds()
- " Run this test only on Unix-like systems and if gzip is available
- if !has('unix') || !executable("gzip")
- return
- endif
- " Make $GZIP empty, "-v" would cause trouble.
- let $GZIP = ""
- " Use a FileChangedShell autocommand to avoid a prompt for 'Xtestfile.gz'
- " being modified outside of Vim (noticed on Solaris).
- au FileChangedShell * echo 'caught FileChangedShell'
- " Test for the FileReadPost, FileWritePre and FileWritePost autocmds
- augroup Test1
- au!
- au FileWritePre *.gz '[,']!gzip
- au FileWritePost *.gz undo
- au FileReadPost *.gz '[,']!gzip -d
- augroup END
- new
- set bin
- call append(0, [
- \ 'line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ])
- 1,9write! Xtestfile.gz
- enew! | close
- new
- " Read and decompress the testfile
- 0read Xtestfile.gz
- call assert_equal([
- \ 'line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ], getline(1, 9))
- enew! | close
- augroup Test1
- au!
- augroup END
- " Test for the FileAppendPre and FileAppendPost autocmds
- augroup Test2
- au!
- au BufNewFile *.c read Xtest.c
- au FileAppendPre *.out '[,']s/new/NEW/
- au FileAppendPost *.out !cat Xtest.c >> test.out
- augroup END
- call writefile(['/*', ' * Here is a new .c file', ' */'], 'Xtest.c', 'D')
- new foo.c " should load Xtest.c
- call assert_equal(['/*', ' * Here is a new .c file', ' */'], getline(2, 4))
- w! >> test.out " append it to the output file
- let contents = readfile('test.out')
- call assert_equal(' * Here is a NEW .c file', contents[2])
- call assert_equal(' * Here is a new .c file', contents[5])
- call delete('test.out')
- enew! | close
- augroup Test2
- au!
- augroup END
- " Test for the BufReadPre and BufReadPost autocmds
- augroup Test3
- au!
- " setup autocommands to decompress before reading and re-compress
- " afterwards
- au BufReadPre *.gz exe '!gzip -d ' . shellescape(expand("<afile>"))
- au BufReadPre *.gz call rename(expand("<afile>:r"), expand("<afile>"))
- au BufReadPost *.gz call rename(expand("<afile>"), expand("<afile>:r"))
- au BufReadPost *.gz exe '!gzip ' . shellescape(expand("<afile>:r"))
- augroup END
- e! Xtestfile.gz " Edit compressed file
- call assert_equal([
- \ 'line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ], getline(1, 9))
- w! >> test.out " Append it to the output file
- augroup Test3
- au!
- augroup END
- " Test for the FilterReadPre and FilterReadPost autocmds.
- set shelltemp " need temp files here
- augroup Test4
- au!
- au FilterReadPre *.out call rename(expand("<afile>"), expand("<afile>") . ".t")
- au FilterReadPre *.out exe 'silent !sed s/e/E/ ' . shellescape(expand("<afile>")) . ".t >" . shellescape(expand("<afile>"))
- au FilterReadPre *.out exe 'silent !rm ' . shellescape(expand("<afile>")) . '.t'
- au FilterReadPost *.out '[,']s/x/X/g
- augroup END
- e! test.out " Edit the output file
- 1,$!cat
- call assert_equal([
- \ 'linE 2 AbcdefghijklmnopqrstuvwXyz',
- \ 'linE 3 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX',
- \ 'linE 4 AbcdefghijklmnopqrstuvwXyz',
- \ 'linE 5 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX',
- \ 'linE 6 AbcdefghijklmnopqrstuvwXyz',
- \ 'linE 7 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX',
- \ 'linE 8 AbcdefghijklmnopqrstuvwXyz',
- \ 'linE 9 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX',
- \ 'linE 10 AbcdefghijklmnopqrstuvwXyz'
- \ ], getline(1, 9))
- call assert_equal([
- \ 'line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ], readfile('test.out'))
- augroup Test4
- au!
- augroup END
- set shelltemp&vim
- " Test for the FileReadPre and FileReadPost autocmds.
- augroup Test5
- au!
- au FileReadPre *.gz exe 'silent !gzip -d ' . shellescape(expand("<afile>"))
- au FileReadPre *.gz call rename(expand("<afile>:r"), expand("<afile>"))
- au FileReadPost *.gz '[,']s/l/L/
- augroup END
- new
- 0r Xtestfile.gz " Read compressed file
- call assert_equal([
- \ 'Line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'Line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'Line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'Line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'Line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'Line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'Line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'Line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'Line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ], getline(1, 9))
- call assert_equal([
- \ 'line 2 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 3 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 4 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 5 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 6 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 7 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 8 Abcdefghijklmnopqrstuvwxyz',
- \ 'line 9 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
- \ 'line 10 Abcdefghijklmnopqrstuvwxyz'
- \ ], readfile('Xtestfile.gz'))
- augroup Test5
- au!
- augroup END
- au! FileChangedShell
- call delete('Xtestfile.gz')
- call delete('test.out')
- endfunc
- func Test_throw_in_BufWritePre()
- new
- call setline(1, ['one', 'two', 'three'])
- call assert_false(filereadable('Xthefile'))
- augroup throwing
- au BufWritePre X* throw 'do not write'
- augroup END
- try
- w Xthefile
- catch
- let caught = 1
- endtry
- call assert_equal(1, caught)
- call assert_false(filereadable('Xthefile'))
- bwipe!
- au! throwing
- endfunc
- func Test_autocmd_in_try_block()
- call mkdir('Xintrydir', 'R')
- au BufEnter * let g:fname = expand('%')
- try
- edit Xintrydir/
- endtry
- call assert_match('Xintrydir', g:fname)
- unlet g:fname
- au! BufEnter
- endfunc
- func Test_autocmd_SafeState()
- CheckRunVimInTerminal
- let lines =<< trim END
- let g:safe = 0
- let g:again = ''
- au SafeState * let g:safe += 1
- au SafeStateAgain * let g:again ..= 'x'
- func CallTimer()
- call timer_start(10, {id -> execute('let g:again ..= "t"')})
- endfunc
- END
- call writefile(lines, 'XSafeState', 'D')
- let buf = RunVimInTerminal('-S XSafeState', #{rows: 6})
- " Sometimes we loop to handle a K_IGNORE, SafeState may be triggered once or
- " more often.
- call term_sendkeys(buf, ":echo g:safe\<CR>")
- call WaitForAssert({-> assert_match('^\d ', term_getline(buf, 6))}, 1000)
- " SafeStateAgain should be invoked at least three times
- call term_sendkeys(buf, ":echo g:again\<CR>")
- call WaitForAssert({-> assert_match('^xxx', term_getline(buf, 6))}, 1000)
- call term_sendkeys(buf, ":let g:again = ''\<CR>:call CallTimer()\<CR>")
- call TermWait(buf, 50)
- call term_sendkeys(buf, ":\<CR>")
- call TermWait(buf, 50)
- call term_sendkeys(buf, ":echo g:again\<CR>")
- call WaitForAssert({-> assert_match('xtx', term_getline(buf, 6))}, 1000)
- call StopVimInTerminal(buf)
- endfunc
- func Test_autocmd_CmdWinEnter()
- CheckRunVimInTerminal
- " There is not cmdwin switch, so
- " test for cmdline_hist
- " (both are available with small builds)
- CheckFeature cmdline_hist
- let lines =<< trim END
- let b:dummy_var = 'This is a dummy'
- autocmd CmdWinEnter * quit
- let winnr = winnr('$')
- END
- let filename = 'XCmdWinEnter'
- call writefile(lines, filename)
- let buf = RunVimInTerminal('-S '.filename, #{rows: 6})
- call term_sendkeys(buf, "q:")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo b:dummy_var\<cr>")
- call WaitForAssert({-> assert_match('^This is a dummy', term_getline(buf, 6))}, 2000)
- call term_sendkeys(buf, ":echo &buftype\<cr>")
- call WaitForAssert({-> assert_notmatch('^nofile', term_getline(buf, 6))}, 1000)
- call term_sendkeys(buf, ":echo winnr\<cr>")
- call WaitForAssert({-> assert_match('^1', term_getline(buf, 6))}, 1000)
- " clean up
- call StopVimInTerminal(buf)
- call delete(filename)
- endfunc
- func Test_autocmd_was_using_freed_memory()
- CheckFeature quickfix
- pedit xx
- n x
- augroup winenter
- au WinEnter * if winnr('$') > 2 | quit | endif
- augroup END
- " Nvim needs large 'winwidth' and 'nowinfixwidth' to crash
- set winwidth=99999 nowinfixwidth
- split
- augroup winenter
- au! WinEnter
- augroup END
- set winwidth& winfixwidth&
- bwipe xx
- bwipe x
- pclose
- endfunc
- func Test_BufWrite_lockmarks()
- let g:test_is_flaky = 1
- edit! Xtest
- call setline(1, ['a', 'b', 'c', 'd'])
- " :lockmarks preserves the marks
- call SetChangeMarks(2, 3)
- lockmarks write
- call assert_equal([2, 3], [line("'["), line("']")])
- " *WritePre autocmds get the correct line range, but lockmarks preserves the
- " original values for the user
- augroup lockmarks
- au!
- au BufWritePre,FilterWritePre * call assert_equal([1, 4], [line("'["), line("']")])
- au FileWritePre * call assert_equal([3, 4], [line("'["), line("']")])
- augroup END
- lockmarks write
- call assert_equal([2, 3], [line("'["), line("']")])
- if executable('cat')
- lockmarks %!cat
- call assert_equal([2, 3], [line("'["), line("']")])
- endif
- lockmarks 3,4write Xtest2
- call assert_equal([2, 3], [line("'["), line("']")])
- au! lockmarks
- augroup! lockmarks
- call delete('Xtest')
- call delete('Xtest2')
- endfunc
- func Test_FileType_spell()
- if !isdirectory('/tmp')
- throw "Skipped: requires /tmp directory"
- endif
- " this was crashing with an invalid free()
- setglobal spellfile=/tmp/en.utf-8.add
- augroup crash
- autocmd!
- autocmd BufNewFile,BufReadPost crashfile setf somefiletype
- autocmd BufNewFile,BufReadPost crashfile set ft=anotherfiletype
- autocmd FileType anotherfiletype setlocal spell
- augroup END
- func! NoCrash() abort
- edit /tmp/crashfile
- endfunc
- call NoCrash()
- au! crash
- setglobal spellfile=
- endfunc
- " this was wiping out the current buffer and using freed memory
- func Test_SpellFileMissing_bwipe()
- next 0
- au SpellFileMissing 0 bwipe
- call assert_fails('set spell spelllang=0', 'E937:')
- au! SpellFileMissing
- set nospell spelllang=en
- bwipe
- endfunc
- " Test closing a window or editing another buffer from a FileChangedRO handler
- " in a readonly buffer
- func Test_FileChangedRO_winclose()
- augroup FileChangedROTest
- au!
- autocmd FileChangedRO * quit
- augroup END
- new
- set readonly
- call assert_fails('normal i', 'E788:')
- close
- augroup! FileChangedROTest
- augroup FileChangedROTest
- au!
- autocmd FileChangedRO * edit Xrofile
- augroup END
- new
- set readonly
- call assert_fails('normal i', 'E788:')
- close
- augroup! FileChangedROTest
- endfunc
- func LogACmd()
- call add(g:logged, line('$'))
- endfunc
- func Test_TermChanged()
- throw 'skipped: Nvim does not support TermChanged event'
- CheckNotGui
- enew!
- tabnew
- call setline(1, ['a', 'b', 'c', 'd'])
- $
- au TermChanged * call LogACmd()
- let g:logged = []
- let term_save = &term
- set term=xterm
- call assert_equal([1, 4], g:logged)
- au! TermChanged
- let &term = term_save
- bwipe!
- endfunc
- " Test for FileReadCmd autocmd
- func Test_autocmd_FileReadCmd()
- func ReadFileCmd()
- call append(line('$'), "v:cmdarg = " .. v:cmdarg)
- endfunc
- augroup FileReadCmdTest
- au!
- au FileReadCmd Xtest call ReadFileCmd()
- augroup END
- new
- read ++bin Xtest
- read ++nobin Xtest
- read ++edit Xtest
- read ++bad=keep Xtest
- read ++bad=drop Xtest
- read ++bad=- Xtest
- read ++ff=unix Xtest
- read ++ff=dos Xtest
- read ++ff=mac Xtest
- read ++enc=utf-8 Xtest
- call assert_equal(['',
- \ 'v:cmdarg = ++bin',
- \ 'v:cmdarg = ++nobin',
- \ 'v:cmdarg = ++edit',
- \ 'v:cmdarg = ++bad=keep',
- \ 'v:cmdarg = ++bad=drop',
- \ 'v:cmdarg = ++bad=-',
- \ 'v:cmdarg = ++ff=unix',
- \ 'v:cmdarg = ++ff=dos',
- \ 'v:cmdarg = ++ff=mac',
- \ 'v:cmdarg = ++enc=utf-8'], getline(1, '$'))
- bwipe!
- augroup FileReadCmdTest
- au!
- augroup END
- delfunc ReadFileCmd
- endfunc
- " Test for passing invalid arguments to autocmd
- func Test_autocmd_invalid_args()
- " Additional character after * for event
- call assert_fails('autocmd *a Xinvfile set ff=unix', 'E215:')
- augroup Test
- augroup END
- " Invalid autocmd event
- call assert_fails('autocmd Bufabc Xinvfile set ft=vim', 'E216:')
- " Invalid autocmd event in a autocmd group
- call assert_fails('autocmd Test Bufabc Xinvfile set ft=vim', 'E216:')
- augroup! Test
- " Execute all autocmds
- call assert_fails('doautocmd * BufEnter', 'E217:')
- call assert_fails('augroup! x1a2b3', 'E367:')
- call assert_fails('autocmd BufNew <buffer=999> pwd', 'E680:')
- call assert_fails('autocmd BufNew \) set ff=unix', 'E55:')
- endfunc
- " Test for deep nesting of autocmds
- func Test_autocmd_deep_nesting()
- autocmd BufEnter Xdeepfile doautocmd BufEnter Xdeepfile
- call assert_fails('doautocmd BufEnter Xdeepfile', 'E218:')
- autocmd! BufEnter Xdeepfile
- endfunc
- " Tests for SigUSR1 autocmd event, which is only available on posix systems.
- func Test_autocmd_sigusr1()
- CheckUnix
- let g:sigusr1_passed = 0
- au Signal SIGUSR1 let g:sigusr1_passed = 1
- call system('kill -s usr1 ' . getpid())
- call WaitForAssert({-> assert_true(g:sigusr1_passed)})
- au! Signal
- unlet g:sigusr1_passed
- endfunc
- " Test for BufReadPre autocmd deleting the file
- func Test_BufReadPre_delfile()
- augroup TestAuCmd
- au!
- autocmd BufReadPre XbufreadPre call delete('XbufreadPre')
- augroup END
- call writefile([], 'XbufreadPre', 'D')
- call assert_fails('new XbufreadPre', 'E200:')
- call assert_equal('XbufreadPre', @%)
- call assert_equal(1, &readonly)
- augroup TestAuCmd
- au!
- augroup END
- close!
- endfunc
- " Test for BufReadPre autocmd changing the current buffer
- func Test_BufReadPre_changebuf()
- augroup TestAuCmd
- au!
- autocmd BufReadPre Xchangebuf edit Xsomeotherfile
- augroup END
- call writefile([], 'Xchangebuf', 'D')
- call assert_fails('new Xchangebuf', 'E201:')
- call assert_equal('Xsomeotherfile', @%)
- call assert_equal(1, &readonly)
- augroup TestAuCmd
- au!
- augroup END
- close!
- endfunc
- " Test for BufWipeouti autocmd changing the current buffer when reading a file
- " in an empty buffer with 'f' flag in 'cpo'
- func Test_BufDelete_changebuf()
- new
- augroup TestAuCmd
- au!
- autocmd BufWipeout * let bufnr = bufadd('somefile') | exe "b " .. bufnr
- augroup END
- let save_cpo = &cpo
- set cpo+=f
- call assert_fails('r Xfile', ['E812:', 'E484:'])
- call assert_equal('somefile', @%)
- let &cpo = save_cpo
- augroup TestAuCmd
- au!
- augroup END
- close!
- endfunc
- " Test for the temporary internal window used to execute autocmds
- func Test_autocmd_window()
- %bw!
- edit one.txt
- tabnew two.txt
- vnew three.txt
- tabnew four.txt
- tabprevious
- let g:blist = []
- augroup aucmd_win_test1
- au!
- au BufEnter * call add(g:blist, [expand('<afile>'),
- \ win_gettype(bufwinnr(expand('<afile>')))])
- augroup END
- doautoall BufEnter
- call assert_equal([
- \ ['one.txt', 'autocmd'],
- \ ['two.txt', ''],
- \ ['four.txt', 'autocmd'],
- \ ['three.txt', ''],
- \ ], g:blist)
- augroup aucmd_win_test1
- au!
- augroup END
- augroup! aucmd_win_test1
- %bw!
- endfunc
- " Test for trying to close the temporary window used for executing an autocmd
- func Test_close_autocmd_window()
- %bw!
- edit one.txt
- tabnew two.txt
- augroup aucmd_win_test2
- au!
- " Nvim makes aucmd_win the last window
- " au BufEnter * if expand('<afile>') == 'one.txt' | 1close | endif
- au BufEnter * if expand('<afile>') == 'one.txt' | close | endif
- augroup END
- call assert_fails('doautoall BufEnter', 'E813:')
- augroup aucmd_win_test2
- au!
- augroup END
- augroup! aucmd_win_test2
- %bw!
- endfunc
- " Test for trying to close the tab that has the temporary window for exeucing
- " an autocmd.
- func Test_close_autocmd_tab()
- edit one.txt
- tabnew two.txt
- augroup aucmd_win_test
- au!
- au BufEnter * if expand('<afile>') == 'one.txt' | tabfirst | tabonly | endif
- augroup END
- call assert_fails('doautoall BufEnter', 'E813:')
- tabonly
- augroup aucmd_win_test
- au!
- augroup END
- augroup! aucmd_win_test
- %bwipe!
- endfunc
- func Test_Visual_doautoall_redraw()
- call setline(1, ['a', 'b'])
- new
- wincmd p
- call feedkeys("G\<C-V>", 'txn')
- autocmd User Explode ++once redraw
- doautoall User Explode
- %bwipe!
- endfunc
- " This was using freed memory.
- func Test_BufNew_arglocal()
- arglocal
- au BufNew * arglocal
- call assert_fails('drop xx', 'E1156:')
- au! BufNew
- endfunc
- func Test_autocmd_closes_window()
- au BufNew,BufWinLeave * e %e
- file yyy
- au BufNew,BufWinLeave * ball
- n xxx
- %bwipe
- au! BufNew
- au! BufWinLeave
- endfunc
- func Test_autocmd_quit_psearch()
- sn aa bb
- augroup aucmd_win_test
- au!
- au BufEnter,BufLeave,BufNew,WinEnter,WinLeave,WinNew * if winnr('$') > 1 | q | endif
- augroup END
- ps /
- augroup aucmd_win_test
- au!
- augroup END
- new
- pclose
- endfunc
- " Fuzzer found some strange combination that caused a crash.
- func Test_autocmd_normal_mess()
- " For unknown reason this hangs on MS-Windows
- CheckNotMSWindows
- augroup aucmd_normal_test
- au BufLeave,BufWinLeave,BufHidden,BufUnload,BufDelete,BufWipeout * norm 7q/qc
- augroup END
- " Nvim has removed :open
- " call assert_fails('o4', 'E1159')
- call assert_fails('e4', 'E1159')
- silent! H
- call assert_fails('e xx', 'E1159')
- normal G
- augroup aucmd_normal_test
- au!
- augroup END
- endfunc
- func Test_autocmd_closing_cmdwin()
- " For unknown reason this hangs on MS-Windows
- CheckNotMSWindows
- au BufWinLeave * nested q
- call assert_fails("norm 7q?\n", 'E855:')
- au! BufWinLeave
- new
- only
- endfunc
- func Test_autocmd_vimgrep()
- augroup aucmd_vimgrep
- au QuickfixCmdPre,BufNew,BufReadCmd * sb
- " Nvim makes aucmd_win the last window
- " au QuickfixCmdPre,BufNew,BufReadCmd * q9
- au QuickfixCmdPre,BufNew,BufReadCmd * exe 'q' .. (winnr('$') - (win_gettype(winnr('$')) == 'autocmd'))
- augroup END
- call assert_fails('lv ?a? foo', 'E926:')
- augroup aucmd_vimgrep
- au!
- augroup END
- endfunc
- func Test_closing_autocmd_window()
- let lines =<< trim END
- edit Xa.txt
- tabnew Xb.txt
- autocmd BufEnter Xa.txt unhide 1
- doautoall BufEnter
- END
- call CheckScriptFailure(lines, 'E814:')
- au! BufEnter
- bwipe Xa.txt
- bwipe Xb.txt
- endfunc
- func Test_switch_window_in_autocmd_window()
- edit Xa.txt
- tabnew Xb.txt
- autocmd BufEnter Xa.txt wincmd w
- doautoall BufEnter
- au! BufEnter
- bwipe Xa.txt
- call assert_false(bufexists('Xa.txt'))
- bwipe Xb.txt
- call assert_false(bufexists('Xb.txt'))
- endfunc
- " Test that using the autocommand window doesn't change current directory.
- func Test_autocmd_window_cwd()
- let saveddir = getcwd()
- call mkdir('Xcwd/a/b/c/d', 'pR')
- new Xa.txt
- tabnew
- new Xb.txt
- tabprev
- cd Xcwd
- call assert_match('/Xcwd$', getcwd())
- call assert_match('\[global\] .*/Xcwd$', trim(execute('verbose pwd')))
- autocmd BufEnter Xb.txt lcd ./a/b/c/d
- doautoall BufEnter
- au! BufEnter
- call assert_match('/Xcwd$', getcwd())
- call assert_match('\[global\] .*/Xcwd$', trim(execute('verbose pwd')))
- tabnext
- cd ./a
- tcd ./b
- lcd ./c
- call assert_match('/Xcwd/a/b/c$', getcwd())
- call assert_match('\[window\] .*/Xcwd/a/b/c$', trim(execute('verbose pwd')))
- autocmd BufEnter Xa.txt call assert_match('Xcwd/a/b/c$', getcwd())
- doautoall BufEnter
- au! BufEnter
- call assert_match('/Xcwd/a/b/c$', getcwd())
- call assert_match('\[window\] .*/Xcwd/a/b/c$', trim(execute('verbose pwd')))
- bwipe!
- call assert_match('/Xcwd/a/b$', getcwd())
- call assert_match('\[tabpage\] .*/Xcwd/a/b$', trim(execute('verbose pwd')))
- bwipe!
- call assert_match('/Xcwd/a$', getcwd())
- call assert_match('\[global\] .*/Xcwd/a$', trim(execute('verbose pwd')))
- bwipe!
- call chdir(saveddir)
- endfunc
- func Test_bufwipeout_changes_window()
- " This should not crash, but we don't have any expectations about what
- " happens, changing window in BufWipeout has unpredictable results.
- tabedit
- let g:window_id = win_getid()
- topleft new
- setlocal bufhidden=wipe
- autocmd BufWipeout <buffer> call win_gotoid(g:window_id)
- tabprevious
- +tabclose
- unlet g:window_id
- au! BufWipeout
- %bwipe!
- endfunc
- func Test_v_event_readonly()
- autocmd CompleteChanged * let v:event.width = 0
- call assert_fails("normal! i\<C-X>\<C-V>", 'E46:')
- au! CompleteChanged
- autocmd DirChangedPre * let v:event.directory = ''
- call assert_fails('cd .', 'E46:')
- au! DirChangedPre
- autocmd ModeChanged * let v:event.new_mode = ''
- call assert_fails('normal! cc', 'E46:')
- au! ModeChanged
- autocmd TextYankPost * let v:event.operator = ''
- call assert_fails('normal! yy', 'E46:')
- au! TextYankPost
- endfunc
- " Test for ModeChanged pattern
- func Test_mode_changes()
- let g:index = 0
- let g:mode_seq = ['n', 'i', 'n', 'v', 'V', 'i', 'ix', 'i', 'ic', 'i', 'n', 'no', 'noV', 'n', 'V', 'v', 's', 'n']
- func! TestMode()
- call assert_equal(g:mode_seq[g:index], get(v:event, "old_mode"))
- call assert_equal(g:mode_seq[g:index + 1], get(v:event, "new_mode"))
- call assert_equal(mode(1), get(v:event, "new_mode"))
- let g:index += 1
- endfunc
- au ModeChanged * :call TestMode()
- let g:n_to_any = 0
- au ModeChanged n:* let g:n_to_any += 1
- call feedkeys("i\<esc>vVca\<CR>\<C-X>\<C-L>\<esc>ggdV\<MouseMove>G", 'tnix')
- let g:V_to_v = 0
- au ModeChanged V:v let g:V_to_v += 1
- call feedkeys("Vv\<C-G>\<esc>", 'tnix')
- call assert_equal(len(filter(g:mode_seq[1:], {idx, val -> val == 'n'})), g:n_to_any)
- call assert_equal(1, g:V_to_v)
- call assert_equal(len(g:mode_seq) - 1, g:index)
- let g:n_to_i = 0
- au ModeChanged n:i let g:n_to_i += 1
- let g:n_to_niI = 0
- au ModeChanged i:niI let g:n_to_niI += 1
- let g:niI_to_i = 0
- au ModeChanged niI:i let g:niI_to_i += 1
- let g:nany_to_i = 0
- au ModeChanged n*:i let g:nany_to_i += 1
- let g:i_to_n = 0
- au ModeChanged i:n let g:i_to_n += 1
- let g:nori_to_any = 0
- au ModeChanged [ni]:* let g:nori_to_any += 1
- let g:i_to_any = 0
- au ModeChanged i:* let g:i_to_any += 1
- let g:index = 0
- let g:mode_seq = ['n', 'i', 'niI', 'i', 'n']
- call feedkeys("a\<C-O>l\<esc>", 'tnix')
- call assert_equal(len(g:mode_seq) - 1, g:index)
- call assert_equal(1, g:n_to_i)
- call assert_equal(1, g:n_to_niI)
- call assert_equal(1, g:niI_to_i)
- call assert_equal(2, g:nany_to_i)
- call assert_equal(1, g:i_to_n)
- call assert_equal(2, g:i_to_any)
- call assert_equal(3, g:nori_to_any)
- if has('terminal')
- let g:mode_seq += ['c', 'n', 't', 'nt', 'c', 'nt', 'n']
- call feedkeys(":term\<CR>\<C-W>N:bd!\<CR>", 'tnix')
- call assert_equal(len(g:mode_seq) - 1, g:index)
- call assert_equal(1, g:n_to_i)
- call assert_equal(1, g:n_to_niI)
- call assert_equal(1, g:niI_to_i)
- call assert_equal(2, g:nany_to_i)
- call assert_equal(1, g:i_to_n)
- call assert_equal(2, g:i_to_any)
- call assert_equal(5, g:nori_to_any)
- endif
- let g:n_to_c = 0
- au ModeChanged n:c let g:n_to_c += 1
- let g:c_to_n = 0
- au ModeChanged c:n let g:c_to_n += 1
- let g:mode_seq += ['c', 'n', 'c', 'n']
- call feedkeys("q:\<C-C>\<Esc>", 'tnix')
- call assert_equal(len(g:mode_seq) - 1, g:index)
- call assert_equal(2, g:n_to_c)
- call assert_equal(2, g:c_to_n)
- let g:n_to_v = 0
- au ModeChanged n:v let g:n_to_v += 1
- let g:v_to_n = 0
- au ModeChanged v:n let g:v_to_n += 1
- let g:mode_seq += ['v', 'n']
- call feedkeys("v\<C-C>", 'tnix')
- call assert_equal(len(g:mode_seq) - 1, g:index)
- call assert_equal(1, g:n_to_v)
- call assert_equal(1, g:v_to_n)
- let g:mode_seq += ['c', 'cr', 'c', 'cr', 'n']
- call feedkeys(":\<Insert>\<Insert>\<Insert>\<CR>", 'tnix')
- call assert_equal(len(g:mode_seq) - 1, g:index)
- au! ModeChanged
- delfunc TestMode
- unlet! g:mode_seq
- unlet! g:index
- unlet! g:n_to_any
- unlet! g:V_to_v
- unlet! g:n_to_i
- unlet! g:n_to_niI
- unlet! g:niI_to_i
- unlet! g:nany_to_i
- unlet! g:i_to_n
- unlet! g:nori_to_any
- unlet! g:i_to_any
- unlet! g:n_to_c
- unlet! g:c_to_n
- unlet! g:n_to_v
- unlet! g:v_to_n
- endfunc
- func Test_recursive_ModeChanged()
- au! ModeChanged * norm 0u
- sil! norm
- au! ModeChanged
- endfunc
- func Test_ModeChanged_starts_visual()
- " This was triggering ModeChanged before setting VIsual, causing a crash.
- au! ModeChanged * norm 0u
- sil! norm
- au! ModeChanged
- endfunc
- func Test_noname_autocmd()
- augroup test_noname_autocmd_group
- autocmd!
- autocmd BufEnter * call add(s:li, ["BufEnter", expand("<afile>")])
- autocmd BufDelete * call add(s:li, ["BufDelete", expand("<afile>")])
- autocmd BufLeave * call add(s:li, ["BufLeave", expand("<afile>")])
- autocmd BufUnload * call add(s:li, ["BufUnload", expand("<afile>")])
- autocmd BufWipeout * call add(s:li, ["BufWipeout", expand("<afile>")])
- augroup END
- let s:li = []
- edit foo
- call assert_equal([['BufUnload', ''], ['BufDelete', ''], ['BufWipeout', ''], ['BufEnter', 'foo']], s:li)
- au! test_noname_autocmd_group
- augroup! test_noname_autocmd_group
- endfunc
- func Test_autocmd_split_dummy()
- " Autocommand trying to split a window containing a dummy buffer.
- auto BufReadPre * exe "sbuf " .. expand("<abuf>")
- " Avoid the "W11" prompt
- au FileChangedShell * let v:fcs_choice = 'reload'
- func Xautocmd_changelist()
- cal writefile(['Xtestfile2:4:4'], 'Xerr')
- edit Xerr
- lex 'Xtestfile2:4:4'
- endfunc
- call Xautocmd_changelist()
- " Should get E86, but it doesn't always happen (timing?)
- silent! call Xautocmd_changelist()
- au! BufReadPre
- au! FileChangedShell
- delfunc Xautocmd_changelist
- bwipe! Xerr
- call delete('Xerr')
- endfunc
- " This was crashing because there was only one window to execute autocommands
- " in.
- func Test_autocmd_nested_setbufvar()
- CheckFeature python3
- set hidden
- edit Xaaa
- edit Xbbb
- call setline(1, 'bar')
- enew
- au BufWriteCmd Xbbb ++nested call setbufvar('Xaaa', '&ft', 'foo') | bw! Xaaa
- au FileType foo call py3eval('vim.current.buffer.options["cindent"]')
- wall
- au! BufWriteCmd
- au! FileType foo
- set nohidden
- call delete('Xaaa')
- call delete('Xbbb')
- %bwipe!
- endfunc
- func SetupVimTest_shm()
- let g:bwe = []
- let g:brp = []
- set shortmess-=l
- messages clear
- let dirname='XVimTestSHM'
- call mkdir(dirname, 'R')
- call writefile(['test'], dirname .. '/1')
- call writefile(['test'], dirname .. '/2')
- call writefile(['test'], dirname .. '/3')
- augroup test
- autocmd!
- autocmd BufWinEnter * call add(g:bwe, $'BufWinEnter: {expand('<amatch>')}')
- autocmd BufReadPost * call add(g:brp, $'BufReadPost: {expand('<amatch>')}')
- augroup END
- call setqflist([
- \ {'filename': dirname .. '/1', 'lnum': 1, 'col': 1, 'text': 'test', 'vcol': 0},
- \ {'filename': dirname .. '/2', 'lnum': 1, 'col': 1, 'text': 'test', 'vcol': 0},
- \ {'filename': dirname .. '/3', 'lnum': 1, 'col': 1, 'text': 'test', 'vcol': 0}
- \ ])
- cdo! substitute/test/TEST
- " clean up
- noa enew!
- set shortmess&vim
- augroup test
- autocmd!
- augroup END
- augroup! test
- endfunc
- func Test_autocmd_shortmess()
- CheckNotMSWindows
- call SetupVimTest_shm()
- let output = execute(':mess')->split('\n')
- let info = copy(output)->filter({idx, val -> val =~# '\d of 3'} )
- let bytes = copy(output)->filter({idx, val -> val =~# 'bytes'} )
- " We test the following here:
- " BufReadPost should have been triggered 3 times, once per file
- " BufWinEnter should have been triggered 3 times, once per file
- " FileInfoMessage should have been shown 3 times, regardless of shm option
- " "(x of 3)" message from :cnext has been shown 3 times
- call assert_equal(3, g:brp->len())
- call assert_equal(3, g:bwe->len())
- call assert_equal(3, info->len())
- call assert_equal(3, bytes->len())
- delfunc SetupVimTest_shm
- endfunc
- func Test_autocmd_invalidates_undo_on_textchanged()
- CheckRunVimInTerminal
- let script =<< trim END
- set hidden
- " create quickfix list (at least 2 lines to move line)
- vimgrep /u/j %
- " enter quickfix window
- cwindow
- " set modifiable
- setlocal modifiable
- " set autocmd to clear quickfix list
- autocmd! TextChanged <buffer> call setqflist([])
- " move line
- move+1
- END
- call writefile(script, 'XTest_autocmd_invalidates_undo_on_textchanged', 'D')
- let buf = RunVimInTerminal('XTest_autocmd_invalidates_undo_on_textchanged', {'rows': 20})
- call term_sendkeys(buf, ":so %\<cr>")
- call term_sendkeys(buf, "G")
- call WaitForAssert({-> assert_match('^XTest_autocmd_invalidates_undo_on_textchanged\s*$', term_getline(buf, 20))}, 1000)
- call StopVimInTerminal(buf)
- endfunc
- func Test_autocmd_creates_new_buffer_on_bufleave()
- e a.txt
- e b.txt
- setlocal bufhidden=wipe
- autocmd BufLeave <buffer> diffsplit c.txt
- bn
- call assert_equal(1, winnr('$'))
- call assert_equal('a.txt', bufname('%'))
- bw a.txt
- bw c.txt
- endfunc
- " Ensure `expected` was just recently written as a Vim session
- func s:assert_session_path(expected)
- call assert_equal(a:expected, v:this_session)
- endfunc
- " Check for `expected` after a session is written to-disk.
- func s:watch_for_session_path(expected)
- execute 'autocmd SessionWritePost * ++once execute "call s:assert_session_path(\"'
- \ . a:expected
- \ . '\")"'
- endfunc
- " Ensure v:this_session gets the full session path, if explicitly stated
- func Test_explicit_session_absolute_path()
- %bwipeout!
- let directory = getcwd()
- let v:this_session = ""
- let name = "some_file.vim"
- let expected = fnamemodify(name, ":p")
- call s:watch_for_session_path(expected)
- execute "mksession! " .. expected
- call delete(expected)
- endfunc
- " Ensure v:this_session gets the full session path, if explicitly stated
- func Test_explicit_session_relative_path()
- %bwipeout!
- let directory = getcwd()
- let v:this_session = ""
- let name = "some_file.vim"
- let expected = fnamemodify(name, ":p")
- call s:watch_for_session_path(expected)
- execute "mksession! " .. name
- call delete(expected)
- endfunc
- " Ensure v:this_session gets the full session path, if not specified
- func Test_implicit_session()
- %bwipeout!
- let directory = getcwd()
- let v:this_session = ""
- let expected = fnamemodify("Session.vim", ":p")
- call s:watch_for_session_path(expected)
- mksession!
- call delete(expected)
- endfunc
- " Test TextChangedI and TextChanged
- func Test_Changed_ChangedI()
- " Run this test in a terminal because it requires running the main loop.
- " Don't use CheckRunVimInTerminal as that will skip the test on Windows.
- CheckFeature terminal
- CheckNotGui
- " Starting a terminal to run Vim is always considered flaky.
- let g:test_is_flaky = 1
- call writefile(['one', 'two', 'three'], 'XTextChangedI2', 'D')
- let before =<< trim END
- set ttimeout ttimeoutlen=10
- let [g:autocmd_n, g:autocmd_i] = ['','']
- func TextChangedAutocmd(char)
- let g:autocmd_{tolower(a:char)} = a:char .. b:changedtick
- call writefile([$'{g:autocmd_n},{g:autocmd_i}'], 'XTextChangedI3')
- endfunc
- au TextChanged <buffer> :call TextChangedAutocmd('N')
- au TextChangedI <buffer> :call TextChangedAutocmd('I')
- nnoremap <CR> o<Esc>
- autocmd SafeState * ++once call writefile([''], 'XTextChangedI3')
- END
- call writefile(before, 'Xinit', 'D')
- let buf = term_start(
- \ GetVimCommandCleanTerm() .. '-n -S Xinit XTextChangedI2',
- \ {'term_rows': 10})
- call assert_equal('running', term_getstatus(buf))
- call WaitForAssert({-> assert_true(filereadable('XTextChangedI3'))})
- defer delete('XTextChangedI3')
- call WaitForAssert({-> assert_equal([''], readfile('XTextChangedI3'))})
- " TextChanged should trigger if a mapping enters and leaves Insert mode.
- call term_sendkeys(buf, "\<CR>")
- call WaitForAssert({-> assert_equal('N4,', readfile('XTextChangedI3')->join("\n"))})
- call term_sendkeys(buf, "i")
- call WaitForAssert({-> assert_match('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_equal('N4,', readfile('XTextChangedI3')->join("\n"))})
- " TextChangedI should trigger if change is done in Insert mode.
- call term_sendkeys(buf, "f")
- call WaitForAssert({-> assert_equal('N4,I5', readfile('XTextChangedI3')->join("\n"))})
- call term_sendkeys(buf, "o")
- call WaitForAssert({-> assert_equal('N4,I6', readfile('XTextChangedI3')->join("\n"))})
- call term_sendkeys(buf, "o")
- call WaitForAssert({-> assert_equal('N4,I7', readfile('XTextChangedI3')->join("\n"))})
- " TextChanged shouldn't trigger when leaving Insert mode and TextChangedI
- " has been triggered.
- call term_sendkeys(buf, "\<Esc>")
- call WaitForAssert({-> assert_notmatch('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_equal('N4,I7', readfile('XTextChangedI3')->join("\n"))})
- " TextChanged should trigger if change is done in Normal mode.
- call term_sendkeys(buf, "yyp")
- call WaitForAssert({-> assert_equal('N8,I7', readfile('XTextChangedI3')->join("\n"))})
- " TextChangedI shouldn't trigger if change isn't done in Insert mode.
- call term_sendkeys(buf, "i")
- call WaitForAssert({-> assert_match('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_equal('N8,I7', readfile('XTextChangedI3')->join("\n"))})
- call term_sendkeys(buf, "\<Esc>")
- call WaitForAssert({-> assert_notmatch('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_equal('N8,I7', readfile('XTextChangedI3')->join("\n"))})
- " TextChangedI should trigger if change is a mix of Normal and Insert modes.
- func! s:validate_mixed_textchangedi(buf, keys)
- let buf = a:buf
- call term_sendkeys(buf, "ifoo")
- call WaitForAssert({-> assert_match('^-- INSERT --', term_getline(buf, 10))})
- call term_sendkeys(buf, "\<Esc>")
- call WaitForAssert({-> assert_notmatch('^-- INSERT --', term_getline(buf, 10))})
- call term_sendkeys(buf, ":let [g:autocmd_n, g:autocmd_i] = ['', '']\<CR>")
- call writefile([], 'XTextChangedI3')
- call term_sendkeys(buf, a:keys)
- call WaitForAssert({-> assert_match('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_match('^,I\d\+', readfile('XTextChangedI3')->join("\n"))})
- call term_sendkeys(buf, "\<Esc>")
- call WaitForAssert({-> assert_notmatch('^-- INSERT --', term_getline(buf, 10))})
- call WaitForAssert({-> assert_match('^,I\d\+', readfile('XTextChangedI3')->join("\n"))})
- endfunc
- call s:validate_mixed_textchangedi(buf, "o")
- call s:validate_mixed_textchangedi(buf, "O")
- call s:validate_mixed_textchangedi(buf, "ciw")
- call s:validate_mixed_textchangedi(buf, "cc")
- call s:validate_mixed_textchangedi(buf, "C")
- call s:validate_mixed_textchangedi(buf, "s")
- call s:validate_mixed_textchangedi(buf, "S")
- " clean up
- bwipe!
- endfunc
- " Test that filetype detection still works when SwapExists autocommand sets
- " filetype in another buffer.
- func Test_SwapExists_set_other_buf_filetype()
- let lines =<< trim END
- set nocompatible directory=.
- filetype on
- let g:buf = bufnr()
- new
- func SwapExists()
- let v:swapchoice = 'o'
- call setbufvar(g:buf, '&filetype', 'text')
- endfunc
- func SafeState()
- edit <script>
- redir! > XftSwapExists.out
- set readonly? filetype?
- redir END
- qall!
- endfunc
- autocmd SwapExists * ++nested call SwapExists()
- autocmd SafeState * ++nested ++once call SafeState()
- END
- call writefile(lines, 'XftSwapExists.vim', 'D')
- new XftSwapExists.vim
- if RunVim('', '', ' -S XftSwapExists.vim')
- call assert_equal(
- \ ['', ' readonly', ' filetype=vim'],
- \ readfile('XftSwapExists.out'))
- call delete('XftSwapExists.out')
- endif
- bwipe!
- endfunc
- " Test that file is not marked as modified when SwapExists autocommand sets
- " 'modified' in another buffer.
- func Test_SwapExists_set_other_buf_modified()
- let lines =<< trim END
- set nocompatible directory=.
- let g:buf = bufnr()
- new
- func SwapExists()
- let v:swapchoice = 'o'
- call setbufvar(g:buf, '&modified', 1)
- endfunc
- func SafeState()
- edit <script>
- redir! > XmodSwapExists.out
- set readonly? modified?
- redir END
- qall!
- endfunc
- autocmd SwapExists * ++nested call SwapExists()
- autocmd SafeState * ++nested ++once call SafeState()
- END
- call writefile(lines, 'XmodSwapExists.vim', 'D')
- new XmodSwapExists.vim
- if RunVim('', '', ' -S XmodSwapExists.vim')
- call assert_equal(
- \ ['', ' readonly', 'nomodified'],
- \ readfile('XmodSwapExists.out'))
- call delete('XmodSwapExists.out')
- endif
- bwipe!
- endfunc
- func Test_BufEnter_botline()
- set hidden
- call writefile(range(10), 'Xxx1', 'D')
- call writefile(range(20), 'Xxx2', 'D')
- edit Xxx1
- edit Xxx2
- au BufEnter Xxx1 call assert_true(line('w$') > 1)
- edit Xxx1
- bwipe! Xxx1
- bwipe! Xxx2
- au! BufEnter Xxx1
- set hidden&vim
- endfunc
- " This was using freed memory
- func Test_autocmd_BufWinLeave_with_vsp()
- new
- let fname = 'XXXBufWinLeaveUAF.txt'
- let dummy = 'XXXDummy.txt'
- call writefile([], fname)
- call writefile([], dummy)
- defer delete(fname)
- defer delete(dummy)
- exe "e " fname
- vsp
- augroup testing
- exe "au BufWinLeave " .. fname .. " :e " dummy .. "| vsp " .. fname
- augroup END
- bw
- call CleanUpTestAuGroup()
- exe "bw! " .. dummy
- endfunc
- func Test_OptionSet_cmdheight()
- set mouse=a laststatus=2
- au OptionSet cmdheight :let &l:ch = v:option_new
- resize -1
- call assert_equal(2, &l:ch)
- resize +1
- call assert_equal(1, &l:ch)
- call Ntest_setmouse(&lines - 1, 1)
- call feedkeys("\<LeftMouse>", 'xt')
- call Ntest_setmouse(&lines - 2, 1)
- call feedkeys("\<LeftDrag>", 'xt')
- call assert_equal(2, &l:ch)
- tabnew | resize +1
- call assert_equal(1, &l:ch)
- tabfirst
- call assert_equal(2, &l:ch)
- tabonly
- set cmdheight& mouse& laststatus&
- endfunc
- func Test_eventignorewin()
- defer CleanUpTestAuGroup()
- augroup testing
- au WinEnter * :call add(g:evs, ["WinEnter", expand("<afile>")])
- au WinLeave * :call add(g:evs, ["WinLeave", expand("<afile>")])
- au BufWinEnter * :call add(g:evs, ["BufWinEnter", expand("<afile>")])
- augroup END
- let g:evs = []
- set eventignorewin=WinLeave,WinEnter
- split foo
- call assert_equal([['BufWinEnter', 'foo']], g:evs)
- set eventignorewin=all
- edit bar
- call assert_equal([['BufWinEnter', 'foo']], g:evs)
- set eventignorewin=
- wincmd w
- call assert_equal([['BufWinEnter', 'foo'], ['WinLeave', 'bar']], g:evs)
- only!
- %bwipe!
- set eventignorewin&
- unlet g:evs
- endfunc
- func Test_WinScrolled_Resized_eiw()
- CheckRunVimInTerminal
- let lines =<< trim END
- call setline(1, ['foo']->repeat(32))
- set eventignorewin=WinScrolled,WinResized
- split
- let [g:afile,g:resized,g:scrolled] = ['none',0,0]
- au WinScrolled * let [g:afile,g:scrolled] = [expand('<afile>'),g:scrolled+1]
- au WinResized * let [g:afile,g:resized] = [expand('<afile>'),g:resized+1]
- END
- call writefile(lines, 'Xtest_winscrolled_eiw', 'D')
- let buf = RunVimInTerminal('-S Xtest_winscrolled_eiw', {'rows': 10})
- " Both windows are ignoring resize events
- call term_sendkeys(buf, "\<C-W>-")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:afile g:resized g:scrolled\<CR>")
- call WaitForAssert({-> assert_equal('none 0 0', term_getline(buf, 10))}, 1000)
- " And scroll events
- call term_sendkeys(buf, "Ggg")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo g:afile g:resized g:scrolled\<CR>")
- call WaitForAssert({-> assert_equal('none 0 0', term_getline(buf, 10))}, 1000)
- " Un-ignore events in second window, make first window current and resize
- call term_sendkeys(buf, ":set eventignorewin=\<CR>\<C-W>w\<C-W>+")
- call TermWait(buf)
- call term_sendkeys(buf, ":echo win_getid() g:afile g:resized g:scrolled\<CR>")
- call WaitForAssert({-> assert_equal('1000 1001 1 1', term_getline(buf, 10))}, 1000)
- call StopVimInTerminal(buf)
- endfunc
- " vim: shiftwidth=2 sts=2 expandtab
|