workflow.vader 30 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084
  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. AssertEqual lnum + 4, line('.')
  250. AssertEqual 3, col('.')
  251. " [[ motion
  252. execute 'normal 0[['
  253. AssertEqual lnum, line('.')
  254. AssertEqual 3, col('.')
  255. " X key to revert the update
  256. AssertExpect '^- ', 2
  257. execute "normal Xn\<cr>"
  258. AssertExpect '^- ', 2
  259. execute "normal Xy\<cr>"
  260. AssertExpect '^- ', 1
  261. " q will close preview window as well
  262. normal q
  263. " We no longer have preview window
  264. silent! wincmd P
  265. AssertEqual 0, &previewwindow
  266. " q should not close preview window if it's already open
  267. pedit
  268. PlugDiff
  269. AssertExpect '^- ', 1
  270. execute "normal ]]j\<cr>"
  271. normal q
  272. silent! wincmd P
  273. AssertEqual 1, &previewwindow
  274. pclose
  275. Execute (Reuse Plug window in another tab):
  276. let tabnr = tabpagenr()
  277. PlugDiff
  278. tab new new-tab
  279. set buftype=nofile
  280. PlugUpdate
  281. normal D
  282. AssertExpect '^- ', 1
  283. normal q
  284. AssertEqual tabnr, tabpagenr()
  285. normal! gt
  286. q
  287. **********************************************************************
  288. ~ On-demand loading / Partial installation/update ~
  289. **********************************************************************
  290. Execute (Trying to execute on-demand commands when plugin is not installed):
  291. call plug#begin()
  292. Plug 'junegunn/vim-easy-align', { 'on': ['EasyAlign', 'LiveEasyAlign'] }
  293. call plug#end()
  294. Assert exists(':EasyAlign')
  295. Assert exists(':LiveEasyAlign')
  296. AssertThrows EasyAlign
  297. AssertThrows LiveEasyAlign
  298. Assert !exists(':EasyAlign')
  299. Assert !exists(':LiveEasyAlign')
  300. Execute (New set of plugins):
  301. call plug#begin()
  302. Plug 'junegunn/vim-fnr'
  303. Plug 'junegunn/vim-pseudocl'
  304. Plug 'junegunn/vim-easy-align', { 'on': 'EasyAlign' }
  305. Plug 'junegunn/vim-redis', { 'for': 'redis' }
  306. call plug#end()
  307. Execute (Check commands):
  308. Assert !exists(':FNR'), 'FNR command should not be found'
  309. Assert !exists(':RedisExecute'), 'RedisExecute command should not be found'
  310. Execute (Partial PlugInstall):
  311. PlugInstall vim-fnr vim-easy-align
  312. AssertExpect 'vim-fnr', 1
  313. q
  314. PlugInstall vim-fnr vim-easy-align 1
  315. AssertExpect 'vim-fnr', 1
  316. AssertExpect 'vim-easy-align', 1
  317. AssertEqual first_rtp, split(&rtp, ',')[0]
  318. AssertEqual last_rtp, split(&rtp, ',')[-1]
  319. q
  320. Given (Unaligned code):
  321. a=1
  322. aa=2
  323. Execute (Check installed plugins):
  324. call EnsureLoaded()
  325. Assert exists(':FNR'), 'FNR command should be found'
  326. Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
  327. Assert exists(':EasyAlign'), 'EasyAlign command should be found'
  328. %EasyAlign=
  329. Expect (Aligned code):
  330. a = 1
  331. aa = 2
  332. Given:
  333. Execute (Partial PlugUpdate):
  334. PlugUpdate vim-redis
  335. q
  336. Execute (On-demand loading based on filetypes):
  337. Assert !exists(':RedisExecute'), 'RedisExecute command still should not be found'
  338. set ft=redis
  339. Assert exists(':RedisExecute'), 'RedisExecute command is now found'
  340. **********************************************************************
  341. ~ Local (unmanaged) plugins
  342. **********************************************************************
  343. Execute (Add unmanaged plugin):
  344. let fzf = expand('$PLUG_FIXTURES/fzf')
  345. Log fzf
  346. call plug#begin()
  347. Plug fzf, { 'on': 'SomeCommand' }
  348. call plug#end()
  349. " Check uri field
  350. Assert !has_key(g:plugs.fzf, 'uri'), 'Should not have uri field'
  351. " Check dir field
  352. AssertEqual fzf.'/', g:plugs.fzf.dir
  353. " Trailing slashes and backslashes should be stripped
  354. for suffix in ['///', '/\/\/']
  355. call plug#begin()
  356. Plug fzf.suffix, { 'on': 'SomeCommand' }
  357. call plug#end()
  358. " Check dir field
  359. AssertEqual fzf.'/', g:plugs.fzf.dir
  360. endfor
  361. Execute (Plug block for following tests):
  362. call plug#begin()
  363. Plug 'junegunn/vim-easy-align'
  364. Plug fzf, { 'on': 'SomeCommand' }
  365. call plug#end()
  366. " Remove plugins from previous tests
  367. PlugClean!
  368. Execute (PlugInstall will only install vim-easy-align):
  369. PlugInstall
  370. Log getline(1, '$')
  371. AssertExpect 'fzf', 0
  372. q
  373. Execute (PlugUpdate will only update vim-easy-align):
  374. PlugUpdate
  375. Log getline(1, '$')
  376. AssertExpect 'fzf', 0
  377. q
  378. Execute (PlugClean should not care about unmanaged plugins):
  379. PlugClean
  380. Log getline(1, '$')
  381. AssertExpect 'fzf', 0
  382. q
  383. Execute (PlugStatus should point out that the plugin is missing):
  384. PlugStatus
  385. Log getline(1, '$')
  386. AssertExpect 'x fzf', 1
  387. AssertExpect 'Not found', 1
  388. q
  389. Execute (Deploy unmanaged plugin):
  390. Assert !exists(':FZF'), ':FZF command should not exist'
  391. call rename(expand('$PLUG_FIXTURES/fzf-staged'), fzf)
  392. Execute (PlugUpdate still should not care):
  393. PlugUpdate
  394. Log getline(1, '$')
  395. AssertExpect 'fzf', 0
  396. q
  397. Execute (PlugStatus with no error):
  398. PlugStatus
  399. Log getline(1, '$')
  400. AssertExpect 'x fzf', 0
  401. AssertExpect 'Not found', 0
  402. q
  403. Execute (Check &rtp after SomeCommand):
  404. Log &rtp
  405. Assert &rtp !~ 'fzf'
  406. silent! SomeCommand
  407. Assert &rtp =~ 'fzf'
  408. AssertEqual first_rtp, split(&rtp, ',')[0]
  409. AssertEqual last_rtp, split(&rtp, ',')[-1]
  410. Execute (Common parent):
  411. call plug#begin()
  412. Plug 'junegunn/vim-pseudocl'
  413. Plug 'junegunn/vim-fnr'
  414. Plug 'junegunn/vim-oblique'
  415. call plug#end()
  416. PlugInstall
  417. Log getline(1, '$')
  418. AssertExpect! '[===]', 1
  419. q
  420. **********************************************************************
  421. ~ Frozen plugins
  422. **********************************************************************
  423. Execute (Frozen plugin are not installed nor updated):
  424. call plug#begin()
  425. Plug 'junegunn/vim-easy-align', { 'frozen': 1 }
  426. call plug#end()
  427. redir => out
  428. silent PlugInstall
  429. redir END
  430. Assert out =~ 'No plugin to install'
  431. redir => out
  432. silent PlugUpdate
  433. redir END
  434. Assert out =~ 'No plugin to update'
  435. Execute (But you can still install it if the name is given as the argument):
  436. PlugInstall vim-easy-align
  437. Log getline(1, '$')
  438. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  439. q
  440. PlugUpdate vim-easy-align
  441. Log getline(1, '$')
  442. AssertEqual 1, len(filter(getline(1, '$'), 'v:val =~ "vim-easy-align"'))
  443. q
  444. **********************************************************************
  445. ~ Retry
  446. **********************************************************************
  447. Execute (Retry failed tasks):
  448. call plug#begin()
  449. Plug 'junegunn/vim-easy-align'
  450. Plug 'junegunn/aaaaaaaaaaaaaa'
  451. call plug#end()
  452. PlugInstall
  453. Log getline(1, '$')
  454. AssertExpect 'x aaa', 1
  455. AssertExpect '- vim-easy-align', 1
  456. normal R
  457. Log getline(1, '$')
  458. AssertExpect 'x aaa', 1
  459. AssertExpect '- vim-easy-align', 0
  460. AssertExpect! '[x]', 1
  461. q
  462. call plug#begin()
  463. Plug 'junegunn/vim-easy-align'
  464. Plug 'junegunn/aaaaaaaaaaaaaa'
  465. Plug 'junegunn/bbbbbbbbbbbbbb'
  466. Plug 'junegunn/cccccccccccccc'
  467. call plug#end()
  468. " Ruby installer
  469. PlugUpdate
  470. normal R
  471. AssertExpect '- vim-easy-align', 0
  472. AssertExpect! '[xxx]', 1
  473. q
  474. " Vim installer
  475. PlugUpdate 1
  476. normal R
  477. AssertExpect '- vim-easy-align', 0
  478. AssertExpect! '[xxx]', 1
  479. q
  480. **********************************************************************
  481. ~ Post-update hook (`do` option)
  482. **********************************************************************
  483. Execute (Cleanup):
  484. call plug#begin()
  485. call plug#end()
  486. PlugClean!
  487. Execute (On install):
  488. call plug#begin()
  489. Plug 'junegunn/vim-easy-align', { 'do': 'touch installed' }
  490. Plug 'junegunn/vim-pseudocl'
  491. call plug#end()
  492. PlugInstall
  493. q
  494. Assert filereadable(g:plugs['vim-easy-align'].dir.'/installed'),
  495. \ 'vim-easy-align/installed should exist'
  496. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed'),
  497. \ 'vim-pseudocl/installed should not exist'
  498. Execute (On update):
  499. call plug#begin()
  500. Plug 'junegunn/vim-easy-align', { 'do': 'touch updated' }
  501. Plug 'junegunn/vim-pseudocl', { 'do': 'touch updated' }
  502. call plug#end()
  503. " Reset for updates
  504. call system('cd '.g:plugs['vim-pseudocl'].dir.' && git reset --hard HEAD^')
  505. PlugUpdate
  506. Log getline(1, '$')
  507. q
  508. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated'),
  509. \ 'vim-easy-align/updated should not exist'
  510. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/updated'),
  511. \ 'vim-pseudocl/updated should exist'
  512. Execute (When already installed):
  513. call plug#begin()
  514. Plug 'junegunn/vim-easy-align', { 'do': 'touch installed2' }
  515. Plug 'junegunn/vim-pseudocl', { 'do': 'touch installed2' }
  516. call plug#end()
  517. PlugInstall
  518. q
  519. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
  520. \ 'vim-easy-align/installed2 should not exist'
  521. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
  522. \ 'vim-pseudocl/installed2 should not exist'
  523. Execute (PlugInstall!):
  524. PlugInstall!
  525. q
  526. Assert filereadable(g:plugs['vim-easy-align'].dir.'/installed2'),
  527. \ 'vim-easy-align/installed2 should exist'
  528. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/installed2'),
  529. \ 'vim-pseudocl/installed2 should exist'
  530. Execute (When already updated):
  531. call plug#begin()
  532. Plug 'junegunn/vim-easy-align', { 'do': 'touch updated2' }
  533. Plug 'junegunn/vim-pseudocl', { 'do': 'touch updated2' }
  534. call plug#end()
  535. PlugUpdate
  536. q
  537. Assert !filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
  538. \ 'vim-easy-align/updated2 should not exist'
  539. Assert !filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
  540. \ 'vim-pseudocl/updated2 should not exist'
  541. Execute (PlugUpdate!):
  542. PlugUpdate!
  543. q
  544. Assert filereadable(g:plugs['vim-easy-align'].dir.'/updated2'),
  545. \ 'vim-easy-align/updated2 should exist'
  546. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/updated2'),
  547. \ 'vim-pseudocl/updated2 should exist'
  548. Execute (Using Funcref):
  549. function! PlugUpdated(info)
  550. call system('touch '. a:info.name . a:info.status . a:info.force . len(a:info))
  551. endfunction
  552. call plug#begin()
  553. Plug 'junegunn/vim-easy-align', { 'do': function('PlugUpdated') }
  554. Plug 'junegunn/vim-pseudocl', { 'do': function('PlugUpdated') }
  555. call plug#end()
  556. call system('cd '.g:plugs['vim-easy-align'].dir.' && git reset --hard HEAD^')
  557. call system('rm -rf '.g:plugs['vim-pseudocl'].dir)
  558. PlugUpdate
  559. Log getline(1, '$')
  560. q
  561. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated03'),
  562. \ 'vim-easy-align/vim-easy-alignupdated03 should exist'
  563. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled03'),
  564. \ 'vim-pseudocl/vim-pseudoclinstalled03 should exist'
  565. call system('rm -rf '.g:plugs['vim-pseudocl'].dir)
  566. PlugInstall!
  567. q
  568. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignunchanged13'),
  569. \ 'vim-easy-align/vim-easy-alignunchanged13 should exist'
  570. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclinstalled13'),
  571. \ 'vim-pseudocl/vim-pseudoclinstalled13 should exist'
  572. call system('cd '.g:plugs['vim-easy-align'].dir.' && git reset --hard HEAD^')
  573. PlugUpdate!
  574. q
  575. Assert filereadable(g:plugs['vim-easy-align'].dir.'/vim-easy-alignupdated13'),
  576. \ 'vim-easy-align/vim-easy-alignupdated13 should exist'
  577. Assert filereadable(g:plugs['vim-pseudocl'].dir.'/vim-pseudoclunchanged13'),
  578. \ 'vim-pseudocl/vim-pseudoclunchanged13 should exist'
  579. **********************************************************************
  580. ~ Overriding `dir`
  581. **********************************************************************
  582. Execute (Using custom dir):
  583. Assert isdirectory(g:plugs['vim-easy-align'].dir)
  584. call system('rm -rf '.$TMPDIR.'easy-align')
  585. call plug#begin()
  586. Plug 'junegunn/vim-easy-align', { 'dir': $TMPDIR.'easy-align' }
  587. call plug#end()
  588. AssertEqual $TMPDIR.'easy-align/', g:plugs['vim-easy-align'].dir
  589. PlugClean!
  590. Assert !isdirectory(g:plugs['vim-easy-align'].dir)
  591. q
  592. PlugInstall
  593. q
  594. Assert isdirectory(g:plugs['vim-easy-align'].dir)
  595. **********************************************************************
  596. ~ On-demand loading load order
  597. **********************************************************************
  598. Before (Clear global vars):
  599. let g:xxx = []
  600. set rtp-=$PLUG_FIXTURES/xxx/
  601. set rtp-=$PLUG_FIXTURES/xxx/after
  602. Execute (Immediate loading):
  603. call plug#begin()
  604. Plug '$PLUG_FIXTURES/xxx'
  605. call plug#end()
  606. " FIXME:
  607. " Different result when Vader is run from commandline with `-c` option
  608. Log g:xxx
  609. if has('vim_starting')
  610. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  611. else
  612. AssertEqual ['xxx/plugin', 'xxx/after/plugin', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  613. endif
  614. Execute (Command-based on-demand loading):
  615. call plug#begin()
  616. Plug '$PLUG_FIXTURES/xxx', { 'on': 'XXX' }
  617. call plug#end()
  618. AssertEqual [], g:xxx
  619. silent! XXX
  620. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'xxx/plugin', 'xxx/after/plugin'], g:xxx
  621. setf xxx
  622. 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
  623. Execute (Filetype-based on-demand loading):
  624. call plug#begin()
  625. Plug '$PLUG_FIXTURES/xxx', { 'for': 'xxx' }
  626. call plug#end()
  627. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect'], g:xxx
  628. setf xxx
  629. 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
  630. Before:
  631. **********************************************************************
  632. ~ plug#helptags()
  633. **********************************************************************
  634. Execute (plug#helptags):
  635. silent! call delete(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  636. Assert !filereadable(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  637. AssertEqual 1, plug#helptags()
  638. Assert filereadable(expand('$PLUG_FIXTURES/xxx/doc/tags'))
  639. **********************************************************************
  640. ~ Manual loading
  641. **********************************************************************
  642. Execute (plug#load - invalid arguments):
  643. AssertEqual 0, plug#load()
  644. AssertEqual 0, plug#load('non-existent-plugin')
  645. AssertEqual 0, plug#load('non-existent-plugin', 'another-non-existent-plugin')
  646. AssertEqual 1, plug#load('xxx')
  647. AssertEqual 0, plug#load('xxx', 'non-existent-plugin')
  648. AssertEqual 0, plug#load('non-existent-plugin', 'xxx')
  649. Execute (on: []):
  650. call plug#begin()
  651. Plug 'junegunn/rust.vim', { 'on': [] }
  652. call plug#end()
  653. PlugInstall
  654. q
  655. Execute (PlugStatus reports (not loaded)):
  656. PlugStatus
  657. AssertExpect 'not loaded', 1
  658. q
  659. Execute (plug#load to load it):
  660. tabnew test.rs
  661. " Vader will switch tab to [Vader-workbench] after Log
  662. " Log &filetype
  663. AssertEqual 1, plug#load('rust.vim')
  664. AssertEqual 'rust', &filetype
  665. q
  666. Execute (PlugStatus should not contain (not loaded)):
  667. PlugStatus
  668. AssertExpect 'not loaded', 0
  669. q
  670. Execute (Load plugin from PlugStatus screen with L key in normal mode):
  671. call plug#begin()
  672. Plug '$PLUG_FIXTURES/yyy', { 'on': [] }
  673. call plug#end()
  674. PlugStatus
  675. AssertExpect 'not loaded', 1
  676. Assert !exists('g:yyy'), 'yyy not loaded'
  677. /not loaded
  678. normal L
  679. AssertExpect 'not loaded', 0
  680. Assert exists('g:yyy'), 'yyy loaded'
  681. q
  682. Execute (Load plugin from PlugStatus screen with L key in visual mode):
  683. call plug#begin()
  684. Plug '$PLUG_FIXTURES/z1', { 'on': [] }
  685. Plug '$PLUG_FIXTURES/z2', { 'for': [] }
  686. call plug#end()
  687. PlugStatus
  688. AssertExpect 'not loaded', 2
  689. Assert !exists('g:z1'), 'z1 not loaded'
  690. Assert !exists('g:z2'), 'z2 not loaded'
  691. normal ggVGL
  692. AssertExpect 'not loaded', 0
  693. Assert exists('g:z1'), 'z1 loaded'
  694. Assert exists('g:z2'), 'z2 loaded'
  695. q
  696. **********************************************************************
  697. ~ g:plug_window
  698. **********************************************************************
  699. Execute (Open plug window in a new tab):
  700. " Without g:plug_window, plug window is open on the left split
  701. let tabnr = tabpagenr()
  702. PlugStatus
  703. AssertEqual tabnr, tabpagenr()
  704. AssertEqual 1, winnr()
  705. " PlugStatus again inside the window should not change the view
  706. normal S
  707. AssertEqual tabnr, tabpagenr()
  708. AssertEqual 1, winnr()
  709. q
  710. " Define g:plug_window so that plug window is open in a new tab
  711. let g:plug_window = 'tabnew'
  712. PlugStatus
  713. AssertNotEqual tabnr, tabpagenr()
  714. " PlugStatus again inside the window should not change the view
  715. let tabnr = tabpagenr()
  716. normal S
  717. AssertEqual tabnr, tabpagenr()
  718. q
  719. unlet g:plug_window
  720. **********************************************************************
  721. ~ g:plug_url_format
  722. **********************************************************************
  723. Execute (Using g:plug_url_format):
  724. call plug#begin()
  725. let g:plug_url_format = 'git@bitbucket.org:%s.git'
  726. Plug 'junegunn/seoul256.vim'
  727. let g:plug_url_format = 'git@bitsocket.org:%s.git'
  728. Plug 'beauty256'
  729. AssertEqual 'git@bitbucket.org:junegunn/seoul256.vim.git', g:plugs['seoul256.vim'].uri
  730. AssertEqual 'git@bitsocket.org:vim-scripts/beauty256.git', g:plugs['beauty256'].uri
  731. unlet g:plug_url_format
  732. **********************************************************************
  733. ~ U
  734. **********************************************************************
  735. Execute (Plug block):
  736. call plug#begin()
  737. Plug 'junegunn/vim-easy-align'
  738. Plug 'junegunn/vim-emoji'
  739. call plug#end()
  740. Execute (Update plugin with U key in normal mode):
  741. PlugStatus
  742. /emoji
  743. normal U
  744. Log getline(1, '$')
  745. AssertExpect 'Updated', 1
  746. AssertExpect 'vim-emoji', 1
  747. AssertExpect 'vim-easy-align', 0
  748. AssertExpect! '[=]', 1
  749. " From PlugInstall screen
  750. PlugInstall
  751. /easy-align
  752. normal U
  753. AssertExpect 'Updated', 1
  754. AssertExpect 'vim-emoji', 0
  755. AssertExpect 'vim-easy-align', 1
  756. AssertExpect! '[=]', 1
  757. q
  758. Execute (Update plugins with U key in visual mode):
  759. silent! call system('rm -rf '.g:plugs['vim-easy-align'].dir)
  760. PlugStatus
  761. normal VGU
  762. Log getline(1, '$')
  763. AssertExpect 'Updated', 1
  764. AssertExpect 'vim-emoji', 1
  765. AssertExpect 'vim-easy-align', 1
  766. AssertExpect! '[==]', 1
  767. " From PlugUpdate screen
  768. normal VGU
  769. Log getline(1, '$')
  770. AssertExpect 'Updated', 1
  771. AssertExpect 'vim-emoji', 1
  772. AssertExpect 'vim-easy-align', 1
  773. AssertExpect! '[==]', 1
  774. q
  775. **********************************************************************
  776. Execute (plug#begin should expand env vars):
  777. AssertNotEqual '$HOME/.emacs/plugged', expand('$HOME/.emacs/plugged')
  778. call plug#begin('$HOME/.emacs/plugged')
  779. AssertEqual expand('$HOME/.emacs/plugged'), g:plug_home
  780. **********************************************************************
  781. Execute (Plug directory with comma):
  782. call plug#begin(temp_plugged . '/p,l,u,g,g,e,d')
  783. Plug 'junegunn/vim-emoji'
  784. call plug#end()
  785. Log &rtp
  786. PlugInstall
  787. q
  788. let found = filter(split(globpath(&rtp, 'README.md'), '\n'), 'v:val =~ ","')
  789. Log found
  790. AssertEqual 1, len(found)
  791. **********************************************************************
  792. Execute (Strict load order):
  793. let g:total_order = []
  794. call plug#begin()
  795. Plug '$PLUG_FIXTURES/xxx'
  796. Plug '$PLUG_FIXTURES/yyy', { 'for': ['xxx'] }
  797. call plug#end()
  798. call EnsureLoaded()
  799. setf xxx
  800. Log 'Case 1: ' . &rtp
  801. AssertEqual ['yyy/ftdetect', 'yyy/after/ftdetect', 'xxx/ftdetect', 'xxx/after/ftdetect'], g:total_order[0:3]
  802. Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
  803. Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
  804. let len = len(split(&rtp, ','))
  805. let g:total_order = []
  806. call plug#begin()
  807. Plug '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
  808. Plug '$PLUG_FIXTURES/yyy'
  809. call plug#end()
  810. call EnsureLoaded()
  811. set rtp^=manually-prepended
  812. set rtp+=manually-appended
  813. setf xxx
  814. Log 'Case 2: ' . &rtp
  815. AssertEqual 'manually-prepended', split(&rtp, ',')[3]
  816. AssertEqual 'manually-appended', split(&rtp, ',')[-4]
  817. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
  818. Assert index(g:total_order, 'yyy/plugin') < index(g:total_order, 'xxx/plugin')
  819. Assert index(g:total_order, 'yyy/after/plugin') < index(g:total_order, 'xxx/after/plugin')
  820. AssertEqual len + 2, len(split(&rtp, ','))
  821. let g:total_order = []
  822. call plug#begin()
  823. Plug '$PLUG_FIXTURES/xxx', { 'for': ['xxx'] }
  824. Plug '$PLUG_FIXTURES/yyy', { 'for': ['xxx'] }
  825. call plug#end()
  826. call EnsureLoaded()
  827. setf xxx
  828. Log 'Case 3: ' . &rtp
  829. AssertEqual ['xxx/ftdetect', 'xxx/after/ftdetect', 'yyy/ftdetect', 'yyy/after/ftdetect'], g:total_order[0:3]
  830. Assert index(g:total_order, 'xxx/plugin') < index(g:total_order, 'yyy/plugin')
  831. Assert index(g:total_order, 'xxx/after/plugin') < index(g:total_order, 'yyy/after/plugin')
  832. AssertEqual len + 2, len(split(&rtp, ','))
  833. **********************************************************************
  834. Execute (PlugClean should not try to remove unmanaged plugins inside g:plug_home):
  835. call plug#begin('$PLUG_FIXTURES')
  836. Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': [] }
  837. Plug '$PLUG_FIXTURES/fzf'
  838. Plug '$PLUG_FIXTURES/xxx'
  839. Plug '$PLUG_FIXTURES/yyy'
  840. call plug#end()
  841. " Remove z1, z2
  842. PlugClean!
  843. AssertExpect '^- ', 2
  844. AssertExpect 'Already clean', 0
  845. PlugClean!
  846. AssertExpect '^- ', 0
  847. AssertExpect 'Already clean', 1
  848. q
  849. **********************************************************************
  850. Execute (#112 On-demand loading should not suppress messages from ftplugin):
  851. call plug#begin('$PLUG_FIXTURES')
  852. Plug '$PLUG_FIXTURES/ftplugin-msg', { 'for': 'c' }
  853. call plug#end()
  854. redir => out
  855. tabnew a.c
  856. redir END
  857. Assert stridx(out, 'ftplugin') >= 0
  858. * The same applies to plug#load())
  859. redir => out
  860. call plug#load('ftplugin-msg')
  861. redir END
  862. Assert stridx(out, 'ftplugin') >= 0
  863. q
  864. **********************************************************************
  865. Execute (PlugSnapshot):
  866. call plug#begin('$TMPDIR/plugged')
  867. Plug 'junegunn/vim-emoji'
  868. Plug 'junegunn/seoul256.vim'
  869. call plug#end()
  870. PlugInstall
  871. PlugSnapshot
  872. AssertEqual '#!/bin/bash', getline(1)
  873. AssertEqual '# Generated by vim-plug', getline(2)
  874. AssertEqual 'vim +PlugUpdate +qa', getline(5)
  875. AssertEqual 'PLUG_HOME=$TMPDIR/plugged', getline(7)
  876. AssertEqual 0, stridx(getline(9), 'cd $PLUG_HOME/seoul256.vim/ && git reset --hard')
  877. AssertEqual 0, stridx(getline(10), 'cd $PLUG_HOME/vim-emoji/ && git reset --hard')
  878. AssertEqual 'sh', &filetype
  879. execute 'PlugSnapshot' g:plug_home.'/snapshot.sh'
  880. AssertEqual 'sh', &filetype
  881. AssertEqual 'snapshot.sh', fnamemodify(expand('%'), ':t')
  882. q
  883. Execute (Cleanup):
  884. silent! call system('rm -rf '.temp_plugged)
  885. silent! call system('rm -rf '.temp_plugged)
  886. silent! call rename(fzf, expand('$PLUG_FIXTURES/fzf-staged'))
  887. silent! unlet g:plugs
  888. silent! unlet g:plug_home
  889. silent! unlet g:plug_url_format
  890. silent! unlet temp_plugged vader plug basertp save_rtp repo lnum fzf out tabnr found len
  891. silent! delf PlugStatusSorted
  892. silent! delf AssertExpect
  893. silent! delf PlugUpdated
  894. silent! delf EnsureLoaded
  895. silent! delc AssertExpect
  896. silent! unmap /
  897. silent! unmap ?
  898. Restore