workflow.vader 31 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120
  1. Execute (Initialize test environment):
  2. Save &rtp, g:plugs, g:plug_home, g:plug_window
  3. let first_rtp = split(&rtp, ',')[0]
  4. let last_rtp = split(&rtp, ',')[-1]
  5. let vader = fnamemodify(globpath(&rtp, 'autoload/vader.vim'), ':h:h')
  6. let plug = fnamemodify(globpath(&rtp, 'autoload/plug.vim'), ':h:h')
  7. set rtp=$HOME/.vim,$VIM/vimfiles,$VIMRUNTIME,$VIM/vimfiles/after,$HOME/.vim/after
  8. execute 'set rtp^='.vader
  9. execute 'set rtp^='.plug
  10. let basertp = &rtp
  11. unlet! g:plugs g:plug_home g:plug_window
  12. set t_Co=256
  13. colo default
  14. pclose
  15. function! PlugStatusSorted()
  16. PlugStatus
  17. %y
  18. q
  19. normal! P
  20. %sort
  21. g/^$/d
  22. endfunction
  23. function! AssertExpect(bang, pat, cnt)
  24. let op = a:bang ? '==#' : '=~#'
  25. AssertEqual a:cnt, len(filter(getline(1, '$'), "v:val ".op." '".a:pat."'"))
  26. endfunction
  27. command! -nargs=+ -bang AssertExpect call AssertExpect('<bang>' == '!', <args>)
  28. function! EnsureLoaded()
  29. if has('vim_starting')
  30. runtime! plugin/**/*.vim
  31. endif
  32. endfunction
  33. Execute (Print Ruby version):
  34. redir => out
  35. silent ruby puts RUBY_VERSION
  36. redir END
  37. Log substitute(out, '\n', '', 'g')
  38. Execute (plug#end() before plug#begin() should fail):
  39. redir => out
  40. AssertEqual 0, plug#end()
  41. redir END
  42. Assert stridx(out, 'Call plug#begin() first') >= 0
  43. Execute (plug#begin() without path argument):
  44. call plug#begin()
  45. AssertEqual split(&rtp, ',')[0].'/plugged', g:plug_home
  46. unlet g:plug_home
  47. Execute (plug#begin() without path argument with empty &rtp):
  48. let save_rtp = &rtp
  49. set rtp=
  50. redir => out
  51. AssertEqual 0, plug#begin()
  52. redir END
  53. Assert stridx(out, 'Unable to determine plug home') >= 0
  54. let &rtp = save_rtp
  55. Execute (plug#begin(path)):
  56. let temp_plugged = tempname()
  57. call plug#begin(temp_plugged.'/')
  58. Assert g:plug_home !~ '[/\\]$', 'Trailing / should be stripped from g:plug_home'
  59. AssertEqual 0, len(g:plugs)
  60. AssertEqual temp_plugged, g:plug_home
  61. AssertEqual basertp, &rtp
  62. Execute (Subsequent plug#begin() calls will reuse g:plug_home):
  63. call plug#begin()
  64. AssertEqual temp_plugged, g:plug_home
  65. Execute (Test Plug command):
  66. " Git repo with branch
  67. Plug 'junegunn/seoul256.vim', 'yes-t_co'
  68. AssertEqual 'https://git::@github.com/junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
  69. AssertEqual join([temp_plugged, 'seoul256.vim/'], '/'), g:plugs['seoul256.vim'].dir
  70. AssertEqual 'yes-t_co', g:plugs['seoul256.vim'].branch
  71. Plug 'junegunn/seoul256.vim', { 'branch': 'no-t_co' } " Using branch option
  72. AssertEqual 'no-t_co', g:plugs['seoul256.vim'].branch
  73. " Git repo with tag
  74. Plug 'junegunn/goyo.vim', '1.5.2'
  75. AssertEqual 'https://git::@github.com/junegunn/goyo.vim.git', g:plugs['goyo.vim'].uri
  76. AssertEqual join([temp_plugged, 'goyo.vim/'], '/'), g:plugs['goyo.vim'].dir
  77. AssertEqual '1.5.2', g:plugs['goyo.vim'].branch
  78. Plug 'junegunn/goyo.vim', { 'tag': '1.5.3' } " Using tag option
  79. AssertEqual '1.5.3', g:plugs['goyo.vim'].branch
  80. " Git URI
  81. Plug 'https://bitbucket.org/junegunn/vim-emoji.git'
  82. AssertEqual 'https://bitbucket.org/junegunn/vim-emoji.git', g:plugs['vim-emoji'].uri
  83. AssertEqual 'master', g:plugs['vim-emoji'].branch
  84. AssertEqual join([temp_plugged, 'vim-emoji/'], '/'), g:plugs['vim-emoji'].dir
  85. " vim-scripts/
  86. Plug 'beauty256'
  87. AssertEqual 'https://git::@github.com/vim-scripts/beauty256.git', g:plugs.beauty256.uri
  88. AssertEqual 'master', g:plugs.beauty256.branch
  89. AssertEqual 4, len(g:plugs)
  90. Execute (Plug command with dictionary option):
  91. Log string(g:plugs)
  92. Plug 'junegunn/seoul256.vim', { 'branch': 'no-t_co', 'rtp': '././' }
  93. AssertEqual join([temp_plugged, 'seoul256.vim/'], '/'), g:plugs['seoul256.vim'].dir
  94. AssertEqual '././', g:plugs['seoul256.vim'].rtp
  95. Log string(g:plugs)
  96. AssertEqual 4, len(g:plugs)
  97. Execute (PlugStatus before installation):
  98. PlugStatus
  99. AssertExpect 'Not found', 4
  100. q
  101. Execute (PlugClean before installation):
  102. PlugClean
  103. AssertExpect 'Already clean', 1
  104. q
  105. Execute (plug#end() updates &rtp):
  106. call plug#end()
  107. Assert len(&rtp) > len(basertp)
  108. AssertEqual first_rtp, split(&rtp, ',')[0]
  109. AssertEqual last_rtp, split(&rtp, ',')[-1]
  110. Execute (Yet, plugins are not available):
  111. Assert empty(globpath(&rtp, 'autoload/emoji.vim'))
  112. Execute (PlugInstall):
  113. PlugInstall
  114. q
  115. Execute (Plugin available after installation):
  116. Assert !empty(globpath(&rtp, 'autoload/emoji.vim'))
  117. Execute (PlugClean after installation):
  118. PlugClean
  119. AssertExpect 'Already clean', 1
  120. q
  121. Execute (PlugStatus after installation):
  122. PlugStatus
  123. Log getline(1, '$')
  124. AssertExpect 'OK', 4
  125. q
  126. Execute (Change tag of goyo.vim):
  127. call plug#begin()
  128. Plug 'junegunn/goyo.vim'
  129. call plug#end()
  130. Execute (PlugStatus):
  131. call PlugStatusSorted()
  132. Expect:
  133. Invalid branch/tag: 1.5.3 (expected: master). Try PlugUpdate.
  134. Finished. 1 error(s).
  135. [=]
  136. x goyo.vim:
  137. Execute (PlugUpdate to set the right branch):
  138. PlugUpdate
  139. call PlugStatusSorted()
  140. Expect:
  141. - goyo.vim: OK
  142. Finished. 0 error(s).
  143. [=]
  144. Execute (Change branch of seoul256.vim):
  145. call plug#begin()
  146. Plug 'junegunn/seoul256.vim'
  147. Plug 'https://bitbucket.org/junegunn/vim-emoji.git'
  148. call plug#end()
  149. Execute (PlugStatus):
  150. call PlugStatusSorted()
  151. Expect:
  152. Invalid branch/tag: no-t_co (expected: master). Try PlugUpdate.
  153. - vim-emoji: OK
  154. Finished. 1 error(s).
  155. [==]
  156. x seoul256.vim:
  157. Execute (Change URI of seoul256.vim):
  158. call plug#begin()
  159. Plug 'junegunn.choi/seoul256.vim'
  160. Plug 'https://bitbucket.org/junegunn/vim-emoji.git'
  161. call plug#end()
  162. Execute (PlugStatus):
  163. call PlugStatusSorted()
  164. Expect:
  165. Expected: https://git::@github.com/junegunn.choi/seoul256.vim.git
  166. Invalid URI: https://git::@github.com/junegunn/seoul256.vim.git
  167. PlugClean required.
  168. - vim-emoji: OK
  169. Finished. 1 error(s).
  170. [==]
  171. x seoul256.vim:
  172. # TODO: does not work due to inputsave()
  173. # Do (PlugClean):
  174. # :PlugClean\<Enter>y\<Enter>
  175. # ggyG
  176. # q
  177. # PGdd
  178. Execute (PlugClean! to remove seoul256.vim):
  179. PlugClean!
  180. " Three removed, emoji left
  181. AssertExpect '^- ', 3
  182. AssertExpect 'Removed', 1
  183. Assert empty(globpath(&rtp, 'colors/seoul256.vim'))
  184. Assert !empty(globpath(&rtp, 'autoload/emoji.vim'))
  185. q
  186. Execute (Change GIT URI of vim-emoji):
  187. call plug#begin()
  188. Plug 'junegunn/seoul256.vim'
  189. Plug 'junegunn/vim-emoji'
  190. call plug#end()
  191. Execute (PlugStatus):
  192. call PlugStatusSorted()
  193. Expect:
  194. Expected: https://git::@github.com/junegunn/vim-emoji.git
  195. Invalid URI: https://bitbucket.org/junegunn/vim-emoji.git
  196. Not found. Try PlugInstall.
  197. PlugClean required.
  198. Finished. 2 error(s).
  199. [==]
  200. x seoul256.vim:
  201. x vim-emoji:
  202. Execute (PlugClean! to remove vim-emoji):
  203. PlugClean!
  204. AssertExpect '^- ', 1
  205. AssertExpect 'Removed', 1
  206. Assert empty(globpath(&rtp, 'colors/seoul256.vim'))
  207. Assert empty(globpath(&rtp, 'autoload/emoji.vim'))
  208. q
  209. Execute (PlugUpdate to install both again):
  210. PlugUpdate
  211. AssertExpect '^- [^:]*:', 2
  212. Assert !empty(globpath(&rtp, 'colors/seoul256.vim')), 'seoul256.vim should be found'
  213. Assert !empty(globpath(&rtp, 'autoload/emoji.vim')), 'vim-emoji should be found'
  214. q
  215. Execute (PlugUpdate only to find out plugins are up-to-date, D key to check):
  216. PlugUpdate
  217. AssertExpect 'Already up-to-date', 2
  218. normal D
  219. AssertEqual 'No updates.', getline(1)
  220. q
  221. Execute (PlugDiff - 'No updates.'):
  222. PlugDiff
  223. AssertEqual 'No updates.', getline(1)
  224. q
  225. Execute (Rollback recent updates, PlugUpdate, then PlugDiff):
  226. for repo in ['seoul256.vim', 'vim-emoji']
  227. call system(printf('cd %s/%s && git reset HEAD^^ --hard', g:plug_home, repo))
  228. endfor
  229. PlugUpdate
  230. " Now we have updates
  231. normal D
  232. AssertEqual 'Last update:', getline(1)
  233. " Preview commit
  234. silent! wincmd P
  235. AssertEqual 0, &previewwindow
  236. " ]] motion
  237. execute 'normal ]]'
  238. let lnum = line('.')
  239. AssertEqual 3, col('.')
  240. " Open commit preview
  241. execute "normal j\<cr>"
  242. wincmd P
  243. AssertEqual 1, &previewwindow
  244. AssertEqual 'git', &filetype
  245. " Back to plug window
  246. wincmd p
  247. " ]] motion
  248. execute 'normal $]]'
  249. Assert index([lnum + 4, lnum + 5], line('.')) >= 0
  250. " +5 for merge commit
  251. AssertEqual 3, col('.')
  252. " [[ motion
  253. execute 'normal 0[['
  254. AssertEqual lnum, line('.')
  255. AssertEqual 3, col('.')
  256. " X key to revert the update
  257. AssertExpect '^- ', 2
  258. execute "normal Xn\<cr>"
  259. AssertExpect '^- ', 2
  260. execute "normal Xy\<cr>"
  261. AssertExpect '^- ', 1
  262. " q will close preview window as well
  263. normal q
  264. " We no longer have preview window
  265. silent! wincmd P
  266. AssertEqual 0, &previewwindow
  267. " q should not close preview window if it's already open
  268. pedit
  269. PlugDiff
  270. AssertExpect '^- ', 1
  271. execute "normal ]]j\<cr>"
  272. normal q
  273. silent! wincmd P
  274. AssertEqual 1, &previewwindow
  275. pclose
  276. Execute (Reuse Plug window in another tab):
  277. let tabnr = tabpagenr()
  278. PlugDiff
  279. tab new new-tab
  280. set buftype=nofile
  281. PlugUpdate
  282. normal D
  283. AssertExpect '^- ', 1
  284. normal q
  285. AssertEqual tabnr, tabpagenr()
  286. normal! gt
  287. q
  288. **********************************************************************
  289. ~ On-demand loading / Partial installation/update ~
  290. **********************************************************************
  291. Execute (Trying to execute on-demand commands when plugin is not installed):
  292. call plug#begin()
  293. Plug 'junegunn/vim-easy-align', { 'on': ['EasyAlign', 'LiveEasyAlign'] }
  294. call plug#end()
  295. Assert exists(':EasyAlign')
  296. Assert exists(':LiveEasyAlign')
  297. AssertThrows EasyAlign
  298. AssertThrows LiveEasyAlign
  299. Assert !exists(':EasyAlign')
  300. Assert !exists(':LiveEasyAlign')
  301. Execute (New set of plugins):
  302. call plug#begin()
  303. Plug 'junegunn/vim-fnr'
  304. Plug 'junegunn/vim-pseudocl'
  305. Plug 'junegunn/vim-easy-align', { 'on': 'EasyAlign' }
  306. Plug 'junegunn/vim-redis', { 'for': 'redis' }
  307. call plug#end()
  308. Execute (Check commands):
  309. Assert !exists(':FNR'), 'FNR command should not be found'
  310. Assert !exists(':RedisExecute'), 'RedisExecute command should not be found'
  311. Execute (Partial PlugInstall):
  312. PlugInstall vim-fnr vim-easy-align
  313. AssertExpect 'vim-fnr', 1
  314. q
  315. PlugInstall vim-fnr vim-easy-align 1
  316. AssertExpect 'vim-fnr', 1
  317. AssertExpect 'vim-easy-align', 1
  318. AssertEqual first_rtp, split(&rtp, ',')[0]
  319. AssertEqual last_rtp, split(&rtp, ',')[-1]
  320. q
  321. Given (Unaligned code):
  322. a=1
  323. aa=2
  324. Execute (Check installed plugins):
  325. call EnsureLoaded()
  326. Assert exists(':FNR'), 'FNR command should be found'
  327. Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
  328. Assert exists(':EasyAlign'), 'EasyAlign command should be found'
  329. %EasyAlign=
  330. Expect (Aligned code):
  331. a = 1
  332. aa = 2
  333. Given:
  334. Execute (Partial PlugUpdate):
  335. PlugUpdate vim-redis
  336. q
  337. Execute (On-demand loading based on filetypes):
  338. Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
  339. set ft=redis
  340. Assert exists(':RedisExecute'), 'RedisExecute command is now found'
  341. **********************************************************************
  342. ~ Local (unmanaged) plugins
  343. **********************************************************************
  344. Execute (Add unmanaged plugin):
  345. let fzf = expand('$PLUG_FIXTURES/fzf')
  346. Log fzf
  347. call plug#begin()
  348. Plug fzf, { 'on': 'SomeCommand' }
  349. call plug#end()
  350. " Check uri field
  351. Assert !has_key(g:plugs.fzf, 'uri'), 'Should not have uri field'
  352. " Check dir field
  353. AssertEqual fzf.'/', g:plugs.fzf.dir
  354. " Trailing slashes and backslashes should be stripped
  355. for suffix in ['///', '/\/\/']
  356. call plug#begin()
  357. Plug fzf.suffix, { 'on': 'SomeCommand' }
  358. call plug#end()
  359. " Check dir field
  360. AssertEqual fzf.'/', g:plugs.fzf.dir
  361. endfor
  362. Execute (Plug block for following tests):
  363. call plug#begin()
  364. Plug 'junegunn/vim-easy-align'
  365. Plug fzf, { 'on': 'SomeCommand' }
  366. call plug#end()
  367. " Remove plugins from previous tests
  368. PlugClean!
  369. Execute (PlugInstall will only install vim-easy-align):
  370. PlugInstall
  371. Log getline(1, '$')
  372. AssertExpect 'fzf', 0
  373. q
  374. Execute (PlugUpdate will only update vim-easy-align):
  375. PlugUpdate
  376. Log getline(1, '$')
  377. AssertExpect 'fzf', 0
  378. q
  379. Execute (PlugClean should not care about unmanaged plugins):
  380. PlugClean
  381. Log getline(1, '$')
  382. AssertExpect 'fzf', 0
  383. q
  384. Execute (PlugStatus should point out that the plugin is missing):
  385. PlugStatus
  386. Log getline(1, '$')
  387. AssertExpect 'x fzf', 1
  388. AssertExpect 'Not found', 1
  389. q
  390. Execute (Deploy unmanaged plugin):
  391. Assert !exists(':FZF'), ':FZF command should not exist'
  392. call rename(expand('$PLUG_FIXTURES/fzf-staged'), fzf)
  393. Execute (PlugUpdate still should not care):
  394. PlugUpdate
  395. Log getline(1, '$')
  396. AssertExpect 'fzf', 0
  397. q
  398. Execute (PlugStatus with no error):
  399. PlugStatus
  400. Log getline(1, '$')
  401. AssertExpect 'x fzf', 0
  402. AssertExpect 'Not found', 0
  403. q
  404. Execute (Check &rtp after SomeCommand):
  405. Log &rtp
  406. Assert &rtp !~ 'fzf'
  407. silent! SomeCommand
  408. Assert &rtp =~ 'fzf'
  409. AssertEqual first_rtp, split(&rtp, ',')[0]
  410. AssertEqual last_rtp, split(&rtp, ',')[-1]
  411. Execute (Common parent):
  412. call plug#begin()
  413. Plug 'junegunn/vim-pseudocl'
  414. Plug 'junegunn/vim-fnr'
  415. Plug 'junegunn/vim-oblique'
  416. call plug#end()
  417. PlugInstall
  418. Log getline(1, '$')
  419. AssertExpect! '[===]', 1
  420. q
  421. **********************************************************************
  422. ~ Frozen plugins
  423. **********************************************************************
  424. - We've decided to install plugins that are frozen: see #113
  425. Execute (Frozen plugin are not ~~installed nor~~ updated):
  426. " Remove plugins
  427. call plug#begin()
  428. call plug#end()
  429. PlugClean!
  430. q
  431. " vim-easy-align is not found, so it will be installed even though it's frozen
  432. call plug#begin()
  433. Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
  434. call plug#end()
  435. PlugInstall
  436. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  437. q
  438. " Remove plugins again
  439. call plug#begin()
  440. call plug#end()
  441. PlugClean!
  442. q
  443. " PlugUpdate will do the same
  444. call plug#begin()
  445. Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
  446. call plug#end()
  447. PlugInstall
  448. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  449. q
  450. " Since vim-easy-align already exists, PlugInstall or PlugUpdate will skip it
  451. redir => out
  452. silent PlugInstall
  453. redir END
  454. Assert out =~ 'No plugin to install'
  455. redir => out
  456. silent PlugUpdate
  457. redir END
  458. Assert out =~ 'No plugin to update'
  459. Execute (But you can still install it if the name is given as the argument):
  460. PlugInstall vim-easy-align
  461. Log getline(1, '$')
  462. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  463. q
  464. PlugUpdate vim-easy-align
  465. Log getline(1, '$')
  466. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  467. q
  468. **********************************************************************
  469. ~ Retry
  470. **********************************************************************
  471. Execute (Retry failed tasks):
  472. call plug#begin()
  473. Plug 'junegunn/vim-easy-align'
  474. Plug 'junegunn/aaaaaaaaaaaaaa'
  475. call plug#end()
  476. PlugInstall
  477. Log getline(1, '$')
  478. AssertExpect 'x aaa', 1
  479. AssertExpect '- vim-easy-align', 1
  480. normal R
  481. Log getline(1, '$')
  482. AssertExpect 'x aaa', 1
  483. AssertExpect '- vim-easy-align', 0
  484. AssertExpect! '[x]', 1
  485. q
  486. call plug#begin()
  487. Plug 'junegunn/vim-easy-align'
  488. Plug 'junegunn/aaaaaaaaaaaaaa'
  489. Plug 'junegunn/bbbbbbbbbbbbbb'
  490. Plug 'junegunn/cccccccccccccc'
  491. call plug#end()
  492. " Ruby installer
  493. PlugUpdate
  494. normal R
  495. AssertExpect '- vim-easy-align', 0
  496. AssertExpect! '[xxx]', 1
  497. q
  498. " Vim installer
  499. PlugUpdate 1
  500. normal R
  501. AssertExpect '- vim-easy-align', 0
  502. AssertExpect! '[xxx]', 1
  503. q
  504. **********************************************************************
  505. ~ Post-update hook (`do` option)
  506. **********************************************************************
  507. Execute (Cleanup):
  508. call plug#begin()
  509. call plug#end()
  510. PlugClean!
  511. Execute (On install):
  512. call plug#begin()
  513. Plug 'junegunn/vim-easy-align', { 'do': 'touch installed' }
  514. Plug 'junegunn/vim-pseudocl'
  515. call plug#end()
  516. PlugInstall
  517. q
  518. Assert filereadable(g:plugs['vim-easy-align'].dir.'/installed'),
  519. \ 'vim-easy-align/installed should exist'
  520. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed'),
  521. \ 'vim-pseudocl/installed should not exist'
  522. Execute (On update):
  523. call plug#begin()
  524. Plug 'junegunn/vim-easy-align', { 'do': 'touch updated' }
  525. Plug 'junegunn/vim-pseudocl', { 'do': 'touch updated' }
  526. call plug#end()
  527. " Reset for updates
  528. call system('cd '.g:plugs['vim-pseudocl'].dir.' && git reset --hard HEAD^')
  529. PlugUpdate
  530. Log getline(1, '$')
  531. q
  532. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated'),
  533. \ 'vim-easy-align/updated should not exist'
  534. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/updated'),
  535. \ 'vim-pseudocl/updated should exist'
  536. Execute (When already installed):
  537. call plug#begin()
  538. Plug 'junegunn/vim-easy-align', { 'do': 'touch installed2' }
  539. Plug 'junegunn/vim-pseudocl', { 'do': 'touch installed2' }
  540. call plug#end()
  541. PlugInstall
  542. q
  543. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
  544. \ 'vim-easy-align/installed2 should not exist'
  545. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
  546. \ 'vim-pseudocl/installed2 should not exist'
  547. Execute (PlugInstall!):
  548. PlugInstall!
  549. q
  550. Assert filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
  551. \ 'vim-easy-align/installed2 should exist'
  552. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
  553. \ 'vim-pseudocl/installed2 should exist'
  554. Execute (When already updated):
  555. call plug#begin()
  556. Plug 'junegunn/vim-easy-align', { 'do': 'touch updated2' }
  557. Plug 'junegunn/vim-pseudocl', { 'do': 'touch updated2' }
  558. call plug#end()
  559. PlugUpdate
  560. q
  561. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
  562. \ 'vim-easy-align/updated2 should not exist'
  563. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
  564. \ 'vim-pseudocl/updated2 should not exist'
  565. Execute (PlugUpdate!):
  566. PlugUpdate!
  567. q
  568. Assert filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
  569. \ 'vim-easy-align/updated2 should exist'
  570. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
  571. \ 'vim-pseudocl/updated2 should exist'
  572. Execute (Using Funcref):
  573. function! PlugUpdated(info)
  574. call system('touch '. a:info.name . a:info.status . a:info.force . len(a:info))
  575. endfunction
  576. call plug#begin()
  577. Plug 'junegunn/vim-easy-align', { 'do': function('PlugUpdated') }
  578. Plug 'junegunn/vim-pseudocl', { 'do': function('PlugUpdated') }
  579. call plug#end()
  580. call system('cd '.g:plugs['vim-easy-align'].dir.' && git reset --hard HEAD^')
  581. call system('rm -rf '.g:plugs['vim-pseudocl'].dir)
  582. PlugUpdate
  583. Log getline(1, '$')
  584. q
  585. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated03'),
  586. \ 'vim-easy-align/vim-easy-alignupdated03 should exist'
  587. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled03'),
  588. \ 'vim-pseudocl/vim-pseudoclinstalled03 should exist'
  589. call system('rm -rf '.g:plugs['vim-pseudocl'].dir)
  590. PlugInstall!
  591. q
  592. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignunchanged13'),
  593. \ 'vim-easy-align/vim-easy-alignunchanged13 should exist'
  594. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled13'),
  595. \ 'vim-pseudocl/vim-pseudoclinstalled13 should exist'
  596. call system('cd '.g:plugs['vim-easy-align'].dir.' && git reset --hard HEAD^')
  597. PlugUpdate!
  598. q
  599. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated13'),
  600. \ 'vim-easy-align/vim-easy-alignupdated13 should exist'
  601. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclunchanged13'),
  602. \ 'vim-pseudocl/vim-pseudoclunchanged13 should exist'
  603. **********************************************************************
  604. ~ Overriding `dir`
  605. **********************************************************************
  606. Execute (Using custom dir):
  607. Assert isdirectory(g:plugs['vim-easy-align'].dir)
  608. call system('rm -rf '.$TMPDIR.'easy-align')
  609. call plug#begin()
  610. Plug 'junegunn/vim-easy-align', { 'dir': $TMPDIR.'easy-align' }
  611. call plug#end()
  612. AssertEqual $TMPDIR.'easy-align/', g:plugs['vim-easy-align'].dir
  613. PlugClean!
  614. Assert !isdirectory(g:plugs['vim-easy-align'].dir)
  615. q
  616. PlugInstall
  617. q
  618. Assert isdirectory(g:plugs['vim-easy-align'].dir)
  619. **********************************************************************
  620. ~ On-demand loading load order
  621. **********************************************************************
  622. Before (Clear global vars):
  623. let g:xxx = []
  624. set rtp-=$PLUG_FIXTURES/xxx/
  625. set rtp-=$PLUG_FIXTURES/xxx/after
  626. Execute (Immediate loading):
  627. call plug#begin()
  628. Plug '$PLUG_FIXTURES/xxx'
  629. call plug#end()
  630. " FIXME:
  631. " Different result when Vader is run from commandline with `-c` option
  632. Log g:xxx
  633. if has('vim_starting')
  634. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  635. else
  636. AssertEqual ['xxx/plugin', 'xxx/after/plugin', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  637. endif
  638. Execute (Command-based on-demand loading):
  639. call plug#begin()
  640. Plug '$PLUG_FIXTURES/xxx', { 'on': 'XXX' }
  641. call plug#end()
  642. AssertEqual [], g:xxx
  643. silent! XXX
  644. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin'], g:xxx
  645. setf xxx
  646. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin', 'xxx/ftplugin', 'xxx/after/ftplugin', 'xxx/indent', 'xxx/after/indent', 'xxx/syntax', 'xxx/after/syntax'], g:xxx
  647. Execute (Filetype-based on-demand loading):
  648. call plug#begin()
  649. Plug '$PLUG_FIXTURES/xxx', { 'for': 'xxx' }
  650. call plug#end()
  651. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  652. setf xxx
  653. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin', 'xxx/ftplugin', 'xxx/after/ftplugin', 'xxx/indent', 'xxx/after/indent', 'xxx/syntax', 'xxx/after/syntax'], g:xxx
  654. Before:
  655. **********************************************************************
  656. ~ plug#helptags()
  657. **********************************************************************
  658. Execute (plug#helptags):
  659. silent! call delete(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  660. Assert !filereadable(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  661. AssertEqual 1, plug#helptags()
  662. Assert filereadable(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  663. **********************************************************************
  664. ~ Manual loading
  665. **********************************************************************
  666. Execute (plug#load - invalid arguments):
  667. AssertEqual 0, plug#load()
  668. AssertEqual 0, plug#load('non-existent-plugin')
  669. AssertEqual 0, plug#load('non-existent-plugin', 'another-non-existent-plugin')
  670. AssertEqual 1, plug#load('xxx')
  671. AssertEqual 0, plug#load('xxx', 'non-existent-plugin')
  672. AssertEqual 0, plug#load('non-existent-plugin', 'xxx')
  673. Execute (on: []):
  674. call plug#begin()
  675. Plug 'junegunn/rust.vim', { 'on': [] }
  676. call plug#end()
  677. PlugInstall
  678. q
  679. Execute (PlugStatus reports (not loaded)):
  680. PlugStatus
  681. AssertExpect 'not loaded', 1
  682. q
  683. Execute (plug#load to load it):
  684. tabnew test.rs
  685. " Vader will switch tab to [Vader-workbench] after Log
  686. " Log &filetype
  687. AssertEqual 1, plug#load('rust.vim')
  688. AssertEqual 'rust', &filetype
  689. q
  690. Execute (PlugStatus should not contain (not loaded)):
  691. PlugStatus
  692. AssertExpect 'not loaded', 0
  693. q
  694. Execute (Load plugin from PlugStatus screen with L key in normal mode):
  695. call plug#begin()
  696. Plug '$PLUG_FIXTURES/yyy', { 'on': [] }
  697. call plug#end()
  698. PlugStatus
  699. AssertExpect 'not loaded', 1
  700. Assert !exists('g:yyy'), 'yyy not loaded'
  701. /not loaded
  702. normal L
  703. AssertExpect 'not loaded', 0
  704. Assert exists('g:yyy'), 'yyy loaded'
  705. q
  706. Execute (Load plugin from PlugStatus screen with L key in visual mode):
  707. call plug#begin()
  708. Plug '$PLUG_FIXTURES/z1', { 'on': [] }
  709. Plug '$PLUG_FIXTURES/z2', { 'for': [] }
  710. call plug#end()
  711. PlugStatus
  712. AssertExpect 'not loaded', 2
  713. Assert !exists('g:z1'), 'z1 not loaded'
  714. Assert !exists('g:z2'), 'z2 not loaded'
  715. normal ggVGL
  716. AssertExpect 'not loaded', 0
  717. Assert exists('g:z1'), 'z1 loaded'
  718. Assert exists('g:z2'), 'z2 loaded'
  719. q
  720. **********************************************************************
  721. ~ g:plug_window
  722. **********************************************************************
  723. Execute (Open plug window in a new tab):
  724. " Without g:plug_window, plug window is open on the left split
  725. let tabnr = tabpagenr()
  726. PlugStatus
  727. AssertEqual tabnr, tabpagenr()
  728. AssertEqual 1, winnr()
  729. " PlugStatus again inside the window should not change the view
  730. normal S
  731. AssertEqual tabnr, tabpagenr()
  732. AssertEqual 1, winnr()
  733. q
  734. " Define g:plug_window so that plug window is open in a new tab
  735. let g:plug_window = 'tabnew'
  736. PlugStatus
  737. AssertNotEqual tabnr, tabpagenr()
  738. " PlugStatus again inside the window should not change the view
  739. let tabnr = tabpagenr()
  740. normal S
  741. AssertEqual tabnr, tabpagenr()
  742. q
  743. unlet g:plug_window
  744. **********************************************************************
  745. ~ g:plug_url_format
  746. **********************************************************************
  747. Execute (Using g:plug_url_format):
  748. call plug#begin()
  749. let g:plug_url_format = 'git@bitbucket.org:%s.git'
  750. Plug 'junegunn/seoul256.vim'
  751. let g:plug_url_format = 'git@bitsocket.org:%s.git'
  752. Plug 'beauty256'
  753. AssertEqual 'git@bitbucket.org:junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
  754. AssertEqual 'git@bitsocket.org:vim-scripts/beauty256.git', g:plugs['beauty256'].uri
  755. unlet g:plug_url_format
  756. **********************************************************************
  757. ~ U
  758. **********************************************************************
  759. Execute (Plug block):
  760. call plug#begin()
  761. Plug 'junegunn/vim-easy-align'
  762. Plug 'junegunn/vim-emoji'
  763. call plug#end()
  764. Execute (Update plugin with U key in normal mode):
  765. PlugStatus
  766. /emoji
  767. normal U
  768. Log getline(1, '$')
  769. AssertExpect 'Updated', 1
  770. AssertExpect 'vim-emoji', 1
  771. AssertExpect 'vim-easy-align', 0
  772. AssertExpect! '[=]', 1
  773. " From PlugInstall screen
  774. PlugInstall
  775. /easy-align
  776. normal U
  777. AssertExpect 'Updated', 1
  778. AssertExpect 'vim-emoji', 0
  779. AssertExpect 'vim-easy-align', 1
  780. AssertExpect! '[=]', 1
  781. q
  782. Execute (Update plugins with U key in visual mode):
  783. silent! call system('rm -rf '.g:plugs['vim-easy-align'].dir)
  784. PlugStatus
  785. normal VGU
  786. Log getline(1, '$')
  787. AssertExpect 'Updated', 1
  788. AssertExpect 'vim-emoji', 1
  789. AssertExpect 'vim-easy-align', 1
  790. AssertExpect! '[==]', 1
  791. " From PlugUpdate screen
  792. normal VGU
  793. Log getline(1, '$')
  794. AssertExpect 'Updated', 1
  795. AssertExpect 'vim-emoji', 1
  796. AssertExpect 'vim-easy-align', 1
  797. AssertExpect! '[==]', 1
  798. q
  799. **********************************************************************
  800. Execute (plug#begin should expand env vars):
  801. AssertNotEqual '$HOME/.emacs/plugged', expand('$HOME/.emacs/plugged')
  802. call plug#begin('$HOME/.emacs/plugged')
  803. AssertEqual expand('$HOME/.emacs/plugged'), g:plug_home
  804. **********************************************************************
  805. Execute (Plug directory with comma):
  806. call plug#begin(temp_plugged . '/p,l,u,g,g,e,d')
  807. Plug 'junegunn/vim-emoji'
  808. call plug#end()
  809. Log &rtp
  810. PlugInstall
  811. q
  812. let found = filter(split(globpath(&rtp, 'README.md'), '\n'), 'v:val =~ ","')
  813. Log found
  814. AssertEqual 1, len(found)
  815. **********************************************************************
  816. Execute (Strict load order):
  817. let g:total_order = []
  818. call plug#begin()
  819. Plug '$PLUG_FIXTURES/xxx'
  820. Plug '$PLUG_FIXTURES/yyy', { 'for': ['xxx'] }
  821. call plug#end()
  822. call EnsureLoaded()
  823. setf xxx
  824. Log 'Case 1: ' . &rtp
  825. AssertEqual ['yyy/ftdetect', 'yyy/after/ftdetect', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:total_order[0:3]
  826. Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
  827. Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
  828. let len = len(split(&rtp, ','))
  829. let g:total_order = []
  830. call plug#begin()
  831. Plug '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
  832. Plug '$PLUG_FIXTURES/yyy'
  833. call plug#end()
  834. call EnsureLoaded()
  835. set rtp^=manually-prepended
  836. set rtp+=manually-appended
  837. setf xxx
  838. Log 'Case 2: ' . &rtp
  839. AssertEqual 'manually-prepended', split(&rtp, ',')[3]
  840. AssertEqual 'manually-appended', split(&rtp, ',')[-4]
  841. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
  842. Assert index(g:total_order, 'yyy/plugin') < index(g:total_order, 'xxx/plugin')
  843. Assert index(g:total_order, 'yyy/after/plugin') < index(g:total_order, 'xxx/after/plugin')
  844. AssertEqual len + 2, len(split(&rtp, ','))
  845. let g:total_order = []
  846. call plug#begin()
  847. Plug '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
  848. Plug '$PLUG_FIXTURES/yyy', { 'for': ['xxx'] }
  849. call plug#end()
  850. call EnsureLoaded()
  851. setf xxx
  852. Log 'Case 3: ' . &rtp
  853. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
  854. Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
  855. Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
  856. AssertEqual len + 2, len(split(&rtp, ','))
  857. **********************************************************************
  858. Execute (PlugClean should not try to remove unmanaged plugins inside g:plug_home):
  859. call plug#begin('$PLUG_FIXTURES')
  860. Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': [] }
  861. Plug '$PLUG_FIXTURES/fzf'
  862. Plug '$PLUG_FIXTURES/xxx'
  863. Plug '$PLUG_FIXTURES/yyy'
  864. call plug#end()
  865. " Remove z1, z2
  866. PlugClean!
  867. AssertExpect '^- ', 2
  868. AssertExpect 'Already clean', 0
  869. PlugClean!
  870. AssertExpect '^- ', 0
  871. AssertExpect 'Already clean', 1
  872. q
  873. **********************************************************************
  874. Execute (#112 On-demand loading should not suppress messages from ftplugin):
  875. call plug#begin('$PLUG_FIXTURES')
  876. Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': 'c' }
  877. call plug#end()
  878. redir => out
  879. tabnew a.c
  880. redir END
  881. Assert stridx(out, 'ftplugin') >= 0
  882. * The same applies to plug#load())
  883. redir => out
  884. call plug#load('ftplugin-msg')
  885. redir END
  886. Assert stridx(out, 'ftplugin') >= 0
  887. q
  888. **********************************************************************
  889. Execute (PlugSnapshot):
  890. call plug#begin('$TMPDIR/plugged')
  891. Plug 'junegunn/vim-emoji'
  892. Plug 'junegunn/seoul256.vim'
  893. call plug#end()
  894. PlugInstall
  895. PlugSnapshot
  896. AssertEqual '#!/bin/bash', getline(1)
  897. AssertEqual '# Generated by vim-plug', getline(2)
  898. AssertEqual 'vim +PlugUpdate +qa', getline(5)
  899. AssertEqual 'PLUG_HOME=$TMPDIR/plugged', getline(7)
  900. AssertEqual 0, stridx(getline(9), 'cd $PLUG_HOME/seoul256.vim/ && git reset --hard')
  901. AssertEqual 0, stridx(getline(10), 'cd $PLUG_HOME/vim-emoji/ && git reset --hard')
  902. AssertEqual 'sh', &filetype
  903. execute 'PlugSnapshot' g:plug_home.'/snapshot.sh'
  904. AssertEqual 'sh', &filetype
  905. AssertEqual 'snapshot.sh', fnamemodify(expand('%'), ':t')
  906. q
  907. **********************************************************************
  908. Execute (#114 Should not contain empty path in &rtp):
  909. call plug#begin('$TMPDIR/plugged')
  910. call plug#end()
  911. Log &rtp
  912. Assert &rtp !~ ',,', 'Commas'
  913. Assert &rtp !~ '^,', 'Comma prefix'
  914. Assert &rtp !~ ',$', 'Comma suffix'
  915. Execute (Cleanup):
  916. silent! call system('rm -rf '.temp_plugged)
  917. silent! call system('rm -rf '.temp_plugged)
  918. silent! call rename(fzf, expand('$PLUG_FIXTURES/fzf-staged'))
  919. silent! unlet g:plugs
  920. silent! unlet g:plug_home
  921. silent! unlet g:plug_url_format
  922. silent! unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out tabnr found len
  923. silent! delf PlugStatusSorted
  924. silent! delf AssertExpect
  925. silent! delf PlugUpdated
  926. silent! delf EnsureLoaded
  927. silent! delc AssertExpect
  928. silent! unmap /
  929. silent! unmap ?
  930. Restore