workflow.vader 29 KB

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