Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

g? (rot13) support #4367

Merged
merged 1 commit into from Dec 26, 2019
Merged

g? (rot13) support #4367

merged 1 commit into from Dec 26, 2019

Conversation

J-Fields
Copy link
Member

Fixes #4363

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[07:17:41] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[07:17:41] Starting 'build'...
[07:17:41] Starting 'prettier'...
[07:17:44] Finished 'prettier' after 2.73 s
[07:17:44] Starting 'tsc'...
[07:17:44] Starting 'tslint'...
[07:17:52] Finished 'tslint' after 8.09 s
[07:18:01] Finished 'tsc' after 17 s
[07:18:01] Starting 'commit-hash'...
[07:18:01] Finished 'commit-hash' after 34 ms
[07:18:01] Finished 'build' after 20 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-11T07:18:06.331Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses
    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (135ms)

    ✓ command <C-w> can remove word in search mode (73ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor (83ms)

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (45ms)

    ✓ <C-u> deletes from cursor to first character (40ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line (40ms)

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (44ms)

    ✓ <C-p>/<C-n> go to the previous/next command (84ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (107ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (40ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line (41ms)

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history (40ms)

    ✓ file system

    ✓ change configuration.history (68ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent
    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (558ms)

    ✓ :smile editor contains smile text (540ms)

  Basic sort

    ✓ Sort whole file, asc (126ms)

    ✓ Sort whole file, asc, ignoreCase (226ms)

    ✓ Sort whole file, dsc (119ms)

    ✓ Sort whole file, dsc, ignoreCase (117ms)

    ✓ Sort range, asc (288ms)

    ✓ Sort range, asc, ignoreCase (152ms)

    ✓ Sort range, dsc (190ms)

    ✓ Sort range, dsc, ignoreCase (127ms)

    ✓ Sort whole file, asc, unique (171ms)

  Horizontal split

    ✓ Run :sp (78ms)

    ✓ Run :split (72ms)

    ✓ Run :new (91ms)

  :close args parser
    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input
  :quit args parser
    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (57ms)

    ✓ Replace with `g` flag (66ms)

    ✓ Replace with flags AND count (111ms)

    ✓ Replace with `c` flag (69ms)

    ✓ Replace with `gc` flag (120ms)

    ✓ Replace across all lines (109ms)

    ✓ Replace on specific single line (150ms)

    ✓ Replace on current line using dot (90ms)

    ✓ Replace single relative line using dot and plus (128ms)

    ✓ Replace across specific line range (168ms)

    ✓ Replace across relative line range using dot, plus, and minus (149ms)

    ✓ Replace across relative line range using numLines+colon shorthand (111ms)

    ✓ Repeat replacement across relative line range (147ms)

    ✓ Replace with range AND count but no flags (120ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (102ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (131ms)

    ✓ Undocumented: trailing operators use 1 as RHS (104ms)

    ✓ Replace specific single equal lines (81ms)

    ✓ Replace current line with no active selection (81ms)

    ✓ Replace text in selection (144ms)

    ✓ Substitute support marks (131ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (47ms)

      ✓ Replace with `g` flag inverts global flag (62ms)

      ✓ Replace with `c` flag inverts global flag (75ms)

      ✓ Replace multiple lines (110ms)

      ✓ Replace across specific lines (101ms)

      ✓ Replace current line with no active selection (99ms)

      ✓ Replace text in selection (128ms)

      ✓ Substitute support marks (197ms)

      ✓ Substitute with escaped delimiter (75ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (322ms)

      ✓ Substitute with previous search using # (333ms)

      ✓ Substitute with previous search using / (298ms)

      ✓ Substitute with parameters should update search state (177ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (387ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (308ms)

      ✓ Substitute repeat previous should accept flags (142ms)

      ✓ Substitute with empty search string should use last searched pattern (392ms)

      ✓ Ampersand (&) should repeat the last substitution (221ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file (47ms)

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (81ms)

    ✓ tabe with current file path does nothing (69ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (45ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (75ms)

    ✓ command line file tab completion with space in file path (133ms)

  Vertical split

    ✓ Run :vs (79ms)

    ✓ Run :vsp (77ms)

    ✓ Run :vsplit (78ms)

    ✓ Run :vnew (290ms)

    ✓ Run :vne (299ms)

  Basic write-quit

    ✓ Run write and quit (97ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (51ms)

      ✓ Can complete lines in file with different indentation (72ms)

      ✓ Returns no completions for unmatched line (62ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (113ms)

  Notation

    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (112ms)

    ✓ getMatchingRemap (99ms)

    ✓ jj -> <Esc> through modehandler (113ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (101ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (132ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (120ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (124ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (178ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (166ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (187ms)

  Neovim Validator

    ✓ neovim enabled without path
    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings
    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (98ms)

        ✓ Can track jumps for keys: GggG (203ms)

        ✓ Can track jumps for keys: GggGgg (129ms)

[main 2019-12-11T07:18:36.335Z] update#setState checking for updates

[main 2019-12-11T07:18:36.392Z] update#setState idle

        ✓ Can track jumps for keys: /b<CR>n (152ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (182ms)

        ✓ Can track jumps for keys: j%% (212ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (132ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (193ms)

        ✓ Can track jumps for keys: j%%<C-o>% (164ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (63ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (235ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (204ms)

        ✓ Can enter number to jump back multiple times (82ms)

        ✓ Can track one-line `` jumps (187ms)

        ✓ Can track one-line double `` jumps (188ms)

        ✓ Can track one-line '' jumps (222ms)

        ✓ Can track one-line double '' jumps (176ms)

        ✓ Can handle '' jumps with no previous jump (182ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (193ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (152ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (244ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (179ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (217ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (270ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (244ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (272ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (226ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (150ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (216ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (170ms)

  Record and execute a macro

    ✓ Can record and execute (297ms)

    ✓ Can repeat last invoked macro (229ms)

    ✓ Can play back with count (517ms)

    ✓ Can play back with count, abort when a motion fails (432ms)

    ✓ Repeat change on contiguous lines (177ms)

    ✓ Append command to a macro (236ms)

    ✓ Can record Ctrl Keys and repeat (317ms)

    ✓ Can execute macros with dot commands properly (169ms)

    ✓ : (command) register can be used as a macro (239ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (130ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (63ms)

    ✓ <C-c> can exit insert (73ms)

    ✓ <Esc> can exit insert (73ms)

    ✓ Stay in insert when entering characters (101ms)

    ✓ Can handle 'O' (67ms)

    ✓ Can handle 'i' (103ms)

    ✓ Can handle 'I' (81ms)

    ✓ Can handle 'a' (100ms)

    ✓ Can handle 'A' (88ms)

    ✓ Can handle '<C-w>' (92ms)

    ✓ Can handle <C-w> on leading whitespace (98ms)

    ✓ Can handle <C-w> at beginning of line (72ms)

    ✓ Can handle <C-u> (199ms)

    ✓ Can handle <C-u> on leading characters (136ms)

    ✓ Can handle <C-u> on leading whitespace (125ms)

    ✓ Correctly places the cursor after deleting the previous line break (98ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (57ms)

    ✓ Backspace works on whitespace only lines (99ms)

    ✓ Backspace works on end of whitespace only lines (126ms)

    ✓ Backspace works at beginning of file (78ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (158ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (110ms)

    ✓ Can perform insert command prefixed with count (227ms)

    ✓ Can perform append command prefixed with count (111ms)

    ✓ Can perform insert at start of line command prefixed with count (122ms)

    ✓ Can perform append to end of line command prefixed with count (106ms)

    ✓ Can perform change char (s) command prefixed with count (139ms)

    ✓ Can perform command prefixed with count with <C-[> (98ms)

    ✓ Can handle 'o' with count (282ms)

    ✓ Can handle 'O' with count (186ms)

    ✓ Can handle backspace at beginning of line with all spaces (57ms)

    ✓ Can handle digraph insert (87ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (63ms)

    ✓ Can handle dw (68ms)

    ✓ Can handle dw (177ms)

    ✓ Can handle dw across lines (1) (105ms)

    ✓ Can handle dw across lines (2) (59ms)

    ✓ Can handle dd last line (53ms)

    ✓ Can handle dd single line (40ms)

    ✓ Can handle dd (71ms)

    ✓ Can handle 3dd (63ms)

    ✓ Can handle 3dd off end of document (69ms)

    ✓ Can handle d2d (74ms)

    ✓ Can handle dd empty line (115ms)

    ✓ Can handle ddp (132ms)

    ✓ Can handle 'de' (95ms)

    ✓ Can handle 'de' then 'de' again (101ms)

    ✓ Can handle 'db' (92ms)

    ✓ Can handle 'db then 'db' again (164ms)

    ✓ Can handle 'dl' at end of line (136ms)

    ✓ Can handle 'dF' (67ms)

    ✓ Can handle 'dT' (198ms)

    ✓ Can handle 'd3' then <enter> (104ms)

    ✓ Can handle 'dj' (97ms)

    ✓ Can handle 'dk' (97ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (146ms)

    ✓ Can handle 'd]}' without deleting closing bracket (93ms)

    ✓ Can handle 'cw' (353ms)

    ✓ Can handle 'cw' without deleting following white spaces (80ms)

    ✓ Can handle 'c2w' (41ms)

    ✓ Can handle 'cw' without removing EOL (99ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (96ms)

    ✓ Can handle 'c]}' without deleting closing bracket (94ms)

    ✓ Can handle 's' (116ms)

    ✓ Can handle 'yiw' with correct cursor ending position (99ms)

    ✓ Can handle 'ciw' (234ms)

    ✓ Can handle 'ciw' on blanks (184ms)

    ✓ Can handle 'caw' (150ms)

    ✓ Can handle 'caw' on first letter (128ms)

    ✓ Can handle 'caw' on blanks (180ms)

    ✓ Can handle 'caw' on blanks (90ms)

    ✓ Can handle 'ci(' on first parentheses (180ms)

    ✓ Can handle 'ci(' with nested parentheses (69ms)

    ✓ Can handle 'ci(' backwards through nested parens (186ms)

    ✓ Can handle 'cib' on first parentheses (74ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (138ms)

    ✓ Can handle count prefixed 'ci)' (116ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (77ms)

    ✓ Can handle 'cab' spanning multiple lines (54ms)

    ✓ Can handle 'ci{' spanning multiple lines (138ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (110ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (167ms)

    ✓ Can handle 'ci(' on the closing bracket (78ms)

    ✓ Can handle 'ciB' spanning multiple lines (62ms)

    ✓ will fail when ca( with no () (44ms)

    ✓ will fail when ca{ with no {} (107ms)

    ✓ will fail when caB with no {} (156ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (54ms)

    ✓ Can handle 'ca[' on first bracket (69ms)

    ✓ Can handle 'ca]' on first bracket (133ms)

    ✓ Can handle 'ci'' on first quote (117ms)

    ✓ Can handle 'ci'' inside quoted string (202ms)

    ✓ Can handle 'ci'' on closing quote (170ms)

    ✓ Can handle 'ci'' when string is ahead (197ms)

    ✓ Can handle 'ci"' on opening quote (95ms)

    ✓ Can handle 'ci"' starting behind the quoted word (117ms)

    ✓ Can handle 'ca"' starting behind the quoted word (113ms)

    ✓ Can handle 'ca"' starting on the opening quote (95ms)

    ✓ Can handle 'ci"' with escaped quotes (118ms)

    ✓ Can handle 'ci"' with a single escaped quote (221ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (151ms)

    ✓ Can handle 'ci"' with an escaped backslash (99ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (67ms)

    ✓ Can handle 'ca"' starting on the closing quote (70ms)

    ✓ Can handle 'ci"' with complex escape sequences (71ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (121ms)

    ✓ will fail when ca" ahead of quoted string (97ms)

    ✓ Can handle 'ca`' inside word (127ms)

    ✓ can handle cj (120ms)

    ✓ can handle ck (237ms)

    ✓ can handle c2j (171ms)

    ✓ can handle c2k (103ms)

    ✓ can handle cj on last line (229ms)

    ✓ can handle ck on first line (72ms)

    ✓ can handle c2j on last line (189ms)

    ✓ can handle c2k on first line (187ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (82ms)

    ✓ Can handle 'daw' on word with trailing spaces (91ms)

    ✓ Can handle 'daw' on word with leading spaces (100ms)

    ✓ Can handle 'daw' on word with numeric prefix (138ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (127ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (111ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (187ms)

    ✓ Can handle 'daw' on end of word (202ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (104ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (159ms)

    ✓ Can handle 'daw' on word at beginning of file (70ms)

    ✓ Can handle 'daw' on word at beginning of line (74ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (70ms)

    ✓ Can handle 'daw' around word at end of line (229ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (68ms)

    ✓ Can handle 'daW' around word at whitespace (72ms)

    ✓ Can handle 'daW' on word with trailing spaces (228ms)

    ✓ Can handle 'daW' on word with leading spaces (147ms)

    ✓ Can handle 'daW' on word with numeric prefix (143ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (130ms)

    ✓ Can handle 'daW' on beginning of word (198ms)

    ✓ Can handle 'daW' on end of one line (138ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (134ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (122ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (214ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (147ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (200ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (139ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (213ms)

    ✓ Can handle 'diw' on word (147ms)

    ✓ Can handle 'diw' on word with numeric prefix (206ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (174ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (212ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (297ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (77ms)

    ✓ Can handle 'diW' on word with trailing spaces (221ms)

    ✓ Can handle 'diW' on word with leading spaces (148ms)

    ✓ Can handle 'diW' on word with numeric prefix (122ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (219ms)

    ✓ Can handle 'diW' on beginning of word (109ms)

    ✓ Can handle d} (203ms)

    ✓ Can handle y} at beginning of line (148ms)

    ✓ Select sentence with trailing spaces (218ms)

    ✓ Select sentence with leading spaces (231ms)

    ✓ Select inner sentence with trailing spaces (81ms)

    ✓ Select inner sentence with leading spaces (318ms)

    ✓ Select spaces between sentences (251ms)

    ✓ Can handle 'df' (155ms)

    ✓ Can handle 'dt' (234ms)

    ✓ Can handle backspace (152ms)

    ✓ Can handle backspace across lines (80ms)

    ✓ Can handle A and backspace (233ms)

    ✓ Can handle 'yy' without changing cursor position (100ms)

    ✓ Can handle 'P' after 'yy' (174ms)

    ✓ Can handle 'p' after 'yy' (164ms)

    ✓ Can handle 'P' after 'Nyy' (189ms)

    ✓ Can handle 'p' after 'Nyy' (93ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (136ms)

    ✓ Can handle 'gp' after 'yy' (208ms)

    ✓ Can handle 'gp' after 'Nyy' (138ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (242ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (74ms)

    ✓ Can handle 'gP' after 'yy' (204ms)

    ✓ Can handle 'gP' after 'Nyy' (160ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (1053ms)

    ✓ Can handle ']p' after yy (53ms)

    ✓ Can handle ']p' after 'Nyy' (122ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (250ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (165ms)

    ✓ Can handle '[p' after yy (224ms)

    ✓ Can handle '[p' after 'Nyy' (155ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (212ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (180ms)

    ✓ Can handle 'p' after y'a (207ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (80ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (155ms)

    ✓ Can handle pasting in visual mode over selection (292ms)

    ✓ Can repeat w (118ms)

    ✓ Can repeat p (219ms)

    ✓ I works correctly (172ms)

    ✓ gI works correctly (255ms)

    ✓ gi works correctly (259ms)

    ✓ `. works correctly (235ms)

    ✓ '. works correctly (127ms)

    ✓ g; works correctly (310ms)

    ✓ g, works correctly (210ms)

    ✓ g_ works correctly (180ms)

    ✓ 3g_ works correctly (179ms)

    ✓ gq handles spaces after single line comments correctly (339ms)

    ✓ gq handles spaces before single line comments correctly (538ms)

    ✓ gq handles tabs before single line comments correctly (387ms)

    ✓ Can handle space (116ms)

    ✓ Can handle space (143ms)

    ✓ Undo 1 (324ms)

    ✓ Undo 2 (272ms)

    ✓ Undo cursor (156ms)

    ✓ Undo cursor 2 (315ms)

    ✓ Undo cursor 3 (299ms)

    ✓ Undo with movement first (126ms)

    ✓ Can handle 'U' (232ms)

    ✓ Can handle 'U' for multiple changes (191ms)

    ✓ Can handle 'U' for new line below (248ms)

    ✓ Can handle 'U' for new line above (215ms)

    ✓ Can handle 'U' for consecutive changes only (167ms)

    ✓ Can handle 'u' to undo 'U' (204ms)

    ✓ Can handle 'U' to undo 'U' (115ms)

    ✓ Redo (289ms)

    ✓ Redo (120ms)

    ✓ Redo (295ms)

    ✓ Can handle u (239ms)

    ✓ Can handle guw (87ms)

    ✓ Can handle gUw (174ms)

    ✓ Can handle u over line breaks (149ms)

    ✓ can handle s in visual mode (214ms)

    ✓ can handle p with selection (133ms)

    ✓ can handle P with selection (244ms)

    ✓ can handle p in visual to end of line (243ms)

    ✓ can repeat backspace twice (190ms)

    ✓ can delete linewise with d2G (111ms)

    ✓ can delete with + motion and count (215ms)

    ✓ can delete with - motion and count (65ms)

    ✓ can dE correctly (220ms)

    ✓ can dE correctly (141ms)

    ✓ can dE correctly (218ms)

    ✓ can ctrl-a correctly behind a word (241ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (121ms)

    ✓ can ctrl-a on word (80ms)

    ✓ can ctrl-a on a hex number (228ms)

    ✓ can ctrl-a on decimal (149ms)

    ✓ can ctrl-a with numeric prefix (227ms)

    ✓ can ctrl-a on a decimal (136ms)

    ✓ can ctrl-a on an octal  (211ms)

    ✓ Correctly increments in the middle of a number (132ms)

    ✓ can ctrl-x correctly behind a word (111ms)

    ✓ can ctrl-a on an number with word before  (213ms)

    ✓ can ctrl-a on an number with word before and after  (133ms)

    ✓ can ctrl-x on a negative number with word before and after  (234ms)

    ✓ can ctrl-a properly on multiple lines (106ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (212ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (147ms)

    ✓ can <C-a> on word with - in front of it (196ms)

    ✓ can do Y (159ms)

    ✓ Can do S (69ms)

    ✓ / does not affect mark (223ms)

    ✓ / can search with regex (171ms)

    ✓ / can search with newline (182ms)

    ✓ / can search through multiple newlines (213ms)

    ✓ / matches ^ per line (185ms)

    ✓ / matches $ per line (227ms)

    ✓ Can search for forward slash (187ms)

    ✓ Can search backward for question mark (178ms)

    ✓ /\c forces case insensitive search (145ms)

    ✓ /\C forces case sensitive search (115ms)

    ✓ <BS> deletes the last character in search in progress mode (174ms)

    ✓ <S-BS> deletes the last character in search in progress mode (216ms)

    ✓ <C-h> deletes the last character in search in progress mode (88ms)

    ✓ Can do C (38ms)

    ✓ Can do cit on a matching tag (356ms)

    ✓ Ignores cit on a non-matching tag (205ms)

    ✓ Ignores cit on a nested tag (187ms)

    ✓ Can do cit on a tag with an attribute tag (200ms)

    ✓ Can do cat on a matching tag (144ms)

    ✓ Can do cit on a multiline tag (217ms)

    ✓ Can do cit on a multiline tag with nested tags (107ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (107ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (225ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (134ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (204ms)

    ✓ can do cit with self closing tags (103ms)

    ✓ Respects indentation with cc (217ms)

    ✓ Resets cursor to indent end with cc (134ms)

    ✓ can handle 'cc' on empty line (172ms)

    ✓ cc copies linewise (189ms)

    ✓ Indent current line with correct Vim Mode (144ms)

    ✓ Can handle <Esc> and do nothing (168ms)

    ✓ Can handle # on consecutive words (180ms)

    ✓ Can handle # on skipped words (133ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (166ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (157ms)

    ✓ cc on whitespace-only treats whitespace as indent (211ms)

    ✓ Can do cai (133ms)

    ✓ Can do cii (73ms)

    ✓ Can do caI (216ms)

    ✓ Can do dai (115ms)

    ✓ Can do dii (245ms)

    ✓ Can do daI (266ms)

    ✓ `] go to the end of the previously operated or put text (94ms)

    ✓ '] go to the end of the previously operated or put text (285ms)

    ✓ `[ go to the start of the previously operated or put text (112ms)

    ✓ '[ go to the start of the previously operated or put text (263ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (110ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (165ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (188ms)

    can handle gn

      ✓ gn selects the next match text (263ms)

      ✓ gn selects the current word at |hello (269ms)

      ✓ gn selects the current word at h|ello (242ms)

      ✓ gn selects the current word at hel|lo (319ms)

      ✓ gn selects the current word at hell|o (205ms)

      ✓ gn selects the next word at hello| (242ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (200ms)

      ✓ dgn deletes the current word when cursor is at |hello (179ms)

      ✓ dgn deletes the current word when cursor is at h|ello (353ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (79ms)

      ✓ dgn deletes the current word when cursor is at hell|o (252ms)

      ✓ dgn deletes the next word when cursor is at hello| (112ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (260ms)

      ✓ cgn deletes the current word when cursor is at |hello (101ms)

      ✓ cgn deletes the current word when cursor is at h|ello (255ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (167ms)

      ✓ cgn deletes the current word when cursor is at hell|o (241ms)

      ✓ cgn deletes the next word when cursor is at hello| (126ms)

    can handle gN

      ✓ gN selects the previous match text (222ms)

      ✓ gN selects the current word at hell|o (366ms)

      ✓ gN selects the current word at hel|lo (463ms)

      ✓ gN selects the current word at h|ello (228ms)

      ✓ gN selects the current word at |hello (269ms)

      ✓ gN selects the previous word at | hello (424ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (66ms)

      ✓ dgN deletes the current word when cursor is at hell|o (251ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (198ms)

      ✓ dgN deletes the current word when cursor is at h|ello (124ms)

      ✓ dgN deletes the current word when cursor is at |hello (248ms)

      ✓ dgN deletes the previous word when cursor is at | hello (187ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (200ms)

      ✓ cgN deletes the current word when cursor is at hell|o (221ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (196ms)

      ✓ cgN deletes the current word when cursor is at h|ello (375ms)

      ✓ cgN deletes the current word when cursor is at |hello (127ms)

      ✓ cgN deletes the previous word when cursor is at | hello (102ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (211ms)

    ✓ Can activate with R from Normal mode (48ms)

    ✓ Can handle R (226ms)

    ✓ Can handle R past current line (126ms)

    ✓ Can handle R and exit Replace Mode (222ms)

    ✓ Can handle R across lines (170ms)

    ✓ Can handle R across lines and exit Replace Mode (183ms)

    ✓ Can handle R with {count} (204ms)

    ✓ Can handle backspace (220ms)

    ✓ Can handle backspace (235ms)

    ✓ Can handle backspace across lines (186ms)

    ✓ Can handle arrows (101ms)

    ✓ Can handle . (275ms)

    ✓ Can handle . across lines (200ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (144ms)

    ✓ Can handle wd (115ms)

    ✓ Can handle x (118ms)

    ✓ Can handle x across a selection (311ms)

    ✓ Can do vwd in middle of sentence (146ms)

    ✓ Can do vwd in middle of sentence (118ms)

    ✓ Can do vwd multiple times (166ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (192ms)

    ✓ Can handle H key (169ms)

    ✓ Can handle backspace key (208ms)

    ✓ handles case where we delete over a newline (152ms)

    ✓ handles change operator (154ms)

    ✓ Can do vat on multiple matching tags (127ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (215ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (327ms)

    ✓ Repeat-prefixed vat does not bleed below (236ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (54ms)

    ✓ Can do vi) on a matching parenthesis (232ms)

    ✓ Can do vi) on multiple matching parens (165ms)

    ✓ Can do va) on a matching parenthesis (217ms)

    ✓ Can do va) on multiple matching parens (78ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (180ms)

    ✓ Repeat-prefixed va) does not bleed below (131ms)

    ✓ Can do va} on a matching bracket as first character (65ms)

    ✓ Can do va} on multiple matching brackets (81ms)

    ✓ Can do vi( on a matching bracket near first character (210ms)

    ✓ Can do vi{ on outer pair of nested braces (67ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (165ms)

    ✓ Can do va] on multiple matching brackets (95ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (256ms)

    ✓ Repeat-prefixed vaf does not bleed below (139ms)

    ✓ vaf only expands to enclosing pairs (63ms)

    ✓ Can use . to repeat indent in visual (64ms)

    ✓ Can do v_x to delete to first char (68ms)

    ✓ Can do vg_x to delete to last char with no EOL (182ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (155ms)

    ✓ Can do v$x to delete to last char including EOL (145ms)

    ✓ Can do gv to reselect previous selection (205ms)

    Vim's EOL handling is weird

      ✓ delete through eol (117ms)

      ✓ join 2 lines by deleting through eol (151ms)

      ✓ d$ doesn't delete whole line (137ms)

      ✓ vd$ does delete whole line (96ms)

      ✓ Paste over selection copies the selection (265ms)

      ✓ Paste over selection copies the selection linewise (108ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (111ms)

      ✓ Can handle <down> key (162ms)

      ✓ Can handle <left> key (151ms)

      ✓ Can handle <right> key (68ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (147ms)

      ✓ Can handle 'gj' (132ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (99ms)

      ✓ Can handle 'vawd' on word with trailing spaces (105ms)

      ✓ Can handle 'vawd' on word with leading spaces (112ms)

      ✓ Can handle 'vawd' on word with numeric prefix (220ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (135ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (202ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (546ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (151ms)

      ✓ Can handle 'vaWd' on word with leading spaces (181ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (181ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (169ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (224ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (160ms)

      ✓ Can handle 'vaWd' on word with leading spaces (106ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (193ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (165ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (224ms)

      ✓ Can handle 'vawd' on word with trailing spaces (103ms)

      ✓ Can handle 'vawd' on word with leading spaces (214ms)

      ✓ Can handle 'vawd' on word with numeric prefix (237ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (113ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (157ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (161ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (111ms)

      ✓ Can handle 'vaWd' on word with leading spaces (120ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (239ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (136ms)

      ✓ Can handle 'Y' in visual mode (110ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (238ms)

      ✓ Select sentence with leading spaces in visual mode (152ms)

      ✓ Select multiple sentences in visual mode (238ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (77ms)

      ✓ Select inner sentence with leading spaces in visual mode (196ms)

      ✓ Select spaces between sentences in visual mode (186ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (140ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (103ms)

      ✓ Can do vat on a matching tag (222ms)

    handles replace in visual mode

      ✓ Can do a single line replace (150ms)

      ✓ Can do a multi line replace (112ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (68ms)

      ✓ D deletes the current line (239ms)

    handles indent blocks in visual mode

      ✓ Can do vai (442ms)

      ✓ Can do vii (74ms)

      ✓ Doesn't naively select the next line (106ms)

      ✓ Searches backwards if cursor line is empty (469ms)

      ✓ Can do vaI (121ms)

    visualstar

      ✓ Works with * (220ms)

      ✓ Works with # (81ms)

    search works in visual mode

      ✓ Works with / (97ms)

      ✓ Works with ? (77ms)

      ✓ Selects correct range (131ms)

    X will delete linewise

      ✓ normal selection (110ms)

      ✓ normal selection (236ms)

    C will delete linewise

      ✓ normal selection (133ms)

      ✓ normal selection (222ms)

    R will delete linewise

      ✓ normal selection (145ms)

      ✓ normal selection (96ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (254ms)

      ✓ upward selection (108ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (59ms)

      ✓ multiline indent bottom up selection (138ms)

      ✓ repeat multiline indent top down selection (345ms)

      ✓ repeat multiline indent bottom up selection (237ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (129ms)

      ✓ multiline outdent bottom up selection (225ms)

      ✓ repeat multiline outdent top down selection (109ms)

      ✓ repeat multiline outdent bottom up selection (210ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (133ms)

    vi{ will go to end of second to last line

      ✓ select (110ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode (72ms)

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (460ms)

      ✓ gv selects the last pasted text (which is longer than original) (440ms)

      ✓ gv selects the last pasted text (multiline) (194ms)

    can handle gn

      ✓ gn selects the next match text (230ms)

      ✓ gn selects the current word at |hello (242ms)

      ✓ gn selects the current word at h|ello (201ms)

      ✓ gn selects the current word at hel|lo (239ms)

      ✓ gn selects the next word at hell|o (234ms)

      ✓ gn selects the next word at hello| (293ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (79ms)

      ✓ multiline insert from top down selection (215ms)

      ✓ skips blank lines (63ms)

    can append text with A

      ✓ multiline append from bottom up selection (209ms)

      ✓ multiline append from top down selection (142ms)

      ✓ skips blank lines (397ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (190ms)

      ✓ U/gU across a selection (163ms)

      ✓ U/gU across a selection (reverse) (247ms)

      ✓ u/gu on single character (149ms)

      ✓ u/gu across a selection (439ms)

      ✓ u/gu across a selection (reverse) (175ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (120ms)

    ✓ Can handle A backwards select (239ms)

    ✓ Can handle I forward select (175ms)

    ✓ Can handle I backwards select (247ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (146ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (162ms)

    ✓ Can handle c forward select (242ms)

    ✓ Can handle c backwards select (88ms)

    ✓ Can handle C (215ms)

    ✓ Can do a multi line replace (152ms)

    ✓ Can handle 'D' (235ms)

    ✓ Can handle 'gj' (172ms)

    ✓ Properly add to end of lines j then $ (206ms)

    ✓ Properly add to end of lines $ then j (205ms)

    ✓ o works in visual block mode (106ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (163ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (142ms)

    ✓ Can handle wd (118ms)

    ✓ Can handle x (128ms)

    ✓ Can handle x across a selection (117ms)

    ✓ Can do vwd in middle of sentence (164ms)

    ✓ Can do vwd in middle of sentence (145ms)

    ✓ Can do vwd multiple times (279ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (160ms)

    ✓ handles case where we delete over a newline (169ms)

    ✓ handles change operator (117ms)

    ✓ Vp updates register content (140ms)

    ✓ Vp does not append unnecessary newlines (first line) (184ms)

    ✓ Vp does not append unnecessary newlines (middle line) (146ms)

    ✓ Vp does not append unnecessary newlines (last line) (143ms)

    Vim's EOL handling is weird

      ✓ delete through eol (100ms)

      ✓ join 2 lines by deleting through eol (92ms)

      ✓ d$ doesn't delete whole line (70ms)

      ✓ vd$ does delete whole line (126ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (172ms)

      ✓ Can handle <down> key (210ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (74ms)

      ✓ Can handle 'gj' (189ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (115ms)

      ✓ Can handle d key (53ms)

      ✓ Can handle d key (59ms)

      ✓ Can handle d key (63ms)

      ✓ can handle 'c' (61ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (209ms)

      ✓ Can do a multi visual line replace (103ms)

      ✓ Can do a multi visual line replace from the bottom up (196ms)

    search works in visual line mode

      ✓ Works with / (154ms)

      ✓ Works with ? (64ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (313ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (145ms)

      ✓ linewise visual put works also in the end of document (225ms)

      ✓ gv selects the last pasted text (which is shorter than original) (384ms)

      ✓ gv selects the last pasted text (which is longer than original) (361ms)

      ✓ gv selects the last pasted text (multiline) (431ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (133ms)

      ✓ multiline insert from top down selection (204ms)

      ✓ skips blank lines (147ms)

    can append text with A

      ✓ multiline append from bottom up selection (208ms)

      ✓ multiline append from top down selection (95ms)

      ✓ skips blank lines (212ms)

  Mode Normal

    ✓ Can handle 'x' (105ms)

    ✓ Can handle 'Nx' (64ms)

    ✓ Can handle 'Nx' and paste (396ms)

    ✓ Can handle 'x' at end of line (109ms)

    ✓ Can handle 'Ns' (80ms)

    ✓ Can handle 'Ns' at end of line (119ms)

    ✓ Can handle '<Del>' (140ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (108ms)

    ✓ Can handle '<Del>' at end of line (260ms)

    ✓ Can handle 'cc' (114ms)

    ✓ Can handle 'Ncc' (123ms)

    ✓ Can handle 'yy' (117ms)

    ✓ Can handle 'D' (192ms)

    ✓ Can handle 'D' on empty lines (120ms)

    ✓ Can handle 'DD' (232ms)

    ✓ Can handle 'C' (143ms)

    ✓ Can handle 'NC' (217ms)

    ✓ Can handle 'NC' and put (91ms)

    ✓ Can handle 'r' (55ms)

    ✓ Can handle '<Count>r' (161ms)

    ✓ Can handle '<Count>r' (147ms)

    ✓ Can handle 'r' after 'dd' (133ms)

    ✓ Can handle 'r
' (64ms)

    ✓ Can handle '<Count>r
' (208ms)

    ✓ Can handle 'J' once (62ms)

    ✓ Can handle 'J' twice (80ms)

    ✓ Can handle 'J' with empty last line (74ms)

    ✓ Can handle 'J's with multiple empty last lines (128ms)

    ✓ Can handle 'J' with leading white space on next line (193ms)

    ✓ Can handle 'J' with only white space on next line (95ms)

    ✓ Can handle 'J' with TWO indented lines (106ms)

    ✓ Can handle 'J' with ')' first character on next line (200ms)

    ✓ Can handle 'J' with a following delete (74ms)

    ✓ Can handle 'J' in Visual Line mode (211ms)

    ✓ Can handle 'gJ' once (159ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (178ms)

    ✓ Can handle '~' (65ms)

    ✓ Can handle 'g~{motion}' (136ms)

    ✓ Can handle '<BS>' in insert mode (216ms)

    ✓ Can handle undo with P (130ms)

    ✓ Can handle 'ge' in multiple lines case1 (79ms)

    ✓ Can handle 'ge' in multiple lines case2 (104ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (200ms)

    ✓ Can repeat '~' with dot (142ms)

    ✓ Can repeat 'x' (110ms)

    ✓ Can repeat 'J' (85ms)

    ✓ Can handle dot with A (266ms)

    ✓ Can handle dot with I (159ms)

    ✓ Can repeat actions that require selections (182ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (120ms)

    ✓ Can repeat insert change and '<C-t>' (241ms)

    ✓ Can repeat change by `<C-a>` (155ms)

    ✓ Only one arrow key can be repeated in Insert Mode (220ms)

    ✓ Cached content change will be cleared by arrow keys (155ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (51ms)

    ✓ inside parenthesis (184ms)

    ✓ nested parenthesis beginning (153ms)

    ✓ nested parenthesis end (184ms)

    ✓ nested bracket and parenthesis beginning (161ms)

    ✓ nested bracket, parenthesis, braces beginning (177ms)

    ✓ nested bracket, parenthesis, braces end (378ms)

    ✓ parentheses after > (74ms)

    ✓ parentheses after "

  Motions in Normal Mode

    ✓ Can handle [( (49ms)

    ✓ Can handle nested [( (46ms)

    ✓ Can handle <number>[( (54ms)

    ✓ Can handle [( and character under cursor exclusive (206ms)

    ✓ Can handle ]) (147ms)

    ✓ Can handle nested ]) (203ms)

    ✓ Can handle <number>]) (112ms)

    ✓ Can handle ]) and character under cursor exclusive (188ms)

    ✓ Can handle [{ (79ms)

    ✓ Can handle nested [{ (194ms)

    ✓ Can handle <number>[{ (606ms)

    ✓ Can handle [{ and character under cursor exclusive (114ms)

    ✓ Can handle ]} (90ms)

    ✓ Can handle nested ]} (99ms)

    ✓ Can handle <number>]} (162ms)

    ✓ Can handle ]} and character under cursor exclusive (108ms)

    ✓ Can handle 'ge' (210ms)

    ✓ Can handle 'gg' (174ms)

    ✓ Can handle 'gg' to first non blank char on random line (60ms)

    ✓ Can handle 'gg' to first non blank char on first line (110ms)

    ✓ 'gg' obeys startofline (164ms)

    ✓ Retain same column when moving up/down (209ms)

    ✓ Can handle <enter> (60ms)

    ✓ $ always keeps cursor on EOL (98ms)

    ✓ Can handle $ with a count (203ms)

    ✓ Can handle $ with a count at end of file (171ms)

    ✓ Can handle <End> with a count (92ms)

    ✓ Can handle <D-right> with a count (78ms)

    ✓ Can handle 'f' (60ms)

    ✓ Can handle 'f' twice (218ms)

    ✓ Can handle 'f' with <tab> (160ms)

    ✓ Can handle 'f' and find back search (192ms)

    ✓ Can handle 'F' (63ms)

    ✓ Can handle 'F' twice (209ms)

    ✓ Can handle 'F' and find back search (169ms)

    ✓ Can handle 'f' and multiple back searches (113ms)

    ✓ Can handle 't' (109ms)

    ✓ Can handle 't' twice (132ms)

    ✓ Can handle 't' and find back search (204ms)

    ✓ Can handle 'T' (329ms)

    ✓ Can handle 'T' twice (68ms)

    ✓ Can handle 'T' and find back search (154ms)

    ✓ Can run a forward search (195ms)

    ✓ Can run a forward and find next search (180ms)

    ✓ Can run a forward and find previous search from end of word (214ms)

    ✓ Can run a reverse search (111ms)

    ✓ Can run a reverse and find next search (95ms)

    ✓ cancelled search reverts to previous search state (143ms)

    ✓ Backspace on empty search cancels (228ms)

    ✓ Search offsets: b does nothing (70ms)

    ✓ Search offsets: b2 goes 2 to the right (239ms)

    ✓ Search offsets: b+3 goes 3 to the right (143ms)

    ✓ Search offsets: e goes to the end (82ms)

    ✓ Search offsets: character offset goes across line boundaries (101ms)

    ✓ Search offsets: 2 goes 2 down (163ms)

    ✓ Search offsets: -2 goes 2 up (88ms)

    ✓ maintains column position correctly (294ms)

    ✓ maintains column position correctly with $ (158ms)

    ✓ Can handle G  (94ms)

    ✓ Can handle G with number prefix (180ms)

    ✓ Can handle G with number prefix (95ms)

    ✓ Can handle gg (48ms)

    ✓ Can handle gg with number prefix (58ms)

    ✓ Can handle 0 (64ms)

    ✓ Can handle 0 as part of a repeat (399ms)

    ✓ Can handle g* (115ms)

    ✓ Can handle g*n (101ms)

    ✓ Can handle * (184ms)

    ✓ Can handle ** (146ms)

    ✓ Can handle # on whitespace (58ms)

    ✓ Can handle # on EOL (104ms)

    ✓ Can handle g# (113ms)

    ✓ Can handle g#n (118ms)

    ✓ Can handle # (334ms)

    ✓ Can handle # already on the word (44ms)

    ✓ Can handle ## (90ms)

    ✓ * adds to search history (92ms)

    ✓ # adds to search history (147ms)

    ✓ Can handle | (67ms)

    ✓ Can handle <number> | (96ms)

    ✓ Can handle + (133ms)

    ✓ Can handle + indent (49ms)

    ✓ Can handle + with count prefix (131ms)

    ✓ Can handle - (41ms)

    ✓ Can handle - indent (54ms)

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix (42ms)

    ✓ Can handle g_ (45ms)

    ✓ Can handle g_ with count prefix (58ms)

    ✓ Can handle <up> key (40ms)

    ✓ Can handle <down> key (248ms)

    ✓ Can handle <left> key (49ms)

    ✓ Can handle <right> key (40ms)

    ✓ Can handle 'gk' (49ms)

    ✓ Can handle 'gj' (43ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right
      ✓ move to end of current word right
      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (38ms)

        ✓ l wraps to next line (41ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (50ms)

      insert mode

        ✓ <left> wraps to previous line (52ms)

        ✓ <right> once goes to end of line (50ms)

        ✓ <right> twice wraps to next line (143ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (178ms)

        ✓ l does not wrap to next line (170ms)

        ✓ <left> does not wrap to previous line (175ms)

        ✓ <right> does not wrap to next line (137ms)

      insert mode

        ✓ <left> does not wrap to previous line (314ms)

        ✓ <right> does not wrap to next line (51ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (223ms)

      ✓ search wraps around the start of the file (262ms)

    wrapscan disabled

      ✓ search stops at the end of the file (183ms)

      ✓ search stops at the start of the file (151ms)

  Multicursor

    ✓ can add multiple cursors below (102ms)

    ✓ can add multiple cursors above (229ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip

  comment operator

    ✓ gcc comments out current line (457ms)

    ✓ gcj comments in current and next line (196ms)

    ✓ block comment with motion (362ms)

    ✓ block comment in Visual Mode (263ms)

    ✓ comment in visual line mode (176ms)

    ✓ comment in visual block mode (251ms)

  format operator

    ✓ == formats current line (302ms)

    ✓ =$ formats entire line (513ms)

    ✓ =j formats two lines (222ms)

    ✓ 3=k formats three lines (194ms)

    ✓ =gg formats to top of file (108ms)

    ✓ =G formats to bottom of file (192ms)

    ✓ =ip formats paragraph (86ms)

    ✓ format in visual mode (217ms)

  put operator

    ✓ basic put test (75ms)

    ✓ test yy end of line (154ms)

    ✓ test yy first line (223ms)

    ✓ test yy middle line (64ms)

    ✓ test yy with correct positon movement (67ms)

    ✓ test visual block single line yank p (630ms)

    ✓ test visual block single line yank P (227ms)

    ✓ test visual block single line delete p (130ms)

    ✓ test visual block single line delete P (231ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (60ms)

    ✓ shift left goto end test (217ms)

    ✓ shift left goto line test (242ms)

    ✓ shift right goto end test (47ms)

    ✓ shift right goto line test (114ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (194ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (163ms)

      ✓ step to Camel word (118ms)

      ✓ step to CAP word (184ms)

      ✓ step after CAP word (171ms)

      ✓ step from middle of word to Camel word (138ms)

      ✓ step to number word (118ms)

      ✓ step to operator word (192ms)

      ✓ step from inside operator word (164ms)

      ✓ step to operator and then over (133ms)

    handles <leader>w for underscore_var

      ✓ step to _word (178ms)

      ✓ step over whitespace to word (65ms)

      ✓ step from inside word to _word (125ms)

      ✓ step form _word to number (181ms)

      ✓ step from nubmer word to _word (127ms)

      ✓ step from in whitespace to word (202ms)

      ✓ step in ALL_CAPS_WORD (59ms)

    handles d<leader>w

      ✓ delete from start of camelWord (202ms)

      ✓ delete from middle of camelWord (144ms)

      ✓ delete from start of CamelWord (59ms)

      ✓ delete two words from camelWord (106ms)

      ✓ delete from start of underscore_word (188ms)

      ✓ delete from middle of underscore_word (113ms)

      ✓ delete two words from camel_word (85ms)

    handles di<leader>w

      ✓ delete from start of camelWord (58ms)

      ✓ delete from middle of camelWord (231ms)

      ✓ delete from start of CamelWord (150ms)

      ✓ delete two words from camelWord (156ms)

      ✓ delete from start of underscore_word (83ms)

      ✓ delete from middle of underscore_word (215ms)

      ✓ delete two words from camel_word (134ms)

    handles <leader>b

      ✓ back from middle of word (187ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (74ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (262ms)

      ✓ from middle to end of underscore_word (48ms)

      ✓ twice to end of word over operator (58ms)

  easymotion plugin

    ✓ Can handle s move (61ms)

    ✓ Can handle 2s move (186ms)

    ✓ Can handle f move (63ms)

    ✓ Can handle 2f move (119ms)

    ✓ Can handle F move (184ms)

    ✓ Can handle 2F move (144ms)

    ✓ Can handle t move (196ms)

    ✓ Can handle bd-t move (111ms)

    ✓ Can handle 2t move (83ms)

    ✓ Can handle bd-t2 move (223ms)

    ✓ Can handle T move (102ms)

    ✓ Can handle 2T move (172ms)

    ✓ Can handle w move (179ms)

    ✓ Can handle bd-w move (228ms)

    ✓ Can handle b move (85ms)

    ✓ Can handle e move (333ms)

    ✓ Can handle bd-e move (244ms)

    ✓ Can handle ge move (148ms)

    ✓ Can handle n-char move (241ms)

    ✓ Can handle j move (169ms)

    ✓ Can handle k move (80ms)

    ✓ Can handle bd-jk move (1) (187ms)

    ✓ Can handle bd-jk move (2) (93ms)

    ✓ Can handle lineforward move (1) (252ms)

    ✓ Can handle lineforward move (2) (204ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (90ms)

    ✓ Can handle searching for backslash (\) (208ms)

    ✓ Can handle searching for carat (^) (161ms)

    ✓ Can handle searching for dot (.) (60ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (320ms)

    ✓ Replaces within inner Word (124ms)

    ✓ Replaces within '' (177ms)

    ✓ Replaces within '' including spaces (144ms)

    ✓ Replaces within () (75ms)

    ✓ Replaces within () including spaces (175ms)

    ✓ Replaces within a paragraph (105ms)

    ✓ Replaces using a specified register (306ms)

    ✓ Replaces within {} over multiple lines (83ms)

    ✓ Replaces a multiline register within {} over multiple lines (208ms)

    ✓ Replaces a multiline register within {} over multiple lines (151ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (192ms)

    ✓ grr replaces the entire line with the register (102ms)

    ✓ grr can replace multiple lines (154ms)

    ✓ Replaces in visual mode (234ms)

    ✓ Replaces in visual mode using a specified register (100ms)

    ✓ Replaces in visual line mode (184ms)

    ✓ grj is linewise (325ms)

  sneak plugin

    ✓ Can handle s motion (95ms)

    ✓ Can handle S motion (106ms)

    ✓ Can handle <operator>z motion (151ms)

    ✓ Can handle <operator>Z motion (193ms)

    ✓ Can handle s; motion (111ms)

    ✓ Can handle s, motion (190ms)

    ✓ Can handle S; motion (151ms)

    ✓ Can handle S, motion (200ms)

    ✓ Can handle single letter s motion (85ms)

    ✓ Can handle single letter S motion (87ms)

    ✓ Can handle single letter <operator>z motion (126ms)

    ✓ Can handle single letter <operator>Z motion (116ms)

    ✓ Can handle single letter s; motion (91ms)

    ✓ Can handle single letter s, motion (71ms)

    ✓ Can handle single letter S; motion (207ms)

    ✓ Can handle single letter S, motion (145ms)

    ✓ Can handle multiline single char <number>s motion (195ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (146ms)

    ✓ 'ysiw(' surrounds word with space (181ms)

    ✓ 'ysw)' surrounds word without space (144ms)

    ✓ 'ysw(' surrounds word with space (119ms)

    ✓ 'ysaw)' surrounds word without space (166ms)

    ✓ 'ysaw(' surrounds word with space (146ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (359ms)

    ✓ 'ysiw<' surrounds word with tags (127ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (173ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (155ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (121ms)

    ✓ change surround (134ms)

    ✓ change surround with two pairs of quotes (568ms)

    ✓ change surround with two pairs of parens (93ms)

    ✓ change surround with alias (146ms)

    ✓ change surround to tags (152ms)

    ✓ delete surround (131ms)

    ✓ delete surround with quotes (400ms)

    ✓ delete surround with nested of quotes (119ms)

    ✓ delete surround with inconsistent quotes (177ms)

    ✓ delete surround with mixed quotes (103ms)

    ✓ delete surround with empty quotes cursor at start (117ms)

    ✓ delete surround with empty quotes cursor at end (131ms)

    ✓ don't delete surround if cursor is after closing match (154ms)

    ✓ delete surround if cursor is before opening match (108ms)

    ✓ delete surround with two pairs of parens (171ms)

    ✓ delete surround with alias (126ms)

    ✓ delete surround with tags (160ms)

    ✓ change surround brackets at end of line (122ms)

    ✓ changing brackets with surround works again (178ms)

    ✓ change surround with tags that contain an attribute and preserve them (189ms)

    ✓ change surround with tags that contain an attribute and remove them (161ms)

  register

    ✓ Can copy to a register (131ms)

    ✓ Can use two registers together (155ms)

    ✓ Can use black hole register (181ms)

    ✓ System clipboard works with chinese characters (178ms)

    ✓ Yank stores text in Register '0' (246ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (181ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (174ms)

    ✓ Register '1'-'9' stores delete content (303ms)

    ✓ "A appends linewise text to "a (199ms)

    ✓ "A appends character wise text to "a (246ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (179ms)

    ✓ Small deletion using Del is stored in small delete register (199ms)

    ✓ Small deletion using X is stored in small delete register (183ms)

    ✓ Search register (/) is set by forward search (344ms)

    ✓ Search register (/) is set by backward search (273ms)

    ✓ Search register (/) is set by star search (247ms)

    ✓ Command register (:) is set by command line (77ms)

    ✓ Read-only registers cannot be written to (226ms)

    clipboard

      ✓ Can access '*' (clipboard) register (74ms)

      ✓ Can access '+' (clipboard) register (209ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (125ms)

    ✓ Can repeat reversed F<character> (203ms)

    ✓ Can repeat t<character> (193ms)

    ✓ Can repeat N times reversed t<character> (209ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (360ms)

      ✓ move one sentence backward (148ms)

      ✓ move [count] sentences backward (204ms)

      ✓ move one sentence backward single line - middle (756ms)

      ✓ move one sentence backward no space (183ms)

      ✓ move one sentence backward no space - middle (113ms)

      ✓ move one sentence backward - multiline (121ms)

      ✓ move one sentence backward - multiline - period (173ms)

      ✓ move one sentence backward - multiline - previous line (118ms)

      ✓ move one sentence backward - multiline - previous line - period (171ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath
      ✓ can separate drive letter path on Windows
      ✓ can separate UNC path on Windows
      ✓ can separate relative path on Windows
      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix
    resolveUri
      ✓ posix

      ✓ win32

  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=2625242322212019181716151413121110987654321.
      + expected - actual

      -2625242322212019181716151413121110987654321
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Missing '|' in test object.
      + expected - actual

      -false
      +true
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Missing '|' in test object.
      + expected - actual

      -false
      +true
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-11T07:18:06.331Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses
    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (135ms)

    ✓ command <C-w> can remove word in search mode (73ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor (83ms)

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (45ms)

    ✓ <C-u> deletes from cursor to first character (40ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line (40ms)

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (44ms)

    ✓ <C-p>/<C-n> go to the previous/next command (84ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (107ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (40ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line (41ms)

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history (40ms)

    ✓ file system

    ✓ change configuration.history (68ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent
    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (558ms)

    ✓ :smile editor contains smile text (540ms)

  Basic sort

    ✓ Sort whole file, asc (126ms)

    ✓ Sort whole file, asc, ignoreCase (226ms)

    ✓ Sort whole file, dsc (119ms)

    ✓ Sort whole file, dsc, ignoreCase (117ms)

    ✓ Sort range, asc (288ms)

    ✓ Sort range, asc, ignoreCase (152ms)

    ✓ Sort range, dsc (190ms)

    ✓ Sort range, dsc, ignoreCase (127ms)

    ✓ Sort whole file, asc, unique (171ms)

  Horizontal split

    ✓ Run :sp (78ms)

    ✓ Run :split (72ms)

    ✓ Run :new (91ms)

  :close args parser
    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input
  :quit args parser
    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (57ms)

    ✓ Replace with `g` flag (66ms)

    ✓ Replace with flags AND count (111ms)

    ✓ Replace with `c` flag (69ms)

    ✓ Replace with `gc` flag (120ms)

    ✓ Replace across all lines (109ms)

    ✓ Replace on specific single line (150ms)

    ✓ Replace on current line using dot (90ms)

    ✓ Replace single relative line using dot and plus (128ms)

    ✓ Replace across specific line range (168ms)

    ✓ Replace across relative line range using dot, plus, and minus (149ms)

    ✓ Replace across relative line range using numLines+colon shorthand (111ms)

    ✓ Repeat replacement across relative line range (147ms)

    ✓ Replace with range AND count but no flags (120ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (102ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (131ms)

    ✓ Undocumented: trailing operators use 1 as RHS (104ms)

    ✓ Replace specific single equal lines (81ms)

    ✓ Replace current line with no active selection (81ms)

    ✓ Replace text in selection (144ms)

    ✓ Substitute support marks (131ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (47ms)

      ✓ Replace with `g` flag inverts global flag (62ms)

      ✓ Replace with `c` flag inverts global flag (75ms)

      ✓ Replace multiple lines (110ms)

      ✓ Replace across specific lines (101ms)

      ✓ Replace current line with no active selection (99ms)

      ✓ Replace text in selection (128ms)

      ✓ Substitute support marks (197ms)

      ✓ Substitute with escaped delimiter (75ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (322ms)

      ✓ Substitute with previous search using # (333ms)

      ✓ Substitute with previous search using / (298ms)

      ✓ Substitute with parameters should update search state (177ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (387ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (308ms)

      ✓ Substitute repeat previous should accept flags (142ms)

      ✓ Substitute with empty search string should use last searched pattern (392ms)

      ✓ Ampersand (&) should repeat the last substitution (221ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file (47ms)

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (81ms)

    ✓ tabe with current file path does nothing (69ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (45ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (75ms)

    ✓ command line file tab completion with space in file path (133ms)

  Vertical split

    ✓ Run :vs (79ms)

    ✓ Run :vsp (77ms)

    ✓ Run :vsplit (78ms)

    ✓ Run :vnew (290ms)

    ✓ Run :vne (299ms)

  Basic write-quit

    ✓ Run write and quit (97ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (51ms)

      ✓ Can complete lines in file with different indentation (72ms)

      ✓ Returns no completions for unmatched line (62ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (113ms)

  Notation

    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (112ms)

    ✓ getMatchingRemap (99ms)

    ✓ jj -> <Esc> through modehandler (113ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (101ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (132ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (120ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (124ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (178ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (166ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (187ms)

  Neovim Validator

    ✓ neovim enabled without path
    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings
    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (98ms)

        ✓ Can track jumps for keys: GggG (203ms)

        ✓ Can track jumps for keys: GggGgg (129ms)

[main 2019-12-11T07:18:36.335Z] update#setState checking for updates

[main 2019-12-11T07:18:36.392Z] update#setState idle

        ✓ Can track jumps for keys: /b<CR>n (152ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (182ms)

        ✓ Can track jumps for keys: j%% (212ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (132ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (193ms)

        ✓ Can track jumps for keys: j%%<C-o>% (164ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (63ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (235ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (204ms)

        ✓ Can enter number to jump back multiple times (82ms)

        ✓ Can track one-line `` jumps (187ms)

        ✓ Can track one-line double `` jumps (188ms)

        ✓ Can track one-line '' jumps (222ms)

        ✓ Can track one-line double '' jumps (176ms)

        ✓ Can handle '' jumps with no previous jump (182ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (193ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (152ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (244ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (179ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (217ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (270ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (244ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (272ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (226ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (150ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (216ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (170ms)

  Record and execute a macro

    ✓ Can record and execute (297ms)

    ✓ Can repeat last invoked macro (229ms)

    ✓ Can play back with count (517ms)

    ✓ Can play back with count, abort when a motion fails (432ms)

    ✓ Repeat change on contiguous lines (177ms)

    ✓ Append command to a macro (236ms)

    ✓ Can record Ctrl Keys and repeat (317ms)

    ✓ Can execute macros with dot commands properly (169ms)

    ✓ : (command) register can be used as a macro (239ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (130ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (63ms)

    ✓ <C-c> can exit insert (73ms)

    ✓ <Esc> can exit insert (73ms)

    ✓ Stay in insert when entering characters (101ms)

    ✓ Can handle 'O' (67ms)

    ✓ Can handle 'i' (103ms)

    ✓ Can handle 'I' (81ms)

    ✓ Can handle 'a' (100ms)

    ✓ Can handle 'A' (88ms)

    ✓ Can handle '<C-w>' (92ms)

    ✓ Can handle <C-w> on leading whitespace (98ms)

    ✓ Can handle <C-w> at beginning of line (72ms)

    ✓ Can handle <C-u> (199ms)

    ✓ Can handle <C-u> on leading characters (136ms)

    ✓ Can handle <C-u> on leading whitespace (125ms)

    ✓ Correctly places the cursor after deleting the previous line break (98ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (57ms)

    ✓ Backspace works on whitespace only lines (99ms)

    ✓ Backspace works on end of whitespace only lines (126ms)

    ✓ Backspace works at beginning of file (78ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (158ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (110ms)

    ✓ Can perform insert command prefixed with count (227ms)

    ✓ Can perform append command prefixed with count (111ms)

    ✓ Can perform insert at start of line command prefixed with count (122ms)

    ✓ Can perform append to end of line command prefixed with count (106ms)

    ✓ Can perform change char (s) command prefixed with count (139ms)

    ✓ Can perform command prefixed with count with <C-[> (98ms)

    ✓ Can handle 'o' with count (282ms)

    ✓ Can handle 'O' with count (186ms)

    ✓ Can handle backspace at beginning of line with all spaces (57ms)

    ✓ Can handle digraph insert (87ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (63ms)

    ✓ Can handle dw (68ms)

    ✓ Can handle dw (177ms)

    ✓ Can handle dw across lines (1) (105ms)

    ✓ Can handle dw across lines (2) (59ms)

    ✓ Can handle dd last line (53ms)

    ✓ Can handle dd single line (40ms)

    ✓ Can handle dd (71ms)

    ✓ Can handle 3dd (63ms)

    ✓ Can handle 3dd off end of document (69ms)

    ✓ Can handle d2d (74ms)

    ✓ Can handle dd empty line (115ms)

    ✓ Can handle ddp (132ms)

    ✓ Can handle 'de' (95ms)

    ✓ Can handle 'de' then 'de' again (101ms)

    ✓ Can handle 'db' (92ms)

    ✓ Can handle 'db then 'db' again (164ms)

    ✓ Can handle 'dl' at end of line (136ms)

    ✓ Can handle 'dF' (67ms)

    ✓ Can handle 'dT' (198ms)

    ✓ Can handle 'd3' then <enter> (104ms)

    ✓ Can handle 'dj' (97ms)

    ✓ Can handle 'dk' (97ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (146ms)

    ✓ Can handle 'd]}' without deleting closing bracket (93ms)

    ✓ Can handle 'cw' (353ms)

    ✓ Can handle 'cw' without deleting following white spaces (80ms)

    ✓ Can handle 'c2w' (41ms)

    ✓ Can handle 'cw' without removing EOL (99ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (96ms)

    ✓ Can handle 'c]}' without deleting closing bracket (94ms)

    ✓ Can handle 's' (116ms)

    ✓ Can handle 'yiw' with correct cursor ending position (99ms)

    ✓ Can handle 'ciw' (234ms)

    ✓ Can handle 'ciw' on blanks (184ms)

    ✓ Can handle 'caw' (150ms)

    ✓ Can handle 'caw' on first letter (128ms)

    ✓ Can handle 'caw' on blanks (180ms)

    ✓ Can handle 'caw' on blanks (90ms)

    ✓ Can handle 'ci(' on first parentheses (180ms)

    ✓ Can handle 'ci(' with nested parentheses (69ms)

    ✓ Can handle 'ci(' backwards through nested parens (186ms)

    ✓ Can handle 'cib' on first parentheses (74ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (138ms)

    ✓ Can handle count prefixed 'ci)' (116ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (77ms)

    ✓ Can handle 'cab' spanning multiple lines (54ms)

    ✓ Can handle 'ci{' spanning multiple lines (138ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (110ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (167ms)

    ✓ Can handle 'ci(' on the closing bracket (78ms)

    ✓ Can handle 'ciB' spanning multiple lines (62ms)

    ✓ will fail when ca( with no () (44ms)

    ✓ will fail when ca{ with no {} (107ms)

    ✓ will fail when caB with no {} (156ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (54ms)

    ✓ Can handle 'ca[' on first bracket (69ms)

    ✓ Can handle 'ca]' on first bracket (133ms)

    ✓ Can handle 'ci'' on first quote (117ms)

    ✓ Can handle 'ci'' inside quoted string (202ms)

    ✓ Can handle 'ci'' on closing quote (170ms)

    ✓ Can handle 'ci'' when string is ahead (197ms)

    ✓ Can handle 'ci"' on opening quote (95ms)

    ✓ Can handle 'ci"' starting behind the quoted word (117ms)

    ✓ Can handle 'ca"' starting behind the quoted word (113ms)

    ✓ Can handle 'ca"' starting on the opening quote (95ms)

    ✓ Can handle 'ci"' with escaped quotes (118ms)

    ✓ Can handle 'ci"' with a single escaped quote (221ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (151ms)

    ✓ Can handle 'ci"' with an escaped backslash (99ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (67ms)

    ✓ Can handle 'ca"' starting on the closing quote (70ms)

    ✓ Can handle 'ci"' with complex escape sequences (71ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (121ms)

    ✓ will fail when ca" ahead of quoted string (97ms)

    ✓ Can handle 'ca`' inside word (127ms)

    ✓ can handle cj (120ms)

    ✓ can handle ck (237ms)

    ✓ can handle c2j (171ms)

    ✓ can handle c2k (103ms)

    ✓ can handle cj on last line (229ms)

    ✓ can handle ck on first line (72ms)

    ✓ can handle c2j on last line (189ms)

    ✓ can handle c2k on first line (187ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (82ms)

    ✓ Can handle 'daw' on word with trailing spaces (91ms)

    ✓ Can handle 'daw' on word with leading spaces (100ms)

    ✓ Can handle 'daw' on word with numeric prefix (138ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (127ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (111ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (187ms)

    ✓ Can handle 'daw' on end of word (202ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (104ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (159ms)

    ✓ Can handle 'daw' on word at beginning of file (70ms)

    ✓ Can handle 'daw' on word at beginning of line (74ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (70ms)

    ✓ Can handle 'daw' around word at end of line (229ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (68ms)

    ✓ Can handle 'daW' around word at whitespace (72ms)

    ✓ Can handle 'daW' on word with trailing spaces (228ms)

    ✓ Can handle 'daW' on word with leading spaces (147ms)

    ✓ Can handle 'daW' on word with numeric prefix (143ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (130ms)

    ✓ Can handle 'daW' on beginning of word (198ms)

    ✓ Can handle 'daW' on end of one line (138ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (134ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (122ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (214ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (147ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (200ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (139ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (213ms)

    ✓ Can handle 'diw' on word (147ms)

    ✓ Can handle 'diw' on word with numeric prefix (206ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (174ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (212ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (297ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (77ms)

    ✓ Can handle 'diW' on word with trailing spaces (221ms)

    ✓ Can handle 'diW' on word with leading spaces (148ms)

    ✓ Can handle 'diW' on word with numeric prefix (122ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (219ms)

    ✓ Can handle 'diW' on beginning of word (109ms)

    ✓ Can handle d} (203ms)

    ✓ Can handle y} at beginning of line (148ms)

    ✓ Select sentence with trailing spaces (218ms)

    ✓ Select sentence with leading spaces (231ms)

    ✓ Select inner sentence with trailing spaces (81ms)

    ✓ Select inner sentence with leading spaces (318ms)

    ✓ Select spaces between sentences (251ms)

    ✓ Can handle 'df' (155ms)

    ✓ Can handle 'dt' (234ms)

    ✓ Can handle backspace (152ms)

    ✓ Can handle backspace across lines (80ms)

    ✓ Can handle A and backspace (233ms)

    ✓ Can handle 'yy' without changing cursor position (100ms)

    ✓ Can handle 'P' after 'yy' (174ms)

    ✓ Can handle 'p' after 'yy' (164ms)

    ✓ Can handle 'P' after 'Nyy' (189ms)

    ✓ Can handle 'p' after 'Nyy' (93ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (136ms)

    ✓ Can handle 'gp' after 'yy' (208ms)

    ✓ Can handle 'gp' after 'Nyy' (138ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (242ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (74ms)

    ✓ Can handle 'gP' after 'yy' (204ms)

    ✓ Can handle 'gP' after 'Nyy' (160ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (1053ms)

    ✓ Can handle ']p' after yy (53ms)

    ✓ Can handle ']p' after 'Nyy' (122ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (250ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (165ms)

    ✓ Can handle '[p' after yy (224ms)

    ✓ Can handle '[p' after 'Nyy' (155ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (212ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (180ms)

    ✓ Can handle 'p' after y'a (207ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (80ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (155ms)

    ✓ Can handle pasting in visual mode over selection (292ms)

    ✓ Can repeat w (118ms)

    ✓ Can repeat p (219ms)

    ✓ I works correctly (172ms)

    ✓ gI works correctly (255ms)

    ✓ gi works correctly (259ms)

    ✓ `. works correctly (235ms)

    ✓ '. works correctly (127ms)

    ✓ g; works correctly (310ms)

    ✓ g, works correctly (210ms)

    ✓ g_ works correctly (180ms)

    ✓ 3g_ works correctly (179ms)

    ✓ gq handles spaces after single line comments correctly (339ms)

    ✓ gq handles spaces before single line comments correctly (538ms)

    ✓ gq handles tabs before single line comments correctly (387ms)

    ✓ Can handle space (116ms)

    ✓ Can handle space (143ms)

    ✓ Undo 1 (324ms)

    ✓ Undo 2 (272ms)

    ✓ Undo cursor (156ms)

    ✓ Undo cursor 2 (315ms)

    ✓ Undo cursor 3 (299ms)

    ✓ Undo with movement first (126ms)

    ✓ Can handle 'U' (232ms)

    ✓ Can handle 'U' for multiple changes (191ms)

    ✓ Can handle 'U' for new line below (248ms)

    ✓ Can handle 'U' for new line above (215ms)

    ✓ Can handle 'U' for consecutive changes only (167ms)

    ✓ Can handle 'u' to undo 'U' (204ms)

    ✓ Can handle 'U' to undo 'U' (115ms)

    ✓ Redo (289ms)

    ✓ Redo (120ms)

    ✓ Redo (295ms)

    ✓ Can handle u (239ms)

    ✓ Can handle guw (87ms)

    ✓ Can handle gUw (174ms)

    ✓ Can handle u over line breaks (149ms)

    ✓ can handle s in visual mode (214ms)

    ✓ can handle p with selection (133ms)

    ✓ can handle P with selection (244ms)

    ✓ can handle p in visual to end of line (243ms)

    ✓ can repeat backspace twice (190ms)

    ✓ can delete linewise with d2G (111ms)

    ✓ can delete with + motion and count (215ms)

    ✓ can delete with - motion and count (65ms)

    ✓ can dE correctly (220ms)

    ✓ can dE correctly (141ms)

    ✓ can dE correctly (218ms)

    ✓ can ctrl-a correctly behind a word (241ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (121ms)

    ✓ can ctrl-a on word (80ms)

    ✓ can ctrl-a on a hex number (228ms)

    ✓ can ctrl-a on decimal (149ms)

    ✓ can ctrl-a with numeric prefix (227ms)

    ✓ can ctrl-a on a decimal (136ms)

    ✓ can ctrl-a on an octal  (211ms)

    ✓ Correctly increments in the middle of a number (132ms)

    ✓ can ctrl-x correctly behind a word (111ms)

    ✓ can ctrl-a on an number with word before  (213ms)

    ✓ can ctrl-a on an number with word before and after  (133ms)

    ✓ can ctrl-x on a negative number with word before and after  (234ms)

    ✓ can ctrl-a properly on multiple lines (106ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (212ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (147ms)

    ✓ can <C-a> on word with - in front of it (196ms)

    ✓ can do Y (159ms)

    ✓ Can do S (69ms)

    ✓ / does not affect mark (223ms)

    ✓ / can search with regex (171ms)

    ✓ / can search with newline (182ms)

    ✓ / can search through multiple newlines (213ms)

    ✓ / matches ^ per line (185ms)

    ✓ / matches $ per line (227ms)

    ✓ Can search for forward slash (187ms)

    ✓ Can search backward for question mark (178ms)

    ✓ /\c forces case insensitive search (145ms)

    ✓ /\C forces case sensitive search (115ms)

    ✓ <BS> deletes the last character in search in progress mode (174ms)

    ✓ <S-BS> deletes the last character in search in progress mode (216ms)

    ✓ <C-h> deletes the last character in search in progress mode (88ms)

    ✓ Can do C (38ms)

    ✓ Can do cit on a matching tag (356ms)

    ✓ Ignores cit on a non-matching tag (205ms)

    ✓ Ignores cit on a nested tag (187ms)

    ✓ Can do cit on a tag with an attribute tag (200ms)

    ✓ Can do cat on a matching tag (144ms)

    ✓ Can do cit on a multiline tag (217ms)

    ✓ Can do cit on a multiline tag with nested tags (107ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (107ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (225ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (134ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (204ms)

    ✓ can do cit with self closing tags (103ms)

    ✓ Respects indentation with cc (217ms)

    ✓ Resets cursor to indent end with cc (134ms)

    ✓ can handle 'cc' on empty line (172ms)

    ✓ cc copies linewise (189ms)

    ✓ Indent current line with correct Vim Mode (144ms)

    ✓ Can handle <Esc> and do nothing (168ms)

    ✓ Can handle # on consecutive words (180ms)

    ✓ Can handle # on skipped words (133ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (166ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (157ms)

    ✓ cc on whitespace-only treats whitespace as indent (211ms)

    ✓ Can do cai (133ms)

    ✓ Can do cii (73ms)

    ✓ Can do caI (216ms)

    ✓ Can do dai (115ms)

    ✓ Can do dii (245ms)

    ✓ Can do daI (266ms)

    ✓ `] go to the end of the previously operated or put text (94ms)

    ✓ '] go to the end of the previously operated or put text (285ms)

    ✓ `[ go to the start of the previously operated or put text (112ms)

    ✓ '[ go to the start of the previously operated or put text (263ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (110ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (165ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (188ms)

    can handle gn

      ✓ gn selects the next match text (263ms)

      ✓ gn selects the current word at |hello (269ms)

      ✓ gn selects the current word at h|ello (242ms)

      ✓ gn selects the current word at hel|lo (319ms)

      ✓ gn selects the current word at hell|o (205ms)

      ✓ gn selects the next word at hello| (242ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (200ms)

      ✓ dgn deletes the current word when cursor is at |hello (179ms)

      ✓ dgn deletes the current word when cursor is at h|ello (353ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (79ms)

      ✓ dgn deletes the current word when cursor is at hell|o (252ms)

      ✓ dgn deletes the next word when cursor is at hello| (112ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (260ms)

      ✓ cgn deletes the current word when cursor is at |hello (101ms)

      ✓ cgn deletes the current word when cursor is at h|ello (255ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (167ms)

      ✓ cgn deletes the current word when cursor is at hell|o (241ms)

      ✓ cgn deletes the next word when cursor is at hello| (126ms)

    can handle gN

      ✓ gN selects the previous match text (222ms)

      ✓ gN selects the current word at hell|o (366ms)

      ✓ gN selects the current word at hel|lo (463ms)

      ✓ gN selects the current word at h|ello (228ms)

      ✓ gN selects the current word at |hello (269ms)

      ✓ gN selects the previous word at | hello (424ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (66ms)

      ✓ dgN deletes the current word when cursor is at hell|o (251ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (198ms)

      ✓ dgN deletes the current word when cursor is at h|ello (124ms)

      ✓ dgN deletes the current word when cursor is at |hello (248ms)

      ✓ dgN deletes the previous word when cursor is at | hello (187ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (200ms)

      ✓ cgN deletes the current word when cursor is at hell|o (221ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (196ms)

      ✓ cgN deletes the current word when cursor is at h|ello (375ms)

      ✓ cgN deletes the current word when cursor is at |hello (127ms)

      ✓ cgN deletes the previous word when cursor is at | hello (102ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (211ms)

    ✓ Can activate with R from Normal mode (48ms)

    ✓ Can handle R (226ms)

    ✓ Can handle R past current line (126ms)

    ✓ Can handle R and exit Replace Mode (222ms)

    ✓ Can handle R across lines (170ms)

    ✓ Can handle R across lines and exit Replace Mode (183ms)

    ✓ Can handle R with {count} (204ms)

    ✓ Can handle backspace (220ms)

    ✓ Can handle backspace (235ms)

    ✓ Can handle backspace across lines (186ms)

    ✓ Can handle arrows (101ms)

    ✓ Can handle . (275ms)

    ✓ Can handle . across lines (200ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (144ms)

    ✓ Can handle wd (115ms)

    ✓ Can handle x (118ms)

    ✓ Can handle x across a selection (311ms)

    ✓ Can do vwd in middle of sentence (146ms)

    ✓ Can do vwd in middle of sentence (118ms)

    ✓ Can do vwd multiple times (166ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (192ms)

    ✓ Can handle H key (169ms)

    ✓ Can handle backspace key (208ms)

    ✓ handles case where we delete over a newline (152ms)

    ✓ handles change operator (154ms)

    ✓ Can do vat on multiple matching tags (127ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (215ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (327ms)

    ✓ Repeat-prefixed vat does not bleed below (236ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (54ms)

    ✓ Can do vi) on a matching parenthesis (232ms)

    ✓ Can do vi) on multiple matching parens (165ms)

    ✓ Can do va) on a matching parenthesis (217ms)

    ✓ Can do va) on multiple matching parens (78ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (180ms)

    ✓ Repeat-prefixed va) does not bleed below (131ms)

    ✓ Can do va} on a matching bracket as first character (65ms)

    ✓ Can do va} on multiple matching brackets (81ms)

    ✓ Can do vi( on a matching bracket near first character (210ms)

    ✓ Can do vi{ on outer pair of nested braces (67ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (165ms)

    ✓ Can do va] on multiple matching brackets (95ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (256ms)

    ✓ Repeat-prefixed vaf does not bleed below (139ms)

    ✓ vaf only expands to enclosing pairs (63ms)

    ✓ Can use . to repeat indent in visual (64ms)

    ✓ Can do v_x to delete to first char (68ms)

    ✓ Can do vg_x to delete to last char with no EOL (182ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (155ms)

    ✓ Can do v$x to delete to last char including EOL (145ms)

    ✓ Can do gv to reselect previous selection (205ms)

    Vim's EOL handling is weird

      ✓ delete through eol (117ms)

      ✓ join 2 lines by deleting through eol (151ms)

      ✓ d$ doesn't delete whole line (137ms)

      ✓ vd$ does delete whole line (96ms)

      ✓ Paste over selection copies the selection (265ms)

      ✓ Paste over selection copies the selection linewise (108ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (111ms)

      ✓ Can handle <down> key (162ms)

      ✓ Can handle <left> key (151ms)

      ✓ Can handle <right> key (68ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (147ms)

      ✓ Can handle 'gj' (132ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (99ms)

      ✓ Can handle 'vawd' on word with trailing spaces (105ms)

      ✓ Can handle 'vawd' on word with leading spaces (112ms)

      ✓ Can handle 'vawd' on word with numeric prefix (220ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (135ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (202ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (546ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (151ms)

      ✓ Can handle 'vaWd' on word with leading spaces (181ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (181ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (169ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (224ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (160ms)

      ✓ Can handle 'vaWd' on word with leading spaces (106ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (193ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (165ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (224ms)

      ✓ Can handle 'vawd' on word with trailing spaces (103ms)

      ✓ Can handle 'vawd' on word with leading spaces (214ms)

      ✓ Can handle 'vawd' on word with numeric prefix (237ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (113ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (157ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (161ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (111ms)

      ✓ Can handle 'vaWd' on word with leading spaces (120ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (239ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (136ms)

      ✓ Can handle 'Y' in visual mode (110ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (238ms)

      ✓ Select sentence with leading spaces in visual mode (152ms)

      ✓ Select multiple sentences in visual mode (238ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (77ms)

      ✓ Select inner sentence with leading spaces in visual mode (196ms)

      ✓ Select spaces between sentences in visual mode (186ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (140ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (103ms)

      ✓ Can do vat on a matching tag (222ms)

    handles replace in visual mode

      ✓ Can do a single line replace (150ms)

      ✓ Can do a multi line replace (112ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (68ms)

      ✓ D deletes the current line (239ms)

    handles indent blocks in visual mode

      ✓ Can do vai (442ms)

      ✓ Can do vii (74ms)

      ✓ Doesn't naively select the next line (106ms)

      ✓ Searches backwards if cursor line is empty (469ms)

      ✓ Can do vaI (121ms)

    visualstar

      ✓ Works with * (220ms)

      ✓ Works with # (81ms)

    search works in visual mode

      ✓ Works with / (97ms)

      ✓ Works with ? (77ms)

      ✓ Selects correct range (131ms)

    X will delete linewise

      ✓ normal selection (110ms)

      ✓ normal selection (236ms)

    C will delete linewise

      ✓ normal selection (133ms)

      ✓ normal selection (222ms)

    R will delete linewise

      ✓ normal selection (145ms)

      ✓ normal selection (96ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (254ms)

      ✓ upward selection (108ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (59ms)

      ✓ multiline indent bottom up selection (138ms)

      ✓ repeat multiline indent top down selection (345ms)

      ✓ repeat multiline indent bottom up selection (237ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (129ms)

      ✓ multiline outdent bottom up selection (225ms)

      ✓ repeat multiline outdent top down selection (109ms)

      ✓ repeat multiline outdent bottom up selection (210ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (133ms)

    vi{ will go to end of second to last line

      ✓ select (110ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode (72ms)

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (460ms)

      ✓ gv selects the last pasted text (which is longer than original) (440ms)

      ✓ gv selects the last pasted text (multiline) (194ms)

    can handle gn

      ✓ gn selects the next match text (230ms)

      ✓ gn selects the current word at |hello (242ms)

      ✓ gn selects the current word at h|ello (201ms)

      ✓ gn selects the current word at hel|lo (239ms)

      ✓ gn selects the next word at hell|o (234ms)

      ✓ gn selects the next word at hello| (293ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (79ms)

      ✓ multiline insert from top down selection (215ms)

      ✓ skips blank lines (63ms)

    can append text with A

      ✓ multiline append from bottom up selection (209ms)

      ✓ multiline append from top down selection (142ms)

      ✓ skips blank lines (397ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (190ms)

      ✓ U/gU across a selection (163ms)

      ✓ U/gU across a selection (reverse) (247ms)

      ✓ u/gu on single character (149ms)

      ✓ u/gu across a selection (439ms)

      ✓ u/gu across a selection (reverse) (175ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (120ms)

    ✓ Can handle A backwards select (239ms)

    ✓ Can handle I forward select (175ms)

    ✓ Can handle I backwards select (247ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (146ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (162ms)

    ✓ Can handle c forward select (242ms)

    ✓ Can handle c backwards select (88ms)

    ✓ Can handle C (215ms)

    ✓ Can do a multi line replace (152ms)

    ✓ Can handle 'D' (235ms)

    ✓ Can handle 'gj' (172ms)

    ✓ Properly add to end of lines j then $ (206ms)

    ✓ Properly add to end of lines $ then j (205ms)

    ✓ o works in visual block mode (106ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (163ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (142ms)

    ✓ Can handle wd (118ms)

    ✓ Can handle x (128ms)

    ✓ Can handle x across a selection (117ms)

    ✓ Can do vwd in middle of sentence (164ms)

    ✓ Can do vwd in middle of sentence (145ms)

    ✓ Can do vwd multiple times (279ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (160ms)

    ✓ handles case where we delete over a newline (169ms)

    ✓ handles change operator (117ms)

    ✓ Vp updates register content (140ms)

    ✓ Vp does not append unnecessary newlines (first line) (184ms)

    ✓ Vp does not append unnecessary newlines (middle line) (146ms)

    ✓ Vp does not append unnecessary newlines (last line) (143ms)

    Vim's EOL handling is weird

      ✓ delete through eol (100ms)

      ✓ join 2 lines by deleting through eol (92ms)

      ✓ d$ doesn't delete whole line (70ms)

      ✓ vd$ does delete whole line (126ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (172ms)

      ✓ Can handle <down> key (210ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (74ms)

      ✓ Can handle 'gj' (189ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (115ms)

      ✓ Can handle d key (53ms)

      ✓ Can handle d key (59ms)

      ✓ Can handle d key (63ms)

      ✓ can handle 'c' (61ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (209ms)

      ✓ Can do a multi visual line replace (103ms)

      ✓ Can do a multi visual line replace from the bottom up (196ms)

    search works in visual line mode

      ✓ Works with / (154ms)

      ✓ Works with ? (64ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (313ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (145ms)

      ✓ linewise visual put works also in the end of document (225ms)

      ✓ gv selects the last pasted text (which is shorter than original) (384ms)

      ✓ gv selects the last pasted text (which is longer than original) (361ms)

      ✓ gv selects the last pasted text (multiline) (431ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (133ms)

      ✓ multiline insert from top down selection (204ms)

      ✓ skips blank lines (147ms)

    can append text with A

      ✓ multiline append from bottom up selection (208ms)

      ✓ multiline append from top down selection (95ms)

      ✓ skips blank lines (212ms)

  Mode Normal

    ✓ Can handle 'x' (105ms)

    ✓ Can handle 'Nx' (64ms)

    ✓ Can handle 'Nx' and paste (396ms)

    ✓ Can handle 'x' at end of line (109ms)

    ✓ Can handle 'Ns' (80ms)

    ✓ Can handle 'Ns' at end of line (119ms)

    ✓ Can handle '<Del>' (140ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (108ms)

    ✓ Can handle '<Del>' at end of line (260ms)

    ✓ Can handle 'cc' (114ms)

    ✓ Can handle 'Ncc' (123ms)

    ✓ Can handle 'yy' (117ms)

    ✓ Can handle 'D' (192ms)

    ✓ Can handle 'D' on empty lines (120ms)

    ✓ Can handle 'DD' (232ms)

    ✓ Can handle 'C' (143ms)

    ✓ Can handle 'NC' (217ms)

    ✓ Can handle 'NC' and put (91ms)

    ✓ Can handle 'r' (55ms)

    ✓ Can handle '<Count>r' (161ms)

    ✓ Can handle '<Count>r' (147ms)

    ✓ Can handle 'r' after 'dd' (133ms)

    ✓ Can handle 'r
' (64ms)

    ✓ Can handle '<Count>r
' (208ms)

    ✓ Can handle 'J' once (62ms)

    ✓ Can handle 'J' twice (80ms)

    ✓ Can handle 'J' with empty last line (74ms)

    ✓ Can handle 'J's with multiple empty last lines (128ms)

    ✓ Can handle 'J' with leading white space on next line (193ms)

    ✓ Can handle 'J' with only white space on next line (95ms)

    ✓ Can handle 'J' with TWO indented lines (106ms)

    ✓ Can handle 'J' with ')' first character on next line (200ms)

    ✓ Can handle 'J' with a following delete (74ms)

    ✓ Can handle 'J' in Visual Line mode (211ms)

    ✓ Can handle 'gJ' once (159ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (178ms)

    ✓ Can handle '~' (65ms)

    ✓ Can handle 'g~{motion}' (136ms)

    ✓ Can handle '<BS>' in insert mode (216ms)

    ✓ Can handle undo with P (130ms)

    ✓ Can handle 'ge' in multiple lines case1 (79ms)

    ✓ Can handle 'ge' in multiple lines case2 (104ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (200ms)

    ✓ Can repeat '~' with dot (142ms)

    ✓ Can repeat 'x' (110ms)

    ✓ Can repeat 'J' (85ms)

    ✓ Can handle dot with A (266ms)

    ✓ Can handle dot with I (159ms)

    ✓ Can repeat actions that require selections (182ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (120ms)

    ✓ Can repeat insert change and '<C-t>' (241ms)

    ✓ Can repeat change by `<C-a>` (155ms)

    ✓ Only one arrow key can be repeated in Insert Mode (220ms)

    ✓ Cached content change will be cleared by arrow keys (155ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (51ms)

    ✓ inside parenthesis (184ms)

    ✓ nested parenthesis beginning (153ms)

    ✓ nested parenthesis end (184ms)

    ✓ nested bracket and parenthesis beginning (161ms)

    ✓ nested bracket, parenthesis, braces beginning (177ms)

    ✓ nested bracket, parenthesis, braces end (378ms)

    ✓ parentheses after > (74ms)

    ✓ parentheses after "

  Motions in Normal Mode

    ✓ Can handle [( (49ms)

    ✓ Can handle nested [( (46ms)

    ✓ Can handle <number>[( (54ms)

    ✓ Can handle [( and character under cursor exclusive (206ms)

    ✓ Can handle ]) (147ms)

    ✓ Can handle nested ]) (203ms)

    ✓ Can handle <number>]) (112ms)

    ✓ Can handle ]) and character under cursor exclusive (188ms)

    ✓ Can handle [{ (79ms)

    ✓ Can handle nested [{ (194ms)

    ✓ Can handle <number>[{ (606ms)

    ✓ Can handle [{ and character under cursor exclusive (114ms)

    ✓ Can handle ]} (90ms)

    ✓ Can handle nested ]} (99ms)

    ✓ Can handle <number>]} (162ms)

    ✓ Can handle ]} and character under cursor exclusive (108ms)

    ✓ Can handle 'ge' (210ms)

    ✓ Can handle 'gg' (174ms)

    ✓ Can handle 'gg' to first non blank char on random line (60ms)

    ✓ Can handle 'gg' to first non blank char on first line (110ms)

    ✓ 'gg' obeys startofline (164ms)

    ✓ Retain same column when moving up/down (209ms)

    ✓ Can handle <enter> (60ms)

    ✓ $ always keeps cursor on EOL (98ms)

    ✓ Can handle $ with a count (203ms)

    ✓ Can handle $ with a count at end of file (171ms)

    ✓ Can handle <End> with a count (92ms)

    ✓ Can handle <D-right> with a count (78ms)

    ✓ Can handle 'f' (60ms)

    ✓ Can handle 'f' twice (218ms)

    ✓ Can handle 'f' with <tab> (160ms)

    ✓ Can handle 'f' and find back search (192ms)

    ✓ Can handle 'F' (63ms)

    ✓ Can handle 'F' twice (209ms)

    ✓ Can handle 'F' and find back search (169ms)

    ✓ Can handle 'f' and multiple back searches (113ms)

    ✓ Can handle 't' (109ms)

    ✓ Can handle 't' twice (132ms)

    ✓ Can handle 't' and find back search (204ms)

    ✓ Can handle 'T' (329ms)

    ✓ Can handle 'T' twice (68ms)

    ✓ Can handle 'T' and find back search (154ms)

    ✓ Can run a forward search (195ms)

    ✓ Can run a forward and find next search (180ms)

    ✓ Can run a forward and find previous search from end of word (214ms)

    ✓ Can run a reverse search (111ms)

    ✓ Can run a reverse and find next search (95ms)

    ✓ cancelled search reverts to previous search state (143ms)

    ✓ Backspace on empty search cancels (228ms)

    ✓ Search offsets: b does nothing (70ms)

    ✓ Search offsets: b2 goes 2 to the right (239ms)

    ✓ Search offsets: b+3 goes 3 to the right (143ms)

    ✓ Search offsets: e goes to the end (82ms)

    ✓ Search offsets: character offset goes across line boundaries (101ms)

    ✓ Search offsets: 2 goes 2 down (163ms)

    ✓ Search offsets: -2 goes 2 up (88ms)

    ✓ maintains column position correctly (294ms)

    ✓ maintains column position correctly with $ (158ms)

    ✓ Can handle G  (94ms)

    ✓ Can handle G with number prefix (180ms)

    ✓ Can handle G with number prefix (95ms)

    ✓ Can handle gg (48ms)

    ✓ Can handle gg with number prefix (58ms)

    ✓ Can handle 0 (64ms)

    ✓ Can handle 0 as part of a repeat (399ms)

    ✓ Can handle g* (115ms)

    ✓ Can handle g*n (101ms)

    ✓ Can handle * (184ms)

    ✓ Can handle ** (146ms)

    ✓ Can handle # on whitespace (58ms)

    ✓ Can handle # on EOL (104ms)

    ✓ Can handle g# (113ms)

    ✓ Can handle g#n (118ms)

    ✓ Can handle # (334ms)

    ✓ Can handle # already on the word (44ms)

    ✓ Can handle ## (90ms)

    ✓ * adds to search history (92ms)

    ✓ # adds to search history (147ms)

    ✓ Can handle | (67ms)

    ✓ Can handle <number> | (96ms)

    ✓ Can handle + (133ms)

    ✓ Can handle + indent (49ms)

    ✓ Can handle + with count prefix (131ms)

    ✓ Can handle - (41ms)

    ✓ Can handle - indent (54ms)

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix (42ms)

    ✓ Can handle g_ (45ms)

    ✓ Can handle g_ with count prefix (58ms)

    ✓ Can handle <up> key (40ms)

    ✓ Can handle <down> key (248ms)

    ✓ Can handle <left> key (49ms)

    ✓ Can handle <right> key (40ms)

    ✓ Can handle 'gk' (49ms)

    ✓ Can handle 'gj' (43ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right
      ✓ move to end of current word right
      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (38ms)

        ✓ l wraps to next line (41ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (50ms)

      insert mode

        ✓ <left> wraps to previous line (52ms)

        ✓ <right> once goes to end of line (50ms)

        ✓ <right> twice wraps to next line (143ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (178ms)

        ✓ l does not wrap to next line (170ms)

        ✓ <left> does not wrap to previous line (175ms)

        ✓ <right> does not wrap to next line (137ms)

      insert mode

        ✓ <left> does not wrap to previous line (314ms)

        ✓ <right> does not wrap to next line (51ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (223ms)

      ✓ search wraps around the start of the file (262ms)

    wrapscan disabled

      ✓ search stops at the end of the file (183ms)

      ✓ search stops at the start of the file (151ms)

  Multicursor

    ✓ can add multiple cursors below (102ms)

    ✓ can add multiple cursors above (229ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip

  comment operator

    ✓ gcc comments out current line (457ms)

    ✓ gcj comments in current and next line (196ms)

    ✓ block comment with motion (362ms)

    ✓ block comment in Visual Mode (263ms)

    ✓ comment in visual line mode (176ms)

    ✓ comment in visual block mode (251ms)

  format operator

    ✓ == formats current line (302ms)

    ✓ =$ formats entire line (513ms)

    ✓ =j formats two lines (222ms)

    ✓ 3=k formats three lines (194ms)

    ✓ =gg formats to top of file (108ms)

    ✓ =G formats to bottom of file (192ms)

    ✓ =ip formats paragraph (86ms)

    ✓ format in visual mode (217ms)

  put operator

    ✓ basic put test (75ms)

    ✓ test yy end of line (154ms)

    ✓ test yy first line (223ms)

    ✓ test yy middle line (64ms)

    ✓ test yy with correct positon movement (67ms)

    ✓ test visual block single line yank p (630ms)

    ✓ test visual block single line yank P (227ms)

    ✓ test visual block single line delete p (130ms)

    ✓ test visual block single line delete P (231ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (60ms)

    ✓ shift left goto end test (217ms)

    ✓ shift left goto line test (242ms)

    ✓ shift right goto end test (47ms)

    ✓ shift right goto line test (114ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (194ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (163ms)

      ✓ step to Camel word (118ms)

      ✓ step to CAP word (184ms)

      ✓ step after CAP word (171ms)

      ✓ step from middle of word to Camel word (138ms)

      ✓ step to number word (118ms)

      ✓ step to operator word (192ms)

      ✓ step from inside operator word (164ms)

      ✓ step to operator and then over (133ms)

    handles <leader>w for underscore_var

      ✓ step to _word (178ms)

      ✓ step over whitespace to word (65ms)

      ✓ step from inside word to _word (125ms)

      ✓ step form _word to number (181ms)

      ✓ step from nubmer word to _word (127ms)

      ✓ step from in whitespace to word (202ms)

      ✓ step in ALL_CAPS_WORD (59ms)

    handles d<leader>w

      ✓ delete from start of camelWord (202ms)

      ✓ delete from middle of camelWord (144ms)

      ✓ delete from start of CamelWord (59ms)

      ✓ delete two words from camelWord (106ms)

      ✓ delete from start of underscore_word (188ms)

      ✓ delete from middle of underscore_word (113ms)

      ✓ delete two words from camel_word (85ms)

    handles di<leader>w

      ✓ delete from start of camelWord (58ms)

      ✓ delete from middle of camelWord (231ms)

      ✓ delete from start of CamelWord (150ms)

      ✓ delete two words from camelWord (156ms)

      ✓ delete from start of underscore_word (83ms)

      ✓ delete from middle of underscore_word (215ms)

      ✓ delete two words from camel_word (134ms)

    handles <leader>b

      ✓ back from middle of word (187ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (74ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (262ms)

      ✓ from middle to end of underscore_word (48ms)

      ✓ twice to end of word over operator (58ms)

  easymotion plugin

    ✓ Can handle s move (61ms)

    ✓ Can handle 2s move (186ms)

    ✓ Can handle f move (63ms)

    ✓ Can handle 2f move (119ms)

    ✓ Can handle F move (184ms)

    ✓ Can handle 2F move (144ms)

    ✓ Can handle t move (196ms)

    ✓ Can handle bd-t move (111ms)

    ✓ Can handle 2t move (83ms)

    ✓ Can handle bd-t2 move (223ms)

    ✓ Can handle T move (102ms)

    ✓ Can handle 2T move (172ms)

    ✓ Can handle w move (179ms)

    ✓ Can handle bd-w move (228ms)

    ✓ Can handle b move (85ms)

    ✓ Can handle e move (333ms)

    ✓ Can handle bd-e move (244ms)

    ✓ Can handle ge move (148ms)

    ✓ Can handle n-char move (241ms)

    ✓ Can handle j move (169ms)

    ✓ Can handle k move (80ms)

    ✓ Can handle bd-jk move (1) (187ms)

    ✓ Can handle bd-jk move (2) (93ms)

    ✓ Can handle lineforward move (1) (252ms)

    ✓ Can handle lineforward move (2) (204ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (90ms)

    ✓ Can handle searching for backslash (\) (208ms)

    ✓ Can handle searching for carat (^) (161ms)

    ✓ Can handle searching for dot (.) (60ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (320ms)

    ✓ Replaces within inner Word (124ms)

    ✓ Replaces within '' (177ms)

    ✓ Replaces within '' including spaces (144ms)

    ✓ Replaces within () (75ms)

    ✓ Replaces within () including spaces (175ms)

    ✓ Replaces within a paragraph (105ms)

    ✓ Replaces using a specified register (306ms)

    ✓ Replaces within {} over multiple lines (83ms)

    ✓ Replaces a multiline register within {} over multiple lines (208ms)

    ✓ Replaces a multiline register within {} over multiple lines (151ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (192ms)

    ✓ grr replaces the entire line with the register (102ms)

    ✓ grr can replace multiple lines (154ms)

    ✓ Replaces in visual mode (234ms)

    ✓ Replaces in visual mode using a specified register (100ms)

    ✓ Replaces in visual line mode (184ms)

    ✓ grj is linewise (325ms)

  sneak plugin

    ✓ Can handle s motion (95ms)

    ✓ Can handle S motion (106ms)

    ✓ Can handle <operator>z motion (151ms)

    ✓ Can handle <operator>Z motion (193ms)

    ✓ Can handle s; motion (111ms)

    ✓ Can handle s, motion (190ms)

    ✓ Can handle S; motion (151ms)

    ✓ Can handle S, motion (200ms)

    ✓ Can handle single letter s motion (85ms)

    ✓ Can handle single letter S motion (87ms)

    ✓ Can handle single letter <operator>z motion (126ms)

    ✓ Can handle single letter <operator>Z motion (116ms)

    ✓ Can handle single letter s; motion (91ms)

    ✓ Can handle single letter s, motion (71ms)

    ✓ Can handle single letter S; motion (207ms)

    ✓ Can handle single letter S, motion (145ms)

    ✓ Can handle multiline single char <number>s motion (195ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (146ms)

    ✓ 'ysiw(' surrounds word with space (181ms)

    ✓ 'ysw)' surrounds word without space (144ms)

    ✓ 'ysw(' surrounds word with space (119ms)

    ✓ 'ysaw)' surrounds word without space (166ms)

    ✓ 'ysaw(' surrounds word with space (146ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (359ms)

    ✓ 'ysiw<' surrounds word with tags (127ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (173ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (155ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (121ms)

    ✓ change surround (134ms)

    ✓ change surround with two pairs of quotes (568ms)

    ✓ change surround with two pairs of parens (93ms)

    ✓ change surround with alias (146ms)

    ✓ change surround to tags (152ms)

    ✓ delete surround (131ms)

    ✓ delete surround with quotes (400ms)

    ✓ delete surround with nested of quotes (119ms)

    ✓ delete surround with inconsistent quotes (177ms)

    ✓ delete surround with mixed quotes (103ms)

    ✓ delete surround with empty quotes cursor at start (117ms)

    ✓ delete surround with empty quotes cursor at end (131ms)

    ✓ don't delete surround if cursor is after closing match (154ms)

    ✓ delete surround if cursor is before opening match (108ms)

    ✓ delete surround with two pairs of parens (171ms)

    ✓ delete surround with alias (126ms)

    ✓ delete surround with tags (160ms)

    ✓ change surround brackets at end of line (122ms)

    ✓ changing brackets with surround works again (178ms)

    ✓ change surround with tags that contain an attribute and preserve them (189ms)

    ✓ change surround with tags that contain an attribute and remove them (161ms)

  register

    ✓ Can copy to a register (131ms)

    ✓ Can use two registers together (155ms)

    ✓ Can use black hole register (181ms)

    ✓ System clipboard works with chinese characters (178ms)

    ✓ Yank stores text in Register '0' (246ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (181ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (174ms)

    ✓ Register '1'-'9' stores delete content (303ms)

    ✓ "A appends linewise text to "a (199ms)

    ✓ "A appends character wise text to "a (246ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (179ms)

    ✓ Small deletion using Del is stored in small delete register (199ms)

    ✓ Small deletion using X is stored in small delete register (183ms)

    ✓ Search register (/) is set by forward search (344ms)

    ✓ Search register (/) is set by backward search (273ms)

    ✓ Search register (/) is set by star search (247ms)

    ✓ Command register (:) is set by command line (77ms)

    ✓ Read-only registers cannot be written to (226ms)

    clipboard

      ✓ Can access '*' (clipboard) register (74ms)

      ✓ Can access '+' (clipboard) register (209ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (125ms)

    ✓ Can repeat reversed F<character> (203ms)

    ✓ Can repeat t<character> (193ms)

    ✓ Can repeat N times reversed t<character> (209ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (360ms)

      ✓ move one sentence backward (148ms)

      ✓ move [count] sentences backward (204ms)

      ✓ move one sentence backward single line - middle (756ms)

      ✓ move one sentence backward no space (183ms)

      ✓ move one sentence backward no space - middle (113ms)

      ✓ move one sentence backward - multiline (121ms)

      ✓ move one sentence backward - multiline - period (173ms)

      ✓ move one sentence backward - multiline - previous line (118ms)

      ✓ move one sentence backward - multiline - previous line - period (171ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath
      ✓ can separate drive letter path on Windows
      ✓ can separate UNC path on Windows
      ✓ can separate relative path on Windows
      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix
    resolveUri
      ✓ posix

      ✓ win32

  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=2625242322212019181716151413121110987654321.
      + expected - actual

      -2625242322212019181716151413121110987654321
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Missing '|' in test object.
      + expected - actual

      -false
      +true
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Missing '|' in test object.
      + expected - actual

      -false
      +true
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 23a431e0-1be7-11ea-ba59-e12deadb3a4c

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[07:32:56] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[07:32:56] Starting 'build'...
[07:32:56] Starting 'prettier'...
[07:32:59] Finished 'prettier' after 2.31 s
[07:32:59] Starting 'tsc'...
[07:32:59] Starting 'tslint'...
[07:33:06] Finished 'tslint' after 7.05 s
[07:33:14] Finished 'tsc' after 15 s
[07:33:14] Starting 'commit-hash'...
[07:33:14] Finished 'commit-hash' after 24 ms
[07:33:14] Finished 'build' after 18 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-11T07:33:17.964Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses
    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (39ms)

    ✓ command <C-w> can remove word in search mode (61ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (42ms)

    ✓ <C-u> deletes from cursor to first character (77ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (58ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (97ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (67ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (53ms)

  command-line lexer

    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot
    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus
    ✓ can lex minus
    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search
    ✓ can lex reverse search escaping
    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs
  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF
    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (552ms)

    ✓ :smile editor contains smile text (559ms)

  Basic sort

    ✓ Sort whole file, asc (224ms)

    ✓ Sort whole file, asc, ignoreCase (164ms)

    ✓ Sort whole file, dsc (246ms)

    ✓ Sort whole file, dsc, ignoreCase (150ms)

    ✓ Sort range, asc (193ms)

    ✓ Sort range, asc, ignoreCase (136ms)

    ✓ Sort range, dsc (214ms)

    ✓ Sort range, dsc, ignoreCase (179ms)

    ✓ Sort whole file, asc, unique (128ms)

  Horizontal split

    ✓ Run :sp (67ms)

    ✓ Run :split (75ms)

    ✓ Run :new (77ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (53ms)

    ✓ Replace with `g` flag (49ms)

    ✓ Replace with flags AND count (122ms)

    ✓ Replace with `c` flag (54ms)

    ✓ Replace with `gc` flag (91ms)

    ✓ Replace across all lines (101ms)

    ✓ Replace on specific single line (143ms)

    ✓ Replace on current line using dot (110ms)

    ✓ Replace single relative line using dot and plus (107ms)

    ✓ Replace across specific line range (135ms)

    ✓ Replace across relative line range using dot, plus, and minus (246ms)

    ✓ Replace across relative line range using numLines+colon shorthand (112ms)

    ✓ Repeat replacement across relative line range (115ms)

    ✓ Replace with range AND count but no flags (108ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (142ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (97ms)

    ✓ Undocumented: trailing operators use 1 as RHS (100ms)

    ✓ Replace specific single equal lines (124ms)

    ✓ Replace current line with no active selection (180ms)

    ✓ Replace text in selection (132ms)

    ✓ Substitute support marks (116ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (63ms)

      ✓ Replace with `g` flag inverts global flag (89ms)

      ✓ Replace with `c` flag inverts global flag (77ms)

      ✓ Replace multiple lines (102ms)

      ✓ Replace across specific lines (114ms)

      ✓ Replace current line with no active selection (102ms)

      ✓ Replace text in selection (114ms)

      ✓ Substitute support marks (132ms)

      ✓ Substitute with escaped delimiter (110ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (260ms)

      ✓ Substitute with previous search using # (230ms)

      ✓ Substitute with previous search using / (349ms)

      ✓ Substitute with parameters should update search state (135ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (268ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (235ms)

      ✓ Substitute repeat previous should accept flags (79ms)

      ✓ Substitute with empty search string should use last searched pattern (366ms)

      ✓ Ampersand (&) should repeat the last substitution (216ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (78ms)

    ✓ tabe with current file path does nothing (58ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (51ms)

    ✓ command line file tab completion with space in file path (100ms)

  Vertical split

    ✓ Run :vs (71ms)

    ✓ Run :vsp (67ms)

    ✓ Run :vsplit (66ms)

    ✓ Run :vnew (202ms)

    ✓ Run :vne (242ms)

  Basic write-quit

    ✓ Run write and quit (77ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (66ms)

      ✓ Can complete lines in file with different indentation (69ms)

      ✓ Returns no completions for unmatched line (47ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (42ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (89ms)

    ✓ getMatchingRemap (94ms)

    ✓ jj -> <Esc> through modehandler (122ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (119ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (84ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (146ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (155ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (158ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (155ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (174ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error
    ✓ error code has message
  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (124ms)

        ✓ Can track jumps for keys: GggG (229ms)

        ✓ Can track jumps for keys: GggGgg (110ms)

        ✓ Can track jumps for keys: /b<CR>n (210ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (67ms)

        ✓ Can track jumps for keys: j%% (60ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (151ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (236ms)

        ✓ Can track jumps for keys: j%%<C-o>% (189ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (194ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (181ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (241ms)

        ✓ Can enter number to jump back multiple times (170ms)

[main 2019-12-11T07:33:47.968Z] update#setState checking for updates

[main 2019-12-11T07:33:48.023Z] update#setState idle

        ✓ Can track one-line `` jumps (93ms)

        ✓ Can track one-line double `` jumps (257ms)

        ✓ Can track one-line '' jumps (365ms)

        ✓ Can track one-line double '' jumps (259ms)

        ✓ Can handle '' jumps with no previous jump (112ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (266ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (182ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (275ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (171ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (120ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (334ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (176ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (217ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (300ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (97ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (250ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (179ms)

  Record and execute a macro

    ✓ Can record and execute (306ms)

    ✓ Can repeat last invoked macro (220ms)

    ✓ Can play back with count (523ms)

    ✓ Can play back with count, abort when a motion fails (522ms)

    ✓ Repeat change on contiguous lines (240ms)

    ✓ Append command to a macro (214ms)

    ✓ Can record Ctrl Keys and repeat (164ms)

    ✓ Can execute macros with dot commands properly (282ms)

    ✓ : (command) register can be used as a macro (142ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode (64ms)

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (98ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (54ms)

    ✓ <C-c> can exit insert (70ms)

    ✓ <Esc> can exit insert (63ms)

    ✓ Stay in insert when entering characters (68ms)

    ✓ Can handle 'O' (49ms)

    ✓ Can handle 'i' (111ms)

    ✓ Can handle 'I' (130ms)

    ✓ Can handle 'a' (125ms)

    ✓ Can handle 'A' (66ms)

    ✓ Can handle '<C-w>' (66ms)

    ✓ Can handle <C-w> on leading whitespace (59ms)

    ✓ Can handle <C-w> at beginning of line (75ms)

    ✓ Can handle <C-u> (65ms)

    ✓ Can handle <C-u> on leading characters (76ms)

    ✓ Can handle <C-u> on leading whitespace (191ms)

    ✓ Correctly places the cursor after deleting the previous line break (193ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (47ms)

    ✓ Backspace works on whitespace only lines (81ms)

    ✓ Backspace works on end of whitespace only lines (80ms)

    ✓ Backspace works at beginning of file (127ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (127ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (85ms)

    ✓ Can perform insert command prefixed with count (97ms)

    ✓ Can perform append command prefixed with count (95ms)

    ✓ Can perform insert at start of line command prefixed with count (130ms)

    ✓ Can perform append to end of line command prefixed with count (92ms)

    ✓ Can perform change char (s) command prefixed with count (104ms)

    ✓ Can perform command prefixed with count with <C-[> (148ms)

    ✓ Can handle 'o' with count (133ms)

    ✓ Can handle 'O' with count (122ms)

    ✓ Can handle backspace at beginning of line with all spaces (109ms)

    ✓ Can handle digraph insert (102ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (101ms)

    ✓ Can handle dw (124ms)

    ✓ Can handle dw (115ms)

    ✓ Can handle dw across lines (1) (181ms)

    ✓ Can handle dw across lines (2) (93ms)

    ✓ Can handle dd last line (63ms)

    ✓ Can handle dd single line (57ms)

    ✓ Can handle dd (68ms)

    ✓ Can handle 3dd (56ms)

    ✓ Can handle 3dd off end of document (196ms)

    ✓ Can handle d2d (67ms)

    ✓ Can handle dd empty line (63ms)

    ✓ Can handle ddp (70ms)

    ✓ Can handle 'de' (69ms)

    ✓ Can handle 'de' then 'de' again (117ms)

    ✓ Can handle 'db' (103ms)

    ✓ Can handle 'db then 'db' again (229ms)

    ✓ Can handle 'dl' at end of line (91ms)

    ✓ Can handle 'dF' (88ms)

    ✓ Can handle 'dT' (101ms)

    ✓ Can handle 'd3' then <enter> (102ms)

    ✓ Can handle 'dj' (143ms)

    ✓ Can handle 'dk' (75ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (123ms)

    ✓ Can handle 'd]}' without deleting closing bracket (96ms)

    ✓ Can handle 'cw' (199ms)

    ✓ Can handle 'cw' without deleting following white spaces (49ms)

    ✓ Can handle 'c2w' (70ms)

    ✓ Can handle 'cw' without removing EOL (146ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (97ms)

    ✓ Can handle 'c]}' without deleting closing bracket (136ms)

    ✓ Can handle 's' (140ms)

    ✓ Can handle 'yiw' with correct cursor ending position (128ms)

    ✓ Can handle 'ciw' (162ms)

    ✓ Can handle 'ciw' on blanks (251ms)

    ✓ Can handle 'caw' (116ms)

    ✓ Can handle 'caw' on first letter (124ms)

    ✓ Can handle 'caw' on blanks (153ms)

    ✓ Can handle 'caw' on blanks (134ms)

    ✓ Can handle 'ci(' on first parentheses (78ms)

    ✓ Can handle 'ci(' with nested parentheses (79ms)

    ✓ Can handle 'ci(' backwards through nested parens (82ms)

    ✓ Can handle 'cib' on first parentheses (82ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (162ms)

    ✓ Can handle count prefixed 'ci)' (111ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (157ms)

    ✓ Can handle 'cab' spanning multiple lines (88ms)

    ✓ Can handle 'ci{' spanning multiple lines (73ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (110ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (68ms)

    ✓ Can handle 'ci(' on the closing bracket (188ms)

    ✓ Can handle 'ciB' spanning multiple lines (76ms)

    ✓ will fail when ca( with no () (40ms)

    ✓ will fail when ca{ with no {} (144ms)

    ✓ will fail when caB with no {} (83ms)

    ✓ Can handle 'ci[' spanning multiple lines (55ms)

    ✓ Can handle 'ci]' on first bracket (72ms)

    ✓ Can handle 'ca[' on first bracket (237ms)

    ✓ Can handle 'ca]' on first bracket (103ms)

    ✓ Can handle 'ci'' on first quote (106ms)

    ✓ Can handle 'ci'' inside quoted string (134ms)

    ✓ Can handle 'ci'' on closing quote (81ms)

    ✓ Can handle 'ci'' when string is ahead (91ms)

    ✓ Can handle 'ci"' on opening quote (82ms)

    ✓ Can handle 'ci"' starting behind the quoted word (41ms)

    ✓ Can handle 'ca"' starting behind the quoted word (107ms)

    ✓ Can handle 'ca"' starting on the opening quote (122ms)

    ✓ Can handle 'ci"' with escaped quotes (90ms)

    ✓ Can handle 'ci"' with a single escaped quote

    ✓ Can handle 'ci"' with a single escaped quote behind (83ms)

    ✓ Can handle 'ci"' with an escaped backslash (150ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (125ms)

    ✓ Can handle 'ca"' starting on the closing quote (97ms)

    ✓ Can handle 'ci"' with complex escape sequences (80ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (59ms)

    ✓ will fail when ca" ahead of quoted string (73ms)

    ✓ Can handle 'ca`' inside word (59ms)

    ✓ can handle cj (148ms)

    ✓ can handle ck (223ms)

    ✓ can handle c2j (136ms)

    ✓ can handle c2k (209ms)

    ✓ can handle cj on last line (180ms)

    ✓ can handle ck on first line (184ms)

    ✓ can handle c2j on last line (131ms)

    ✓ can handle c2k on first line (146ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (135ms)

    ✓ Can handle 'daw' on word with trailing spaces (83ms)

    ✓ Can handle 'daw' on word with leading spaces (104ms)

    ✓ Can handle 'daw' on word with numeric prefix (99ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (208ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (104ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (269ms)

    ✓ Can handle 'daw' on end of word (145ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (90ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (77ms)

    ✓ Can handle 'daw' on word at beginning of file (126ms)

    ✓ Can handle 'daw' on word at beginning of line (159ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (69ms)

    ✓ Can handle 'daw' around word at end of line (82ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (110ms)

    ✓ Can handle 'daW' around word at whitespace (78ms)

    ✓ Can handle 'daW' on word with trailing spaces (69ms)

    ✓ Can handle 'daW' on word with leading spaces (124ms)

    ✓ Can handle 'daW' on word with numeric prefix (107ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (142ms)

    ✓ Can handle 'daW' on beginning of word (176ms)

    ✓ Can handle 'daW' on end of one line (70ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (76ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (60ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (126ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (88ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (75ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (66ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (88ms)

    ✓ Can handle 'diw' on word (63ms)

    ✓ Can handle 'diw' on word with numeric prefix (68ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (135ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (140ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (151ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (72ms)

    ✓ Can handle 'diW' on word with trailing spaces (112ms)

    ✓ Can handle 'diW' on word with leading spaces (188ms)

    ✓ Can handle 'diW' on word with numeric prefix (204ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (150ms)

    ✓ Can handle 'diW' on beginning of word (162ms)

    ✓ Can handle d} (215ms)

    ✓ Can handle y} at beginning of line (166ms)

    ✓ Select sentence with trailing spaces (216ms)

    ✓ Select sentence with leading spaces (159ms)

    ✓ Select inner sentence with trailing spaces (213ms)

    ✓ Select inner sentence with leading spaces (187ms)

    ✓ Select spaces between sentences (176ms)

    ✓ Can handle 'df' (227ms)

    ✓ Can handle 'dt' (74ms)

    ✓ Can handle backspace (211ms)

    ✓ Can handle backspace across lines (184ms)

    ✓ Can handle A and backspace (205ms)

    ✓ Can handle 'yy' without changing cursor position (135ms)

    ✓ Can handle 'P' after 'yy' (186ms)

    ✓ Can handle 'p' after 'yy' (181ms)

    ✓ Can handle 'P' after 'Nyy' (181ms)

    ✓ Can handle 'p' after 'Nyy' (69ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (64ms)

    ✓ Can handle 'gp' after 'yy' (214ms)

    ✓ Can handle 'gp' after 'Nyy' (168ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (230ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (70ms)

    ✓ Can handle 'gP' after 'yy' (227ms)

    ✓ Can handle 'gP' after 'Nyy' (156ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (227ms)

    ✓ Can handle ']p' after yy (52ms)

    ✓ Can handle ']p' after 'Nyy' (91ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (101ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (154ms)

    ✓ Can handle '[p' after yy (166ms)

    ✓ Can handle '[p' after 'Nyy' (232ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (154ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (247ms)

    ✓ Can handle 'p' after y'a (174ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (99ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (221ms)

    ✓ Can handle pasting in visual mode over selection (291ms)

    ✓ Can repeat w (94ms)

    ✓ Can repeat p (224ms)

    ✓ I works correctly (200ms)

    ✓ gI works correctly (223ms)

    ✓ gi works correctly (240ms)

    ✓ `. works correctly (204ms)

    ✓ '. works correctly (218ms)

    ✓ g; works correctly (248ms)

    ✓ g, works correctly (260ms)

    ✓ g_ works correctly (140ms)

    ✓ 3g_ works correctly (216ms)

    ✓ gq handles spaces after single line comments correctly (378ms)

    ✓ gq handles spaces before single line comments correctly (390ms)

    ✓ gq handles tabs before single line comments correctly (367ms)

    ✓ Can handle space (44ms)

    ✓ Can handle space (67ms)

    ✓ Undo 1 (124ms)

    ✓ Undo 2 (266ms)

    ✓ Undo cursor (173ms)

    ✓ Undo cursor 2 (275ms)

    ✓ Undo cursor 3 (126ms)

    ✓ Undo with movement first (281ms)

    ✓ Can handle 'U' (89ms)

    ✓ Can handle 'U' for multiple changes (103ms)

    ✓ Can handle 'U' for new line below (101ms)

    ✓ Can handle 'U' for new line above (284ms)

    ✓ Can handle 'U' for consecutive changes only (439ms)

    ✓ Can handle 'u' to undo 'U' (387ms)

    ✓ Can handle 'U' to undo 'U' (267ms)

    ✓ Redo (297ms)

    ✓ Redo (155ms)

    ✓ Redo (196ms)

    ✓ Can handle u (192ms)

    ✓ Can handle guw (148ms)

    ✓ Can handle gUw (221ms)

    ✓ Can handle u over line breaks (153ms)

    ✓ can handle s in visual mode (117ms)

    ✓ can handle p with selection (250ms)

    ✓ can handle P with selection (188ms)

    ✓ can handle p in visual to end of line (239ms)

    ✓ can repeat backspace twice (186ms)

    ✓ can delete linewise with d2G (213ms)

    ✓ can delete with + motion and count (148ms)

    ✓ can delete with - motion and count (86ms)

    ✓ can dE correctly (215ms)

    ✓ can dE correctly (126ms)

    ✓ can dE correctly (207ms)

    ✓ can ctrl-a correctly behind a word (154ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (216ms)

    ✓ can ctrl-a on word (138ms)

    ✓ can ctrl-a on a hex number (142ms)

    ✓ can ctrl-a on decimal (213ms)

    ✓ can ctrl-a with numeric prefix (205ms)

    ✓ can ctrl-a on a decimal (185ms)

    ✓ can ctrl-a on an octal  (168ms)

    ✓ Correctly increments in the middle of a number (213ms)

    ✓ can ctrl-x correctly behind a word

    ✓ can ctrl-a on an number with word before  (91ms)

    ✓ can ctrl-a on an number with word before and after  (106ms)

    ✓ can ctrl-x on a negative number with word before and after  (238ms)

    ✓ can ctrl-a properly on multiple lines (121ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (202ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (212ms)

    ✓ can <C-a> on word with - in front of it (115ms)

    ✓ can do Y (77ms)

    ✓ Can do S (71ms)

    ✓ / does not affect mark (220ms)

    ✓ / can search with regex (184ms)

    ✓ / can search with newline (177ms)

    ✓ / can search through multiple newlines (247ms)

    ✓ / matches ^ per line (186ms)

    ✓ / matches $ per line (107ms)

    ✓ Can search for forward slash (226ms)

    ✓ Can search backward for question mark (84ms)

    ✓ /\c forces case insensitive search (45ms)

    ✓ /\C forces case sensitive search (127ms)

    ✓ <BS> deletes the last character in search in progress mode (242ms)

    ✓ <S-BS> deletes the last character in search in progress mode (191ms)

    ✓ <C-h> deletes the last character in search in progress mode (183ms)

    ✓ Can do C (40ms)

    ✓ Can do cit on a matching tag (93ms)

    ✓ Ignores cit on a non-matching tag (215ms)

    ✓ Ignores cit on a nested tag (192ms)

    ✓ Can do cit on a tag with an attribute tag (214ms)

    ✓ Can do cat on a matching tag (149ms)

    ✓ Can do cit on a multiline tag (206ms)

    ✓ Can do cit on a multiline tag with nested tags (135ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (117ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (175ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (151ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (216ms)

    ✓ can do cit with self closing tags (312ms)

    ✓ Respects indentation with cc (206ms)

    ✓ Resets cursor to indent end with cc (65ms)

    ✓ can handle 'cc' on empty line (42ms)

    ✓ cc copies linewise (214ms)

    ✓ Indent current line with correct Vim Mode (150ms)

    ✓ Can handle <Esc> and do nothing (206ms)

    ✓ Can handle # on consecutive words (203ms)

    ✓ Can handle # on skipped words (218ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (141ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (271ms)

    ✓ cc on whitespace-only treats whitespace as indent (145ms)

    ✓ Can do cai (218ms)

    ✓ Can do cii (87ms)

    ✓ Can do caI (207ms)

    ✓ Can do dai (102ms)

    ✓ Can do dii (81ms)

    ✓ Can do daI (210ms)

    ✓ `] go to the end of the previously operated or put text (97ms)

    ✓ '] go to the end of the previously operated or put text (275ms)

    ✓ `[ go to the start of the previously operated or put text (140ms)

    ✓ '[ go to the start of the previously operated or put text (270ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (97ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (245ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (205ms)

    can handle gn

      ✓ gn selects the next match text (252ms)

      ✓ gn selects the current word at |hello (286ms)

      ✓ gn selects the current word at h|ello (449ms)

      ✓ gn selects the current word at hel|lo (262ms)

      ✓ gn selects the current word at hell|o (225ms)

      ✓ gn selects the next word at hello| (249ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (73ms)

      ✓ dgn deletes the current word when cursor is at |hello (248ms)

      ✓ dgn deletes the current word when cursor is at h|ello (69ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (215ms)

      ✓ dgn deletes the current word when cursor is at hell|o (180ms)

      ✓ dgn deletes the next word when cursor is at hello| (190ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (204ms)

      ✓ cgn deletes the current word when cursor is at |hello (188ms)

      ✓ cgn deletes the current word when cursor is at h|ello (239ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (182ms)

      ✓ cgn deletes the current word when cursor is at hell|o (72ms)

      ✓ cgn deletes the next word when cursor is at hello| (258ms)

    can handle gN

      ✓ gN selects the previous match text (238ms)

      ✓ gN selects the current word at hell|o (345ms)

      ✓ gN selects the current word at hel|lo (370ms)

      ✓ gN selects the current word at h|ello (238ms)

      ✓ gN selects the current word at |hello (253ms)

      ✓ gN selects the previous word at | hello (260ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (82ms)

      ✓ dgN deletes the current word when cursor is at hell|o (248ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (302ms)

      ✓ dgN deletes the current word when cursor is at h|ello (192ms)

      ✓ dgN deletes the current word when cursor is at |hello (174ms)

      ✓ dgN deletes the previous word when cursor is at | hello (223ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (331ms)

      ✓ cgN deletes the current word when cursor is at hell|o (159ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (236ms)

      ✓ cgN deletes the current word when cursor is at h|ello (186ms)

      ✓ cgN deletes the current word when cursor is at |hello (206ms)

      ✓ cgN deletes the previous word when cursor is at | hello (154ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (156ms)

    ✓ Can activate with R from Normal mode (132ms)

    ✓ Can handle R (125ms)

    ✓ Can handle R past current line (221ms)

    ✓ Can handle R and exit Replace Mode (112ms)

    ✓ Can handle R across lines (264ms)

    ✓ Can handle R across lines and exit Replace Mode (118ms)

    ✓ Can handle R with {count} (266ms)

    ✓ Can handle backspace (147ms)

    ✓ Can handle backspace (248ms)

    ✓ Can handle backspace across lines (169ms)

    ✓ Can handle arrows (112ms)

    ✓ Can handle . (291ms)

    ✓ Can handle . across lines (215ms)

  Mode Visual

    ✓ can be activated (167ms)

    ✓ Can handle w (172ms)

    ✓ Can handle wd (126ms)

    ✓ Can handle x (138ms)

    ✓ Can handle x across a selection (148ms)

    ✓ Can do vwd in middle of sentence (195ms)

    ✓ Can do vwd in middle of sentence (143ms)

    ✓ Can do vwd multiple times (196ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (179ms)

    ✓ Can handle H key (203ms)

    ✓ Can handle backspace key (179ms)

    ✓ handles case where we delete over a newline (165ms)

    ✓ handles change operator (167ms)

    ✓ Can do vat on multiple matching tags (228ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (271ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (131ms)

    ✓ Repeat-prefixed vat does not bleed below (233ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (96ms)

    ✓ Can do vi) on a matching parenthesis (254ms)

    ✓ Can do vi) on multiple matching parens (162ms)

    ✓ Can do va) on a matching parenthesis (211ms)

    ✓ Can do va) on multiple matching parens (186ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (122ms)

    ✓ Repeat-prefixed va) does not bleed below (229ms)

    ✓ Can do va} on a matching bracket as first character (64ms)

    ✓ Can do va} on multiple matching brackets (122ms)

    ✓ Can do vi( on a matching bracket near first character (256ms)

    ✓ Can do vi{ on outer pair of nested braces (97ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (80ms)

    ✓ Can do va] on multiple matching brackets (242ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (166ms)

    ✓ Repeat-prefixed vaf does not bleed below (221ms)

    ✓ vaf only expands to enclosing pairs (72ms)

    ✓ Can use . to repeat indent in visual (243ms)

    ✓ Can do v_x to delete to first char (150ms)

    ✓ Can do vg_x to delete to last char with no EOL (145ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (154ms)

    ✓ Can do v$x to delete to last char including EOL (91ms)

    ✓ Can do gv to reselect previous selection (270ms)

    Vim's EOL handling is weird

      ✓ delete through eol (116ms)

      ✓ join 2 lines by deleting through eol (146ms)

      ✓ d$ doesn't delete whole line (79ms)

      ✓ vd$ does delete whole line (115ms)

      ✓ Paste over selection copies the selection (248ms)

      ✓ Paste over selection copies the selection linewise (171ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (231ms)

      ✓ Can handle <down> key (55ms)

      ✓ Can handle <left> key (70ms)

      ✓ Can handle <right> key (229ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (111ms)

      ✓ Can handle 'gj' (111ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (227ms)

      ✓ Can handle 'vawd' on word with trailing spaces (156ms)

      ✓ Can handle 'vawd' on word with leading spaces (119ms)

      ✓ Can handle 'vawd' on word with numeric prefix (149ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (212ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (414ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (144ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (143ms)

      ✓ Can handle 'vaWd' on word with leading spaces (150ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (133ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (247ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (150ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (173ms)

      ✓ Can handle 'vaWd' on word with leading spaces (179ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (190ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (134ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (182ms)

      ✓ Can handle 'vawd' on word with trailing spaces (241ms)

      ✓ Can handle 'vawd' on word with leading spaces (156ms)

      ✓ Can handle 'vawd' on word with numeric prefix (162ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (162ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (139ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (211ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (77ms)

      ✓ Can handle 'vaWd' on word with leading spaces (135ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (73ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (149ms)

      ✓ Can handle 'Y' in visual mode (131ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (216ms)

      ✓ Select sentence with leading spaces in visual mode (229ms)

      ✓ Select multiple sentences in visual mode (224ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (139ms)

      ✓ Select inner sentence with leading spaces in visual mode (127ms)

      ✓ Select spaces between sentences in visual mode (166ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (111ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (150ms)

      ✓ Can do vat on a matching tag (219ms)

    handles replace in visual mode

      ✓ Can do a single line replace (125ms)

      ✓ Can do a multi line replace (190ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (98ms)

      ✓ D deletes the current line (121ms)

    handles indent blocks in visual mode

      ✓ Can do vai (233ms)

      ✓ Can do vii (122ms)

      ✓ Doesn't naively select the next line (74ms)

      ✓ Searches backwards if cursor line is empty (224ms)

      ✓ Can do vaI (148ms)

    visualstar

      ✓ Works with * (91ms)

      ✓ Works with # (69ms)

    search works in visual mode

      ✓ Works with / (64ms)

      ✓ Works with ? (76ms)

      ✓ Selects correct range (394ms)

    X will delete linewise

      ✓ normal selection (62ms)

      ✓ normal selection (77ms)

    C will delete linewise

      ✓ normal selection (67ms)

      ✓ normal selection (76ms)

    R will delete linewise

      ✓ normal selection (196ms)

      ✓ normal selection (160ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (172ms)

      ✓ upward selection (98ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (70ms)

      ✓ multiline indent bottom up selection (85ms)

      ✓ repeat multiline indent top down selection (83ms)

      ✓ repeat multiline indent bottom up selection (136ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (105ms)

      ✓ multiline outdent bottom up selection (107ms)

      ✓ repeat multiline outdent top down selection (225ms)

      ✓ repeat multiline outdent bottom up selection (153ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (156ms)

    vi{ will go to end of second to last line

      ✓ select (264ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (475ms)

      ✓ gv selects the last pasted text (which is longer than original) (569ms)

      ✓ gv selects the last pasted text (multiline) (211ms)

    can handle gn

      ✓ gn selects the next match text (229ms)

      ✓ gn selects the current word at |hello (239ms)

      ✓ gn selects the current word at h|ello (210ms)

      ✓ gn selects the current word at hel|lo (271ms)

      ✓ gn selects the next word at hell|o (257ms)

      ✓ gn selects the next word at hello| (249ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (143ms)

      ✓ multiline insert from top down selection (167ms)

      ✓ skips blank lines (225ms)

    can append text with A

      ✓ multiline append from bottom up selection (155ms)

      ✓ multiline append from top down selection (62ms)

      ✓ skips blank lines (219ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (231ms)

      ✓ U/gU across a selection (197ms)

      ✓ U/gU across a selection (reverse) (165ms)

      ✓ u/gu on single character (88ms)

      ✓ u/gu across a selection (276ms)

      ✓ u/gu across a selection (reverse) (228ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (437ms)

    ✓ Can handle A backwards select (267ms)

    ✓ Can handle I forward select (151ms)

    ✓ Can handle I backwards select (182ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (120ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (237ms)

    ✓ Can handle c forward select (169ms)

    ✓ Can handle c backwards select (121ms)

    ✓ Can handle C (248ms)

    ✓ Can do a multi line replace (98ms)

    ✓ Can handle 'D' (88ms)

    ✓ Can handle 'gj' (162ms)

    ✓ Properly add to end of lines j then $ (175ms)

    ✓ Properly add to end of lines $ then j (136ms)

    ✓ o works in visual block mode (108ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (175ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (160ms)

    ✓ Can handle wd (143ms)

    ✓ Can handle x (140ms)

    ✓ Can handle x across a selection (113ms)

    ✓ Can do vwd in middle of sentence (149ms)

    ✓ Can do vwd in middle of sentence (143ms)

    ✓ Can do vwd multiple times (185ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (132ms)

    ✓ handles case where we delete over a newline (268ms)

    ✓ handles change operator (121ms)

    ✓ Vp updates register content (218ms)

    ✓ Vp does not append unnecessary newlines (first line) (133ms)

    ✓ Vp does not append unnecessary newlines (middle line) (114ms)

    ✓ Vp does not append unnecessary newlines (last line) (146ms)

    Vim's EOL handling is weird

      ✓ delete through eol (81ms)

      ✓ join 2 lines by deleting through eol (98ms)

      ✓ d$ doesn't delete whole line (87ms)

      ✓ vd$ does delete whole line (109ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (69ms)

      ✓ Can handle <down> key (78ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (111ms)

      ✓ Can handle 'gj' (107ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (178ms)

      ✓ Can handle d key (197ms)

      ✓ Can handle d key (72ms)

      ✓ Can handle d key (60ms)

      ✓ can handle 'c' (53ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (63ms)

      ✓ Can do a multi visual line replace (227ms)

      ✓ Can do a multi visual line replace from the bottom up (147ms)

    search works in visual line mode

      ✓ Works with / (247ms)

      ✓ Works with ? (278ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (173ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (135ms)

      ✓ linewise visual put works also in the end of document (116ms)

      ✓ gv selects the last pasted text (which is shorter than original) (421ms)

      ✓ gv selects the last pasted text (which is longer than original) (369ms)

      ✓ gv selects the last pasted text (multiline) (178ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (155ms)

      ✓ multiline insert from top down selection (217ms)

      ✓ skips blank lines (160ms)

    can append text with A

      ✓ multiline append from bottom up selection (186ms)

      ✓ multiline append from top down selection (163ms)

      ✓ skips blank lines (209ms)

  Mode Normal

    ✓ Can handle 'x' (127ms)

    ✓ Can handle 'Nx' (201ms)

    ✓ Can handle 'Nx' and paste (66ms)

    ✓ Can handle 'x' at end of line (232ms)

    ✓ Can handle 'Ns' (179ms)

    ✓ Can handle 'Ns' at end of line (211ms)

    ✓ Can handle '<Del>' (147ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (167ms)

    ✓ Can handle '<Del>' at end of line (144ms)

    ✓ Can handle 'cc' (169ms)

    ✓ Can handle 'Ncc' (155ms)

    ✓ Can handle 'yy' (93ms)

    ✓ Can handle 'D' (152ms)

    ✓ Can handle 'D' on empty lines (176ms)

    ✓ Can handle 'DD' (136ms)

    ✓ Can handle 'C' (85ms)

    ✓ Can handle 'NC' (224ms)

    ✓ Can handle 'NC' and put (448ms)

    ✓ Can handle 'r' (140ms)

    ✓ Can handle '<Count>r' (217ms)

    ✓ Can handle '<Count>r' (107ms)

    ✓ Can handle 'r' after 'dd' (103ms)

    ✓ Can handle 'r
' (203ms)

    ✓ Can handle '<Count>r
' (73ms)

    ✓ Can handle 'J' once (51ms)

    ✓ Can handle 'J' twice (133ms)

    ✓ Can handle 'J' with empty last line (85ms)

    ✓ Can handle 'J's with multiple empty last lines (265ms)

    ✓ Can handle 'J' with leading white space on next line (38ms)

    ✓ Can handle 'J' with only white space on next line (47ms)

    ✓ Can handle 'J' with TWO indented lines (57ms)

    ✓ Can handle 'J' with ')' first character on next line (70ms)

    ✓ Can handle 'J' with a following delete (45ms)

    ✓ Can handle 'J' in Visual Line mode (338ms)

    ✓ Can handle 'gJ' once (177ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (152ms)

    ✓ Can handle '~' (86ms)

    ✓ Can handle 'g~{motion}' (110ms)

    ✓ Can handle '<BS>' in insert mode (127ms)

    ✓ Can handle undo with P (242ms)

    ✓ Can handle 'ge' in multiple lines case1 (100ms)

    ✓ Can handle 'ge' in multiple lines case2 (105ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (189ms)

    ✓ Can repeat '~' with dot (113ms)

    ✓ Can repeat 'x' (158ms)

    ✓ Can repeat 'J' (45ms)

    ✓ Can handle dot with A (101ms)

    ✓ Can handle dot with I (264ms)

    ✓ Can repeat actions that require selections (251ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (157ms)

    ✓ Can repeat insert change and '<C-t>' (249ms)

    ✓ Can repeat change by `<C-a>` (154ms)

    ✓ Only one arrow key can be repeated in Insert Mode (117ms)

    ✓ Cached content change will be cleared by arrow keys (243ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (76ms)

    ✓ inside parenthesis (102ms)

    ✓ nested parenthesis beginning (47ms)

    ✓ nested parenthesis end (85ms)

    ✓ nested bracket and parenthesis beginning (112ms)

    ✓ nested bracket, parenthesis, braces beginning (191ms)

    ✓ nested bracket, parenthesis, braces end (72ms)

    ✓ parentheses after > (143ms)

    ✓ parentheses after " (212ms)

  Motions in Normal Mode

    ✓ Can handle [( (141ms)

    ✓ Can handle nested [( (201ms)

    ✓ Can handle <number>[( (409ms)

    ✓ Can handle [( and character under cursor exclusive (106ms)

    ✓ Can handle ]) (213ms)

    ✓ Can handle nested ]) (85ms)

    ✓ Can handle <number>]) (202ms)

    ✓ Can handle ]) and character under cursor exclusive (176ms)

    ✓ Can handle [{ (197ms)

    ✓ Can handle nested [{ (169ms)

    ✓ Can handle <number>[{ (52ms)

    ✓ Can handle [{ and character under cursor exclusive (53ms)

    ✓ Can handle ]} (46ms)

    ✓ Can handle nested ]} (47ms)

    ✓ Can handle <number>]} (44ms)

    ✓ Can handle ]} and character under cursor exclusive (51ms)

    ✓ Can handle 'ge' (227ms)

    ✓ Can handle 'gg' (146ms)

    ✓ Can handle 'gg' to first non blank char on random line (286ms)

    ✓ Can handle 'gg' to first non blank char on first line (174ms)

    ✓ 'gg' obeys startofline (213ms)

    ✓ Retain same column when moving up/down (165ms)

    ✓ Can handle <enter> (70ms)

    ✓ $ always keeps cursor on EOL (188ms)

    ✓ Can handle $ with a count (143ms)

    ✓ Can handle $ with a count at end of file (207ms)

    ✓ Can handle <End> with a count (46ms)

    ✓ Can handle <D-right> with a count (55ms)

    ✓ Can handle 'f' (68ms)

    ✓ Can handle 'f' twice (144ms)

    ✓ Can handle 'f' with <tab> (190ms)

    ✓ Can handle 'f' and find back search (161ms)

    ✓ Can handle 'F' (209ms)

    ✓ Can handle 'F' twice (139ms)

    ✓ Can handle 'F' and find back search (157ms)

    ✓ Can handle 'f' and multiple back searches (150ms)

    ✓ Can handle 't' (203ms)

    ✓ Can handle 't' twice (204ms)

    ✓ Can handle 't' and find back search (66ms)

    ✓ Can handle 'T' (106ms)

    ✓ Can handle 'T' twice (64ms)

    ✓ Can handle 'T' and find back search (319ms)

    ✓ Can run a forward search (188ms)

    ✓ Can run a forward and find next search (50ms)

    ✓ Can run a forward and find previous search from end of word (52ms)

    ✓ Can run a reverse search (63ms)

    ✓ Can run a reverse and find next search (102ms)

    ✓ cancelled search reverts to previous search state (159ms)

    ✓ Backspace on empty search cancels (194ms)

    ✓ Search offsets: b does nothing (74ms)

    ✓ Search offsets: b2 goes 2 to the right (243ms)

    ✓ Search offsets: b+3 goes 3 to the right (195ms)

    ✓ Search offsets: e goes to the end (131ms)

    ✓ Search offsets: character offset goes across line boundaries (141ms)

    ✓ Search offsets: 2 goes 2 down (110ms)

    ✓ Search offsets: -2 goes 2 up (144ms)

    ✓ maintains column position correctly (213ms)

    ✓ maintains column position correctly with $ (86ms)

    ✓ Can handle G  (203ms)

    ✓ Can handle G with number prefix (170ms)

    ✓ Can handle G with number prefix (141ms)

    ✓ Can handle gg (54ms)

    ✓ Can handle gg with number prefix

    ✓ Can handle 0 (65ms)

    ✓ Can handle 0 as part of a repeat

    ✓ Can handle g*

    ✓ Can handle g*n (79ms)

    ✓ Can handle * (223ms)

    ✓ Can handle ** (163ms)

    ✓ Can handle # on whitespace (67ms)

    ✓ Can handle # on EOL (60ms)

    ✓ Can handle g# (103ms)

    ✓ Can handle g#n (91ms)

    ✓ Can handle # (131ms)

    ✓ Can handle # already on the word (52ms)

    ✓ Can handle ## (99ms)

    ✓ * adds to search history (63ms)

    ✓ # adds to search history (143ms)

    ✓ Can handle | (82ms)

    ✓ Can handle <number> | (79ms)

    ✓ Can handle + (201ms)

    ✓ Can handle + indent (117ms)

    ✓ Can handle + with count prefix (212ms)

    ✓ Can handle - (51ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _ (45ms)

    ✓ Can handle _ with count prefix (48ms)

    ✓ Can handle g_ (238ms)

    ✓ Can handle g_ with count prefix (44ms)

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key (45ms)

    ✓ Can handle <right> key (45ms)

    ✓ Can handle 'gk' (44ms)

    ✓ Can handle 'gj' (42ms)

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character
    word right

      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right
      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending
      ✓ next sentence when cursor is at the end of previous paragraph
      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ��� move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping
    whichwrap enabled
      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (49ms)

        ✓ <left> wraps to previous line (107ms)

        ✓ <right> wraps to next line (53ms)

      insert mode

        ✓ <left> wraps to previous line (44ms)

        ✓ <right> once goes to end of line (67ms)

        ✓ <right> twice wraps to next line (51ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (112ms)

        ✓ l does not wrap to next line (208ms)

        ✓ <left> does not wrap to previous line (136ms)

        ✓ <right> does not wrap to next line (169ms)

      insert mode

        ✓ <left> does not wrap to previous line (160ms)

        ✓ <right> does not wrap to next line (169ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (64ms)

      ✓ search wraps around the start of the file (221ms)

    wrapscan disabled

      ✓ search stops at the end of the file (185ms)

      ✓ search stops at the start of the file (90ms)

  Multicursor

    ✓ can add multiple cursors below (120ms)

    ✓ can add multiple cursors above (233ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

    ✓ gcc comments out current line (252ms)

    ✓ gcj comments in current and next line (209ms)

    ✓ block comment with motion (319ms)

    ✓ block comment in Visual Mode (237ms)

    ✓ comment in visual line mode (194ms)

    ✓ comment in visual block mode (238ms)

  format operator

    ✓ == formats current line (320ms)

    ✓ =$ formats entire line (392ms)

    ✓ =j formats two lines (211ms)

    ✓ 3=k formats three lines (196ms)

    ✓ =gg formats to top of file (105ms)

    ✓ =G formats to bottom of file (170ms)

    ✓ =ip formats paragraph (87ms)

    ✓ format in visual mode (125ms)

  put operator

    ✓ basic put test (74ms)

    ✓ test yy end of line (82ms)

    ✓ test yy first line (70ms)

    ✓ test yy middle line (218ms)

    ✓ test yy with correct positon movement (163ms)

    ✓ test visual block single line yank p (234ms)

    ✓ test visual block single line yank P (128ms)

    ✓ test visual block single line delete p (227ms)

    ✓ test visual block single line delete P (131ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (49ms)

    ✓ shift left goto end test (58ms)

    ✓ shift left goto line test (221ms)

    ✓ shift right goto end test (44ms)

    ✓ shift right goto line test (214ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (124ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (193ms)

      ✓ step to Camel word (156ms)

      ✓ step to CAP word (77ms)

      ✓ step after CAP word (199ms)

      ✓ step from middle of word to Camel word (167ms)

      ✓ step to number word (206ms)

      ✓ step to operator word (116ms)

      ✓ step from inside operator word (528ms)

      ✓ step to operator and then over (71ms)

    handles <leader>w for underscore_var

      ✓ step to _word (77ms)

      ✓ step over whitespace to word (211ms)

      ✓ step from inside word to _word (200ms)

      ✓ step form _word to number (89ms)

      ✓ step from nubmer word to _word (124ms)

      ✓ step from in whitespace to word (85ms)

      ✓ step in ALL_CAPS_WORD (80ms)

    handles d<leader>w

      ✓ delete from start of camelWord (96ms)

      ✓ delete from middle of camelWord (221ms)

      ✓ delete from start of CamelWord (145ms)

      ✓ delete two words from camelWord (200ms)

      ✓ delete from start of underscore_word (151ms)

      ✓ delete from middle of underscore_word (118ms)

      ✓ delete two words from camel_word (190ms)

    handles di<leader>w

      ✓ delete from start of camelWord (102ms)

      ✓ delete from middle of camelWord (210ms)

      ✓ delete from start of CamelWord (104ms)

      ✓ delete two words from camelWord (51ms)

      ✓ delete from start of underscore_word (165ms)

      ✓ delete from middle of underscore_word (177ms)

      ✓ delete two words from camel_word (95ms)

    handles <leader>b

      ✓ back from middle of word (209ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (208ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (66ms)

      ✓ from middle to end of underscore_word (55ms)

      ✓ twice to end of word over operator (177ms)

  easymotion plugin

    ✓ Can handle s move (84ms)

    ✓ Can handle 2s move (199ms)

    ✓ Can handle f move (92ms)

    ✓ Can handle 2f move (81ms)

    ✓ Can handle F move (229ms)

    ✓ Can handle 2F move (175ms)

    ✓ Can handle t move (80ms)

    ✓ Can handle bd-t move (82ms)

    ✓ Can handle 2t move (133ms)

    ✓ Can handle bd-t2 move (144ms)

    ✓ Can handle T move (322ms)

    ✓ Can handle 2T move (168ms)

    ✓ Can handle w move (216ms)

    ✓ Can handle bd-w move (172ms)

    ✓ Can handle b move (228ms)

    ✓ Can handle e move (133ms)

    ✓ Can handle bd-e move (208ms)

    ✓ Can handle ge move (106ms)

    ✓ Can handle n-char move (227ms)

    ✓ Can handle j move (178ms)

    ✓ Can handle k move (111ms)

    ✓ Can handle bd-jk move (1) (219ms)

    ✓ Can handle bd-jk move (2) (174ms)

    ✓ Can handle lineforward move (1) (124ms)

    ✓ Can handle lineforward move (2) (77ms)

    ✓ Can handle linebackward move (1) (119ms)

    ✓ Can handle linebackward move (2) (83ms)

    ✓ Can handle searching for backslash (\) (111ms)

    ✓ Can handle searching for carat (^) (153ms)

    ✓ Can handle searching for dot (.) (65ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (116ms)

    ✓ Replaces within inner Word (184ms)

    ✓ Replaces within '' (381ms)

    ✓ Replaces within '' including spaces (68ms)

    ✓ Replaces within () (220ms)

    ✓ Replaces within () including spaces (130ms)

    ✓ Replaces within a paragraph (108ms)

    ✓ Replaces using a specified register (158ms)

    ✓ Replaces within {} over multiple lines (107ms)

    ✓ Replaces a multiline register within {} over multiple lines (67ms)

    ✓ Replaces a multiline register within {} over multiple lines (115ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (206ms)

    ✓ grr replaces the entire line with the register (72ms)

    ✓ grr can replace multiple lines (83ms)

    ✓ Replaces in visual mode (235ms)

    ✓ Replaces in visual mode using a specified register (146ms)

    ✓ Replaces in visual line mode (325ms)

    ✓ grj is linewise (162ms)

  sneak plugin

    ✓ Can handle s motion (108ms)

    ✓ Can handle S motion (156ms)

    ✓ Can handle <operator>z motion (204ms)

    ✓ Can handle <operator>Z motion (144ms)

    ✓ Can handle s; motion (48ms)

    ✓ Can handle s, motion (210ms)

    ✓ Can handle S; motion (160ms)

    ✓ Can handle S, motion (98ms)

    ✓ Can handle single letter s motion (118ms)

    ✓ Can handle single letter S motion (192ms)

    ✓ Can handle single letter <operator>z motion (104ms)

    ✓ Can handle single letter <operator>Z motion (46ms)

    ✓ Can handle single letter s; motion (49ms)

    ✓ Can handle single letter s, motion (75ms)

    ✓ Can handle single letter S; motion (108ms)

    ✓ Can handle single letter S, motion (216ms)

    ✓ Can handle multiline single char <number>s motion (177ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (178ms)

    ✓ 'ysiw(' surrounds word with space (165ms)

    ✓ 'ysw)' surrounds word without space (118ms)

    ✓ 'ysw(' surrounds word with space (92ms)

    ✓ 'ysaw)' surrounds word without space (233ms)

    ✓ 'ysaw(' surrounds word with space (93ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (183ms)

    ✓ 'ysiw<' surrounds word with tags (84ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (89ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (168ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (151ms)

    ✓ change surround (148ms)

    ✓ change surround with two pairs of quotes (133ms)

    ✓ change surround with two pairs of parens (161ms)

    ✓ change surround with alias (193ms)

    ✓ change surround to tags (131ms)

    ✓ delete surround (87ms)

    ✓ delete surround with quotes (95ms)

    ✓ delete surround with nested of quotes (110ms)

    ✓ delete surround with inconsistent quotes (395ms)

    ✓ delete surround with mixed quotes (523ms)

    ✓ delete surround with empty quotes cursor at start (103ms)

    ✓ delete surround with empty quotes cursor at end (62ms)

    ✓ don't delete surround if cursor is after closing match (169ms)

    ✓ delete surround if cursor is before opening match (78ms)

    ✓ delete surround with two pairs of parens (182ms)

    ✓ delete surround with alias (113ms)

    ✓ delete surround with tags (177ms)

    ✓ change surround brackets at end of line (76ms)

    ✓ changing brackets with surround works again (93ms)

    ✓ change surround with tags that contain an attribute and preserve them (206ms)

    ✓ change surround with tags that contain an attribute and remove them (148ms)

  register

    ✓ Can copy to a register (180ms)

    ✓ Can use two registers together (88ms)

    ✓ Can use black hole register (185ms)

    ✓ System clipboard works with chinese characters (43ms)

    ✓ Yank stores text in Register '0' (230ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (201ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (189ms)

    ✓ Register '1'-'9' stores delete content (214ms)

    ✓ "A appends linewise text to "a (252ms)

    ✓ "A appends character wise text to "a (167ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (210ms)

    ✓ Small deletion using Del is stored in small delete register (150ms)

    ✓ Small deletion using X is stored in small delete register (200ms)

    ✓ Search register (/) is set by forward search (297ms)

    ✓ Search register (/) is set by backward search (269ms)

    ✓ Search register (/) is set by star search (232ms)

    ✓ Command register (:) is set by command line (74ms)

    ✓ Read-only registers cannot be written to (173ms)

    clipboard

      ✓ Can access '*' (clipboard) register (110ms)

      ✓ Can access '+' (clipboard) register (156ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (192ms)

    ✓ Can repeat reversed F<character> (213ms)

    ✓ Can repeat t<character> (66ms)

    ✓ Can repeat N times reversed t<character> (69ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (177ms)

      ✓ move one sentence backward (320ms)

      ✓ move [count] sentences backward (217ms)

      ✓ move one sentence backward single line - middle (105ms)

      ✓ move one sentence backward no space (151ms)

      ✓ move one sentence backward no space - middle (210ms)

      ✓ move one sentence backward - multiline (96ms)

      ✓ move one sentence backward - multiline - period (159ms)

      ✓ move one sentence backward - multiline - previous line (125ms)

      ✓ move one sentence backward - multiline - previous line - period (170ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath
      ✓ can separate drive letter path on Windows
      ✓ can separate UNC path on Windows
      ✓ can separate relative path on Windows
      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix

    resolveUri

      ✓ posix
      ✓ win32
  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=�������������.
      + expected - actual

      -�������������
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=a��.
      + expected - actual

      -a��
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=a��.
      + expected - actual

      -a��
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-11T07:33:17.964Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses
    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (39ms)

    ✓ command <C-w> can remove word in search mode (61ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (42ms)

    ✓ <C-u> deletes from cursor to first character (77ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (58ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (97ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (67ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (53ms)

  command-line lexer

    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot
    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus
    ✓ can lex minus
    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search
    ✓ can lex reverse search escaping
    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs
  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF
    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (552ms)

    ✓ :smile editor contains smile text (559ms)

  Basic sort

    ✓ Sort whole file, asc (224ms)

    ✓ Sort whole file, asc, ignoreCase (164ms)

    ✓ Sort whole file, dsc (246ms)

    ✓ Sort whole file, dsc, ignoreCase (150ms)

    ✓ Sort range, asc (193ms)

    ✓ Sort range, asc, ignoreCase (136ms)

    ✓ Sort range, dsc (214ms)

    ✓ Sort range, dsc, ignoreCase (179ms)

    ✓ Sort whole file, asc, unique (128ms)

  Horizontal split

    ✓ Run :sp (67ms)

    ✓ Run :split (75ms)

    ✓ Run :new (77ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (53ms)

    ✓ Replace with `g` flag (49ms)

    ✓ Replace with flags AND count (122ms)

    ✓ Replace with `c` flag (54ms)

    ✓ Replace with `gc` flag (91ms)

    ✓ Replace across all lines (101ms)

    ✓ Replace on specific single line (143ms)

    ✓ Replace on current line using dot (110ms)

    ✓ Replace single relative line using dot and plus (107ms)

    ✓ Replace across specific line range (135ms)

    ✓ Replace across relative line range using dot, plus, and minus (246ms)

    ✓ Replace across relative line range using numLines+colon shorthand (112ms)

    ✓ Repeat replacement across relative line range (115ms)

    ✓ Replace with range AND count but no flags (108ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (142ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (97ms)

    ✓ Undocumented: trailing operators use 1 as RHS (100ms)

    ✓ Replace specific single equal lines (124ms)

    ✓ Replace current line with no active selection (180ms)

    ✓ Replace text in selection (132ms)

    ✓ Substitute support marks (116ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (63ms)

      ✓ Replace with `g` flag inverts global flag (89ms)

      ✓ Replace with `c` flag inverts global flag (77ms)

      ✓ Replace multiple lines (102ms)

      ✓ Replace across specific lines (114ms)

      ✓ Replace current line with no active selection (102ms)

      ✓ Replace text in selection (114ms)

      ✓ Substitute support marks (132ms)

      ✓ Substitute with escaped delimiter (110ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (260ms)

      ✓ Substitute with previous search using # (230ms)

      ✓ Substitute with previous search using / (349ms)

      ✓ Substitute with parameters should update search state (135ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (268ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (235ms)

      ✓ Substitute repeat previous should accept flags (79ms)

      ✓ Substitute with empty search string should use last searched pattern (366ms)

      ✓ Ampersand (&) should repeat the last substitution (216ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (78ms)

    ✓ tabe with current file path does nothing (58ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (51ms)

    ✓ command line file tab completion with space in file path (100ms)

  Vertical split

    ✓ Run :vs (71ms)

    ✓ Run :vsp (67ms)

    ✓ Run :vsplit (66ms)

    ✓ Run :vnew (202ms)

    ✓ Run :vne (242ms)

  Basic write-quit

    ✓ Run write and quit (77ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (66ms)

      ✓ Can complete lines in file with different indentation (69ms)

      ✓ Returns no completions for unmatched line (47ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (42ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (89ms)

    ✓ getMatchingRemap (94ms)

    ✓ jj -> <Esc> through modehandler (122ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (119ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (84ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (146ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (155ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (158ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (155ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (174ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error
    ✓ error code has message
  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (124ms)

        ✓ Can track jumps for keys: GggG (229ms)

        ✓ Can track jumps for keys: GggGgg (110ms)

        ✓ Can track jumps for keys: /b<CR>n (210ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (67ms)

        ✓ Can track jumps for keys: j%% (60ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (151ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (236ms)

        ✓ Can track jumps for keys: j%%<C-o>% (189ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (194ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (181ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (241ms)

        ✓ Can enter number to jump back multiple times (170ms)

[main 2019-12-11T07:33:47.968Z] update#setState checking for updates

[main 2019-12-11T07:33:48.023Z] update#setState idle

        ✓ Can track one-line `` jumps (93ms)

        ✓ Can track one-line double `` jumps (257ms)

        ✓ Can track one-line '' jumps (365ms)

        ✓ Can track one-line double '' jumps (259ms)

        ✓ Can handle '' jumps with no previous jump (112ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (266ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (182ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (275ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (171ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (120ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (334ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (176ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (217ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (300ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (97ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (250ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (179ms)

  Record and execute a macro

    ✓ Can record and execute (306ms)

    ✓ Can repeat last invoked macro (220ms)

    ✓ Can play back with count (523ms)

    ✓ Can play back with count, abort when a motion fails (522ms)

    ✓ Repeat change on contiguous lines (240ms)

    ✓ Append command to a macro (214ms)

    ✓ Can record Ctrl Keys and repeat (164ms)

    ✓ Can execute macros with dot commands properly (282ms)

    ✓ : (command) register can be used as a macro (142ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode (64ms)

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (98ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (54ms)

    ✓ <C-c> can exit insert (70ms)

    ✓ <Esc> can exit insert (63ms)

    ✓ Stay in insert when entering characters (68ms)

    ✓ Can handle 'O' (49ms)

    ✓ Can handle 'i' (111ms)

    ✓ Can handle 'I' (130ms)

    ✓ Can handle 'a' (125ms)

    ✓ Can handle 'A' (66ms)

    ✓ Can handle '<C-w>' (66ms)

    ✓ Can handle <C-w> on leading whitespace (59ms)

    ✓ Can handle <C-w> at beginning of line (75ms)

    ✓ Can handle <C-u> (65ms)

    ✓ Can handle <C-u> on leading characters (76ms)

    ✓ Can handle <C-u> on leading whitespace (191ms)

    ✓ Correctly places the cursor after deleting the previous line break (193ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (47ms)

    ✓ Backspace works on whitespace only lines (81ms)

    ✓ Backspace works on end of whitespace only lines (80ms)

    ✓ Backspace works at beginning of file (127ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (127ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (85ms)

    ✓ Can perform insert command prefixed with count (97ms)

    ✓ Can perform append command prefixed with count (95ms)

    ✓ Can perform insert at start of line command prefixed with count (130ms)

    ✓ Can perform append to end of line command prefixed with count (92ms)

    ✓ Can perform change char (s) command prefixed with count (104ms)

    ✓ Can perform command prefixed with count with <C-[> (148ms)

    ✓ Can handle 'o' with count (133ms)

    ✓ Can handle 'O' with count (122ms)

    ✓ Can handle backspace at beginning of line with all spaces (109ms)

    ✓ Can handle digraph insert (102ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (101ms)

    ✓ Can handle dw (124ms)

    ✓ Can handle dw (115ms)

    ✓ Can handle dw across lines (1) (181ms)

    ✓ Can handle dw across lines (2) (93ms)

    ✓ Can handle dd last line (63ms)

    ✓ Can handle dd single line (57ms)

    ✓ Can handle dd (68ms)

    ✓ Can handle 3dd (56ms)

    ✓ Can handle 3dd off end of document (196ms)

    ✓ Can handle d2d (67ms)

    ✓ Can handle dd empty line (63ms)

    ✓ Can handle ddp (70ms)

    ✓ Can handle 'de' (69ms)

    ✓ Can handle 'de' then 'de' again (117ms)

    ✓ Can handle 'db' (103ms)

    ✓ Can handle 'db then 'db' again (229ms)

    ✓ Can handle 'dl' at end of line (91ms)

    ✓ Can handle 'dF' (88ms)

    ✓ Can handle 'dT' (101ms)

    ✓ Can handle 'd3' then <enter> (102ms)

    ✓ Can handle 'dj' (143ms)

    ✓ Can handle 'dk' (75ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (123ms)

    ✓ Can handle 'd]}' without deleting closing bracket (96ms)

    ✓ Can handle 'cw' (199ms)

    ✓ Can handle 'cw' without deleting following white spaces (49ms)

    ✓ Can handle 'c2w' (70ms)

    ✓ Can handle 'cw' without removing EOL (146ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (97ms)

    ✓ Can handle 'c]}' without deleting closing bracket (136ms)

    ✓ Can handle 's' (140ms)

    ✓ Can handle 'yiw' with correct cursor ending position (128ms)

    ✓ Can handle 'ciw' (162ms)

    ✓ Can handle 'ciw' on blanks (251ms)

    ✓ Can handle 'caw' (116ms)

    ✓ Can handle 'caw' on first letter (124ms)

    ✓ Can handle 'caw' on blanks (153ms)

    ✓ Can handle 'caw' on blanks (134ms)

    ✓ Can handle 'ci(' on first parentheses (78ms)

    ✓ Can handle 'ci(' with nested parentheses (79ms)

    ✓ Can handle 'ci(' backwards through nested parens (82ms)

    ✓ Can handle 'cib' on first parentheses (82ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (162ms)

    ✓ Can handle count prefixed 'ci)' (111ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (157ms)

    ✓ Can handle 'cab' spanning multiple lines (88ms)

    ✓ Can handle 'ci{' spanning multiple lines (73ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (110ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (68ms)

    ✓ Can handle 'ci(' on the closing bracket (188ms)

    ✓ Can handle 'ciB' spanning multiple lines (76ms)

    ✓ will fail when ca( with no () (40ms)

    ✓ will fail when ca{ with no {} (144ms)

    ✓ will fail when caB with no {} (83ms)

    ✓ Can handle 'ci[' spanning multiple lines (55ms)

    ✓ Can handle 'ci]' on first bracket (72ms)

    ✓ Can handle 'ca[' on first bracket (237ms)

    ✓ Can handle 'ca]' on first bracket (103ms)

    ✓ Can handle 'ci'' on first quote (106ms)

    ✓ Can handle 'ci'' inside quoted string (134ms)

    ✓ Can handle 'ci'' on closing quote (81ms)

    ✓ Can handle 'ci'' when string is ahead (91ms)

    ✓ Can handle 'ci"' on opening quote (82ms)

    ✓ Can handle 'ci"' starting behind the quoted word (41ms)

    ✓ Can handle 'ca"' starting behind the quoted word (107ms)

    ✓ Can handle 'ca"' starting on the opening quote (122ms)

    ✓ Can handle 'ci"' with escaped quotes (90ms)

    ✓ Can handle 'ci"' with a single escaped quote

    ✓ Can handle 'ci"' with a single escaped quote behind (83ms)

    ✓ Can handle 'ci"' with an escaped backslash (150ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (125ms)

    ✓ Can handle 'ca"' starting on the closing quote (97ms)

    ✓ Can handle 'ci"' with complex escape sequences (80ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (59ms)

    ✓ will fail when ca" ahead of quoted string (73ms)

    ✓ Can handle 'ca`' inside word (59ms)

    ✓ can handle cj (148ms)

    ✓ can handle ck (223ms)

    ✓ can handle c2j (136ms)

    ✓ can handle c2k (209ms)

    ✓ can handle cj on last line (180ms)

    ✓ can handle ck on first line (184ms)

    ✓ can handle c2j on last line (131ms)

    ✓ can handle c2k on first line (146ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (135ms)

    ✓ Can handle 'daw' on word with trailing spaces (83ms)

    ✓ Can handle 'daw' on word with leading spaces (104ms)

    ✓ Can handle 'daw' on word with numeric prefix (99ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (208ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (104ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (269ms)

    ✓ Can handle 'daw' on end of word (145ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (90ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (77ms)

    ✓ Can handle 'daw' on word at beginning of file (126ms)

    ✓ Can handle 'daw' on word at beginning of line (159ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (69ms)

    ✓ Can handle 'daw' around word at end of line (82ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (110ms)

    ✓ Can handle 'daW' around word at whitespace (78ms)

    ✓ Can handle 'daW' on word with trailing spaces (69ms)

    ✓ Can handle 'daW' on word with leading spaces (124ms)

    ✓ Can handle 'daW' on word with numeric prefix (107ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (142ms)

    ✓ Can handle 'daW' on beginning of word (176ms)

    ✓ Can handle 'daW' on end of one line (70ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (76ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (60ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (126ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (88ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (75ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (66ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (88ms)

    ✓ Can handle 'diw' on word (63ms)

    ✓ Can handle 'diw' on word with numeric prefix (68ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (135ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (140ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (151ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (72ms)

    ✓ Can handle 'diW' on word with trailing spaces (112ms)

    ✓ Can handle 'diW' on word with leading spaces (188ms)

    ✓ Can handle 'diW' on word with numeric prefix (204ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (150ms)

    ✓ Can handle 'diW' on beginning of word (162ms)

    ✓ Can handle d} (215ms)

    ✓ Can handle y} at beginning of line (166ms)

    ✓ Select sentence with trailing spaces (216ms)

    ✓ Select sentence with leading spaces (159ms)

    ✓ Select inner sentence with trailing spaces (213ms)

    ✓ Select inner sentence with leading spaces (187ms)

    ✓ Select spaces between sentences (176ms)

    ✓ Can handle 'df' (227ms)

    ✓ Can handle 'dt' (74ms)

    ✓ Can handle backspace (211ms)

    ✓ Can handle backspace across lines (184ms)

    ✓ Can handle A and backspace (205ms)

    ✓ Can handle 'yy' without changing cursor position (135ms)

    ✓ Can handle 'P' after 'yy' (186ms)

    ✓ Can handle 'p' after 'yy' (181ms)

    ✓ Can handle 'P' after 'Nyy' (181ms)

    ✓ Can handle 'p' after 'Nyy' (69ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (64ms)

    ✓ Can handle 'gp' after 'yy' (214ms)

    ✓ Can handle 'gp' after 'Nyy' (168ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (230ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (70ms)

    ✓ Can handle 'gP' after 'yy' (227ms)

    ✓ Can handle 'gP' after 'Nyy' (156ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (227ms)

    ✓ Can handle ']p' after yy (52ms)

    ✓ Can handle ']p' after 'Nyy' (91ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (101ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (154ms)

    ✓ Can handle '[p' after yy (166ms)

    ✓ Can handle '[p' after 'Nyy' (232ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (154ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (247ms)

    ✓ Can handle 'p' after y'a (174ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (99ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (221ms)

    ✓ Can handle pasting in visual mode over selection (291ms)

    ✓ Can repeat w (94ms)

    ✓ Can repeat p (224ms)

    ✓ I works correctly (200ms)

    ✓ gI works correctly (223ms)

    ✓ gi works correctly (240ms)

    ✓ `. works correctly (204ms)

    ✓ '. works correctly (218ms)

    ✓ g; works correctly (248ms)

    ✓ g, works correctly (260ms)

    ✓ g_ works correctly (140ms)

    ✓ 3g_ works correctly (216ms)

    ✓ gq handles spaces after single line comments correctly (378ms)

    ✓ gq handles spaces before single line comments correctly (390ms)

    ✓ gq handles tabs before single line comments correctly (367ms)

    ✓ Can handle space (44ms)

    ✓ Can handle space (67ms)

    ✓ Undo 1 (124ms)

    ✓ Undo 2 (266ms)

    ✓ Undo cursor (173ms)

    ✓ Undo cursor 2 (275ms)

    ✓ Undo cursor 3 (126ms)

    ✓ Undo with movement first (281ms)

    ✓ Can handle 'U' (89ms)

    ✓ Can handle 'U' for multiple changes (103ms)

    ✓ Can handle 'U' for new line below (101ms)

    ✓ Can handle 'U' for new line above (284ms)

    ✓ Can handle 'U' for consecutive changes only (439ms)

    ✓ Can handle 'u' to undo 'U' (387ms)

    ✓ Can handle 'U' to undo 'U' (267ms)

    ✓ Redo (297ms)

    ✓ Redo (155ms)

    ✓ Redo (196ms)

    ✓ Can handle u (192ms)

    ✓ Can handle guw (148ms)

    ✓ Can handle gUw (221ms)

    ✓ Can handle u over line breaks (153ms)

    ✓ can handle s in visual mode (117ms)

    ✓ can handle p with selection (250ms)

    ✓ can handle P with selection (188ms)

    ✓ can handle p in visual to end of line (239ms)

    ✓ can repeat backspace twice (186ms)

    ✓ can delete linewise with d2G (213ms)

    ✓ can delete with + motion and count (148ms)

    ✓ can delete with - motion and count (86ms)

    ✓ can dE correctly (215ms)

    ✓ can dE correctly (126ms)

    ✓ can dE correctly (207ms)

    ✓ can ctrl-a correctly behind a word (154ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (216ms)

    ✓ can ctrl-a on word (138ms)

    ✓ can ctrl-a on a hex number (142ms)

    ✓ can ctrl-a on decimal (213ms)

    ✓ can ctrl-a with numeric prefix (205ms)

    ✓ can ctrl-a on a decimal (185ms)

    ✓ can ctrl-a on an octal  (168ms)

    ✓ Correctly increments in the middle of a number (213ms)

    ✓ can ctrl-x correctly behind a word

    ✓ can ctrl-a on an number with word before  (91ms)

    ✓ can ctrl-a on an number with word before and after  (106ms)

    ✓ can ctrl-x on a negative number with word before and after  (238ms)

    ✓ can ctrl-a properly on multiple lines (121ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (202ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (212ms)

    ✓ can <C-a> on word with - in front of it (115ms)

    ✓ can do Y (77ms)

    ✓ Can do S (71ms)

    ✓ / does not affect mark (220ms)

    ✓ / can search with regex (184ms)

    ✓ / can search with newline (177ms)

    ✓ / can search through multiple newlines (247ms)

    ✓ / matches ^ per line (186ms)

    ✓ / matches $ per line (107ms)

    ✓ Can search for forward slash (226ms)

    ✓ Can search backward for question mark (84ms)

    ✓ /\c forces case insensitive search (45ms)

    ✓ /\C forces case sensitive search (127ms)

    ✓ <BS> deletes the last character in search in progress mode (242ms)

    ✓ <S-BS> deletes the last character in search in progress mode (191ms)

    ✓ <C-h> deletes the last character in search in progress mode (183ms)

    ✓ Can do C (40ms)

    ✓ Can do cit on a matching tag (93ms)

    ✓ Ignores cit on a non-matching tag (215ms)

    ✓ Ignores cit on a nested tag (192ms)

    ✓ Can do cit on a tag with an attribute tag (214ms)

    ✓ Can do cat on a matching tag (149ms)

    ✓ Can do cit on a multiline tag (206ms)

    ✓ Can do cit on a multiline tag with nested tags (135ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (117ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (175ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (151ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (216ms)

    ✓ can do cit with self closing tags (312ms)

    ✓ Respects indentation with cc (206ms)

    ✓ Resets cursor to indent end with cc (65ms)

    ✓ can handle 'cc' on empty line (42ms)

    ✓ cc copies linewise (214ms)

    ✓ Indent current line with correct Vim Mode (150ms)

    ✓ Can handle <Esc> and do nothing (206ms)

    ✓ Can handle # on consecutive words (203ms)

    ✓ Can handle # on skipped words (218ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (141ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (271ms)

    ✓ cc on whitespace-only treats whitespace as indent (145ms)

    ✓ Can do cai (218ms)

    ✓ Can do cii (87ms)

    ✓ Can do caI (207ms)

    ✓ Can do dai (102ms)

    ✓ Can do dii (81ms)

    ✓ Can do daI (210ms)

    ✓ `] go to the end of the previously operated or put text (97ms)

    ✓ '] go to the end of the previously operated or put text (275ms)

    ✓ `[ go to the start of the previously operated or put text (140ms)

    ✓ '[ go to the start of the previously operated or put text (270ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (97ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (245ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (205ms)

    can handle gn

      ✓ gn selects the next match text (252ms)

      ✓ gn selects the current word at |hello (286ms)

      ✓ gn selects the current word at h|ello (449ms)

      ✓ gn selects the current word at hel|lo (262ms)

      ✓ gn selects the current word at hell|o (225ms)

      ✓ gn selects the next word at hello| (249ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (73ms)

      ✓ dgn deletes the current word when cursor is at |hello (248ms)

      ✓ dgn deletes the current word when cursor is at h|ello (69ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (215ms)

      ✓ dgn deletes the current word when cursor is at hell|o (180ms)

      ✓ dgn deletes the next word when cursor is at hello| (190ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (204ms)

      ✓ cgn deletes the current word when cursor is at |hello (188ms)

      ✓ cgn deletes the current word when cursor is at h|ello (239ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (182ms)

      ✓ cgn deletes the current word when cursor is at hell|o (72ms)

      ✓ cgn deletes the next word when cursor is at hello| (258ms)

    can handle gN

      ✓ gN selects the previous match text (238ms)

      ✓ gN selects the current word at hell|o (345ms)

      ✓ gN selects the current word at hel|lo (370ms)

      ✓ gN selects the current word at h|ello (238ms)

      ✓ gN selects the current word at |hello (253ms)

      ✓ gN selects the previous word at | hello (260ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (82ms)

      ✓ dgN deletes the current word when cursor is at hell|o (248ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (302ms)

      ✓ dgN deletes the current word when cursor is at h|ello (192ms)

      ✓ dgN deletes the current word when cursor is at |hello (174ms)

      ✓ dgN deletes the previous word when cursor is at | hello (223ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (331ms)

      ✓ cgN deletes the current word when cursor is at hell|o (159ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (236ms)

      ✓ cgN deletes the current word when cursor is at h|ello (186ms)

      ✓ cgN deletes the current word when cursor is at |hello (206ms)

      ✓ cgN deletes the previous word when cursor is at | hello (154ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (156ms)

    ✓ Can activate with R from Normal mode (132ms)

    ✓ Can handle R (125ms)

    ✓ Can handle R past current line (221ms)

    ✓ Can handle R and exit Replace Mode (112ms)

    ✓ Can handle R across lines (264ms)

    ✓ Can handle R across lines and exit Replace Mode (118ms)

    ✓ Can handle R with {count} (266ms)

    ✓ Can handle backspace (147ms)

    ✓ Can handle backspace (248ms)

    ✓ Can handle backspace across lines (169ms)

    ✓ Can handle arrows (112ms)

    ✓ Can handle . (291ms)

    ✓ Can handle . across lines (215ms)

  Mode Visual

    ✓ can be activated (167ms)

    ✓ Can handle w (172ms)

    ✓ Can handle wd (126ms)

    ✓ Can handle x (138ms)

    ✓ Can handle x across a selection (148ms)

    ✓ Can do vwd in middle of sentence (195ms)

    ✓ Can do vwd in middle of sentence (143ms)

    ✓ Can do vwd multiple times (196ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (179ms)

    ✓ Can handle H key (203ms)

    ✓ Can handle backspace key (179ms)

    ✓ handles case where we delete over a newline (165ms)

    ✓ handles change operator (167ms)

    ✓ Can do vat on multiple matching tags (228ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (271ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (131ms)

    ✓ Repeat-prefixed vat does not bleed below (233ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (96ms)

    ✓ Can do vi) on a matching parenthesis (254ms)

    ✓ Can do vi) on multiple matching parens (162ms)

    ✓ Can do va) on a matching parenthesis (211ms)

    ✓ Can do va) on multiple matching parens (186ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (122ms)

    ✓ Repeat-prefixed va) does not bleed below (229ms)

    ✓ Can do va} on a matching bracket as first character (64ms)

    ✓ Can do va} on multiple matching brackets (122ms)

    ✓ Can do vi( on a matching bracket near first character (256ms)

    ✓ Can do vi{ on outer pair of nested braces (97ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (80ms)

    ✓ Can do va] on multiple matching brackets (242ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (166ms)

    ✓ Repeat-prefixed vaf does not bleed below (221ms)

    ✓ vaf only expands to enclosing pairs (72ms)

    ✓ Can use . to repeat indent in visual (243ms)

    ✓ Can do v_x to delete to first char (150ms)

    ✓ Can do vg_x to delete to last char with no EOL (145ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (154ms)

    ✓ Can do v$x to delete to last char including EOL (91ms)

    ✓ Can do gv to reselect previous selection (270ms)

    Vim's EOL handling is weird

      ✓ delete through eol (116ms)

      ✓ join 2 lines by deleting through eol (146ms)

      ✓ d$ doesn't delete whole line (79ms)

      ✓ vd$ does delete whole line (115ms)

      ✓ Paste over selection copies the selection (248ms)

      ✓ Paste over selection copies the selection linewise (171ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (231ms)

      ✓ Can handle <down> key (55ms)

      ✓ Can handle <left> key (70ms)

      ✓ Can handle <right> key (229ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (111ms)

      ✓ Can handle 'gj' (111ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (227ms)

      ✓ Can handle 'vawd' on word with trailing spaces (156ms)

      ✓ Can handle 'vawd' on word with leading spaces (119ms)

      ✓ Can handle 'vawd' on word with numeric prefix (149ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (212ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (414ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (144ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (143ms)

      ✓ Can handle 'vaWd' on word with leading spaces (150ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (133ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (247ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (150ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (173ms)

      ✓ Can handle 'vaWd' on word with leading spaces (179ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (190ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (134ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (182ms)

      ✓ Can handle 'vawd' on word with trailing spaces (241ms)

      ✓ Can handle 'vawd' on word with leading spaces (156ms)

      ✓ Can handle 'vawd' on word with numeric prefix (162ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (162ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (139ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (211ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (77ms)

      ✓ Can handle 'vaWd' on word with leading spaces (135ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (73ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (149ms)

      ✓ Can handle 'Y' in visual mode (131ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (216ms)

      ✓ Select sentence with leading spaces in visual mode (229ms)

      ✓ Select multiple sentences in visual mode (224ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (139ms)

      ✓ Select inner sentence with leading spaces in visual mode (127ms)

      ✓ Select spaces between sentences in visual mode (166ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (111ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (150ms)

      ✓ Can do vat on a matching tag (219ms)

    handles replace in visual mode

      ✓ Can do a single line replace (125ms)

      ✓ Can do a multi line replace (190ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (98ms)

      ✓ D deletes the current line (121ms)

    handles indent blocks in visual mode

      ✓ Can do vai (233ms)

      ✓ Can do vii (122ms)

      ✓ Doesn't naively select the next line (74ms)

      ✓ Searches backwards if cursor line is empty (224ms)

      ✓ Can do vaI (148ms)

    visualstar

      ✓ Works with * (91ms)

      ✓ Works with # (69ms)

    search works in visual mode

      ✓ Works with / (64ms)

      ✓ Works with ? (76ms)

      ✓ Selects correct range (394ms)

    X will delete linewise

      ✓ normal selection (62ms)

      ✓ normal selection (77ms)

    C will delete linewise

      ✓ normal selection (67ms)

      ✓ normal selection (76ms)

    R will delete linewise

      ✓ normal selection (196ms)

      ✓ normal selection (160ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (172ms)

      ✓ upward selection (98ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (70ms)

      ✓ multiline indent bottom up selection (85ms)

      ✓ repeat multiline indent top down selection (83ms)

      ✓ repeat multiline indent bottom up selection (136ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (105ms)

      ✓ multiline outdent bottom up selection (107ms)

      ✓ repeat multiline outdent top down selection (225ms)

      ✓ repeat multiline outdent bottom up selection (153ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (156ms)

    vi{ will go to end of second to last line

      ✓ select (264ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (475ms)

      ✓ gv selects the last pasted text (which is longer than original) (569ms)

      ✓ gv selects the last pasted text (multiline) (211ms)

    can handle gn

      ✓ gn selects the next match text (229ms)

      ✓ gn selects the current word at |hello (239ms)

      ✓ gn selects the current word at h|ello (210ms)

      ✓ gn selects the current word at hel|lo (271ms)

      ✓ gn selects the next word at hell|o (257ms)

      ✓ gn selects the next word at hello| (249ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (143ms)

      ✓ multiline insert from top down selection (167ms)

      ✓ skips blank lines (225ms)

    can append text with A

      ✓ multiline append from bottom up selection (155ms)

      ✓ multiline append from top down selection (62ms)

      ✓ skips blank lines (219ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (231ms)

      ✓ U/gU across a selection (197ms)

      ✓ U/gU across a selection (reverse) (165ms)

      ✓ u/gu on single character (88ms)

      ✓ u/gu across a selection (276ms)

      ✓ u/gu across a selection (reverse) (228ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (437ms)

    ✓ Can handle A backwards select (267ms)

    ✓ Can handle I forward select (151ms)

    ✓ Can handle I backwards select (182ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (120ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (237ms)

    ✓ Can handle c forward select (169ms)

    ✓ Can handle c backwards select (121ms)

    ✓ Can handle C (248ms)

    ✓ Can do a multi line replace (98ms)

    ✓ Can handle 'D' (88ms)

    ✓ Can handle 'gj' (162ms)

    ✓ Properly add to end of lines j then $ (175ms)

    ✓ Properly add to end of lines $ then j (136ms)

    ✓ o works in visual block mode (108ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (175ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (160ms)

    ✓ Can handle wd (143ms)

    ✓ Can handle x (140ms)

    ✓ Can handle x across a selection (113ms)

    ✓ Can do vwd in middle of sentence (149ms)

    ✓ Can do vwd in middle of sentence (143ms)

    ✓ Can do vwd multiple times (185ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (132ms)

    ✓ handles case where we delete over a newline (268ms)

    ✓ handles change operator (121ms)

    ✓ Vp updates register content (218ms)

    ✓ Vp does not append unnecessary newlines (first line) (133ms)

    ✓ Vp does not append unnecessary newlines (middle line) (114ms)

    ✓ Vp does not append unnecessary newlines (last line) (146ms)

    Vim's EOL handling is weird

      ✓ delete through eol (81ms)

      ✓ join 2 lines by deleting through eol (98ms)

      ✓ d$ doesn't delete whole line (87ms)

      ✓ vd$ does delete whole line (109ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (69ms)

      ✓ Can handle <down> key (78ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (111ms)

      ✓ Can handle 'gj' (107ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (178ms)

      ✓ Can handle d key (197ms)

      ✓ Can handle d key (72ms)

      ✓ Can handle d key (60ms)

      ✓ can handle 'c' (53ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (63ms)

      ✓ Can do a multi visual line replace (227ms)

      ✓ Can do a multi visual line replace from the bottom up (147ms)

    search works in visual line mode

      ✓ Works with / (247ms)

      ✓ Works with ? (278ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (173ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (135ms)

      ✓ linewise visual put works also in the end of document (116ms)

      ✓ gv selects the last pasted text (which is shorter than original) (421ms)

      ✓ gv selects the last pasted text (which is longer than original) (369ms)

      ✓ gv selects the last pasted text (multiline) (178ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (155ms)

      ✓ multiline insert from top down selection (217ms)

      ✓ skips blank lines (160ms)

    can append text with A

      ✓ multiline append from bottom up selection (186ms)

      ✓ multiline append from top down selection (163ms)

      ✓ skips blank lines (209ms)

  Mode Normal

    ✓ Can handle 'x' (127ms)

    ✓ Can handle 'Nx' (201ms)

    ✓ Can handle 'Nx' and paste (66ms)

    ✓ Can handle 'x' at end of line (232ms)

    ✓ Can handle 'Ns' (179ms)

    ✓ Can handle 'Ns' at end of line (211ms)

    ✓ Can handle '<Del>' (147ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (167ms)

    ✓ Can handle '<Del>' at end of line (144ms)

    ✓ Can handle 'cc' (169ms)

    ✓ Can handle 'Ncc' (155ms)

    ✓ Can handle 'yy' (93ms)

    ✓ Can handle 'D' (152ms)

    ✓ Can handle 'D' on empty lines (176ms)

    ✓ Can handle 'DD' (136ms)

    ✓ Can handle 'C' (85ms)

    ✓ Can handle 'NC' (224ms)

    ✓ Can handle 'NC' and put (448ms)

    ✓ Can handle 'r' (140ms)

    ✓ Can handle '<Count>r' (217ms)

    ✓ Can handle '<Count>r' (107ms)

    ✓ Can handle 'r' after 'dd' (103ms)

    ✓ Can handle 'r
' (203ms)

    ✓ Can handle '<Count>r
' (73ms)

    ✓ Can handle 'J' once (51ms)

    ✓ Can handle 'J' twice (133ms)

    ✓ Can handle 'J' with empty last line (85ms)

    ✓ Can handle 'J's with multiple empty last lines (265ms)

    ✓ Can handle 'J' with leading white space on next line (38ms)

    ✓ Can handle 'J' with only white space on next line (47ms)

    ✓ Can handle 'J' with TWO indented lines (57ms)

    ✓ Can handle 'J' with ')' first character on next line (70ms)

    ✓ Can handle 'J' with a following delete (45ms)

    ✓ Can handle 'J' in Visual Line mode (338ms)

    ✓ Can handle 'gJ' once (177ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (152ms)

    ✓ Can handle '~' (86ms)

    ✓ Can handle 'g~{motion}' (110ms)

    ✓ Can handle '<BS>' in insert mode (127ms)

    ✓ Can handle undo with P (242ms)

    ✓ Can handle 'ge' in multiple lines case1 (100ms)

    ✓ Can handle 'ge' in multiple lines case2 (105ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (189ms)

    ✓ Can repeat '~' with dot (113ms)

    ✓ Can repeat 'x' (158ms)

    ✓ Can repeat 'J' (45ms)

    ✓ Can handle dot with A (101ms)

    ✓ Can handle dot with I (264ms)

    ✓ Can repeat actions that require selections (251ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (157ms)

    ✓ Can repeat insert change and '<C-t>' (249ms)

    ✓ Can repeat change by `<C-a>` (154ms)

    ✓ Only one arrow key can be repeated in Insert Mode (117ms)

    ✓ Cached content change will be cleared by arrow keys (243ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (76ms)

    ✓ inside parenthesis (102ms)

    ✓ nested parenthesis beginning (47ms)

    ✓ nested parenthesis end (85ms)

    ✓ nested bracket and parenthesis beginning (112ms)

    ✓ nested bracket, parenthesis, braces beginning (191ms)

    ✓ nested bracket, parenthesis, braces end (72ms)

    ✓ parentheses after > (143ms)

    ✓ parentheses after " (212ms)

  Motions in Normal Mode

    ✓ Can handle [( (141ms)

    ✓ Can handle nested [( (201ms)

    ✓ Can handle <number>[( (409ms)

    ✓ Can handle [( and character under cursor exclusive (106ms)

    ✓ Can handle ]) (213ms)

    ✓ Can handle nested ]) (85ms)

    ✓ Can handle <number>]) (202ms)

    ✓ Can handle ]) and character under cursor exclusive (176ms)

    ✓ Can handle [{ (197ms)

    ✓ Can handle nested [{ (169ms)

    ✓ Can handle <number>[{ (52ms)

    ✓ Can handle [{ and character under cursor exclusive (53ms)

    ✓ Can handle ]} (46ms)

    ✓ Can handle nested ]} (47ms)

    ✓ Can handle <number>]} (44ms)

    ✓ Can handle ]} and character under cursor exclusive (51ms)

    ✓ Can handle 'ge' (227ms)

    ✓ Can handle 'gg' (146ms)

    ✓ Can handle 'gg' to first non blank char on random line (286ms)

    ✓ Can handle 'gg' to first non blank char on first line (174ms)

    ✓ 'gg' obeys startofline (213ms)

    ✓ Retain same column when moving up/down (165ms)

    ✓ Can handle <enter> (70ms)

    ✓ $ always keeps cursor on EOL (188ms)

    ✓ Can handle $ with a count (143ms)

    ✓ Can handle $ with a count at end of file (207ms)

    ✓ Can handle <End> with a count (46ms)

    ✓ Can handle <D-right> with a count (55ms)

    ✓ Can handle 'f' (68ms)

    ✓ Can handle 'f' twice (144ms)

    ✓ Can handle 'f' with <tab> (190ms)

    ✓ Can handle 'f' and find back search (161ms)

    ✓ Can handle 'F' (209ms)

    ✓ Can handle 'F' twice (139ms)

    ✓ Can handle 'F' and find back search (157ms)

    ✓ Can handle 'f' and multiple back searches (150ms)

    ✓ Can handle 't' (203ms)

    ✓ Can handle 't' twice (204ms)

    ✓ Can handle 't' and find back search (66ms)

    ✓ Can handle 'T' (106ms)

    ✓ Can handle 'T' twice (64ms)

    ✓ Can handle 'T' and find back search (319ms)

    ✓ Can run a forward search (188ms)

    ✓ Can run a forward and find next search (50ms)

    ✓ Can run a forward and find previous search from end of word (52ms)

    ✓ Can run a reverse search (63ms)

    ✓ Can run a reverse and find next search (102ms)

    ✓ cancelled search reverts to previous search state (159ms)

    ✓ Backspace on empty search cancels (194ms)

    ✓ Search offsets: b does nothing (74ms)

    ✓ Search offsets: b2 goes 2 to the right (243ms)

    ✓ Search offsets: b+3 goes 3 to the right (195ms)

    ✓ Search offsets: e goes to the end (131ms)

    ✓ Search offsets: character offset goes across line boundaries (141ms)

    ✓ Search offsets: 2 goes 2 down (110ms)

    ✓ Search offsets: -2 goes 2 up (144ms)

    ✓ maintains column position correctly (213ms)

    ✓ maintains column position correctly with $ (86ms)

    ✓ Can handle G  (203ms)

    ✓ Can handle G with number prefix (170ms)

    ✓ Can handle G with number prefix (141ms)

    ✓ Can handle gg (54ms)

    ✓ Can handle gg with number prefix

    ✓ Can handle 0 (65ms)

    ✓ Can handle 0 as part of a repeat

    ✓ Can handle g*

    ✓ Can handle g*n (79ms)

    ✓ Can handle * (223ms)

    ✓ Can handle ** (163ms)

    ✓ Can handle # on whitespace (67ms)

    ✓ Can handle # on EOL (60ms)

    ✓ Can handle g# (103ms)

    ✓ Can handle g#n (91ms)

    ✓ Can handle # (131ms)

    ✓ Can handle # already on the word (52ms)

    ✓ Can handle ## (99ms)

    ✓ * adds to search history (63ms)

    ✓ # adds to search history (143ms)

    ✓ Can handle | (82ms)

    ✓ Can handle <number> | (79ms)

    ✓ Can handle + (201ms)

    ✓ Can handle + indent (117ms)

    ✓ Can handle + with count prefix (212ms)

    ✓ Can handle - (51ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _ (45ms)

    ✓ Can handle _ with count prefix (48ms)

    ✓ Can handle g_ (238ms)

    ✓ Can handle g_ with count prefix (44ms)

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key (45ms)

    ✓ Can handle <right> key (45ms)

    ✓ Can handle 'gk' (44ms)

    ✓ Can handle 'gj' (42ms)

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character
    word right

      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right
      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending
      ✓ next sentence when cursor is at the end of previous paragraph
      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ��� move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping
    whichwrap enabled
      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (49ms)

        ✓ <left> wraps to previous line (107ms)

        ✓ <right> wraps to next line (53ms)

      insert mode

        ✓ <left> wraps to previous line (44ms)

        ✓ <right> once goes to end of line (67ms)

        ✓ <right> twice wraps to next line (51ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (112ms)

        ✓ l does not wrap to next line (208ms)

        ✓ <left> does not wrap to previous line (136ms)

        ✓ <right> does not wrap to next line (169ms)

      insert mode

        ✓ <left> does not wrap to previous line (160ms)

        ✓ <right> does not wrap to next line (169ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (64ms)

      ✓ search wraps around the start of the file (221ms)

    wrapscan disabled

      ✓ search stops at the end of the file (185ms)

      ✓ search stops at the start of the file (90ms)

  Multicursor

    ✓ can add multiple cursors below (120ms)

    ✓ can add multiple cursors above (233ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

    ✓ gcc comments out current line (252ms)

    ✓ gcj comments in current and next line (209ms)

    ✓ block comment with motion (319ms)

    ✓ block comment in Visual Mode (237ms)

    ✓ comment in visual line mode (194ms)

    ✓ comment in visual block mode (238ms)

  format operator

    ✓ == formats current line (320ms)

    ✓ =$ formats entire line (392ms)

    ✓ =j formats two lines (211ms)

    ✓ 3=k formats three lines (196ms)

    ✓ =gg formats to top of file (105ms)

    ✓ =G formats to bottom of file (170ms)

    ✓ =ip formats paragraph (87ms)

    ✓ format in visual mode (125ms)

  put operator

    ✓ basic put test (74ms)

    ✓ test yy end of line (82ms)

    ✓ test yy first line (70ms)

    ✓ test yy middle line (218ms)

    ✓ test yy with correct positon movement (163ms)

    ✓ test visual block single line yank p (234ms)

    ✓ test visual block single line yank P (128ms)

    ✓ test visual block single line delete p (227ms)

    ✓ test visual block single line delete P (131ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (49ms)

    ✓ shift left goto end test (58ms)

    ✓ shift left goto line test (221ms)

    ✓ shift right goto end test (44ms)

    ✓ shift right goto line test (214ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (124ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (193ms)

      ✓ step to Camel word (156ms)

      ✓ step to CAP word (77ms)

      ✓ step after CAP word (199ms)

      ✓ step from middle of word to Camel word (167ms)

      ✓ step to number word (206ms)

      ✓ step to operator word (116ms)

      ✓ step from inside operator word (528ms)

      ✓ step to operator and then over (71ms)

    handles <leader>w for underscore_var

      ✓ step to _word (77ms)

      ✓ step over whitespace to word (211ms)

      ✓ step from inside word to _word (200ms)

      ✓ step form _word to number (89ms)

      ✓ step from nubmer word to _word (124ms)

      ✓ step from in whitespace to word (85ms)

      ✓ step in ALL_CAPS_WORD (80ms)

    handles d<leader>w

      ✓ delete from start of camelWord (96ms)

      ✓ delete from middle of camelWord (221ms)

      ✓ delete from start of CamelWord (145ms)

      ✓ delete two words from camelWord (200ms)

      ✓ delete from start of underscore_word (151ms)

      ✓ delete from middle of underscore_word (118ms)

      ✓ delete two words from camel_word (190ms)

    handles di<leader>w

      ✓ delete from start of camelWord (102ms)

      ✓ delete from middle of camelWord (210ms)

      ✓ delete from start of CamelWord (104ms)

      ✓ delete two words from camelWord (51ms)

      ✓ delete from start of underscore_word (165ms)

      ✓ delete from middle of underscore_word (177ms)

      ✓ delete two words from camel_word (95ms)

    handles <leader>b

      ✓ back from middle of word (209ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (208ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (66ms)

      ✓ from middle to end of underscore_word (55ms)

      ✓ twice to end of word over operator (177ms)

  easymotion plugin

    ✓ Can handle s move (84ms)

    ✓ Can handle 2s move (199ms)

    ✓ Can handle f move (92ms)

    ✓ Can handle 2f move (81ms)

    ✓ Can handle F move (229ms)

    ✓ Can handle 2F move (175ms)

    ✓ Can handle t move (80ms)

    ✓ Can handle bd-t move (82ms)

    ✓ Can handle 2t move (133ms)

    ✓ Can handle bd-t2 move (144ms)

    ✓ Can handle T move (322ms)

    ✓ Can handle 2T move (168ms)

    ✓ Can handle w move (216ms)

    ✓ Can handle bd-w move (172ms)

    ✓ Can handle b move (228ms)

    ✓ Can handle e move (133ms)

    ✓ Can handle bd-e move (208ms)

    ✓ Can handle ge move (106ms)

    ✓ Can handle n-char move (227ms)

    ✓ Can handle j move (178ms)

    ✓ Can handle k move (111ms)

    ✓ Can handle bd-jk move (1) (219ms)

    ✓ Can handle bd-jk move (2) (174ms)

    ✓ Can handle lineforward move (1) (124ms)

    ✓ Can handle lineforward move (2) (77ms)

    ✓ Can handle linebackward move (1) (119ms)

    ✓ Can handle linebackward move (2) (83ms)

    ✓ Can handle searching for backslash (\) (111ms)

    ✓ Can handle searching for carat (^) (153ms)

    ✓ Can handle searching for dot (.) (65ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (116ms)

    ✓ Replaces within inner Word (184ms)

    ✓ Replaces within '' (381ms)

    ✓ Replaces within '' including spaces (68ms)

    ✓ Replaces within () (220ms)

    ✓ Replaces within () including spaces (130ms)

    ✓ Replaces within a paragraph (108ms)

    ✓ Replaces using a specified register (158ms)

    ✓ Replaces within {} over multiple lines (107ms)

    ✓ Replaces a multiline register within {} over multiple lines (67ms)

    ✓ Replaces a multiline register within {} over multiple lines (115ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (206ms)

    ✓ grr replaces the entire line with the register (72ms)

    ✓ grr can replace multiple lines (83ms)

    ✓ Replaces in visual mode (235ms)

    ✓ Replaces in visual mode using a specified register (146ms)

    ✓ Replaces in visual line mode (325ms)

    ✓ grj is linewise (162ms)

  sneak plugin

    ✓ Can handle s motion (108ms)

    ✓ Can handle S motion (156ms)

    ✓ Can handle <operator>z motion (204ms)

    ✓ Can handle <operator>Z motion (144ms)

    ✓ Can handle s; motion (48ms)

    ✓ Can handle s, motion (210ms)

    ✓ Can handle S; motion (160ms)

    ✓ Can handle S, motion (98ms)

    ✓ Can handle single letter s motion (118ms)

    ✓ Can handle single letter S motion (192ms)

    ✓ Can handle single letter <operator>z motion (104ms)

    ✓ Can handle single letter <operator>Z motion (46ms)

    ✓ Can handle single letter s; motion (49ms)

    ✓ Can handle single letter s, motion (75ms)

    ✓ Can handle single letter S; motion (108ms)

    ✓ Can handle single letter S, motion (216ms)

    ✓ Can handle multiline single char <number>s motion (177ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (178ms)

    ✓ 'ysiw(' surrounds word with space (165ms)

    ✓ 'ysw)' surrounds word without space (118ms)

    ✓ 'ysw(' surrounds word with space (92ms)

    ✓ 'ysaw)' surrounds word without space (233ms)

    ✓ 'ysaw(' surrounds word with space (93ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (183ms)

    ✓ 'ysiw<' surrounds word with tags (84ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (89ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (168ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (151ms)

    ✓ change surround (148ms)

    ✓ change surround with two pairs of quotes (133ms)

    ✓ change surround with two pairs of parens (161ms)

    ✓ change surround with alias (193ms)

    ✓ change surround to tags (131ms)

    ✓ delete surround (87ms)

    ✓ delete surround with quotes (95ms)

    ✓ delete surround with nested of quotes (110ms)

    ✓ delete surround with inconsistent quotes (395ms)

    ✓ delete surround with mixed quotes (523ms)

    ✓ delete surround with empty quotes cursor at start (103ms)

    ✓ delete surround with empty quotes cursor at end (62ms)

    ✓ don't delete surround if cursor is after closing match (169ms)

    ✓ delete surround if cursor is before opening match (78ms)

    ✓ delete surround with two pairs of parens (182ms)

    ✓ delete surround with alias (113ms)

    ✓ delete surround with tags (177ms)

    ✓ change surround brackets at end of line (76ms)

    ✓ changing brackets with surround works again (93ms)

    ✓ change surround with tags that contain an attribute and preserve them (206ms)

    ✓ change surround with tags that contain an attribute and remove them (148ms)

  register

    ✓ Can copy to a register (180ms)

    ✓ Can use two registers together (88ms)

    ✓ Can use black hole register (185ms)

    ✓ System clipboard works with chinese characters (43ms)

    ✓ Yank stores text in Register '0' (230ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (201ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (189ms)

    ✓ Register '1'-'9' stores delete content (214ms)

    ✓ "A appends linewise text to "a (252ms)

    ✓ "A appends character wise text to "a (167ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (210ms)

    ✓ Small deletion using Del is stored in small delete register (150ms)

    ✓ Small deletion using X is stored in small delete register (200ms)

    ✓ Search register (/) is set by forward search (297ms)

    ✓ Search register (/) is set by backward search (269ms)

    ✓ Search register (/) is set by star search (232ms)

    ✓ Command register (:) is set by command line (74ms)

    ✓ Read-only registers cannot be written to (173ms)

    clipboard

      ✓ Can access '*' (clipboard) register (110ms)

      ✓ Can access '+' (clipboard) register (156ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (192ms)

    ✓ Can repeat reversed F<character> (213ms)

    ✓ Can repeat t<character> (66ms)

    ✓ Can repeat N times reversed t<character> (69ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (177ms)

      ✓ move one sentence backward (320ms)

      ✓ move [count] sentences backward (217ms)

      ✓ move one sentence backward single line - middle (105ms)

      ✓ move one sentence backward no space (151ms)

      ✓ move one sentence backward no space - middle (210ms)

      ✓ move one sentence backward - multiline (96ms)

      ✓ move one sentence backward - multiline - period (159ms)

      ✓ move one sentence backward - multiline - previous line (125ms)

      ✓ move one sentence backward - multiline - previous line - period (170ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath
      ✓ can separate drive letter path on Windows
      ✓ can separate UNC path on Windows
      ✓ can separate relative path on Windows
      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix

    resolveUri

      ✓ posix
      ✓ win32
  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=�������������.
      + expected - actual

      -�������������
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=a��.
      + expected - actual

      -a��
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=a��.
      + expected - actual

      -a��
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 3936e410-1be9-11ea-ba59-e12deadb3a4c

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[17:10:37] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[17:10:37] Starting 'build'...
[17:10:37] Starting 'prettier'...
[17:10:39] Finished 'prettier' after 1.77 s
[17:10:39] Starting 'tsc'...
[17:10:39] Starting 'tslint'...
[17:10:47] Finished 'tslint' after 8.48 s
[17:10:57] Finished 'tsc' after 18 s
[17:10:57] Starting 'commit-hash'...
[17:10:57] Finished 'commit-hash' after 31 ms
[17:10:57] Finished 'build' after 20 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: read ECONNRESET
    at TLSWrap.onread (net.js:622:25)
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: read ECONNRESET
    at TLSWrap.onread (net.js:622:25)
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 3745db20-1c39-11ea-8f89-4d10c456a4d8

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[17:18:26] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[17:18:26] Starting 'build'...
[17:18:26] Starting 'prettier'...
[17:18:28] Finished 'prettier' after 1.45 s
[17:18:28] Starting 'tsc'...
[17:18:28] Starting 'tslint'...
[17:18:35] Finished 'tslint' after 7.12 s
[17:18:43] Finished 'tsc' after 15 s
[17:18:43] Starting 'commit-hash'...
[17:18:43] Finished 'commit-hash' after 27 ms
[17:18:43] Finished 'build' after 17 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
Failed to execute tests: Error: spawn /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code ENOENT
Tests exited with code: -2
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
Failed to execute tests: Error: spawn /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code ENOENT
Tests exited with code: -2
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 5f0addd0-1c3a-11ea-8f89-4d10c456a4d8

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[08:41:54] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[08:41:54] Starting 'build'...
[08:41:54] Starting 'prettier'...
[08:41:56] Finished 'prettier' after 2.33 s
[08:41:56] Starting 'tsc'...
[08:41:56] Starting 'tslint'...
[08:42:03] Finished 'tslint' after 6.93 s
[08:42:11] Finished 'tsc' after 15 s
[08:42:11] Starting 'commit-hash'...
[08:42:11] Finished 'commit-hash' after 27 ms
[08:42:11] Finished 'build' after 17 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-12T08:42:15.235Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (40ms)

    ✓ command <C-w> can remove word in search mode (73ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character (43ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (76ms)

    ✓ <C-p>/<C-n> go to the previous/next command (60ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (94ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command (38ms)

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (60ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar
    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (549ms)

    ✓ :smile editor contains smile text (549ms)

  Basic sort

    ✓ Sort whole file, asc (201ms)

    ✓ Sort whole file, asc, ignoreCase (144ms)

    ✓ Sort whole file, dsc (241ms)

    ✓ Sort whole file, dsc, ignoreCase (150ms)

    ✓ Sort range, asc (146ms)

    ✓ Sort range, asc, ignoreCase (324ms)

    ✓ Sort range, dsc (184ms)

    ✓ Sort range, dsc, ignoreCase (118ms)

    ✓ Sort whole file, asc, unique (282ms)

  Horizontal split

    ✓ Run :sp (79ms)

    ✓ Run :split (71ms)

    ✓ Run :new (85ms)

  :close args parser

    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args
    ✓ can parse an absolute position
    ✓ can parse a relative position
    ✓ fails with invalid inputs
  getParser
    ✓ empty
    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (52ms)

    ✓ Replace with `g` flag (59ms)

    ✓ Replace with flags AND count (113ms)

    ✓ Replace with `c` flag (45ms)

    ✓ Replace with `gc` flag (80ms)

    ✓ Replace across all lines (99ms)

    ✓ Replace on specific single line (110ms)

    ✓ Replace on current line using dot (92ms)

    ✓ Replace single relative line using dot and plus (111ms)

    ✓ Replace across specific line range (94ms)

    ✓ Replace across relative line range using dot, plus, and minus (158ms)

    ✓ Replace across relative line range using numLines+colon shorthand (116ms)

    ✓ Repeat replacement across relative line range (119ms)

    ✓ Replace with range AND count but no flags (143ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (145ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (91ms)

    ✓ Undocumented: trailing operators use 1 as RHS (107ms)

    ✓ Replace specific single equal lines (80ms)

    ✓ Replace current line with no active selection (97ms)

    ✓ Replace text in selection (115ms)

    ✓ Substitute support marks (94ms)
    Effects of gdefault=true

      ✓ Replace all matches in the line (82ms)

      ✓ Replace with `g` flag inverts global flag (51ms)

      ✓ Replace with `c` flag inverts global flag (96ms)

      ✓ Replace multiple lines (115ms)

      ✓ Replace across specific lines (100ms)

      ✓ Replace current line with no active selection (88ms)

      ✓ Replace text in selection (131ms)

      ✓ Substitute support marks (125ms)

      ✓ Substitute with escaped delimiter (81ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (199ms)

      ✓ Substitute with previous search using # (232ms)

      ✓ Substitute with previous search using / (208ms)

      ✓ Substitute with parameters should update search state (132ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (246ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (205ms)

      ✓ Substitute repeat previous should accept flags (261ms)

      ✓ Substitute with empty search string should use last searched pattern (227ms)

      ✓ Ampersand (&) should repeat the last substitution (100ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (78ms)

    ✓ tabe with current file path does nothing (61ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (68ms)

    ✓ command line file tab completion with space in file path (110ms)

  Vertical split

    ✓ Run :vs (69ms)

    ✓ Run :vsp (70ms)

    ✓ Run :vsplit (76ms)

    ✓ Run :vnew (305ms)

    ✓ Run :vne (240ms)

  Basic write-quit

    ✓ Run write and quit (106ms)
  Provide line completions
    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (52ms)

      ✓ Can complete lines in file with different indentation (45ms)

      ✓ Returns no completions for unmatched line (61ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (40ms)

  Notation

    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (79ms)

    ✓ getMatchingRemap (107ms)

    ✓ jj -> <Esc> through modehandler (93ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (115ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (96ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (87ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (139ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (148ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (156ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (154ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps
    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim
      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (106ms)

        ✓ Can track jumps for keys: GggG (215ms)

        ✓ Can track jumps for keys: GggGgg (191ms)

        ✓ Can track jumps for keys: /b<CR>n (127ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (256ms)

        ✓ Can track jumps for keys: j%% (184ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (212ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (204ms)

        ✓ Can track jumps for keys: j%%<C-o>% (176ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (261ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (63ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (104ms)

        ✓ Can enter number to jump back multiple times (222ms)

        ✓ Can track one-line `` jumps (194ms)

        ✓ Can track one-line double `` jumps (93ms)

[main 2019-12-12T08:42:45.238Z] update#setState checking for updates

[main 2019-12-12T08:42:45.294Z] update#setState idle

        ✓ Can track one-line '' jumps (257ms)

        ✓ Can track one-line double '' jumps (182ms)

        ✓ Can handle '' jumps with no previous jump (213ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (223ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (173ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (276ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (216ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (221ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (313ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (220ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (293ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (177ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (215ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (226ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (188ms)

  Record and execute a macro

    ✓ Can record and execute (306ms)

    ✓ Can repeat last invoked macro (235ms)

    ✓ Can play back with count (458ms)

    ✓ Can play back with count, abort when a motion fails (503ms)

    ✓ Repeat change on contiguous lines (233ms)

    ✓ Append command to a macro (220ms)

    ✓ Can record Ctrl Keys and repeat (132ms)

    ✓ Can execute macros with dot commands properly (157ms)

    ✓ : (command) register can be used as a macro (250ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (124ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (44ms)

    ✓ <C-c> can exit insert (114ms)

    ✓ <Esc> can exit insert (59ms)

    ✓ Stay in insert when entering characters (61ms)

    ✓ Can handle 'O' (56ms)

    ✓ Can handle 'i' (97ms)

    ✓ Can handle 'I' (104ms)

    ✓ Can handle 'a' (120ms)

    ✓ Can handle 'A' (69ms)

    ✓ Can handle '<C-w>' (78ms)

    ✓ Can handle <C-w> on leading whitespace (59ms)

    ✓ Can handle <C-w> at beginning of line (82ms)

    ✓ Can handle <C-u> (73ms)

    ✓ Can handle <C-u> on leading characters (150ms)

    ✓ Can handle <C-u> on leading whitespace (122ms)

    ✓ Correctly places the cursor after deleting the previous line break (65ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (41ms)

    ✓ Backspace works on whitespace only lines (88ms)

    ✓ Backspace works on end of whitespace only lines (93ms)

    ✓ Backspace works at beginning of file (84ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (107ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (135ms)

    ✓ Can perform insert command prefixed with count (73ms)

    ✓ Can perform append command prefixed with count (62ms)

    ✓ Can perform insert at start of line command prefixed with count (64ms)

    ✓ Can perform append to end of line command prefixed with count (79ms)

    ✓ Can perform change char (s) command prefixed with count (183ms)

    ✓ Can perform command prefixed with count with <C-[> (62ms)

    ✓ Can handle 'o' with count (116ms)

    ✓ Can handle 'O' with count (111ms)

    ✓ Can handle backspace at beginning of line with all spaces (219ms)

    ✓ Can handle digraph insert (170ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (85ms)

    ✓ Can handle dw (47ms)

    ✓ Can handle dw (40ms)

    ✓ Can handle dw across lines (1) (71ms)

    ✓ Can handle dw across lines (2) (79ms)

    ✓ Can handle dd last line (124ms)

    ✓ Can handle dd single line (40ms)

    ✓ Can handle dd (79ms)

    ✓ Can handle 3dd (51ms)

    ✓ Can handle 3dd off end of document (47ms)

    ✓ Can handle d2d (77ms)

    ✓ Can handle dd empty line (56ms)

    ✓ Can handle ddp (121ms)

    ✓ Can handle 'de' (72ms)

    ✓ Can handle 'de' then 'de' again (117ms)

    ✓ Can handle 'db' (54ms)

    ✓ Can handle 'db then 'db' again (119ms)

    ✓ Can handle 'dl' at end of line (168ms)

    ✓ Can handle 'dF' (209ms)

    ✓ Can handle 'dT' (70ms)

    ✓ Can handle 'd3' then <enter> (64ms)

    ✓ Can handle 'dj' (112ms)

    ✓ Can handle 'dk' (71ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (54ms)

    ✓ Can handle 'd]}' without deleting closing bracket (87ms)

    ✓ Can handle 'cw' (162ms)

    ✓ Can handle 'cw' without deleting following white spaces (78ms)

    ✓ Can handle 'c2w' (38ms)

    ✓ Can handle 'cw' without removing EOL (122ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (110ms)

    ✓ Can handle 'c]}' without deleting closing bracket (239ms)

    ✓ Can handle 's' (163ms)

    ✓ Can handle 'yiw' with correct cursor ending position (98ms)

    ✓ Can handle 'ciw' (162ms)

    ✓ Can handle 'ciw' on blanks (182ms)

    ✓ Can handle 'caw' (111ms)

    ✓ Can handle 'caw' on first letter (129ms)

    ✓ Can handle 'caw' on blanks (187ms)

    ✓ Can handle 'caw' on blanks (69ms)

    ✓ Can handle 'ci(' on first parentheses (67ms)

    ✓ Can handle 'ci(' with nested parentheses (54ms)

    ✓ Can handle 'ci(' backwards through nested parens (82ms)

    ✓ Can handle 'cib' on first parentheses (99ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (112ms)

    ✓ Can handle count prefixed 'ci)' (114ms)

    ✓ Can handle count prefixed 'ca)' (121ms)

    ✓ Can handle 'ca(' spanning multiple lines (101ms)

    ✓ Can handle 'cab' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines (206ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (58ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (69ms)

    ✓ Can handle 'ci(' on the closing bracket (53ms)

    ✓ Can handle 'ciB' spanning multiple lines (132ms)

    ✓ will fail when ca( with no () (99ms)

    ✓ will fail when ca{ with no {} (51ms)

    ✓ will fail when caB with no {} (59ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (67ms)

    ✓ Can handle 'ca[' on first bracket (75ms)

    ✓ Can handle 'ca]' on first bracket (102ms)

    ✓ Can handle 'ci'' on first quote (57ms)

    ✓ Can handle 'ci'' inside quoted string (54ms)

    ✓ Can handle 'ci'' on closing quote (97ms)

    ✓ Can handle 'ci'' when string is ahead (67ms)

    ✓ Can handle 'ci"' on opening quote (55ms)

    ✓ Can handle 'ci"' starting behind the quoted word (91ms)

    ✓ Can handle 'ca"' starting behind the quoted word (81ms)

    ✓ Can handle 'ca"' starting on the opening quote (60ms)

    ✓ Can handle 'ci"' with escaped quotes (84ms)

    ✓ Can handle 'ci"' with a single escaped quote

    ✓ Can handle 'ci"' with a single escaped quote behind (127ms)

    ✓ Can handle 'ci"' with an escaped backslash (144ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (50ms)

    ✓ Can handle 'ca"' starting on the closing quote (84ms)

    ✓ Can handle 'ci"' with complex escape sequences (54ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (74ms)

    ✓ will fail when ca" ahead of quoted string (70ms)

    ✓ Can handle 'ca`' inside word (54ms)

    ✓ can handle cj (132ms)

    ✓ can handle ck (133ms)

    ✓ can handle c2j (118ms)

    ✓ can handle c2k (84ms)

    ✓ can handle cj on last line (92ms)

    ✓ can handle ck on first line (90ms)

    ✓ can handle c2j on last line (122ms)

    ✓ can handle c2k on first line (119ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (219ms)

    ✓ Can handle 'daw' on word with trailing spaces (67ms)

    ✓ Can handle 'daw' on word with leading spaces (107ms)

    ✓ Can handle 'daw' on word with numeric prefix (169ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (152ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (128ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (121ms)

    ✓ Can handle 'daw' on end of word (134ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (51ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (90ms)

    ✓ Can handle 'daw' on word at beginning of file (55ms)

    ✓ Can handle 'daw' on word at beginning of line (129ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (133ms)

    ✓ Can handle 'daw' around word at end of line (138ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (95ms)

    ✓ Can handle 'daW' around word at whitespace (124ms)

    ✓ Can handle 'daW' on word with trailing spaces (74ms)

    ✓ Can handle 'daW' on word with leading spaces (176ms)

    ✓ Can handle 'daW' on word with numeric prefix (79ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (199ms)

    ✓ Can handle 'daW' on beginning of word (46ms)

    ✓ Can handle 'daW' on end of one line (51ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (64ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (87ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (228ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (126ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (189ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (68ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (66ms)

    ✓ Can handle 'diw' on word (142ms)

    ✓ Can handle 'diw' on word with numeric prefix (53ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (110ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (131ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (202ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (81ms)

    ✓ Can handle 'diW' on word with trailing spaces (65ms)

    ✓ Can handle 'diW' on word with leading spaces (84ms)

    ✓ Can handle 'diW' on word with numeric prefix (71ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (114ms)

    ✓ Can handle 'diW' on beginning of word (114ms)

    ✓ Can handle d} (206ms)

    ✓ Can handle y} at beginning of line (161ms)

    ✓ Select sentence with trailing spaces (89ms)

    ✓ Select sentence with leading spaces (153ms)

    ✓ Select inner sentence with trailing spaces (209ms)

    ✓ Select inner sentence with leading spaces (130ms)

    ✓ Select spaces between sentences (139ms)

    ✓ Can handle 'df' (218ms)

    ✓ Can handle 'dt' (174ms)

    ✓ Can handle backspace (208ms)

    ✓ Can handle backspace across lines (84ms)

    ✓ Can handle A and backspace (222ms)

    ✓ Can handle 'yy' without changing cursor position (159ms)

    ✓ Can handle 'P' after 'yy' (224ms)

    ✓ Can handle 'p' after 'yy' (151ms)

    ✓ Can handle 'P' after 'Nyy' (215ms)

    ✓ Can handle 'p' after 'Nyy' (52ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (131ms)

    ✓ Can handle 'gp' after 'yy' (67ms)

    ✓ Can handle 'gp' after 'Nyy' (73ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (64ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (74ms)

    ✓ Can handle 'gP' after 'yy' (227ms)

    ✓ Can handle 'gP' after 'Nyy' (180ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (180ms)

    ✓ Can handle ']p' after yy (58ms)

    ✓ Can handle ']p' after 'Nyy' (71ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (60ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (75ms)

    ✓ Can handle '[p' after yy (55ms)

    ✓ Can handle '[p' after 'Nyy' (76ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (198ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (174ms)

    ✓ Can handle 'p' after y'a (241ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (81ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (221ms)

    ✓ Can handle pasting in visual mode over selection (177ms)

    ✓ Can repeat w (202ms)

    ✓ Can repeat p (181ms)

    ✓ I works correctly (281ms)

    ✓ gI works correctly (136ms)

    ✓ gi works correctly (271ms)

    ✓ `. works correctly (92ms)

    ✓ '. works correctly (234ms)

    ✓ g; works correctly (159ms)

    ✓ g, works correctly (270ms)

    ✓ g_ works correctly (219ms)

    ✓ 3g_ works correctly (165ms)

    ✓ gq handles spaces after single line comments correctly (353ms)

    ✓ gq handles spaces before single line comments correctly (310ms)

    ✓ gq handles tabs before single line comments correctly (392ms)

    ✓ Can handle space (58ms)

    ✓ Can handle space (211ms)

    ✓ Undo 1 (278ms)

    ✓ Undo 2 (146ms)

    ✓ Undo cursor (293ms)

    ✓ Undo cursor 2 (167ms)

    ✓ Undo cursor 3 (279ms)

    ✓ Undo with movement first (129ms)

    ✓ Can handle 'U' (330ms)

    ✓ Can handle 'U' for multiple changes (227ms)

    ✓ Can handle 'U' for new line below (195ms)

    ✓ Can handle 'U' for new line above (284ms)

    ✓ Can handle 'U' for consecutive changes only (518ms)

    ✓ Can handle 'u' to undo 'U' (122ms)

    ✓ Can handle 'U' to undo 'U' (235ms)

    ✓ Redo (148ms)

    ✓ Redo (289ms)

    ✓ Redo (114ms)

    ✓ Can handle u (248ms)

    ✓ Can handle guw (125ms)

    ✓ Can handle gUw (215ms)

    ✓ Can handle u over line breaks (165ms)

    ✓ can handle s in visual mode (185ms)

    ✓ can handle p with selection (148ms)

    ✓ can handle P with selection (114ms)

    ✓ can handle p in visual to end of line (295ms)

    ✓ can repeat backspace twice (214ms)

    ✓ can delete linewise with d2G (184ms)

    ✓ can delete with + motion and count (214ms)

    ✓ can delete with - motion and count (54ms)

    ✓ can dE correctly (228ms)

    ✓ can dE correctly (91ms)

    ✓ can dE correctly (212ms)

    ✓ can ctrl-a correctly behind a word (159ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (202ms)

    ✓ can ctrl-a on word (97ms)

    ✓ can ctrl-a on a hex number (214ms)

    ✓ can ctrl-a on decimal (162ms)

    ✓ can ctrl-a with numeric prefix (204ms)

    ✓ can ctrl-a on a decimal (157ms)

    ✓ can ctrl-a on an octal  (219ms)

    ✓ Correctly increments in the middle of a number (133ms)

    ✓ can ctrl-x correctly behind a word (177ms)

    ✓ can ctrl-a on an number with word before  (69ms)

    ✓ can ctrl-a on an number with word before and after  (67ms)

    ✓ can ctrl-x on a negative number with word before and after  (53ms)

    ✓ can ctrl-a properly on multiple lines (57ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (45ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (49ms)

    ✓ can <C-a> on word with - in front of it (48ms)

    ✓ can do Y (74ms)

    ✓ Can do S (51ms)

    ✓ / does not affect mark (221ms)

    ✓ / can search with regex (148ms)

    ✓ / can search with newline (127ms)

    ✓ / can search through multiple newlines (251ms)

    ✓ / matches ^ per line (169ms)

    ✓ / matches $ per line (193ms)

    ✓ Can search for forward slash (118ms)

    ✓ Can search backward for question mark (76ms)

    ✓ /\c forces case insensitive search (59ms)

    ✓ /\C forces case sensitive search (68ms)

    ✓ <BS> deletes the last character in search in progress mode (50ms)

    ✓ <S-BS> deletes the last character in search in progress mode (49ms)

    ✓ <C-h> deletes the last character in search in progress mode (74ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (95ms)

    ✓ Ignores cit on a non-matching tag (213ms)

    ✓ Ignores cit on a nested tag (170ms)

    ✓ Can do cit on a tag with an attribute tag (198ms)

    ✓ Can do cat on a matching tag (301ms)

    ✓ Can do cit on a multiline tag (146ms)

    ✓ Can do cit on a multiline tag with nested tags (104ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (117ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (215ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (162ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (219ms)

    ✓ can do cit with self closing tags (175ms)

    ✓ Respects indentation with cc (94ms)

    ✓ Resets cursor to indent end with cc (224ms)

    ✓ can handle 'cc' on empty line (154ms)

    ✓ cc copies linewise (214ms)

    ✓ Indent current line with correct Vim Mode (147ms)

    ✓ Can handle <Esc> and do nothing (205ms)

    ✓ Can handle # on consecutive words (80ms)

    ✓ Can handle # on skipped words (155ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (105ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (219ms)

    ✓ cc on whitespace-only treats whitespace as indent (154ms)

    ✓ Can do cai (212ms)

    ✓ Can do cii (65ms)

    ✓ Can do caI (114ms)

    ✓ Can do dai (161ms)

    ✓ Can do dii (41ms)

    ✓ Can do daI (105ms)

    ✓ `] go to the end of the previously operated or put text (85ms)

    ✓ '] go to the end of the previously operated or put text (240ms)

    ✓ `[ go to the start of the previously operated or put text (183ms)

    ✓ '[ go to the start of the previously operated or put text (385ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (172ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (195ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (116ms)

    can handle gn

      ✓ gn selects the next match text (259ms)

      ✓ gn selects the current word at |hello (289ms)

      ✓ gn selects the current word at h|ello (230ms)

      ✓ gn selects the current word at hel|lo (237ms)

      ✓ gn selects the current word at hell|o (184ms)

      ✓ gn selects the next word at hello| (247ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (119ms)

      ✓ dgn deletes the current word when cursor is at |hello (233ms)

      ✓ dgn deletes the current word when cursor is at h|ello (192ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (189ms)

      ✓ dgn deletes the current word when cursor is at hell|o (139ms)

      ✓ dgn deletes the next word when cursor is at hello| (234ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (152ms)

      ✓ cgn deletes the current word when cursor is at |hello (222ms)

      ✓ cgn deletes the current word when cursor is at h|ello (179ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (244ms)

      ✓ cgn deletes the current word when cursor is at hell|o (163ms)

      ✓ cgn deletes the next word when cursor is at hello| (115ms)

    can handle gN

      ✓ gN selects the previous match text (525ms)

      ✓ gN selects the current word at hell|o (322ms)

      ✓ gN selects the current word at hel|lo (288ms)

      ✓ gN selects the current word at h|ello (231ms)

      ✓ gN selects the current word at |hello (216ms)

      ✓ gN selects the previous word at | hello (228ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (70ms)

      ✓ dgN deletes the current word when cursor is at hell|o (80ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (171ms)

      ✓ dgN deletes the current word when cursor is at h|ello (214ms)

      ✓ dgN deletes the current word when cursor is at |hello (158ms)

      ✓ dgN deletes the previous word when cursor is at | hello (179ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (234ms)

      ✓ cgN deletes the current word when cursor is at hell|o (136ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (264ms)

      ✓ cgN deletes the current word when cursor is at h|ello (182ms)

      ✓ cgN deletes the current word when cursor is at |hello (234ms)

      ✓ cgN deletes the previous word when cursor is at | hello (297ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (156ms)

    ✓ Can activate with R from Normal mode (190ms)

    ✓ Can handle R (186ms)

    ✓ Can handle R past current line (181ms)

    ✓ Can handle R and exit Replace Mode (199ms)

    ✓ Can handle R across lines (310ms)

    ✓ Can handle R across lines and exit Replace Mode (164ms)

    ✓ Can handle R with {count} (195ms)

    ✓ Can handle backspace (182ms)

    ✓ Can handle backspace (202ms)

    ✓ Can handle backspace across lines (227ms)

    ✓ Can handle arrows (147ms)

    ✓ Can handle . (231ms)

    ✓ Can handle . across lines (202ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (133ms)

    ✓ Can handle wd (139ms)

    ✓ Can handle x (119ms)

    ✓ Can handle x across a selection (117ms)

    ✓ Can do vwd in middle of sentence (248ms)

    ✓ Can do vwd in middle of sentence (116ms)

    ✓ Can do vwd multiple times (182ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (126ms)

    ✓ Can handle H key (215ms)

    ✓ Can handle backspace key (167ms)

    ✓ handles case where we delete over a newline (186ms)

    ✓ handles change operator (116ms)

    ✓ Can do vat on multiple matching tags (222ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (187ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (286ms)

    ✓ Repeat-prefixed vat does not bleed below (114ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (45ms)

    ✓ Can do vi) on a matching parenthesis (235ms)

    ✓ Can do vi) on multiple matching parens (154ms)

    ✓ Can do va) on a matching parenthesis (211ms)

    ✓ Can do va) on multiple matching parens (173ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (230ms)

    ✓ Repeat-prefixed va) does not bleed below (86ms)

    ✓ Can do va} on a matching bracket as first character (60ms)

    ✓ Can do va} on multiple matching brackets (75ms)

    ✓ Can do vi( on a matching bracket near first character (220ms)

    ✓ Can do vi{ on outer pair of nested braces (77ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (79ms)

    ✓ Can do va] on multiple matching brackets (167ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (233ms)

    ✓ Repeat-prefixed vaf does not bleed below (167ms)

    ✓ vaf only expands to enclosing pairs (67ms)

    ✓ Can use . to repeat indent in visual (226ms)

    ✓ Can do v_x to delete to first char (306ms)

    ✓ Can do vg_x to delete to last char with no EOL (140ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (170ms)

    ✓ Can do v$x to delete to last char including EOL (56ms)

    ✓ Can do gv to reselect previous selection (173ms)

    Vim's EOL handling is weird

      ✓ delete through eol (131ms)

      ✓ join 2 lines by deleting through eol (224ms)

      ✓ d$ doesn't delete whole line (73ms)

      ✓ vd$ does delete whole line (84ms)

      ✓ Paste over selection copies the selection (242ms)

      ✓ Paste over selection copies the selection linewise (166ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (242ms)

      ✓ Can handle <down> key (159ms)

      ✓ Can handle <left> key (166ms)

      ✓ Can handle <right> key (223ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (152ms)

      ✓ Can handle 'gj' (230ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (156ms)

      ✓ Can handle 'vawd' on word with trailing spaces (236ms)

      ✓ Can handle 'vawd' on word with leading spaces (163ms)

      ✓ Can handle 'vawd' on word with numeric prefix (201ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (158ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (128ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (227ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (164ms)

      ✓ Can handle 'vaWd' on word with leading spaces (225ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (109ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (206ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (162ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (160ms)

      ✓ Can handle 'vaWd' on word with leading spaces (234ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (146ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (229ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (161ms)

      ✓ Can handle 'vawd' on word with trailing spaces (227ms)

      ✓ Can handle 'vawd' on word with leading spaces (174ms)

      ✓ Can handle 'vawd' on word with numeric prefix (147ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (211ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (179ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (232ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (267ms)

      ✓ Can handle 'vaWd' on word with leading spaces (234ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (163ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (229ms)

      ✓ Can handle 'Y' in visual mode (146ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (209ms)

      ✓ Select sentence with leading spaces in visual mode (167ms)

      ✓ Select multiple sentences in visual mode (210ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (161ms)

      ✓ Select inner sentence with leading spaces in visual mode (381ms)

      ✓ Select spaces between sentences in visual mode (124ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (218ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (164ms)

      ✓ Can do vat on a matching tag (225ms)

    handles replace in visual mode

      ✓ Can do a single line replace (111ms)

      ✓ Can do a multi line replace (260ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (91ms)

      ✓ D deletes the current line (156ms)

    handles indent blocks in visual mode

      ✓ Can do vai (218ms)

      ✓ Can do vii (72ms)

      ✓ Doesn't naively select the next line (69ms)

      ✓ Searches backwards if cursor line is empty (228ms)

      ✓ Can do vaI (338ms)

    visualstar

      ✓ Works with * (156ms)

      ✓ Works with # (61ms)

    search works in visual mode

      ✓ Works with / (65ms)

      ✓ Works with ? (84ms)

      ✓ Selects correct range (95ms)

    X will delete linewise

      ✓ normal selection (217ms)

      ✓ normal selection (180ms)

    C will delete linewise

      ✓ normal selection (245ms)

      ✓ normal selection (137ms)

    R will delete linewise

      ✓ normal selection (208ms)

      ✓ normal selection (161ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (218ms)

      ✓ upward selection (160ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (51ms)

      ✓ multiline indent bottom up selection (64ms)

      ✓ repeat multiline indent top down selection (196ms)

      ✓ repeat multiline indent bottom up selection (188ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (180ms)

      ✓ multiline outdent bottom up selection (67ms)

      ✓ repeat multiline outdent top down selection (274ms)

      ✓ repeat multiline outdent bottom up selection (249ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (121ms)

    vi{ will go to end of second to last line

      ✓ select (239ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (336ms)

      ✓ gv selects the last pasted text (which is longer than original) (379ms)

      ✓ gv selects the last pasted text (multiline) (184ms)

    can handle gn

      ✓ gn selects the next match text (196ms)

      ✓ gn selects the current word at |hello (449ms)

      ✓ gn selects the current word at h|ello (197ms)

      ✓ gn selects the current word at hel|lo (221ms)

      ✓ gn selects the next word at hell|o (223ms)

      ✓ gn selects the next word at hello| (197ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (51ms)

      ✓ multiline insert from top down selection (57ms)

      ✓ skips blank lines (66ms)

    can append text with A

      ✓ multiline append from bottom up selection (63ms)

      ✓ multiline append from top down selection (60ms)

      ✓ skips blank lines (215ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (195ms)

      ✓ U/gU across a selection (80ms)

      ✓ U/gU across a selection (reverse) (231ms)

      ✓ u/gu on single character (150ms)

      ✓ u/gu across a selection (269ms)

      ✓ u/gu across a selection (reverse) (149ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (118ms)

    ✓ Can handle A backwards select (229ms)

    ✓ Can handle I forward select (126ms)

    ✓ Can handle I backwards select (274ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (217ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (180ms)

    ✓ Can handle c forward select (57ms)

    ✓ Can handle c backwards select (77ms)

    ✓ Can handle C (226ms)

    ✓ Can do a multi line replace (159ms)

    ✓ Can handle 'D' (219ms)

    ✓ Can handle 'gj' (160ms)

    ✓ Properly add to end of lines j then $ (116ms)

    ✓ Properly add to end of lines $ then j (238ms)

    ✓ o works in visual block mode (151ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (155ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (145ms)

    ✓ Can handle wd (127ms)

    ✓ Can handle x (92ms)

    ✓ Can handle x across a selection (128ms)

    ✓ Can do vwd in middle of sentence (152ms)

    ✓ Can do vwd in middle of sentence (124ms)

    ✓ Can do vwd multiple times (164ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (131ms)

    ✓ handles case where we delete over a newline (163ms)

    ✓ handles change operator (93ms)

    ✓ Vp updates register content (236ms)

    ✓ Vp does not append unnecessary newlines (first line) (135ms)

    ✓ Vp does not append unnecessary newlines (middle line) (738ms)

    ✓ Vp does not append unnecessary newlines (last line) (412ms)

    Vim's EOL handling is weird

      ✓ delete through eol (114ms)

      ✓ join 2 lines by deleting through eol (84ms)

      ✓ d$ doesn't delete whole line (80ms)

      ✓ vd$ does delete whole line (139ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (85ms)

      ✓ Can handle <down> key (200ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (169ms)

      ✓ Can handle 'gj' (111ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (230ms)

      ✓ Can handle d key (135ms)

      ✓ Can handle d key (48ms)

      ✓ Can handle d key (69ms)

      ✓ can handle 'c' (68ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (201ms)

      ✓ Can do a multi visual line replace (179ms)

      ✓ Can do a multi visual line replace from the bottom up (94ms)

    search works in visual line mode

      ✓ Works with / (242ms)

      ✓ Works with ? (64ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (162ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (103ms)

      ✓ linewise visual put works also in the end of document (227ms)

      ✓ gv selects the last pasted text (which is shorter than original) (409ms)

      ✓ gv selects the last pasted text (which is longer than original) (371ms)

      ✓ gv selects the last pasted text (multiline) (299ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (222ms)

      ✓ skips blank lines (65ms)

    can append text with A

      ✓ multiline append from bottom up selection (174ms)

      ✓ multiline append from top down selection (137ms)

      ✓ skips blank lines (67ms)

  Mode Normal

    ✓ Can handle 'x' (99ms)

    ✓ Can handle 'Nx' (207ms)

    ✓ Can handle 'Nx' and paste (141ms)

    ✓ Can handle 'x' at end of line (272ms)

    ✓ Can handle 'Ns' (113ms)

    ✓ Can handle 'Ns' at end of line (164ms)

    ✓ Can handle '<Del>' (276ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (142ms)

    ✓ Can handle '<Del>' at end of line (126ms)

    ✓ Can handle 'cc' (219ms)

    ✓ Can handle 'Ncc' (143ms)

    ✓ Can handle 'yy' (172ms)

    ✓ Can handle 'D' (178ms)

    ✓ Can handle 'D' on empty lines (145ms)

    ✓ Can handle 'DD' (216ms)

    ✓ Can handle 'C' (155ms)

    ✓ Can handle 'NC' (199ms)

    ✓ Can handle 'NC' and put (143ms)

    ✓ Can handle 'r' (165ms)

    ✓ Can handle '<Count>r' (183ms)

    ✓ Can handle '<Count>r' (133ms)

    ✓ Can handle 'r' after 'dd' (211ms)

    ✓ Can handle 'r
' (932ms)

    ✓ Can handle '<Count>r
' (114ms)

    ✓ Can handle 'J' once (101ms)

    ✓ Can handle 'J' twice (203ms)

    ✓ Can handle 'J' with empty last line (155ms)

    ✓ Can handle 'J's with multiple empty last lines (252ms)

    ✓ Can handle 'J' with leading white space on next line (134ms)

    ✓ Can handle 'J' with only white space on next line (178ms)

    ✓ Can handle 'J' with TWO indented lines (142ms)

    ✓ Can handle 'J' with ')' first character on next line (198ms)

    ✓ Can handle 'J' with a following delete (98ms)

    ✓ Can handle 'J' in Visual Line mode (215ms)

    ✓ Can handle 'gJ' once (130ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (200ms)

    ✓ Can handle '~' (142ms)

    ✓ Can handle 'g~{motion}' (43ms)

    ✓ Can handle '<BS>' in insert mode (195ms)

    ✓ Can handle undo with P (173ms)

    ✓ Can handle 'ge' in multiple lines case1 (65ms)

    ✓ Can handle 'ge' in multiple lines case2 (93ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (199ms)

    ✓ Can repeat '~' with dot (158ms)

    ✓ Can repeat 'x' (210ms)

    ✓ Can repeat 'J' (146ms)

    ✓ Can handle dot with A (134ms)

    ✓ Can handle dot with I (295ms)

    ✓ Can repeat actions that require selections (107ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (257ms)

    ✓ Can repeat insert change and '<C-t>' (139ms)

    ✓ Can repeat change by `<C-a>` (257ms)

    ✓ Only one arrow key can be repeated in Insert Mode (143ms)

    ✓ Cached content change will be cleared by arrow keys (622ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (120ms)

    ✓ inside parenthesis (200ms)

    ✓ nested parenthesis beginning (108ms)

    ✓ nested parenthesis end (134ms)

    ✓ nested bracket and parenthesis beginning (201ms)

    ✓ nested bracket, parenthesis, braces beginning (163ms)

    ✓ nested bracket, parenthesis, braces end (209ms)

    ✓ parentheses after > (172ms)

    ✓ parentheses after " (169ms)

  Motions in Normal Mode

    ✓ Can handle [( (204ms)

    ✓ Can handle nested [( (135ms)

    ✓ Can handle <number>[( (203ms)

    ✓ Can handle [( and character under cursor exclusive (165ms)

    ✓ Can handle ]) (308ms)

    ✓ Can handle nested ]) (163ms)

    ✓ Can handle <number>]) (198ms)

    ✓ Can handle ]) and character under cursor exclusive (106ms)

    ✓ Can handle [{ (204ms)

    ✓ Can handle nested [{ (74ms)

    ✓ Can handle <number>[{ (206ms)

    ✓ Can handle [{ and character under cursor exclusive (168ms)

    ✓ Can handle ]} (164ms)

    ✓ Can handle nested ]} (158ms)

    ✓ Can handle <number>]} (215ms)

    ✓ Can handle ]} and character under cursor exclusive (171ms)

    ✓ Can handle 'ge' (139ms)

    ✓ Can handle 'gg' (211ms)

    ✓ Can handle 'gg' to first non blank char on random line (158ms)

    ✓ Can handle 'gg' to first non blank char on first line (193ms)

    ✓ 'gg' obeys startofline (340ms)

    ✓ Retain same column when moving up/down (171ms)

    ✓ Can handle <enter> (143ms)

    ✓ $ always keeps cursor on EOL (198ms)

    ✓ Can handle $ with a count (164ms)

    ✓ Can handle $ with a count at end of file (194ms)

    ✓ Can handle <End> with a count (140ms)

    ✓ Can handle <D-right> with a count (186ms)

    ✓ Can handle 'f' (53ms)

    ✓ Can handle 'f' twice (224ms)

    ✓ Can handle 'f' with <tab> (161ms)

    ✓ Can handle 'f' and find back search (210ms)

    ✓ Can handle 'F' (170ms)

    ✓ Can handle 'F' twice (308ms)

    ✓ Can handle 'F' and find back search (190ms)

    ✓ Can handle 'f' and multiple back searches (162ms)

    ✓ Can handle 't' (214ms)

    ✓ Can handle 't' twice (196ms)

    ✓ Can handle 't' and find back search (160ms)

    ✓ Can handle 'T' (193ms)

    ✓ Can handle 'T' twice (69ms)

    ✓ Can handle 'T' and find back search (209ms)

    ✓ Can run a forward search (162ms)

    ✓ Can run a forward and find next search (179ms)

    ✓ Can run a forward and find previous search from end of word (125ms)

    ✓ Can run a reverse search (79ms)

    ✓ Can run a reverse and find next search (116ms)

    ✓ cancelled search reverts to previous search state (301ms)

    ✓ Backspace on empty search cancels (211ms)

    ✓ Search offsets: b does nothing (183ms)

    ✓ Search offsets: b2 goes 2 to the right (225ms)

    ✓ Search offsets: b+3 goes 3 to the right (182ms)

    ✓ Search offsets: e goes to the end (170ms)

    ✓ Search offsets: character offset goes across line boundaries (219ms)

    ✓ Search offsets: 2 goes 2 down (67ms)

    ✓ Search offsets: -2 goes 2 up (56ms)

    ✓ maintains column position correctly (149ms)

    ✓ maintains column position correctly with $ (214ms)

    ✓ Can handle G  (101ms)

    ✓ Can handle G with number prefix (130ms)

    ✓ Can handle G with number prefix (196ms)

    ✓ Can handle gg (51ms)

    ✓ Can handle gg with number prefix (55ms)

    ✓ Can handle 0 (167ms)

    ✓ Can handle 0 as part of a repeat (68ms)

    ✓ Can handle g* (46ms)

    ✓ Can handle g*n (64ms)

    ✓ Can handle * (164ms)

    ✓ Can handle ** (194ms)

    ✓ Can handle # on whitespace (65ms)

    ✓ Can handle # on EOL (58ms)

    ✓ Can handle g# (138ms)

    ✓ Can handle g#n (114ms)

    ✓ Can handle # (439ms)

    ✓ Can handle # already on the word (41ms)

    ✓ Can handle ## (79ms)

    ✓ * adds to search history (199ms)

    ✓ # adds to search history (194ms)

    ✓ Can handle | (97ms)

    ✓ Can handle <number> | (97ms)

    ✓ Can handle + (146ms)

    ✓ Can handle + indent (178ms)

    ✓ Can handle + with count prefix (169ms)

    ✓ Can handle - (48ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _ (38ms)

    ✓ Can handle _ with count prefix (46ms)

    ✓ Can handle g_ (49ms)

    ✓ Can handle g_ with count prefix (48ms)

    ✓ Can handle <up> key (45ms)

    ✓ Can handle <down> key (45ms)

    ✓ Can handle <left> key (63ms)

    ✓ Can handle <right> key (40ms)

    ✓ Can handle 'gk' (65ms)

    ✓ Can handle 'gj' (42ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin
    ✓ line end
    ✓ document begin
    ✓ document end
    ✓ line begin cursor on first non-blank character
    ✓ last line begin cursor on first non-blank character
    line up
      ✓ should move cursor one line up
      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)
    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally
      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (38ms)

        ✓ <left> wraps to previous line (46ms)

        ✓ <right> wraps to next line (45ms)

      insert mode

        ✓ <left> wraps to previous line (41ms)

        ✓ <right> once goes to end of line (183ms)

        ✓ <right> twice wraps to next line (178ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (207ms)

        ✓ l does not wrap to next line (133ms)

        ✓ <left> does not wrap to previous line (165ms)

        ✓ <right> does not wrap to next line (206ms)

      insert mode

        ✓ <left> does not wrap to previous line (182ms)

        ✓ <right> does not wrap to next line (214ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (172ms)

      ✓ search wraps around the start of the file (251ms)

    wrapscan disabled

      ✓ search stops at the end of the file (482ms)

      ✓ search stops at the start of the file (114ms)

  Multicursor

    ✓ can add multiple cursors below (131ms)

    ✓ can add multiple cursors above (229ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip

  comment operator

    ✓ gcc comments out current line (331ms)

    ✓ gcj comments in current and next line (261ms)

    ✓ block comment with motion (261ms)

    ✓ block comment in Visual Mode (235ms)

    ✓ comment in visual line mode (130ms)

    ✓ comment in visual block mode (247ms)

  format operator

    ✓ == formats current line (394ms)

    ✓ =$ formats entire line (345ms)

    ✓ =j formats two lines (199ms)

    ✓ 3=k formats three lines (228ms)

    ✓ =gg formats to top of file (207ms)

    ✓ =G formats to bottom of file (110ms)

    ✓ =ip formats paragraph (323ms)

    ✓ format in visual mode (220ms)

  put operator

    ✓ basic put test (59ms)

    ✓ test yy end of line (64ms)

    ✓ test yy first line (196ms)

    ✓ test yy middle line (157ms)

    ✓ test yy with correct positon movement (209ms)

    ✓ test visual block single line yank p (175ms)

    ✓ test visual block single line yank P (546ms)

    ✓ test visual block single line delete p (183ms)

    ✓ test visual block single line delete P (173ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (168ms)

    ✓ shift left goto end test (300ms)

    ✓ shift left goto line test (51ms)

    ✓ shift right goto end test (52ms)

    ✓ shift right goto line test (43ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (197ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (159ms)

      ✓ step to Camel word (107ms)

      ✓ step to CAP word (202ms)

      ✓ step after CAP word (130ms)

      ✓ step from middle of word to Camel word (207ms)

      ✓ step to number word (173ms)

      ✓ step to operator word (198ms)

      ✓ step from inside operator word (169ms)

      ✓ step to operator and then over (143ms)

    handles <leader>w for underscore_var

      ✓ step to _word (172ms)

      ✓ step over whitespace to word (141ms)

      ✓ step from inside word to _word (79ms)

      ✓ step form _word to number (190ms)

      ✓ step from nubmer word to _word (173ms)

      ✓ step from in whitespace to word (58ms)

      ✓ step in ALL_CAPS_WORD (49ms)

    handles d<leader>w

      ✓ delete from start of camelWord

      ✓ delete from middle of camelWord (54ms)

      ✓ delete from start of CamelWord (113ms)

      ✓ delete two words from camelWord (208ms)

      ✓ delete from start of underscore_word (159ms)

      ✓ delete from middle of underscore_word (198ms)

      ✓ delete two words from camel_word (143ms)

    handles di<leader>w

      ✓ delete from start of camelWord (176ms)

      ✓ delete from middle of camelWord (112ms)

      ✓ delete from start of CamelWord (322ms)

      ✓ delete two words from camelWord (216ms)

      ✓ delete from start of underscore_word (146ms)

      ✓ delete from middle of underscore_word (203ms)

      ✓ delete two words from camel_word (62ms)

    handles <leader>b

      ✓ back from middle of word (211ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (120ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (46ms)

      ✓ from middle to end of underscore_word (66ms)

      ✓ twice to end of word over operator (208ms)

  easymotion plugin

    ✓ Can handle s move (187ms)

    ✓ Can handle 2s move (147ms)

    ✓ Can handle f move (196ms)

    ✓ Can handle 2f move (178ms)

    ✓ Can handle F move (318ms)

    ✓ Can handle 2F move (194ms)

    ✓ Can handle t move (171ms)

    ✓ Can handle bd-t move (131ms)

    ✓ Can handle 2t move (81ms)

    ✓ Can handle bd-t2 move (465ms)

    ✓ Can handle T move (92ms)

    ✓ Can handle 2T move (65ms)

    ✓ Can handle w move (220ms)

    ✓ Can handle bd-w move (182ms)

    ✓ Can handle b move (156ms)

    ✓ Can handle e move (222ms)

    ✓ Can handle bd-e move (131ms)

    ✓ Can handle ge move (55ms)

    ✓ Can handle n-char move (76ms)

    ✓ Can handle j move (222ms)

    ✓ Can handle k move (440ms)

    ✓ Can handle bd-jk move (1) (100ms)

    ✓ Can handle bd-jk move (2) (198ms)

    ✓ Can handle lineforward move (1) (130ms)

    ✓ Can handle lineforward move (2) (176ms)

    ✓ Can handle linebackward move (1) (195ms)

    ✓ Can handle linebackward move (2) (176ms)

    ✓ Can handle searching for backslash (\) (92ms)

    ✓ Can handle searching for carat (^) (82ms)

    ✓ Can handle searching for dot (.) (213ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (116ms)

    ✓ Replaces within inner Word (153ms)

    ✓ Replaces within '' (215ms)

    ✓ Replaces within '' including spaces (182ms)

    ✓ Replaces within () (235ms)

    ✓ Replaces within () including spaces (186ms)

    ✓ Replaces within a paragraph (439ms)

    ✓ Replaces using a specified register (141ms)

    ✓ Replaces within {} over multiple lines (210ms)

    ✓ Replaces a multiline register within {} over multiple lines (156ms)

    ✓ Replaces a multiline register within {} over multiple lines (128ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (210ms)

    ✓ grr replaces the entire line with the register (90ms)

    ✓ grr can replace multiple lines (124ms)

    ✓ Replaces in visual mode (173ms)

    ✓ Replaces in visual mode using a specified register (250ms)

    ✓ Replaces in visual line mode (163ms)

    ✓ grj is linewise (205ms)

  sneak plugin

    ✓ Can handle s motion (157ms)

    ✓ Can handle S motion (204ms)

    ✓ Can handle <operator>z motion (105ms)

    ✓ Can handle <operator>Z motion (163ms)

    ✓ Can handle s; motion (189ms)

    ✓ Can handle s, motion (369ms)

    ✓ Can handle S; motion (104ms)

    ✓ Can handle S, motion (209ms)

    ✓ Can handle single letter s motion (85ms)

    ✓ Can handle single letter S motion (110ms)

    ✓ Can handle single letter <operator>z motion (204ms)

    ✓ Can handle single letter <operator>Z motion (157ms)

    ✓ Can handle single letter s; motion (202ms)

    ✓ Can handle single letter s, motion (178ms)

    ✓ Can handle single letter S; motion (85ms)

    ✓ Can handle single letter S, motion (213ms)

    ✓ Can handle multiline single char <number>s motion (171ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (180ms)

    ✓ 'ysiw(' surrounds word with space (212ms)

    ✓ 'ysw)' surrounds word without space (144ms)

    ✓ 'ysw(' surrounds word with space (165ms)

    ✓ 'ysaw)' surrounds word without space (146ms)

    ✓ 'ysaw(' surrounds word with space (351ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (128ms)

    ✓ 'ysiw<' surrounds word with tags (180ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (113ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (179ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (81ms)

    ✓ change surround (98ms)

    ✓ change surround with two pairs of quotes (497ms)

    ✓ change surround with two pairs of parens (111ms)

    ✓ change surround with alias (221ms)

    ✓ change surround to tags (169ms)

    ✓ delete surround (116ms)

    ✓ delete surround with quotes (155ms)

    ✓ delete surround with nested of quotes (97ms)

    ✓ delete surround with inconsistent quotes (186ms)

    ✓ delete surround with mixed quotes (120ms)

    ✓ delete surround with empty quotes cursor at start (182ms)

    ✓ delete surround with empty quotes cursor at end (134ms)

    ✓ don't delete surround if cursor is after closing match (172ms)

    ✓ delete surround if cursor is before opening match (162ms)

    ✓ delete surround with two pairs of parens (82ms)

    ✓ delete surround with alias (204ms)

    ✓ delete surround with tags (195ms)

    ✓ change surround brackets at end of line (149ms)

    ✓ changing brackets with surround works again (146ms)

    ✓ change surround with tags that contain an attribute and preserve them (154ms)

    ✓ change surround with tags that contain an attribute and remove them (168ms)

  register

    ✓ Can copy to a register (172ms)

    ✓ Can use two registers together (97ms)

    ✓ Can use black hole register (221ms)

    ✓ System clipboard works with chinese characters (47ms)

    ✓ Yank stores text in Register '0' (196ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (225ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (193ms)

    ✓ Register '1'-'9' stores delete content (278ms)

    ✓ "A appends linewise text to "a (238ms)

    ✓ "A appends character wise text to "a (236ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (194ms)

    ✓ Small deletion using Del is stored in small delete register (188ms)

    ✓ Small deletion using X is stored in small delete register (178ms)

    ✓ Search register (/) is set by forward search (308ms)

    ✓ Search register (/) is set by backward search (562ms)

    ✓ Search register (/) is set by star search (252ms)

    ✓ Command register (:) is set by command line (88ms)

    ✓ Read-only registers cannot be written to (848ms)

    clipboard

      ✓ Can access '*' (clipboard) register (156ms)

      ✓ Can access '+' (clipboard) register (196ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (157ms)

    ✓ Can repeat reversed F<character> (206ms)

    ✓ Can repeat t<character> (195ms)

    ✓ Can repeat N times reversed t<character> (163ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (181ms)

      ✓ move one sentence backward (154ms)

      ✓ move [count] sentences backward (182ms)

      ✓ move one sentence backward single line - middle (146ms)

      ✓ move one sentence backward no space (164ms)

      ✓ move one sentence backward no space - middle (109ms)

      ✓ move one sentence backward - multiline (118ms)

      ✓ move one sentence backward - multiline - period (153ms)

      ✓ move one sentence backward - multiline - previous line (180ms)

      ✓ move one sentence backward - multiline - previous line - period (93ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path
    separatePath
      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix
    resolveUri
      ✓ posix

      ✓ win32
  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=�������������.
      + expected - actual

      -�������������
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=a��.
      + expected - actual

      -a��
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=a��.
      + expected - actual

      -a��
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.40.2 into .vscode-test/vscode-1.40.2.
Downloading VS Code from: https://update.code.visualstudio.com/1.40.2/linux-x64/stable
Downloaded VS Code 1.40.2
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.40.2/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-12T08:42:15.235Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (40ms)

    ✓ command <C-w> can remove word in search mode (73ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character (43ms)

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (76ms)

    ✓ <C-p>/<C-n> go to the previous/next command (60ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (94ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line

    ✓ <C-r> <C-w> insert word under cursor in search mode

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command (38ms)

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (60ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar
    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (549ms)

    ✓ :smile editor contains smile text (549ms)

  Basic sort

    ✓ Sort whole file, asc (201ms)

    ✓ Sort whole file, asc, ignoreCase (144ms)

    ✓ Sort whole file, dsc (241ms)

    ✓ Sort whole file, dsc, ignoreCase (150ms)

    ✓ Sort range, asc (146ms)

    ✓ Sort range, asc, ignoreCase (324ms)

    ✓ Sort range, dsc (184ms)

    ✓ Sort range, dsc, ignoreCase (118ms)

    ✓ Sort whole file, asc, unique (282ms)

  Horizontal split

    ✓ Run :sp (79ms)

    ✓ Run :split (71ms)

    ✓ Run :new (85ms)

  :close args parser

    ✓ can parse empty args
    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args
    ✓ can parse an absolute position
    ✓ can parse a relative position
    ✓ fails with invalid inputs
  getParser
    ✓ empty
    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (52ms)

    ✓ Replace with `g` flag (59ms)

    ✓ Replace with flags AND count (113ms)

    ✓ Replace with `c` flag (45ms)

    ✓ Replace with `gc` flag (80ms)

    ✓ Replace across all lines (99ms)

    ✓ Replace on specific single line (110ms)

    ✓ Replace on current line using dot (92ms)

    ✓ Replace single relative line using dot and plus (111ms)

    ✓ Replace across specific line range (94ms)

    ✓ Replace across relative line range using dot, plus, and minus (158ms)

    ✓ Replace across relative line range using numLines+colon shorthand (116ms)

    ✓ Repeat replacement across relative line range (119ms)

    ✓ Replace with range AND count but no flags (143ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (145ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (91ms)

    ✓ Undocumented: trailing operators use 1 as RHS (107ms)

    ✓ Replace specific single equal lines (80ms)

    ✓ Replace current line with no active selection (97ms)

    ✓ Replace text in selection (115ms)

    ✓ Substitute support marks (94ms)
    Effects of gdefault=true

      ✓ Replace all matches in the line (82ms)

      ✓ Replace with `g` flag inverts global flag (51ms)

      ✓ Replace with `c` flag inverts global flag (96ms)

      ✓ Replace multiple lines (115ms)

      ✓ Replace across specific lines (100ms)

      ✓ Replace current line with no active selection (88ms)

      ✓ Replace text in selection (131ms)

      ✓ Substitute support marks (125ms)

      ✓ Substitute with escaped delimiter (81ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (199ms)

      ✓ Substitute with previous search using # (232ms)

      ✓ Substitute with previous search using / (208ms)

      ✓ Substitute with parameters should update search state (132ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (246ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (205ms)

      ✓ Substitute repeat previous should accept flags (261ms)

      ✓ Substitute with empty search string should use last searched pattern (227ms)

      ✓ Ampersand (&) should repeat the last substitution (100ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (78ms)

    ✓ tabe with current file path does nothing (61ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (68ms)

    ✓ command line file tab completion with space in file path (110ms)

  Vertical split

    ✓ Run :vs (69ms)

    ✓ Run :vsp (70ms)

    ✓ Run :vsplit (76ms)

    ✓ Run :vnew (305ms)

    ✓ Run :vne (240ms)

  Basic write-quit

    ✓ Run write and quit (106ms)
  Provide line completions
    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (52ms)

      ✓ Can complete lines in file with different indentation (45ms)

      ✓ Returns no completions for unmatched line (61ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (40ms)

  Notation

    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (79ms)

    ✓ getMatchingRemap (107ms)

    ✓ jj -> <Esc> through modehandler (93ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (115ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (96ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (87ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (139ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (148ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (156ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (154ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps
    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim
      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (106ms)

        ✓ Can track jumps for keys: GggG (215ms)

        ✓ Can track jumps for keys: GggGgg (191ms)

        ✓ Can track jumps for keys: /b<CR>n (127ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (256ms)

        ✓ Can track jumps for keys: j%% (184ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (212ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (204ms)

        ✓ Can track jumps for keys: j%%<C-o>% (176ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (261ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (63ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (104ms)

        ✓ Can enter number to jump back multiple times (222ms)

        ✓ Can track one-line `` jumps (194ms)

        ✓ Can track one-line double `` jumps (93ms)

[main 2019-12-12T08:42:45.238Z] update#setState checking for updates

[main 2019-12-12T08:42:45.294Z] update#setState idle

        ✓ Can track one-line '' jumps (257ms)

        ✓ Can track one-line double '' jumps (182ms)

        ✓ Can handle '' jumps with no previous jump (213ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (223ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (173ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (276ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (216ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (221ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (313ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (220ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (293ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (177ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (215ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (226ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (188ms)

  Record and execute a macro

    ✓ Can record and execute (306ms)

    ✓ Can repeat last invoked macro (235ms)

    ✓ Can play back with count (458ms)

    ✓ Can play back with count, abort when a motion fails (503ms)

    ✓ Repeat change on contiguous lines (233ms)

    ✓ Append command to a macro (220ms)

    ✓ Can record Ctrl Keys and repeat (132ms)

    ✓ Can execute macros with dot commands properly (157ms)

    ✓ : (command) register can be used as a macro (250ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (124ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (44ms)

    ✓ <C-c> can exit insert (114ms)

    ✓ <Esc> can exit insert (59ms)

    ✓ Stay in insert when entering characters (61ms)

    ✓ Can handle 'O' (56ms)

    ✓ Can handle 'i' (97ms)

    ✓ Can handle 'I' (104ms)

    ✓ Can handle 'a' (120ms)

    ✓ Can handle 'A' (69ms)

    ✓ Can handle '<C-w>' (78ms)

    ✓ Can handle <C-w> on leading whitespace (59ms)

    ✓ Can handle <C-w> at beginning of line (82ms)

    ✓ Can handle <C-u> (73ms)

    ✓ Can handle <C-u> on leading characters (150ms)

    ✓ Can handle <C-u> on leading whitespace (122ms)

    ✓ Correctly places the cursor after deleting the previous line break (65ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (41ms)

    ✓ Backspace works on whitespace only lines (88ms)

    ✓ Backspace works on end of whitespace only lines (93ms)

    ✓ Backspace works at beginning of file (84ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (107ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (135ms)

    ✓ Can perform insert command prefixed with count (73ms)

    ✓ Can perform append command prefixed with count (62ms)

    ✓ Can perform insert at start of line command prefixed with count (64ms)

    ✓ Can perform append to end of line command prefixed with count (79ms)

    ✓ Can perform change char (s) command prefixed with count (183ms)

    ✓ Can perform command prefixed with count with <C-[> (62ms)

    ✓ Can handle 'o' with count (116ms)

    ✓ Can handle 'O' with count (111ms)

    ✓ Can handle backspace at beginning of line with all spaces (219ms)

    ✓ Can handle digraph insert (170ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (85ms)

    ✓ Can handle dw (47ms)

    ✓ Can handle dw (40ms)

    ✓ Can handle dw across lines (1) (71ms)

    ✓ Can handle dw across lines (2) (79ms)

    ✓ Can handle dd last line (124ms)

    ✓ Can handle dd single line (40ms)

    ✓ Can handle dd (79ms)

    ✓ Can handle 3dd (51ms)

    ✓ Can handle 3dd off end of document (47ms)

    ✓ Can handle d2d (77ms)

    ✓ Can handle dd empty line (56ms)

    ✓ Can handle ddp (121ms)

    ✓ Can handle 'de' (72ms)

    ✓ Can handle 'de' then 'de' again (117ms)

    ✓ Can handle 'db' (54ms)

    ✓ Can handle 'db then 'db' again (119ms)

    ✓ Can handle 'dl' at end of line (168ms)

    ✓ Can handle 'dF' (209ms)

    ✓ Can handle 'dT' (70ms)

    ✓ Can handle 'd3' then <enter> (64ms)

    ✓ Can handle 'dj' (112ms)

    ✓ Can handle 'dk' (71ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (54ms)

    ✓ Can handle 'd]}' without deleting closing bracket (87ms)

    ✓ Can handle 'cw' (162ms)

    ✓ Can handle 'cw' without deleting following white spaces (78ms)

    ✓ Can handle 'c2w' (38ms)

    ✓ Can handle 'cw' without removing EOL (122ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (110ms)

    ✓ Can handle 'c]}' without deleting closing bracket (239ms)

    ✓ Can handle 's' (163ms)

    ✓ Can handle 'yiw' with correct cursor ending position (98ms)

    ✓ Can handle 'ciw' (162ms)

    ✓ Can handle 'ciw' on blanks (182ms)

    ✓ Can handle 'caw' (111ms)

    ✓ Can handle 'caw' on first letter (129ms)

    ✓ Can handle 'caw' on blanks (187ms)

    ✓ Can handle 'caw' on blanks (69ms)

    ✓ Can handle 'ci(' on first parentheses (67ms)

    ✓ Can handle 'ci(' with nested parentheses (54ms)

    ✓ Can handle 'ci(' backwards through nested parens (82ms)

    ✓ Can handle 'cib' on first parentheses (99ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (112ms)

    ✓ Can handle count prefixed 'ci)' (114ms)

    ✓ Can handle count prefixed 'ca)' (121ms)

    ✓ Can handle 'ca(' spanning multiple lines (101ms)

    ✓ Can handle 'cab' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines (206ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (58ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (69ms)

    ✓ Can handle 'ci(' on the closing bracket (53ms)

    ✓ Can handle 'ciB' spanning multiple lines (132ms)

    ✓ will fail when ca( with no () (99ms)

    ✓ will fail when ca{ with no {} (51ms)

    ✓ will fail when caB with no {} (59ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (67ms)

    ✓ Can handle 'ca[' on first bracket (75ms)

    ✓ Can handle 'ca]' on first bracket (102ms)

    ✓ Can handle 'ci'' on first quote (57ms)

    ✓ Can handle 'ci'' inside quoted string (54ms)

    ✓ Can handle 'ci'' on closing quote (97ms)

    ✓ Can handle 'ci'' when string is ahead (67ms)

    ✓ Can handle 'ci"' on opening quote (55ms)

    ✓ Can handle 'ci"' starting behind the quoted word (91ms)

    ✓ Can handle 'ca"' starting behind the quoted word (81ms)

    ✓ Can handle 'ca"' starting on the opening quote (60ms)

    ✓ Can handle 'ci"' with escaped quotes (84ms)

    ✓ Can handle 'ci"' with a single escaped quote

    ✓ Can handle 'ci"' with a single escaped quote behind (127ms)

    ✓ Can handle 'ci"' with an escaped backslash (144ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (50ms)

    ✓ Can handle 'ca"' starting on the closing quote (84ms)

    ✓ Can handle 'ci"' with complex escape sequences (54ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (74ms)

    ✓ will fail when ca" ahead of quoted string (70ms)

    ✓ Can handle 'ca`' inside word (54ms)

    ✓ can handle cj (132ms)

    ✓ can handle ck (133ms)

    ✓ can handle c2j (118ms)

    ✓ can handle c2k (84ms)

    ✓ can handle cj on last line (92ms)

    ✓ can handle ck on first line (90ms)

    ✓ can handle c2j on last line (122ms)

    ✓ can handle c2k on first line (119ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (219ms)

    ✓ Can handle 'daw' on word with trailing spaces (67ms)

    ✓ Can handle 'daw' on word with leading spaces (107ms)

    ✓ Can handle 'daw' on word with numeric prefix (169ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (152ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (128ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (121ms)

    ✓ Can handle 'daw' on end of word (134ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (51ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (90ms)

    ✓ Can handle 'daw' on word at beginning of file (55ms)

    ✓ Can handle 'daw' on word at beginning of line (129ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (133ms)

    ✓ Can handle 'daw' around word at end of line (138ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (95ms)

    ✓ Can handle 'daW' around word at whitespace (124ms)

    ✓ Can handle 'daW' on word with trailing spaces (74ms)

    ✓ Can handle 'daW' on word with leading spaces (176ms)

    ✓ Can handle 'daW' on word with numeric prefix (79ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (199ms)

    ✓ Can handle 'daW' on beginning of word (46ms)

    ✓ Can handle 'daW' on end of one line (51ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (64ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (87ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (228ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (126ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (189ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (68ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (66ms)

    ✓ Can handle 'diw' on word (142ms)

    ✓ Can handle 'diw' on word with numeric prefix (53ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (110ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (131ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (202ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (81ms)

    ✓ Can handle 'diW' on word with trailing spaces (65ms)

    ✓ Can handle 'diW' on word with leading spaces (84ms)

    ✓ Can handle 'diW' on word with numeric prefix (71ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (114ms)

    ✓ Can handle 'diW' on beginning of word (114ms)

    ✓ Can handle d} (206ms)

    ✓ Can handle y} at beginning of line (161ms)

    ✓ Select sentence with trailing spaces (89ms)

    ✓ Select sentence with leading spaces (153ms)

    ✓ Select inner sentence with trailing spaces (209ms)

    ✓ Select inner sentence with leading spaces (130ms)

    ✓ Select spaces between sentences (139ms)

    ✓ Can handle 'df' (218ms)

    ✓ Can handle 'dt' (174ms)

    ✓ Can handle backspace (208ms)

    ✓ Can handle backspace across lines (84ms)

    ✓ Can handle A and backspace (222ms)

    ✓ Can handle 'yy' without changing cursor position (159ms)

    ✓ Can handle 'P' after 'yy' (224ms)

    ✓ Can handle 'p' after 'yy' (151ms)

    ✓ Can handle 'P' after 'Nyy' (215ms)

    ✓ Can handle 'p' after 'Nyy' (52ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (131ms)

    ✓ Can handle 'gp' after 'yy' (67ms)

    ✓ Can handle 'gp' after 'Nyy' (73ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (64ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (74ms)

    ✓ Can handle 'gP' after 'yy' (227ms)

    ✓ Can handle 'gP' after 'Nyy' (180ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (180ms)

    ✓ Can handle ']p' after yy (58ms)

    ✓ Can handle ']p' after 'Nyy' (71ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (60ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (75ms)

    ✓ Can handle '[p' after yy (55ms)

    ✓ Can handle '[p' after 'Nyy' (76ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (198ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (174ms)

    ✓ Can handle 'p' after y'a (241ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (81ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (221ms)

    ✓ Can handle pasting in visual mode over selection (177ms)

    ✓ Can repeat w (202ms)

    ✓ Can repeat p (181ms)

    ✓ I works correctly (281ms)

    ✓ gI works correctly (136ms)

    ✓ gi works correctly (271ms)

    ✓ `. works correctly (92ms)

    ✓ '. works correctly (234ms)

    ✓ g; works correctly (159ms)

    ✓ g, works correctly (270ms)

    ✓ g_ works correctly (219ms)

    ✓ 3g_ works correctly (165ms)

    ✓ gq handles spaces after single line comments correctly (353ms)

    ✓ gq handles spaces before single line comments correctly (310ms)

    ✓ gq handles tabs before single line comments correctly (392ms)

    ✓ Can handle space (58ms)

    ✓ Can handle space (211ms)

    ✓ Undo 1 (278ms)

    ✓ Undo 2 (146ms)

    ✓ Undo cursor (293ms)

    ✓ Undo cursor 2 (167ms)

    ✓ Undo cursor 3 (279ms)

    ✓ Undo with movement first (129ms)

    ✓ Can handle 'U' (330ms)

    ✓ Can handle 'U' for multiple changes (227ms)

    ✓ Can handle 'U' for new line below (195ms)

    ✓ Can handle 'U' for new line above (284ms)

    ✓ Can handle 'U' for consecutive changes only (518ms)

    ✓ Can handle 'u' to undo 'U' (122ms)

    ✓ Can handle 'U' to undo 'U' (235ms)

    ✓ Redo (148ms)

    ✓ Redo (289ms)

    ✓ Redo (114ms)

    ✓ Can handle u (248ms)

    ✓ Can handle guw (125ms)

    ✓ Can handle gUw (215ms)

    ✓ Can handle u over line breaks (165ms)

    ✓ can handle s in visual mode (185ms)

    ✓ can handle p with selection (148ms)

    ✓ can handle P with selection (114ms)

    ✓ can handle p in visual to end of line (295ms)

    ✓ can repeat backspace twice (214ms)

    ✓ can delete linewise with d2G (184ms)

    ✓ can delete with + motion and count (214ms)

    ✓ can delete with - motion and count (54ms)

    ✓ can dE correctly (228ms)

    ✓ can dE correctly (91ms)

    ✓ can dE correctly (212ms)

    ✓ can ctrl-a correctly behind a word (159ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (202ms)

    ✓ can ctrl-a on word (97ms)

    ✓ can ctrl-a on a hex number (214ms)

    ✓ can ctrl-a on decimal (162ms)

    ✓ can ctrl-a with numeric prefix (204ms)

    ✓ can ctrl-a on a decimal (157ms)

    ✓ can ctrl-a on an octal  (219ms)

    ✓ Correctly increments in the middle of a number (133ms)

    ✓ can ctrl-x correctly behind a word (177ms)

    ✓ can ctrl-a on an number with word before  (69ms)

    ✓ can ctrl-a on an number with word before and after  (67ms)

    ✓ can ctrl-x on a negative number with word before and after  (53ms)

    ✓ can ctrl-a properly on multiple lines (57ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (45ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (49ms)

    ✓ can <C-a> on word with - in front of it (48ms)

    ✓ can do Y (74ms)

    ✓ Can do S (51ms)

    ✓ / does not affect mark (221ms)

    ✓ / can search with regex (148ms)

    ✓ / can search with newline (127ms)

    ✓ / can search through multiple newlines (251ms)

    ✓ / matches ^ per line (169ms)

    ✓ / matches $ per line (193ms)

    ✓ Can search for forward slash (118ms)

    ✓ Can search backward for question mark (76ms)

    ✓ /\c forces case insensitive search (59ms)

    ✓ /\C forces case sensitive search (68ms)

    ✓ <BS> deletes the last character in search in progress mode (50ms)

    ✓ <S-BS> deletes the last character in search in progress mode (49ms)

    ✓ <C-h> deletes the last character in search in progress mode (74ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (95ms)

    ✓ Ignores cit on a non-matching tag (213ms)

    ✓ Ignores cit on a nested tag (170ms)

    ✓ Can do cit on a tag with an attribute tag (198ms)

    ✓ Can do cat on a matching tag (301ms)

    ✓ Can do cit on a multiline tag (146ms)

    ✓ Can do cit on a multiline tag with nested tags (104ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (117ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (215ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (162ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (219ms)

    ✓ can do cit with self closing tags (175ms)

    ✓ Respects indentation with cc (94ms)

    ✓ Resets cursor to indent end with cc (224ms)

    ✓ can handle 'cc' on empty line (154ms)

    ✓ cc copies linewise (214ms)

    ✓ Indent current line with correct Vim Mode (147ms)

    ✓ Can handle <Esc> and do nothing (205ms)

    ✓ Can handle # on consecutive words (80ms)

    ✓ Can handle # on skipped words (155ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (105ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (219ms)

    ✓ cc on whitespace-only treats whitespace as indent (154ms)

    ✓ Can do cai (212ms)

    ✓ Can do cii (65ms)

    ✓ Can do caI (114ms)

    ✓ Can do dai (161ms)

    ✓ Can do dii (41ms)

    ✓ Can do daI (105ms)

    ✓ `] go to the end of the previously operated or put text (85ms)

    ✓ '] go to the end of the previously operated or put text (240ms)

    ✓ `[ go to the start of the previously operated or put text (183ms)

    ✓ '[ go to the start of the previously operated or put text (385ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (172ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (195ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (116ms)

    can handle gn

      ✓ gn selects the next match text (259ms)

      ✓ gn selects the current word at |hello (289ms)

      ✓ gn selects the current word at h|ello (230ms)

      ✓ gn selects the current word at hel|lo (237ms)

      ✓ gn selects the current word at hell|o (184ms)

      ✓ gn selects the next word at hello| (247ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (119ms)

      ✓ dgn deletes the current word when cursor is at |hello (233ms)

      ✓ dgn deletes the current word when cursor is at h|ello (192ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (189ms)

      ✓ dgn deletes the current word when cursor is at hell|o (139ms)

      ✓ dgn deletes the next word when cursor is at hello| (234ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (152ms)

      ✓ cgn deletes the current word when cursor is at |hello (222ms)

      ✓ cgn deletes the current word when cursor is at h|ello (179ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (244ms)

      ✓ cgn deletes the current word when cursor is at hell|o (163ms)

      ✓ cgn deletes the next word when cursor is at hello| (115ms)

    can handle gN

      ✓ gN selects the previous match text (525ms)

      ✓ gN selects the current word at hell|o (322ms)

      ✓ gN selects the current word at hel|lo (288ms)

      ✓ gN selects the current word at h|ello (231ms)

      ✓ gN selects the current word at |hello (216ms)

      ✓ gN selects the previous word at | hello (228ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (70ms)

      ✓ dgN deletes the current word when cursor is at hell|o (80ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (171ms)

      ✓ dgN deletes the current word when cursor is at h|ello (214ms)

      ✓ dgN deletes the current word when cursor is at |hello (158ms)

      ✓ dgN deletes the previous word when cursor is at | hello (179ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (234ms)

      ✓ cgN deletes the current word when cursor is at hell|o (136ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (264ms)

      ✓ cgN deletes the current word when cursor is at h|ello (182ms)

      ✓ cgN deletes the current word when cursor is at |hello (234ms)

      ✓ cgN deletes the previous word when cursor is at | hello (297ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (156ms)

    ✓ Can activate with R from Normal mode (190ms)

    ✓ Can handle R (186ms)

    ✓ Can handle R past current line (181ms)

    ✓ Can handle R and exit Replace Mode (199ms)

    ✓ Can handle R across lines (310ms)

    ✓ Can handle R across lines and exit Replace Mode (164ms)

    ✓ Can handle R with {count} (195ms)

    ✓ Can handle backspace (182ms)

    ✓ Can handle backspace (202ms)

    ✓ Can handle backspace across lines (227ms)

    ✓ Can handle arrows (147ms)

    ✓ Can handle . (231ms)

    ✓ Can handle . across lines (202ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (133ms)

    ✓ Can handle wd (139ms)

    ✓ Can handle x (119ms)

    ✓ Can handle x across a selection (117ms)

    ✓ Can do vwd in middle of sentence (248ms)

    ✓ Can do vwd in middle of sentence (116ms)

    ✓ Can do vwd multiple times (182ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (126ms)

    ✓ Can handle H key (215ms)

    ✓ Can handle backspace key (167ms)

    ✓ handles case where we delete over a newline (186ms)

    ✓ handles change operator (116ms)

    ✓ Can do vat on multiple matching tags (222ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (187ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (286ms)

    ✓ Repeat-prefixed vat does not bleed below (114ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (45ms)

    ✓ Can do vi) on a matching parenthesis (235ms)

    ✓ Can do vi) on multiple matching parens (154ms)

    ✓ Can do va) on a matching parenthesis (211ms)

    ✓ Can do va) on multiple matching parens (173ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (230ms)

    ✓ Repeat-prefixed va) does not bleed below (86ms)

    ✓ Can do va} on a matching bracket as first character (60ms)

    ✓ Can do va} on multiple matching brackets (75ms)

    ✓ Can do vi( on a matching bracket near first character (220ms)

    ✓ Can do vi{ on outer pair of nested braces (77ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (79ms)

    ✓ Can do va] on multiple matching brackets (167ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (233ms)

    ✓ Repeat-prefixed vaf does not bleed below (167ms)

    ✓ vaf only expands to enclosing pairs (67ms)

    ✓ Can use . to repeat indent in visual (226ms)

    ✓ Can do v_x to delete to first char (306ms)

    ✓ Can do vg_x to delete to last char with no EOL (140ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (170ms)

    ✓ Can do v$x to delete to last char including EOL (56ms)

    ✓ Can do gv to reselect previous selection (173ms)

    Vim's EOL handling is weird

      ✓ delete through eol (131ms)

      ✓ join 2 lines by deleting through eol (224ms)

      ✓ d$ doesn't delete whole line (73ms)

      ✓ vd$ does delete whole line (84ms)

      ✓ Paste over selection copies the selection (242ms)

      ✓ Paste over selection copies the selection linewise (166ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (242ms)

      ✓ Can handle <down> key (159ms)

      ✓ Can handle <left> key (166ms)

      ✓ Can handle <right> key (223ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (152ms)

      ✓ Can handle 'gj' (230ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (156ms)

      ✓ Can handle 'vawd' on word with trailing spaces (236ms)

      ✓ Can handle 'vawd' on word with leading spaces (163ms)

      ✓ Can handle 'vawd' on word with numeric prefix (201ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (158ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (128ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (227ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (164ms)

      ✓ Can handle 'vaWd' on word with leading spaces (225ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (109ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (206ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (162ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (160ms)

      ✓ Can handle 'vaWd' on word with leading spaces (234ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (146ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (229ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (161ms)

      ✓ Can handle 'vawd' on word with trailing spaces (227ms)

      ✓ Can handle 'vawd' on word with leading spaces (174ms)

      ✓ Can handle 'vawd' on word with numeric prefix (147ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (211ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (179ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (232ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (267ms)

      ✓ Can handle 'vaWd' on word with leading spaces (234ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (163ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (229ms)

      ✓ Can handle 'Y' in visual mode (146ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (209ms)

      ✓ Select sentence with leading spaces in visual mode (167ms)

      ✓ Select multiple sentences in visual mode (210ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (161ms)

      ✓ Select inner sentence with leading spaces in visual mode (381ms)

      ✓ Select spaces between sentences in visual mode (124ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (218ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (164ms)

      ✓ Can do vat on a matching tag (225ms)

    handles replace in visual mode

      ✓ Can do a single line replace (111ms)

      ✓ Can do a multi line replace (260ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (91ms)

      ✓ D deletes the current line (156ms)

    handles indent blocks in visual mode

      ✓ Can do vai (218ms)

      ✓ Can do vii (72ms)

      ✓ Doesn't naively select the next line (69ms)

      ✓ Searches backwards if cursor line is empty (228ms)

      ✓ Can do vaI (338ms)

    visualstar

      ✓ Works with * (156ms)

      ✓ Works with # (61ms)

    search works in visual mode

      ✓ Works with / (65ms)

      ✓ Works with ? (84ms)

      ✓ Selects correct range (95ms)

    X will delete linewise

      ✓ normal selection (217ms)

      ✓ normal selection (180ms)

    C will delete linewise

      ✓ normal selection (245ms)

      ✓ normal selection (137ms)

    R will delete linewise

      ✓ normal selection (208ms)

      ✓ normal selection (161ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (218ms)

      ✓ upward selection (160ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (51ms)

      ✓ multiline indent bottom up selection (64ms)

      ✓ repeat multiline indent top down selection (196ms)

      ✓ repeat multiline indent bottom up selection (188ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (180ms)

      ✓ multiline outdent bottom up selection (67ms)

      ✓ repeat multiline outdent top down selection (274ms)

      ✓ repeat multiline outdent bottom up selection (249ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (121ms)

    vi{ will go to end of second to last line

      ✓ select (239ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (336ms)

      ✓ gv selects the last pasted text (which is longer than original) (379ms)

      ✓ gv selects the last pasted text (multiline) (184ms)

    can handle gn

      ✓ gn selects the next match text (196ms)

      ✓ gn selects the current word at |hello (449ms)

      ✓ gn selects the current word at h|ello (197ms)

      ✓ gn selects the current word at hel|lo (221ms)

      ✓ gn selects the next word at hell|o (223ms)

      ✓ gn selects the next word at hello| (197ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (51ms)

      ✓ multiline insert from top down selection (57ms)

      ✓ skips blank lines (66ms)

    can append text with A

      ✓ multiline append from bottom up selection (63ms)

      ✓ multiline append from top down selection (60ms)

      ✓ skips blank lines (215ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (195ms)

      ✓ U/gU across a selection (80ms)

      ✓ U/gU across a selection (reverse) (231ms)

      ✓ u/gu on single character (150ms)

      ✓ u/gu across a selection (269ms)

      ✓ u/gu across a selection (reverse) (149ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (118ms)

    ✓ Can handle A backwards select (229ms)

    ✓ Can handle I forward select (126ms)

    ✓ Can handle I backwards select (274ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (217ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (180ms)

    ✓ Can handle c forward select (57ms)

    ✓ Can handle c backwards select (77ms)

    ✓ Can handle C (226ms)

    ✓ Can do a multi line replace (159ms)

    ✓ Can handle 'D' (219ms)

    ✓ Can handle 'gj' (160ms)

    ✓ Properly add to end of lines j then $ (116ms)

    ✓ Properly add to end of lines $ then j (238ms)

    ✓ o works in visual block mode (151ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (155ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (145ms)

    ✓ Can handle wd (127ms)

    ✓ Can handle x (92ms)

    ✓ Can handle x across a selection (128ms)

    ✓ Can do vwd in middle of sentence (152ms)

    ✓ Can do vwd in middle of sentence (124ms)

    ✓ Can do vwd multiple times (164ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (131ms)

    ✓ handles case where we delete over a newline (163ms)

    ✓ handles change operator (93ms)

    ✓ Vp updates register content (236ms)

    ✓ Vp does not append unnecessary newlines (first line) (135ms)

    ✓ Vp does not append unnecessary newlines (middle line) (738ms)

    ✓ Vp does not append unnecessary newlines (last line) (412ms)

    Vim's EOL handling is weird

      ✓ delete through eol (114ms)

      ✓ join 2 lines by deleting through eol (84ms)

      ✓ d$ doesn't delete whole line (80ms)

      ✓ vd$ does delete whole line (139ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (85ms)

      ✓ Can handle <down> key (200ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (169ms)

      ✓ Can handle 'gj' (111ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (230ms)

      ✓ Can handle d key (135ms)

      ✓ Can handle d key (48ms)

      ✓ Can handle d key (69ms)

      ✓ can handle 'c' (68ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (201ms)

      ✓ Can do a multi visual line replace (179ms)

      ✓ Can do a multi visual line replace from the bottom up (94ms)

    search works in visual line mode

      ✓ Works with / (242ms)

      ✓ Works with ? (64ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (162ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (103ms)

      ✓ linewise visual put works also in the end of document (227ms)

      ✓ gv selects the last pasted text (which is shorter than original) (409ms)

      ✓ gv selects the last pasted text (which is longer than original) (371ms)

      ✓ gv selects the last pasted text (multiline) (299ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (222ms)

      ✓ skips blank lines (65ms)

    can append text with A

      ✓ multiline append from bottom up selection (174ms)

      ✓ multiline append from top down selection (137ms)

      ✓ skips blank lines (67ms)

  Mode Normal

    ✓ Can handle 'x' (99ms)

    ✓ Can handle 'Nx' (207ms)

    ✓ Can handle 'Nx' and paste (141ms)

    ✓ Can handle 'x' at end of line (272ms)

    ✓ Can handle 'Ns' (113ms)

    ✓ Can handle 'Ns' at end of line (164ms)

    ✓ Can handle '<Del>' (276ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (142ms)

    ✓ Can handle '<Del>' at end of line (126ms)

    ✓ Can handle 'cc' (219ms)

    ✓ Can handle 'Ncc' (143ms)

    ✓ Can handle 'yy' (172ms)

    ✓ Can handle 'D' (178ms)

    ✓ Can handle 'D' on empty lines (145ms)

    ✓ Can handle 'DD' (216ms)

    ✓ Can handle 'C' (155ms)

    ✓ Can handle 'NC' (199ms)

    ✓ Can handle 'NC' and put (143ms)

    ✓ Can handle 'r' (165ms)

    ✓ Can handle '<Count>r' (183ms)

    ✓ Can handle '<Count>r' (133ms)

    ✓ Can handle 'r' after 'dd' (211ms)

    ✓ Can handle 'r
' (932ms)

    ✓ Can handle '<Count>r
' (114ms)

    ✓ Can handle 'J' once (101ms)

    ✓ Can handle 'J' twice (203ms)

    ✓ Can handle 'J' with empty last line (155ms)

    ✓ Can handle 'J's with multiple empty last lines (252ms)

    ✓ Can handle 'J' with leading white space on next line (134ms)

    ✓ Can handle 'J' with only white space on next line (178ms)

    ✓ Can handle 'J' with TWO indented lines (142ms)

    ✓ Can handle 'J' with ')' first character on next line (198ms)

    ✓ Can handle 'J' with a following delete (98ms)

    ✓ Can handle 'J' in Visual Line mode (215ms)

    ✓ Can handle 'gJ' once (130ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (200ms)

    ✓ Can handle '~' (142ms)

    ✓ Can handle 'g~{motion}' (43ms)

    ✓ Can handle '<BS>' in insert mode (195ms)

    ✓ Can handle undo with P (173ms)

    ✓ Can handle 'ge' in multiple lines case1 (65ms)

    ✓ Can handle 'ge' in multiple lines case2 (93ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (199ms)

    ✓ Can repeat '~' with dot (158ms)

    ✓ Can repeat 'x' (210ms)

    ✓ Can repeat 'J' (146ms)

    ✓ Can handle dot with A (134ms)

    ✓ Can handle dot with I (295ms)

    ✓ Can repeat actions that require selections (107ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (257ms)

    ✓ Can repeat insert change and '<C-t>' (139ms)

    ✓ Can repeat change by `<C-a>` (257ms)

    ✓ Only one arrow key can be repeated in Insert Mode (143ms)

    ✓ Cached content change will be cleared by arrow keys (622ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (120ms)

    ✓ inside parenthesis (200ms)

    ✓ nested parenthesis beginning (108ms)

    ✓ nested parenthesis end (134ms)

    ✓ nested bracket and parenthesis beginning (201ms)

    ✓ nested bracket, parenthesis, braces beginning (163ms)

    ✓ nested bracket, parenthesis, braces end (209ms)

    ✓ parentheses after > (172ms)

    ✓ parentheses after " (169ms)

  Motions in Normal Mode

    ✓ Can handle [( (204ms)

    ✓ Can handle nested [( (135ms)

    ✓ Can handle <number>[( (203ms)

    ✓ Can handle [( and character under cursor exclusive (165ms)

    ✓ Can handle ]) (308ms)

    ✓ Can handle nested ]) (163ms)

    ✓ Can handle <number>]) (198ms)

    ✓ Can handle ]) and character under cursor exclusive (106ms)

    ✓ Can handle [{ (204ms)

    ✓ Can handle nested [{ (74ms)

    ✓ Can handle <number>[{ (206ms)

    ✓ Can handle [{ and character under cursor exclusive (168ms)

    ✓ Can handle ]} (164ms)

    ✓ Can handle nested ]} (158ms)

    ✓ Can handle <number>]} (215ms)

    ✓ Can handle ]} and character under cursor exclusive (171ms)

    ✓ Can handle 'ge' (139ms)

    ✓ Can handle 'gg' (211ms)

    ✓ Can handle 'gg' to first non blank char on random line (158ms)

    ✓ Can handle 'gg' to first non blank char on first line (193ms)

    ✓ 'gg' obeys startofline (340ms)

    ✓ Retain same column when moving up/down (171ms)

    ✓ Can handle <enter> (143ms)

    ✓ $ always keeps cursor on EOL (198ms)

    ✓ Can handle $ with a count (164ms)

    ✓ Can handle $ with a count at end of file (194ms)

    ✓ Can handle <End> with a count (140ms)

    ✓ Can handle <D-right> with a count (186ms)

    ✓ Can handle 'f' (53ms)

    ✓ Can handle 'f' twice (224ms)

    ✓ Can handle 'f' with <tab> (161ms)

    ✓ Can handle 'f' and find back search (210ms)

    ✓ Can handle 'F' (170ms)

    ✓ Can handle 'F' twice (308ms)

    ✓ Can handle 'F' and find back search (190ms)

    ✓ Can handle 'f' and multiple back searches (162ms)

    ✓ Can handle 't' (214ms)

    ✓ Can handle 't' twice (196ms)

    ✓ Can handle 't' and find back search (160ms)

    ✓ Can handle 'T' (193ms)

    ✓ Can handle 'T' twice (69ms)

    ✓ Can handle 'T' and find back search (209ms)

    ✓ Can run a forward search (162ms)

    ✓ Can run a forward and find next search (179ms)

    ✓ Can run a forward and find previous search from end of word (125ms)

    ✓ Can run a reverse search (79ms)

    ✓ Can run a reverse and find next search (116ms)

    ✓ cancelled search reverts to previous search state (301ms)

    ✓ Backspace on empty search cancels (211ms)

    ✓ Search offsets: b does nothing (183ms)

    ✓ Search offsets: b2 goes 2 to the right (225ms)

    ✓ Search offsets: b+3 goes 3 to the right (182ms)

    ✓ Search offsets: e goes to the end (170ms)

    ✓ Search offsets: character offset goes across line boundaries (219ms)

    ✓ Search offsets: 2 goes 2 down (67ms)

    ✓ Search offsets: -2 goes 2 up (56ms)

    ✓ maintains column position correctly (149ms)

    ✓ maintains column position correctly with $ (214ms)

    ✓ Can handle G  (101ms)

    ✓ Can handle G with number prefix (130ms)

    ✓ Can handle G with number prefix (196ms)

    ✓ Can handle gg (51ms)

    ✓ Can handle gg with number prefix (55ms)

    ✓ Can handle 0 (167ms)

    ✓ Can handle 0 as part of a repeat (68ms)

    ✓ Can handle g* (46ms)

    ✓ Can handle g*n (64ms)

    ✓ Can handle * (164ms)

    ✓ Can handle ** (194ms)

    ✓ Can handle # on whitespace (65ms)

    ✓ Can handle # on EOL (58ms)

    ✓ Can handle g# (138ms)

    ✓ Can handle g#n (114ms)

    ✓ Can handle # (439ms)

    ✓ Can handle # already on the word (41ms)

    ✓ Can handle ## (79ms)

    ✓ * adds to search history (199ms)

    ✓ # adds to search history (194ms)

    ✓ Can handle | (97ms)

    ✓ Can handle <number> | (97ms)

    ✓ Can handle + (146ms)

    ✓ Can handle + indent (178ms)

    ✓ Can handle + with count prefix (169ms)

    ✓ Can handle - (48ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _ (38ms)

    ✓ Can handle _ with count prefix (46ms)

    ✓ Can handle g_ (49ms)

    ✓ Can handle g_ with count prefix (48ms)

    ✓ Can handle <up> key (45ms)

    ✓ Can handle <down> key (45ms)

    ✓ Can handle <left> key (63ms)

    ✓ Can handle <right> key (40ms)

    ✓ Can handle 'gk' (65ms)

    ✓ Can handle 'gj' (42ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin
    ✓ line end
    ✓ document begin
    ✓ document end
    ✓ line begin cursor on first non-blank character
    ✓ last line begin cursor on first non-blank character
    line up
      ✓ should move cursor one line up
      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)
    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally
      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (38ms)

        ✓ <left> wraps to previous line (46ms)

        ✓ <right> wraps to next line (45ms)

      insert mode

        ✓ <left> wraps to previous line (41ms)

        ✓ <right> once goes to end of line (183ms)

        ✓ <right> twice wraps to next line (178ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (207ms)

        ✓ l does not wrap to next line (133ms)

        ✓ <left> does not wrap to previous line (165ms)

        ✓ <right> does not wrap to next line (206ms)

      insert mode

        ✓ <left> does not wrap to previous line (182ms)

        ✓ <right> does not wrap to next line (214ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (172ms)

      ✓ search wraps around the start of the file (251ms)

    wrapscan disabled

      ✓ search stops at the end of the file (482ms)

      ✓ search stops at the start of the file (114ms)

  Multicursor

    ✓ can add multiple cursors below (131ms)

    ✓ can add multiple cursors above (229ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip

  comment operator

    ✓ gcc comments out current line (331ms)

    ✓ gcj comments in current and next line (261ms)

    ✓ block comment with motion (261ms)

    ✓ block comment in Visual Mode (235ms)

    ✓ comment in visual line mode (130ms)

    ✓ comment in visual block mode (247ms)

  format operator

    ✓ == formats current line (394ms)

    ✓ =$ formats entire line (345ms)

    ✓ =j formats two lines (199ms)

    ✓ 3=k formats three lines (228ms)

    ✓ =gg formats to top of file (207ms)

    ✓ =G formats to bottom of file (110ms)

    ✓ =ip formats paragraph (323ms)

    ✓ format in visual mode (220ms)

  put operator

    ✓ basic put test (59ms)

    ✓ test yy end of line (64ms)

    ✓ test yy first line (196ms)

    ✓ test yy middle line (157ms)

    ✓ test yy with correct positon movement (209ms)

    ✓ test visual block single line yank p (175ms)

    ✓ test visual block single line yank P (546ms)

    ✓ test visual block single line delete p (183ms)

    ✓ test visual block single line delete P (173ms)

  rot13 operator

    1) the rot13 function is correct

    2) g?j works

    3) g? in visual mode works

  shift operator

    ✓ basic shift left test (168ms)

    ✓ shift left goto end test (300ms)

    ✓ shift left goto line test (51ms)

    ✓ shift right goto end test (52ms)

    ✓ shift right goto line test (43ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (197ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (159ms)

      ✓ step to Camel word (107ms)

      ✓ step to CAP word (202ms)

      ✓ step after CAP word (130ms)

      ✓ step from middle of word to Camel word (207ms)

      ✓ step to number word (173ms)

      ✓ step to operator word (198ms)

      ✓ step from inside operator word (169ms)

      ✓ step to operator and then over (143ms)

    handles <leader>w for underscore_var

      ✓ step to _word (172ms)

      ✓ step over whitespace to word (141ms)

      ✓ step from inside word to _word (79ms)

      ✓ step form _word to number (190ms)

      ✓ step from nubmer word to _word (173ms)

      ✓ step from in whitespace to word (58ms)

      ✓ step in ALL_CAPS_WORD (49ms)

    handles d<leader>w

      ✓ delete from start of camelWord

      ✓ delete from middle of camelWord (54ms)

      ✓ delete from start of CamelWord (113ms)

      ✓ delete two words from camelWord (208ms)

      ✓ delete from start of underscore_word (159ms)

      ✓ delete from middle of underscore_word (198ms)

      ✓ delete two words from camel_word (143ms)

    handles di<leader>w

      ✓ delete from start of camelWord (176ms)

      ✓ delete from middle of camelWord (112ms)

      ✓ delete from start of CamelWord (322ms)

      ✓ delete two words from camelWord (216ms)

      ✓ delete from start of underscore_word (146ms)

      ✓ delete from middle of underscore_word (203ms)

      ✓ delete two words from camel_word (62ms)

    handles <leader>b

      ✓ back from middle of word (211ms)

      ✓ back over whitespace to camelWord (168ms)

      ✓ back twice over operator (120ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (46ms)

      ✓ from middle to end of underscore_word (66ms)

      ✓ twice to end of word over operator (208ms)

  easymotion plugin

    ✓ Can handle s move (187ms)

    ✓ Can handle 2s move (147ms)

    ✓ Can handle f move (196ms)

    ✓ Can handle 2f move (178ms)

    ✓ Can handle F move (318ms)

    ✓ Can handle 2F move (194ms)

    ✓ Can handle t move (171ms)

    ✓ Can handle bd-t move (131ms)

    ✓ Can handle 2t move (81ms)

    ✓ Can handle bd-t2 move (465ms)

    ✓ Can handle T move (92ms)

    ✓ Can handle 2T move (65ms)

    ✓ Can handle w move (220ms)

    ✓ Can handle bd-w move (182ms)

    ✓ Can handle b move (156ms)

    ✓ Can handle e move (222ms)

    ✓ Can handle bd-e move (131ms)

    ✓ Can handle ge move (55ms)

    ✓ Can handle n-char move (76ms)

    ✓ Can handle j move (222ms)

    ✓ Can handle k move (440ms)

    ✓ Can handle bd-jk move (1) (100ms)

    ✓ Can handle bd-jk move (2) (198ms)

    ✓ Can handle lineforward move (1) (130ms)

    ✓ Can handle lineforward move (2) (176ms)

    ✓ Can handle linebackward move (1) (195ms)

    ✓ Can handle linebackward move (2) (176ms)

    ✓ Can handle searching for backslash (\) (92ms)

    ✓ Can handle searching for carat (^) (82ms)

    ✓ Can handle searching for dot (.) (213ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (116ms)

    ✓ Replaces within inner Word (153ms)

    ✓ Replaces within '' (215ms)

    ✓ Replaces within '' including spaces (182ms)

    ✓ Replaces within () (235ms)

    ✓ Replaces within () including spaces (186ms)

    ✓ Replaces within a paragraph (439ms)

    ✓ Replaces using a specified register (141ms)

    ✓ Replaces within {} over multiple lines (210ms)

    ✓ Replaces a multiline register within {} over multiple lines (156ms)

    ✓ Replaces a multiline register within {} over multiple lines (128ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (210ms)

    ✓ grr replaces the entire line with the register (90ms)

    ✓ grr can replace multiple lines (124ms)

    ✓ Replaces in visual mode (173ms)

    ✓ Replaces in visual mode using a specified register (250ms)

    ✓ Replaces in visual line mode (163ms)

    ✓ grj is linewise (205ms)

  sneak plugin

    ✓ Can handle s motion (157ms)

    ✓ Can handle S motion (204ms)

    ✓ Can handle <operator>z motion (105ms)

    ✓ Can handle <operator>Z motion (163ms)

    ✓ Can handle s; motion (189ms)

    ✓ Can handle s, motion (369ms)

    ✓ Can handle S; motion (104ms)

    ✓ Can handle S, motion (209ms)

    ✓ Can handle single letter s motion (85ms)

    ✓ Can handle single letter S motion (110ms)

    ✓ Can handle single letter <operator>z motion (204ms)

    ✓ Can handle single letter <operator>Z motion (157ms)

    ✓ Can handle single letter s; motion (202ms)

    ✓ Can handle single letter s, motion (178ms)

    ✓ Can handle single letter S; motion (85ms)

    ✓ Can handle single letter S, motion (213ms)

    ✓ Can handle multiline single char <number>s motion (171ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (180ms)

    ✓ 'ysiw(' surrounds word with space (212ms)

    ✓ 'ysw)' surrounds word without space (144ms)

    ✓ 'ysw(' surrounds word with space (165ms)

    ✓ 'ysaw)' surrounds word without space (146ms)

    ✓ 'ysaw(' surrounds word with space (351ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (128ms)

    ✓ 'ysiw<' surrounds word with tags (180ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (113ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (179ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (81ms)

    ✓ change surround (98ms)

    ✓ change surround with two pairs of quotes (497ms)

    ✓ change surround with two pairs of parens (111ms)

    ✓ change surround with alias (221ms)

    ✓ change surround to tags (169ms)

    ✓ delete surround (116ms)

    ✓ delete surround with quotes (155ms)

    ✓ delete surround with nested of quotes (97ms)

    ✓ delete surround with inconsistent quotes (186ms)

    ✓ delete surround with mixed quotes (120ms)

    ✓ delete surround with empty quotes cursor at start (182ms)

    ✓ delete surround with empty quotes cursor at end (134ms)

    ✓ don't delete surround if cursor is after closing match (172ms)

    ✓ delete surround if cursor is before opening match (162ms)

    ✓ delete surround with two pairs of parens (82ms)

    ✓ delete surround with alias (204ms)

    ✓ delete surround with tags (195ms)

    ✓ change surround brackets at end of line (149ms)

    ✓ changing brackets with surround works again (146ms)

    ✓ change surround with tags that contain an attribute and preserve them (154ms)

    ✓ change surround with tags that contain an attribute and remove them (168ms)

  register

    ✓ Can copy to a register (172ms)

    ✓ Can use two registers together (97ms)

    ✓ Can use black hole register (221ms)

    ✓ System clipboard works with chinese characters (47ms)

    ✓ Yank stores text in Register '0' (196ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (225ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (193ms)

    ✓ Register '1'-'9' stores delete content (278ms)

    ✓ "A appends linewise text to "a (238ms)

    ✓ "A appends character wise text to "a (236ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (194ms)

    ✓ Small deletion using Del is stored in small delete register (188ms)

    ✓ Small deletion using X is stored in small delete register (178ms)

    ✓ Search register (/) is set by forward search (308ms)

    ✓ Search register (/) is set by backward search (562ms)

    ✓ Search register (/) is set by star search (252ms)

    ✓ Command register (:) is set by command line (88ms)

    ✓ Read-only registers cannot be written to (848ms)

    clipboard

      ✓ Can access '*' (clipboard) register (156ms)

      ✓ Can access '+' (clipboard) register (196ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (157ms)

    ✓ Can repeat reversed F<character> (206ms)

    ✓ Can repeat t<character> (195ms)

    ✓ Can repeat N times reversed t<character> (163ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (181ms)

      ✓ move one sentence backward (154ms)

      ✓ move [count] sentences backward (182ms)

      ✓ move one sentence backward single line - middle (146ms)

      ✓ move one sentence backward no space (164ms)

      ✓ move one sentence backward no space - middle (109ms)

      ✓ move one sentence backward - multiline (118ms)

      ✓ move one sentence backward - multiline - period (153ms)

      ✓ move one sentence backward - multiline - previous line (180ms)

      ✓ move one sentence backward - multiline - previous line - period (93ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path
    separatePath
      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix
      ✓ can separate relative path on posix
    resolveUri
      ✓ posix

      ✓ win32
  1298 passing (5m)

  4 pending

  3 failing

  1) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=�������������.
      + expected - actual

      -�������������
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=a��.
      + expected - actual

      -a��
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  3) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=a��.
      + expected - actual

      -a��
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 05f89cf0-1cbc-11ea-b100-ed5cc7209ba0

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[20:30:01] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[20:30:01] Starting 'build'...
[20:30:01] Starting 'prettier'...
[20:30:02] Finished 'prettier' after 1.7 s
[20:30:02] Starting 'tsc'...
[20:30:02] Starting 'tslint'...
[20:30:10] Finished 'tslint' after 7.9 s
[20:30:19] Finished 'tsc' after 17 s
[20:30:19] Starting 'commit-hash'...
[20:30:19] Finished 'commit-hash' after 30 ms
[20:30:19] Finished 'build' after 19 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.0 into .vscode-test/vscode-1.41.0.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.0/linux-x64/stable
Downloaded VS Code 1.41.0
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-14T20:30:24.215Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command <C-w> can remove word in search mode (134ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (44ms)

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (52ms)

    ✓ <C-p>/<C-n> go to the previous/next command (88ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (100ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line

    ✓ <C-r> <C-w> insert word under cursor in search mode (38ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (52ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (560ms)

    ✓ :smile editor contains smile text (553ms)

  Basic sort

    ✓ Sort whole file, asc (174ms)

    ✓ Sort whole file, asc, ignoreCase (175ms)

    ✓ Sort whole file, dsc (138ms)

    ✓ Sort whole file, dsc, ignoreCase (212ms)

    ✓ Sort range, asc (233ms)

    ✓ Sort range, asc, ignoreCase (154ms)

    ✓ Sort range, dsc (144ms)

    ✓ Sort range, dsc, ignoreCase (153ms)

    ✓ Sort whole file, asc, unique (165ms)

  Horizontal split

    ✓ Run :sp (83ms)

    ✓ Run :split (85ms)

    ✓ Run :new (88ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall
    :write args parser
      ✓ can parse empty args
      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replace single word once (86ms)

    ✓ Replace with `g` flag (50ms)

    ✓ Replace with flags AND count (136ms)

    ✓ Replace with `c` flag (53ms)

    ✓ Replace with `gc` flag (117ms)

    ✓ Replace across all lines (81ms)

    ✓ Replace on specific single line (148ms)

    ✓ Replace on current line using dot (116ms)

    ✓ Replace single relative line using dot and plus (108ms)

    ✓ Replace across specific line range (134ms)

    ✓ Replace across relative line range using dot, plus, and minus (137ms)

    ✓ Replace across relative line range using numLines+colon shorthand (96ms)

    ✓ Repeat replacement across relative line range (153ms)

    ✓ Replace with range AND count but no flags (101ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (124ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (113ms)

    ✓ Undocumented: trailing operators use 1 as RHS (118ms)

    ✓ Replace specific single equal lines (129ms)

    ✓ Replace current line with no active selection (207ms)

    ✓ Replace text in selection (134ms)

    ✓ Substitute support marks (137ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (74ms)

      ✓ Replace with `g` flag inverts global flag (59ms)

      ✓ Replace with `c` flag inverts global flag (113ms)

      ✓ Replace multiple lines (134ms)

      ✓ Replace across specific lines (100ms)

      ✓ Replace current line with no active selection (88ms)

      ✓ Replace text in selection (142ms)

      ✓ Substitute support marks (117ms)

      ✓ Substitute with escaped delimiter (204ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (269ms)

      ✓ Substitute with previous search using # (269ms)

      ✓ Substitute with previous search using / (322ms)

      ✓ Substitute with parameters should update search state (176ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (297ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (175ms)

      ✓ Substitute repeat previous should accept flags (184ms)

      ✓ Substitute with empty search string should use last searched pattern (374ms)

      ✓ Ampersand (&) should repeat the last substitution (119ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (90ms)

    ✓ tabe with current file path does nothing (89ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion directory with / at the end (51ms)

    ✓ command line file navigate tab completion (54ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (152ms)

    ✓ command line file tab completion with space in file path (121ms)

  Vertical split

    ✓ Run :vs (79ms)

    ✓ Run :vsp (86ms)

    ✓ Run :vsplit (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :vnew (325ms)

    ✓ Run :vne (309ms)

  Basic write-quit

    ✓ Run write and quit (96ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (54ms)

      ✓ Can complete lines in file with different indentation (109ms)

      ✓ Returns no completions for unmatched line (50ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (117ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (109ms)

    ✓ getMatchingRemap (86ms)

    ✓ jj -> <Esc> through modehandler (114ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (123ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (114ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (110ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (127ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (234ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (273ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (192ms)

  Neovim Validator
    ✓ neovim enabled without path
    ✓ neovim disabled
  Remapping Validator
    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message
  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim
      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (92ms)

        ✓ Can track jumps for keys: GggG (78ms)

[main 2019-12-14T20:30:54.218Z] update#setState checking for updates

[main 2019-12-14T20:30:54.274Z] update#setState idle

        ✓ Can track jumps for keys: GggGgg (224ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /b<CR>n (158ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (197ms)

        ✓ Can track jumps for keys: j%% (177ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (154ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (229ms)

        ✓ Can track jumps for keys: j%%<C-o>% (80ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (244ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (155ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (324ms)

        ✓ Can enter number to jump back multiple times (162ms)

        ✓ Can track one-line `` jumps (239ms)

        ✓ Can track one-line double `` jumps (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line '' jumps (290ms)

        ✓ Can track one-line double '' jumps (163ms)

        ✓ Can handle '' jumps with no previous jump (183ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (210ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (204ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (198ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (189ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (203ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (286ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (195ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (391ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (278ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (100ms)

      Can track jumps from macros

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (298ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (105ms)

  Record and execute a macro

    ✓ Can record and execute (258ms)

    ✓ Can repeat last invoked macro (186ms)

    ✓ Can play back with count (430ms)

    ✓ Can play back with count, abort when a motion fails (455ms)

    ✓ Repeat change on contiguous lines (292ms)

    ✓ Append command to a macro (192ms)

    ✓ Can record Ctrl Keys and repeat (242ms)

    ✓ Can execute macros with dot commands properly (152ms)

    ✓ : (command) register can be used as a macro (160ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (99ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (58ms)

    ✓ <C-c> can exit insert (78ms)

    ✓ <Esc> can exit insert (103ms)

    ✓ Stay in insert when entering characters (116ms)

    ✓ Can handle 'O' (76ms)

    ✓ Can handle 'i' (110ms)

    ✓ Can handle 'I' (96ms)

    ✓ Can handle 'a' (128ms)

    ✓ Can handle 'A' (71ms)

    ✓ Can handle '<C-w>' (92ms)

    ✓ Can handle <C-w> on leading whitespace (94ms)

    ✓ Can handle <C-w> at beginning of line (146ms)

    ✓ Can handle <C-u> (216ms)

    ✓ Can handle <C-u> on leading characters (85ms)

    ✓ Can handle <C-u> on leading whitespace (196ms)

    ✓ Correctly places the cursor after deleting the previous line break (104ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (38ms)

    ✓ Backspace works on whitespace only lines (67ms)

    ✓ Backspace works on end of whitespace only lines (110ms)

    ✓ Backspace works at beginning of file (110ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (196ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (161ms)

    ✓ Can perform insert command prefixed with count (117ms)

    ✓ Can perform append command prefixed with count (89ms)

    ✓ Can perform insert at start of line command prefixed with count (119ms)

    ✓ Can perform append to end of line command prefixed with count (146ms)

    ✓ Can perform change char (s) command prefixed with count (118ms)

    ✓ Can perform command prefixed with count with <C-[> (61ms)

    ✓ Can handle 'o' with count (139ms)

    ✓ Can handle 'O' with count (131ms)

    ✓ Can handle backspace at beginning of line with all spaces (100ms)

    ✓ Can handle digraph insert (112ms)

    ✓ Can handle custom digraph insert (44ms)

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (76ms)

    ✓ Can handle dw (47ms)

    ✓ Can handle dw (80ms)

    ✓ Can handle dw across lines (1) (212ms)

    ✓ Can handle dw across lines (2) (156ms)

    ✓ Can handle dd last line (98ms)

    ✓ Can handle dd single line (58ms)

    ✓ Can handle dd

    ✓ Can handle 3dd (66ms)

    ✓ Can handle 3dd off end of document (74ms)

    ✓ Can handle d2d (72ms)

    ✓ Can handle dd empty line (59ms)

    ✓ Can handle ddp (61ms)

    ✓ Can handle 'de' (63ms)

    ✓ Can handle 'de' then 'de' again (93ms)

    ✓ Can handle 'db' (68ms)

    ✓ Can handle 'db then 'db' again (85ms)

    ✓ Can handle 'dl' at end of line (215ms)

    ✓ Can handle 'dF' (118ms)

    ✓ Can handle 'dT' (86ms)

    ✓ Can handle 'd3' then <enter> (79ms)

    ✓ Can handle 'dj' (128ms)

    ✓ Can handle 'dk' (78ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (82ms)

    ✓ Can handle 'd]}' without deleting closing bracket (70ms)

    ✓ Can handle 'cw' (161ms)

    ✓ Can handle 'cw' without deleting following white spaces (97ms)

    ✓ Can handle 'c2w' (120ms)

    ✓ Can handle 'cw' without removing EOL (213ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (155ms)

    ✓ Can handle 'c]}' without deleting closing bracket (95ms)

    ✓ Can handle 's' (109ms)

    ✓ Can handle 'yiw' with correct cursor ending position (64ms)

    ✓ Can handle 'ciw' (126ms)

    ✓ Can handle 'ciw' on blanks (189ms)

    ✓ Can handle 'caw' (142ms)

    ✓ Can handle 'caw' on first letter (118ms)

    ✓ Can handle 'caw' on blanks (141ms)

    ✓ Can handle 'caw' on blanks (217ms)

    ✓ Can handle 'ci(' on first parentheses (173ms)

    ✓ Can handle 'ci(' with nested parentheses (185ms)

    ✓ Can handle 'ci(' backwards through nested parens (143ms)

    ✓ Can handle 'cib' on first parentheses (138ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (103ms)

    ✓ Can handle count prefixed 'ci)' (140ms)

    ✓ Can handle count prefixed 'ca)' (225ms)

    ✓ Can handle 'ca(' spanning multiple lines (294ms)

    ✓ Can handle 'cab' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines (115ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (115ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (159ms)

    ✓ Can handle 'ci(' on the closing bracket (167ms)

    ✓ Can handle 'ciB' spanning multiple lines (184ms)

    ✓ will fail when ca( with no () (64ms)

    ✓ will fail when ca{ with no {} (74ms)

    ✓ will fail when caB with no {} (61ms)

    ✓ Can handle 'ci[' spanning multiple lines (78ms)

    ✓ Can handle 'ci]' on first bracket (92ms)

    ✓ Can handle 'ca[' on first bracket (91ms)

    ✓ Can handle 'ca]' on first bracket (100ms)

    ✓ Can handle 'ci'' on first quote (69ms)

    ✓ Can handle 'ci'' inside quoted string (147ms)

    ✓ Can handle 'ci'' on closing quote (82ms)

    ✓ Can handle 'ci'' when string is ahead (184ms)

    ✓ Can handle 'ci"' on opening quote (107ms)

    ✓ Can handle 'ci"' starting behind the quoted word (55ms)

    ✓ Can handle 'ca"' starting behind the quoted word (65ms)

    ✓ Can handle 'ca"' starting on the opening quote (62ms)

    ✓ Can handle 'ci"' with escaped quotes (92ms)

    ✓ Can handle 'ci"' with a single escaped quote (71ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (81ms)

    ✓ Can handle 'ci"' with an escaped backslash (100ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (117ms)

    ✓ Can handle 'ca"' starting on the closing quote (98ms)

    ✓ Can handle 'ci"' with complex escape sequences (87ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (119ms)

    ✓ will fail when ca" ahead of quoted string (84ms)

    ✓ Can handle 'ca`' inside word (70ms)

    ✓ can handle cj (173ms)

    ✓ can handle ck (103ms)

    ✓ can handle c2j (117ms)

    ✓ can handle c2k (115ms)

    ✓ can handle cj on last line (164ms)

    ✓ can handle ck on first line (233ms)

    ✓ can handle c2j on last line (118ms)

    ✓ can handle c2k on first line (243ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (164ms)

    ✓ Can handle 'daw' on word with trailing spaces (207ms)

    ✓ Can handle 'daw' on word with leading spaces (144ms)

    ✓ Can handle 'daw' on word with numeric prefix (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (354ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (105ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (136ms)

    ✓ Can handle 'daw' on end of word (140ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (208ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (116ms)

    ✓ Can handle 'daw' on word at beginning of file (103ms)

    ✓ Can handle 'daw' on word at beginning of line (85ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (195ms)

    ✓ Can handle 'daw' around word at end of line (151ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (128ms)

    ✓ Can handle 'daW' around word at whitespace (215ms)

    ✓ Can handle 'daW' on word with trailing spaces (156ms)

    ✓ Can handle 'daW' on word with leading spaces (225ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' on word with numeric prefix (139ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (218ms)

    ✓ Can handle 'daW' on beginning of word (150ms)

    ✓ Can handle 'daW' on end of one line (187ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (162ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (215ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (161ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (111ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (218ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (111ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (193ms)

    ✓ Can handle 'diw' on word (159ms)

    ✓ Can handle 'diw' on word with numeric prefix (200ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (178ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (134ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (187ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (161ms)

    ✓ Can handle 'diW' on word with trailing spaces (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diW' on word with leading spaces (103ms)

    ✓ Can handle 'diW' on word with numeric prefix (214ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (165ms)

    ✓ Can handle 'diW' on beginning of word (209ms)

    ✓ Can handle d} (63ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle y} at beginning of line (217ms)

    ✓ Select sentence with trailing spaces (120ms)

    ✓ Select sentence with leading spaces (197ms)

    ✓ Select inner sentence with trailing spaces (168ms)

    ✓ Select inner sentence with leading spaces (189ms)

    ✓ Select spaces between sentences (193ms)

    ✓ Can handle 'df' (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'dt' (233ms)

    ✓ Can handle backspace (131ms)

    ✓ Can handle backspace across lines (171ms)

    ✓ Can handle A and backspace (222ms)

    ✓ Can handle 'yy' without changing cursor position (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'P' after 'yy' (234ms)

    ✓ Can handle 'p' after 'yy' (123ms)

    ✓ Can handle 'P' after 'Nyy' (216ms)

    ✓ Can handle 'p' after 'Nyy' (59ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'p' after 'yy' with correct cursor position (229ms)

    ✓ Can handle 'gp' after 'yy' (140ms)

    ✓ Can handle 'gp' after 'Nyy' (173ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (140ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (69ms)

    ✓ Can handle 'gP' after 'yy' (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gP' after 'Nyy' (431ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (143ms)

    ✓ Can handle ']p' after yy (98ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ']p' after 'Nyy' (230ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (72ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (875ms)

    ✓ Can handle '[p' after yy (143ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '[p' after 'Nyy' (231ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (146ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (138ms)

    ✓ Can handle 'p' after y'a (234ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (87ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (217ms)

    ✓ Can handle pasting in visual mode over selection (196ms)

    ✓ Can repeat w (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat p (230ms)

    ✓ I works correctly (277ms)

    ✓ gI works correctly (140ms)

    ✓ gi works correctly (399ms)

    ✓ `. works correctly (247ms)

    ✓ '. works correctly (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g; works correctly (254ms)

    ✓ g, works correctly (135ms)

    ✓ g_ works correctly (212ms)

    ✓ 3g_ works correctly (170ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (433ms)

    ✓ gq handles spaces before single line comments correctly (649ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles tabs before single line comments correctly (439ms)

    ✓ Can handle space (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (230ms)

    ✓ Undo 1 (210ms)

    ✓ Undo 2 (156ms)

    ✓ Undo cursor (323ms)

    ✓ Undo cursor 2 (128ms)

    ✓ Undo cursor 3 (252ms)

    ✓ Undo with movement first (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' (462ms)

    ✓ Can handle 'U' for multiple changes (243ms)

    ✓ Can handle 'U' for new line below (233ms)

    ✓ Can handle 'U' for new line above (234ms)

    ✓ Can handle 'U' for consecutive changes only (255ms)

    ✓ Can handle 'u' to undo 'U' (130ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' to undo 'U' (245ms)

    ✓ Redo (164ms)

    ✓ Redo (331ms)

    ✓ Redo (248ms)

    ✓ Can handle u (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle guw (221ms)

    ✓ Can handle gUw (147ms)

    ✓ Can handle u over line breaks (228ms)

    ✓ can handle s in visual mode (184ms)

    ✓ can handle p with selection (216ms)

    ✓ can handle P with selection (75ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle p in visual to end of line (269ms)

    ✓ can repeat backspace twice (180ms)

    ✓ can delete linewise with d2G (154ms)

    ✓ can delete with + motion and count (166ms)

    ✓ can delete with - motion and count (65ms)

    ✓ can dE correctly (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can dE correctly (126ms)

    ✓ can dE correctly (211ms)

    ✓ can ctrl-a correctly behind a word (147ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (187ms)

    ✓ can ctrl-a on word (149ms)

    ✓ can ctrl-a on a hex number (208ms)

    ✓ can ctrl-a on decimal (135ms)

    ✓ can ctrl-a with numeric prefix (53ms)

    ✓ can ctrl-a on a decimal (81ms)

    ✓ can ctrl-a on an octal  (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Correctly increments in the middle of a number (248ms)

    ✓ can ctrl-x correctly behind a word (48ms)

    ✓ can ctrl-a on an number with word before  (217ms)

    ✓ can ctrl-a on an number with word before and after  (153ms)

    ✓ can ctrl-x on a negative number with word before and after  (222ms)

    ✓ can ctrl-a properly on multiple lines (129ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (207ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (133ms)

    ✓ can <C-a> on word with - in front of it (211ms)

    ✓ can do Y (136ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do S (272ms)

    ✓ / does not affect mark (129ms)

    ✓ / can search with regex (235ms)

    ✓ / can search with newline (171ms)

    ✓ / can search through multiple newlines (111ms)

    ✓ / matches ^ per line (213ms)

    ✓ / matches $ per line (176ms)

    ✓ Can search for forward slash (166ms)

    ✓ Can search backward for question mark (146ms)

    ✓ /\c forces case insensitive search (221ms)

    ✓ /\C forces case sensitive search (179ms)

    ✓ <BS> deletes the last character in search in progress mode (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <S-BS> deletes the last character in search in progress mode (216ms)

    ✓ <C-h> deletes the last character in search in progress mode (159ms)

    ✓ Can do C (125ms)

    ✓ Can do cit on a matching tag (130ms)

    ✓ Ignores cit on a non-matching tag (167ms)

    ✓ Ignores cit on a nested tag (194ms)

    ✓ Can do cit on a tag with an attribute tag (160ms)

    ✓ Can do cat on a matching tag (208ms)

    ✓ Can do cit on a multiline tag (162ms)

    ✓ Can do cit on a multiline tag with nested tags (137ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (144ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (215ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (215ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (202ms)

    ✓ can do cit with self closing tags (135ms)

    ✓ Respects indentation with cc (202ms)

    ✓ Resets cursor to indent end with cc (78ms)

    ✓ can handle 'cc' on empty line (209ms)

    ✓ cc copies linewise (169ms)

    ✓ Indent current line with correct Vim Mode (168ms)

    ✓ Can handle <Esc> and do nothing (201ms)

    ✓ Can handle # on consecutive words (157ms)

    ✓ Can handle # on skipped words (207ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (148ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (205ms)

    ✓ cc on whitespace-only treats whitespace as indent (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cai (374ms)

    ✓ Can do cii (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do caI (220ms)

    ✓ Can do dai (136ms)

    ✓ Can do dii (114ms)

    ✓ Can do daI (205ms)

    ✓ `] go to the end of the previously operated or put text (122ms)

    ✓ '] go to the end of the previously operated or put text (251ms)

    ✓ `[ go to the start of the previously operated or put text (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '[ go to the start of the previously operated or put text (724ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (110ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (209ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (163ms)

    can handle gn

      ✓ gn selects the next match text (257ms)

      ✓ gn selects the current word at |hello (241ms)

      ✓ gn selects the current word at h|ello (230ms)

      ✓ gn selects the current word at hel|lo (233ms)

      ✓ gn selects the current word at hell|o (220ms)

      ✓ gn selects the next word at hello| (265ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (216ms)

      ✓ dgn deletes the current word when cursor is at |hello (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at h|ello (239ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (174ms)

      ✓ dgn deletes the current word when cursor is at hell|o (229ms)

      ✓ dgn deletes the next word when cursor is at hello| (140ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (441ms)

      ✓ cgn deletes the current word when cursor is at |hello (110ms)

      ✓ cgn deletes the current word when cursor is at h|ello (164ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (232ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hell|o (296ms)

      ✓ cgn deletes the next word when cursor is at hello| (90ms)

    can handle gN

      ✓ gN selects the previous match text (316ms)

      ✓ gN selects the current word at hell|o (440ms)

      ✓ gN selects the current word at hel|lo (354ms)

      ✓ gN selects the current word at h|ello (234ms)

      ✓ gN selects the current word at |hello (264ms)

      ✓ gN selects the previous word at | hello (227ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (131ms)

      ✓ dgN deletes the current word when cursor is at hell|o (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at hel|lo (250ms)

      ✓ dgN deletes the current word when cursor is at h|ello (153ms)

      ✓ dgN deletes the current word when cursor is at |hello (206ms)

      ✓ dgN deletes the previous word when cursor is at | hello (132ms)

    can handle cgN

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the previous match text (from first line) (252ms)

      ✓ cgN deletes the current word when cursor is at hell|o (181ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (307ms)

      ✓ cgN deletes the current word when cursor is at h|ello (182ms)

      ✓ cgN deletes the current word when cursor is at |hello (156ms)

      ✓ cgN deletes the previous word when cursor is at | hello (201ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (105ms)

    ✓ Can activate with R from Normal mode (160ms)

    ✓ Can handle R (201ms)

    ✓ Can handle R past current line (114ms)

    ✓ Can handle R and exit Replace Mode (236ms)

    ✓ Can handle R across lines (114ms)

    ✓ Can handle R across lines and exit Replace Mode (208ms)

    ✓ Can handle R with {count} (143ms)

    ✓ Can handle backspace (221ms)

    ✓ Can handle backspace (146ms)

    ✓ Can handle backspace across lines (204ms)

    ✓ Can handle arrows (89ms)

    ✓ Can handle . (110ms)

    ✓ Can handle . across lines (333ms)

  Mode Visual

    ✓ can be activated (47ms)

    ✓ Can handle w (179ms)

    ✓ Can handle wd (137ms)

    ✓ Can handle x (119ms)

    ✓ Can handle x across a selection (243ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vwd in middle of sentence (423ms)

    ✓ Can do vwd in middle of sentence (114ms)

    ✓ Can do vwd multiple times (179ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (250ms)

    ✓ Can handle H key (72ms)

    ✓ Can handle backspace key (188ms)

    ✓ handles case where we delete over a newline (212ms)

    ✓ handles change operator (201ms)

    ✓ Can do vat on multiple matching tags (159ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (148ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (212ms)

    ✓ Repeat-prefixed vat does not bleed below (150ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (59ms)

    ✓ Can do vi) on a matching parenthesis (82ms)

    ✓ Can do vi) on multiple matching parens (129ms)

    ✓ Can do va) on a matching parenthesis (220ms)

    ✓ Can do va) on multiple matching parens (138ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (172ms)

    ✓ Repeat-prefixed va) does not bleed below (111ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va} on a matching bracket as first character (170ms)

    ✓ Can do va} on multiple matching brackets (148ms)

    ✓ Can do vi( on a matching bracket near first character (222ms)

    ✓ Can do vi{ on outer pair of nested braces (67ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (65ms)

    ✓ Can do va] on multiple matching brackets (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (255ms)

    ✓ Repeat-prefixed vaf does not bleed below (135ms)

    ✓ vaf only expands to enclosing pairs (81ms)

    ✓ Can use . to repeat indent in visual (145ms)

    ✓ Can do v_x to delete to first char (81ms)

    ✓ Can do vg_x to delete to last char with no EOL (83ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (145ms)

    ✓ Can do v$x to delete to last char including EOL (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do gv to reselect previous selection (276ms)

    Vim's EOL handling is weird

      ✓ delete through eol (175ms)

      ✓ join 2 lines by deleting through eol (158ms)

      ✓ d$ doesn't delete whole line (102ms)

      ✓ vd$ does delete whole line (118ms)

      ✓ Paste over selection copies the selection (250ms)

      ✓ Paste over selection copies the selection linewise (136ms)

    Arrow keys work perfectly in Visual Mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <up> key (562ms)

      ✓ Can handle <down> key (146ms)

      ✓ Can handle <left> key (190ms)

      ✓ Can handle <right> key (123ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (210ms)

      ✓ Can handle 'gj' (172ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (92ms)

      ✓ Can handle 'vawd' on word with trailing spaces (219ms)

      ✓ Can handle 'vawd' on word with leading spaces (151ms)

      ✓ Can handle 'vawd' on word with numeric prefix (184ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (176ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (149ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (311ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (227ms)

      ✓ Can handle 'vaWd' on word with leading spaces (136ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (182ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (167ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (137ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (182ms)

      ✓ Can handle 'vaWd' on word with leading spaces (162ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (97ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (117ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (203ms)

      ✓ Can handle 'vawd' on word with trailing spaces (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with leading spaces (241ms)

      ✓ Can handle 'vawd' on word with numeric prefix (129ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (127ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (204ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (223ms)

      ✓ Can handle 'vaWd' on word with leading spaces (112ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (211ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (166ms)

      ✓ Can handle 'Y' in visual mode (218ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (552ms)

      ✓ Select multiple sentences in visual mode (145ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (110ms)

      ✓ Select inner sentence with leading spaces in visual mode (217ms)

      ✓ Select spaces between sentences in visual mode (158ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (184ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (233ms)

      ✓ Can do vat on a matching tag (98ms)

    handles replace in visual mode

      ✓ Can do a single line replace (183ms)

      ✓ Can do a multi line replace (124ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (213ms)

      ✓ D deletes the current line (121ms)

    handles indent blocks in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do vai (237ms)

      ✓ Can do vii (79ms)

      ✓ Doesn't naively select the next line (143ms)

      ✓ Searches backwards if cursor line is empty (91ms)

      ✓ Can do vaI (133ms)

    visualstar

      ✓ Works with * (193ms)

      ✓ Works with # (61ms)

    search works in visual mode

      ✓ Works with / (80ms)

      1) Works with ?

      ✓ Selects correct range (185ms)

    X will delete linewise

      ✓ normal selection (169ms)

      ✓ normal selection (170ms)

    C will delete linewise

      ✓ normal selection (171ms)

      ✓ normal selection (195ms)

    R will delete linewise

      ✓ normal selection (196ms)

      ✓ normal selection (173ms)

    Linewise Registers will be inserted properly

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ downward selection (263ms)

      ✓ upward selection (141ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (55ms)

      ✓ multiline indent bottom up selection (303ms)

      ✓ repeat multiline indent top down selection (147ms)

      ✓ repeat multiline indent bottom up selection (150ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (105ms)

      ✓ multiline outdent bottom up selection (201ms)

      ✓ repeat multiline outdent top down selection (180ms)

      ✓ repeat multiline outdent bottom up selection (212ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (159ms)

    vi{ will go to end of second to last line

      ✓ select (114ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode (41ms)

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (452ms)

      ✓ gv selects the last pasted text (which is longer than original) (705ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gv selects the last pasted text (multiline) (551ms)

    can handle gn

      ✓ gn selects the next match text (316ms)

      ✓ gn selects the current word at |hello (260ms)

      ✓ gn selects the current word at h|ello (377ms)

      ✓ gn selects the current word at hel|lo (257ms)

      ✓ gn selects the next word at hell|o (259ms)

      ✓ gn selects the next word at hello| (315ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (74ms)

      ✓ multiline insert from top down selection (112ms)

      ✓ skips blank lines (66ms)

    can append text with A

      ✓ multiline append from bottom up selection (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (264ms)

      ✓ skips blank lines (51ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (316ms)

      ✓ U/gU across a selection (226ms)

      ✓ U/gU across a selection (reverse) (170ms)

      ✓ u/gu on single character (115ms)

      ✓ u/gu across a selection (100ms)

      ✓ u/gu across a selection (reverse) (136ms)

  Mode Visual Block

    ✓ can be activated (46ms)

    ✓ Can handle A forward select (235ms)

    ✓ Can handle A backwards select (168ms)

    ✓ Can handle I forward select (143ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle I backwards select (361ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (83ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (176ms)

    ✓ Can handle c forward select (120ms)

    ✓ Can handle c backwards select (192ms)

    ✓ Can handle C (132ms)

    ✓ Can do a multi line replace (183ms)

    ✓ Can handle 'D' (58ms)

    ✓ Can handle 'gj' (95ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Properly add to end of lines j then $ (334ms)

    ✓ Properly add to end of lines $ then j (124ms)

    ✓ o works in visual block mode (106ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (209ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle wd (477ms)

    ✓ Can handle x (112ms)

    ✓ Can handle x across a selection (160ms)

    ✓ Can do vwd in middle of sentence (174ms)

    ✓ Can do vwd in middle of sentence (133ms)

    ✓ Can do vwd multiple times (267ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (120ms)

    ✓ handles case where we delete over a newline (185ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ handles change operator (362ms)

    ✓ Vp updates register content (78ms)

    ✓ Vp does not append unnecessary newlines (first line) (78ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (354ms)

    ✓ Vp does not append unnecessary newlines (last line) (148ms)

    Vim's EOL handling is weird

      ✓ delete through eol (118ms)

      ✓ join 2 lines by deleting through eol (162ms)

      ✓ d$ doesn't delete whole line (76ms)

      ✓ vd$ does delete whole line (123ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (189ms)

      ✓ Can handle <down> key (74ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (196ms)

      ✓ Can handle 'gj' (157ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (209ms)

      ✓ Can handle d key (71ms)

      ✓ Can handle d key (55ms)

      ✓ Can handle d key (66ms)

      ✓ can handle 'c' (52ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (117ms)

      ✓ Can do a multi visual line replace (56ms)

      ✓ Can do a multi visual line replace from the bottom up (122ms)

    search works in visual line mode

      ✓ Works with / (108ms)

      ✓ Works with ? (88ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (229ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (77ms)

      ✓ linewise visual put works also in the end of document (154ms)

      ✓ gv selects the last pasted text (which is shorter than original) (661ms)

      ✓ gv selects the last pasted text (which is longer than original) (432ms)

      ✓ gv selects the last pasted text (multiline) (275ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (62ms)

      ✓ multiline insert from top down selection (187ms)

      ✓ skips blank lines (167ms)

    can append text with A

      ✓ multiline append from bottom up selection (138ms)

      ✓ multiline append from top down selection (215ms)

      ✓ skips blank lines (145ms)

  Mode Normal

    ✓ Can handle 'x' (120ms)

    ✓ Can handle 'Nx' (196ms)

    ✓ Can handle 'Nx' and paste (77ms)

    ✓ Can handle 'x' at end of line (128ms)

    ✓ Can handle 'Ns' (83ms)

    ✓ Can handle 'Ns' at end of line (138ms)

    ✓ Can handle '<Del>' (109ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (117ms)

    ✓ Can handle '<Del>' at end of line (119ms)

    ✓ Can handle 'cc' (229ms)

    ✓ Can handle 'Ncc' (133ms)

    ✓ Can handle 'yy' (164ms)

    ✓ Can handle 'D' (364ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' on empty lines (135ms)

    ✓ Can handle 'DD' (183ms)

    ✓ Can handle 'C' (149ms)

    ✓ Can handle 'NC' (174ms)

    ✓ Can handle 'NC' and put (115ms)

    ✓ Can handle 'r' (193ms)

    ✓ Can handle '<Count>r' (63ms)

    ✓ Can handle '<Count>r' (201ms)

    ✓ Can handle 'r' after 'dd' (159ms)

    ✓ Can handle 'r
' (92ms)

    ✓ Can handle '<Count>r
' (116ms)

    ✓ Can handle 'J' once (183ms)

    ✓ Can handle 'J' twice (127ms)

    ✓ Can handle 'J' with empty last line (213ms)

    ✓ Can handle 'J's with multiple empty last lines (160ms)

    ✓ Can handle 'J' with leading white space on next line (130ms)

    ✓ Can handle 'J' with only white space on next line (55ms)

    ✓ Can handle 'J' with TWO indented lines (55ms)

    ✓ Can handle 'J' with ')' first character on next line (130ms)

    ✓ Can handle 'J' with a following delete (148ms)

    ✓ Can handle 'J' in Visual Line mode (58ms)

    ✓ Can handle 'gJ' once (211ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (142ms)

    ✓ Can handle '~' (187ms)

    ✓ Can handle 'g~{motion}' (84ms)

    ✓ Can handle '<BS>' in insert mode (170ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle undo with P (409ms)

    ✓ Can handle 'ge' in multiple lines case1 (112ms)

    ✓ Can handle 'ge' in multiple lines case2 (197ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (138ms)

    ✓ Can repeat '~' with dot (229ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat 'x' (129ms)

    ✓ Can repeat 'J' (141ms)

    ✓ Can handle dot with A (250ms)

    ✓ Can handle dot with I (101ms)

    ✓ Can repeat actions that require selections (101ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (195ms)

    ✓ Can repeat insert change and '<C-t>' (174ms)

    ✓ Can repeat change by `<C-a>` (224ms)

    ✓ Only one arrow key can be repeated in Insert Mode (241ms)

    ✓ Cached content change will be cleared by arrow keys (183ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (119ms)

    ✓ inside parenthesis (100ms)

    ✓ nested parenthesis beginning (104ms)

    ✓ nested parenthesis end (199ms)

    ✓ nested bracket and parenthesis beginning (140ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested bracket, parenthesis, braces beginning (129ms)

    ✓ nested bracket, parenthesis, braces end (186ms)

    ✓ parentheses after > (158ms)

    ✓ parentheses after " (66ms)

  Motions in Normal Mode

    ✓ Can handle [( (145ms)

    ✓ Can handle nested [( (167ms)

    ✓ Can handle <number>[( (82ms)

    ✓ Can handle [( and character under cursor exclusive (103ms)

    ✓ Can handle ]) (126ms)

    ✓ Can handle nested ]) (147ms)

    ✓ Can handle <number>]) (139ms)

    ✓ Can handle ]) and character under cursor exclusive (131ms)

    ✓ Can handle [{ (133ms)

    ✓ Can handle nested [{ (118ms)

    ✓ Can handle <number>[{ (126ms)

    ✓ Can handle [{ and character under cursor exclusive (199ms)

    ✓ Can handle ]} (158ms)

    ✓ Can handle nested ]} (208ms)

    ✓ Can handle <number>]} (153ms)

    ✓ Can handle ]} and character under cursor exclusive (200ms)

    ✓ Can handle 'ge' (131ms)

    ✓ Can handle 'gg' (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gg' to first non blank char on random line (319ms)

    ✓ Can handle 'gg' to first non blank char on first line (163ms)

    ✓ 'gg' obeys startofline (165ms)

    ✓ Retain same column when moving up/down (73ms)

    ✓ Can handle <enter> (172ms)

    ✓ $ always keeps cursor on EOL (139ms)

    ✓ Can handle $ with a count (110ms)

    ✓ Can handle $ with a count at end of file (152ms)

    ✓ Can handle <End> with a count (195ms)

    ✓ Can handle <D-right> with a count (68ms)

    ✓ Can handle 'f' (66ms)

    ✓ Can handle 'f' twice (178ms)

    ✓ Can handle 'f' with <tab> (158ms)

    ✓ Can handle 'f' and find back search (161ms)

    ✓ Can handle 'F' (146ms)

    ✓ Can handle 'F' twice (151ms)

    ✓ Can handle 'F' and find back search (52ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'f' and multiple back searches (235ms)

    ✓ Can handle 't' (138ms)

    ✓ Can handle 't' twice (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 't' and find back search (380ms)

    ✓ Can handle 'T' (94ms)

    ✓ Can handle 'T' twice (178ms)

    ✓ Can handle 'T' and find back search (193ms)

    ✓ Can run a forward search (93ms)

    ✓ Can run a forward and find next search (59ms)

    ✓ Can run a forward and find previous search from end of word (200ms)

    ✓ Can run a reverse search (93ms)

    ✓ Can run a reverse and find next search (136ms)

    ✓ cancelled search reverts to previous search state (149ms)

    ✓ Backspace on empty search cancels (144ms)

    ✓ Search offsets: b does nothing (114ms)

    ✓ Search offsets: b2 goes 2 to the right (196ms)

    ✓ Search offsets: b+3 goes 3 to the right (78ms)

    ✓ Search offsets: e goes to the end (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Search offsets: character offset goes across line boundaries (118ms)

    ✓ Search offsets: 2 goes 2 down (213ms)

    ✓ Search offsets: -2 goes 2 up (84ms)

    ✓ maintains column position correctly (226ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ maintains column position correctly with $ (161ms)

    ✓ Can handle G  (183ms)

    ✓ Can handle G with number prefix (275ms)

    ✓ Can handle G with number prefix (155ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix (67ms)

    ✓ Can handle 0 (165ms)

    ✓ Can handle 0 as part of a repeat (160ms)

    ✓ Can handle g* (206ms)

    ✓ Can handle g*n (139ms)

    ✓ Can handle * (185ms)

    ✓ Can handle ** (74ms)

    ✓ Can handle # on whitespace (107ms)

    ✓ Can handle # on EOL (79ms)

    ✓ Can handle g# (111ms)

    ✓ Can handle g#n (126ms)

    ✓ Can handle # (176ms)

    ✓ Can handle # already on the word (46ms)

    ✓ Can handle ## (115ms)

    ✓ * adds to search history (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ # adds to search history (282ms)

    ✓ Can handle | (92ms)

    ✓ Can handle <number> | (79ms)

    ✓ Can handle + (140ms)

    ✓ Can handle + indent (164ms)

    ✓ Can handle + with count prefix (192ms)

    ✓ Can handle - (117ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix (43ms)

    ✓ Can handle _ (131ms)

    ✓ Can handle _ with count prefix (51ms)

    ✓ Can handle g_ (52ms)

    ✓ Can handle g_ with count prefix (117ms)

    ✓ Can handle <up> key (44ms)

    ✓ Can handle <down> key (49ms)

    ✓ Can handle <left> key (127ms)

    ✓ Can handle <right> key (47ms)

    ✓ Can handle 'gk' (47ms)

    ✓ Can handle 'gj' (123ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move to word right (41ms)

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right
      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph
      ✓ move down starting inside empty line
      ✓ paragraph at end of document
    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (141ms)

        ✓ l wraps to next line (42ms)

        ✓ <left> wraps to previous line (97ms)

        ✓ <right> wraps to next line (190ms)

      insert mode

        ✓ <left> wraps to previous line (49ms)

        ✓ <right> once goes to end of line (84ms)

        ✓ <right> twice wraps to next line (131ms)

    whichwrap disabled
      normal mode

        ✓ h does not wrap to previous line (154ms)

        ✓ l does not wrap to next line (54ms)

        ✓ <left> does not wrap to previous line (180ms)

        ✓ <right> does not wrap to next line (81ms)

      insert mode

        ✓ <left> does not wrap to previous line (205ms)

        ✓ <right> does not wrap to next line (147ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (153ms)

      ✓ search wraps around the start of the file (119ms)

    wrapscan disabled

      ✓ search stops at the end of the file (205ms)

      ✓ search stops at the start of the file (62ms)

  Multicursor

    ✓ can add multiple cursors below (188ms)

    ✓ can add multiple cursors above (161ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (348ms)

    ✓ gcj comments in current and next line (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (537ms)

    ✓ block comment in Visual Mode (230ms)

    ✓ comment in visual line mode (141ms)

    ✓ comment in visual block mode (192ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (1310ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =$ formats entire line (333ms)

    ✓ =j formats two lines (201ms)

    ✓ 3=k formats three lines (223ms)

    ✓ =gg formats to top of file (199ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =G formats to bottom of file (116ms)

    ✓ =ip formats paragraph (188ms)

    ✓ format in visual mode (110ms)

  put operator

    ✓ basic put test (194ms)

    ✓ test yy end of line (100ms)

    ✓ test yy first line (173ms)

    ✓ test yy middle line (150ms)

    ✓ test yy with correct positon movement (201ms)

    ✓ test visual block single line yank p (152ms)

    ✓ test visual block single line yank P (95ms)

    ✓ test visual block single line delete p (78ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line delete P (261ms)

  rot13 operator

    2) the rot13 function is correct

    3) g?j works

    4) g? in visual mode works

    5) g? in visual line mode works

    6) g? in visual block mode works

  shift operator

    ✓ basic shift left test (162ms)

    ✓ shift left goto end test (78ms)

    ✓ shift left goto line test (179ms)

    ✓ shift right goto end test (131ms)

    ✓ shift right goto line test (115ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (118ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step over whitespace (1062ms)

      ✓ step to Camel word (171ms)

      ✓ step to CAP word (76ms)

      ✓ step after CAP word (188ms)

      ✓ step from middle of word to Camel word (203ms)

      ✓ step to number word (148ms)

      ✓ step to operator word (134ms)

      ✓ step from inside operator word (257ms)

      ✓ step to operator and then over (114ms)

    handles <leader>w for underscore_var

      ✓ step to _word (193ms)

      ✓ step over whitespace to word (159ms)

      ✓ step from inside word to _word (78ms)

      ✓ step form _word to number (165ms)

      ✓ step from nubmer word to _word (126ms)

      ✓ step from in whitespace to word (198ms)

      ✓ step in ALL_CAPS_WORD (198ms)

    handles d<leader>w

      ✓ delete from start of camelWord (129ms)

      ✓ delete from middle of camelWord (108ms)

      ✓ delete from start of CamelWord (178ms)

      ✓ delete two words from camelWord (140ms)

      ✓ delete from start of underscore_word (56ms)

      ✓ delete from middle of underscore_word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camel_word (615ms)

    handles di<leader>w

      ✓ delete from start of camelWord (160ms)

      ✓ delete from middle of camelWord (199ms)

      ✓ delete from start of CamelWord (173ms)

      ✓ delete two words from camelWord (137ms)

      ✓ delete from start of underscore_word (149ms)

      ✓ delete from middle of underscore_word (173ms)

      ✓ delete two words from camel_word (61ms)

    handles <leader>b

      ✓ back from middle of word (201ms)

      ✓ back over whitespace to camelWord (108ms)

      ✓ back twice over operator (158ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (51ms)

      ✓ from middle to end of underscore_word (167ms)

      ✓ twice to end of word over operator (96ms)

  easymotion plugin

    ✓ Can handle s move (217ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2s move (674ms)

    ✓ Can handle f move (47ms)

    ✓ Can handle 2f move (63ms)

    ✓ Can handle F move (103ms)

    ✓ Can handle 2F move (182ms)

    ✓ Can handle t move (140ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle bd-t move (228ms)

    ✓ Can handle 2t move (165ms)

    ✓ Can handle bd-t2 move (112ms)

    ✓ Can handle T move (159ms)

    ✓ Can handle 2T move (123ms)

    ✓ Can handle w move (213ms)

    ✓ Can handle bd-w move (170ms)

    ✓ Can handle b move (164ms)

    ✓ Can handle e move (287ms)

    ✓ Can handle bd-e move (124ms)

    ✓ Can handle ge move (215ms)

    ✓ Can handle n-char move (179ms)

    ✓ Can handle j move (208ms)

    ✓ Can handle k move (138ms)

    ✓ Can handle bd-jk move (1) (170ms)

    ✓ Can handle bd-jk move (2) (188ms)

    ✓ Can handle lineforward move (1) (158ms)

    ✓ Can handle lineforward move (2) (170ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (162ms)

    ✓ Can handle searching for backslash (\) (123ms)

    ✓ Can handle searching for carat (^) (244ms)

    ✓ Can handle searching for dot (.) (62ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (109ms)

    ✓ Replaces within inner Word (207ms)

    ✓ Replaces within '' (131ms)

    ✓ Replaces within '' including spaces (225ms)

    ✓ Replaces within () (147ms)

    ✓ Replaces within () including spaces (185ms)

    ✓ Replaces within a paragraph (170ms)

    ✓ Replaces using a specified register (218ms)

    ✓ Replaces within {} over multiple lines (145ms)

    ✓ Replaces a multiline register within {} over multiple lines (205ms)

    ✓ Replaces a multiline register within {} over multiple lines (123ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (154ms)

    ✓ grr replaces the entire line with the register (71ms)

    ✓ grr can replace multiple lines (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode (232ms)

    ✓ Replaces in visual mode using a specified register (207ms)

    ✓ Replaces in visual line mode (227ms)

    ✓ grj is linewise (184ms)

  sneak plugin

    ✓ Can handle s motion (149ms)

    ✓ Can handle S motion (196ms)

    ✓ Can handle <operator>z motion (152ms)

    ✓ Can handle <operator>Z motion (192ms)

    ✓ Can handle s; motion (145ms)

    ✓ Can handle s, motion (190ms)

    ✓ Can handle S; motion (149ms)

    ✓ Can handle S, motion (183ms)

    ✓ Can handle single letter s motion (102ms)

    ✓ Can handle single letter S motion (183ms)

    ✓ Can handle single letter <operator>z motion (142ms)

    ✓ Can handle single letter <operator>Z motion (198ms)

    ✓ Can handle single letter s; motion (170ms)

    ✓ Can handle single letter s, motion (167ms)

    ✓ Can handle single letter S; motion (160ms)

    ✓ Can handle single letter S, motion (77ms)

    ✓ Can handle multiline single char <number>s motion (201ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (245ms)

    ✓ 'ysiw(' surrounds word with space (180ms)

    ✓ 'ysw)' surrounds word without space (148ms)

    ✓ 'ysw(' surrounds word with space (118ms)

    ✓ 'ysaw)' surrounds word without space (124ms)

    ✓ 'ysaw(' surrounds word with space (198ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw<' surrounds word with tags (394ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (248ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (182ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (155ms)

    ✓ change surround (109ms)

    ✓ change surround with two pairs of quotes (176ms)

    ✓ change surround with two pairs of parens (107ms)

    ✓ change surround with alias (197ms)

    ✓ change surround to tags (199ms)

    ✓ delete surround (182ms)

    ✓ delete surround with quotes (110ms)

    ✓ delete surround with nested of quotes (178ms)

    ✓ delete surround with inconsistent quotes (111ms)

    ✓ delete surround with mixed quotes (211ms)

    ✓ delete surround with empty quotes cursor at start (88ms)

    ✓ delete surround with empty quotes cursor at end (185ms)

    ✓ don't delete surround if cursor is after closing match (109ms)

    ✓ delete surround if cursor is before opening match (81ms)

    ✓ delete surround with two pairs of parens (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround with alias (247ms)

    ✓ delete surround with tags (130ms)

    ✓ change surround brackets at end of line (160ms)

    ✓ changing brackets with surround works again (79ms)

    ✓ change surround with tags that contain an attribute and preserve them (195ms)

    ✓ change surround with tags that contain an attribute and remove them (188ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (263ms)

    ✓ Can use two registers together (224ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use black hole register (609ms)

    ✓ System clipboard works with chinese characters (53ms)

    ✓ Yank stores text in Register '0' (210ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (248ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (199ms)

    ✓ Register '1'-'9' stores delete content (263ms)

    ✓ "A appends linewise text to "a (307ms)

    ✓ "A appends character wise text to "a (201ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (184ms)

    ✓ Small deletion using Del is stored in small delete register (292ms)

    ✓ Small deletion using X is stored in small delete register (209ms)

    ✓ Search register (/) is set by forward search (426ms)

    ✓ Search register (/) is set by backward search (267ms)

    ✓ Search register (/) is set by star search (256ms)

    ✓ Command register (:) is set by command line (73ms)

    ✓ Read-only registers cannot be written to (212ms)

    clipboard

      ✓ Can access '*' (clipboard) register (161ms)

      ✓ Can access '+' (clipboard) register (257ms)

  Repeatable movements with f and t

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat f<character> (59ms)

    ✓ Can repeat reversed F<character>

    ✓ Can repeat t<character> (410ms)

    ✓ Can repeat N times reversed t<character> (142ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (137ms)

      ✓ move one sentence backward (169ms)

      ✓ move [count] sentences backward (187ms)

      ✓ move one sentence backward single line - middle (145ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward no space (233ms)

      ✓ move one sentence backward no space - middle (177ms)

      ✓ move one sentence backward - multiline (270ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward - multiline - period (297ms)

      ✓ move one sentence backward - multiline - previous line (133ms)

      ✓ move one sentence backward - multiline - previous line - period (72ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1297 passing (6m)

  4 pending

  6 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:921:5)


  2) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=zyxwvutsrqponmlkjihgfedcba.
      + expected - actual

      -zyxwvutsrqponmlkjihgfedcba
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  3) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=zyx.
      + expected - actual

      -zyx
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  4) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=ayx.
      + expected - actual

      -ayx
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


  5) rot13 operator
       g? in visual line mode works:

      Content does not match; Expected=nop. Actual=zyx.
      + expected - actual

      -zyx
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:35:3)


  6) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=aop. Actual=ayx.
      + expected - actual

      -ayx
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:42:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.0 into .vscode-test/vscode-1.41.0.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.0/linux-x64/stable
Downloaded VS Code 1.41.0
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-14T20:30:24.215Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive
    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command <C-w> can remove word in search mode (134ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (44ms)

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (52ms)

    ✓ <C-p>/<C-n> go to the previous/next command (88ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (100ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line

    ✓ <C-r> <C-w> insert word under cursor in search mode (38ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (52ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (560ms)

    ✓ :smile editor contains smile text (553ms)

  Basic sort

    ✓ Sort whole file, asc (174ms)

    ✓ Sort whole file, asc, ignoreCase (175ms)

    ✓ Sort whole file, dsc (138ms)

    ✓ Sort whole file, dsc, ignoreCase (212ms)

    ✓ Sort range, asc (233ms)

    ✓ Sort range, asc, ignoreCase (154ms)

    ✓ Sort range, dsc (144ms)

    ✓ Sort range, dsc, ignoreCase (153ms)

    ✓ Sort whole file, asc, unique (165ms)

  Horizontal split

    ✓ Run :sp (83ms)

    ✓ Run :split (85ms)

    ✓ Run :new (88ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall
    :write args parser
      ✓ can parse empty args
      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replace single word once (86ms)

    ✓ Replace with `g` flag (50ms)

    ✓ Replace with flags AND count (136ms)

    ✓ Replace with `c` flag (53ms)

    ✓ Replace with `gc` flag (117ms)

    ✓ Replace across all lines (81ms)

    ✓ Replace on specific single line (148ms)

    ✓ Replace on current line using dot (116ms)

    ✓ Replace single relative line using dot and plus (108ms)

    ✓ Replace across specific line range (134ms)

    ✓ Replace across relative line range using dot, plus, and minus (137ms)

    ✓ Replace across relative line range using numLines+colon shorthand (96ms)

    ✓ Repeat replacement across relative line range (153ms)

    ✓ Replace with range AND count but no flags (101ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (124ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (113ms)

    ✓ Undocumented: trailing operators use 1 as RHS (118ms)

    ✓ Replace specific single equal lines (129ms)

    ✓ Replace current line with no active selection (207ms)

    ✓ Replace text in selection (134ms)

    ✓ Substitute support marks (137ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (74ms)

      ✓ Replace with `g` flag inverts global flag (59ms)

      ✓ Replace with `c` flag inverts global flag (113ms)

      ✓ Replace multiple lines (134ms)

      ✓ Replace across specific lines (100ms)

      ✓ Replace current line with no active selection (88ms)

      ✓ Replace text in selection (142ms)

      ✓ Substitute support marks (117ms)

      ✓ Substitute with escaped delimiter (204ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (269ms)

      ✓ Substitute with previous search using # (269ms)

      ✓ Substitute with previous search using / (322ms)

      ✓ Substitute with parameters should update search state (176ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (297ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (175ms)

      ✓ Substitute repeat previous should accept flags (184ms)

      ✓ Substitute with empty search string should use last searched pattern (374ms)

      ✓ Ampersand (&) should repeat the last substitution (119ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (90ms)

    ✓ tabe with current file path does nothing (89ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion directory with / at the end (51ms)

    ✓ command line file navigate tab completion (54ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (152ms)

    ✓ command line file tab completion with space in file path (121ms)

  Vertical split

    ✓ Run :vs (79ms)

    ✓ Run :vsp (86ms)

    ✓ Run :vsplit (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :vnew (325ms)

    ✓ Run :vne (309ms)

  Basic write-quit

    ✓ Run write and quit (96ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (54ms)

      ✓ Can complete lines in file with different indentation (109ms)

      ✓ Returns no completions for unmatched line (50ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (117ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (109ms)

    ✓ getMatchingRemap (86ms)

    ✓ jj -> <Esc> through modehandler (114ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (123ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (114ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (110ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (127ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (234ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (273ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (192ms)

  Neovim Validator
    ✓ neovim enabled without path
    ✓ neovim disabled
  Remapping Validator
    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message
  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim
      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (92ms)

        ✓ Can track jumps for keys: GggG (78ms)

[main 2019-12-14T20:30:54.218Z] update#setState checking for updates

[main 2019-12-14T20:30:54.274Z] update#setState idle

        ✓ Can track jumps for keys: GggGgg (224ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /b<CR>n (158ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (197ms)

        ✓ Can track jumps for keys: j%% (177ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (154ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (229ms)

        ✓ Can track jumps for keys: j%%<C-o>% (80ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (244ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (155ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (324ms)

        ✓ Can enter number to jump back multiple times (162ms)

        ✓ Can track one-line `` jumps (239ms)

        ✓ Can track one-line double `` jumps (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line '' jumps (290ms)

        ✓ Can track one-line double '' jumps (163ms)

        ✓ Can handle '' jumps with no previous jump (183ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (210ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (204ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (198ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (189ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (203ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (286ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (195ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (391ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (278ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (100ms)

      Can track jumps from macros

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (298ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (105ms)

  Record and execute a macro

    ✓ Can record and execute (258ms)

    ✓ Can repeat last invoked macro (186ms)

    ✓ Can play back with count (430ms)

    ✓ Can play back with count, abort when a motion fails (455ms)

    ✓ Repeat change on contiguous lines (292ms)

    ✓ Append command to a macro (192ms)

    ✓ Can record Ctrl Keys and repeat (242ms)

    ✓ Can execute macros with dot commands properly (152ms)

    ✓ : (command) register can be used as a macro (160ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (99ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (58ms)

    ✓ <C-c> can exit insert (78ms)

    ✓ <Esc> can exit insert (103ms)

    ✓ Stay in insert when entering characters (116ms)

    ✓ Can handle 'O' (76ms)

    ✓ Can handle 'i' (110ms)

    ✓ Can handle 'I' (96ms)

    ✓ Can handle 'a' (128ms)

    ✓ Can handle 'A' (71ms)

    ✓ Can handle '<C-w>' (92ms)

    ✓ Can handle <C-w> on leading whitespace (94ms)

    ✓ Can handle <C-w> at beginning of line (146ms)

    ✓ Can handle <C-u> (216ms)

    ✓ Can handle <C-u> on leading characters (85ms)

    ✓ Can handle <C-u> on leading whitespace (196ms)

    ✓ Correctly places the cursor after deleting the previous line break (104ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket (38ms)

    ✓ Backspace works on whitespace only lines (67ms)

    ✓ Backspace works on end of whitespace only lines (110ms)

    ✓ Backspace works at beginning of file (110ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (196ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (161ms)

    ✓ Can perform insert command prefixed with count (117ms)

    ✓ Can perform append command prefixed with count (89ms)

    ✓ Can perform insert at start of line command prefixed with count (119ms)

    ✓ Can perform append to end of line command prefixed with count (146ms)

    ✓ Can perform change char (s) command prefixed with count (118ms)

    ✓ Can perform command prefixed with count with <C-[> (61ms)

    ✓ Can handle 'o' with count (139ms)

    ✓ Can handle 'O' with count (131ms)

    ✓ Can handle backspace at beginning of line with all spaces (100ms)

    ✓ Can handle digraph insert (112ms)

    ✓ Can handle custom digraph insert (44ms)

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (76ms)

    ✓ Can handle dw (47ms)

    ✓ Can handle dw (80ms)

    ✓ Can handle dw across lines (1) (212ms)

    ✓ Can handle dw across lines (2) (156ms)

    ✓ Can handle dd last line (98ms)

    ✓ Can handle dd single line (58ms)

    ✓ Can handle dd

    ✓ Can handle 3dd (66ms)

    ✓ Can handle 3dd off end of document (74ms)

    ✓ Can handle d2d (72ms)

    ✓ Can handle dd empty line (59ms)

    ✓ Can handle ddp (61ms)

    ✓ Can handle 'de' (63ms)

    ✓ Can handle 'de' then 'de' again (93ms)

    ✓ Can handle 'db' (68ms)

    ✓ Can handle 'db then 'db' again (85ms)

    ✓ Can handle 'dl' at end of line (215ms)

    ✓ Can handle 'dF' (118ms)

    ✓ Can handle 'dT' (86ms)

    ✓ Can handle 'd3' then <enter> (79ms)

    ✓ Can handle 'dj' (128ms)

    ✓ Can handle 'dk' (78ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (82ms)

    ✓ Can handle 'd]}' without deleting closing bracket (70ms)

    ✓ Can handle 'cw' (161ms)

    ✓ Can handle 'cw' without deleting following white spaces (97ms)

    ✓ Can handle 'c2w' (120ms)

    ✓ Can handle 'cw' without removing EOL (213ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (155ms)

    ✓ Can handle 'c]}' without deleting closing bracket (95ms)

    ✓ Can handle 's' (109ms)

    ✓ Can handle 'yiw' with correct cursor ending position (64ms)

    ✓ Can handle 'ciw' (126ms)

    ✓ Can handle 'ciw' on blanks (189ms)

    ✓ Can handle 'caw' (142ms)

    ✓ Can handle 'caw' on first letter (118ms)

    ✓ Can handle 'caw' on blanks (141ms)

    ✓ Can handle 'caw' on blanks (217ms)

    ✓ Can handle 'ci(' on first parentheses (173ms)

    ✓ Can handle 'ci(' with nested parentheses (185ms)

    ✓ Can handle 'ci(' backwards through nested parens (143ms)

    ✓ Can handle 'cib' on first parentheses (138ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (103ms)

    ✓ Can handle count prefixed 'ci)' (140ms)

    ✓ Can handle count prefixed 'ca)' (225ms)

    ✓ Can handle 'ca(' spanning multiple lines (294ms)

    ✓ Can handle 'cab' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines (115ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (115ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (159ms)

    ✓ Can handle 'ci(' on the closing bracket (167ms)

    ✓ Can handle 'ciB' spanning multiple lines (184ms)

    ✓ will fail when ca( with no () (64ms)

    ✓ will fail when ca{ with no {} (74ms)

    ✓ will fail when caB with no {} (61ms)

    ✓ Can handle 'ci[' spanning multiple lines (78ms)

    ✓ Can handle 'ci]' on first bracket (92ms)

    ✓ Can handle 'ca[' on first bracket (91ms)

    ✓ Can handle 'ca]' on first bracket (100ms)

    ✓ Can handle 'ci'' on first quote (69ms)

    ✓ Can handle 'ci'' inside quoted string (147ms)

    ✓ Can handle 'ci'' on closing quote (82ms)

    ✓ Can handle 'ci'' when string is ahead (184ms)

    ✓ Can handle 'ci"' on opening quote (107ms)

    ✓ Can handle 'ci"' starting behind the quoted word (55ms)

    ✓ Can handle 'ca"' starting behind the quoted word (65ms)

    ✓ Can handle 'ca"' starting on the opening quote (62ms)

    ✓ Can handle 'ci"' with escaped quotes (92ms)

    ✓ Can handle 'ci"' with a single escaped quote (71ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (81ms)

    ✓ Can handle 'ci"' with an escaped backslash (100ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (117ms)

    ✓ Can handle 'ca"' starting on the closing quote (98ms)

    ✓ Can handle 'ci"' with complex escape sequences (87ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (119ms)

    ✓ will fail when ca" ahead of quoted string (84ms)

    ✓ Can handle 'ca`' inside word (70ms)

    ✓ can handle cj (173ms)

    ✓ can handle ck (103ms)

    ✓ can handle c2j (117ms)

    ✓ can handle c2k (115ms)

    ✓ can handle cj on last line (164ms)

    ✓ can handle ck on first line (233ms)

    ✓ can handle c2j on last line (118ms)

    ✓ can handle c2k on first line (243ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (164ms)

    ✓ Can handle 'daw' on word with trailing spaces (207ms)

    ✓ Can handle 'daw' on word with leading spaces (144ms)

    ✓ Can handle 'daw' on word with numeric prefix (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (354ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (105ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (136ms)

    ✓ Can handle 'daw' on end of word (140ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (208ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (116ms)

    ✓ Can handle 'daw' on word at beginning of file (103ms)

    ✓ Can handle 'daw' on word at beginning of line (85ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (195ms)

    ✓ Can handle 'daw' around word at end of line (151ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (128ms)

    ✓ Can handle 'daW' around word at whitespace (215ms)

    ✓ Can handle 'daW' on word with trailing spaces (156ms)

    ✓ Can handle 'daW' on word with leading spaces (225ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' on word with numeric prefix (139ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (218ms)

    ✓ Can handle 'daW' on beginning of word (150ms)

    ✓ Can handle 'daW' on end of one line (187ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (162ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (215ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (161ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (111ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (218ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (111ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (193ms)

    ✓ Can handle 'diw' on word (159ms)

    ✓ Can handle 'diw' on word with numeric prefix (200ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (178ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (134ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (187ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (161ms)

    ✓ Can handle 'diW' on word with trailing spaces (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diW' on word with leading spaces (103ms)

    ✓ Can handle 'diW' on word with numeric prefix (214ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (165ms)

    ✓ Can handle 'diW' on beginning of word (209ms)

    ✓ Can handle d} (63ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle y} at beginning of line (217ms)

    ✓ Select sentence with trailing spaces (120ms)

    ✓ Select sentence with leading spaces (197ms)

    ✓ Select inner sentence with trailing spaces (168ms)

    ✓ Select inner sentence with leading spaces (189ms)

    ✓ Select spaces between sentences (193ms)

    ✓ Can handle 'df' (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'dt' (233ms)

    ✓ Can handle backspace (131ms)

    ✓ Can handle backspace across lines (171ms)

    ✓ Can handle A and backspace (222ms)

    ✓ Can handle 'yy' without changing cursor position (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'P' after 'yy' (234ms)

    ✓ Can handle 'p' after 'yy' (123ms)

    ✓ Can handle 'P' after 'Nyy' (216ms)

    ✓ Can handle 'p' after 'Nyy' (59ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'p' after 'yy' with correct cursor position (229ms)

    ✓ Can handle 'gp' after 'yy' (140ms)

    ✓ Can handle 'gp' after 'Nyy' (173ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (140ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (69ms)

    ✓ Can handle 'gP' after 'yy' (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gP' after 'Nyy' (431ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (143ms)

    ✓ Can handle ']p' after yy (98ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ']p' after 'Nyy' (230ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (72ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (875ms)

    ✓ Can handle '[p' after yy (143ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '[p' after 'Nyy' (231ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (146ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (138ms)

    ✓ Can handle 'p' after y'a (234ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (87ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (217ms)

    ✓ Can handle pasting in visual mode over selection (196ms)

    ✓ Can repeat w (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat p (230ms)

    ✓ I works correctly (277ms)

    ✓ gI works correctly (140ms)

    ✓ gi works correctly (399ms)

    ✓ `. works correctly (247ms)

    ✓ '. works correctly (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g; works correctly (254ms)

    ✓ g, works correctly (135ms)

    ✓ g_ works correctly (212ms)

    ✓ 3g_ works correctly (170ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (433ms)

    ✓ gq handles spaces before single line comments correctly (649ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles tabs before single line comments correctly (439ms)

    ✓ Can handle space (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (230ms)

    ✓ Undo 1 (210ms)

    ✓ Undo 2 (156ms)

    ✓ Undo cursor (323ms)

    ✓ Undo cursor 2 (128ms)

    ✓ Undo cursor 3 (252ms)

    ✓ Undo with movement first (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' (462ms)

    ✓ Can handle 'U' for multiple changes (243ms)

    ✓ Can handle 'U' for new line below (233ms)

    ✓ Can handle 'U' for new line above (234ms)

    ✓ Can handle 'U' for consecutive changes only (255ms)

    ✓ Can handle 'u' to undo 'U' (130ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' to undo 'U' (245ms)

    ✓ Redo (164ms)

    ✓ Redo (331ms)

    ✓ Redo (248ms)

    ✓ Can handle u (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle guw (221ms)

    ✓ Can handle gUw (147ms)

    ✓ Can handle u over line breaks (228ms)

    ✓ can handle s in visual mode (184ms)

    ✓ can handle p with selection (216ms)

    ✓ can handle P with selection (75ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle p in visual to end of line (269ms)

    ✓ can repeat backspace twice (180ms)

    ✓ can delete linewise with d2G (154ms)

    ✓ can delete with + motion and count (166ms)

    ✓ can delete with - motion and count (65ms)

    ✓ can dE correctly (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can dE correctly (126ms)

    ✓ can dE correctly (211ms)

    ✓ can ctrl-a correctly behind a word (147ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (187ms)

    ✓ can ctrl-a on word (149ms)

    ✓ can ctrl-a on a hex number (208ms)

    ✓ can ctrl-a on decimal (135ms)

    ✓ can ctrl-a with numeric prefix (53ms)

    ✓ can ctrl-a on a decimal (81ms)

    ✓ can ctrl-a on an octal  (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Correctly increments in the middle of a number (248ms)

    ✓ can ctrl-x correctly behind a word (48ms)

    ✓ can ctrl-a on an number with word before  (217ms)

    ✓ can ctrl-a on an number with word before and after  (153ms)

    ✓ can ctrl-x on a negative number with word before and after  (222ms)

    ✓ can ctrl-a properly on multiple lines (129ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (207ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (133ms)

    ✓ can <C-a> on word with - in front of it (211ms)

    ✓ can do Y (136ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do S (272ms)

    ✓ / does not affect mark (129ms)

    ✓ / can search with regex (235ms)

    ✓ / can search with newline (171ms)

    ✓ / can search through multiple newlines (111ms)

    ✓ / matches ^ per line (213ms)

    ✓ / matches $ per line (176ms)

    ✓ Can search for forward slash (166ms)

    ✓ Can search backward for question mark (146ms)

    ✓ /\c forces case insensitive search (221ms)

    ✓ /\C forces case sensitive search (179ms)

    ✓ <BS> deletes the last character in search in progress mode (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <S-BS> deletes the last character in search in progress mode (216ms)

    ✓ <C-h> deletes the last character in search in progress mode (159ms)

    ✓ Can do C (125ms)

    ✓ Can do cit on a matching tag (130ms)

    ✓ Ignores cit on a non-matching tag (167ms)

    ✓ Ignores cit on a nested tag (194ms)

    ✓ Can do cit on a tag with an attribute tag (160ms)

    ✓ Can do cat on a matching tag (208ms)

    ✓ Can do cit on a multiline tag (162ms)

    ✓ Can do cit on a multiline tag with nested tags (137ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (144ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (215ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (215ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (202ms)

    ✓ can do cit with self closing tags (135ms)

    ✓ Respects indentation with cc (202ms)

    ✓ Resets cursor to indent end with cc (78ms)

    ✓ can handle 'cc' on empty line (209ms)

    ✓ cc copies linewise (169ms)

    ✓ Indent current line with correct Vim Mode (168ms)

    ✓ Can handle <Esc> and do nothing (201ms)

    ✓ Can handle # on consecutive words (157ms)

    ✓ Can handle # on skipped words (207ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (148ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (205ms)

    ✓ cc on whitespace-only treats whitespace as indent (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cai (374ms)

    ✓ Can do cii (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do caI (220ms)

    ✓ Can do dai (136ms)

    ✓ Can do dii (114ms)

    ✓ Can do daI (205ms)

    ✓ `] go to the end of the previously operated or put text (122ms)

    ✓ '] go to the end of the previously operated or put text (251ms)

    ✓ `[ go to the start of the previously operated or put text (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '[ go to the start of the previously operated or put text (724ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (110ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (209ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (163ms)

    can handle gn

      ✓ gn selects the next match text (257ms)

      ✓ gn selects the current word at |hello (241ms)

      ✓ gn selects the current word at h|ello (230ms)

      ✓ gn selects the current word at hel|lo (233ms)

      ✓ gn selects the current word at hell|o (220ms)

      ✓ gn selects the next word at hello| (265ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (216ms)

      ✓ dgn deletes the current word when cursor is at |hello (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at h|ello (239ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (174ms)

      ✓ dgn deletes the current word when cursor is at hell|o (229ms)

      ✓ dgn deletes the next word when cursor is at hello| (140ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (441ms)

      ✓ cgn deletes the current word when cursor is at |hello (110ms)

      ✓ cgn deletes the current word when cursor is at h|ello (164ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (232ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hell|o (296ms)

      ✓ cgn deletes the next word when cursor is at hello| (90ms)

    can handle gN

      ✓ gN selects the previous match text (316ms)

      ✓ gN selects the current word at hell|o (440ms)

      ✓ gN selects the current word at hel|lo (354ms)

      ✓ gN selects the current word at h|ello (234ms)

      ✓ gN selects the current word at |hello (264ms)

      ✓ gN selects the previous word at | hello (227ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (131ms)

      ✓ dgN deletes the current word when cursor is at hell|o (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at hel|lo (250ms)

      ✓ dgN deletes the current word when cursor is at h|ello (153ms)

      ✓ dgN deletes the current word when cursor is at |hello (206ms)

      ✓ dgN deletes the previous word when cursor is at | hello (132ms)

    can handle cgN

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the previous match text (from first line) (252ms)

      ✓ cgN deletes the current word when cursor is at hell|o (181ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (307ms)

      ✓ cgN deletes the current word when cursor is at h|ello (182ms)

      ✓ cgN deletes the current word when cursor is at |hello (156ms)

      ✓ cgN deletes the previous word when cursor is at | hello (201ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (105ms)

    ✓ Can activate with R from Normal mode (160ms)

    ✓ Can handle R (201ms)

    ✓ Can handle R past current line (114ms)

    ✓ Can handle R and exit Replace Mode (236ms)

    ✓ Can handle R across lines (114ms)

    ✓ Can handle R across lines and exit Replace Mode (208ms)

    ✓ Can handle R with {count} (143ms)

    ✓ Can handle backspace (221ms)

    ✓ Can handle backspace (146ms)

    ✓ Can handle backspace across lines (204ms)

    ✓ Can handle arrows (89ms)

    ✓ Can handle . (110ms)

    ✓ Can handle . across lines (333ms)

  Mode Visual

    ✓ can be activated (47ms)

    ✓ Can handle w (179ms)

    ✓ Can handle wd (137ms)

    ✓ Can handle x (119ms)

    ✓ Can handle x across a selection (243ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vwd in middle of sentence (423ms)

    ✓ Can do vwd in middle of sentence (114ms)

    ✓ Can do vwd multiple times (179ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (250ms)

    ✓ Can handle H key (72ms)

    ✓ Can handle backspace key (188ms)

    ✓ handles case where we delete over a newline (212ms)

    ✓ handles change operator (201ms)

    ✓ Can do vat on multiple matching tags (159ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (148ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (212ms)

    ✓ Repeat-prefixed vat does not bleed below (150ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (59ms)

    ✓ Can do vi) on a matching parenthesis (82ms)

    ✓ Can do vi) on multiple matching parens (129ms)

    ✓ Can do va) on a matching parenthesis (220ms)

    ✓ Can do va) on multiple matching parens (138ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (172ms)

    ✓ Repeat-prefixed va) does not bleed below (111ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va} on a matching bracket as first character (170ms)

    ✓ Can do va} on multiple matching brackets (148ms)

    ✓ Can do vi( on a matching bracket near first character (222ms)

    ✓ Can do vi{ on outer pair of nested braces (67ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (65ms)

    ✓ Can do va] on multiple matching brackets (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (255ms)

    ✓ Repeat-prefixed vaf does not bleed below (135ms)

    ✓ vaf only expands to enclosing pairs (81ms)

    ✓ Can use . to repeat indent in visual (145ms)

    ✓ Can do v_x to delete to first char (81ms)

    ✓ Can do vg_x to delete to last char with no EOL (83ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (145ms)

    ✓ Can do v$x to delete to last char including EOL (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do gv to reselect previous selection (276ms)

    Vim's EOL handling is weird

      ✓ delete through eol (175ms)

      ✓ join 2 lines by deleting through eol (158ms)

      ✓ d$ doesn't delete whole line (102ms)

      ✓ vd$ does delete whole line (118ms)

      ✓ Paste over selection copies the selection (250ms)

      ✓ Paste over selection copies the selection linewise (136ms)

    Arrow keys work perfectly in Visual Mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <up> key (562ms)

      ✓ Can handle <down> key (146ms)

      ✓ Can handle <left> key (190ms)

      ✓ Can handle <right> key (123ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (210ms)

      ✓ Can handle 'gj' (172ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (92ms)

      ✓ Can handle 'vawd' on word with trailing spaces (219ms)

      ✓ Can handle 'vawd' on word with leading spaces (151ms)

      ✓ Can handle 'vawd' on word with numeric prefix (184ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (176ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (149ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (311ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (227ms)

      ✓ Can handle 'vaWd' on word with leading spaces (136ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (182ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (167ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (137ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (182ms)

      ✓ Can handle 'vaWd' on word with leading spaces (162ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (97ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (117ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (203ms)

      ✓ Can handle 'vawd' on word with trailing spaces (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with leading spaces (241ms)

      ✓ Can handle 'vawd' on word with numeric prefix (129ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (127ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (204ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (223ms)

      ✓ Can handle 'vaWd' on word with leading spaces (112ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (211ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (166ms)

      ✓ Can handle 'Y' in visual mode (218ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (552ms)

      ✓ Select multiple sentences in visual mode (145ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (110ms)

      ✓ Select inner sentence with leading spaces in visual mode (217ms)

      ✓ Select spaces between sentences in visual mode (158ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (184ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (233ms)

      ✓ Can do vat on a matching tag (98ms)

    handles replace in visual mode

      ✓ Can do a single line replace (183ms)

      ✓ Can do a multi line replace (124ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (213ms)

      ✓ D deletes the current line (121ms)

    handles indent blocks in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do vai (237ms)

      ✓ Can do vii (79ms)

      ✓ Doesn't naively select the next line (143ms)

      ✓ Searches backwards if cursor line is empty (91ms)

      ✓ Can do vaI (133ms)

    visualstar

      ✓ Works with * (193ms)

      ✓ Works with # (61ms)

    search works in visual mode

      ✓ Works with / (80ms)

      1) Works with ?

      ✓ Selects correct range (185ms)

    X will delete linewise

      ✓ normal selection (169ms)

      ✓ normal selection (170ms)

    C will delete linewise

      ✓ normal selection (171ms)

      ✓ normal selection (195ms)

    R will delete linewise

      ✓ normal selection (196ms)

      ✓ normal selection (173ms)

    Linewise Registers will be inserted properly

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ downward selection (263ms)

      ✓ upward selection (141ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (55ms)

      ✓ multiline indent bottom up selection (303ms)

      ✓ repeat multiline indent top down selection (147ms)

      ✓ repeat multiline indent bottom up selection (150ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (105ms)

      ✓ multiline outdent bottom up selection (201ms)

      ✓ repeat multiline outdent top down selection (180ms)

      ✓ repeat multiline outdent bottom up selection (212ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (159ms)

    vi{ will go to end of second to last line

      ✓ select (114ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode (41ms)

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (452ms)

      ✓ gv selects the last pasted text (which is longer than original) (705ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gv selects the last pasted text (multiline) (551ms)

    can handle gn

      ✓ gn selects the next match text (316ms)

      ✓ gn selects the current word at |hello (260ms)

      ✓ gn selects the current word at h|ello (377ms)

      ✓ gn selects the current word at hel|lo (257ms)

      ✓ gn selects the next word at hell|o (259ms)

      ✓ gn selects the next word at hello| (315ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (74ms)

      ✓ multiline insert from top down selection (112ms)

      ✓ skips blank lines (66ms)

    can append text with A

      ✓ multiline append from bottom up selection (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (264ms)

      ✓ skips blank lines (51ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (316ms)

      ✓ U/gU across a selection (226ms)

      ✓ U/gU across a selection (reverse) (170ms)

      ✓ u/gu on single character (115ms)

      ✓ u/gu across a selection (100ms)

      ✓ u/gu across a selection (reverse) (136ms)

  Mode Visual Block

    ✓ can be activated (46ms)

    ✓ Can handle A forward select (235ms)

    ✓ Can handle A backwards select (168ms)

    ✓ Can handle I forward select (143ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle I backwards select (361ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (83ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (176ms)

    ✓ Can handle c forward select (120ms)

    ✓ Can handle c backwards select (192ms)

    ✓ Can handle C (132ms)

    ✓ Can do a multi line replace (183ms)

    ✓ Can handle 'D' (58ms)

    ✓ Can handle 'gj' (95ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Properly add to end of lines j then $ (334ms)

    ✓ Properly add to end of lines $ then j (124ms)

    ✓ o works in visual block mode (106ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (209ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle wd (477ms)

    ✓ Can handle x (112ms)

    ✓ Can handle x across a selection (160ms)

    ✓ Can do vwd in middle of sentence (174ms)

    ✓ Can do vwd in middle of sentence (133ms)

    ✓ Can do vwd multiple times (267ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (120ms)

    ✓ handles case where we delete over a newline (185ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ handles change operator (362ms)

    ✓ Vp updates register content (78ms)

    ✓ Vp does not append unnecessary newlines (first line) (78ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (354ms)

    ✓ Vp does not append unnecessary newlines (last line) (148ms)

    Vim's EOL handling is weird

      ✓ delete through eol (118ms)

      ✓ join 2 lines by deleting through eol (162ms)

      ✓ d$ doesn't delete whole line (76ms)

      ✓ vd$ does delete whole line (123ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (189ms)

      ✓ Can handle <down> key (74ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (196ms)

      ✓ Can handle 'gj' (157ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (209ms)

      ✓ Can handle d key (71ms)

      ✓ Can handle d key (55ms)

      ✓ Can handle d key (66ms)

      ✓ can handle 'c' (52ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (117ms)

      ✓ Can do a multi visual line replace (56ms)

      ✓ Can do a multi visual line replace from the bottom up (122ms)

    search works in visual line mode

      ✓ Works with / (108ms)

      ✓ Works with ? (88ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (229ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (77ms)

      ✓ linewise visual put works also in the end of document (154ms)

      ✓ gv selects the last pasted text (which is shorter than original) (661ms)

      ✓ gv selects the last pasted text (which is longer than original) (432ms)

      ✓ gv selects the last pasted text (multiline) (275ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (62ms)

      ✓ multiline insert from top down selection (187ms)

      ✓ skips blank lines (167ms)

    can append text with A

      ✓ multiline append from bottom up selection (138ms)

      ✓ multiline append from top down selection (215ms)

      ✓ skips blank lines (145ms)

  Mode Normal

    ✓ Can handle 'x' (120ms)

    ✓ Can handle 'Nx' (196ms)

    ✓ Can handle 'Nx' and paste (77ms)

    ✓ Can handle 'x' at end of line (128ms)

    ✓ Can handle 'Ns' (83ms)

    ✓ Can handle 'Ns' at end of line (138ms)

    ✓ Can handle '<Del>' (109ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (117ms)

    ✓ Can handle '<Del>' at end of line (119ms)

    ✓ Can handle 'cc' (229ms)

    ✓ Can handle 'Ncc' (133ms)

    ✓ Can handle 'yy' (164ms)

    ✓ Can handle 'D' (364ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' on empty lines (135ms)

    ✓ Can handle 'DD' (183ms)

    ✓ Can handle 'C' (149ms)

    ✓ Can handle 'NC' (174ms)

    ✓ Can handle 'NC' and put (115ms)

    ✓ Can handle 'r' (193ms)

    ✓ Can handle '<Count>r' (63ms)

    ✓ Can handle '<Count>r' (201ms)

    ✓ Can handle 'r' after 'dd' (159ms)

    ✓ Can handle 'r
' (92ms)

    ✓ Can handle '<Count>r
' (116ms)

    ✓ Can handle 'J' once (183ms)

    ✓ Can handle 'J' twice (127ms)

    ✓ Can handle 'J' with empty last line (213ms)

    ✓ Can handle 'J's with multiple empty last lines (160ms)

    ✓ Can handle 'J' with leading white space on next line (130ms)

    ✓ Can handle 'J' with only white space on next line (55ms)

    ✓ Can handle 'J' with TWO indented lines (55ms)

    ✓ Can handle 'J' with ')' first character on next line (130ms)

    ✓ Can handle 'J' with a following delete (148ms)

    ✓ Can handle 'J' in Visual Line mode (58ms)

    ✓ Can handle 'gJ' once (211ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (142ms)

    ✓ Can handle '~' (187ms)

    ✓ Can handle 'g~{motion}' (84ms)

    ✓ Can handle '<BS>' in insert mode (170ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle undo with P (409ms)

    ✓ Can handle 'ge' in multiple lines case1 (112ms)

    ✓ Can handle 'ge' in multiple lines case2 (197ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (138ms)

    ✓ Can repeat '~' with dot (229ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat 'x' (129ms)

    ✓ Can repeat 'J' (141ms)

    ✓ Can handle dot with A (250ms)

    ✓ Can handle dot with I (101ms)

    ✓ Can repeat actions that require selections (101ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (195ms)

    ✓ Can repeat insert change and '<C-t>' (174ms)

    ✓ Can repeat change by `<C-a>` (224ms)

    ✓ Only one arrow key can be repeated in Insert Mode (241ms)

    ✓ Cached content change will be cleared by arrow keys (183ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (119ms)

    ✓ inside parenthesis (100ms)

    ✓ nested parenthesis beginning (104ms)

    ✓ nested parenthesis end (199ms)

    ✓ nested bracket and parenthesis beginning (140ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested bracket, parenthesis, braces beginning (129ms)

    ✓ nested bracket, parenthesis, braces end (186ms)

    ✓ parentheses after > (158ms)

    ✓ parentheses after " (66ms)

  Motions in Normal Mode

    ✓ Can handle [( (145ms)

    ✓ Can handle nested [( (167ms)

    ✓ Can handle <number>[( (82ms)

    ✓ Can handle [( and character under cursor exclusive (103ms)

    ✓ Can handle ]) (126ms)

    ✓ Can handle nested ]) (147ms)

    ✓ Can handle <number>]) (139ms)

    ✓ Can handle ]) and character under cursor exclusive (131ms)

    ✓ Can handle [{ (133ms)

    ✓ Can handle nested [{ (118ms)

    ✓ Can handle <number>[{ (126ms)

    ✓ Can handle [{ and character under cursor exclusive (199ms)

    ✓ Can handle ]} (158ms)

    ✓ Can handle nested ]} (208ms)

    ✓ Can handle <number>]} (153ms)

    ✓ Can handle ]} and character under cursor exclusive (200ms)

    ✓ Can handle 'ge' (131ms)

    ✓ Can handle 'gg' (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gg' to first non blank char on random line (319ms)

    ✓ Can handle 'gg' to first non blank char on first line (163ms)

    ✓ 'gg' obeys startofline (165ms)

    ✓ Retain same column when moving up/down (73ms)

    ✓ Can handle <enter> (172ms)

    ✓ $ always keeps cursor on EOL (139ms)

    ✓ Can handle $ with a count (110ms)

    ✓ Can handle $ with a count at end of file (152ms)

    ✓ Can handle <End> with a count (195ms)

    ✓ Can handle <D-right> with a count (68ms)

    ✓ Can handle 'f' (66ms)

    ✓ Can handle 'f' twice (178ms)

    ✓ Can handle 'f' with <tab> (158ms)

    ✓ Can handle 'f' and find back search (161ms)

    ✓ Can handle 'F' (146ms)

    ✓ Can handle 'F' twice (151ms)

    ✓ Can handle 'F' and find back search (52ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'f' and multiple back searches (235ms)

    ✓ Can handle 't' (138ms)

    ✓ Can handle 't' twice (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 't' and find back search (380ms)

    ✓ Can handle 'T' (94ms)

    ✓ Can handle 'T' twice (178ms)

    ✓ Can handle 'T' and find back search (193ms)

    ✓ Can run a forward search (93ms)

    ✓ Can run a forward and find next search (59ms)

    ✓ Can run a forward and find previous search from end of word (200ms)

    ✓ Can run a reverse search (93ms)

    ✓ Can run a reverse and find next search (136ms)

    ✓ cancelled search reverts to previous search state (149ms)

    ✓ Backspace on empty search cancels (144ms)

    ✓ Search offsets: b does nothing (114ms)

    ✓ Search offsets: b2 goes 2 to the right (196ms)

    ✓ Search offsets: b+3 goes 3 to the right (78ms)

    ✓ Search offsets: e goes to the end (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Search offsets: character offset goes across line boundaries (118ms)

    ✓ Search offsets: 2 goes 2 down (213ms)

    ✓ Search offsets: -2 goes 2 up (84ms)

    ✓ maintains column position correctly (226ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ maintains column position correctly with $ (161ms)

    ✓ Can handle G  (183ms)

    ✓ Can handle G with number prefix (275ms)

    ✓ Can handle G with number prefix (155ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix (67ms)

    ✓ Can handle 0 (165ms)

    ✓ Can handle 0 as part of a repeat (160ms)

    ✓ Can handle g* (206ms)

    ✓ Can handle g*n (139ms)

    ✓ Can handle * (185ms)

    ✓ Can handle ** (74ms)

    ✓ Can handle # on whitespace (107ms)

    ✓ Can handle # on EOL (79ms)

    ✓ Can handle g# (111ms)

    ✓ Can handle g#n (126ms)

    ✓ Can handle # (176ms)

    ✓ Can handle # already on the word (46ms)

    ✓ Can handle ## (115ms)

    ✓ * adds to search history (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ # adds to search history (282ms)

    ✓ Can handle | (92ms)

    ✓ Can handle <number> | (79ms)

    ✓ Can handle + (140ms)

    ✓ Can handle + indent (164ms)

    ✓ Can handle + with count prefix (192ms)

    ✓ Can handle - (117ms)

    ✓ Can handle - indent

    ✓ Can handle - with count prefix (43ms)

    ✓ Can handle _ (131ms)

    ✓ Can handle _ with count prefix (51ms)

    ✓ Can handle g_ (52ms)

    ✓ Can handle g_ with count prefix (117ms)

    ✓ Can handle <up> key (44ms)

    ✓ Can handle <down> key (49ms)

    ✓ Can handle <left> key (127ms)

    ✓ Can handle <right> key (47ms)

    ✓ Can handle 'gk' (47ms)

    ✓ Can handle 'gj' (123ms)

    - Preserves cursor position when handling 'gk'
    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move to word right (41ms)

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right
      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph
      ✓ move down starting inside empty line
      ✓ paragraph at end of document
    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (141ms)

        ✓ l wraps to next line (42ms)

        ✓ <left> wraps to previous line (97ms)

        ✓ <right> wraps to next line (190ms)

      insert mode

        ✓ <left> wraps to previous line (49ms)

        ✓ <right> once goes to end of line (84ms)

        ✓ <right> twice wraps to next line (131ms)

    whichwrap disabled
      normal mode

        ✓ h does not wrap to previous line (154ms)

        ✓ l does not wrap to next line (54ms)

        ✓ <left> does not wrap to previous line (180ms)

        ✓ <right> does not wrap to next line (81ms)

      insert mode

        ✓ <left> does not wrap to previous line (205ms)

        ✓ <right> does not wrap to next line (147ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (153ms)

      ✓ search wraps around the start of the file (119ms)

    wrapscan disabled

      ✓ search stops at the end of the file (205ms)

      ✓ search stops at the start of the file (62ms)

  Multicursor

    ✓ can add multiple cursors below (188ms)

    ✓ can add multiple cursors above (161ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (348ms)

    ✓ gcj comments in current and next line (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (537ms)

    ✓ block comment in Visual Mode (230ms)

    ✓ comment in visual line mode (141ms)

    ✓ comment in visual block mode (192ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (1310ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =$ formats entire line (333ms)

    ✓ =j formats two lines (201ms)

    ✓ 3=k formats three lines (223ms)

    ✓ =gg formats to top of file (199ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =G formats to bottom of file (116ms)

    ✓ =ip formats paragraph (188ms)

    ✓ format in visual mode (110ms)

  put operator

    ✓ basic put test (194ms)

    ✓ test yy end of line (100ms)

    ✓ test yy first line (173ms)

    ✓ test yy middle line (150ms)

    ✓ test yy with correct positon movement (201ms)

    ✓ test visual block single line yank p (152ms)

    ✓ test visual block single line yank P (95ms)

    ✓ test visual block single line delete p (78ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line delete P (261ms)

  rot13 operator

    2) the rot13 function is correct

    3) g?j works

    4) g? in visual mode works

    5) g? in visual line mode works

    6) g? in visual block mode works

  shift operator

    ✓ basic shift left test (162ms)

    ✓ shift left goto end test (78ms)

    ✓ shift left goto line test (179ms)

    ✓ shift right goto end test (131ms)

    ✓ shift right goto line test (115ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (118ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step over whitespace (1062ms)

      ✓ step to Camel word (171ms)

      ✓ step to CAP word (76ms)

      ✓ step after CAP word (188ms)

      ✓ step from middle of word to Camel word (203ms)

      ✓ step to number word (148ms)

      ✓ step to operator word (134ms)

      ✓ step from inside operator word (257ms)

      ✓ step to operator and then over (114ms)

    handles <leader>w for underscore_var

      ✓ step to _word (193ms)

      ✓ step over whitespace to word (159ms)

      ✓ step from inside word to _word (78ms)

      ✓ step form _word to number (165ms)

      ✓ step from nubmer word to _word (126ms)

      ✓ step from in whitespace to word (198ms)

      ✓ step in ALL_CAPS_WORD (198ms)

    handles d<leader>w

      ✓ delete from start of camelWord (129ms)

      ✓ delete from middle of camelWord (108ms)

      ✓ delete from start of CamelWord (178ms)

      ✓ delete two words from camelWord (140ms)

      ✓ delete from start of underscore_word (56ms)

      ✓ delete from middle of underscore_word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camel_word (615ms)

    handles di<leader>w

      ✓ delete from start of camelWord (160ms)

      ✓ delete from middle of camelWord (199ms)

      ✓ delete from start of CamelWord (173ms)

      ✓ delete two words from camelWord (137ms)

      ✓ delete from start of underscore_word (149ms)

      ✓ delete from middle of underscore_word (173ms)

      ✓ delete two words from camel_word (61ms)

    handles <leader>b

      ✓ back from middle of word (201ms)

      ✓ back over whitespace to camelWord (108ms)

      ✓ back twice over operator (158ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (51ms)

      ✓ from middle to end of underscore_word (167ms)

      ✓ twice to end of word over operator (96ms)

  easymotion plugin

    ✓ Can handle s move (217ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2s move (674ms)

    ✓ Can handle f move (47ms)

    ✓ Can handle 2f move (63ms)

    ✓ Can handle F move (103ms)

    ✓ Can handle 2F move (182ms)

    ✓ Can handle t move (140ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle bd-t move (228ms)

    ✓ Can handle 2t move (165ms)

    ✓ Can handle bd-t2 move (112ms)

    ✓ Can handle T move (159ms)

    ✓ Can handle 2T move (123ms)

    ✓ Can handle w move (213ms)

    ✓ Can handle bd-w move (170ms)

    ✓ Can handle b move (164ms)

    ✓ Can handle e move (287ms)

    ✓ Can handle bd-e move (124ms)

    ✓ Can handle ge move (215ms)

    ✓ Can handle n-char move (179ms)

    ✓ Can handle j move (208ms)

    ✓ Can handle k move (138ms)

    ✓ Can handle bd-jk move (1) (170ms)

    ✓ Can handle bd-jk move (2) (188ms)

    ✓ Can handle lineforward move (1) (158ms)

    ✓ Can handle lineforward move (2) (170ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (162ms)

    ✓ Can handle searching for backslash (\) (123ms)

    ✓ Can handle searching for carat (^) (244ms)

    ✓ Can handle searching for dot (.) (62ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (109ms)

    ✓ Replaces within inner Word (207ms)

    ✓ Replaces within '' (131ms)

    ✓ Replaces within '' including spaces (225ms)

    ✓ Replaces within () (147ms)

    ✓ Replaces within () including spaces (185ms)

    ✓ Replaces within a paragraph (170ms)

    ✓ Replaces using a specified register (218ms)

    ✓ Replaces within {} over multiple lines (145ms)

    ✓ Replaces a multiline register within {} over multiple lines (205ms)

    ✓ Replaces a multiline register within {} over multiple lines (123ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (154ms)

    ✓ grr replaces the entire line with the register (71ms)

    ✓ grr can replace multiple lines (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode (232ms)

    ✓ Replaces in visual mode using a specified register (207ms)

    ✓ Replaces in visual line mode (227ms)

    ✓ grj is linewise (184ms)

  sneak plugin

    ✓ Can handle s motion (149ms)

    ✓ Can handle S motion (196ms)

    ✓ Can handle <operator>z motion (152ms)

    ✓ Can handle <operator>Z motion (192ms)

    ✓ Can handle s; motion (145ms)

    ✓ Can handle s, motion (190ms)

    ✓ Can handle S; motion (149ms)

    ✓ Can handle S, motion (183ms)

    ✓ Can handle single letter s motion (102ms)

    ✓ Can handle single letter S motion (183ms)

    ✓ Can handle single letter <operator>z motion (142ms)

    ✓ Can handle single letter <operator>Z motion (198ms)

    ✓ Can handle single letter s; motion (170ms)

    ✓ Can handle single letter s, motion (167ms)

    ✓ Can handle single letter S; motion (160ms)

    ✓ Can handle single letter S, motion (77ms)

    ✓ Can handle multiline single char <number>s motion (201ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (245ms)

    ✓ 'ysiw(' surrounds word with space (180ms)

    ✓ 'ysw)' surrounds word without space (148ms)

    ✓ 'ysw(' surrounds word with space (118ms)

    ✓ 'ysaw)' surrounds word without space (124ms)

    ✓ 'ysaw(' surrounds word with space (198ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw<' surrounds word with tags (394ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (248ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (182ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (155ms)

    ✓ change surround (109ms)

    ✓ change surround with two pairs of quotes (176ms)

    ✓ change surround with two pairs of parens (107ms)

    ✓ change surround with alias (197ms)

    ✓ change surround to tags (199ms)

    ✓ delete surround (182ms)

    ✓ delete surround with quotes (110ms)

    ✓ delete surround with nested of quotes (178ms)

    ✓ delete surround with inconsistent quotes (111ms)

    ✓ delete surround with mixed quotes (211ms)

    ✓ delete surround with empty quotes cursor at start (88ms)

    ✓ delete surround with empty quotes cursor at end (185ms)

    ✓ don't delete surround if cursor is after closing match (109ms)

    ✓ delete surround if cursor is before opening match (81ms)

    ✓ delete surround with two pairs of parens (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround with alias (247ms)

    ✓ delete surround with tags (130ms)

    ✓ change surround brackets at end of line (160ms)

    ✓ changing brackets with surround works again (79ms)

    ✓ change surround with tags that contain an attribute and preserve them (195ms)

    ✓ change surround with tags that contain an attribute and remove them (188ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (263ms)

    ✓ Can use two registers together (224ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use black hole register (609ms)

    ✓ System clipboard works with chinese characters (53ms)

    ✓ Yank stores text in Register '0' (210ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (248ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (199ms)

    ✓ Register '1'-'9' stores delete content (263ms)

    ✓ "A appends linewise text to "a (307ms)

    ✓ "A appends character wise text to "a (201ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (184ms)

    ✓ Small deletion using Del is stored in small delete register (292ms)

    ✓ Small deletion using X is stored in small delete register (209ms)

    ✓ Search register (/) is set by forward search (426ms)

    ✓ Search register (/) is set by backward search (267ms)

    ✓ Search register (/) is set by star search (256ms)

    ✓ Command register (:) is set by command line (73ms)

    ✓ Read-only registers cannot be written to (212ms)

    clipboard

      ✓ Can access '*' (clipboard) register (161ms)

      ✓ Can access '+' (clipboard) register (257ms)

  Repeatable movements with f and t

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat f<character> (59ms)

    ✓ Can repeat reversed F<character>

    ✓ Can repeat t<character> (410ms)

    ✓ Can repeat N times reversed t<character> (142ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (137ms)

      ✓ move one sentence backward (169ms)

      ✓ move [count] sentences backward (187ms)

      ✓ move one sentence backward single line - middle (145ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward no space (233ms)

      ✓ move one sentence backward no space - middle (177ms)

      ✓ move one sentence backward - multiline (270ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward - multiline - period (297ms)

      ✓ move one sentence backward - multiline - previous line (133ms)

      ✓ move one sentence backward - multiline - previous line - period (72ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1297 passing (6m)

  4 pending

  6 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:921:5)


  2) rot13 operator
       the rot13 function is correct:

      Content does not match; Expected=nopqrstuvwxyzabcdefghijklm. Actual=zyxwvutsrqponmlkjihgfedcba.
      + expected - actual

      -zyxwvutsrqponmlkjihgfedcba
      +nopqrstuvwxyzabcdefghijklm
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:14:3)


  3) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=zyx.
      + expected - actual

      -zyx
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:21:3)


  4) rot13 operator
       g? in visual mode works:

      Content does not match; Expected=aop. Actual=ayx.
      + expected - actual

      -ayx
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:28:3)


  5) rot13 operator
       g? in visual line mode works:

      Content does not match; Expected=nop. Actual=zyx.
      + expected - actual

      -zyx
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:35:3)


  6) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=aop. Actual=ayx.
      + expected - actual

      -ayx
      +aop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:42:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 5a723420-1eb1-11ea-8c7c-334558e6cc20

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.2 build /home/travis/build/VSCodeVim/Vim
> gulp build

[20:49:48] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[20:49:48] Starting 'build'...
[20:49:48] Starting 'prettier'...
[20:49:50] Finished 'prettier' after 1.57 s
[20:49:50] Starting 'tsc'...
[20:49:50] Starting 'tslint'...
[20:49:57] Finished 'tslint' after 7.51 s
[20:50:06] Finished 'tsc' after 16 s
[20:50:06] Starting 'commit-hash'...
[20:50:06] Finished 'commit-hash' after 30 ms
[20:50:06] Finished 'build' after 18 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.0 into .vscode-test/vscode-1.41.0.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.0/linux-x64/stable
Downloaded VS Code 1.41.0
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-14T20:50:10.840Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive
    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command <C-w> can remove word in search mode (58ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (38ms)

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (64ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (101ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (57ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (50ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (60ms)

  command-line lexer

    ✓ can lex empty string
    ✓ can lex comma
    ✓ can lex percent
    ✓ can lex dollar
    ✓ can lex dot
    ✓ can lex one number
    ✓ can lex longer number
    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args
    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args
    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (567ms)

    ✓ :smile editor contains smile text (544ms)

  Basic sort

    ✓ Sort whole file, asc (222ms)

    ✓ Sort whole file, asc, ignoreCase (164ms)

    ✓ Sort whole file, dsc (151ms)

    ✓ Sort whole file, dsc, ignoreCase (154ms)

    ✓ Sort range, asc (248ms)

    ✓ Sort range, asc, ignoreCase (225ms)

    ✓ Sort range, dsc (208ms)

    ✓ Sort range, dsc, ignoreCase (185ms)

    ✓ Sort whole file, asc, unique (277ms)

  Horizontal split

    ✓ Run :sp (83ms)

    ✓ Run :split (93ms)

    ✓ Run :new (83ms)

  :close args parser
    ✓ can parse empty args

    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input
  :substitute args parser
    ✓ can parse pattern, replace, and flags
    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter
    ✓ can parse flag KeepPreviousFlags
  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang
      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (104ms)

    ✓ Replace with `g` flag (86ms)

    ✓ Replace with flags AND count (190ms)

    ✓ Replace with `c` flag (77ms)

    ✓ Replace with `gc` flag (167ms)

    ✓ Replace across all lines (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replace on specific single line (390ms)

    ✓ Replace on current line using dot (127ms)

    ✓ Replace single relative line using dot and plus (159ms)

    ✓ Replace across specific line range (161ms)

    ✓ Replace across relative line range using dot, plus, and minus (169ms)

    ✓ Replace across relative line range using numLines+colon shorthand (200ms)

    ✓ Repeat replacement across relative line range (165ms)

    ✓ Replace with range AND count but no flags (120ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (212ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (161ms)

    ✓ Undocumented: trailing operators use 1 as RHS (136ms)

    ✓ Replace specific single equal lines (165ms)

    ✓ Replace current line with no active selection (145ms)

    ✓ Replace text in selection (222ms)

    ✓ Substitute support marks (129ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (77ms)

      ✓ Replace with `g` flag inverts global flag (91ms)

      ✓ Replace with `c` flag inverts global flag (135ms)

      ✓ Replace multiple lines (136ms)

      ✓ Replace across specific lines (164ms)

      ✓ Replace current line with no active selection (169ms)

      ✓ Replace text in selection (185ms)

      ✓ Substitute support marks (176ms)

      ✓ Substitute with escaped delimiter (82ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (369ms)

      ✓ Substitute with previous search using # (375ms)

      ✓ Substitute with previous search using / (351ms)

      ✓ Substitute with parameters should update search state (190ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (367ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (278ms)

      ✓ Substitute repeat previous should accept flags (114ms)

      ✓ Substitute with empty search string should use last searched pattern (433ms)

      ✓ Ampersand (&) should repeat the last substitution (227ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file (40ms)

    ✓ tabedit with no arguments when not in workspace opens an untitled file (44ms)

    ✓ tabe with absolute path when not in workspace opens file (98ms)

    ✓ tabe with current file path does nothing (119ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (52ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (81ms)

    ✓ command line file tab completion with space in file path (152ms)

  Vertical split

    ✓ Run :vs (115ms)

    ✓ Run :vsp (87ms)

    ✓ Run :vsplit (104ms)

    ✓ Run :vnew (395ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :vne (445ms)

  Basic write-quit

    ✓ Run write and quit (99ms)

  Provide line completions
    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (65ms)

      ✓ Can complete lines in file with different indentation (82ms)

      ✓ Returns no completions for unmatched line (99ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (60ms)

  Notation

    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (108ms)

[main 2019-12-14T20:50:40.842Z] update#setState checking for updates

    ✓ getMatchingRemap (105ms)

[main 2019-12-14T20:50:40.898Z] update#setState idle

    ✓ jj -> <Esc> through modehandler (151ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (144ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (157ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (114ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (132ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (198ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (489ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (240ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command
    ✓ remappings are de-duped
  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (69ms)

        ✓ Can track jumps for keys: GggG (147ms)

        ✓ Can track jumps for keys: GggGgg (153ms)

        ✓ Can track jumps for keys: /b<CR>n (82ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (230ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%% (135ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (103ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (175ms)

        ✓ Can track jumps for keys: j%%<C-o>% (165ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (113ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (180ms)

        ✓ Can enter number to jump back multiple times (173ms)

        ✓ Can track one-line `` jumps (175ms)

        ✓ Can track one-line double `` jumps (215ms)

        ✓ Can track one-line '' jumps (171ms)

        ✓ Can track one-line double '' jumps (239ms)

        ✓ Can handle '' jumps with no previous jump (109ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (222ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (108ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (263ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (197ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (219ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (149ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (227ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (366ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (81ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (182ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (53ms)

  Record and execute a macro

    ✓ Can record and execute (266ms)

    ✓ Can repeat last invoked macro (306ms)

    ✓ Can play back with count (660ms)

    ✓ Can play back with count, abort when a motion fails (602ms)

    ✓ Repeat change on contiguous lines (266ms)

    ✓ Append command to a macro (299ms)

    ✓ Can record Ctrl Keys and repeat (303ms)

    ✓ Can execute macros with dot commands properly (192ms)

    ✓ : (command) register can be used as a macro (147ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (132ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (94ms)

    ✓ <C-c> can exit insert (123ms)

    ✓ <Esc> can exit insert (158ms)

    ✓ Stay in insert when entering characters (152ms)

    ✓ Can handle 'O' (108ms)

    ✓ Can handle 'i' (216ms)

    ✓ Can handle 'I' (156ms)

    ✓ Can handle 'a' (170ms)

    ✓ Can handle 'A' (119ms)

    ✓ Can handle '<C-w>' (101ms)

    ✓ Can handle <C-w> on leading whitespace (50ms)

    ✓ Can handle <C-w> at beginning of line (85ms)

    ✓ Can handle <C-u> (149ms)

    ✓ Can handle <C-u> on leading characters (95ms)

    ✓ Can handle <C-u> on leading whitespace (72ms)

    ✓ Correctly places the cursor after deleting the previous line break (81ms)

    ✓ will not remove leading spaces input by user (41ms)

    ✓ will remove closing bracket (42ms)

    ✓ Backspace works on whitespace only lines (81ms)

    ✓ Backspace works on end of whitespace only lines (130ms)

    ✓ Backspace works at beginning of file (109ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (160ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (110ms)

    ✓ Can perform insert command prefixed with count (252ms)

    ✓ Can perform append command prefixed with count (131ms)

    ✓ Can perform insert at start of line command prefixed with count (129ms)

    ✓ Can perform append to end of line command prefixed with count (218ms)

    ✓ Can perform change char (s) command prefixed with count (191ms)

    ✓ Can perform command prefixed with count with <C-[> (128ms)

    ✓ Can handle 'o' with count (209ms)

    ✓ Can handle 'O' with count (113ms)

    ✓ Can handle backspace at beginning of line with all spaces (84ms)

    ✓ Can handle digraph insert (125ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (118ms)

    ✓ Can handle dw (66ms)

    ✓ Can handle dw (191ms)

    ✓ Can handle dw across lines (1) (133ms)

    ✓ Can handle dw across lines (2) (57ms)

    ✓ Can handle dd last line (79ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (77ms)

    ✓ Can handle 3dd (43ms)

    ✓ Can handle 3dd off end of document (63ms)

    ✓ Can handle d2d (205ms)

    ✓ Can handle dd empty line (64ms)

    ✓ Can handle ddp (97ms)

    ✓ Can handle 'de' (92ms)

    ✓ Can handle 'de' then 'de' again (100ms)

    ✓ Can handle 'db' (137ms)

    ✓ Can handle 'db then 'db' again (150ms)

    ✓ Can handle 'dl' at end of line (99ms)

    ✓ Can handle 'dF' (65ms)

    ✓ Can handle 'dT' (172ms)

    ✓ Can handle 'd3' then <enter> (102ms)

    ✓ Can handle 'dj' (43ms)

    ✓ Can handle 'dk' (57ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (62ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (138ms)

    ✓ Can handle 'cw' without deleting following white spaces (167ms)

    ✓ Can handle 'c2w' (107ms)

    ✓ Can handle 'cw' without removing EOL (192ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (124ms)

    ✓ Can handle 'c]}' without deleting closing bracket (157ms)

    ✓ Can handle 's' (110ms)

    ✓ Can handle 'yiw' with correct cursor ending position (92ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'ciw' (243ms)

    ✓ Can handle 'ciw' on blanks (224ms)

    ✓ Can handle 'caw' (225ms)

    ✓ Can handle 'caw' on first letter (193ms)

    ✓ Can handle 'caw' on blanks (211ms)

    ✓ Can handle 'caw' on blanks (129ms)

    ✓ Can handle 'ci(' on first parentheses (189ms)

    ✓ Can handle 'ci(' with nested parentheses (98ms)

    ✓ Can handle 'ci(' backwards through nested parens (164ms)

    ✓ Can handle 'cib' on first parentheses (113ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (66ms)

    ✓ Can handle count prefixed 'ci)' (121ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (93ms)

    ✓ Can handle 'cab' spanning multiple lines (180ms)

    ✓ Can handle 'ci{' spanning multiple lines (105ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (194ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (170ms)

    ✓ Can handle 'ci(' on the closing bracket (105ms)

    ✓ Can handle 'ciB' spanning multiple lines (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ will fail when ca( with no () (121ms)

    ✓ will fail when ca{ with no {} (152ms)

    ✓ will fail when caB with no {} (133ms)

    ✓ Can handle 'ci[' spanning multiple lines (156ms)

    ✓ Can handle 'ci]' on first bracket (97ms)

    ✓ Can handle 'ca[' on first bracket (182ms)

    ✓ Can handle 'ca]' on first bracket (111ms)

    ✓ Can handle 'ci'' on first quote (144ms)

    ✓ Can handle 'ci'' inside quoted string (145ms)

    ✓ Can handle 'ci'' on closing quote (119ms)

    ✓ Can handle 'ci'' when string is ahead (146ms)

    ✓ Can handle 'ci"' on opening quote (147ms)

    ✓ Can handle 'ci"' starting behind the quoted word (208ms)

    ✓ Can handle 'ca"' starting behind the quoted word (87ms)

    ✓ Can handle 'ca"' starting on the opening quote (155ms)

    ✓ Can handle 'ci"' with escaped quotes (111ms)

    ✓ Can handle 'ci"' with a single escaped quote (116ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (153ms)

    ✓ Can handle 'ci"' with an escaped backslash (143ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (145ms)

    ✓ Can handle 'ca"' starting on the closing quote (215ms)

    ✓ Can handle 'ci"' with complex escape sequences (111ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (127ms)

    ✓ will fail when ca" ahead of quoted string (290ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'ca`' inside word (98ms)

    ✓ can handle cj (246ms)

    ✓ can handle ck (148ms)

    ✓ can handle c2j (134ms)

    ✓ can handle c2k (137ms)

    ✓ can handle cj on last line (218ms)

    ✓ can handle ck on first line (166ms)

    ✓ can handle c2j on last line (289ms)

    ✓ can handle c2k on first line (231ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (115ms)

    ✓ Can handle 'daw' on word with trailing spaces (78ms)

    ✓ Can handle 'daw' on word with leading spaces (95ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix (224ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (169ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (97ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (226ms)

    ✓ Can handle 'daw' on end of word (169ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (213ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word at beginning of file (233ms)

    ✓ Can handle 'daw' on word at beginning of line (129ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (182ms)

    ✓ Can handle 'daw' around word at end of line (164ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' around word at whitespace (106ms)

    ✓ Can handle 'daW' on word with trailing spaces (180ms)

    ✓ Can handle 'daW' on word with leading spaces (200ms)

    ✓ Can handle 'daW' on word with numeric prefix (123ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (222ms)

    ✓ Can handle 'daW' on beginning of word (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' on end of one line (223ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (104ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (226ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (179ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (207ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (327ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (84ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word (267ms)

    ✓ Can handle 'diw' on word with numeric prefix (101ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (127ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (142ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (225ms)

    ✓ Can handle 'diW' on word with trailing spaces (109ms)

    ✓ Can handle 'diW' on word with leading spaces (212ms)

    ✓ Can handle 'diW' on word with numeric prefix (133ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (211ms)

    ✓ Can handle 'diW' on beginning of word (126ms)

    ✓ Can handle d} (151ms)

    ✓ Can handle y} at beginning of line (210ms)

    ✓ Select sentence with trailing spaces (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Select sentence with leading spaces (229ms)

    ✓ Select inner sentence with trailing spaces (161ms)

    ✓ Select inner sentence with leading spaces (229ms)

    ✓ Select spaces between sentences (222ms)

    ✓ Can handle 'df' (208ms)

    ✓ Can handle 'dt' (155ms)

    ✓ Can handle backspace (94ms)

    ✓ Can handle backspace across lines (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A and backspace (158ms)

    ✓ Can handle 'yy' without changing cursor position (156ms)

    ✓ Can handle 'P' after 'yy' (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'p' after 'yy' (220ms)

    ✓ Can handle 'P' after 'Nyy' (167ms)

    ✓ Can handle 'p' after 'Nyy' (44ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (81ms)

    ✓ Can handle 'gp' after 'yy' (216ms)

    ✓ Can handle 'gp' after 'Nyy' (160ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (209ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (151ms)

    ✓ Can handle 'gP' after 'yy' (180ms)

    ✓ Can handle 'gP' after 'Nyy' (262ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (109ms)

    ✓ Can handle ']p' after yy (43ms)

    ✓ Can handle ']p' after 'Nyy' (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (237ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (168ms)

    ✓ Can handle '[p' after yy (225ms)

    ✓ Can handle '[p' after 'Nyy' (221ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (173ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (206ms)

    ✓ Can handle 'p' after y'a (144ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (139ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (212ms)

    ✓ Can handle pasting in visual mode over selection (227ms)

    ✓ Can repeat w (80ms)

    ✓ Can repeat p (199ms)

    ✓ I works correctly (211ms)

    ✓ gI works correctly (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gi works correctly (468ms)

    ✓ `. works correctly (229ms)

    ✓ '. works correctly (176ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g; works correctly (281ms)

    ✓ g, works correctly (147ms)

    ✓ g_ works correctly (204ms)

    ✓ 3g_ works correctly (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (638ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces before single line comments correctly (603ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles tabs before single line comments correctly (719ms)

    ✓ Can handle space (181ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (279ms)

    ✓ Undo 1 (250ms)

    ✓ Undo 2 (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Undo cursor (304ms)

    ✓ Undo cursor 2 (263ms)

    ✓ Undo cursor 3 (216ms)

    ✓ Undo with movement first (202ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' (233ms)

    ✓ Can handle 'U' for multiple changes (192ms)

    ✓ Can handle 'U' for new line below (212ms)

    ✓ Can handle 'U' for new line above (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' for consecutive changes only (523ms)

    ✓ Can handle 'u' to undo 'U' (127ms)

    ✓ Can handle 'U' to undo 'U' (267ms)

    ✓ Redo (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Redo (222ms)

    ✓ Redo (266ms)

    ✓ Can handle u (134ms)

    ✓ Can handle guw (164ms)

    ✓ Can handle gUw (168ms)

    ✓ Can handle u over line breaks (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle s in visual mode (246ms)

    ✓ can handle p with selection (174ms)

    ✓ can handle P with selection (237ms)

    ✓ can handle p in visual to end of line (229ms)

    ✓ can repeat backspace twice (92ms)

    ✓ can delete linewise with d2G (72ms)

    ✓ can delete with + motion and count (212ms)

    ✓ can delete with - motion and count (181ms)

    ✓ can dE correctly (130ms)

    ✓ can dE correctly (202ms)

    ✓ can dE correctly (112ms)

    ✓ can ctrl-a correctly behind a word (116ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (211ms)

    ✓ can ctrl-a on word (111ms)

    ✓ can ctrl-a on a hex number (210ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a on decimal (472ms)

    ✓ can ctrl-a with numeric prefix (248ms)

    ✓ can ctrl-a on a decimal (153ms)

    ✓ can ctrl-a on an octal  (223ms)

    ✓ Correctly increments in the middle of a number (55ms)

    ✓ can ctrl-x correctly behind a word (42ms)

    ✓ can ctrl-a on an number with word before  (187ms)

    ✓ can ctrl-a on an number with word before and after  (168ms)

    ✓ can ctrl-x on a negative number with word before and after  (235ms)

    ✓ can ctrl-a properly on multiple lines (112ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (201ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (92ms)

    ✓ can <C-a> on word with - in front of it (178ms)

    ✓ can do Y (158ms)

    ✓ Can do S (206ms)

    ✓ / does not affect mark (170ms)

    ✓ / can search with regex (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ / can search with newline (230ms)

    ✓ / can search through multiple newlines (203ms)

    ✓ / matches ^ per line (135ms)

    ✓ / matches $ per line (238ms)

    ✓ Can search for forward slash (144ms)

    ✓ Can search backward for question mark (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ /\c forces case insensitive search (272ms)

    ✓ /\C forces case sensitive search (139ms)

    ✓ <BS> deletes the last character in search in progress mode (200ms)

    ✓ <S-BS> deletes the last character in search in progress mode (124ms)

    ✓ <C-h> deletes the last character in search in progress mode (155ms)

    ✓ Can do C (94ms)

    ✓ Can do cit on a matching tag (205ms)

    ✓ Ignores cit on a non-matching tag (125ms)

    ✓ Ignores cit on a nested tag (214ms)

    ✓ Can do cit on a tag with an attribute tag (135ms)

    ✓ Can do cat on a matching tag (198ms)

    ✓ Can do cit on a multiline tag (123ms)

    ✓ Can do cit on a multiline tag with nested tags (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (237ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (233ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (193ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (155ms)

    ✓ can do cit with self closing tags (184ms)

    ✓ Respects indentation with cc (147ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Resets cursor to indent end with cc (567ms)

    ✓ can handle 'cc' on empty line (64ms)

    ✓ cc copies linewise (60ms)

    ✓ Indent current line with correct Vim Mode (125ms)

    ✓ Can handle <Esc> and do nothing (159ms)

    ✓ Can handle # on consecutive words (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle # on skipped words (328ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (202ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (382ms)

    ✓ cc on whitespace-only treats whitespace as indent (200ms)

    ✓ Can do cai (172ms)

    ✓ Can do cii (106ms)

    ✓ Can do caI (209ms)

    ✓ Can do dai (192ms)

    ✓ Can do dii (77ms)

    ✓ Can do daI (201ms)

    ✓ `] go to the end of the previously operated or put text (170ms)

    ✓ '] go to the end of the previously operated or put text (198ms)

    ✓ `[ go to the start of the previously operated or put text (229ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '[ go to the start of the previously operated or put text (475ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (189ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (263ms)

    can handle gn

      ✓ gn selects the next match text (213ms)

      ✓ gn selects the current word at |hello (307ms)

      ✓ gn selects the current word at h|ello (294ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the current word at hel|lo (437ms)

      ✓ gn selects the current word at hell|o (201ms)

      ✓ gn selects the next word at hello| (363ms)

    can handle dgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the next match text (from first line) (244ms)

      ✓ dgn deletes the current word when cursor is at |hello (256ms)

      ✓ dgn deletes the current word when cursor is at h|ello (166ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (190ms)

      ✓ dgn deletes the current word when cursor is at hell|o (175ms)

      ✓ dgn deletes the next word when cursor is at hello| (147ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (269ms)

      ✓ cgn deletes the current word when cursor is at |hello (360ms)

      ✓ cgn deletes the current word when cursor is at h|ello (150ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hel|lo (245ms)

      ✓ cgn deletes the current word when cursor is at hell|o (145ms)

      ✓ cgn deletes the next word when cursor is at hello| (144ms)

    can handle gN

      ✓ gN selects the previous match text (512ms)

      ✓ gN selects the current word at hell|o (510ms)

      ✓ gN selects the current word at hel|lo (433ms)

      ✓ gN selects the current word at h|ello (232ms)

      ✓ gN selects the current word at |hello (222ms)

      ✓ gN selects the previous word at | hello (351ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (112ms)

      ✓ dgN deletes the current word when cursor is at hell|o (170ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (152ms)

      ✓ dgN deletes the current word when cursor is at h|ello (158ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at |hello (266ms)

      ✓ dgN deletes the previous word when cursor is at | hello (488ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (170ms)

      ✓ cgN deletes the current word when cursor is at hell|o (186ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (227ms)

      ✓ cgN deletes the current word when cursor is at h|ello (164ms)

      ✓ cgN deletes the current word when cursor is at |hello (200ms)

      ✓ cgN deletes the previous word when cursor is at | hello (211ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (123ms)

    ✓ Can activate with R from Normal mode (106ms)

    ✓ Can handle R (155ms)

    ✓ Can handle R past current line (211ms)

    ✓ Can handle R and exit Replace Mode (158ms)

    ✓ Can handle R across lines (146ms)

    ✓ Can handle R across lines and exit Replace Mode (196ms)

    ✓ Can handle R with {count} (186ms)

    ✓ Can handle backspace (188ms)

    ✓ Can handle backspace (245ms)

    ✓ Can handle backspace across lines (255ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle arrows (479ms)

    ✓ Can handle . (178ms)

    ✓ Can handle . across lines (303ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (356ms)

    ✓ Can handle wd (197ms)

    ✓ Can handle x (176ms)

    ✓ Can handle x across a selection (514ms)

    ✓ Can do vwd in middle of sentence (282ms)

    ✓ Can do vwd in middle of sentence (209ms)

    ✓ Can do vwd multiple times (390ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (195ms)

    ✓ Can handle H key (121ms)

    ✓ Can handle backspace key (188ms)

    ✓ handles case where we delete over a newline (277ms)

    ✓ handles change operator (248ms)

    ✓ Can do vat on multiple matching tags (166ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (205ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (209ms)

    ✓ Repeat-prefixed vat does not bleed below (93ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (110ms)

    ✓ Can do vi) on a matching parenthesis (211ms)

    ✓ Can do vi) on multiple matching parens (185ms)

    ✓ Can do va) on a matching parenthesis (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va) on multiple matching parens (401ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Repeat-prefixed va) does not bleed below (404ms)

    ✓ Can do va} on a matching bracket as first character (117ms)

    ✓ Can do va} on multiple matching brackets (142ms)

    ✓ Can do vi( on a matching bracket near first character (104ms)

    ✓ Can do vi{ on outer pair of nested braces (164ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (94ms)

    ✓ Can do va] on multiple matching brackets (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (311ms)

    ✓ Repeat-prefixed vaf does not bleed below (125ms)

    ✓ vaf only expands to enclosing pairs (108ms)

    ✓ Can use . to repeat indent in visual (197ms)

    ✓ Can do v_x to delete to first char (117ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vg_x to delete to last char with no EOL (230ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (217ms)

    ✓ Can do v$x to delete to last char including EOL (70ms)

    ✓ Can do gv to reselect previous selection (94ms)

    Vim's EOL handling is weird

      ✓ delete through eol (113ms)

      ✓ join 2 lines by deleting through eol (197ms)

      ✓ d$ doesn't delete whole line (85ms)

      ✓ vd$ does delete whole line (179ms)

      ✓ Paste over selection copies the selection (172ms)

      ✓ Paste over selection copies the selection linewise (202ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <down> key (293ms)

      ✓ Can handle <left> key (161ms)

      ✓ Can handle <right> key (227ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (127ms)

      ✓ Can handle 'gj' (121ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (237ms)

      ✓ Can handle 'vawd' on word with leading spaces (152ms)

      ✓ Can handle 'vawd' on word with numeric prefix (212ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (310ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (76ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (222ms)

      ✓ Can handle 'vaWd' on word with leading spaces (164ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (218ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (174ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (145ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (181ms)

      ✓ Can handle 'vaWd' on word with leading spaces (204ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (458ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (189ms)

      ✓ Can handle 'vawd' on word with trailing spaces (170ms)

      ✓ Can handle 'vawd' on word with leading spaces (168ms)

      ✓ Can handle 'vawd' on word with numeric prefix (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (459ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (228ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (225ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (131ms)

      ✓ Can handle 'vaWd' on word with leading spaces (190ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (108ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (210ms)

      ✓ Can handle 'Y' in visual mode (193ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (440ms)

      ✓ Select multiple sentences in visual mode (258ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select inner sentence with leading spaces in visual mode (365ms)

      ✓ Select spaces between sentences in visual mode (276ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (229ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (137ms)

      ✓ Can do vat on a matching tag (195ms)

    handles replace in visual mode

      ✓ Can do a single line replace (219ms)

      ✓ Can do a multi line replace (130ms)

    D command will remove all selected lines

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ D deletes all selected lines (302ms)

      ✓ D deletes the current line (174ms)

    handles indent blocks in visual mode

      ✓ Can do vai (203ms)

      ✓ Can do vii (193ms)

      ✓ Doesn't naively select the next line (155ms)

      ✓ Searches backwards if cursor line is empty (153ms)

      ✓ Can do vaI (157ms)

    visualstar

      ✓ Works with * (162ms)

      ✓ Works with # (76ms)

    search works in visual mode

      ✓ Works with / (86ms)

      1) Works with ?

      ✓ Selects correct range (131ms)

    X will delete linewise

      ✓ normal selection (77ms)

      ✓ normal selection (226ms)

    C will delete linewise

      ✓ normal selection (143ms)

      ✓ normal selection (222ms)

    R will delete linewise

      ✓ normal selection (105ms)

      ✓ normal selection (228ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (190ms)

      ✓ upward selection (181ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (74ms)

      ✓ multiline indent bottom up selection (163ms)

      ✓ repeat multiline indent top down selection (85ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent bottom up selection (265ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (303ms)

      ✓ multiline outdent bottom up selection (148ms)

      ✓ repeat multiline outdent top down selection (112ms)

      ✓ repeat multiline outdent bottom up selection (215ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (155ms)

    vi{ will go to end of second to last line

      ✓ select (84ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (647ms)

      ✓ gv selects the last pasted text (which is longer than original) (419ms)

      ✓ gv selects the last pasted text (multiline) (370ms)

    can handle gn

      ✓ gn selects the next match text (452ms)

      ✓ gn selects the current word at |hello (222ms)

      ✓ gn selects the current word at h|ello (213ms)

      ✓ gn selects the current word at hel|lo (254ms)

      ✓ gn selects the next word at hell|o (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the next word at hello| (376ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (60ms)

      ✓ skips blank lines (146ms)

    can append text with A

      ✓ multiline append from bottom up selection (161ms)

      ✓ multiline append from top down selection (118ms)

      ✓ skips blank lines (190ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (167ms)

      ✓ U/gU across a selection (234ms)

      ✓ U/gU across a selection (reverse) (185ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ u/gu on single character (135ms)

      ✓ u/gu across a selection (132ms)

      ✓ u/gu across a selection (reverse) (262ms)

  Mode Visual Block

    ✓ can be activated (41ms)

    ✓ Can handle A forward select (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (260ms)

    ✓ Can handle I forward select (137ms)

    ✓ Can handle I backwards select (237ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (150ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (202ms)

    ✓ Can handle c forward select (165ms)

    ✓ Can handle c backwards select (245ms)

    ✓ Can handle C (133ms)

    ✓ Can do a multi line replace (131ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' (232ms)

    ✓ Can handle 'gj' (78ms)

    ✓ Properly add to end of lines j then $ (85ms)

    ✓ Properly add to end of lines $ then j (136ms)

    ✓ o works in visual block mode (113ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (165ms)

  Mode Visual Line

    ✓ can be activated (39ms)

    ✓ Can handle w (149ms)

    ✓ Can handle wd (228ms)

    ✓ Can handle x (196ms)

    ✓ Can handle x across a selection (311ms)

    ✓ Can do vwd in middle of sentence (182ms)

    ✓ Can do vwd in middle of sentence (109ms)

    ✓ Can do vwd multiple times (320ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (144ms)

    ✓ handles case where we delete over a newline (160ms)

    ✓ handles change operator (198ms)

    ✓ Vp updates register content (97ms)

    ✓ Vp does not append unnecessary newlines (first line) (204ms)

    ✓ Vp does not append unnecessary newlines (middle line) (125ms)

    ✓ Vp does not append unnecessary newlines (last line) (163ms)

    Vim's EOL handling is weird

      ✓ delete through eol (149ms)

      ✓ join 2 lines by deleting through eol (119ms)

      ✓ d$ doesn't delete whole line (76ms)

      ✓ vd$ does delete whole line (109ms)

    Arrow keys work perfectly in Visual Line Mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <up> key (349ms)

      ✓ Can handle <down> key (79ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (62ms)

      ✓ Can handle 'gj' (59ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (190ms)

      ✓ Can handle d key (166ms)

      ✓ Can handle d key (66ms)

      ✓ Can handle d key (146ms)

      ✓ can handle 'c' (57ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (75ms)

      ✓ Can do a multi visual line replace (205ms)

      ✓ Can do a multi visual line replace from the bottom up (158ms)

    search works in visual line mode

      ✓ Works with / (223ms)

      ✓ Works with ? (120ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (237ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (200ms)

      ✓ linewise visual put works also in the end of document (144ms)

      ✓ gv selects the last pasted text (which is shorter than original) (474ms)

      ✓ gv selects the last pasted text (which is longer than original) (397ms)

      ✓ gv selects the last pasted text (multiline) (168ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (181ms)

      ✓ multiline insert from top down selection (148ms)

      ✓ skips blank lines (160ms)

    can append text with A

      ✓ multiline append from bottom up selection (201ms)

      ✓ multiline append from top down selection (126ms)

      ✓ skips blank lines (215ms)

  Mode Normal

    ✓ Can handle 'x' (141ms)

    ✓ Can handle 'Nx' (59ms)

    ✓ Can handle 'Nx' and paste (63ms)

    ✓ Can handle 'x' at end of line (231ms)

    ✓ Can handle 'Ns' (113ms)

    ✓ Can handle 'Ns' at end of line (176ms)

    ✓ Can handle '<Del>' (181ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (146ms)

    ✓ Can handle '<Del>' at end of line (228ms)

    ✓ Can handle 'cc' (200ms)

    ✓ Can handle 'Ncc' (121ms)

    ✓ Can handle 'yy' (143ms)

    ✓ Can handle 'D' (152ms)

    ✓ Can handle 'D' on empty lines (84ms)

    ✓ Can handle 'DD' (146ms)

    ✓ Can handle 'C' (206ms)

    ✓ Can handle 'NC' (163ms)

    ✓ Can handle 'NC' and put (174ms)

    ✓ Can handle 'r' (176ms)

    ✓ Can handle '<Count>r' (208ms)

    ✓ Can handle '<Count>r' (100ms)

    ✓ Can handle 'r' after 'dd' (199ms)

    ✓ Can handle 'r
' (95ms)

    ✓ Can handle '<Count>r
' (180ms)

    ✓ Can handle 'J' once (73ms)

    ✓ Can handle 'J' twice (140ms)

    ✓ Can handle 'J' with empty last line (161ms)

    ✓ Can handle 'J's with multiple empty last lines (215ms)

    ✓ Can handle 'J' with leading white space on next line (48ms)

    ✓ Can handle 'J' with only white space on next line (181ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with TWO indented lines (334ms)

    ✓ Can handle 'J' with ')' first character on next line (206ms)

    ✓ Can handle 'J' with a following delete (93ms)

    ✓ Can handle 'J' in Visual Line mode (155ms)

    ✓ Can handle 'gJ' once (109ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (182ms)

    ✓ Can handle '~' (132ms)

    ✓ Can handle 'g~{motion}' (120ms)

    ✓ Can handle '<BS>' in insert mode (147ms)

    ✓ Can handle undo with P (320ms)

    ✓ Can handle 'ge' in multiple lines case1 (129ms)

    ✓ Can handle 'ge' in multiple lines case2 (135ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (117ms)

    ✓ Can repeat '~' with dot (163ms)

    ✓ Can repeat 'x' (186ms)

    ✓ Can repeat 'J' (144ms)

    ✓ Can handle dot with A (141ms)

    ✓ Can handle dot with I (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat actions that require selections (349ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (104ms)

    ✓ Can repeat insert change and '<C-t>' (244ms)

    ✓ Can repeat change by `<C-a>` (240ms)

    ✓ Only one arrow key can be repeated in Insert Mode (71ms)

    ✓ Cached content change will be cleared by arrow keys (267ms)

  Matching Bracket (%)

    ✓ before opening parenthesis

    ✓ inside parenthesis (187ms)

    ✓ nested parenthesis beginning (46ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested parenthesis end (130ms)

    ✓ nested bracket and parenthesis beginning (150ms)

    ✓ nested bracket, parenthesis, braces beginning (63ms)

    ✓ nested bracket, parenthesis, braces end (121ms)

    ✓ parentheses after > (171ms)

    ✓ parentheses after " (38ms)

  Motions in Normal Mode

    ✓ Can handle [( (187ms)

    ✓ Can handle nested [( (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <number>[( (217ms)

    ✓ Can handle [( and character under cursor exclusive (109ms)

    ✓ Can handle ]) (110ms)

    ✓ Can handle nested ]) (159ms)

    ✓ Can handle <number>]) (96ms)

    ✓ Can handle ]) and character under cursor exclusive (181ms)

    ✓ Can handle [{ (77ms)

    ✓ Can handle nested [{ (120ms)

    ✓ Can handle <number>[{ (177ms)

    ✓ Can handle [{ and character under cursor exclusive (160ms)

    ✓ Can handle ]} (208ms)

    ✓ Can handle nested ]} (136ms)

    ✓ Can handle <number>]} (110ms)

    ✓ Can handle ]} and character under cursor exclusive (198ms)

    ✓ Can handle 'ge' (196ms)

    ✓ Can handle 'gg' (157ms)

    ✓ Can handle 'gg' to first non blank char on random line (115ms)

    ✓ Can handle 'gg' to first non blank char on first line (186ms)

    ✓ 'gg' obeys startofline (81ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Retain same column when moving up/down (371ms)

    ✓ Can handle <enter> (129ms)

    ✓ $ always keeps cursor on EOL (214ms)

    ✓ Can handle $ with a count (233ms)

    ✓ Can handle $ with a count at end of file (94ms)

    ✓ Can handle <End> with a count (180ms)

    ✓ Can handle <D-right> with a count (165ms)

    ✓ Can handle 'f' (145ms)

    ✓ Can handle 'f' twice (197ms)

    ✓ Can handle 'f' with <tab> (160ms)

    ✓ Can handle 'f' and find back search (104ms)

    ✓ Can handle 'F' (78ms)

    ✓ Can handle 'F' twice (122ms)

    ✓ Can handle 'F' and find back search (141ms)

    ✓ Can handle 'f' and multiple back searches (198ms)

    ✓ Can handle 't' (68ms)

    ✓ Can handle 't' twice (134ms)

    ✓ Can handle 't' and find back search (177ms)

    ✓ Can handle 'T' (132ms)

    ✓ Can handle 'T' twice (125ms)

    ✓ Can handle 'T' and find back search (268ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a forward search (109ms)

    ✓ Can run a forward and find next search (193ms)

    ✓ Can run a forward and find previous search from end of word (208ms)

    ✓ Can run a reverse search (244ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a reverse and find next search (568ms)

    ✓ cancelled search reverts to previous search state (172ms)

    ✓ Backspace on empty search cancels (150ms)

    ✓ Search offsets: b does nothing (95ms)

    ✓ Search offsets: b2 goes 2 to the right (115ms)

    ✓ Search offsets: b+3 goes 3 to the right (213ms)

    ✓ Search offsets: e goes to the end (169ms)

    ✓ Search offsets: character offset goes across line boundaries (117ms)

    ✓ Search offsets: 2 goes 2 down (154ms)

    ✓ Search offsets: -2 goes 2 up (74ms)

    ✓ maintains column position correctly (234ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ maintains column position correctly with $ (124ms)

    ✓ Can handle G  (165ms)

    ✓ Can handle G with number prefix (83ms)

    ✓ Can handle G with number prefix (189ms)

    ✓ Can handle gg (44ms)

    ✓ Can handle gg with number prefix (181ms)

    ✓ Can handle 0 (80ms)

    ✓ Can handle 0 as part of a repeat (177ms)

    ✓ Can handle g* (175ms)

    ✓ Can handle g*n (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle * (267ms)

    ✓ Can handle ** (69ms)

    ✓ Can handle # on whitespace (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle # on EOL (496ms)

    ✓ Can handle g# (295ms)

    ✓ Can handle g#n (184ms)

    ✓ Can handle # (179ms)

    ✓ Can handle # already on the word (193ms)

    ✓ Can handle ## (164ms)

    ✓ * adds to search history (109ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ # adds to search history (440ms)

    ✓ Can handle | (145ms)

    ✓ Can handle <number> | (139ms)

    ✓ Can handle + (65ms)

    ✓ Can handle + indent (153ms)

    ✓ Can handle + with count prefix (137ms)

    ✓ Can handle - (58ms)

    ✓ Can handle - indent (49ms)

    ✓ Can handle - with count prefix (101ms)

    ✓ Can handle _ (55ms)

    ✓ Can handle _ with count prefix (45ms)

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix (44ms)

    ✓ Can handle <up> key (92ms)

    ✓ Can handle <down> key (61ms)

    ✓ Can handle <left> key (51ms)

    ✓ Can handle <right> key (47ms)

    ✓ Can handle 'gk' (67ms)

    ✓ Can handle 'gj' (80ms)

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right
    ✓ char right
    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down
    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin
    ✓ line end
    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character
    ✓ last line begin cursor on first non-blank character
    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)
    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right
      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph
      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (56ms)

        ✓ l wraps to next line (179ms)

        ✓ <left> wraps to previous line (59ms)

        ✓ <right> wraps to next line (82ms)

      insert mode

        ✓ <left> wraps to previous line (58ms)

        ✓ <right> once goes to end of line (183ms)

        ✓ <right> twice wraps to next line (98ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ l does not wrap to next line (491ms)

        ✓ <left> does not wrap to previous line (141ms)

        ✓ <right> does not wrap to next line (72ms)

      insert mode

        ✓ <left> does not wrap to previous line (193ms)

        ✓ <right> does not wrap to next line (166ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (245ms)

      ✓ search wraps around the start of the file (141ms)

    wrapscan disabled

      ✓ search stops at the end of the file (129ms)

      ✓ search stops at the start of the file (196ms)

  Multicursor

    ✓ can add multiple cursors below (219ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can add multiple cursors above (471ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip
  comment operator

    ✓ gcc comments out current line (237ms)

    ✓ gcj comments in current and next line (215ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (401ms)

    ✓ block comment in Visual Mode (226ms)

    ✓ comment in visual line mode (161ms)

    ✓ comment in visual block mode (217ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (635ms)

    ✓ =$ formats entire line (566ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =j formats two lines (252ms)

    ✓ 3=k formats three lines (228ms)

    ✓ =gg formats to top of file (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =G formats to bottom of file (315ms)

    ✓ =ip formats paragraph (184ms)

    ✓ format in visual mode (190ms)

  put operator

    ✓ basic put test (173ms)

    ✓ test yy end of line (83ms)

    ✓ test yy first line (184ms)

    ✓ test yy middle line (178ms)

    ✓ test yy with correct positon movement (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line yank p (249ms)

    ✓ test visual block single line yank P (186ms)

    ✓ test visual block single line delete p (283ms)

    ✓ test visual block single line delete P (230ms)

  rot13 operator

    2) rot13() unit test

    ✓ g?j works (167ms)

    ✓ g? in visual mode works (156ms)

    3) g? in visual line mode works

    4) g? in visual block mode works

  shift operator

    ✓ basic shift left test (139ms)

    ✓ shift left goto end test (197ms)

    ✓ shift left goto line test (166ms)

    ✓ shift right goto end test (115ms)

    ✓ shift right goto line test (206ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (120ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step to Camel word (428ms)

      ✓ step to CAP word (206ms)

      ✓ step after CAP word (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from middle of word to Camel word (259ms)

      ✓ step to number word (183ms)

      ✓ step to operator word (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (277ms)

      ✓ step to operator and then over (144ms)

    handles <leader>w for underscore_var

      ✓ step to _word (186ms)

      ✓ step over whitespace to word (124ms)

      ✓ step from inside word to _word (173ms)

      ✓ step form _word to number (197ms)

      ✓ step from nubmer word to _word (190ms)

      ✓ step from in whitespace to word (190ms)

      ✓ step in ALL_CAPS_WORD (120ms)

    handles d<leader>w

      ✓ delete from start of camelWord (181ms)

      ✓ delete from middle of camelWord (186ms)

      ✓ delete from start of CamelWord (225ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camelWord (119ms)

      ✓ delete from start of underscore_word (206ms)

      ✓ delete from middle of underscore_word (113ms)

      ✓ delete two words from camel_word (194ms)

    handles di<leader>w

      ✓ delete from start of camelWord (171ms)

      ✓ delete from middle of camelWord (210ms)

      ✓ delete from start of CamelWord (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camelWord (215ms)

      ✓ delete from start of underscore_word (123ms)

      ✓ delete from middle of underscore_word (90ms)

      ✓ delete two words from camel_word (211ms)

    handles <leader>b

      ✓ back from middle of word (256ms)

      ✓ back over whitespace to camelWord (157ms)

      ✓ back twice over operator (153ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ from middle to end of underscore_word (375ms)

      ✓ twice to end of word over operator (447ms)

  easymotion plugin

    ✓ Can handle s move (130ms)

    ✓ Can handle 2s move (193ms)

    ✓ Can handle f move (125ms)

    ✓ Can handle 2f move (227ms)

    ✓ Can handle F move (480ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2F move (169ms)

    ✓ Can handle t move (211ms)

    ✓ Can handle bd-t move (164ms)

    ✓ Can handle 2t move (121ms)

    ✓ Can handle bd-t2 move (182ms)

    ✓ Can handle T move (132ms)

    ✓ Can handle 2T move (160ms)

    ✓ Can handle w move (132ms)

    ✓ Can handle bd-w move (204ms)

    ✓ Can handle b move (178ms)

    ✓ Can handle e move (124ms)

    ✓ Can handle bd-e move (215ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ge move (160ms)

    ✓ Can handle n-char move (186ms)

    ✓ Can handle j move (191ms)

    ✓ Can handle k move (132ms)

    ✓ Can handle bd-jk move (1) (207ms)

    ✓ Can handle bd-jk move (2) (169ms)

    ✓ Can handle lineforward move (1) (205ms)

    ✓ Can handle lineforward move (2) (102ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle linebackward move (1) (230ms)

    ✓ Can handle linebackward move (2) (157ms)

    ✓ Can handle searching for backslash (\) (169ms)

    ✓ Can handle searching for carat (^) (130ms)

    ✓ Can handle searching for dot (.) (135ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (198ms)

    ✓ Replaces within inner Word (130ms)

    ✓ Replaces within '' (225ms)

    ✓ Replaces within '' including spaces (116ms)

    ✓ Replaces within () (223ms)

    ✓ Replaces within () including spaces (202ms)

    ✓ Replaces within a paragraph (105ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces using a specified register (233ms)

    ✓ Replaces within {} over multiple lines (133ms)

    ✓ Replaces a multiline register within {} over multiple lines (171ms)

    ✓ Replaces a multiline register within {} over multiple lines (472ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (440ms)

    ✓ grr replaces the entire line with the register (171ms)

    ✓ grr can replace multiple lines (573ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode (231ms)

    ✓ Replaces in visual mode using a specified register (156ms)

    ✓ Replaces in visual line mode (147ms)

    ✓ grj is linewise (212ms)

  sneak plugin

    ✓ Can handle s motion (137ms)

    ✓ Can handle S motion (213ms)

    ✓ Can handle <operator>z motion (192ms)

    ✓ Can handle <operator>Z motion (115ms)

    ✓ Can handle s; motion (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle s, motion (882ms)

    ✓ Can handle S; motion (240ms)

    ✓ Can handle S, motion (133ms)

    ✓ Can handle single letter s motion (172ms)

    ✓ Can handle single letter S motion (132ms)

    ✓ Can handle single letter <operator>z motion (200ms)

    ✓ Can handle single letter <operator>Z motion (210ms)

    ✓ Can handle single letter s; motion (114ms)

    ✓ Can handle single letter s, motion (189ms)

    ✓ Can handle single letter S; motion (144ms)

    ✓ Can handle single letter S, motion (141ms)

    ✓ Can handle multiline single char <number>s motion (209ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (156ms)

    ✓ 'ysiw(' surrounds word with space (253ms)

    ✓ 'ysw)' surrounds word without space (169ms)

    ✓ 'ysw(' surrounds word with space (116ms)

    ✓ 'ysaw)' surrounds word without space (158ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysaw(' surrounds word with space (374ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (123ms)

    ✓ 'ysiw<' surrounds word with tags (159ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'cst<' surrounds word with tags that have a dot in them (417ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (711ms)

    ✓ change surround (155ms)

    ✓ change surround with two pairs of quotes (169ms)

    ✓ change surround with two pairs of parens (209ms)

    ✓ change surround with alias (188ms)

    ✓ change surround to tags (186ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround (795ms)

    ✓ delete surround with quotes (144ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround with nested of quotes (245ms)

    ✓ delete surround with inconsistent quotes (86ms)

    ✓ delete surround with mixed quotes (191ms)

    ✓ delete surround with empty quotes cursor at start (115ms)

    ✓ delete surround with empty quotes cursor at end (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ don't delete surround if cursor is after closing match (230ms)

    ✓ delete surround if cursor is before opening match (119ms)

    ✓ delete surround with two pairs of parens (158ms)

    ✓ delete surround with alias (131ms)

    ✓ delete surround with tags (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (330ms)

    ✓ changing brackets with surround works again (112ms)

    ✓ change surround with tags that contain an attribute and preserve them (328ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with tags that contain an attribute and remove them (264ms)

  register

    ✓ Can copy to a register (104ms)

    ✓ Can use two registers together (368ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use black hole register (378ms)

    ✓ System clipboard works with chinese characters (61ms)

    ✓ Yank stores text in Register '0' (381ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (639ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (370ms)

    ✓ Register '1'-'9' stores delete content (376ms)

    ✓ "A appends linewise text to "a (439ms)

    ✓ "A appends character wise text to "a (609ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (310ms)

    ✓ Small deletion using Del is stored in small delete register (382ms)

    ✓ Small deletion using X is stored in small delete register (420ms)

    ✓ Search register (/) is set by forward search (579ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Search register (/) is set by backward search (1216ms)

    ✓ Search register (/) is set by star search (447ms)

    ✓ Command register (:) is set by command line (105ms)

    ✓ Read-only registers cannot be written to (276ms)

    clipboard

      ✓ Can access '*' (clipboard) register (180ms)

      ✓ Can access '+' (clipboard) register (164ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (162ms)

    ✓ Can repeat reversed F<character> (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat t<character> (214ms)

    ✓ Can repeat N times reversed t<character> (127ms)

  sentence motion
    [count] sentences backward

      ✓ move one sentence backward (237ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward (688ms)

      ✓ move [count] sentences backward (250ms)

      ✓ move one sentence backward single line - middle (140ms)

      ✓ move one sentence backward no space (175ms)

      ✓ move one sentence backward no space - middle (155ms)

      ✓ move one sentence backward - multiline (168ms)

      ✓ move one sentence backward - multiline - period (131ms)

      ✓ move one sentence backward - multiline - previous line (171ms)

      ✓ move one sentence backward - multiline - previous line - period (82ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1299 passing (6m)

  4 pending

  4 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:921:5)


  2) rot13 operator
       rot13() unit test:

      AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
+ actual - expected

+ 'n'
- 'nopqrstuvwxyzabcdefghijklm'
      + expected - actual

      -n
      +nopqrstuvwxyzabcdefghijklm
      
      at Context.<anonymous> (test/operator/rot13.test.ts:25:14)


  3) rot13 operator
       g? in visual line mode works:

      Cursor CHARACTER position is wrong.
      + expected - actual

      -0
      +1
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:43:3)


  4) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=drs. Actual=qrs.
      + expected - actual

      -qrs
      +drs
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:50:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.2 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.0 into .vscode-test/vscode-1.41.0.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.0/linux-x64/stable
Downloaded VS Code 1.41.0
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-14T20:50:10.840Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.16.2"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative
    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative
    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive
    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command <C-w> can remove word in search mode (58ms)

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor (38ms)

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (64ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (101ms)

    ✓ <C-r> <C-w> insert right word of cursor on command line (57ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (50ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (60ms)

  command-line lexer

    ✓ can lex empty string
    ✓ can lex comma
    ✓ can lex percent
    ✓ can lex dollar
    ✓ can lex dot
    ✓ can lex one number
    ✓ can lex longer number
    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args
    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args
    ✓ can lex left and right line refs

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (567ms)

    ✓ :smile editor contains smile text (544ms)

  Basic sort

    ✓ Sort whole file, asc (222ms)

    ✓ Sort whole file, asc, ignoreCase (164ms)

    ✓ Sort whole file, dsc (151ms)

    ✓ Sort whole file, dsc, ignoreCase (154ms)

    ✓ Sort range, asc (248ms)

    ✓ Sort range, asc, ignoreCase (225ms)

    ✓ Sort range, dsc (208ms)

    ✓ Sort range, dsc, ignoreCase (185ms)

    ✓ Sort whole file, asc, unique (277ms)

  Horizontal split

    ✓ Run :sp (83ms)

    ✓ Run :split (93ms)

    ✓ Run :new (83ms)

  :close args parser
    ✓ can parse empty args

    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space
    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !
    ✓ throws if bad input
  :substitute args parser
    ✓ can parse pattern, replace, and flags
    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter
    ✓ can parse flag KeepPreviousFlags
  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang
      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (104ms)

    ✓ Replace with `g` flag (86ms)

    ✓ Replace with flags AND count (190ms)

    ✓ Replace with `c` flag (77ms)

    ✓ Replace with `gc` flag (167ms)

    ✓ Replace across all lines (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replace on specific single line (390ms)

    ✓ Replace on current line using dot (127ms)

    ✓ Replace single relative line using dot and plus (159ms)

    ✓ Replace across specific line range (161ms)

    ✓ Replace across relative line range using dot, plus, and minus (169ms)

    ✓ Replace across relative line range using numLines+colon shorthand (200ms)

    ✓ Repeat replacement across relative line range (165ms)

    ✓ Replace with range AND count but no flags (120ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (212ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (161ms)

    ✓ Undocumented: trailing operators use 1 as RHS (136ms)

    ✓ Replace specific single equal lines (165ms)

    ✓ Replace current line with no active selection (145ms)

    ✓ Replace text in selection (222ms)

    ✓ Substitute support marks (129ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (77ms)

      ✓ Replace with `g` flag inverts global flag (91ms)

      ✓ Replace with `c` flag inverts global flag (135ms)

      ✓ Replace multiple lines (136ms)

      ✓ Replace across specific lines (164ms)

      ✓ Replace current line with no active selection (169ms)

      ✓ Replace text in selection (185ms)

      ✓ Substitute support marks (176ms)

      ✓ Substitute with escaped delimiter (82ms)
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (369ms)

      ✓ Substitute with previous search using # (375ms)

      ✓ Substitute with previous search using / (351ms)

      ✓ Substitute with parameters should update search state (190ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (367ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (278ms)

      ✓ Substitute repeat previous should accept flags (114ms)

      ✓ Substitute with empty search string should use last searched pattern (433ms)

      ✓ Ampersand (&) should repeat the last substitution (227ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file (40ms)

    ✓ tabedit with no arguments when not in workspace opens an untitled file (44ms)

    ✓ tabe with absolute path when not in workspace opens file (98ms)

    ✓ tabe with current file path does nothing (119ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (52ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (81ms)

    ✓ command line file tab completion with space in file path (152ms)

  Vertical split

    ✓ Run :vs (115ms)

    ✓ Run :vsp (87ms)

    ✓ Run :vsplit (104ms)

    ✓ Run :vnew (395ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :vne (445ms)

  Basic write-quit

    ✓ Run write and quit (99ms)

  Provide line completions
    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (65ms)

      ✓ Can complete lines in file with different indentation (82ms)

      ✓ Returns no completions for unmatched line (99ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (60ms)

  Notation

    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (108ms)

[main 2019-12-14T20:50:40.842Z] update#setState checking for updates

    ✓ getMatchingRemap (105ms)

[main 2019-12-14T20:50:40.898Z] update#setState idle

    ✓ jj -> <Esc> through modehandler (151ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (144ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (157ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (114ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (132ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (198ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (489ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (240ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command
    ✓ remappings are de-duped
  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (69ms)

        ✓ Can track jumps for keys: GggG (147ms)

        ✓ Can track jumps for keys: GggGgg (153ms)

        ✓ Can track jumps for keys: /b<CR>n (82ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (230ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%% (135ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (103ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (175ms)

        ✓ Can track jumps for keys: j%%<C-o>% (165ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (113ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (180ms)

        ✓ Can enter number to jump back multiple times (173ms)

        ✓ Can track one-line `` jumps (175ms)

        ✓ Can track one-line double `` jumps (215ms)

        ✓ Can track one-line '' jumps (171ms)

        ✓ Can track one-line double '' jumps (239ms)

        ✓ Can handle '' jumps with no previous jump (109ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (222ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (108ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (263ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (197ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (219ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (149ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (227ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (366ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (81ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (182ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (53ms)

  Record and execute a macro

    ✓ Can record and execute (266ms)

    ✓ Can repeat last invoked macro (306ms)

    ✓ Can play back with count (660ms)

    ✓ Can play back with count, abort when a motion fails (602ms)

    ✓ Repeat change on contiguous lines (266ms)

    ✓ Append command to a macro (299ms)

    ✓ Can record Ctrl Keys and repeat (303ms)

    ✓ Can execute macros with dot commands properly (192ms)

    ✓ : (command) register can be used as a macro (147ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (132ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position (94ms)

    ✓ <C-c> can exit insert (123ms)

    ✓ <Esc> can exit insert (158ms)

    ✓ Stay in insert when entering characters (152ms)

    ✓ Can handle 'O' (108ms)

    ✓ Can handle 'i' (216ms)

    ✓ Can handle 'I' (156ms)

    ✓ Can handle 'a' (170ms)

    ✓ Can handle 'A' (119ms)

    ✓ Can handle '<C-w>' (101ms)

    ✓ Can handle <C-w> on leading whitespace (50ms)

    ✓ Can handle <C-w> at beginning of line (85ms)

    ✓ Can handle <C-u> (149ms)

    ✓ Can handle <C-u> on leading characters (95ms)

    ✓ Can handle <C-u> on leading whitespace (72ms)

    ✓ Correctly places the cursor after deleting the previous line break (81ms)

    ✓ will not remove leading spaces input by user (41ms)

    ✓ will remove closing bracket (42ms)

    ✓ Backspace works on whitespace only lines (81ms)

    ✓ Backspace works on end of whitespace only lines (130ms)

    ✓ Backspace works at beginning of file (109ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (160ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (110ms)

    ✓ Can perform insert command prefixed with count (252ms)

    ✓ Can perform append command prefixed with count (131ms)

    ✓ Can perform insert at start of line command prefixed with count (129ms)

    ✓ Can perform append to end of line command prefixed with count (218ms)

    ✓ Can perform change char (s) command prefixed with count (191ms)

    ✓ Can perform command prefixed with count with <C-[> (128ms)

    ✓ Can handle 'o' with count (209ms)

    ✓ Can handle 'O' with count (113ms)

    ✓ Can handle backspace at beginning of line with all spaces (84ms)

    ✓ Can handle digraph insert (125ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (118ms)

    ✓ Can handle dw (66ms)

    ✓ Can handle dw (191ms)

    ✓ Can handle dw across lines (1) (133ms)

    ✓ Can handle dw across lines (2) (57ms)

    ✓ Can handle dd last line (79ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (77ms)

    ✓ Can handle 3dd (43ms)

    ✓ Can handle 3dd off end of document (63ms)

    ✓ Can handle d2d (205ms)

    ✓ Can handle dd empty line (64ms)

    ✓ Can handle ddp (97ms)

    ✓ Can handle 'de' (92ms)

    ✓ Can handle 'de' then 'de' again (100ms)

    ✓ Can handle 'db' (137ms)

    ✓ Can handle 'db then 'db' again (150ms)

    ✓ Can handle 'dl' at end of line (99ms)

    ✓ Can handle 'dF' (65ms)

    ✓ Can handle 'dT' (172ms)

    ✓ Can handle 'd3' then <enter> (102ms)

    ✓ Can handle 'dj' (43ms)

    ✓ Can handle 'dk' (57ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (62ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (138ms)

    ✓ Can handle 'cw' without deleting following white spaces (167ms)

    ✓ Can handle 'c2w' (107ms)

    ✓ Can handle 'cw' without removing EOL (192ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (124ms)

    ✓ Can handle 'c]}' without deleting closing bracket (157ms)

    ✓ Can handle 's' (110ms)

    ✓ Can handle 'yiw' with correct cursor ending position (92ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'ciw' (243ms)

    ✓ Can handle 'ciw' on blanks (224ms)

    ✓ Can handle 'caw' (225ms)

    ✓ Can handle 'caw' on first letter (193ms)

    ✓ Can handle 'caw' on blanks (211ms)

    ✓ Can handle 'caw' on blanks (129ms)

    ✓ Can handle 'ci(' on first parentheses (189ms)

    ✓ Can handle 'ci(' with nested parentheses (98ms)

    ✓ Can handle 'ci(' backwards through nested parens (164ms)

    ✓ Can handle 'cib' on first parentheses (113ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (66ms)

    ✓ Can handle count prefixed 'ci)' (121ms)

    ✓ Can handle count prefixed 'ca)' (136ms)

    ✓ Can handle 'ca(' spanning multiple lines (93ms)

    ✓ Can handle 'cab' spanning multiple lines (180ms)

    ✓ Can handle 'ci{' spanning multiple lines (105ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (194ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (170ms)

    ✓ Can handle 'ci(' on the closing bracket (105ms)

    ✓ Can handle 'ciB' spanning multiple lines (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ will fail when ca( with no () (121ms)

    ✓ will fail when ca{ with no {} (152ms)

    ✓ will fail when caB with no {} (133ms)

    ✓ Can handle 'ci[' spanning multiple lines (156ms)

    ✓ Can handle 'ci]' on first bracket (97ms)

    ✓ Can handle 'ca[' on first bracket (182ms)

    ✓ Can handle 'ca]' on first bracket (111ms)

    ✓ Can handle 'ci'' on first quote (144ms)

    ✓ Can handle 'ci'' inside quoted string (145ms)

    ✓ Can handle 'ci'' on closing quote (119ms)

    ✓ Can handle 'ci'' when string is ahead (146ms)

    ✓ Can handle 'ci"' on opening quote (147ms)

    ✓ Can handle 'ci"' starting behind the quoted word (208ms)

    ✓ Can handle 'ca"' starting behind the quoted word (87ms)

    ✓ Can handle 'ca"' starting on the opening quote (155ms)

    ✓ Can handle 'ci"' with escaped quotes (111ms)

    ✓ Can handle 'ci"' with a single escaped quote (116ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (153ms)

    ✓ Can handle 'ci"' with an escaped backslash (143ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (145ms)

    ✓ Can handle 'ca"' starting on the closing quote (215ms)

    ✓ Can handle 'ci"' with complex escape sequences (111ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (127ms)

    ✓ will fail when ca" ahead of quoted string (290ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'ca`' inside word (98ms)

    ✓ can handle cj (246ms)

    ✓ can handle ck (148ms)

    ✓ can handle c2j (134ms)

    ✓ can handle c2k (137ms)

    ✓ can handle cj on last line (218ms)

    ✓ can handle ck on first line (166ms)

    ✓ can handle c2j on last line (289ms)

    ✓ can handle c2k on first line (231ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (115ms)

    ✓ Can handle 'daw' on word with trailing spaces (78ms)

    ✓ Can handle 'daw' on word with leading spaces (95ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix (224ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (169ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (97ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (226ms)

    ✓ Can handle 'daw' on end of word (169ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (213ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word at beginning of file (233ms)

    ✓ Can handle 'daw' on word at beginning of line (129ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (182ms)

    ✓ Can handle 'daw' around word at end of line (164ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' around word at whitespace (106ms)

    ✓ Can handle 'daW' on word with trailing spaces (180ms)

    ✓ Can handle 'daW' on word with leading spaces (200ms)

    ✓ Can handle 'daW' on word with numeric prefix (123ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (222ms)

    ✓ Can handle 'daW' on beginning of word (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daW' on end of one line (223ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (104ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (226ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (179ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (207ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (327ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (84ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word (267ms)

    ✓ Can handle 'diw' on word with numeric prefix (101ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (127ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (142ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (225ms)

    ✓ Can handle 'diW' on word with trailing spaces (109ms)

    ✓ Can handle 'diW' on word with leading spaces (212ms)

    ✓ Can handle 'diW' on word with numeric prefix (133ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (211ms)

    ✓ Can handle 'diW' on beginning of word (126ms)

    ✓ Can handle d} (151ms)

    ✓ Can handle y} at beginning of line (210ms)

    ✓ Select sentence with trailing spaces (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Select sentence with leading spaces (229ms)

    ✓ Select inner sentence with trailing spaces (161ms)

    ✓ Select inner sentence with leading spaces (229ms)

    ✓ Select spaces between sentences (222ms)

    ✓ Can handle 'df' (208ms)

    ✓ Can handle 'dt' (155ms)

    ✓ Can handle backspace (94ms)

    ✓ Can handle backspace across lines (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A and backspace (158ms)

    ✓ Can handle 'yy' without changing cursor position (156ms)

    ✓ Can handle 'P' after 'yy' (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'p' after 'yy' (220ms)

    ✓ Can handle 'P' after 'Nyy' (167ms)

    ✓ Can handle 'p' after 'Nyy' (44ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (81ms)

    ✓ Can handle 'gp' after 'yy' (216ms)

    ✓ Can handle 'gp' after 'Nyy' (160ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (209ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (151ms)

    ✓ Can handle 'gP' after 'yy' (180ms)

    ✓ Can handle 'gP' after 'Nyy' (262ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (109ms)

    ✓ Can handle ']p' after yy (43ms)

    ✓ Can handle ']p' after 'Nyy' (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (237ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (168ms)

    ✓ Can handle '[p' after yy (225ms)

    ✓ Can handle '[p' after 'Nyy' (221ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (173ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (206ms)

    ✓ Can handle 'p' after y'a (144ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (139ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (212ms)

    ✓ Can handle pasting in visual mode over selection (227ms)

    ✓ Can repeat w (80ms)

    ✓ Can repeat p (199ms)

    ✓ I works correctly (211ms)

    ✓ gI works correctly (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gi works correctly (468ms)

    ✓ `. works correctly (229ms)

    ✓ '. works correctly (176ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g; works correctly (281ms)

    ✓ g, works correctly (147ms)

    ✓ g_ works correctly (204ms)

    ✓ 3g_ works correctly (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (638ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces before single line comments correctly (603ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles tabs before single line comments correctly (719ms)

    ✓ Can handle space (181ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (279ms)

    ✓ Undo 1 (250ms)

    ✓ Undo 2 (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Undo cursor (304ms)

    ✓ Undo cursor 2 (263ms)

    ✓ Undo cursor 3 (216ms)

    ✓ Undo with movement first (202ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' (233ms)

    ✓ Can handle 'U' for multiple changes (192ms)

    ✓ Can handle 'U' for new line below (212ms)

    ✓ Can handle 'U' for new line above (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' for consecutive changes only (523ms)

    ✓ Can handle 'u' to undo 'U' (127ms)

    ✓ Can handle 'U' to undo 'U' (267ms)

    ✓ Redo (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Redo (222ms)

    ✓ Redo (266ms)

    ✓ Can handle u (134ms)

    ✓ Can handle guw (164ms)

    ✓ Can handle gUw (168ms)

    ✓ Can handle u over line breaks (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle s in visual mode (246ms)

    ✓ can handle p with selection (174ms)

    ✓ can handle P with selection (237ms)

    ✓ can handle p in visual to end of line (229ms)

    ✓ can repeat backspace twice (92ms)

    ✓ can delete linewise with d2G (72ms)

    ✓ can delete with + motion and count (212ms)

    ✓ can delete with - motion and count (181ms)

    ✓ can dE correctly (130ms)

    ✓ can dE correctly (202ms)

    ✓ can dE correctly (112ms)

    ✓ can ctrl-a correctly behind a word (116ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (211ms)

    ✓ can ctrl-a on word (111ms)

    ✓ can ctrl-a on a hex number (210ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a on decimal (472ms)

    ✓ can ctrl-a with numeric prefix (248ms)

    ✓ can ctrl-a on a decimal (153ms)

    ✓ can ctrl-a on an octal  (223ms)

    ✓ Correctly increments in the middle of a number (55ms)

    ✓ can ctrl-x correctly behind a word (42ms)

    ✓ can ctrl-a on an number with word before  (187ms)

    ✓ can ctrl-a on an number with word before and after  (168ms)

    ✓ can ctrl-x on a negative number with word before and after  (235ms)

    ✓ can ctrl-a properly on multiple lines (112ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (201ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (92ms)

    ✓ can <C-a> on word with - in front of it (178ms)

    ✓ can do Y (158ms)

    ✓ Can do S (206ms)

    ✓ / does not affect mark (170ms)

    ✓ / can search with regex (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ / can search with newline (230ms)

    ✓ / can search through multiple newlines (203ms)

    ✓ / matches ^ per line (135ms)

    ✓ / matches $ per line (238ms)

    ✓ Can search for forward slash (144ms)

    ✓ Can search backward for question mark (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ /\c forces case insensitive search (272ms)

    ✓ /\C forces case sensitive search (139ms)

    ✓ <BS> deletes the last character in search in progress mode (200ms)

    ✓ <S-BS> deletes the last character in search in progress mode (124ms)

    ✓ <C-h> deletes the last character in search in progress mode (155ms)

    ✓ Can do C (94ms)

    ✓ Can do cit on a matching tag (205ms)

    ✓ Ignores cit on a non-matching tag (125ms)

    ✓ Ignores cit on a nested tag (214ms)

    ✓ Can do cit on a tag with an attribute tag (135ms)

    ✓ Can do cat on a matching tag (198ms)

    ✓ Can do cit on a multiline tag (123ms)

    ✓ Can do cit on a multiline tag with nested tags (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (237ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (233ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (193ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (155ms)

    ✓ can do cit with self closing tags (184ms)

    ✓ Respects indentation with cc (147ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Resets cursor to indent end with cc (567ms)

    ✓ can handle 'cc' on empty line (64ms)

    ✓ cc copies linewise (60ms)

    ✓ Indent current line with correct Vim Mode (125ms)

    ✓ Can handle <Esc> and do nothing (159ms)

    ✓ Can handle # on consecutive words (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle # on skipped words (328ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (202ms)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (382ms)

    ✓ cc on whitespace-only treats whitespace as indent (200ms)

    ✓ Can do cai (172ms)

    ✓ Can do cii (106ms)

    ✓ Can do caI (209ms)

    ✓ Can do dai (192ms)

    ✓ Can do dii (77ms)

    ✓ Can do daI (201ms)

    ✓ `] go to the end of the previously operated or put text (170ms)

    ✓ '] go to the end of the previously operated or put text (198ms)

    ✓ `[ go to the start of the previously operated or put text (229ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '[ go to the start of the previously operated or put text (475ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (189ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (263ms)

    can handle gn

      ✓ gn selects the next match text (213ms)

      ✓ gn selects the current word at |hello (307ms)

      ✓ gn selects the current word at h|ello (294ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the current word at hel|lo (437ms)

      ✓ gn selects the current word at hell|o (201ms)

      ✓ gn selects the next word at hello| (363ms)

    can handle dgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the next match text (from first line) (244ms)

      ✓ dgn deletes the current word when cursor is at |hello (256ms)

      ✓ dgn deletes the current word when cursor is at h|ello (166ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (190ms)

      ✓ dgn deletes the current word when cursor is at hell|o (175ms)

      ✓ dgn deletes the next word when cursor is at hello| (147ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (269ms)

      ✓ cgn deletes the current word when cursor is at |hello (360ms)

      ✓ cgn deletes the current word when cursor is at h|ello (150ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hel|lo (245ms)

      ✓ cgn deletes the current word when cursor is at hell|o (145ms)

      ✓ cgn deletes the next word when cursor is at hello| (144ms)

    can handle gN

      ✓ gN selects the previous match text (512ms)

      ✓ gN selects the current word at hell|o (510ms)

      ✓ gN selects the current word at hel|lo (433ms)

      ✓ gN selects the current word at h|ello (232ms)

      ✓ gN selects the current word at |hello (222ms)

      ✓ gN selects the previous word at | hello (351ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (112ms)

      ✓ dgN deletes the current word when cursor is at hell|o (170ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (152ms)

      ✓ dgN deletes the current word when cursor is at h|ello (158ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at |hello (266ms)

      ✓ dgN deletes the previous word when cursor is at | hello (488ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (170ms)

      ✓ cgN deletes the current word when cursor is at hell|o (186ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (227ms)

      ✓ cgN deletes the current word when cursor is at h|ello (164ms)

      ✓ cgN deletes the current word when cursor is at |hello (200ms)

      ✓ cgN deletes the previous word when cursor is at | hello (211ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (123ms)

    ✓ Can activate with R from Normal mode (106ms)

    ✓ Can handle R (155ms)

    ✓ Can handle R past current line (211ms)

    ✓ Can handle R and exit Replace Mode (158ms)

    ✓ Can handle R across lines (146ms)

    ✓ Can handle R across lines and exit Replace Mode (196ms)

    ✓ Can handle R with {count} (186ms)

    ✓ Can handle backspace (188ms)

    ✓ Can handle backspace (245ms)

    ✓ Can handle backspace across lines (255ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle arrows (479ms)

    ✓ Can handle . (178ms)

    ✓ Can handle . across lines (303ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (356ms)

    ✓ Can handle wd (197ms)

    ✓ Can handle x (176ms)

    ✓ Can handle x across a selection (514ms)

    ✓ Can do vwd in middle of sentence (282ms)

    ✓ Can do vwd in middle of sentence (209ms)

    ✓ Can do vwd multiple times (390ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (195ms)

    ✓ Can handle H key (121ms)

    ✓ Can handle backspace key (188ms)

    ✓ handles case where we delete over a newline (277ms)

    ✓ handles change operator (248ms)

    ✓ Can do vat on multiple matching tags (166ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (205ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (209ms)

    ✓ Repeat-prefixed vat does not bleed below (93ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (110ms)

    ✓ Can do vi) on a matching parenthesis (211ms)

    ✓ Can do vi) on multiple matching parens (185ms)

    ✓ Can do va) on a matching parenthesis (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va) on multiple matching parens (401ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (177ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Repeat-prefixed va) does not bleed below (404ms)

    ✓ Can do va} on a matching bracket as first character (117ms)

    ✓ Can do va} on multiple matching brackets (142ms)

    ✓ Can do vi( on a matching bracket near first character (104ms)

    ✓ Can do vi{ on outer pair of nested braces (164ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (94ms)

    ✓ Can do va] on multiple matching brackets (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (311ms)

    ✓ Repeat-prefixed vaf does not bleed below (125ms)

    ✓ vaf only expands to enclosing pairs (108ms)

    ✓ Can use . to repeat indent in visual (197ms)

    ✓ Can do v_x to delete to first char (117ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vg_x to delete to last char with no EOL (230ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (217ms)

    ✓ Can do v$x to delete to last char including EOL (70ms)

    ✓ Can do gv to reselect previous selection (94ms)

    Vim's EOL handling is weird

      ✓ delete through eol (113ms)

      ✓ join 2 lines by deleting through eol (197ms)

      ✓ d$ doesn't delete whole line (85ms)

      ✓ vd$ does delete whole line (179ms)

      ✓ Paste over selection copies the selection (172ms)

      ✓ Paste over selection copies the selection linewise (202ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <down> key (293ms)

      ✓ Can handle <left> key (161ms)

      ✓ Can handle <right> key (227ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (127ms)

      ✓ Can handle 'gj' (121ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (237ms)

      ✓ Can handle 'vawd' on word with leading spaces (152ms)

      ✓ Can handle 'vawd' on word with numeric prefix (212ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (310ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (76ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (222ms)

      ✓ Can handle 'vaWd' on word with leading spaces (164ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (218ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (174ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (145ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (181ms)

      ✓ Can handle 'vaWd' on word with leading spaces (204ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (458ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (189ms)

      ✓ Can handle 'vawd' on word with trailing spaces (170ms)

      ✓ Can handle 'vawd' on word with leading spaces (168ms)

      ✓ Can handle 'vawd' on word with numeric prefix (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (459ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (228ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (225ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (131ms)

      ✓ Can handle 'vaWd' on word with leading spaces (190ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (108ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (210ms)

      ✓ Can handle 'Y' in visual mode (193ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (440ms)

      ✓ Select multiple sentences in visual mode (258ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select inner sentence with leading spaces in visual mode (365ms)

      ✓ Select spaces between sentences in visual mode (276ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (229ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (137ms)

      ✓ Can do vat on a matching tag (195ms)

    handles replace in visual mode

      ✓ Can do a single line replace (219ms)

      ✓ Can do a multi line replace (130ms)

    D command will remove all selected lines

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ D deletes all selected lines (302ms)

      ✓ D deletes the current line (174ms)

    handles indent blocks in visual mode

      ✓ Can do vai (203ms)

      ✓ Can do vii (193ms)

      ✓ Doesn't naively select the next line (155ms)

      ✓ Searches backwards if cursor line is empty (153ms)

      ✓ Can do vaI (157ms)

    visualstar

      ✓ Works with * (162ms)

      ✓ Works with # (76ms)

    search works in visual mode

      ✓ Works with / (86ms)

      1) Works with ?

      ✓ Selects correct range (131ms)

    X will delete linewise

      ✓ normal selection (77ms)

      ✓ normal selection (226ms)

    C will delete linewise

      ✓ normal selection (143ms)

      ✓ normal selection (222ms)

    R will delete linewise

      ✓ normal selection (105ms)

      ✓ normal selection (228ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (190ms)

      ✓ upward selection (181ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (74ms)

      ✓ multiline indent bottom up selection (163ms)

      ✓ repeat multiline indent top down selection (85ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent bottom up selection (265ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (303ms)

      ✓ multiline outdent bottom up selection (148ms)

      ✓ repeat multiline outdent top down selection (112ms)

      ✓ repeat multiline outdent bottom up selection (215ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (155ms)

    vi{ will go to end of second to last line

      ✓ select (84ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (647ms)

      ✓ gv selects the last pasted text (which is longer than original) (419ms)

      ✓ gv selects the last pasted text (multiline) (370ms)

    can handle gn

      ✓ gn selects the next match text (452ms)

      ✓ gn selects the current word at |hello (222ms)

      ✓ gn selects the current word at h|ello (213ms)

      ✓ gn selects the current word at hel|lo (254ms)

      ✓ gn selects the next word at hell|o (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the next word at hello| (376ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (60ms)

      ✓ skips blank lines (146ms)

    can append text with A

      ✓ multiline append from bottom up selection (161ms)

      ✓ multiline append from top down selection (118ms)

      ✓ skips blank lines (190ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (167ms)

      ✓ U/gU across a selection (234ms)

      ✓ U/gU across a selection (reverse) (185ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ u/gu on single character (135ms)

      ✓ u/gu across a selection (132ms)

      ✓ u/gu across a selection (reverse) (262ms)

  Mode Visual Block

    ✓ can be activated (41ms)

    ✓ Can handle A forward select (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (260ms)

    ✓ Can handle I forward select (137ms)

    ✓ Can handle I backwards select (237ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (150ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (202ms)

    ✓ Can handle c forward select (165ms)

    ✓ Can handle c backwards select (245ms)

    ✓ Can handle C (133ms)

    ✓ Can do a multi line replace (131ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' (232ms)

    ✓ Can handle 'gj' (78ms)

    ✓ Properly add to end of lines j then $ (85ms)

    ✓ Properly add to end of lines $ then j (136ms)

    ✓ o works in visual block mode (113ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (165ms)

  Mode Visual Line

    ✓ can be activated (39ms)

    ✓ Can handle w (149ms)

    ✓ Can handle wd (228ms)

    ✓ Can handle x (196ms)

    ✓ Can handle x across a selection (311ms)

    ✓ Can do vwd in middle of sentence (182ms)

    ✓ Can do vwd in middle of sentence (109ms)

    ✓ Can do vwd multiple times (320ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (144ms)

    ✓ handles case where we delete over a newline (160ms)

    ✓ handles change operator (198ms)

    ✓ Vp updates register content (97ms)

    ✓ Vp does not append unnecessary newlines (first line) (204ms)

    ✓ Vp does not append unnecessary newlines (middle line) (125ms)

    ✓ Vp does not append unnecessary newlines (last line) (163ms)

    Vim's EOL handling is weird

      ✓ delete through eol (149ms)

      ✓ join 2 lines by deleting through eol (119ms)

      ✓ d$ doesn't delete whole line (76ms)

      ✓ vd$ does delete whole line (109ms)

    Arrow keys work perfectly in Visual Line Mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle <up> key (349ms)

      ✓ Can handle <down> key (79ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (62ms)

      ✓ Can handle 'gj' (59ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (190ms)

      ✓ Can handle d key (166ms)

      ✓ Can handle d key (66ms)

      ✓ Can handle d key (146ms)

      ✓ can handle 'c' (57ms)

    handles replace in visual line mode

      ✓ Can do a single line replace (75ms)

      ✓ Can do a multi visual line replace (205ms)

      ✓ Can do a multi visual line replace from the bottom up (158ms)

    search works in visual line mode

      ✓ Works with / (223ms)

      ✓ Works with ? (120ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (237ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (200ms)

      ✓ linewise visual put works also in the end of document (144ms)

      ✓ gv selects the last pasted text (which is shorter than original) (474ms)

      ✓ gv selects the last pasted text (which is longer than original) (397ms)

      ✓ gv selects the last pasted text (multiline) (168ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (181ms)

      ✓ multiline insert from top down selection (148ms)

      ✓ skips blank lines (160ms)

    can append text with A

      ✓ multiline append from bottom up selection (201ms)

      ✓ multiline append from top down selection (126ms)

      ✓ skips blank lines (215ms)

  Mode Normal

    ✓ Can handle 'x' (141ms)

    ✓ Can handle 'Nx' (59ms)

    ✓ Can handle 'Nx' and paste (63ms)

    ✓ Can handle 'x' at end of line (231ms)

    ✓ Can handle 'Ns' (113ms)

    ✓ Can handle 'Ns' at end of line (176ms)

    ✓ Can handle '<Del>' (181ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (146ms)

    ✓ Can handle '<Del>' at end of line (228ms)

    ✓ Can handle 'cc' (200ms)

    ✓ Can handle 'Ncc' (121ms)

    ✓ Can handle 'yy' (143ms)

    ✓ Can handle 'D' (152ms)

    ✓ Can handle 'D' on empty lines (84ms)

    ✓ Can handle 'DD' (146ms)

    ✓ Can handle 'C' (206ms)

    ✓ Can handle 'NC' (163ms)

    ✓ Can handle 'NC' and put (174ms)

    ✓ Can handle 'r' (176ms)

    ✓ Can handle '<Count>r' (208ms)

    ✓ Can handle '<Count>r' (100ms)

    ✓ Can handle 'r' after 'dd' (199ms)

    ✓ Can handle 'r
' (95ms)

    ✓ Can handle '<Count>r
' (180ms)

    ✓ Can handle 'J' once (73ms)

    ✓ Can handle 'J' twice (140ms)

    ✓ Can handle 'J' with empty last line (161ms)

    ✓ Can handle 'J's with multiple empty last lines (215ms)

    ✓ Can handle 'J' with leading white space on next line (48ms)

    ✓ Can handle 'J' with only white space on next line (181ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with TWO indented lines (334ms)

    ✓ Can handle 'J' with ')' first character on next line (206ms)

    ✓ Can handle 'J' with a following delete (93ms)

    ✓ Can handle 'J' in Visual Line mode (155ms)

    ✓ Can handle 'gJ' once (109ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (182ms)

    ✓ Can handle '~' (132ms)

    ✓ Can handle 'g~{motion}' (120ms)

    ✓ Can handle '<BS>' in insert mode (147ms)

    ✓ Can handle undo with P (320ms)

    ✓ Can handle 'ge' in multiple lines case1 (129ms)

    ✓ Can handle 'ge' in multiple lines case2 (135ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (117ms)

    ✓ Can repeat '~' with dot (163ms)

    ✓ Can repeat 'x' (186ms)

    ✓ Can repeat 'J' (144ms)

    ✓ Can handle dot with A (141ms)

    ✓ Can handle dot with I (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat actions that require selections (349ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (104ms)

    ✓ Can repeat insert change and '<C-t>' (244ms)

    ✓ Can repeat change by `<C-a>` (240ms)

    ✓ Only one arrow key can be repeated in Insert Mode (71ms)

    ✓ Cached content change will be cleared by arrow keys (267ms)

  Matching Bracket (%)

    ✓ before opening parenthesis

    ✓ inside parenthesis (187ms)

    ✓ nested parenthesis beginning (46ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested parenthesis end (130ms)

    ✓ nested bracket and parenthesis beginning (150ms)

    ✓ nested bracket, parenthesis, braces beginning (63ms)

    ✓ nested bracket, parenthesis, braces end (121ms)

    ✓ parentheses after > (171ms)

    ✓ parentheses after " (38ms)

  Motions in Normal Mode

    ✓ Can handle [( (187ms)

    ✓ Can handle nested [( (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <number>[( (217ms)

    ✓ Can handle [( and character under cursor exclusive (109ms)

    ✓ Can handle ]) (110ms)

    ✓ Can handle nested ]) (159ms)

    ✓ Can handle <number>]) (96ms)

    ✓ Can handle ]) and character under cursor exclusive (181ms)

    ✓ Can handle [{ (77ms)

    ✓ Can handle nested [{ (120ms)

    ✓ Can handle <number>[{ (177ms)

    ✓ Can handle [{ and character under cursor exclusive (160ms)

    ✓ Can handle ]} (208ms)

    ✓ Can handle nested ]} (136ms)

    ✓ Can handle <number>]} (110ms)

    ✓ Can handle ]} and character under cursor exclusive (198ms)

    ✓ Can handle 'ge' (196ms)

    ✓ Can handle 'gg' (157ms)

    ✓ Can handle 'gg' to first non blank char on random line (115ms)

    ✓ Can handle 'gg' to first non blank char on first line (186ms)

    ✓ 'gg' obeys startofline (81ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Retain same column when moving up/down (371ms)

    ✓ Can handle <enter> (129ms)

    ✓ $ always keeps cursor on EOL (214ms)

    ✓ Can handle $ with a count (233ms)

    ✓ Can handle $ with a count at end of file (94ms)

    ✓ Can handle <End> with a count (180ms)

    ✓ Can handle <D-right> with a count (165ms)

    ✓ Can handle 'f' (145ms)

    ✓ Can handle 'f' twice (197ms)

    ✓ Can handle 'f' with <tab> (160ms)

    ✓ Can handle 'f' and find back search (104ms)

    ✓ Can handle 'F' (78ms)

    ✓ Can handle 'F' twice (122ms)

    ✓ Can handle 'F' and find back search (141ms)

    ✓ Can handle 'f' and multiple back searches (198ms)

    ✓ Can handle 't' (68ms)

    ✓ Can handle 't' twice (134ms)

    ✓ Can handle 't' and find back search (177ms)

    ✓ Can handle 'T' (132ms)

    ✓ Can handle 'T' twice (125ms)

    ✓ Can handle 'T' and find back search (268ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a forward search (109ms)

    ✓ Can run a forward and find next search (193ms)

    ✓ Can run a forward and find previous search from end of word (208ms)

    ✓ Can run a reverse search (244ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a reverse and find next search (568ms)

    ✓ cancelled search reverts to previous search state (172ms)

    ✓ Backspace on empty search cancels (150ms)

    ✓ Search offsets: b does nothing (95ms)

    ✓ Search offsets: b2 goes 2 to the right (115ms)

    ✓ Search offsets: b+3 goes 3 to the right (213ms)

    ✓ Search offsets: e goes to the end (169ms)

    ✓ Search offsets: character offset goes across line boundaries (117ms)

    ✓ Search offsets: 2 goes 2 down (154ms)

    ✓ Search offsets: -2 goes 2 up (74ms)

    ✓ maintains column position correctly (234ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ maintains column position correctly with $ (124ms)

    ✓ Can handle G  (165ms)

    ✓ Can handle G with number prefix (83ms)

    ✓ Can handle G with number prefix (189ms)

    ✓ Can handle gg (44ms)

    ✓ Can handle gg with number prefix (181ms)

    ✓ Can handle 0 (80ms)

    ✓ Can handle 0 as part of a repeat (177ms)

    ✓ Can handle g* (175ms)

    ✓ Can handle g*n (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle * (267ms)

    ✓ Can handle ** (69ms)

    ✓ Can handle # on whitespace (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle # on EOL (496ms)

    ✓ Can handle g# (295ms)

    ✓ Can handle g#n (184ms)

    ✓ Can handle # (179ms)

    ✓ Can handle # already on the word (193ms)

    ✓ Can handle ## (164ms)

    ✓ * adds to search history (109ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ # adds to search history (440ms)

    ✓ Can handle | (145ms)

    ✓ Can handle <number> | (139ms)

    ✓ Can handle + (65ms)

    ✓ Can handle + indent (153ms)

    ✓ Can handle + with count prefix (137ms)

    ✓ Can handle - (58ms)

    ✓ Can handle - indent (49ms)

    ✓ Can handle - with count prefix (101ms)

    ✓ Can handle _ (55ms)

    ✓ Can handle _ with count prefix (45ms)

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix (44ms)

    ✓ Can handle <up> key (92ms)

    ✓ Can handle <down> key (61ms)

    ✓ Can handle <left> key (51ms)

    ✓ Can handle <right> key (47ms)

    ✓ Can handle 'gk' (67ms)

    ✓ Can handle 'gj' (80ms)

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right
    ✓ char right
    ✓ char left: should move cursor one column left
    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down
    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin
    ✓ line end
    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character
    ✓ last line begin cursor on first non-blank character
    word right
      ✓ move to word right
      ✓ last word should move to next line
      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line
      ✓ last word on last line should go to end of document (special case!)
    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right
      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)
      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)
      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph
      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line (56ms)

        ✓ l wraps to next line (179ms)

        ✓ <left> wraps to previous line (59ms)

        ✓ <right> wraps to next line (82ms)

      insert mode

        ✓ <left> wraps to previous line (58ms)

        ✓ <right> once goes to end of line (183ms)

        ✓ <right> twice wraps to next line (98ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (99ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ l does not wrap to next line (491ms)

        ✓ <left> does not wrap to previous line (141ms)

        ✓ <right> does not wrap to next line (72ms)

      insert mode

        ✓ <left> does not wrap to previous line (193ms)

        ✓ <right> does not wrap to next line (166ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (245ms)

      ✓ search wraps around the start of the file (141ms)

    wrapscan disabled

      ✓ search stops at the end of the file (129ms)

      ✓ search stops at the start of the file (196ms)

  Multicursor

    ✓ can add multiple cursors below (219ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can add multiple cursors above (471ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip
  comment operator

    ✓ gcc comments out current line (237ms)

    ✓ gcj comments in current and next line (215ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (401ms)

    ✓ block comment in Visual Mode (226ms)

    ✓ comment in visual line mode (161ms)

    ✓ comment in visual block mode (217ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (635ms)

    ✓ =$ formats entire line (566ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =j formats two lines (252ms)

    ✓ 3=k formats three lines (228ms)

    ✓ =gg formats to top of file (132ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ =G formats to bottom of file (315ms)

    ✓ =ip formats paragraph (184ms)

    ✓ format in visual mode (190ms)

  put operator

    ✓ basic put test (173ms)

    ✓ test yy end of line (83ms)

    ✓ test yy first line (184ms)

    ✓ test yy middle line (178ms)

    ✓ test yy with correct positon movement (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line yank p (249ms)

    ✓ test visual block single line yank P (186ms)

    ✓ test visual block single line delete p (283ms)

    ✓ test visual block single line delete P (230ms)

  rot13 operator

    2) rot13() unit test

    ✓ g?j works (167ms)

    ✓ g? in visual mode works (156ms)

    3) g? in visual line mode works

    4) g? in visual block mode works

  shift operator

    ✓ basic shift left test (139ms)

    ✓ shift left goto end test (197ms)

    ✓ shift left goto line test (166ms)

    ✓ shift right goto end test (115ms)

    ✓ shift right goto line test (206ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (120ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step to Camel word (428ms)

      ✓ step to CAP word (206ms)

      ✓ step after CAP word (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from middle of word to Camel word (259ms)

      ✓ step to number word (183ms)

      ✓ step to operator word (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (277ms)

      ✓ step to operator and then over (144ms)

    handles <leader>w for underscore_var

      ✓ step to _word (186ms)

      ✓ step over whitespace to word (124ms)

      ✓ step from inside word to _word (173ms)

      ✓ step form _word to number (197ms)

      ✓ step from nubmer word to _word (190ms)

      ✓ step from in whitespace to word (190ms)

      ✓ step in ALL_CAPS_WORD (120ms)

    handles d<leader>w

      ✓ delete from start of camelWord (181ms)

      ✓ delete from middle of camelWord (186ms)

      ✓ delete from start of CamelWord (225ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camelWord (119ms)

      ✓ delete from start of underscore_word (206ms)

      ✓ delete from middle of underscore_word (113ms)

      ✓ delete two words from camel_word (194ms)

    handles di<leader>w

      ✓ delete from start of camelWord (171ms)

      ✓ delete from middle of camelWord (210ms)

      ✓ delete from start of CamelWord (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete two words from camelWord (215ms)

      ✓ delete from start of underscore_word (123ms)

      ✓ delete from middle of underscore_word (90ms)

      ✓ delete two words from camel_word (211ms)

    handles <leader>b

      ✓ back from middle of word (256ms)

      ✓ back over whitespace to camelWord (157ms)

      ✓ back twice over operator (153ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (206ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ from middle to end of underscore_word (375ms)

      ✓ twice to end of word over operator (447ms)

  easymotion plugin

    ✓ Can handle s move (130ms)

    ✓ Can handle 2s move (193ms)

    ✓ Can handle f move (125ms)

    ✓ Can handle 2f move (227ms)

    ✓ Can handle F move (480ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2F move (169ms)

    ✓ Can handle t move (211ms)

    ✓ Can handle bd-t move (164ms)

    ✓ Can handle 2t move (121ms)

    ✓ Can handle bd-t2 move (182ms)

    ✓ Can handle T move (132ms)

    ✓ Can handle 2T move (160ms)

    ✓ Can handle w move (132ms)

    ✓ Can handle bd-w move (204ms)

    ✓ Can handle b move (178ms)

    ✓ Can handle e move (124ms)

    ✓ Can handle bd-e move (215ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle ge move (160ms)

    ✓ Can handle n-char move (186ms)

    ✓ Can handle j move (191ms)

    ✓ Can handle k move (132ms)

    ✓ Can handle bd-jk move (1) (207ms)

    ✓ Can handle bd-jk move (2) (169ms)

    ✓ Can handle lineforward move (1) (205ms)

    ✓ Can handle lineforward move (2) (102ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle linebackward move (1) (230ms)

    ✓ Can handle linebackward move (2) (157ms)

    ✓ Can handle searching for backslash (\) (169ms)

    ✓ Can handle searching for carat (^) (130ms)

    ✓ Can handle searching for dot (.) (135ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (198ms)

    ✓ Replaces within inner Word (130ms)

    ✓ Replaces within '' (225ms)

    ✓ Replaces within '' including spaces (116ms)

    ✓ Replaces within () (223ms)

    ✓ Replaces within () including spaces (202ms)

    ✓ Replaces within a paragraph (105ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces using a specified register (233ms)

    ✓ Replaces within {} over multiple lines (133ms)

    ✓ Replaces a multiline register within {} over multiple lines (171ms)

    ✓ Replaces a multiline register within {} over multiple lines (472ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (440ms)

    ✓ grr replaces the entire line with the register (171ms)

    ✓ grr can replace multiple lines (573ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode (231ms)

    ✓ Replaces in visual mode using a specified register (156ms)

    ✓ Replaces in visual line mode (147ms)

    ✓ grj is linewise (212ms)

  sneak plugin

    ✓ Can handle s motion (137ms)

    ✓ Can handle S motion (213ms)

    ✓ Can handle <operator>z motion (192ms)

    ✓ Can handle <operator>Z motion (115ms)

    ✓ Can handle s; motion (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle s, motion (882ms)

    ✓ Can handle S; motion (240ms)

    ✓ Can handle S, motion (133ms)

    ✓ Can handle single letter s motion (172ms)

    ✓ Can handle single letter S motion (132ms)

    ✓ Can handle single letter <operator>z motion (200ms)

    ✓ Can handle single letter <operator>Z motion (210ms)

    ✓ Can handle single letter s; motion (114ms)

    ✓ Can handle single letter s, motion (189ms)

    ✓ Can handle single letter S; motion (144ms)

    ✓ Can handle single letter S, motion (141ms)

    ✓ Can handle multiline single char <number>s motion (209ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (156ms)

    ✓ 'ysiw(' surrounds word with space (253ms)

    ✓ 'ysw)' surrounds word without space (169ms)

    ✓ 'ysw(' surrounds word with space (116ms)

    ✓ 'ysaw)' surrounds word without space (158ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysaw(' surrounds word with space (374ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (123ms)

    ✓ 'ysiw<' surrounds word with tags (159ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'cst<' surrounds word with tags that have a dot in them (417ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (711ms)

    ✓ change surround (155ms)

    ✓ change surround with two pairs of quotes (169ms)

    ✓ change surround with two pairs of parens (209ms)

    ✓ change surround with alias (188ms)

    ✓ change surround to tags (186ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround (795ms)

    ✓ delete surround with quotes (144ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ delete surround with nested of quotes (245ms)

    ✓ delete surround with inconsistent quotes (86ms)

    ✓ delete surround with mixed quotes (191ms)

    ✓ delete surround with empty quotes cursor at start (115ms)

    ✓ delete surround with empty quotes cursor at end (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ don't delete surround if cursor is after closing match (230ms)

    ✓ delete surround if cursor is before opening match (119ms)

    ✓ delete surround with two pairs of parens (158ms)

    ✓ delete surround with alias (131ms)

    ✓ delete surround with tags (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (330ms)

    ✓ changing brackets with surround works again (112ms)

    ✓ change surround with tags that contain an attribute and preserve them (328ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with tags that contain an attribute and remove them (264ms)

  register

    ✓ Can copy to a register (104ms)

    ✓ Can use two registers together (368ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use black hole register (378ms)

    ✓ System clipboard works with chinese characters (61ms)

    ✓ Yank stores text in Register '0' (381ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (639ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (370ms)

    ✓ Register '1'-'9' stores delete content (376ms)

    ✓ "A appends linewise text to "a (439ms)

    ✓ "A appends character wise text to "a (609ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (310ms)

    ✓ Small deletion using Del is stored in small delete register (382ms)

    ✓ Small deletion using X is stored in small delete register (420ms)

    ✓ Search register (/) is set by forward search (579ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Search register (/) is set by backward search (1216ms)

    ✓ Search register (/) is set by star search (447ms)

    ✓ Command register (:) is set by command line (105ms)

    ✓ Read-only registers cannot be written to (276ms)

    clipboard

      ✓ Can access '*' (clipboard) register (180ms)

      ✓ Can access '+' (clipboard) register (164ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (162ms)

    ✓ Can repeat reversed F<character> (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat t<character> (214ms)

    ✓ Can repeat N times reversed t<character> (127ms)

  sentence motion
    [count] sentences backward

      ✓ move one sentence backward (237ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.0/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move one sentence backward (688ms)

      ✓ move [count] sentences backward (250ms)

      ✓ move one sentence backward single line - middle (140ms)

      ✓ move one sentence backward no space (175ms)

      ✓ move one sentence backward no space - middle (155ms)

      ✓ move one sentence backward - multiline (168ms)

      ✓ move one sentence backward - multiline - period (131ms)

      ✓ move one sentence backward - multiline - previous line (171ms)

      ✓ move one sentence backward - multiline - previous line - period (82ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1299 passing (6m)

  4 pending

  4 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:921:5)


  2) rot13 operator
       rot13() unit test:

      AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
+ actual - expected

+ 'n'
- 'nopqrstuvwxyzabcdefghijklm'
      + expected - actual

      -n
      +nopqrstuvwxyzabcdefghijklm
      
      at Context.<anonymous> (test/operator/rot13.test.ts:25:14)


  3) rot13 operator
       g? in visual line mode works:

      Cursor CHARACTER position is wrong.
      + expected - actual

      -0
      +1
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:43:3)


  4) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=drs. Actual=qrs.
      + expected - actual

      -qrs
      +drs
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:50:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 355941d0-1eb4-11ea-8c7c-334558e6cc20

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.3 build /home/travis/build/VSCodeVim/Vim
> gulp build

[04:37:08] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[04:37:08] Starting 'build'...
[04:37:08] Starting 'prettier'...
[04:37:08] Finished 'prettier' after 27 ms
[04:37:08] Starting 'tsc'...
[04:37:08] Starting 'tslint'...
[04:37:15] Finished 'tslint' after 6.56 s
[04:37:22] Finished 'tsc' after 14 s
[04:37:22] Starting 'commit-hash'...
[04:37:22] Finished 'commit-hash' after 28 ms
[04:37:22] Finished 'build' after 14 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T04:37:26.293Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line (38ms)

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (42ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (71ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (71ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (46ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history (38ms)

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (52ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (984ms)

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (529ms)

    ✓ :smile editor contains smile text (535ms)

  Basic sort

    ✓ Sort whole file, asc (68ms)

    ✓ Sort whole file, asc, ignoreCase (76ms)

    ✓ Sort whole file, dsc (84ms)

    ✓ Sort whole file, dsc, ignoreCase (65ms)

    ✓ Sort range, asc (105ms)

    ✓ Sort range, asc, ignoreCase (100ms)

    ✓ Sort range, dsc (83ms)

    ✓ Sort range, dsc, ignoreCase (104ms)

    ✓ Sort whole file, asc, unique (94ms)

  Horizontal split

    ✓ :sp creates a second split (63ms)

    ✓ :split creates a second split (59ms)

    ✓ :new creates a second split (209ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once

    ✓ Replace with `g` flag (42ms)

    ✓ Replace with flags AND count (123ms)

    ✓ Replace with `c` flag

    ✓ Replace with `gc` flag (54ms)

    ✓ Replace across all lines (60ms)

    ✓ Replace on specific single line (70ms)

    ✓ Replace on current line using dot (49ms)

    ✓ Replace single relative line using dot and plus (114ms)

    ✓ Replace across specific line range (108ms)

    ✓ Replace across relative line range using dot, plus, and minus (113ms)

    ✓ Replace across relative line range using numLines+colon shorthand (81ms)

    ✓ Repeat replacement across relative line range (85ms)

    ✓ Replace with range AND count but no flags (80ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (76ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (80ms)

    ✓ Undocumented: trailing operators use 1 as RHS (68ms)

    ✓ Replace specific single equal lines (42ms)

    ✓ Replace current line with no active selection (70ms)

    ✓ Replace text in selection (65ms)

    ✓ Substitute support marks (61ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line

      ✓ Replace with `g` flag inverts global flag

      ✓ Replace with `c` flag inverts global flag (57ms)

      ✓ Replace multiple lines (71ms)

      ✓ Replace across specific lines (53ms)

      ✓ Replace current line with no active selection (75ms)

      ✓ Replace text in selection (176ms)

      ✓ Substitute support marks (67ms)

      ✓ Substitute with escaped delimiter (58ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (138ms)

      ✓ Substitute with previous search using # (144ms)

      ✓ Substitute with previous search using / (143ms)

      ✓ Substitute with parameters should update search state (103ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (201ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (104ms)

      ✓ Substitute repeat previous should accept flags (64ms)

      ✓ Substitute with empty search string should use last searched pattern (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Ampersand (&) should repeat the last substitution (233ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (53ms)

    ✓ tabe with current file path does nothing (55ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (47ms)

    ✓ command line file tab completion with space in file path (124ms)

  Vertical split

    ✓ :vs creates a second split (72ms)

    ✓ :vsp creates a second split (55ms)

    ✓ :vsplit creates a second split (62ms)

    ✓ :vnew creates a second split (167ms)

    ✓ :vne creates a second split (154ms)

  Basic write-quit

    ✓ Run write and quit (43ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (39ms)

      ✓ Can complete lines in file with different indentation (74ms)

      ✓ Returns no completions for unmatched line

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (80ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (68ms)

    ✓ getMatchingRemap (53ms)

    ✓ jj -> <Esc> through modehandler (85ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (70ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (67ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (146ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (82ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (114ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (100ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (120ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator
    ✓ no remappings
    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped
  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers
    ✓ all defined configurations in package.json have handlers
  Record and navigate jumps
    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (58ms)

        ✓ Can track jumps for keys: GggG (67ms)

        ✓ Can track jumps for keys: GggGgg (66ms)

        ✓ Can track jumps for keys: /b<CR>n (81ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (79ms)

        ✓ Can track jumps for keys: j%% (41ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (87ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (65ms)

        ✓ Can track jumps for keys: j%%<C-o>% (81ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (71ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (81ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (103ms)

        ✓ Can enter number to jump back multiple times (38ms)

        ✓ Can track one-line `` jumps (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line double `` jumps (250ms)

        ✓ Can track one-line '' jumps (179ms)

        ✓ Can track one-line double '' jumps (113ms)

        ✓ Can handle '' jumps with no previous jump (213ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (209ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (254ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (167ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (284ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (292ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (186ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (229ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (168ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (164ms)

      Can track jumps from marks

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: maG`a (230ms)

  Record and execute a macro

    ✓ Can record and execute (404ms)

[main 2019-12-26T04:37:56.296Z] update#setState checking for updates

[main 2019-12-26T04:37:56.376Z] update#setState idle

    ✓ Can repeat last invoked macro (333ms)

    ✓ Can play back with count (291ms)

    ✓ Can play back with count, abort when a motion fails (332ms)

    ✓ Repeat change on contiguous lines (148ms)

    ✓ Append command to a macro (239ms)

    ✓ Can record Ctrl Keys and repeat (219ms)

    ✓ Can execute macros with dot commands properly (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ : (command) register can be used as a macro (246ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (48ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert (50ms)

    ✓ <Esc> can exit insert

    ✓ Stay in insert when entering characters (71ms)

    ✓ Can handle 'O'

    ✓ 'i' puts you in insert mode before the cursor (70ms)

    ✓ 'I' puts you in insert mode at start of line

    ✓ 'a' puts you in insert mode after the cursor (91ms)

    ✓ 'A' appends to end of line (124ms)

    ✓ '<C-w>' deletes a word (143ms)

    ✓ Can handle <C-w> on leading whitespace (137ms)

    ✓ Can handle <C-w> at beginning of line (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <C-u> deletes to start of line (234ms)

    ✓ Can handle <C-u> on leading characters (44ms)

    ✓ Can handle <C-u> on leading whitespace (212ms)

    ✓ Correctly places the cursor after deleting the previous line break (44ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (105ms)

    ✓ Backspace works on end of whitespace only lines (51ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Backspace works at beginning of file (234ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (219ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (102ms)

    ✓ Can perform insert command prefixed with count (46ms)

    ✓ Can perform append command prefixed with count (122ms)

    ✓ Can perform insert at start of line command prefixed with count (222ms)

    ✓ Can perform append to end of line command prefixed with count (118ms)

    ✓ Can perform change char (s) command prefixed with count (137ms)

    ✓ Can perform command prefixed with count with <C-[>

    ✓ Can handle 'o' with count (88ms)

    ✓ Can handle 'O' with count (101ms)

    ✓ Can handle backspace at beginning of line with all spaces (50ms)

    ✓ Can handle digraph insert (61ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (109ms)

    ✓ Can handle dw

    ✓ Can handle dw

    ✓ Can handle dw across lines (1) (71ms)

    ✓ Can handle dw across lines (2) (64ms)

    ✓ Can handle dd last line (85ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (66ms)

    ✓ Can handle 3dd (65ms)

    ✓ Can handle 3dd off end of document

    ✓ Can handle d2d (119ms)

    ✓ Can handle dd empty line

    ✓ Can handle ddp (120ms)

    ✓ Can handle 'de' (159ms)

    ✓ Can handle 'de' then 'de' again (70ms)

    ✓ Can handle 'db'

    ✓ Can handle 'db then 'db' again (81ms)

    ✓ Can handle 'dl' at end of line (55ms)

    ✓ Can handle 'dF' (142ms)

    ✓ Can handle 'dT' (48ms)

    ✓ Can handle 'd3' then <enter> (65ms)

    ✓ Can handle 'dj' (75ms)

    ✓ Can handle 'dk' (66ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (49ms)

    ✓ Can handle 'd]}' without deleting closing bracket (80ms)

    ✓ Can handle 'cw' (120ms)

    ✓ Can handle 'cw' without deleting following white spaces (136ms)

    ✓ Can handle 'c2w' (48ms)

    ✓ Can handle 'cw' without removing EOL (98ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (45ms)

    ✓ Can handle 'c]}' without deleting closing bracket (63ms)

    ✓ Can handle 's' (45ms)

    ✓ Can handle 'yiw' with correct cursor ending position (118ms)

    ✓ Can handle 'ciw' (101ms)

    ✓ Can handle 'ciw' on blanks (82ms)

    ✓ Can handle 'caw' (99ms)

    ✓ Can handle 'caw' on first letter (94ms)

    ✓ Can handle 'caw' on blanks (58ms)

    ✓ Can handle 'caw' on blanks (70ms)

    ✓ Can handle 'ci(' on first parentheses (54ms)

    ✓ Can handle 'ci(' with nested parentheses (75ms)

    ✓ Can handle 'ci(' backwards through nested parens (72ms)

    ✓ Can handle 'cib' on first parentheses (41ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (47ms)

    ✓ Can handle count prefixed 'ci)' (72ms)

    ✓ Can handle count prefixed 'ca)' (54ms)

    ✓ Can handle 'ca(' spanning multiple lines (87ms)

    ✓ Can handle 'cab' spanning multiple lines (50ms)

    ✓ Can handle 'ci{' spanning multiple lines (90ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (41ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (111ms)

    ✓ Can handle 'ci(' on the closing bracket (40ms)

    ✓ Can handle 'ciB' spanning multiple lines (47ms)

    ✓ will fail when ca( with no () (67ms)

    ✓ will fail when ca{ with no {} (137ms)

    ✓ will fail when caB with no {}

    ✓ Can handle 'ci[' spanning multiple lines (107ms)

    ✓ Can handle 'ci]' on first bracket (39ms)

    ✓ Can handle 'ca[' on first bracket (47ms)

    ✓ Can handle 'ca]' on first bracket (43ms)

    ✓ Can handle 'ci'' on first quote (78ms)

    ✓ Can handle 'ci'' inside quoted string (64ms)

    ✓ Can handle 'ci'' on closing quote (69ms)

    ✓ Can handle 'ci'' when string is ahead

    ✓ Can handle 'ci"' on opening quote (118ms)

    ✓ Can handle 'ci"' starting behind the quoted word (39ms)

    ✓ Can handle 'ca"' starting behind the quoted word (84ms)

    ✓ Can handle 'ca"' starting on the opening quote (59ms)

    ✓ Can handle 'ci"' with escaped quotes (42ms)

    ✓ Can handle 'ci"' with a single escaped quote (40ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (99ms)

    ✓ Can handle 'ci"' with an escaped backslash (40ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (81ms)

    ✓ Can handle 'ca"' starting on the closing quote (69ms)

    ✓ Can handle 'ci"' with complex escape sequences (74ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (152ms)

    ✓ will fail when ca" ahead of quoted string (128ms)

    ✓ Can handle 'ca`' inside word (49ms)

    ✓ can handle cj (75ms)

    ✓ can handle ck (107ms)

    ✓ can handle c2j (118ms)

    ✓ can handle c2k (73ms)

    ✓ can handle cj on last line (102ms)

    ✓ can handle ck on first line (74ms)

    ✓ can handle c2j on last line (53ms)

    ✓ can handle c2k on first line (116ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (42ms)

    ✓ Can handle 'daw' on word with trailing spaces (95ms)

    ✓ Can handle 'daw' on word with leading spaces (122ms)

    ✓ Can handle 'daw' on word with numeric prefix (71ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (74ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (56ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (82ms)

    ✓ Can handle 'daw' on end of word (140ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (47ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (42ms)

    ✓ Can handle 'daw' on word at beginning of file (40ms)

    ✓ Can handle 'daw' on word at beginning of line (39ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (64ms)

    ✓ Can handle 'daw' around word at end of line (66ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (91ms)

    ✓ Can handle 'daW' around word at whitespace (65ms)

    ✓ Can handle 'daW' on word with trailing spaces (51ms)

    ✓ Can handle 'daW' on word with leading spaces (102ms)

    ✓ Can handle 'daW' on word with numeric prefix (95ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (110ms)

    ✓ Can handle 'daW' on beginning of word (47ms)

    ✓ Can handle 'daW' on end of one line (97ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (39ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (72ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (57ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (68ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (49ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (109ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (46ms)

    ✓ Can handle 'diw' on word (47ms)

    ✓ Can handle 'diw' on word with numeric prefix

    ✓ Can handle 'diw' on trailing spaces at the end of line (83ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (97ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (262ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (121ms)

    ✓ Can handle 'diW' on word with trailing spaces (63ms)

    ✓ Can handle 'diW' on word with leading spaces (59ms)

    ✓ Can handle 'diW' on word with numeric prefix (55ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (87ms)

    ✓ Can handle 'diW' on beginning of word (41ms)

    ✓ Can handle d} (62ms)

    ✓ Can handle y} at beginning of line (51ms)

    ✓ Select sentence with trailing spaces (108ms)

    ✓ Select sentence with leading spaces (157ms)

    ✓ Select inner sentence with trailing spaces (66ms)

    ✓ Select inner sentence with leading spaces (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Select spaces between sentences (255ms)

    ✓ Can handle 'df' (66ms)

    ✓ Can handle 'dt' (194ms)

    ✓ Can handle backspace (102ms)

    ✓ Can handle backspace across lines

    ✓ Can handle A and backspace

    ✓ Can handle 'yy' without changing cursor position (39ms)

    ✓ Can handle 'P' after 'yy' (65ms)

    ✓ Can handle 'p' after 'yy' (83ms)

    ✓ Can handle 'P' after 'Nyy' (53ms)

    ✓ Can handle 'p' after 'Nyy'

    ✓ Can handle 'p' after 'yy' with correct cursor position (63ms)

    ✓ Can handle 'gp' after 'yy' (80ms)

    ✓ Can handle 'gp' after 'Nyy'

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (61ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (50ms)

    ✓ Can handle 'gP' after 'yy' (86ms)

    ✓ Can handle 'gP' after 'Nyy' (71ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (98ms)

    ✓ Can handle ']p' after yy (40ms)

    ✓ Can handle ']p' after 'Nyy' (58ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (89ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (77ms)

    ✓ Can handle '[p' after yy (108ms)

    ✓ Can handle '[p' after 'Nyy' (211ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (85ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (46ms)

    ✓ Can handle 'p' after y'a (52ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (67ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (76ms)

    ✓ Can handle pasting in visual mode over selection (103ms)

    ✓ Can repeat w

    ✓ Can repeat p (47ms)

    ✓ I works correctly (88ms)

    ✓ gI works correctly (90ms)

    ✓ gi works correctly (54ms)

    ✓ `. works correctly (99ms)

    ✓ '. works correctly (82ms)

    ✓ g; works correctly (90ms)

    ✓ g, works correctly (108ms)

    ✓ g_ works correctly (39ms)

    ✓ 3g_ works correctly (79ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (254ms)

    ✓ gq handles spaces before single line comments correctly (217ms)

    ✓ gq handles tabs before single line comments correctly (270ms)

    ✓ Can handle space (66ms)

    ✓ Can handle space

    ✓ Undo 1 (100ms)

    ✓ Undo 2 (80ms)

    ✓ Undo cursor (97ms)

    ✓ Undo cursor 2 (131ms)

    ✓ Undo cursor 3 (117ms)

    ✓ Undo with movement first (81ms)

    ✓ Can handle 'U' (71ms)

    ✓ Can handle 'U' for multiple changes (102ms)

    ✓ Can handle 'U' for new line below (127ms)

    ✓ Can handle 'U' for new line above (158ms)

    ✓ Can handle 'U' for consecutive changes only (178ms)

    ✓ Can handle 'u' to undo 'U' (63ms)

    ✓ Can handle 'U' to undo 'U' (55ms)

    ✓ Can handle 'u' after :s/abc/def (140ms)

    ✓ Redo (143ms)

    ✓ Redo (149ms)

    ✓ Redo (71ms)

    ✓ Can handle u (42ms)

    ✓ Can handle guw

    ✓ Can handle gUw (112ms)

    ✓ Can handle u over line breaks (41ms)

    ✓ can handle s in visual mode (141ms)

    ✓ can handle p with selection (114ms)

    ✓ can handle P with selection (179ms)

    ✓ can handle p in visual to end of line (77ms)

    ✓ can repeat backspace twice (84ms)

    ✓ can delete linewise with d2G (60ms)

    ✓ can delete with + motion and count (54ms)

    ✓ can delete with - motion and count (54ms)

    ✓ can dE correctly (59ms)

    ✓ can dE correctly (84ms)

    ✓ can dE correctly (70ms)

    ✓ can ctrl-a correctly behind a word (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (218ms)

    ✓ can ctrl-a on word (167ms)

    ✓ can ctrl-a on a hex number (225ms)

    ✓ can ctrl-a on decimal (125ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a with numeric prefix (222ms)

    ✓ can ctrl-a on a decimal (140ms)

    ✓ can ctrl-a on an octal  (230ms)

    ✓ Correctly increments in the middle of a number (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-x correctly behind a word (225ms)

    ✓ can ctrl-a on an number with word before  (179ms)

    ✓ can ctrl-a on an number with word before and after  (221ms)

    ✓ can ctrl-x on a negative number with word before and after  (186ms)

    ✓ can ctrl-a properly on multiple lines (261ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (191ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (209ms)

    ✓ can <C-a> on word with - in front of it (180ms)

    ✓ can do Y (48ms)

    ✓ Can do S (101ms)

    ✓ / does not affect mark (66ms)

    ✓ / can search with regex (80ms)

    ✓ / can search with newline (73ms)

    ✓ / can search through multiple newlines (152ms)

    ✓ / matches ^ per line (123ms)

    ✓ / matches $ per line (46ms)

    ✓ Can search for forward slash (112ms)

    ✓ Can search backward for question mark (39ms)

    ✓ /\c forces case insensitive search (123ms)

    ✓ /\C forces case sensitive search (153ms)

    ✓ <BS> deletes the last character in search in progress mode (195ms)

    ✓ <S-BS> deletes the last character in search in progress mode (202ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <C-h> deletes the last character in search in progress mode (221ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (232ms)

    ✓ Ignores cit on a non-matching tag (138ms)

    ✓ Ignores cit on a nested tag (71ms)

    ✓ Can do cit on a tag with an attribute tag (45ms)

    ✓ Can do cat on a matching tag (75ms)

    ✓ Can do cit on a multiline tag (46ms)

    ✓ Can do cit on a multiline tag with nested tags (69ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (83ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (58ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (88ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (83ms)

    ✓ can do cit with self closing tags (60ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Respects indentation with cc (233ms)

    ✓ Resets cursor to indent end with cc (90ms)

    ✓ can handle 'cc' on empty line (123ms)

    ✓ cc copies linewise (39ms)

    ✓ Indent current line with correct Vim Mode (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <Esc> and do nothing (364ms)

    ✓ Can handle # on consecutive words (191ms)

    ✓ Can handle # on skipped words (99ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (231ms)

    ✓ cc on whitespace-only treats whitespace as indent (153ms)

    ✓ Can do cai (192ms)

    ✓ Can do cii (59ms)

    ✓ Can do caI (87ms)

    ✓ Can do dai (60ms)

    ✓ Can do dii

    ✓ Can do daI (91ms)

    ✓ `] go to the end of the previously operated or put text (63ms)

    ✓ '] go to the end of the previously operated or put text (99ms)

    ✓ `[ go to the start of the previously operated or put text (78ms)

    ✓ '[ go to the start of the previously operated or put text (80ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (54ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (99ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (53ms)

    can handle gn

      ✓ gn selects the next match text (191ms)

      ✓ gn selects the current word at |hello (165ms)

      ✓ gn selects the current word at h|ello (216ms)

      ✓ gn selects the current word at hel|lo (190ms)

      ✓ gn selects the current word at hell|o (160ms)

      ✓ gn selects the next word at hello| (303ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (132ms)

      ✓ dgn deletes the current word when cursor is at |hello (196ms)

      ✓ dgn deletes the current word when cursor is at h|ello (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at hel|lo (245ms)

      ✓ dgn deletes the current word when cursor is at hell|o (110ms)

      ✓ dgn deletes the next word when cursor is at hello| (276ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (179ms)

      ✓ cgn deletes the current word when cursor is at |hello (213ms)

      ✓ cgn deletes the current word when cursor is at h|ello (76ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (218ms)

      ✓ cgn deletes the current word when cursor is at hell|o (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next word when cursor is at hello| (246ms)

    can handle gN

      ✓ gN selects the previous match text (179ms)

      ✓ gN selects the current word at hell|o (260ms)

      ✓ gN selects the current word at hel|lo (148ms)

      ✓ gN selects the current word at h|ello (185ms)

      ✓ gN selects the current word at |hello (188ms)

      ✓ gN selects the previous word at | hello (164ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (61ms)

      ✓ dgN deletes the current word when cursor is at hell|o (124ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (125ms)

      ✓ dgN deletes the current word when cursor is at h|ello (62ms)

      ✓ dgN deletes the current word when cursor is at |hello (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the previous word when cursor is at | hello (256ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (196ms)

      ✓ cgN deletes the current word when cursor is at hell|o (196ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (219ms)

      ✓ cgN deletes the current word when cursor is at h|ello (187ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the current word when cursor is at |hello (239ms)

      ✓ cgN deletes the previous word when cursor is at | hello (215ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (185ms)

    ✓ Can activate with R from Normal mode (75ms)

    ✓ Can handle R (210ms)

    ✓ Can handle R past current line (194ms)

    ✓ Can handle R and exit Replace Mode (216ms)

    ✓ Can handle R across lines (80ms)

    ✓ Can handle R across lines and exit Replace Mode (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle R with {count} (241ms)

    ✓ Can handle backspace (155ms)

    ✓ Can handle backspace (132ms)

    ✓ Can handle backspace across lines (260ms)

    ✓ Can handle arrows (104ms)

    ✓ Can handle . (102ms)

    ✓ Can handle . across lines (129ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (282ms)

    ✓ Can handle wd (59ms)

    ✓ Can handle x (73ms)

    ✓ Can handle x across a selection (70ms)

    ✓ Can do vwd in middle of sentence (131ms)

    ✓ Can do vwd in middle of sentence (83ms)

    ✓ Can do vwd multiple times (138ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (115ms)

    ✓ Can handle H key

    ✓ Can handle backspace key (59ms)

    ✓ handles case where we delete over a newline (306ms)

    ✓ handles change operator (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vat on multiple matching tags (235ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (177ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (230ms)

    ✓ Repeat-prefixed vat does not bleed below (169ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (44ms)

    ✓ Can do vi) on a matching parenthesis (146ms)

    ✓ Can do vi) on multiple matching parens (163ms)

    ✓ Can do va) on a matching parenthesis (105ms)

    ✓ Can do va) on multiple matching parens (57ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (192ms)

    ✓ Repeat-prefixed va) does not bleed below (178ms)

    ✓ Can do va} on a matching bracket as first character

    ✓ Can do va} on multiple matching brackets (50ms)

    ✓ Can do vi( on a matching bracket near first character (88ms)

    ✓ Can do vi{ on outer pair of nested braces (48ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (43ms)

    ✓ Can do va] on multiple matching brackets (112ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (193ms)

    ✓ Repeat-prefixed vaf does not bleed below (199ms)

    ✓ vaf only expands to enclosing pairs (51ms)

    ✓ Can use . to repeat indent in visual (106ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v_x to delete to first char (231ms)

    ✓ Can do vg_x to delete to last char with no EOL (178ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (82ms)

    ✓ Can do v$x to delete to last char including EOL (42ms)

    ✓ Can do gv to reselect previous selection (172ms)

    Vim's EOL handling is weird

      ✓ delete through eol (63ms)

      ✓ join 2 lines by deleting through eol (128ms)

      ✓ d$ doesn't delete whole line (49ms)

      ✓ vd$ does delete whole line (54ms)

      ✓ Paste over selection copies the selection (106ms)

      ✓ Paste over selection copies the selection linewise (69ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (74ms)

      ✓ Can handle <down> key (68ms)

      ✓ Can handle <left> key (176ms)

      ✓ Can handle <right> key (204ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (188ms)

      ✓ Can handle 'gj' (218ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (61ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (230ms)

      ✓ Can handle 'vawd' on word with leading spaces (178ms)

      ✓ Can handle 'vawd' on word with numeric prefix (264ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (234ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (131ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (91ms)

      ✓ Can handle 'vaWd' on word with leading spaces (271ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (187ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (190ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (169ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (231ms)

      ✓ Can handle 'vaWd' on word with leading spaces (182ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (101ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (139ms)

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (230ms)

      ✓ Can handle 'vawd' on word with trailing spaces (171ms)

      ✓ Can handle 'vawd' on word with leading spaces (129ms)

      ✓ Can handle 'vawd' on word with numeric prefix (196ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (211ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (160ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (239ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (233ms)

      ✓ Can handle 'vaWd' on word with leading spaces (159ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (235ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (134ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'Y' in visual mode (246ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (183ms)

      ✓ Select sentence with leading spaces in visual mode (230ms)

      ✓ Select multiple sentences in visual mode (168ms)

    handles is in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select inner sentence with trailing spaces in visual mode (234ms)

      ✓ Select inner sentence with leading spaces in visual mode (184ms)

      ✓ Select spaces between sentences in visual mode (151ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (222ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do vat on a matching tag (142ms)

    handles replace in visual mode

      ✓ Can do a single line replace (123ms)

      ✓ Can do a multi line replace (46ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (82ms)

      ✓ D deletes the current line (219ms)

    handles indent blocks in visual mode

      ✓ Can do vai (171ms)

      ✓ Can do vii (55ms)

      ✓ Doesn't naively select the next line (98ms)

      ✓ Searches backwards if cursor line is empty (200ms)

      ✓ Can do vaI (154ms)

    visualstar

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with * (226ms)

      ✓ Works with # (53ms)

    search works in visual mode

      ✓ Works with / (52ms)

      1) Works with ?

      ✓ Selects correct range (345ms)

    X will delete linewise

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (233ms)

      ✓ normal selection (131ms)

    C will delete linewise

      ✓ normal selection (105ms)

      ✓ normal selection (218ms)

    R will delete linewise

      ✓ normal selection (187ms)

      ✓ normal selection (182ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (170ms)

      ✓ upward selection (80ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (95ms)

      ✓ multiline indent bottom up selection (45ms)

      ✓ repeat multiline indent top down selection (112ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent bottom up selection (239ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (96ms)

      ✓ multiline outdent bottom up selection (447ms)

      ✓ repeat multiline outdent top down selection (71ms)

      ✓ repeat multiline outdent bottom up selection (187ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (163ms)

    vi{ will go to end of second to last line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ select (290ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode (50ms)

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode (43ms)

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (339ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gv selects the last pasted text (which is longer than original) (401ms)

      ✓ gv selects the last pasted text (multiline) (174ms)

    can handle gn

      ✓ gn selects the next match text (170ms)

      ✓ gn selects the current word at |hello (199ms)

      ✓ gn selects the current word at h|ello (156ms)

      ✓ gn selects the current word at hel|lo (246ms)

      ✓ gn selects the next word at hell|o (136ms)

      ✓ gn selects the next word at hello| (218ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (78ms)

      ✓ multiline insert from top down selection (194ms)

      ✓ skips blank lines (155ms)

    can append text with A

      ✓ multiline append from bottom up selection (47ms)

      ✓ multiline append from top down selection (73ms)

      ✓ skips blank lines

    Can handle u/gu, U/gU

      ✓ U/gU on single character (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ U/gU across a selection (253ms)

      ✓ U/gU across a selection (reverse) (184ms)

      ✓ u/gu on single character (212ms)

      ✓ u/gu across a selection (224ms)

      ✓ u/gu across a selection (reverse) (176ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (146ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (238ms)

    ✓ Can handle I forward select (195ms)

    ✓ Can handle I backwards select (390ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (243ms)

    ✓ Can handle c forward select (201ms)

    ✓ Can handle c backwards select (52ms)

    ✓ Can handle C (94ms)

    ✓ Can do a multi line replace (45ms)

    ✓ Can handle 'D' (95ms)

    ✓ Can handle 'gj' (55ms)

    ✓ Properly add to end of lines j then $ (95ms)

    ✓ Properly add to end of lines $ then j (60ms)

    ✓ o works in visual block mode (97ms)

    Non-darwin <C-c> tests

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ <C-c> copies and sets mode to normal (109ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (88ms)

    ✓ Can handle wd (70ms)

    ✓ Can handle x (85ms)

    ✓ Can handle x across a selection (71ms)

    ✓ Can do vwd in middle of sentence (114ms)

    ✓ Can do vwd in middle of sentence (237ms)

    ✓ Can do vwd multiple times (112ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (86ms)

    ✓ handles case where we delete over a newline (97ms)

    ✓ handles change operator (82ms)

    ✓ Vp updates register content (69ms)

    ✓ Vp does not append unnecessary newlines (first line) (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (231ms)

    ✓ Vp does not append unnecessary newlines (last line) (176ms)

    Vim's EOL handling is weird

      ✓ delete through eol (70ms)

      ✓ join 2 lines by deleting through eol (52ms)

      ✓ d$ doesn't delete whole line (48ms)

      ✓ vd$ does delete whole line (44ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (69ms)

      ✓ Can handle <down> key (70ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (69ms)

      ✓ Can handle 'gj' (71ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle d key (229ms)

      ✓ Can handle d key

      ✓ Can handle d key

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (106ms)

      ✓ Can do a multi visual line replace (39ms)

      ✓ Can do a multi visual line replace from the bottom up (111ms)

    search works in visual line mode

      ✓ Works with / (44ms)

      ✓ Works with ? (55ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (162ms)

    replace text in linewise visual-mode with linewise register content

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ yyVp does not change the content but changes cursor position (212ms)

      ✓ linewise visual put works also in the end of document (125ms)

      ✓ gv selects the last pasted text (which is shorter than original) (222ms)

      ✓ gv selects the last pasted text (which is longer than original) (205ms)

      ✓ gv selects the last pasted text (multiline) (108ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (49ms)

      ✓ multiline insert from top down selection (81ms)

      ✓ skips blank lines (42ms)

    can append text with A

      ✓ multiline append from bottom up selection (60ms)

      ✓ multiline append from top down selection (73ms)

      ✓ skips blank lines (71ms)

  Mode Normal

    ✓ Can handle 'x' (67ms)

    ✓ Can handle 'Nx' (57ms)

    ✓ Can handle 'Nx' and paste (82ms)

    ✓ Can handle 'x' at end of line (52ms)

    ✓ Can handle 'Ns' (86ms)

    ✓ Can handle 'Ns' at end of line (54ms)

    ✓ Can handle '<Del>' (85ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (42ms)

    ✓ Can handle '<Del>' at end of line (130ms)

    ✓ Can handle 'cc' (163ms)

    ✓ Can handle 'Ncc' (70ms)

    ✓ Can handle 'yy' (66ms)

    ✓ Can handle 'D' (82ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' on empty lines (217ms)

    ✓ Can handle 'DD' (40ms)

    ✓ Can handle 'C' (69ms)

    ✓ Can handle 'NC' (295ms)

    ✓ Can handle 'NC' and put (201ms)

    ✓ Can handle 'r' (60ms)

    ✓ Can handle '<Count>r' (77ms)

    ✓ Can handle '<Count>r'

    ✓ Can handle 'r' after 'dd' (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'r
' (224ms)

    ✓ Can handle '<Count>r
' (181ms)

    ✓ Can handle 'J' once (62ms)

    ✓ Can handle 'J' twice (77ms)

    ✓ Can handle 'J' with empty last line (70ms)

    ✓ Can handle 'J's with multiple empty last lines (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with leading white space on next line (466ms)

    ✓ Can handle 'J' with only white space on next line

    ✓ Can handle 'J' with TWO indented lines (48ms)

    ✓ Can handle 'J' with ')' first character on next line (81ms)

    ✓ Can handle 'J' with a following delete (48ms)

    ✓ Can handle 'J' in Visual Line mode (88ms)

    ✓ Can handle 'gJ' once

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (109ms)

    ✓ Can handle '~'

    ✓ Can handle 'g~{motion}' (46ms)

    ✓ Can handle '<BS>' in insert mode (59ms)

    ✓ Can handle undo with P (94ms)

    ✓ Can handle 'ge' in multiple lines case1 (46ms)

    ✓ Can handle 'ge' in multiple lines case2 (69ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (214ms)

    ✓ Can repeat '~' with dot (116ms)

    ✓ Can repeat 'x'

    ✓ Can repeat 'J' (104ms)

    ✓ Can handle dot with A (75ms)

    ✓ Can handle dot with I (87ms)

    ✓ Can repeat actions that require selections (66ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (93ms)

    ✓ Can repeat insert change and '<C-t>' (81ms)

    ✓ Can repeat change by `<C-a>` (69ms)

    ✓ Only one arrow key can be repeated in Insert Mode (100ms)

    ✓ Cached content change will be cleared by arrow keys (79ms)

  Matching Bracket (%)

    ✓ before opening parenthesis

    ✓ inside parenthesis (77ms)

    ✓ nested parenthesis beginning (38ms)

    ✓ nested parenthesis end (104ms)

    ✓ nested bracket and parenthesis beginning

    ✓ nested bracket, parenthesis, braces beginning (116ms)

    ✓ nested bracket, parenthesis, braces end (84ms)

    ✓ parentheses after > (60ms)

    ✓ parentheses after " (84ms)

  Motions in Normal Mode

    ✓ Can handle [( (54ms)

    ✓ Can handle nested [( (94ms)

    ✓ Can handle <number>[(

    ✓ Can handle [( and character under cursor exclusive (136ms)

    ✓ Can handle ]) (209ms)

    ✓ Can handle nested ]) (189ms)

    ✓ Can handle <number>]) (111ms)

    ✓ Can handle ]) and character under cursor exclusive

    ✓ Can handle [{ (51ms)

    ✓ Can handle nested [{ (66ms)

    ✓ Can handle <number>[{

    ✓ Can handle [{ and character under cursor exclusive (111ms)

    ✓ Can handle ]}

    ✓ Can handle nested ]} (106ms)

    ✓ Can handle <number>]} (45ms)

    ✓ Can handle ]} and character under cursor exclusive (182ms)

    ✓ Can handle 'ge' (112ms)

    ✓ Can handle 'gg'

    ✓ Can handle 'gg' to first non blank char on random line (106ms)

    ✓ Can handle 'gg' to first non blank char on first line (80ms)

    ✓ 'gg' obeys startofline (63ms)

    ✓ Retain same column when moving up/down (83ms)

    ✓ Can handle <enter> (54ms)

    ✓ $ always keeps cursor on EOL (97ms)

    ✓ Can handle $ with a count (43ms)

    ✓ Can handle $ with a count at end of file (97ms)

    ✓ Can handle <End> with a count

    ✓ Can handle <D-right> with a count (99ms)

    ✓ Can handle 'f' (38ms)

    ✓ Can handle 'f' twice (46ms)

    ✓ Can handle 'f' with <tab> (86ms)

    ✓ Can handle 'f' and find back search (44ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' (110ms)

    ✓ Can handle 'F' twice (73ms)

    ✓ Can handle 'F' and find back search (50ms)

    ✓ Can handle 'f' and multiple back searches (103ms)

    ✓ Can handle 't' (41ms)

    ✓ Can handle 't' twice (50ms)

    ✓ Can handle 't' and find back search (89ms)

    ✓ Can handle 'T' (54ms)

    ✓ Can handle 'T' twice (89ms)

    ✓ Can handle 'T' and find back search

    ✓ Can run a forward search (122ms)

    ✓ Can run a forward and find next search

    ✓ Can run a forward and find previous search from end of word (42ms)

    ✓ Can run a reverse search (69ms)

    ✓ Can run a reverse and find next search (64ms)

    ✓ cancelled search reverts to previous search state (49ms)

    ✓ Backspace on empty search cancels (76ms)

    ✓ Search offsets: b does nothing (75ms)

    ✓ Search offsets: b2 goes 2 to the right

    ✓ Search offsets: b+3 goes 3 to the right (91ms)

    ✓ Search offsets: e goes to the end (41ms)

    ✓ Search offsets: character offset goes across line boundaries (82ms)

    ✓ Search offsets: 2 goes 2 down (87ms)

    ✓ Search offsets: -2 goes 2 up (42ms)

    ✓ maintains column position correctly (75ms)

    ✓ maintains column position correctly with $ (84ms)

    ✓ Can handle G 

    ✓ Can handle G with number prefix (68ms)

    ✓ Can handle G with number prefix (77ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix

    ✓ Can handle 0 (52ms)

    ✓ Can handle 0 as part of a repeat (91ms)

    ✓ Can handle g* (38ms)

    ✓ Can handle g*n (84ms)

    ✓ Can handle *

    ✓ Can handle ** (112ms)

    ✓ Can handle # on whitespace (41ms)

    ✓ Can handle # on EOL (50ms)

    ✓ Can handle g# (63ms)

    ✓ Can handle g#n (109ms)

    ✓ Can handle # (65ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (50ms)

    ✓ * adds to search history (67ms)

    ✓ # adds to search history (95ms)

    ✓ Can handle | (88ms)

    ✓ Can handle <number> | (62ms)

    ✓ Can handle + (82ms)

    ✓ Can handle + indent (49ms)

    ✓ Can handle + with count prefix (68ms)

    ✓ Can handle -

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix (221ms)

    ✓ Can handle g_ (43ms)

    ✓ Can handle g_ with count prefix

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key

    ✓ Can handle <right> key

    ✓ Can handle 'gk'

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down
    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character
    word right
      ✓ move to word right
      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)
    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line
    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward
      ✓ next concrete sentence
      ✓ next sentence that ends with paragraph ending
      ✓ next sentence when cursor is at the end of previous paragraph
      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (42ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (45ms)

      insert mode

        ✓ <left> wraps to previous line (74ms)

        ✓ <right> once goes to end of line (49ms)

        ✓ <right> twice wraps to next line (76ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line

        ✓ l does not wrap to next line (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <left> does not wrap to previous line (216ms)

        ✓ <right> does not wrap to next line (62ms)

      insert mode

        ✓ <left> does not wrap to previous line (130ms)

        ✓ <right> does not wrap to next line (215ms)

    wrapscan enabled

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ search wraps around the end of the file (528ms)

      ✓ search wraps around the start of the file (42ms)

    wrapscan disabled

      ✓ search stops at the end of the file

      ✓ search stops at the start of the file (114ms)

  Multicursor

    ✓ can add multiple cursors below (67ms)

    ✓ can add multiple cursors above (212ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip
    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (326ms)

    ✓ gcj comments in current and next line (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (408ms)

    ✓ block comment in Visual Mode (131ms)

    ✓ comment in visual line mode (166ms)

    ✓ comment in visual block mode (194ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (317ms)

    ✓ =$ formats entire line (241ms)

    ✓ =j formats two lines (164ms)

    ✓ 3=k formats three lines (141ms)

    ✓ =gg formats to top of file (251ms)

    ✓ =G formats to bottom of file (74ms)

    ✓ =ip formats paragraph (172ms)

    ✓ format in visual mode (101ms)

  put operator

    ✓ basic put test (187ms)

    ✓ test yy end of line (104ms)

    ✓ test yy first line (57ms)

    ✓ test yy middle line (57ms)

    ✓ test yy with correct positon movement (72ms)

    ✓ test visual block single line yank p (64ms)

    ✓ test visual block single line yank P

    ✓ test visual block single line delete p (56ms)

    ✓ test visual block single line delete P (53ms)

  rot13 operator

    2) rot13() unit test

    ✓ g?j works (134ms)

    ✓ g? in visual mode works (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    3) g? in visual line mode works

    4) g? in visual block mode works

  shift operator

    ✓ basic shift left test (69ms)

    ✓ shift left goto end test (72ms)

    ✓ shift left goto line test (54ms)

    ✓ shift right goto end test (79ms)

    ✓ shift right goto line test (50ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (40ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (92ms)

      ✓ step to Camel word

      ✓ step to CAP word (125ms)

      ✓ step after CAP word (95ms)

      ✓ step from middle of word to Camel word (71ms)

      ✓ step to number word (90ms)

      ✓ step to operator word (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (153ms)

      ✓ step to operator and then over (183ms)

    handles <leader>w for underscore_var

      ✓ step to _word (206ms)

      ✓ step over whitespace to word (87ms)

      ✓ step from inside word to _word (47ms)

      ✓ step form _word to number (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from nubmer word to _word (141ms)

      ✓ step from in whitespace to word (67ms)

      ✓ step in ALL_CAPS_WORD (83ms)

    handles d<leader>w

      ✓ delete from start of camelWord (51ms)

      ✓ delete from middle of camelWord (57ms)

      ✓ delete from start of CamelWord (39ms)

      ✓ delete two words from camelWord (94ms)

      ✓ delete from start of underscore_word

      ✓ delete from middle of underscore_word (53ms)

      ✓ delete two words from camel_word (64ms)

    handles di<leader>w

      ✓ delete from start of camelWord (69ms)

      ✓ delete from middle of camelWord (49ms)

      ✓ delete from start of CamelWord (65ms)

      ✓ delete two words from camelWord (43ms)

      ✓ delete from start of underscore_word (75ms)

      ✓ delete from middle of underscore_word (49ms)

      ✓ delete two words from camel_word (113ms)

    handles <leader>b

      ✓ back from middle of word (93ms)

      ✓ back over whitespace to camelWord (57ms)

      ✓ back twice over operator (120ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (161ms)

      ✓ from middle to end of underscore_word (206ms)

      ✓ twice to end of word over operator (126ms)

  easymotion plugin

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle s move (171ms)

    ✓ Can handle 2s move (56ms)

    ✓ Can handle f move (52ms)

    ✓ Can handle 2f move (454ms)

    ✓ Can handle F move (191ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2F move (224ms)

    ✓ Can handle t move (155ms)

    ✓ Can handle bd-t move (49ms)

    ✓ Can handle 2t move (91ms)

    ✓ Can handle bd-t2 move (60ms)

    ✓ Can handle T move (50ms)

    ✓ Can handle 2T move (81ms)

    ✓ Can handle w move (43ms)

    ✓ Can handle bd-w move (86ms)

    ✓ Can handle b move (212ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle e move (43ms)

    ✓ Can handle bd-e move (66ms)

    ✓ Can handle ge move (56ms)

    ✓ Can handle n-char move (67ms)

    ✓ Can handle j move (91ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle k move (232ms)

    ✓ Can handle bd-jk move (1) (196ms)

    ✓ Can handle bd-jk move (2) (212ms)

    ✓ Can handle lineforward move (1) (108ms)

    ✓ Can handle lineforward move (2) (198ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (177ms)

    ✓ Can handle searching for backslash (\) (138ms)

    ✓ Can handle searching for carat (^) (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for dot (.) (228ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (46ms)

    ✓ Replaces within inner Word (252ms)

    ✓ Replaces within '' (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces within '' including spaces (245ms)

    ✓ Replaces within () (162ms)

    ✓ Replaces within () including spaces (130ms)

    ✓ Replaces within a paragraph (233ms)

    ✓ Replaces using a specified register (200ms)

    ✓ Replaces within {} over multiple lines (182ms)

    ✓ Replaces a multiline register within {} over multiple lines (79ms)

    ✓ Replaces a multiline register within {} over multiple lines (59ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (219ms)

    ✓ grr replaces the entire line with the register (65ms)

    ✓ grr can replace multiple lines (58ms)

    ✓ Replaces in visual mode (54ms)

    ✓ Replaces in visual mode using a specified register (86ms)

    ✓ Replaces in visual line mode (62ms)

    ✓ grj is linewise (81ms)

  sneak plugin

    ✓ Can handle s motion (91ms)

    ✓ Can handle S motion (51ms)

    ✓ Can handle <operator>z motion (66ms)

    ✓ Can handle <operator>Z motion (87ms)

    ✓ Can handle s; motion (73ms)

    ✓ Can handle s, motion (44ms)

    ✓ Can handle S; motion (40ms)

    ✓ Can handle S, motion (72ms)

    ✓ Can handle single letter s motion

    ✓ Can handle single letter S motion (45ms)

    ✓ Can handle single letter <operator>z motion (78ms)

    ✓ Can handle single letter <operator>Z motion (55ms)

    ✓ Can handle single letter s; motion (90ms)

    ✓ Can handle single letter s, motion

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter S; motion (321ms)

    ✓ Can handle single letter S, motion (58ms)

    ✓ Can handle multiline single char <number>s motion (62ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (130ms)

    ✓ 'ysiw(' surrounds word with space (135ms)

    ✓ 'ysw)' surrounds word without space (203ms)

    ✓ 'ysw(' surrounds word with space (87ms)

    ✓ 'ysaw)' surrounds word without space (70ms)

    ✓ 'ysaw(' surrounds word with space (77ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (136ms)

    ✓ 'ysiw<' surrounds word with tags (83ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (94ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (190ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (113ms)

    ✓ change surround (110ms)

    ✓ change surround with two pairs of quotes (110ms)

    ✓ change surround with two pairs of parens (176ms)

    ✓ change surround with alias (71ms)

    ✓ change surround to tags (197ms)

    ✓ delete surround (126ms)

    ✓ delete surround with quotes (128ms)

    ✓ delete surround with nested of quotes (203ms)

    ✓ delete surround with inconsistent quotes (134ms)

    ✓ delete surround with mixed quotes (78ms)

    ✓ delete surround with empty quotes cursor at start (195ms)

    ✓ delete surround with empty quotes cursor at end (70ms)

    ✓ don't delete surround if cursor is after closing match (108ms)

    ✓ delete surround if cursor is before opening match (102ms)

    ✓ delete surround with two pairs of parens (190ms)

    ✓ delete surround with alias (77ms)

    ✓ delete surround with tags (190ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (178ms)

    ✓ changing brackets with surround works again (201ms)

    ✓ change surround with tags that contain an attribute and preserve them (117ms)

    ✓ change surround with tags that contain an attribute and remove them (103ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (236ms)

    ✓ Can use two registers together (86ms)

    ✓ Can use black hole register (169ms)

    ✓ System clipboard works with chinese characters (52ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yank stores text in Register '0' (518ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (108ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (136ms)

    ✓ Register '1'-'9' stores delete content (140ms)

    ✓ "A appends linewise text to "a (147ms)

    ✓ "A appends character wise text to "a (176ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (131ms)

    ✓ Small deletion using Del is stored in small delete register (128ms)

    ✓ Small deletion using X is stored in small delete register (116ms)

    ✓ Search register (/) is set by forward search (183ms)

    ✓ Search register (/) is set by backward search (215ms)

    ✓ Search register (/) is set by star search (168ms)

    ✓ Command register (:) is set by command line (78ms)

    ✓ Read-only registers cannot be written to (124ms)

    clipboard

      ✓ Can access '*' (clipboard) register (173ms)

      ✓ Can access '+' (clipboard) register (207ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat reversed F<character> (370ms)

    ✓ Can repeat t<character> (215ms)

    ✓ Can repeat N times reversed t<character> (189ms)

  sentence motion
    [count] sentences backward

      ✓ move one sentence backward (163ms)

      ✓ move one sentence backward (92ms)

      ✓ move [count] sentences backward (188ms)

      ✓ move one sentence backward single line - middle (160ms)

      ✓ move one sentence backward no space (184ms)

      ✓ move one sentence backward no space - middle (61ms)

      ✓ move one sentence backward - multiline (98ms)

      ✓ move one sentence backward - multiline - period (162ms)

      ✓ move one sentence backward - multiline - previous line (158ms)

      ✓ move one sentence backward - multiline - previous line - period (202ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line
    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1301 passing (4m)
  4 pending

  4 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:920:5)

  2) rot13 operator
       rot13() unit test:

      AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
+ actual - expected

+ 'n'
- 'nopqrstuvwxyzabcdefghijklm'
      + expected - actual

      -n
      +nopqrstuvwxyzabcdefghijklm
      
      at Context.<anonymous> (test/operator/rot13.test.ts:25:14)

  3) rot13 operator
       g? in visual line mode works:

      Cursor CHARACTER position is wrong.
      + expected - actual

      -0
      +1
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:43:3)

  4) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=drs. Actual=qrs.
      + expected - actual

      -qrs
      +drs
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:50:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T04:37:26.293Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive
    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive
    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative
    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line (38ms)

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (42ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (71ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (71ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (46ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history (38ms)

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (52ms)

  command-line lexer

    ✓ can lex empty string

    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (984ms)

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (529ms)

    ✓ :smile editor contains smile text (535ms)

  Basic sort

    ✓ Sort whole file, asc (68ms)

    ✓ Sort whole file, asc, ignoreCase (76ms)

    ✓ Sort whole file, dsc (84ms)

    ✓ Sort whole file, dsc, ignoreCase (65ms)

    ✓ Sort range, asc (105ms)

    ✓ Sort range, asc, ignoreCase (100ms)

    ✓ Sort range, dsc (83ms)

    ✓ Sort range, dsc, ignoreCase (104ms)

    ✓ Sort whole file, asc, unique (94ms)

  Horizontal split

    ✓ :sp creates a second split (63ms)

    ✓ :split creates a second split (59ms)

    ✓ :new creates a second split (209ms)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once

    ✓ Replace with `g` flag (42ms)

    ✓ Replace with flags AND count (123ms)

    ✓ Replace with `c` flag

    ✓ Replace with `gc` flag (54ms)

    ✓ Replace across all lines (60ms)

    ✓ Replace on specific single line (70ms)

    ✓ Replace on current line using dot (49ms)

    ✓ Replace single relative line using dot and plus (114ms)

    ✓ Replace across specific line range (108ms)

    ✓ Replace across relative line range using dot, plus, and minus (113ms)

    ✓ Replace across relative line range using numLines+colon shorthand (81ms)

    ✓ Repeat replacement across relative line range (85ms)

    ✓ Replace with range AND count but no flags (80ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (76ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (80ms)

    ✓ Undocumented: trailing operators use 1 as RHS (68ms)

    ✓ Replace specific single equal lines (42ms)

    ✓ Replace current line with no active selection (70ms)

    ✓ Replace text in selection (65ms)

    ✓ Substitute support marks (61ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line

      ✓ Replace with `g` flag inverts global flag

      ✓ Replace with `c` flag inverts global flag (57ms)

      ✓ Replace multiple lines (71ms)

      ✓ Replace across specific lines (53ms)

      ✓ Replace current line with no active selection (75ms)

      ✓ Replace text in selection (176ms)

      ✓ Substitute support marks (67ms)

      ✓ Substitute with escaped delimiter (58ms)

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (138ms)

      ✓ Substitute with previous search using # (144ms)

      ✓ Substitute with previous search using / (143ms)

      ✓ Substitute with parameters should update search state (103ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (201ms)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (104ms)

      ✓ Substitute repeat previous should accept flags (64ms)

      ✓ Substitute with empty search string should use last searched pattern (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Ampersand (&) should repeat the last substitution (233ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (53ms)

    ✓ tabe with current file path does nothing (55ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (47ms)

    ✓ command line file tab completion with space in file path (124ms)

  Vertical split

    ✓ :vs creates a second split (72ms)

    ✓ :vsp creates a second split (55ms)

    ✓ :vsplit creates a second split (62ms)

    ✓ :vnew creates a second split (167ms)

    ✓ :vne creates a second split (154ms)

  Basic write-quit

    ✓ Run write and quit (43ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (39ms)

      ✓ Can complete lines in file with different indentation (74ms)

      ✓ Returns no completions for unmatched line

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (80ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (68ms)

    ✓ getMatchingRemap (53ms)

    ✓ jj -> <Esc> through modehandler (85ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (70ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (67ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (146ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (82ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (114ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (100ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (120ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator
    ✓ no remappings
    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped
  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers
    ✓ all defined configurations in package.json have handlers
  Record and navigate jumps
    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (58ms)

        ✓ Can track jumps for keys: GggG (67ms)

        ✓ Can track jumps for keys: GggGgg (66ms)

        ✓ Can track jumps for keys: /b<CR>n (81ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (79ms)

        ✓ Can track jumps for keys: j%% (41ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (87ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (65ms)

        ✓ Can track jumps for keys: j%%<C-o>% (81ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (71ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (81ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (103ms)

        ✓ Can enter number to jump back multiple times (38ms)

        ✓ Can track one-line `` jumps (137ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line double `` jumps (250ms)

        ✓ Can track one-line '' jumps (179ms)

        ✓ Can track one-line double '' jumps (113ms)

        ✓ Can handle '' jumps with no previous jump (213ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (209ms)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (254ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (167ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (284ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (292ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (186ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (229ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (168ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (164ms)

      Can track jumps from marks

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: maG`a (230ms)

  Record and execute a macro

    ✓ Can record and execute (404ms)

[main 2019-12-26T04:37:56.296Z] update#setState checking for updates

[main 2019-12-26T04:37:56.376Z] update#setState idle

    ✓ Can repeat last invoked macro (333ms)

    ✓ Can play back with count (291ms)

    ✓ Can play back with count, abort when a motion fails (332ms)

    ✓ Repeat change on contiguous lines (148ms)

    ✓ Append command to a macro (239ms)

    ✓ Can record Ctrl Keys and repeat (219ms)

    ✓ Can execute macros with dot commands properly (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ : (command) register can be used as a macro (246ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (48ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert (50ms)

    ✓ <Esc> can exit insert

    ✓ Stay in insert when entering characters (71ms)

    ✓ Can handle 'O'

    ✓ 'i' puts you in insert mode before the cursor (70ms)

    ✓ 'I' puts you in insert mode at start of line

    ✓ 'a' puts you in insert mode after the cursor (91ms)

    ✓ 'A' appends to end of line (124ms)

    ✓ '<C-w>' deletes a word (143ms)

    ✓ Can handle <C-w> on leading whitespace (137ms)

    ✓ Can handle <C-w> at beginning of line (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <C-u> deletes to start of line (234ms)

    ✓ Can handle <C-u> on leading characters (44ms)

    ✓ Can handle <C-u> on leading whitespace (212ms)

    ✓ Correctly places the cursor after deleting the previous line break (44ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (105ms)

    ✓ Backspace works on end of whitespace only lines (51ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Backspace works at beginning of file (234ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (219ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (102ms)

    ✓ Can perform insert command prefixed with count (46ms)

    ✓ Can perform append command prefixed with count (122ms)

    ✓ Can perform insert at start of line command prefixed with count (222ms)

    ✓ Can perform append to end of line command prefixed with count (118ms)

    ✓ Can perform change char (s) command prefixed with count (137ms)

    ✓ Can perform command prefixed with count with <C-[>

    ✓ Can handle 'o' with count (88ms)

    ✓ Can handle 'O' with count (101ms)

    ✓ Can handle backspace at beginning of line with all spaces (50ms)

    ✓ Can handle digraph insert (61ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (109ms)

    ✓ Can handle dw

    ✓ Can handle dw

    ✓ Can handle dw across lines (1) (71ms)

    ✓ Can handle dw across lines (2) (64ms)

    ✓ Can handle dd last line (85ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (66ms)

    ✓ Can handle 3dd (65ms)

    ✓ Can handle 3dd off end of document

    ✓ Can handle d2d (119ms)

    ✓ Can handle dd empty line

    ✓ Can handle ddp (120ms)

    ✓ Can handle 'de' (159ms)

    ✓ Can handle 'de' then 'de' again (70ms)

    ✓ Can handle 'db'

    ✓ Can handle 'db then 'db' again (81ms)

    ✓ Can handle 'dl' at end of line (55ms)

    ✓ Can handle 'dF' (142ms)

    ✓ Can handle 'dT' (48ms)

    ✓ Can handle 'd3' then <enter> (65ms)

    ✓ Can handle 'dj' (75ms)

    ✓ Can handle 'dk' (66ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (49ms)

    ✓ Can handle 'd]}' without deleting closing bracket (80ms)

    ✓ Can handle 'cw' (120ms)

    ✓ Can handle 'cw' without deleting following white spaces (136ms)

    ✓ Can handle 'c2w' (48ms)

    ✓ Can handle 'cw' without removing EOL (98ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (45ms)

    ✓ Can handle 'c]}' without deleting closing bracket (63ms)

    ✓ Can handle 's' (45ms)

    ✓ Can handle 'yiw' with correct cursor ending position (118ms)

    ✓ Can handle 'ciw' (101ms)

    ✓ Can handle 'ciw' on blanks (82ms)

    ✓ Can handle 'caw' (99ms)

    ✓ Can handle 'caw' on first letter (94ms)

    ✓ Can handle 'caw' on blanks (58ms)

    ✓ Can handle 'caw' on blanks (70ms)

    ✓ Can handle 'ci(' on first parentheses (54ms)

    ✓ Can handle 'ci(' with nested parentheses (75ms)

    ✓ Can handle 'ci(' backwards through nested parens (72ms)

    ✓ Can handle 'cib' on first parentheses (41ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (47ms)

    ✓ Can handle count prefixed 'ci)' (72ms)

    ✓ Can handle count prefixed 'ca)' (54ms)

    ✓ Can handle 'ca(' spanning multiple lines (87ms)

    ✓ Can handle 'cab' spanning multiple lines (50ms)

    ✓ Can handle 'ci{' spanning multiple lines (90ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (41ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (111ms)

    ✓ Can handle 'ci(' on the closing bracket (40ms)

    ✓ Can handle 'ciB' spanning multiple lines (47ms)

    ✓ will fail when ca( with no () (67ms)

    ✓ will fail when ca{ with no {} (137ms)

    ✓ will fail when caB with no {}

    ✓ Can handle 'ci[' spanning multiple lines (107ms)

    ✓ Can handle 'ci]' on first bracket (39ms)

    ✓ Can handle 'ca[' on first bracket (47ms)

    ✓ Can handle 'ca]' on first bracket (43ms)

    ✓ Can handle 'ci'' on first quote (78ms)

    ✓ Can handle 'ci'' inside quoted string (64ms)

    ✓ Can handle 'ci'' on closing quote (69ms)

    ✓ Can handle 'ci'' when string is ahead

    ✓ Can handle 'ci"' on opening quote (118ms)

    ✓ Can handle 'ci"' starting behind the quoted word (39ms)

    ✓ Can handle 'ca"' starting behind the quoted word (84ms)

    ✓ Can handle 'ca"' starting on the opening quote (59ms)

    ✓ Can handle 'ci"' with escaped quotes (42ms)

    ✓ Can handle 'ci"' with a single escaped quote (40ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (99ms)

    ✓ Can handle 'ci"' with an escaped backslash (40ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (81ms)

    ✓ Can handle 'ca"' starting on the closing quote (69ms)

    ✓ Can handle 'ci"' with complex escape sequences (74ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (152ms)

    ✓ will fail when ca" ahead of quoted string (128ms)

    ✓ Can handle 'ca`' inside word (49ms)

    ✓ can handle cj (75ms)

    ✓ can handle ck (107ms)

    ✓ can handle c2j (118ms)

    ✓ can handle c2k (73ms)

    ✓ can handle cj on last line (102ms)

    ✓ can handle ck on first line (74ms)

    ✓ can handle c2j on last line (53ms)

    ✓ can handle c2k on first line (116ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (42ms)

    ✓ Can handle 'daw' on word with trailing spaces (95ms)

    ✓ Can handle 'daw' on word with leading spaces (122ms)

    ✓ Can handle 'daw' on word with numeric prefix (71ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (74ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (56ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (82ms)

    ✓ Can handle 'daw' on end of word (140ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (47ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (42ms)

    ✓ Can handle 'daw' on word at beginning of file (40ms)

    ✓ Can handle 'daw' on word at beginning of line (39ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (64ms)

    ✓ Can handle 'daw' around word at end of line (66ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (91ms)

    ✓ Can handle 'daW' around word at whitespace (65ms)

    ✓ Can handle 'daW' on word with trailing spaces (51ms)

    ✓ Can handle 'daW' on word with leading spaces (102ms)

    ✓ Can handle 'daW' on word with numeric prefix (95ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (110ms)

    ✓ Can handle 'daW' on beginning of word (47ms)

    ✓ Can handle 'daW' on end of one line (97ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (39ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (72ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (57ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (68ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (49ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (109ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (46ms)

    ✓ Can handle 'diw' on word (47ms)

    ✓ Can handle 'diw' on word with numeric prefix

    ✓ Can handle 'diw' on trailing spaces at the end of line (83ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (97ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (262ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (121ms)

    ✓ Can handle 'diW' on word with trailing spaces (63ms)

    ✓ Can handle 'diW' on word with leading spaces (59ms)

    ✓ Can handle 'diW' on word with numeric prefix (55ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (87ms)

    ✓ Can handle 'diW' on beginning of word (41ms)

    ✓ Can handle d} (62ms)

    ✓ Can handle y} at beginning of line (51ms)

    ✓ Select sentence with trailing spaces (108ms)

    ✓ Select sentence with leading spaces (157ms)

    ✓ Select inner sentence with trailing spaces (66ms)

    ✓ Select inner sentence with leading spaces (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Select spaces between sentences (255ms)

    ✓ Can handle 'df' (66ms)

    ✓ Can handle 'dt' (194ms)

    ✓ Can handle backspace (102ms)

    ✓ Can handle backspace across lines

    ✓ Can handle A and backspace

    ✓ Can handle 'yy' without changing cursor position (39ms)

    ✓ Can handle 'P' after 'yy' (65ms)

    ✓ Can handle 'p' after 'yy' (83ms)

    ✓ Can handle 'P' after 'Nyy' (53ms)

    ✓ Can handle 'p' after 'Nyy'

    ✓ Can handle 'p' after 'yy' with correct cursor position (63ms)

    ✓ Can handle 'gp' after 'yy' (80ms)

    ✓ Can handle 'gp' after 'Nyy'

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (61ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (50ms)

    ✓ Can handle 'gP' after 'yy' (86ms)

    ✓ Can handle 'gP' after 'Nyy' (71ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (98ms)

    ✓ Can handle ']p' after yy (40ms)

    ✓ Can handle ']p' after 'Nyy' (58ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (89ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (77ms)

    ✓ Can handle '[p' after yy (108ms)

    ✓ Can handle '[p' after 'Nyy' (211ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (85ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (46ms)

    ✓ Can handle 'p' after y'a (52ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (67ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (76ms)

    ✓ Can handle pasting in visual mode over selection (103ms)

    ✓ Can repeat w

    ✓ Can repeat p (47ms)

    ✓ I works correctly (88ms)

    ✓ gI works correctly (90ms)

    ✓ gi works correctly (54ms)

    ✓ `. works correctly (99ms)

    ✓ '. works correctly (82ms)

    ✓ g; works correctly (90ms)

    ✓ g, works correctly (108ms)

    ✓ g_ works correctly (39ms)

    ✓ 3g_ works correctly (79ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (254ms)

    ✓ gq handles spaces before single line comments correctly (217ms)

    ✓ gq handles tabs before single line comments correctly (270ms)

    ✓ Can handle space (66ms)

    ✓ Can handle space

    ✓ Undo 1 (100ms)

    ✓ Undo 2 (80ms)

    ✓ Undo cursor (97ms)

    ✓ Undo cursor 2 (131ms)

    ✓ Undo cursor 3 (117ms)

    ✓ Undo with movement first (81ms)

    ✓ Can handle 'U' (71ms)

    ✓ Can handle 'U' for multiple changes (102ms)

    ✓ Can handle 'U' for new line below (127ms)

    ✓ Can handle 'U' for new line above (158ms)

    ✓ Can handle 'U' for consecutive changes only (178ms)

    ✓ Can handle 'u' to undo 'U' (63ms)

    ✓ Can handle 'U' to undo 'U' (55ms)

    ✓ Can handle 'u' after :s/abc/def (140ms)

    ✓ Redo (143ms)

    ✓ Redo (149ms)

    ✓ Redo (71ms)

    ✓ Can handle u (42ms)

    ✓ Can handle guw

    ✓ Can handle gUw (112ms)

    ✓ Can handle u over line breaks (41ms)

    ✓ can handle s in visual mode (141ms)

    ✓ can handle p with selection (114ms)

    ✓ can handle P with selection (179ms)

    ✓ can handle p in visual to end of line (77ms)

    ✓ can repeat backspace twice (84ms)

    ✓ can delete linewise with d2G (60ms)

    ✓ can delete with + motion and count (54ms)

    ✓ can delete with - motion and count (54ms)

    ✓ can dE correctly (59ms)

    ✓ can dE correctly (84ms)

    ✓ can dE correctly (70ms)

    ✓ can ctrl-a correctly behind a word (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (218ms)

    ✓ can ctrl-a on word (167ms)

    ✓ can ctrl-a on a hex number (225ms)

    ✓ can ctrl-a on decimal (125ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a with numeric prefix (222ms)

    ✓ can ctrl-a on a decimal (140ms)

    ✓ can ctrl-a on an octal  (230ms)

    ✓ Correctly increments in the middle of a number (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-x correctly behind a word (225ms)

    ✓ can ctrl-a on an number with word before  (179ms)

    ✓ can ctrl-a on an number with word before and after  (221ms)

    ✓ can ctrl-x on a negative number with word before and after  (186ms)

    ✓ can ctrl-a properly on multiple lines (261ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (191ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (209ms)

    ✓ can <C-a> on word with - in front of it (180ms)

    ✓ can do Y (48ms)

    ✓ Can do S (101ms)

    ✓ / does not affect mark (66ms)

    ✓ / can search with regex (80ms)

    ✓ / can search with newline (73ms)

    ✓ / can search through multiple newlines (152ms)

    ✓ / matches ^ per line (123ms)

    ✓ / matches $ per line (46ms)

    ✓ Can search for forward slash (112ms)

    ✓ Can search backward for question mark (39ms)

    ✓ /\c forces case insensitive search (123ms)

    ✓ /\C forces case sensitive search (153ms)

    ✓ <BS> deletes the last character in search in progress mode (195ms)

    ✓ <S-BS> deletes the last character in search in progress mode (202ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <C-h> deletes the last character in search in progress mode (221ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (232ms)

    ✓ Ignores cit on a non-matching tag (138ms)

    ✓ Ignores cit on a nested tag (71ms)

    ✓ Can do cit on a tag with an attribute tag (45ms)

    ✓ Can do cat on a matching tag (75ms)

    ✓ Can do cit on a multiline tag (46ms)

    ✓ Can do cit on a multiline tag with nested tags (69ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (83ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (58ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (88ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (83ms)

    ✓ can do cit with self closing tags (60ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Respects indentation with cc (233ms)

    ✓ Resets cursor to indent end with cc (90ms)

    ✓ can handle 'cc' on empty line (123ms)

    ✓ cc copies linewise (39ms)

    ✓ Indent current line with correct Vim Mode (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <Esc> and do nothing (364ms)

    ✓ Can handle # on consecutive words (191ms)

    ✓ Can handle # on skipped words (99ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (231ms)

    ✓ cc on whitespace-only treats whitespace as indent (153ms)

    ✓ Can do cai (192ms)

    ✓ Can do cii (59ms)

    ✓ Can do caI (87ms)

    ✓ Can do dai (60ms)

    ✓ Can do dii

    ✓ Can do daI (91ms)

    ✓ `] go to the end of the previously operated or put text (63ms)

    ✓ '] go to the end of the previously operated or put text (99ms)

    ✓ `[ go to the start of the previously operated or put text (78ms)

    ✓ '[ go to the start of the previously operated or put text (80ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (54ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (99ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (53ms)

    can handle gn

      ✓ gn selects the next match text (191ms)

      ✓ gn selects the current word at |hello (165ms)

      ✓ gn selects the current word at h|ello (216ms)

      ✓ gn selects the current word at hel|lo (190ms)

      ✓ gn selects the current word at hell|o (160ms)

      ✓ gn selects the next word at hello| (303ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (132ms)

      ✓ dgn deletes the current word when cursor is at |hello (196ms)

      ✓ dgn deletes the current word when cursor is at h|ello (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at hel|lo (245ms)

      ✓ dgn deletes the current word when cursor is at hell|o (110ms)

      ✓ dgn deletes the next word when cursor is at hello| (276ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (179ms)

      ✓ cgn deletes the current word when cursor is at |hello (213ms)

      ✓ cgn deletes the current word when cursor is at h|ello (76ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (218ms)

      ✓ cgn deletes the current word when cursor is at hell|o (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next word when cursor is at hello| (246ms)

    can handle gN

      ✓ gN selects the previous match text (179ms)

      ✓ gN selects the current word at hell|o (260ms)

      ✓ gN selects the current word at hel|lo (148ms)

      ✓ gN selects the current word at h|ello (185ms)

      ✓ gN selects the current word at |hello (188ms)

      ✓ gN selects the previous word at | hello (164ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (61ms)

      ✓ dgN deletes the current word when cursor is at hell|o (124ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (125ms)

      ✓ dgN deletes the current word when cursor is at h|ello (62ms)

      ✓ dgN deletes the current word when cursor is at |hello (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the previous word when cursor is at | hello (256ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (196ms)

      ✓ cgN deletes the current word when cursor is at hell|o (196ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (219ms)

      ✓ cgN deletes the current word when cursor is at h|ello (187ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the current word when cursor is at |hello (239ms)

      ✓ cgN deletes the previous word when cursor is at | hello (215ms)

  Mode Replace

    ✓ Can activate with <Insert> from Insert mode (185ms)

    ✓ Can activate with R from Normal mode (75ms)

    ✓ Can handle R (210ms)

    ✓ Can handle R past current line (194ms)

    ✓ Can handle R and exit Replace Mode (216ms)

    ✓ Can handle R across lines (80ms)

    ✓ Can handle R across lines and exit Replace Mode (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle R with {count} (241ms)

    ✓ Can handle backspace (155ms)

    ✓ Can handle backspace (132ms)

    ✓ Can handle backspace across lines (260ms)

    ✓ Can handle arrows (104ms)

    ✓ Can handle . (102ms)

    ✓ Can handle . across lines (129ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (282ms)

    ✓ Can handle wd (59ms)

    ✓ Can handle x (73ms)

    ✓ Can handle x across a selection (70ms)

    ✓ Can do vwd in middle of sentence (131ms)

    ✓ Can do vwd in middle of sentence (83ms)

    ✓ Can do vwd multiple times (138ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (115ms)

    ✓ Can handle H key

    ✓ Can handle backspace key (59ms)

    ✓ handles case where we delete over a newline (306ms)

    ✓ handles change operator (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vat on multiple matching tags (235ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (177ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (230ms)

    ✓ Repeat-prefixed vat does not bleed below (169ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (44ms)

    ✓ Can do vi) on a matching parenthesis (146ms)

    ✓ Can do vi) on multiple matching parens (163ms)

    ✓ Can do va) on a matching parenthesis (105ms)

    ✓ Can do va) on multiple matching parens (57ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (192ms)

    ✓ Repeat-prefixed va) does not bleed below (178ms)

    ✓ Can do va} on a matching bracket as first character

    ✓ Can do va} on multiple matching brackets (50ms)

    ✓ Can do vi( on a matching bracket near first character (88ms)

    ✓ Can do vi{ on outer pair of nested braces (48ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (43ms)

    ✓ Can do va] on multiple matching brackets (112ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (193ms)

    ✓ Repeat-prefixed vaf does not bleed below (199ms)

    ✓ vaf only expands to enclosing pairs (51ms)

    ✓ Can use . to repeat indent in visual (106ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v_x to delete to first char (231ms)

    ✓ Can do vg_x to delete to last char with no EOL (178ms)

    ✓ Can do v3g_x to delete to last char with no EOL with count (82ms)

    ✓ Can do v$x to delete to last char including EOL (42ms)

    ✓ Can do gv to reselect previous selection (172ms)

    Vim's EOL handling is weird

      ✓ delete through eol (63ms)

      ✓ join 2 lines by deleting through eol (128ms)

      ✓ d$ doesn't delete whole line (49ms)

      ✓ vd$ does delete whole line (54ms)

      ✓ Paste over selection copies the selection (106ms)

      ✓ Paste over selection copies the selection linewise (69ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (74ms)

      ✓ Can handle <down> key (68ms)

      ✓ Can handle <left> key (176ms)

      ✓ Can handle <right> key (204ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (188ms)

      ✓ Can handle 'gj' (218ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (61ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (230ms)

      ✓ Can handle 'vawd' on word with leading spaces (178ms)

      ✓ Can handle 'vawd' on word with numeric prefix (264ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (234ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (131ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (91ms)

      ✓ Can handle 'vaWd' on word with leading spaces (271ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (187ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (190ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (169ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (231ms)

      ✓ Can handle 'vaWd' on word with leading spaces (182ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (101ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (139ms)

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (230ms)

      ✓ Can handle 'vawd' on word with trailing spaces (171ms)

      ✓ Can handle 'vawd' on word with leading spaces (129ms)

      ✓ Can handle 'vawd' on word with numeric prefix (196ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (211ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (160ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (239ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (233ms)

      ✓ Can handle 'vaWd' on word with leading spaces (159ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (235ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (134ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'Y' in visual mode (246ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (183ms)

      ✓ Select sentence with leading spaces in visual mode (230ms)

      ✓ Select multiple sentences in visual mode (168ms)

    handles is in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select inner sentence with trailing spaces in visual mode (234ms)

      ✓ Select inner sentence with leading spaces in visual mode (184ms)

      ✓ Select spaces between sentences in visual mode (151ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (222ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do vat on a matching tag (142ms)

    handles replace in visual mode

      ✓ Can do a single line replace (123ms)

      ✓ Can do a multi line replace (46ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (82ms)

      ✓ D deletes the current line (219ms)

    handles indent blocks in visual mode

      ✓ Can do vai (171ms)

      ✓ Can do vii (55ms)

      ✓ Doesn't naively select the next line (98ms)

      ✓ Searches backwards if cursor line is empty (200ms)

      ✓ Can do vaI (154ms)

    visualstar

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with * (226ms)

      ✓ Works with # (53ms)

    search works in visual mode

      ✓ Works with / (52ms)

      1) Works with ?

      ✓ Selects correct range (345ms)

    X will delete linewise

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (233ms)

      ✓ normal selection (131ms)

    C will delete linewise

      ✓ normal selection (105ms)

      ✓ normal selection (218ms)

    R will delete linewise

      ✓ normal selection (187ms)

      ✓ normal selection (182ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (170ms)

      ✓ upward selection (80ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (95ms)

      ✓ multiline indent bottom up selection (45ms)

      ✓ repeat multiline indent top down selection (112ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent bottom up selection (239ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (96ms)

      ✓ multiline outdent bottom up selection (447ms)

      ✓ repeat multiline outdent top down selection (71ms)

      ✓ repeat multiline outdent bottom up selection (187ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (163ms)

    vi{ will go to end of second to last line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ select (290ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode (50ms)

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode (43ms)

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (339ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gv selects the last pasted text (which is longer than original) (401ms)

      ✓ gv selects the last pasted text (multiline) (174ms)

    can handle gn

      ✓ gn selects the next match text (170ms)

      ✓ gn selects the current word at |hello (199ms)

      ✓ gn selects the current word at h|ello (156ms)

      ✓ gn selects the current word at hel|lo (246ms)

      ✓ gn selects the next word at hell|o (136ms)

      ✓ gn selects the next word at hello| (218ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (78ms)

      ✓ multiline insert from top down selection (194ms)

      ✓ skips blank lines (155ms)

    can append text with A

      ✓ multiline append from bottom up selection (47ms)

      ✓ multiline append from top down selection (73ms)

      ✓ skips blank lines

    Can handle u/gu, U/gU

      ✓ U/gU on single character (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ U/gU across a selection (253ms)

      ✓ U/gU across a selection (reverse) (184ms)

      ✓ u/gu on single character (212ms)

      ✓ u/gu across a selection (224ms)

      ✓ u/gu across a selection (reverse) (176ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (146ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (238ms)

    ✓ Can handle I forward select (195ms)

    ✓ Can handle I backwards select (390ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (243ms)

    ✓ Can handle c forward select (201ms)

    ✓ Can handle c backwards select (52ms)

    ✓ Can handle C (94ms)

    ✓ Can do a multi line replace (45ms)

    ✓ Can handle 'D' (95ms)

    ✓ Can handle 'gj' (55ms)

    ✓ Properly add to end of lines j then $ (95ms)

    ✓ Properly add to end of lines $ then j (60ms)

    ✓ o works in visual block mode (97ms)

    Non-darwin <C-c> tests

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ <C-c> copies and sets mode to normal (109ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (88ms)

    ✓ Can handle wd (70ms)

    ✓ Can handle x (85ms)

    ✓ Can handle x across a selection (71ms)

    ✓ Can do vwd in middle of sentence (114ms)

    ✓ Can do vwd in middle of sentence (237ms)

    ✓ Can do vwd multiple times (112ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (86ms)

    ✓ handles case where we delete over a newline (97ms)

    ✓ handles change operator (82ms)

    ✓ Vp updates register content (69ms)

    ✓ Vp does not append unnecessary newlines (first line) (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (231ms)

    ✓ Vp does not append unnecessary newlines (last line) (176ms)

    Vim's EOL handling is weird

      ✓ delete through eol (70ms)

      ✓ join 2 lines by deleting through eol (52ms)

      ✓ d$ doesn't delete whole line (48ms)

      ✓ vd$ does delete whole line (44ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (69ms)

      ✓ Can handle <down> key (70ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (69ms)

      ✓ Can handle 'gj' (71ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle d key (229ms)

      ✓ Can handle d key

      ✓ Can handle d key

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (106ms)

      ✓ Can do a multi visual line replace (39ms)

      ✓ Can do a multi visual line replace from the bottom up (111ms)

    search works in visual line mode

      ✓ Works with / (44ms)

      ✓ Works with ? (55ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (162ms)

    replace text in linewise visual-mode with linewise register content

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ yyVp does not change the content but changes cursor position (212ms)

      ✓ linewise visual put works also in the end of document (125ms)

      ✓ gv selects the last pasted text (which is shorter than original) (222ms)

      ✓ gv selects the last pasted text (which is longer than original) (205ms)

      ✓ gv selects the last pasted text (multiline) (108ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (49ms)

      ✓ multiline insert from top down selection (81ms)

      ✓ skips blank lines (42ms)

    can append text with A

      ✓ multiline append from bottom up selection (60ms)

      ✓ multiline append from top down selection (73ms)

      ✓ skips blank lines (71ms)

  Mode Normal

    ✓ Can handle 'x' (67ms)

    ✓ Can handle 'Nx' (57ms)

    ✓ Can handle 'Nx' and paste (82ms)

    ✓ Can handle 'x' at end of line (52ms)

    ✓ Can handle 'Ns' (86ms)

    ✓ Can handle 'Ns' at end of line (54ms)

    ✓ Can handle '<Del>' (85ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (42ms)

    ✓ Can handle '<Del>' at end of line (130ms)

    ✓ Can handle 'cc' (163ms)

    ✓ Can handle 'Ncc' (70ms)

    ✓ Can handle 'yy' (66ms)

    ✓ Can handle 'D' (82ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' on empty lines (217ms)

    ✓ Can handle 'DD' (40ms)

    ✓ Can handle 'C' (69ms)

    ✓ Can handle 'NC' (295ms)

    ✓ Can handle 'NC' and put (201ms)

    ✓ Can handle 'r' (60ms)

    ✓ Can handle '<Count>r' (77ms)

    ✓ Can handle '<Count>r'

    ✓ Can handle 'r' after 'dd' (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'r
' (224ms)

    ✓ Can handle '<Count>r
' (181ms)

    ✓ Can handle 'J' once (62ms)

    ✓ Can handle 'J' twice (77ms)

    ✓ Can handle 'J' with empty last line (70ms)

    ✓ Can handle 'J's with multiple empty last lines (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with leading white space on next line (466ms)

    ✓ Can handle 'J' with only white space on next line

    ✓ Can handle 'J' with TWO indented lines (48ms)

    ✓ Can handle 'J' with ')' first character on next line (81ms)

    ✓ Can handle 'J' with a following delete (48ms)

    ✓ Can handle 'J' in Visual Line mode (88ms)

    ✓ Can handle 'gJ' once

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (109ms)

    ✓ Can handle '~'

    ✓ Can handle 'g~{motion}' (46ms)

    ✓ Can handle '<BS>' in insert mode (59ms)

    ✓ Can handle undo with P (94ms)

    ✓ Can handle 'ge' in multiple lines case1 (46ms)

    ✓ Can handle 'ge' in multiple lines case2 (69ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (214ms)

    ✓ Can repeat '~' with dot (116ms)

    ✓ Can repeat 'x'

    ✓ Can repeat 'J' (104ms)

    ✓ Can handle dot with A (75ms)

    ✓ Can handle dot with I (87ms)

    ✓ Can repeat actions that require selections (66ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (93ms)

    ✓ Can repeat insert change and '<C-t>' (81ms)

    ✓ Can repeat change by `<C-a>` (69ms)

    ✓ Only one arrow key can be repeated in Insert Mode (100ms)

    ✓ Cached content change will be cleared by arrow keys (79ms)

  Matching Bracket (%)

    ✓ before opening parenthesis

    ✓ inside parenthesis (77ms)

    ✓ nested parenthesis beginning (38ms)

    ✓ nested parenthesis end (104ms)

    ✓ nested bracket and parenthesis beginning

    ✓ nested bracket, parenthesis, braces beginning (116ms)

    ✓ nested bracket, parenthesis, braces end (84ms)

    ✓ parentheses after > (60ms)

    ✓ parentheses after " (84ms)

  Motions in Normal Mode

    ✓ Can handle [( (54ms)

    ✓ Can handle nested [( (94ms)

    ✓ Can handle <number>[(

    ✓ Can handle [( and character under cursor exclusive (136ms)

    ✓ Can handle ]) (209ms)

    ✓ Can handle nested ]) (189ms)

    ✓ Can handle <number>]) (111ms)

    ✓ Can handle ]) and character under cursor exclusive

    ✓ Can handle [{ (51ms)

    ✓ Can handle nested [{ (66ms)

    ✓ Can handle <number>[{

    ✓ Can handle [{ and character under cursor exclusive (111ms)

    ✓ Can handle ]}

    ✓ Can handle nested ]} (106ms)

    ✓ Can handle <number>]} (45ms)

    ✓ Can handle ]} and character under cursor exclusive (182ms)

    ✓ Can handle 'ge' (112ms)

    ✓ Can handle 'gg'

    ✓ Can handle 'gg' to first non blank char on random line (106ms)

    ✓ Can handle 'gg' to first non blank char on first line (80ms)

    ✓ 'gg' obeys startofline (63ms)

    ✓ Retain same column when moving up/down (83ms)

    ✓ Can handle <enter> (54ms)

    ✓ $ always keeps cursor on EOL (97ms)

    ✓ Can handle $ with a count (43ms)

    ✓ Can handle $ with a count at end of file (97ms)

    ✓ Can handle <End> with a count

    ✓ Can handle <D-right> with a count (99ms)

    ✓ Can handle 'f' (38ms)

    ✓ Can handle 'f' twice (46ms)

    ✓ Can handle 'f' with <tab> (86ms)

    ✓ Can handle 'f' and find back search (44ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' (110ms)

    ✓ Can handle 'F' twice (73ms)

    ✓ Can handle 'F' and find back search (50ms)

    ✓ Can handle 'f' and multiple back searches (103ms)

    ✓ Can handle 't' (41ms)

    ✓ Can handle 't' twice (50ms)

    ✓ Can handle 't' and find back search (89ms)

    ✓ Can handle 'T' (54ms)

    ✓ Can handle 'T' twice (89ms)

    ✓ Can handle 'T' and find back search

    ✓ Can run a forward search (122ms)

    ✓ Can run a forward and find next search

    ✓ Can run a forward and find previous search from end of word (42ms)

    ✓ Can run a reverse search (69ms)

    ✓ Can run a reverse and find next search (64ms)

    ✓ cancelled search reverts to previous search state (49ms)

    ✓ Backspace on empty search cancels (76ms)

    ✓ Search offsets: b does nothing (75ms)

    ✓ Search offsets: b2 goes 2 to the right

    ✓ Search offsets: b+3 goes 3 to the right (91ms)

    ✓ Search offsets: e goes to the end (41ms)

    ✓ Search offsets: character offset goes across line boundaries (82ms)

    ✓ Search offsets: 2 goes 2 down (87ms)

    ✓ Search offsets: -2 goes 2 up (42ms)

    ✓ maintains column position correctly (75ms)

    ✓ maintains column position correctly with $ (84ms)

    ✓ Can handle G 

    ✓ Can handle G with number prefix (68ms)

    ✓ Can handle G with number prefix (77ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix

    ✓ Can handle 0 (52ms)

    ✓ Can handle 0 as part of a repeat (91ms)

    ✓ Can handle g* (38ms)

    ✓ Can handle g*n (84ms)

    ✓ Can handle *

    ✓ Can handle ** (112ms)

    ✓ Can handle # on whitespace (41ms)

    ✓ Can handle # on EOL (50ms)

    ✓ Can handle g# (63ms)

    ✓ Can handle g#n (109ms)

    ✓ Can handle # (65ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (50ms)

    ✓ * adds to search history (67ms)

    ✓ # adds to search history (95ms)

    ✓ Can handle | (88ms)

    ✓ Can handle <number> | (62ms)

    ✓ Can handle + (82ms)

    ✓ Can handle + indent (49ms)

    ✓ Can handle + with count prefix (68ms)

    ✓ Can handle -

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix (221ms)

    ✓ Can handle g_ (43ms)

    ✓ Can handle g_ with count prefix

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key

    ✓ Can handle <right> key

    ✓ Can handle 'gk'

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down
    ✓ line down: bottom-most line should stay at the same location
    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character
    word right
      ✓ move to word right
      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line
      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)
    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line
    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)
      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward
      ✓ next concrete sentence
      ✓ next sentence that ends with paragraph ending
      ✓ next sentence when cursor is at the end of previous paragraph
      ✓ next sentence when paragraph contains a line of whilte spaces
    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin
      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (42ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (45ms)

      insert mode

        ✓ <left> wraps to previous line (74ms)

        ✓ <right> once goes to end of line (49ms)

        ✓ <right> twice wraps to next line (76ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line

        ✓ l does not wrap to next line (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <left> does not wrap to previous line (216ms)

        ✓ <right> does not wrap to next line (62ms)

      insert mode

        ✓ <left> does not wrap to previous line (130ms)

        ✓ <right> does not wrap to next line (215ms)

    wrapscan enabled

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ search wraps around the end of the file (528ms)

      ✓ search wraps around the start of the file (42ms)

    wrapscan disabled

      ✓ search stops at the end of the file

      ✓ search stops at the start of the file (114ms)

  Multicursor

    ✓ can add multiple cursors below (67ms)

    ✓ can add multiple cursors above (212ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip
    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (326ms)

    ✓ gcj comments in current and next line (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (408ms)

    ✓ block comment in Visual Mode (131ms)

    ✓ comment in visual line mode (166ms)

    ✓ comment in visual block mode (194ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (317ms)

    ✓ =$ formats entire line (241ms)

    ✓ =j formats two lines (164ms)

    ✓ 3=k formats three lines (141ms)

    ✓ =gg formats to top of file (251ms)

    ✓ =G formats to bottom of file (74ms)

    ✓ =ip formats paragraph (172ms)

    ✓ format in visual mode (101ms)

  put operator

    ✓ basic put test (187ms)

    ✓ test yy end of line (104ms)

    ✓ test yy first line (57ms)

    ✓ test yy middle line (57ms)

    ✓ test yy with correct positon movement (72ms)

    ✓ test visual block single line yank p (64ms)

    ✓ test visual block single line yank P

    ✓ test visual block single line delete p (56ms)

    ✓ test visual block single line delete P (53ms)

  rot13 operator

    2) rot13() unit test

    ✓ g?j works (134ms)

    ✓ g? in visual mode works (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    3) g? in visual line mode works

    4) g? in visual block mode works

  shift operator

    ✓ basic shift left test (69ms)

    ✓ shift left goto end test (72ms)

    ✓ shift left goto line test (54ms)

    ✓ shift right goto end test (79ms)

    ✓ shift right goto line test (50ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (40ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (92ms)

      ✓ step to Camel word

      ✓ step to CAP word (125ms)

      ✓ step after CAP word (95ms)

      ✓ step from middle of word to Camel word (71ms)

      ✓ step to number word (90ms)

      ✓ step to operator word (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (153ms)

      ✓ step to operator and then over (183ms)

    handles <leader>w for underscore_var

      ✓ step to _word (206ms)

      ✓ step over whitespace to word (87ms)

      ✓ step from inside word to _word (47ms)

      ✓ step form _word to number (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from nubmer word to _word (141ms)

      ✓ step from in whitespace to word (67ms)

      ✓ step in ALL_CAPS_WORD (83ms)

    handles d<leader>w

      ✓ delete from start of camelWord (51ms)

      ✓ delete from middle of camelWord (57ms)

      ✓ delete from start of CamelWord (39ms)

      ✓ delete two words from camelWord (94ms)

      ✓ delete from start of underscore_word

      ✓ delete from middle of underscore_word (53ms)

      ✓ delete two words from camel_word (64ms)

    handles di<leader>w

      ✓ delete from start of camelWord (69ms)

      ✓ delete from middle of camelWord (49ms)

      ✓ delete from start of CamelWord (65ms)

      ✓ delete two words from camelWord (43ms)

      ✓ delete from start of underscore_word (75ms)

      ✓ delete from middle of underscore_word (49ms)

      ✓ delete two words from camel_word (113ms)

    handles <leader>b

      ✓ back from middle of word (93ms)

      ✓ back over whitespace to camelWord (57ms)

      ✓ back twice over operator (120ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (161ms)

      ✓ from middle to end of underscore_word (206ms)

      ✓ twice to end of word over operator (126ms)

  easymotion plugin

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle s move (171ms)

    ✓ Can handle 2s move (56ms)

    ✓ Can handle f move (52ms)

    ✓ Can handle 2f move (454ms)

    ✓ Can handle F move (191ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 2F move (224ms)

    ✓ Can handle t move (155ms)

    ✓ Can handle bd-t move (49ms)

    ✓ Can handle 2t move (91ms)

    ✓ Can handle bd-t2 move (60ms)

    ✓ Can handle T move (50ms)

    ✓ Can handle 2T move (81ms)

    ✓ Can handle w move (43ms)

    ✓ Can handle bd-w move (86ms)

    ✓ Can handle b move (212ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle e move (43ms)

    ✓ Can handle bd-e move (66ms)

    ✓ Can handle ge move (56ms)

    ✓ Can handle n-char move (67ms)

    ✓ Can handle j move (91ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle k move (232ms)

    ✓ Can handle bd-jk move (1) (196ms)

    ✓ Can handle bd-jk move (2) (212ms)

    ✓ Can handle lineforward move (1) (108ms)

    ✓ Can handle lineforward move (2) (198ms)

    ✓ Can handle linebackward move (1) (184ms)

    ✓ Can handle linebackward move (2) (177ms)

    ✓ Can handle searching for backslash (\) (138ms)

    ✓ Can handle searching for carat (^) (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for dot (.) (228ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (46ms)

    ✓ Replaces within inner Word (252ms)

    ✓ Replaces within '' (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces within '' including spaces (245ms)

    ✓ Replaces within () (162ms)

    ✓ Replaces within () including spaces (130ms)

    ✓ Replaces within a paragraph (233ms)

    ✓ Replaces using a specified register (200ms)

    ✓ Replaces within {} over multiple lines (182ms)

    ✓ Replaces a multiline register within {} over multiple lines (79ms)

    ✓ Replaces a multiline register within {} over multiple lines (59ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (219ms)

    ✓ grr replaces the entire line with the register (65ms)

    ✓ grr can replace multiple lines (58ms)

    ✓ Replaces in visual mode (54ms)

    ✓ Replaces in visual mode using a specified register (86ms)

    ✓ Replaces in visual line mode (62ms)

    ✓ grj is linewise (81ms)

  sneak plugin

    ✓ Can handle s motion (91ms)

    ✓ Can handle S motion (51ms)

    ✓ Can handle <operator>z motion (66ms)

    ✓ Can handle <operator>Z motion (87ms)

    ✓ Can handle s; motion (73ms)

    ✓ Can handle s, motion (44ms)

    ✓ Can handle S; motion (40ms)

    ✓ Can handle S, motion (72ms)

    ✓ Can handle single letter s motion

    ✓ Can handle single letter S motion (45ms)

    ✓ Can handle single letter <operator>z motion (78ms)

    ✓ Can handle single letter <operator>Z motion (55ms)

    ✓ Can handle single letter s; motion (90ms)

    ✓ Can handle single letter s, motion

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter S; motion (321ms)

    ✓ Can handle single letter S, motion (58ms)

    ✓ Can handle multiline single char <number>s motion (62ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (130ms)

    ✓ 'ysiw(' surrounds word with space (135ms)

    ✓ 'ysw)' surrounds word without space (203ms)

    ✓ 'ysw(' surrounds word with space (87ms)

    ✓ 'ysaw)' surrounds word without space (70ms)

    ✓ 'ysaw(' surrounds word with space (77ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (136ms)

    ✓ 'ysiw<' surrounds word with tags (83ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (94ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (190ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (113ms)

    ✓ change surround (110ms)

    ✓ change surround with two pairs of quotes (110ms)

    ✓ change surround with two pairs of parens (176ms)

    ✓ change surround with alias (71ms)

    ✓ change surround to tags (197ms)

    ✓ delete surround (126ms)

    ✓ delete surround with quotes (128ms)

    ✓ delete surround with nested of quotes (203ms)

    ✓ delete surround with inconsistent quotes (134ms)

    ✓ delete surround with mixed quotes (78ms)

    ✓ delete surround with empty quotes cursor at start (195ms)

    ✓ delete surround with empty quotes cursor at end (70ms)

    ✓ don't delete surround if cursor is after closing match (108ms)

    ✓ delete surround if cursor is before opening match (102ms)

    ✓ delete surround with two pairs of parens (190ms)

    ✓ delete surround with alias (77ms)

    ✓ delete surround with tags (190ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (178ms)

    ✓ changing brackets with surround works again (201ms)

    ✓ change surround with tags that contain an attribute and preserve them (117ms)

    ✓ change surround with tags that contain an attribute and remove them (103ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (236ms)

    ✓ Can use two registers together (86ms)

    ✓ Can use black hole register (169ms)

    ✓ System clipboard works with chinese characters (52ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Yank stores text in Register '0' (518ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (108ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (136ms)

    ✓ Register '1'-'9' stores delete content (140ms)

    ✓ "A appends linewise text to "a (147ms)

    ✓ "A appends character wise text to "a (176ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (131ms)

    ✓ Small deletion using Del is stored in small delete register (128ms)

    ✓ Small deletion using X is stored in small delete register (116ms)

    ✓ Search register (/) is set by forward search (183ms)

    ✓ Search register (/) is set by backward search (215ms)

    ✓ Search register (/) is set by star search (168ms)

    ✓ Command register (:) is set by command line (78ms)

    ✓ Read-only registers cannot be written to (124ms)

    clipboard

      ✓ Can access '*' (clipboard) register (173ms)

      ✓ Can access '+' (clipboard) register (207ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character> (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat reversed F<character> (370ms)

    ✓ Can repeat t<character> (215ms)

    ✓ Can repeat N times reversed t<character> (189ms)

  sentence motion
    [count] sentences backward

      ✓ move one sentence backward (163ms)

      ✓ move one sentence backward (92ms)

      ✓ move [count] sentences backward (188ms)

      ✓ move one sentence backward single line - middle (160ms)

      ✓ move one sentence backward no space (184ms)

      ✓ move one sentence backward no space - middle (61ms)

      ✓ move one sentence backward - multiline (98ms)

      ✓ move one sentence backward - multiline - period (162ms)

      ✓ move one sentence backward - multiline - previous line (158ms)

      ✓ move one sentence backward - multiline - previous line - period (202ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line
    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1301 passing (4m)
  4 pending

  4 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:920:5)

  2) rot13 operator
       rot13() unit test:

      AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
+ actual - expected

+ 'n'
- 'nopqrstuvwxyzabcdefghijklm'
      + expected - actual

      -n
      +nopqrstuvwxyzabcdefghijklm
      
      at Context.<anonymous> (test/operator/rot13.test.ts:25:14)

  3) rot13 operator
       g? in visual line mode works:

      Cursor CHARACTER position is wrong.
      + expected - actual

      -0
      +1
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:43:3)

  4) rot13 operator
       g? in visual block mode works:

      Content does not match; Expected=drs. Actual=qrs.
      + expected - actual

      -qrs
      +drs
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:50:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: fa6edaf0-2799-11ea-8215-356b6c757fb9

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.3 build /home/travis/build/VSCodeVim/Vim
> gulp build

[05:42:32] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[05:42:32] Starting 'build'...
[05:42:32] Starting 'prettier'...
[05:42:32] Finished 'prettier' after 28 ms
[05:42:32] Starting 'tsc'...
[05:42:32] Starting 'tslint'...
[05:42:39] Finished 'tslint' after 6.57 s
[05:42:46] Finished 'tsc' after 14 s
[05:42:46] Starting 'commit-hash'...
[05:42:46] Finished 'commit-hash' after 26 ms
[05:42:46] Finished 'build' after 14 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T05:42:50.430Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (42ms)

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (45ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (76ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (61ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (56ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (51ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (1014ms)

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar
    ✓ can parse left - percent
    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (532ms)

    ✓ :smile editor contains smile text (533ms)

  Basic sort

    ✓ Sort whole file, asc (71ms)

    ✓ Sort whole file, asc, ignoreCase (76ms)

    ✓ Sort whole file, dsc (75ms)

    ✓ Sort whole file, dsc, ignoreCase (70ms)

    ✓ Sort range, asc (136ms)

    ✓ Sort range, asc, ignoreCase (105ms)

    ✓ Sort range, dsc (95ms)

    ✓ Sort range, dsc, ignoreCase (110ms)

    ✓ Sort whole file, asc, unique (101ms)

  Horizontal split

    ✓ :sp creates a second split (66ms)

    ✓ :split creates a second split (73ms)

    ✓ :new creates a second split (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !

    ✓ throws if bad input
  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (62ms)

    ✓ Replace with `g` flag

    ✓ Replace with flags AND count (62ms)

    ✓ Replace with `c` flag

    ✓ Replace with `gc` flag (69ms)

    ✓ Replace across all lines (174ms)

    ✓ Replace on specific single line (66ms)

    ✓ Replace on current line using dot (55ms)

    ✓ Replace single relative line using dot and plus (110ms)

    ✓ Replace across specific line range (100ms)

    ✓ Replace across relative line range using dot, plus, and minus (74ms)

    ✓ Replace across relative line range using numLines+colon shorthand (127ms)

    ✓ Repeat replacement across relative line range (106ms)

    ✓ Replace with range AND count but no flags (65ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (62ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (80ms)

    ✓ Undocumented: trailing operators use 1 as RHS (85ms)

    ✓ Replace specific single equal lines (53ms)

    ✓ Replace current line with no active selection (52ms)

    ✓ Replace text in selection (87ms)

    ✓ Substitute support marks (91ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line

      ✓ Replace with `g` flag inverts global flag (44ms)

      ✓ Replace with `c` flag inverts global flag (64ms)

      ✓ Replace multiple lines (78ms)

      ✓ Replace across specific lines (46ms)

      ✓ Replace current line with no active selection (63ms)

      ✓ Replace text in selection (171ms)

      ✓ Substitute support marks (61ms)

      ✓ Substitute with escaped delimiter

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (146ms)

      ✓ Substitute with previous search using # (137ms)

      ✓ Substitute with previous search using / (165ms)

      ✓ Substitute with parameters should update search state (81ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (279ms)

      ✓ Substitute repeat previous should accept flags (98ms)

      ✓ Substitute with empty search string should use last searched pattern (262ms)

      ✓ Ampersand (&) should repeat the last substitution (194ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (66ms)

    ✓ tabe with current file path does nothing (41ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file navigate tab completion (44ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (54ms)

    ✓ command line file tab completion with space in file path (124ms)

  Vertical split

    ✓ :vs creates a second split (60ms)

    ✓ :vsp creates a second split (60ms)

    ✓ :vsplit creates a second split (75ms)

    ✓ :vnew creates a second split (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ :vne creates a second split (163ms)

  Basic write-quit

    ✓ Run write and quit (40ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (78ms)

      ✓ Can complete lines in file with different indentation (57ms)

      ✓ Returns no completions for unmatched line (118ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (85ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (64ms)

    ✓ getMatchingRemap (64ms)

    ✓ jj -> <Esc> through modehandler (58ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (73ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (79ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (76ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (73ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (122ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (114ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (114ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (63ms)

        ✓ Can track jumps for keys: GggG (63ms)

        ✓ Can track jumps for keys: GggGgg (74ms)

        ✓ Can track jumps for keys: /b<CR>n (78ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (90ms)

        ✓ Can track jumps for keys: j%% (78ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (41ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (81ms)

        ✓ Can track jumps for keys: j%%<C-o>% (79ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (94ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (69ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (109ms)

        ✓ Can enter number to jump back multiple times (64ms)

        ✓ Can track one-line `` jumps (99ms)

        ✓ Can track one-line double `` jumps (52ms)

        ✓ Can track one-line '' jumps (97ms)

        ✓ Can track one-line double '' jumps (175ms)

        ✓ Can handle '' jumps with no previous jump (174ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (245ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (197ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (257ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (127ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (93ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (216ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (230ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (195ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (71ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (96ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (43ms)

  Record and execute a macro

    ✓ Can record and execute (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

[main 2019-12-26T05:43:20.432Z] update#setState checking for updates

    ✓ Can repeat last invoked macro (377ms)

[main 2019-12-26T05:43:20.516Z] update#setState idle

    ✓ Can play back with count (420ms)

    ✓ Can play back with count, abort when a motion fails (261ms)

    ✓ Repeat change on contiguous lines (195ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Append command to a macro (322ms)

    ✓ Can record Ctrl Keys and repeat (159ms)

    ✓ Can execute macros with dot commands properly (250ms)

    ✓ : (command) register can be used as a macro (197ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (55ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert

    ✓ <Esc> can exit insert

    ✓ Stay in insert when entering characters (48ms)

    ✓ Can handle 'O' (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'i' puts you in insert mode before the cursor (231ms)

    ✓ 'I' puts you in insert mode at start of line (172ms)

    ✓ 'a' puts you in insert mode after the cursor (172ms)

    ✓ 'A' appends to end of line (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '<C-w>' deletes a word (223ms)

    ✓ Can handle <C-w> on leading whitespace (170ms)

    ✓ Can handle <C-w> at beginning of line (222ms)

    ✓ <C-u> deletes to start of line (53ms)

    ✓ Can handle <C-u> on leading characters (61ms)

    ✓ Can handle <C-u> on leading whitespace (74ms)

    ✓ Correctly places the cursor after deleting the previous line break (48ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (112ms)

    ✓ Backspace works on end of whitespace only lines (55ms)

    ✓ Backspace works at beginning of file (91ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (77ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (247ms)

    ✓ Can perform insert command prefixed with count (162ms)

    ✓ Can perform append command prefixed with count (70ms)

    ✓ Can perform insert at start of line command prefixed with count (74ms)

    ✓ Can perform append to end of line command prefixed with count (150ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can perform change char (s) command prefixed with count (268ms)

    ✓ Can perform command prefixed with count with <C-[> (110ms)

    ✓ Can handle 'o' with count (108ms)

    ✓ Can handle 'O' with count (79ms)

    ✓ Can handle backspace at beginning of line with all spaces (66ms)

    ✓ Can handle digraph insert (59ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (43ms)

    ✓ Can handle dw (99ms)

    ✓ Can handle dw (55ms)

    ✓ Can handle dw across lines (1) (58ms)

    ✓ Can handle dw across lines (2) (52ms)

    ✓ Can handle dd last line

    ✓ Can handle dd single line (54ms)

    ✓ Can handle dd (49ms)

    ✓ Can handle 3dd (91ms)

    ✓ Can handle 3dd off end of document (61ms)

    ✓ Can handle d2d (42ms)

    ✓ Can handle dd empty line (73ms)

    ✓ Can handle ddp (52ms)

    ✓ Can handle 'de' (54ms)

    ✓ Can handle 'de' then 'de' again (56ms)

    ✓ Can handle 'db' (60ms)

    ✓ Can handle 'db then 'db' again (96ms)

    ✓ Can handle 'dl' at end of line (102ms)

    ✓ Can handle 'dF' (38ms)

    ✓ Can handle 'dT' (93ms)

    ✓ Can handle 'd3' then <enter> (40ms)

    ✓ Can handle 'dj' (51ms)

    ✓ Can handle 'dk' (58ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (60ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (98ms)

    ✓ Can handle 'cw' without deleting following white spaces (84ms)

    ✓ Can handle 'c2w' (47ms)

    ✓ Can handle 'cw' without removing EOL (77ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (54ms)

    ✓ Can handle 'c]}' without deleting closing bracket (78ms)

    ✓ Can handle 's' (48ms)

    ✓ Can handle 'yiw' with correct cursor ending position (65ms)

    ✓ Can handle 'ciw' (120ms)

    ✓ Can handle 'ciw' on blanks (87ms)

    ✓ Can handle 'caw' (100ms)

    ✓ Can handle 'caw' on first letter (79ms)

    ✓ Can handle 'caw' on blanks (110ms)

    ✓ Can handle 'caw' on blanks (99ms)

    ✓ Can handle 'ci(' on first parentheses (54ms)

    ✓ Can handle 'ci(' with nested parentheses (87ms)

    ✓ Can handle 'ci(' backwards through nested parens (49ms)

    ✓ Can handle 'cib' on first parentheses (47ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (39ms)

    ✓ Can handle count prefixed 'ci)' (49ms)

    ✓ Can handle count prefixed 'ca)' (121ms)

    ✓ Can handle 'ca(' spanning multiple lines (223ms)

    ✓ Can handle 'cab' spanning multiple lines (149ms)

    ✓ Can handle 'ci{' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (89ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly

    ✓ Can handle 'ci(' on the closing bracket (98ms)

    ✓ Can handle 'ciB' spanning multiple lines (43ms)

    ✓ will fail when ca( with no () (66ms)

    ✓ will fail when ca{ with no {} (66ms)

    ✓ will fail when caB with no {} (85ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (50ms)

    ✓ Can handle 'ca[' on first bracket (116ms)

    ✓ Can handle 'ca]' on first bracket (43ms)

    ✓ Can handle 'ci'' on first quote (49ms)

    ✓ Can handle 'ci'' inside quoted string (54ms)

    ✓ Can handle 'ci'' on closing quote (90ms)

    ✓ Can handle 'ci'' when string is ahead (61ms)

    ✓ Can handle 'ci"' on opening quote (82ms)

    ✓ Can handle 'ci"' starting behind the quoted word

    ✓ Can handle 'ca"' starting behind the quoted word

    ✓ Can handle 'ca"' starting on the opening quote (118ms)

    ✓ Can handle 'ci"' with escaped quotes (164ms)

    ✓ Can handle 'ci"' with a single escaped quote (55ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (59ms)

    ✓ Can handle 'ci"' with an escaped backslash (62ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (69ms)

    ✓ Can handle 'ca"' starting on the closing quote (50ms)

    ✓ Can handle 'ci"' with complex escape sequences (61ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (85ms)

    ✓ will fail when ca" ahead of quoted string (54ms)

    ✓ Can handle 'ca`' inside word (48ms)

    ✓ can handle cj (66ms)

    ✓ can handle ck (79ms)

    ✓ can handle c2j (106ms)

    ✓ can handle c2k (105ms)

    ✓ can handle cj on last line (60ms)

    ✓ can handle ck on first line (71ms)

    ✓ can handle c2j on last line (99ms)

    ✓ can handle c2k on first line (63ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (68ms)

    ✓ Can handle 'daw' on word with trailing spaces (84ms)

    ✓ Can handle 'daw' on word with leading spaces (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix (236ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (96ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (59ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (140ms)

    ✓ Can handle 'daw' on end of word (194ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (53ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (62ms)

    ✓ Can handle 'daw' on word at beginning of file (87ms)

    ✓ Can handle 'daw' on word at beginning of line (65ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (73ms)

    ✓ Can handle 'daw' around word at end of line (38ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (46ms)

    ✓ Can handle 'daW' around word at whitespace (40ms)

    ✓ Can handle 'daW' on word with trailing spaces (89ms)

    ✓ Can handle 'daW' on word with leading spaces (53ms)

    ✓ Can handle 'daW' on word with numeric prefix

    ✓ Can handle 'daW' on word with numeric prefix and across lines (97ms)

    ✓ Can handle 'daW' on beginning of word (104ms)

    ✓ Can handle 'daW' on end of one line (43ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (46ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (68ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (60ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (85ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (181ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (42ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (180ms)

    ✓ Can handle 'diw' on word (51ms)

    ✓ Can handle 'diw' on word with numeric prefix (45ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (110ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (127ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (90ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (116ms)

    ✓ Can handle 'diW' on word with trailing spaces (82ms)

    ✓ Can handle 'diW' on word with leading spaces (70ms)

    ✓ Can handle 'diW' on word with numeric prefix (69ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (93ms)

    ✓ Can handle 'diW' on beginning of word (46ms)

    ✓ Can handle d} (55ms)

    ✓ Can handle y} at beginning of line

    ✓ Select sentence with trailing spaces (82ms)

    ✓ Select sentence with leading spaces (88ms)

    ✓ Select inner sentence with trailing spaces (56ms)

    ✓ Select inner sentence with leading spaces (85ms)

    ✓ Select spaces between sentences (126ms)

    ✓ Can handle 'df' (50ms)

    ✓ Can handle 'dt' (47ms)

    ✓ Can handle backspace (45ms)

    ✓ Can handle backspace across lines (41ms)

    ✓ Can handle A and backspace

    ✓ Can handle 'yy' without changing cursor position (47ms)

    ✓ Can handle 'P' after 'yy' (117ms)

    ✓ Can handle 'p' after 'yy' (42ms)

    ✓ Can handle 'P' after 'Nyy' (66ms)

    ✓ Can handle 'p' after 'Nyy' (58ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (48ms)

    ✓ Can handle 'gp' after 'yy' (59ms)

    ✓ Can handle 'gp' after 'Nyy' (57ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (40ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (91ms)

    ✓ Can handle 'gP' after 'yy' (42ms)

    ✓ Can handle 'gP' after 'Nyy' (66ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (51ms)

    ✓ Can handle ']p' after yy (84ms)

    ✓ Can handle ']p' after 'Nyy' (55ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (100ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (47ms)

    ✓ Can handle '[p' after yy (68ms)

    ✓ Can handle '[p' after 'Nyy' (166ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (65ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (70ms)

    ✓ Can handle 'p' after y'a (47ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (54ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (72ms)

    ✓ Can handle pasting in visual mode over selection (113ms)

    ✓ Can repeat w

    ✓ Can repeat p

    ✓ I works correctly (69ms)

    ✓ gI works correctly (95ms)

    ✓ gi works correctly (93ms)

    ✓ `. works correctly (80ms)

    ✓ '. works correctly (77ms)

    ✓ g; works correctly (81ms)

    ✓ g, works correctly (75ms)

    ✓ g_ works correctly (95ms)

    ✓ 3g_ works correctly (65ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (256ms)

    ✓ gq handles spaces before single line comments correctly (222ms)

    ✓ gq handles tabs before single line comments correctly (453ms)

    ✓ Can handle space

    ✓ Can handle space (83ms)

    ✓ Undo 1 (98ms)

    ✓ Undo 2 (61ms)

    ✓ Undo cursor (111ms)

    ✓ Undo cursor 2 (104ms)

    ✓ Undo cursor 3 (88ms)

    ✓ Undo with movement first (111ms)

    ✓ Can handle 'U' (49ms)

    ✓ Can handle 'U' for multiple changes (150ms)

    ✓ Can handle 'U' for new line below (137ms)

    ✓ Can handle 'U' for new line above (77ms)

    ✓ Can handle 'U' for consecutive changes only (130ms)

    ✓ Can handle 'u' to undo 'U' (63ms)

    ✓ Can handle 'U' to undo 'U' (86ms)

    ✓ Can handle 'u' after :s/abc/def (139ms)

    ✓ Redo (74ms)

    ✓ Redo (84ms)

    ✓ Redo (75ms)

    ✓ Can handle u (85ms)

    ✓ Can handle guw (57ms)

    ✓ Can handle gUw (53ms)

    ✓ Can handle u over line breaks (51ms)

    ✓ can handle s in visual mode (86ms)

    ✓ can handle p with selection (58ms)

    ✓ can handle P with selection (70ms)

    ✓ can handle p in visual to end of line (103ms)

    ✓ can repeat backspace twice (118ms)

    ✓ can delete linewise with d2G (131ms)

    ✓ can delete with + motion and count

    ✓ can delete with - motion and count (58ms)

    ✓ can dE correctly (71ms)

    ✓ can dE correctly (47ms)

    ✓ can dE correctly (100ms)

    ✓ can ctrl-a correctly behind a word

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (108ms)

    ✓ can ctrl-a on word (190ms)

    ✓ can ctrl-a on a hex number (173ms)

    ✓ can ctrl-a on decimal (197ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a with numeric prefix (225ms)

    ✓ can ctrl-a on a decimal (106ms)

    ✓ can ctrl-a on an octal  (223ms)

    ✓ Correctly increments in the middle of a number (153ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-x correctly behind a word (223ms)

    ✓ can ctrl-a on an number with word before  (61ms)

    ✓ can ctrl-a on an number with word before and after  (77ms)

    ✓ can ctrl-x on a negative number with word before and after  (81ms)

    ✓ can ctrl-a properly on multiple lines (61ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (77ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (53ms)

    ✓ can <C-a> on word with - in front of it (67ms)

    ✓ can do Y

    ✓ Can do S (128ms)

    ✓ / does not affect mark (42ms)

    ✓ / can search with regex (156ms)

    ✓ / can search with newline (197ms)

    ✓ / can search through multiple newlines (67ms)

    ✓ / matches ^ per line (50ms)

    ✓ / matches $ per line (74ms)

    ✓ Can search for forward slash (93ms)

    ✓ Can search backward for question mark (59ms)

    ✓ /\c forces case insensitive search (97ms)

    ✓ /\C forces case sensitive search (56ms)

    ✓ <BS> deletes the last character in search in progress mode (88ms)

    ✓ <S-BS> deletes the last character in search in progress mode (107ms)

    ✓ <C-h> deletes the last character in search in progress mode (39ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (115ms)

    ✓ Ignores cit on a non-matching tag (108ms)

    ✓ Ignores cit on a nested tag (156ms)

    ✓ Can do cit on a tag with an attribute tag (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cat on a matching tag (225ms)

    ✓ Can do cit on a multiline tag (219ms)

    ✓ Can do cit on a multiline tag with nested tags (75ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (84ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (67ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (79ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (68ms)

    ✓ can do cit with self closing tags (91ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Respects indentation with cc (227ms)

    ✓ Resets cursor to indent end with cc (159ms)

    ✓ can handle 'cc' on empty line (200ms)

    ✓ cc copies linewise (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Indent current line with correct Vim Mode (227ms)

    ✓ Can handle <Esc> and do nothing (156ms)

    ✓ Can handle # on consecutive words (216ms)

    ✓ Can handle # on skipped words (133ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ cc on whitespace-only treats whitespace as indent (220ms)

    ✓ Can do cai (173ms)

    ✓ Can do cii (46ms)

    ✓ Can do caI (103ms)

    ✓ Can do dai (221ms)

    ✓ Can do dii (46ms)

    ✓ Can do daI (94ms)

    ✓ `] go to the end of the previously operated or put text (66ms)

    ✓ '] go to the end of the previously operated or put text (84ms)

    ✓ `[ go to the start of the previously operated or put text (122ms)

    ✓ '[ go to the start of the previously operated or put text (69ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (219ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (68ms)

    can handle gn

      ✓ gn selects the next match text (335ms)

      ✓ gn selects the current word at |hello (135ms)

      ✓ gn selects the current word at h|ello (228ms)

      ✓ gn selects the current word at hel|lo (219ms)

      ✓ gn selects the current word at hell|o (279ms)

      ✓ gn selects the next word at hello| (139ms)

    can handle dgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the next match text (from first line) (232ms)

      ✓ dgn deletes the current word when cursor is at |hello (150ms)

      ✓ dgn deletes the current word when cursor is at h|ello (259ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (172ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at hell|o (252ms)

      ✓ dgn deletes the next word when cursor is at hello| (195ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (168ms)

      ✓ cgn deletes the current word when cursor is at |hello (112ms)

      ✓ cgn deletes the current word when cursor is at h|ello (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hel|lo (246ms)

      ✓ cgn deletes the current word when cursor is at hell|o (171ms)

      ✓ cgn deletes the next word when cursor is at hello| (212ms)

    can handle gN

      ✓ gN selects the previous match text (166ms)

      ✓ gN selects the current word at hell|o (229ms)

      ✓ gN selects the current word at hel|lo (156ms)

      ✓ gN selects the current word at h|ello (207ms)

      ✓ gN selects the current word at |hello (180ms)

      ✓ gN selects the previous word at | hello (184ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (85ms)

      ✓ dgN deletes the current word when cursor is at hell|o (184ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at h|ello (241ms)

      ✓ dgN deletes the current word when cursor is at |hello (180ms)

      ✓ dgN deletes the previous word when cursor is at | hello (222ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the current word when cursor is at hell|o (239ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (149ms)

      ✓ cgN deletes the current word when cursor is at h|ello (277ms)

      ✓ cgN deletes the current word when cursor is at |hello (177ms)

      ✓ cgN deletes the previous word when cursor is at | hello (239ms)

  Mode Replace

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can activate with <Insert> from Insert mode (183ms)

    ✓ Can activate with R from Normal mode (40ms)

    ✓ Can handle R (63ms)

    ✓ Can handle R past current line (73ms)

    ✓ Can handle R and exit Replace Mode (139ms)

    ✓ Can handle R across lines (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle R across lines and exit Replace Mode (404ms)

    ✓ Can handle R with {count} (178ms)

    ✓ Can handle backspace (221ms)

    ✓ Can handle backspace (234ms)

    ✓ Can handle backspace across lines (179ms)

    ✓ Can handle arrows (203ms)

    ✓ Can handle . (118ms)

    ✓ Can handle . across lines (285ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (168ms)

    ✓ Can handle wd (126ms)

    ✓ Can handle x (131ms)

    ✓ Can handle x across a selection (141ms)

    ✓ Can do vwd in middle of sentence (150ms)

    ✓ Can do vwd in middle of sentence (156ms)

    ✓ Can do vwd multiple times (155ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (94ms)

    ✓ Can handle H key (197ms)

    ✓ Can handle backspace key (123ms)

    ✓ handles case where we delete over a newline (100ms)

    ✓ handles change operator (104ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vat on multiple matching tags (151ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (245ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (196ms)

    ✓ Repeat-prefixed vat does not bleed below (205ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (46ms)

    ✓ Can do vi) on a matching parenthesis (56ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vi) on multiple matching parens (230ms)

    ✓ Can do va) on a matching parenthesis (134ms)

    ✓ Can do va) on multiple matching parens (84ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (61ms)

    ✓ Repeat-prefixed va) does not bleed below (221ms)

    ✓ Can do va} on a matching bracket as first character (55ms)

    ✓ Can do va} on multiple matching brackets (62ms)

    ✓ Can do vi( on a matching bracket near first character (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vi{ on outer pair of nested braces (315ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (45ms)

    ✓ Can do va] on multiple matching brackets (71ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (288ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Repeat-prefixed vaf does not bleed below (234ms)

    ✓ vaf only expands to enclosing pairs (51ms)

    ✓ Can use . to repeat indent in visual (109ms)

    ✓ Can do v_x to delete to first char (203ms)

    ✓ Can do vg_x to delete to last char with no EOL (58ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v3g_x to delete to last char with no EOL with count (245ms)

    ✓ Can do v$x to delete to last char including EOL (52ms)

    ✓ Can do gv to reselect previous selection (72ms)

    Vim's EOL handling is weird

      ✓ delete through eol (61ms)

      ✓ join 2 lines by deleting through eol (107ms)

      ✓ d$ doesn't delete whole line (115ms)

      ✓ vd$ does delete whole line (51ms)

      ✓ Paste over selection copies the selection (119ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Paste over selection copies the selection linewise (248ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (130ms)

      ✓ Can handle <down> key (231ms)

      ✓ Can handle <left> key (86ms)

      ✓ Can handle <right> key (185ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (195ms)

      ✓ Can handle 'gj' (69ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (231ms)

      ✓ Can handle 'vawd' on word with leading spaces (141ms)

      ✓ Can handle 'vawd' on word with numeric prefix (78ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (82ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (233ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (145ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (79ms)

      ✓ Can handle 'vaWd' on word with leading spaces (58ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (106ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (132ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (242ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (167ms)

      ✓ Can handle 'vaWd' on word with leading spaces (205ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (113ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (150ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (213ms)

      ✓ Can handle 'vawd' on word with trailing spaces (185ms)

      ✓ Can handle 'vawd' on word with leading spaces (200ms)

      ✓ Can handle 'vawd' on word with numeric prefix (50ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (235ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (100ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (128ms)

      ✓ Can handle 'vaWd' on word with leading spaces (203ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (416ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (88ms)

      ✓ Can handle 'Y' in visual mode (236ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (239ms)

      ✓ Select multiple sentences in visual mode (156ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (208ms)

      ✓ Select inner sentence with leading spaces in visual mode (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select spaces between sentences in visual mode (233ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (183ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (203ms)

      ✓ Can do vat on a matching tag (191ms)

    handles replace in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do a single line replace (239ms)

      ✓ Can do a multi line replace (110ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (230ms)

      ✓ D deletes the current line (187ms)

    handles indent blocks in visual mode

      ✓ Can do vai (204ms)

      ✓ Can do vii (51ms)

      ✓ Doesn't naively select the next line (46ms)

      ✓ Searches backwards if cursor line is empty (90ms)

      ✓ Can do vaI (134ms)

    visualstar

      ✓ Works with * (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with #

    search works in visual mode

      ✓ Works with / (60ms)

      1) Works with ?

      ✓ Selects correct range (128ms)

    X will delete linewise

      ✓ normal selection (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (215ms)

    C will delete linewise

      ✓ normal selection (126ms)

      ✓ normal selection (127ms)

    R will delete linewise

      ✓ normal selection (114ms)

      ✓ normal selection (212ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (178ms)

      ✓ upward selection (86ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (61ms)

      ✓ multiline indent bottom up selection (46ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent top down selection (503ms)

      ✓ repeat multiline indent bottom up selection (159ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (204ms)

      ✓ multiline outdent bottom up selection (189ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline outdent top down selection (238ms)

      ✓ repeat multiline outdent bottom up selection (142ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (166ms)

    vi{ will go to end of second to last line

      ✓ select (233ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode (64ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (541ms)

      ✓ gv selects the last pasted text (which is longer than original) (287ms)

      ✓ gv selects the last pasted text (multiline) (129ms)

    can handle gn

      ✓ gn selects the next match text (133ms)

      ✓ gn selects the current word at |hello (177ms)

      ✓ gn selects the current word at h|ello (150ms)

      ✓ gn selects the current word at hel|lo (213ms)

      ✓ gn selects the next word at hell|o (123ms)

      ✓ gn selects the next word at hello| (205ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (45ms)

      ✓ multiline insert from top down selection (51ms)

      ✓ skips blank lines (67ms)

    can append text with A

      ✓ multiline append from bottom up selection (49ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (273ms)

      ✓ skips blank lines (143ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (286ms)

      ✓ U/gU across a selection (164ms)

      ✓ U/gU across a selection (reverse) (184ms)

      ✓ u/gu on single character (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ u/gu across a selection (311ms)

      ✓ u/gu across a selection (reverse) (118ms)

  Mode Visual Block

    ✓ can be activated (44ms)

    ✓ Can handle A forward select (76ms)

    ✓ Can handle A backwards select (258ms)

    ✓ Can handle I forward select (134ms)

    ✓ Can handle I backwards select (181ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (125ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (219ms)

    ✓ Can handle c forward select (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle c backwards select (260ms)

    ✓ Can handle C (110ms)

    ✓ Can do a multi line replace (235ms)

    ✓ Can handle 'D' (131ms)

    ✓ Can handle 'gj' (146ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Properly add to end of lines j then $ (257ms)

    ✓ Properly add to end of lines $ then j (184ms)

    ✓ o works in visual block mode (221ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (150ms)

  Mode Visual Line

    ✓ can be activated

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle w (414ms)

    ✓ Can handle wd (117ms)

    ✓ Can handle x (94ms)

    ✓ Can handle x across a selection (72ms)

    ✓ Can do vwd in middle of sentence (88ms)

    ✓ Can do vwd in middle of sentence (142ms)

    ✓ Can do vwd multiple times (149ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (128ms)

    ✓ handles case where we delete over a newline (158ms)

    ✓ handles change operator (131ms)

    ✓ Vp updates register content (195ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (first line) (234ms)

    ✓ Vp does not append unnecessary newlines (middle line) (133ms)

    ✓ Vp does not append unnecessary newlines (last line) (229ms)

    Vim's EOL handling is weird

      ✓ delete through eol (63ms)

      ✓ join 2 lines by deleting through eol (133ms)

      ✓ d$ doesn't delete whole line (48ms)

      ✓ vd$ does delete whole line (52ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (75ms)

      ✓ Can handle <down> key (221ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'gj' (231ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (56ms)

      ✓ Can handle d key (109ms)

      ✓ Can handle d key (39ms)

      ✓ Can handle d key (38ms)

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (68ms)

      ✓ Can do a multi visual line replace (52ms)

      ✓ Can do a multi visual line replace from the bottom up (78ms)

    search works in visual line mode

      ✓ Works with / (69ms)

      ✓ Works with ? (103ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (318ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (91ms)

      ✓ linewise visual put works also in the end of document (40ms)

      ✓ gv selects the last pasted text (which is shorter than original) (240ms)

      ✓ gv selects the last pasted text (which is longer than original) (336ms)

      ✓ gv selects the last pasted text (multiline) (102ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (38ms)

      ✓ skips blank lines (96ms)

    can append text with A

      ✓ multiline append from bottom up selection (181ms)

      ✓ multiline append from top down selection (66ms)

      ✓ skips blank lines (45ms)

  Mode Normal

    ✓ Can handle 'x' (67ms)

    ✓ Can handle 'Nx' (63ms)

    ✓ Can handle 'Nx' and paste (53ms)

    ✓ Can handle 'x' at end of line (193ms)

    ✓ Can handle 'Ns' (79ms)

    ✓ Can handle 'Ns' at end of line (67ms)

    ✓ Can handle '<Del>' (41ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (49ms)

    ✓ Can handle '<Del>' at end of line (106ms)

    ✓ Can handle 'cc' (52ms)

    ✓ Can handle 'Ncc' (88ms)

    ✓ Can handle 'yy' (58ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' (237ms)

    ✓ Can handle 'D' on empty lines (47ms)

    ✓ Can handle 'DD' (49ms)

    ✓ Can handle 'C' (80ms)

    ✓ Can handle 'NC' (47ms)

    ✓ Can handle 'NC' and put (101ms)

    ✓ Can handle 'r'

    ✓ Can handle '<Count>r' (114ms)

    ✓ Can handle '<Count>r'

    ✓ Can handle 'r' after 'dd' (135ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'r
' (230ms)

    ✓ Can handle '<Count>r
' (63ms)

    ✓ Can handle 'J' once (40ms)

    ✓ Can handle 'J' twice (78ms)

    ✓ Can handle 'J' with empty last line (73ms)

    ✓ Can handle 'J's with multiple empty last lines (212ms)

    ✓ Can handle 'J' with leading white space on next line (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with only white space on next line (610ms)

    ✓ Can handle 'J' with TWO indented lines

    ✓ Can handle 'J' with ')' first character on next line (53ms)

    ✓ Can handle 'J' with a following delete (71ms)

    ✓ Can handle 'J' in Visual Line mode (61ms)

    ✓ Can handle 'gJ' once (200ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (174ms)

    ✓ Can handle '~' (205ms)

    ✓ Can handle 'g~{motion}' (269ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<BS>' in insert mode

    ✓ Can handle undo with P (224ms)

    ✓ Can handle 'ge' in multiple lines case1 (133ms)

    ✓ Can handle 'ge' in multiple lines case2 (67ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (183ms)

    ✓ Can repeat '~' with dot (127ms)

    ✓ Can repeat 'x' (198ms)

    ✓ Can repeat 'J' (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle dot with A (257ms)

    ✓ Can handle dot with I (252ms)

    ✓ Can repeat actions that require selections (124ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (55ms)

    ✓ Can repeat insert change and '<C-t>' (118ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat change by `<C-a>` (268ms)

    ✓ Only one arrow key can be repeated in Insert Mode (145ms)

    ✓ Cached content change will be cleared by arrow keys (250ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (132ms)

    ✓ inside parenthesis (113ms)

    ✓ nested parenthesis beginning (111ms)

    ✓ nested parenthesis end

    ✓ nested bracket and parenthesis beginning

    ✓ nested bracket, parenthesis, braces beginning (151ms)

    ✓ nested bracket, parenthesis, braces end (163ms)

    ✓ parentheses after > (51ms)

    ✓ parentheses after " (40ms)

  Motions in Normal Mode

    ✓ Can handle [( (86ms)

    ✓ Can handle nested [( (102ms)

    ✓ Can handle <number>[( (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle [( and character under cursor exclusive (220ms)

    ✓ Can handle ]) (181ms)

    ✓ Can handle nested ]) (121ms)

    ✓ Can handle <number>]) (144ms)

    ✓ Can handle ]) and character under cursor exclusive (203ms)

    ✓ Can handle [{ (188ms)

    ✓ Can handle nested [{ (119ms)

    ✓ Can handle <number>[{ (104ms)

    ✓ Can handle [{ and character under cursor exclusive (49ms)

    ✓ Can handle ]} (103ms)

    ✓ Can handle nested ]}

    ✓ Can handle <number>]} (96ms)

    ✓ Can handle ]} and character under cursor exclusive (131ms)

    ✓ Can handle 'ge' (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gg' (222ms)

    ✓ Can handle 'gg' to first non blank char on random line (193ms)

    ✓ Can handle 'gg' to first non blank char on first line (151ms)

    ✓ 'gg' obeys startofline (148ms)

    ✓ Retain same column when moving up/down (139ms)

    ✓ Can handle <enter> (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ $ always keeps cursor on EOL (139ms)

    ✓ Can handle $ with a count (68ms)

    ✓ Can handle $ with a count at end of file (58ms)

    ✓ Can handle <End> with a count (127ms)

    ✓ Can handle <D-right> with a count (159ms)

    ✓ Can handle 'f' (147ms)

    ✓ Can handle 'f' twice (67ms)

    ✓ Can handle 'f' with <tab> (65ms)

    ✓ Can handle 'f' and find back search (48ms)

    ✓ Can handle 'F' (183ms)

    ✓ Can handle 'F' twice (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' and find back search (220ms)

    ✓ Can handle 'f' and multiple back searches (148ms)

    ✓ Can handle 't' (194ms)

    ✓ Can handle 't' twice (49ms)

    ✓ Can handle 't' and find back search (83ms)

    ✓ Can handle 'T' (161ms)

    ✓ Can handle 'T' twice (109ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'T' and find back search (220ms)

    ✓ Can run a forward search (48ms)

    ✓ Can run a forward and find next search (62ms)

    ✓ Can run a forward and find previous search from end of word (216ms)

    ✓ Can run a reverse search (320ms)

    ✓ Can run a reverse and find next search (61ms)

    ✓ cancelled search reverts to previous search state (66ms)

    ✓ Backspace on empty search cancels (74ms)

    ✓ Search offsets: b does nothing (218ms)

    ✓ Search offsets: b2 goes 2 to the right (63ms)

    ✓ Search offsets: b+3 goes 3 to the right (46ms)

    ✓ Search offsets: e goes to the end (39ms)

    ✓ Search offsets: character offset goes across line boundaries (50ms)

    ✓ Search offsets: 2 goes 2 down

    ✓ Search offsets: -2 goes 2 up (39ms)

    ✓ maintains column position correctly (113ms)

    ✓ maintains column position correctly with $ (106ms)

    ✓ Can handle G  (132ms)

    ✓ Can handle G with number prefix (51ms)

    ✓ Can handle G with number prefix (53ms)

    ✓ Can handle gg (75ms)

    ✓ Can handle gg with number prefix (51ms)

    ✓ Can handle 0 (57ms)

    ✓ Can handle 0 as part of a repeat (75ms)

    ✓ Can handle g* (51ms)

    ✓ Can handle g*n (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle * (398ms)

    ✓ Can handle **

    ✓ Can handle # on whitespace

    ✓ Can handle # on EOL (47ms)

    ✓ Can handle g# (69ms)

    ✓ Can handle g#n (70ms)

    ✓ Can handle # (126ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (54ms)

    ✓ * adds to search history

    ✓ # adds to search history (80ms)

    ✓ Can handle | (49ms)

    ✓ Can handle <number> | (47ms)

    ✓ Can handle + (71ms)

    ✓ Can handle + indent (45ms)

    ✓ Can handle + with count prefix (94ms)

    ✓ Can handle -

    ✓ Can handle - indent (60ms)

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix (172ms)

    ✓ Can handle <up> key

    ✓ Can handle <down> key (71ms)

    ✓ Can handle <left> key

    ✓ Can handle <right> key (38ms)

    ✓ Can handle 'gk' (76ms)

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin
    ✓ line end
    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

      ✓ move to word right

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right
      ✓ move to end of current word right
      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph
      ✓ move up longer paragraph
      ✓ move up starting inside empty line

  motion line wrapping
    whichwrap enabled
      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (48ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line

      insert mode

        ✓ <left> wraps to previous line (43ms)

        ✓ <right> once goes to end of line (81ms)

        ✓ <right> twice wraps to next line (38ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ l does not wrap to next line (218ms)

        ✓ <left> does not wrap to previous line

        ✓ <right> does not wrap to next line (68ms)

      insert mode

        ✓ <left> does not wrap to previous line (65ms)

        ✓ <right> does not wrap to next line (61ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (186ms)

      ✓ search wraps around the start of the file (184ms)

    wrapscan disabled

      ✓ search stops at the end of the file (62ms)

      ✓ search stops at the start of the file (69ms)

  Multicursor

    ✓ can add multiple cursors below (65ms)

    ✓ can add multiple cursors above (202ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip

  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (239ms)

    ✓ gcj comments in current and next line (217ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (570ms)

    ✓ block comment in Visual Mode (223ms)

    ✓ comment in visual line mode (55ms)

    ✓ comment in visual block mode (215ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (392ms)

    ✓ =$ formats entire line (210ms)

    ✓ =j formats two lines (191ms)

    ✓ 3=k formats three lines (183ms)

    ✓ =gg formats to top of file (210ms)

    ✓ =G formats to bottom of file (122ms)

    ✓ =ip formats paragraph (74ms)

    ✓ format in visual mode (73ms)

  put operator

    ✓ basic put test (162ms)

    ✓ test yy end of line (49ms)

    ✓ test yy first line (39ms)

    ✓ test yy middle line (115ms)

    ✓ test yy with correct positon movement (203ms)

    ✓ test visual block single line yank p (159ms)

    ✓ test visual block single line yank P (121ms)

    ✓ test visual block single line delete p (154ms)

    ✓ test visual block single line delete P (83ms)

  rot13 operator

    ✓ rot13() unit test

    2) g?j works

    ✓ g? in visual mode works (134ms)

    ✓ g? in visual line mode works (172ms)

    ✓ g? in visual block mode works (133ms)

  shift operator

    ✓ basic shift left test (61ms)

    ✓ shift left goto end test (52ms)

    ✓ shift left goto line test (52ms)

    ✓ shift right goto end test (180ms)

    ✓ shift right goto line test (96ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (78ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (209ms)

      ✓ step to Camel word (175ms)

      ✓ step to CAP word (67ms)

      ✓ step after CAP word (63ms)

      ✓ step from middle of word to Camel word (212ms)

      ✓ step to number word (139ms)

      ✓ step to operator word (152ms)

      ✓ step from inside operator word (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step to operator and then over (219ms)

    handles <leader>w for underscore_var

      ✓ step to _word (111ms)

      ✓ step over whitespace to word (111ms)

      ✓ step from inside word to _word (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step form _word to number (179ms)

      ✓ step from nubmer word to _word (180ms)

      ✓ step from in whitespace to word (64ms)

      ✓ step in ALL_CAPS_WORD (47ms)

    handles d<leader>w

      ✓ delete from start of camelWord (87ms)

      ✓ delete from middle of camelWord (153ms)

      ✓ delete from start of CamelWord (157ms)

      ✓ delete two words from camelWord (190ms)

      ✓ delete from start of underscore_word (115ms)

      ✓ delete from middle of underscore_word (130ms)

      ✓ delete two words from camel_word (51ms)

    handles di<leader>w

      ✓ delete from start of camelWord (132ms)

      ✓ delete from middle of camelWord (104ms)

      ✓ delete from start of CamelWord (54ms)

      ✓ delete two words from camelWord (57ms)

      ✓ delete from start of underscore_word (61ms)

      ✓ delete from middle of underscore_word (140ms)

      ✓ delete two words from camel_word (222ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    handles <leader>b

      ✓ back from middle of word (73ms)

      ✓ back over whitespace to camelWord (197ms)

      ✓ back twice over operator (172ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ from middle to end of underscore_word (214ms)

      ✓ twice to end of word over operator (179ms)

  easymotion plugin

    ✓ Can handle s move (230ms)

    ✓ Can handle 2s move (66ms)

    ✓ Can handle f move (115ms)

    ✓ Can handle 2f move (55ms)

    ✓ Can handle F move (66ms)

    ✓ Can handle 2F move (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle t move (219ms)

    ✓ Can handle bd-t move (94ms)

    ✓ Can handle 2t move (215ms)

    ✓ Can handle bd-t2 move (86ms)

    ✓ Can handle T move (63ms)

    ✓ Can handle 2T move (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle w move (201ms)

    ✓ Can handle bd-w move (74ms)

    ✓ Can handle b move (78ms)

    ✓ Can handle e move

    ✓ Can handle bd-e move (135ms)

    ✓ Can handle ge move (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle n-char move (309ms)

    ✓ Can handle j move (96ms)

    ✓ Can handle k move (232ms)

    ✓ Can handle bd-jk move (1) (74ms)

    ✓ Can handle bd-jk move (2) (209ms)

    ✓ Can handle lineforward move (1) (192ms)

    ✓ Can handle lineforward move (2) (192ms)

    ✓ Can handle linebackward move (1) (152ms)

    ✓ Can handle linebackward move (2) (153ms)

    ✓ Can handle searching for backslash (\) (134ms)

    ✓ Can handle searching for carat (^) (210ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for dot (.) (179ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (108ms)

    ✓ Replaces within inner Word (171ms)

    ✓ Replaces within '' (112ms)

    ✓ Replaces within '' including spaces (184ms)

    ✓ Replaces within () (180ms)

    ✓ Replaces within () including spaces (128ms)

    ✓ Replaces within a paragraph (131ms)

    ✓ Replaces using a specified register (51ms)

    ✓ Replaces within {} over multiple lines (69ms)

    ✓ Replaces a multiline register within {} over multiple lines (61ms)

    ✓ Replaces a multiline register within {} over multiple lines (63ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (142ms)

    ✓ grr replaces the entire line with the register (75ms)

    ✓ grr can replace multiple lines (214ms)

    ✓ Replaces in visual mode (133ms)

    ✓ Replaces in visual mode using a specified register (201ms)

    ✓ Replaces in visual line mode (104ms)

    ✓ grj is linewise (113ms)

  sneak plugin

    ✓ Can handle s motion (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle S motion (243ms)

    ✓ Can handle <operator>z motion (206ms)

    ✓ Can handle <operator>Z motion (114ms)

    ✓ Can handle s; motion (210ms)

    ✓ Can handle s, motion (61ms)

    ✓ Can handle S; motion (119ms)

    ✓ Can handle S, motion (50ms)

    ✓ Can handle single letter s motion (43ms)

    ✓ Can handle single letter S motion (142ms)

    ✓ Can handle single letter <operator>z motion (147ms)

    ✓ Can handle single letter <operator>Z motion (152ms)

    ✓ Can handle single letter s; motion (176ms)

    ✓ Can handle single letter s, motion (185ms)

    ✓ Can handle single letter S; motion (169ms)

    ✓ Can handle single letter S, motion (51ms)

    ✓ Can handle multiline single char <number>s motion (136ms)

  surround plugin

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw)' surrounds word without space (162ms)

    ✓ 'ysiw(' surrounds word with space (186ms)

    ✓ 'ysw)' surrounds word without space (163ms)

    ✓ 'ysw(' surrounds word with space (144ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysaw)' surrounds word without space (205ms)

    ✓ 'ysaw(' surrounds word with space (125ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (114ms)

    ✓ 'ysiw<' surrounds word with tags (107ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (80ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (85ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (222ms)

    ✓ change surround (112ms)

    ✓ change surround with two pairs of quotes (158ms)

    ✓ change surround with two pairs of parens (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with alias (178ms)

    ✓ change surround to tags (83ms)

    ✓ delete surround (152ms)

    ✓ delete surround with quotes (139ms)

    ✓ delete surround with nested of quotes (212ms)

    ✓ delete surround with inconsistent quotes (146ms)

    ✓ delete surround with mixed quotes (130ms)

    ✓ delete surround with empty quotes cursor at start (127ms)

    ✓ delete surround with empty quotes cursor at end (138ms)

    ✓ don't delete surround if cursor is after closing match (78ms)

    ✓ delete surround if cursor is before opening match (106ms)

    ✓ delete surround with two pairs of parens (105ms)

    ✓ delete surround with alias (106ms)

    ✓ delete surround with tags (193ms)

    ✓ change surround brackets at end of line (122ms)

    ✓ changing brackets with surround works again (194ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with tags that contain an attribute and preserve them (242ms)

    ✓ change surround with tags that contain an attribute and remove them (209ms)

  register

    ✓ Can copy to a register (258ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use two registers together (586ms)

    ✓ Can use black hole register (65ms)

    ✓ System clipboard works with chinese characters (58ms)

    ✓ Yank stores text in Register '0' (183ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (192ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (137ms)

    ✓ Register '1'-'9' stores delete content (265ms)

    ✓ "A appends linewise text to "a (200ms)

    ✓ "A appends character wise text to "a (259ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (145ms)

    ✓ Small deletion using Del is stored in small delete register (108ms)

    ✓ Small deletion using X is stored in small delete register (164ms)

    ✓ Search register (/) is set by forward search (206ms)

    ✓ Search register (/) is set by backward search (205ms)

    ✓ Search register (/) is set by star search (252ms)

    ✓ Command register (:) is set by command line (70ms)

    ✓ Read-only registers cannot be written to (150ms)

    clipboard

      ✓ Can access '*' (clipboard) register (161ms)

      ✓ Can access '+' (clipboard) register (187ms)

  Repeatable movements with f and t

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat f<character> (298ms)

    ✓ Can repeat reversed F<character> (51ms)

    ✓ Can repeat t<character> (190ms)

    ✓ Can repeat N times reversed t<character>

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (119ms)

      ✓ move one sentence backward (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move [count] sentences backward (289ms)

      ✓ move one sentence backward single line - middle (121ms)

      ✓ move one sentence backward no space (190ms)

      ✓ move one sentence backward no space - middle (57ms)

      ✓ move one sentence backward - multiline (68ms)

      ✓ move one sentence backward - multiline - period (181ms)

      ✓ move one sentence backward - multiline - previous line (69ms)

      ✓ move one sentence backward - multiline - previous line - period (160ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path
    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1303 passing (4m)

  4 pending

  2 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:920:5)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=abc.
      + expected - actual

      -abc
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:29:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T05:42:50.430Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (42ms)

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line

    ✓ <C-p>/<C-n> go to the previous/next command (45ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (76ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (61ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (56ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (51ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma

    ✓ can lex percent

    ✓ can lex dollar

    ✓ can lex dot

    ✓ can lex one number

    ✓ can lex longer number

    ✓ can lex plus

    ✓ can lex minus

    ✓ can lex forward search

    ✓ can lex forward search escaping

    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args

    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (1014ms)

  command-line parser

    ✓ can parse empty string

    ✓ can parse left - dot

    ✓ can parse left - dollar
    ✓ can parse left - percent
    ✓ can parse separator - comma

    ✓ can parse right - dollar

  command line scanner

    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (532ms)

    ✓ :smile editor contains smile text (533ms)

  Basic sort

    ✓ Sort whole file, asc (71ms)

    ✓ Sort whole file, asc, ignoreCase (76ms)

    ✓ Sort whole file, dsc (75ms)

    ✓ Sort whole file, dsc, ignoreCase (70ms)

    ✓ Sort range, asc (136ms)

    ✓ Sort range, asc, ignoreCase (105ms)

    ✓ Sort range, dsc (95ms)

    ✓ Sort range, dsc, ignoreCase (110ms)

    ✓ Sort whole file, asc, unique (101ms)

  Horizontal split

    ✓ :sp creates a second split (66ms)

    ✓ :split creates a second split (73ms)

    ✓ :new creates a second split (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !
    ✓ throws if space before !
    ✓ ignores space after !

    ✓ throws if bad input
  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (62ms)

    ✓ Replace with `g` flag

    ✓ Replace with flags AND count (62ms)

    ✓ Replace with `c` flag

    ✓ Replace with `gc` flag (69ms)

    ✓ Replace across all lines (174ms)

    ✓ Replace on specific single line (66ms)

    ✓ Replace on current line using dot (55ms)

    ✓ Replace single relative line using dot and plus (110ms)

    ✓ Replace across specific line range (100ms)

    ✓ Replace across relative line range using dot, plus, and minus (74ms)

    ✓ Replace across relative line range using numLines+colon shorthand (127ms)

    ✓ Repeat replacement across relative line range (106ms)

    ✓ Replace with range AND count but no flags (65ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (62ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (80ms)

    ✓ Undocumented: trailing operators use 1 as RHS (85ms)

    ✓ Replace specific single equal lines (53ms)

    ✓ Replace current line with no active selection (52ms)

    ✓ Replace text in selection (87ms)

    ✓ Substitute support marks (91ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line

      ✓ Replace with `g` flag inverts global flag (44ms)

      ✓ Replace with `c` flag inverts global flag (64ms)

      ✓ Replace multiple lines (78ms)

      ✓ Replace across specific lines (46ms)

      ✓ Replace current line with no active selection (63ms)

      ✓ Replace text in selection (171ms)

      ✓ Substitute support marks (61ms)

      ✓ Substitute with escaped delimiter

    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (146ms)

      ✓ Substitute with previous search using # (137ms)

      ✓ Substitute with previous search using / (165ms)

      ✓ Substitute with parameters should update search state (81ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (279ms)

      ✓ Substitute repeat previous should accept flags (98ms)

      ✓ Substitute with empty search string should use last searched pattern (262ms)

      ✓ Ampersand (&) should repeat the last substitution (194ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (66ms)

    ✓ tabe with current file path does nothing (41ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

    ✓ command line file tab completion directory with / at the end

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file navigate tab completion (44ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (54ms)

    ✓ command line file tab completion with space in file path (124ms)

  Vertical split

    ✓ :vs creates a second split (60ms)

    ✓ :vsp creates a second split (60ms)

    ✓ :vsplit creates a second split (75ms)

    ✓ :vnew creates a second split (213ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ :vne creates a second split (163ms)

  Basic write-quit

    ✓ Run write and quit (40ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (78ms)

      ✓ Can complete lines in file with different indentation (57ms)

      ✓ Returns no completions for unmatched line (118ms)

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (85ms)

  Notation
    ✓ Normalize
  Remapper

    ✓ getLongestedRemappedKeySequence (64ms)

    ✓ getMatchingRemap (64ms)

    ✓ jj -> <Esc> through modehandler (58ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (73ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (79ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (76ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (73ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (122ms)

TextEditor is closed/disposed

TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (114ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (114ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (63ms)

        ✓ Can track jumps for keys: GggG (63ms)

        ✓ Can track jumps for keys: GggGgg (74ms)

        ✓ Can track jumps for keys: /b<CR>n (78ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (90ms)

        ✓ Can track jumps for keys: j%% (78ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (41ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (81ms)

        ✓ Can track jumps for keys: j%%<C-o>% (79ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (94ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg (69ms)

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (109ms)

        ✓ Can enter number to jump back multiple times (64ms)

        ✓ Can track one-line `` jumps (99ms)

        ✓ Can track one-line double `` jumps (52ms)

        ✓ Can track one-line '' jumps (97ms)

        ✓ Can track one-line double '' jumps (175ms)

        ✓ Can handle '' jumps with no previous jump (174ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (163ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnkdd (245ms)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (197ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (257ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (127ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (93ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (216ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (230ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (195ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (71ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (96ms)

      Can track jumps from marks

        ✓ Can track jumps for keys: maG`a (43ms)

  Record and execute a macro

    ✓ Can record and execute (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

[main 2019-12-26T05:43:20.432Z] update#setState checking for updates

    ✓ Can repeat last invoked macro (377ms)

[main 2019-12-26T05:43:20.516Z] update#setState idle

    ✓ Can play back with count (420ms)

    ✓ Can play back with count, abort when a motion fails (261ms)

    ✓ Repeat change on contiguous lines (195ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Append command to a macro (322ms)

    ✓ Can record Ctrl Keys and repeat (159ms)

    ✓ Can execute macros with dot commands properly (250ms)

    ✓ : (command) register can be used as a macro (197ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate

  Mode Insert

    ✓ can be activated (55ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert

    ✓ <Esc> can exit insert

    ✓ Stay in insert when entering characters (48ms)

    ✓ Can handle 'O' (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'i' puts you in insert mode before the cursor (231ms)

    ✓ 'I' puts you in insert mode at start of line (172ms)

    ✓ 'a' puts you in insert mode after the cursor (172ms)

    ✓ 'A' appends to end of line (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '<C-w>' deletes a word (223ms)

    ✓ Can handle <C-w> on leading whitespace (170ms)

    ✓ Can handle <C-w> at beginning of line (222ms)

    ✓ <C-u> deletes to start of line (53ms)

    ✓ Can handle <C-u> on leading characters (61ms)

    ✓ Can handle <C-u> on leading whitespace (74ms)

    ✓ Correctly places the cursor after deleting the previous line break (48ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (112ms)

    ✓ Backspace works on end of whitespace only lines (55ms)

    ✓ Backspace works at beginning of file (91ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (77ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (247ms)

    ✓ Can perform insert command prefixed with count (162ms)

    ✓ Can perform append command prefixed with count (70ms)

    ✓ Can perform insert at start of line command prefixed with count (74ms)

    ✓ Can perform append to end of line command prefixed with count (150ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can perform change char (s) command prefixed with count (268ms)

    ✓ Can perform command prefixed with count with <C-[> (110ms)

    ✓ Can handle 'o' with count (108ms)

    ✓ Can handle 'O' with count (79ms)

    ✓ Can handle backspace at beginning of line with all spaces (66ms)

    ✓ Can handle digraph insert (59ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (43ms)

    ✓ Can handle dw (99ms)

    ✓ Can handle dw (55ms)

    ✓ Can handle dw across lines (1) (58ms)

    ✓ Can handle dw across lines (2) (52ms)

    ✓ Can handle dd last line

    ✓ Can handle dd single line (54ms)

    ✓ Can handle dd (49ms)

    ✓ Can handle 3dd (91ms)

    ✓ Can handle 3dd off end of document (61ms)

    ✓ Can handle d2d (42ms)

    ✓ Can handle dd empty line (73ms)

    ✓ Can handle ddp (52ms)

    ✓ Can handle 'de' (54ms)

    ✓ Can handle 'de' then 'de' again (56ms)

    ✓ Can handle 'db' (60ms)

    ✓ Can handle 'db then 'db' again (96ms)

    ✓ Can handle 'dl' at end of line (102ms)

    ✓ Can handle 'dF' (38ms)

    ✓ Can handle 'dT' (93ms)

    ✓ Can handle 'd3' then <enter> (40ms)

    ✓ Can handle 'dj' (51ms)

    ✓ Can handle 'dk' (58ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (60ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (98ms)

    ✓ Can handle 'cw' without deleting following white spaces (84ms)

    ✓ Can handle 'c2w' (47ms)

    ✓ Can handle 'cw' without removing EOL (77ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (54ms)

    ✓ Can handle 'c]}' without deleting closing bracket (78ms)

    ✓ Can handle 's' (48ms)

    ✓ Can handle 'yiw' with correct cursor ending position (65ms)

    ✓ Can handle 'ciw' (120ms)

    ✓ Can handle 'ciw' on blanks (87ms)

    ✓ Can handle 'caw' (100ms)

    ✓ Can handle 'caw' on first letter (79ms)

    ✓ Can handle 'caw' on blanks (110ms)

    ✓ Can handle 'caw' on blanks (99ms)

    ✓ Can handle 'ci(' on first parentheses (54ms)

    ✓ Can handle 'ci(' with nested parentheses (87ms)

    ✓ Can handle 'ci(' backwards through nested parens (49ms)

    ✓ Can handle 'cib' on first parentheses (47ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (39ms)

    ✓ Can handle count prefixed 'ci)' (49ms)

    ✓ Can handle count prefixed 'ca)' (121ms)

    ✓ Can handle 'ca(' spanning multiple lines (223ms)

    ✓ Can handle 'cab' spanning multiple lines (149ms)

    ✓ Can handle 'ci{' spanning multiple lines (70ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (89ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly

    ✓ Can handle 'ci(' on the closing bracket (98ms)

    ✓ Can handle 'ciB' spanning multiple lines (43ms)

    ✓ will fail when ca( with no () (66ms)

    ✓ will fail when ca{ with no {} (66ms)

    ✓ will fail when caB with no {} (85ms)

    ✓ Can handle 'ci[' spanning multiple lines (65ms)

    ✓ Can handle 'ci]' on first bracket (50ms)

    ✓ Can handle 'ca[' on first bracket (116ms)

    ✓ Can handle 'ca]' on first bracket (43ms)

    ✓ Can handle 'ci'' on first quote (49ms)

    ✓ Can handle 'ci'' inside quoted string (54ms)

    ✓ Can handle 'ci'' on closing quote (90ms)

    ✓ Can handle 'ci'' when string is ahead (61ms)

    ✓ Can handle 'ci"' on opening quote (82ms)

    ✓ Can handle 'ci"' starting behind the quoted word

    ✓ Can handle 'ca"' starting behind the quoted word

    ✓ Can handle 'ca"' starting on the opening quote (118ms)

    ✓ Can handle 'ci"' with escaped quotes (164ms)

    ✓ Can handle 'ci"' with a single escaped quote (55ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (59ms)

    ✓ Can handle 'ci"' with an escaped backslash (62ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (69ms)

    ✓ Can handle 'ca"' starting on the closing quote (50ms)

    ✓ Can handle 'ci"' with complex escape sequences (61ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (85ms)

    ✓ will fail when ca" ahead of quoted string (54ms)

    ✓ Can handle 'ca`' inside word (48ms)

    ✓ can handle cj (66ms)

    ✓ can handle ck (79ms)

    ✓ can handle c2j (106ms)

    ✓ can handle c2k (105ms)

    ✓ can handle cj on last line (60ms)

    ✓ can handle ck on first line (71ms)

    ✓ can handle c2j on last line (99ms)

    ✓ can handle c2k on first line (63ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (68ms)

    ✓ Can handle 'daw' on word with trailing spaces (84ms)

    ✓ Can handle 'daw' on word with leading spaces (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on word with numeric prefix (236ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (96ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (59ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (140ms)

    ✓ Can handle 'daw' on end of word (194ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (53ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (62ms)

    ✓ Can handle 'daw' on word at beginning of file (87ms)

    ✓ Can handle 'daw' on word at beginning of line (65ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (73ms)

    ✓ Can handle 'daw' around word at end of line (38ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (46ms)

    ✓ Can handle 'daW' around word at whitespace (40ms)

    ✓ Can handle 'daW' on word with trailing spaces (89ms)

    ✓ Can handle 'daW' on word with leading spaces (53ms)

    ✓ Can handle 'daW' on word with numeric prefix

    ✓ Can handle 'daW' on word with numeric prefix and across lines (97ms)

    ✓ Can handle 'daW' on beginning of word (104ms)

    ✓ Can handle 'daW' on end of one line (43ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (46ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (68ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (60ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (85ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (181ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (42ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (180ms)

    ✓ Can handle 'diw' on word (51ms)

    ✓ Can handle 'diw' on word with numeric prefix (45ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (110ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (127ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (90ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (116ms)

    ✓ Can handle 'diW' on word with trailing spaces (82ms)

    ✓ Can handle 'diW' on word with leading spaces (70ms)

    ✓ Can handle 'diW' on word with numeric prefix (69ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (93ms)

    ✓ Can handle 'diW' on beginning of word (46ms)

    ✓ Can handle d} (55ms)

    ✓ Can handle y} at beginning of line

    ✓ Select sentence with trailing spaces (82ms)

    ✓ Select sentence with leading spaces (88ms)

    ✓ Select inner sentence with trailing spaces (56ms)

    ✓ Select inner sentence with leading spaces (85ms)

    ✓ Select spaces between sentences (126ms)

    ✓ Can handle 'df' (50ms)

    ✓ Can handle 'dt' (47ms)

    ✓ Can handle backspace (45ms)

    ✓ Can handle backspace across lines (41ms)

    ✓ Can handle A and backspace

    ✓ Can handle 'yy' without changing cursor position (47ms)

    ✓ Can handle 'P' after 'yy' (117ms)

    ✓ Can handle 'p' after 'yy' (42ms)

    ✓ Can handle 'P' after 'Nyy' (66ms)

    ✓ Can handle 'p' after 'Nyy' (58ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (48ms)

    ✓ Can handle 'gp' after 'yy' (59ms)

    ✓ Can handle 'gp' after 'Nyy' (57ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (40ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (91ms)

    ✓ Can handle 'gP' after 'yy' (42ms)

    ✓ Can handle 'gP' after 'Nyy' (66ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (51ms)

    ✓ Can handle ']p' after yy (84ms)

    ✓ Can handle ']p' after 'Nyy' (55ms)

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (100ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (47ms)

    ✓ Can handle '[p' after yy (68ms)

    ✓ Can handle '[p' after 'Nyy' (166ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (65ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (70ms)

    ✓ Can handle 'p' after y'a (47ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (54ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (72ms)

    ✓ Can handle pasting in visual mode over selection (113ms)

    ✓ Can repeat w

    ✓ Can repeat p

    ✓ I works correctly (69ms)

    ✓ gI works correctly (95ms)

    ✓ gi works correctly (93ms)

    ✓ `. works correctly (80ms)

    ✓ '. works correctly (77ms)

    ✓ g; works correctly (81ms)

    ✓ g, works correctly (75ms)

    ✓ g_ works correctly (95ms)

    ✓ 3g_ works correctly (65ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces after single line comments correctly (256ms)

    ✓ gq handles spaces before single line comments correctly (222ms)

    ✓ gq handles tabs before single line comments correctly (453ms)

    ✓ Can handle space

    ✓ Can handle space (83ms)

    ✓ Undo 1 (98ms)

    ✓ Undo 2 (61ms)

    ✓ Undo cursor (111ms)

    ✓ Undo cursor 2 (104ms)

    ✓ Undo cursor 3 (88ms)

    ✓ Undo with movement first (111ms)

    ✓ Can handle 'U' (49ms)

    ✓ Can handle 'U' for multiple changes (150ms)

    ✓ Can handle 'U' for new line below (137ms)

    ✓ Can handle 'U' for new line above (77ms)

    ✓ Can handle 'U' for consecutive changes only (130ms)

    ✓ Can handle 'u' to undo 'U' (63ms)

    ✓ Can handle 'U' to undo 'U' (86ms)

    ✓ Can handle 'u' after :s/abc/def (139ms)

    ✓ Redo (74ms)

    ✓ Redo (84ms)

    ✓ Redo (75ms)

    ✓ Can handle u (85ms)

    ✓ Can handle guw (57ms)

    ✓ Can handle gUw (53ms)

    ✓ Can handle u over line breaks (51ms)

    ✓ can handle s in visual mode (86ms)

    ✓ can handle p with selection (58ms)

    ✓ can handle P with selection (70ms)

    ✓ can handle p in visual to end of line (103ms)

    ✓ can repeat backspace twice (118ms)

    ✓ can delete linewise with d2G (131ms)

    ✓ can delete with + motion and count

    ✓ can delete with - motion and count (58ms)

    ✓ can dE correctly (71ms)

    ✓ can dE correctly (47ms)

    ✓ can dE correctly (100ms)

    ✓ can ctrl-a correctly behind a word

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (108ms)

    ✓ can ctrl-a on word (190ms)

    ✓ can ctrl-a on a hex number (173ms)

    ✓ can ctrl-a on decimal (197ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a with numeric prefix (225ms)

    ✓ can ctrl-a on a decimal (106ms)

    ✓ can ctrl-a on an octal  (223ms)

    ✓ Correctly increments in the middle of a number (153ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-x correctly behind a word (223ms)

    ✓ can ctrl-a on an number with word before  (61ms)

    ✓ can ctrl-a on an number with word before and after  (77ms)

    ✓ can ctrl-x on a negative number with word before and after  (81ms)

    ✓ can ctrl-a properly on multiple lines (61ms)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (77ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (53ms)

    ✓ can <C-a> on word with - in front of it (67ms)

    ✓ can do Y

    ✓ Can do S (128ms)

    ✓ / does not affect mark (42ms)

    ✓ / can search with regex (156ms)

    ✓ / can search with newline (197ms)

    ✓ / can search through multiple newlines (67ms)

    ✓ / matches ^ per line (50ms)

    ✓ / matches $ per line (74ms)

    ✓ Can search for forward slash (93ms)

    ✓ Can search backward for question mark (59ms)

    ✓ /\c forces case insensitive search (97ms)

    ✓ /\C forces case sensitive search (56ms)

    ✓ <BS> deletes the last character in search in progress mode (88ms)

    ✓ <S-BS> deletes the last character in search in progress mode (107ms)

    ✓ <C-h> deletes the last character in search in progress mode (39ms)

    ✓ Can do C

    ✓ Can do cit on a matching tag (115ms)

    ✓ Ignores cit on a non-matching tag (108ms)

    ✓ Ignores cit on a nested tag (156ms)

    ✓ Can do cit on a tag with an attribute tag (164ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cat on a matching tag (225ms)

    ✓ Can do cit on a multiline tag (219ms)

    ✓ Can do cit on a multiline tag with nested tags (75ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (84ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (67ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (79ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (68ms)

    ✓ can do cit with self closing tags (91ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Respects indentation with cc (227ms)

    ✓ Resets cursor to indent end with cc (159ms)

    ✓ can handle 'cc' on empty line (200ms)

    ✓ cc copies linewise (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Indent current line with correct Vim Mode (227ms)

    ✓ Can handle <Esc> and do nothing (156ms)

    ✓ Can handle # on consecutive words (216ms)

    ✓ Can handle # on skipped words (133ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (90ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (223ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ cc on whitespace-only treats whitespace as indent (220ms)

    ✓ Can do cai (173ms)

    ✓ Can do cii (46ms)

    ✓ Can do caI (103ms)

    ✓ Can do dai (221ms)

    ✓ Can do dii (46ms)

    ✓ Can do daI (94ms)

    ✓ `] go to the end of the previously operated or put text (66ms)

    ✓ '] go to the end of the previously operated or put text (84ms)

    ✓ `[ go to the start of the previously operated or put text (122ms)

    ✓ '[ go to the start of the previously operated or put text (69ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (219ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (68ms)

    can handle gn

      ✓ gn selects the next match text (335ms)

      ✓ gn selects the current word at |hello (135ms)

      ✓ gn selects the current word at h|ello (228ms)

      ✓ gn selects the current word at hel|lo (219ms)

      ✓ gn selects the current word at hell|o (279ms)

      ✓ gn selects the next word at hello| (139ms)

    can handle dgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the next match text (from first line) (232ms)

      ✓ dgn deletes the current word when cursor is at |hello (150ms)

      ✓ dgn deletes the current word when cursor is at h|ello (259ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (172ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at hell|o (252ms)

      ✓ dgn deletes the next word when cursor is at hello| (195ms)

    can handle cgn

      ✓ cgn deletes the next match text (from first line) (168ms)

      ✓ cgn deletes the current word when cursor is at |hello (112ms)

      ✓ cgn deletes the current word when cursor is at h|ello (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the current word when cursor is at hel|lo (246ms)

      ✓ cgn deletes the current word when cursor is at hell|o (171ms)

      ✓ cgn deletes the next word when cursor is at hello| (212ms)

    can handle gN

      ✓ gN selects the previous match text (166ms)

      ✓ gN selects the current word at hell|o (229ms)

      ✓ gN selects the current word at hel|lo (156ms)

      ✓ gN selects the current word at h|ello (207ms)

      ✓ gN selects the current word at |hello (180ms)

      ✓ gN selects the previous word at | hello (184ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (85ms)

      ✓ dgN deletes the current word when cursor is at hell|o (184ms)

      ✓ dgN deletes the current word when cursor is at hel|lo (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at h|ello (241ms)

      ✓ dgN deletes the current word when cursor is at |hello (180ms)

      ✓ dgN deletes the previous word when cursor is at | hello (222ms)

    can handle cgN

      ✓ cgN deletes the previous match text (from first line) (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the current word when cursor is at hell|o (239ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (149ms)

      ✓ cgN deletes the current word when cursor is at h|ello (277ms)

      ✓ cgN deletes the current word when cursor is at |hello (177ms)

      ✓ cgN deletes the previous word when cursor is at | hello (239ms)

  Mode Replace

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can activate with <Insert> from Insert mode (183ms)

    ✓ Can activate with R from Normal mode (40ms)

    ✓ Can handle R (63ms)

    ✓ Can handle R past current line (73ms)

    ✓ Can handle R and exit Replace Mode (139ms)

    ✓ Can handle R across lines (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle R across lines and exit Replace Mode (404ms)

    ✓ Can handle R with {count} (178ms)

    ✓ Can handle backspace (221ms)

    ✓ Can handle backspace (234ms)

    ✓ Can handle backspace across lines (179ms)

    ✓ Can handle arrows (203ms)

    ✓ Can handle . (118ms)

    ✓ Can handle . across lines (285ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (168ms)

    ✓ Can handle wd (126ms)

    ✓ Can handle x (131ms)

    ✓ Can handle x across a selection (141ms)

    ✓ Can do vwd in middle of sentence (150ms)

    ✓ Can do vwd in middle of sentence (156ms)

    ✓ Can do vwd multiple times (155ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (94ms)

    ✓ Can handle H key (197ms)

    ✓ Can handle backspace key (123ms)

    ✓ handles case where we delete over a newline (100ms)

    ✓ handles change operator (104ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vat on multiple matching tags (151ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (245ms)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (196ms)

    ✓ Repeat-prefixed vat does not bleed below (205ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (46ms)

    ✓ Can do vi) on a matching parenthesis (56ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vi) on multiple matching parens (230ms)

    ✓ Can do va) on a matching parenthesis (134ms)

    ✓ Can do va) on multiple matching parens (84ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (61ms)

    ✓ Repeat-prefixed va) does not bleed below (221ms)

    ✓ Can do va} on a matching bracket as first character (55ms)

    ✓ Can do va} on multiple matching brackets (62ms)

    ✓ Can do vi( on a matching bracket near first character (216ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do vi{ on outer pair of nested braces (315ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (45ms)

    ✓ Can do va] on multiple matching brackets (71ms)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (288ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Repeat-prefixed vaf does not bleed below (234ms)

    ✓ vaf only expands to enclosing pairs (51ms)

    ✓ Can use . to repeat indent in visual (109ms)

    ✓ Can do v_x to delete to first char (203ms)

    ✓ Can do vg_x to delete to last char with no EOL (58ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v3g_x to delete to last char with no EOL with count (245ms)

    ✓ Can do v$x to delete to last char including EOL (52ms)

    ✓ Can do gv to reselect previous selection (72ms)

    Vim's EOL handling is weird

      ✓ delete through eol (61ms)

      ✓ join 2 lines by deleting through eol (107ms)

      ✓ d$ doesn't delete whole line (115ms)

      ✓ vd$ does delete whole line (51ms)

      ✓ Paste over selection copies the selection (119ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Paste over selection copies the selection linewise (248ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (130ms)

      ✓ Can handle <down> key (231ms)

      ✓ Can handle <left> key (86ms)

      ✓ Can handle <right> key (185ms)

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (195ms)

      ✓ Can handle 'gj' (69ms)

      - Preserves cursor position when handling 'gk'
      - Preserves cursor position when handling 'gj'
    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with trailing spaces (231ms)

      ✓ Can handle 'vawd' on word with leading spaces (141ms)

      ✓ Can handle 'vawd' on word with numeric prefix (78ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (82ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (233ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (145ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (79ms)

      ✓ Can handle 'vaWd' on word with leading spaces (58ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (106ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (132ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (242ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (167ms)

      ✓ Can handle 'vaWd' on word with leading spaces (205ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (113ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (150ms)

    handles aw in visual mode

      ✓ Can handle 'vawd' on word with cursor inside spaces (213ms)

      ✓ Can handle 'vawd' on word with trailing spaces (185ms)

      ✓ Can handle 'vawd' on word with leading spaces (200ms)

      ✓ Can handle 'vawd' on word with numeric prefix (50ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (100ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (235ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (100ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (128ms)

      ✓ Can handle 'vaWd' on word with leading spaces (203ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (416ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (88ms)

      ✓ Can handle 'Y' in visual mode (236ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (239ms)

      ✓ Select multiple sentences in visual mode (156ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (208ms)

      ✓ Select inner sentence with leading spaces in visual mode (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select spaces between sentences in visual mode (233ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (183ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (203ms)

      ✓ Can do vat on a matching tag (191ms)

    handles replace in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can do a single line replace (239ms)

      ✓ Can do a multi line replace (110ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (230ms)

      ✓ D deletes the current line (187ms)

    handles indent blocks in visual mode

      ✓ Can do vai (204ms)

      ✓ Can do vii (51ms)

      ✓ Doesn't naively select the next line (46ms)

      ✓ Searches backwards if cursor line is empty (90ms)

      ✓ Can do vaI (134ms)

    visualstar

      ✓ Works with * (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with #

    search works in visual mode

      ✓ Works with / (60ms)

      1) Works with ?

      ✓ Selects correct range (128ms)

    X will delete linewise

      ✓ normal selection (182ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (215ms)

    C will delete linewise

      ✓ normal selection (126ms)

      ✓ normal selection (127ms)

    R will delete linewise

      ✓ normal selection (114ms)

      ✓ normal selection (212ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (178ms)

      ✓ upward selection (86ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (61ms)

      ✓ multiline indent bottom up selection (46ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent top down selection (503ms)

      ✓ repeat multiline indent bottom up selection (159ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (204ms)

      ✓ multiline outdent bottom up selection (189ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline outdent top down selection (238ms)

      ✓ repeat multiline outdent bottom up selection (142ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (166ms)

    vi{ will go to end of second to last line

      ✓ select (233ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode

      ✓ <C-v><C-v> will back to normal mode (64ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (541ms)

      ✓ gv selects the last pasted text (which is longer than original) (287ms)

      ✓ gv selects the last pasted text (multiline) (129ms)

    can handle gn

      ✓ gn selects the next match text (133ms)

      ✓ gn selects the current word at |hello (177ms)

      ✓ gn selects the current word at h|ello (150ms)

      ✓ gn selects the current word at hel|lo (213ms)

      ✓ gn selects the next word at hell|o (123ms)

      ✓ gn selects the next word at hello| (205ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (45ms)

      ✓ multiline insert from top down selection (51ms)

      ✓ skips blank lines (67ms)

    can append text with A

      ✓ multiline append from bottom up selection (49ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (273ms)

      ✓ skips blank lines (143ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (286ms)

      ✓ U/gU across a selection (164ms)

      ✓ U/gU across a selection (reverse) (184ms)

      ✓ u/gu on single character (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ u/gu across a selection (311ms)

      ✓ u/gu across a selection (reverse) (118ms)

  Mode Visual Block

    ✓ can be activated (44ms)

    ✓ Can handle A forward select (76ms)

    ✓ Can handle A backwards select (258ms)

    ✓ Can handle I forward select (134ms)

    ✓ Can handle I backwards select (181ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (125ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (219ms)

    ✓ Can handle c forward select (178ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle c backwards select (260ms)

    ✓ Can handle C (110ms)

    ✓ Can do a multi line replace (235ms)

    ✓ Can handle 'D' (131ms)

    ✓ Can handle 'gj' (146ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Properly add to end of lines j then $ (257ms)

    ✓ Properly add to end of lines $ then j (184ms)

    ✓ o works in visual block mode (221ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (150ms)

  Mode Visual Line

    ✓ can be activated

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle w (414ms)

    ✓ Can handle wd (117ms)

    ✓ Can handle x (94ms)

    ✓ Can handle x across a selection (72ms)

    ✓ Can do vwd in middle of sentence (88ms)

    ✓ Can do vwd in middle of sentence (142ms)

    ✓ Can do vwd multiple times (149ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (128ms)

    ✓ handles case where we delete over a newline (158ms)

    ✓ handles change operator (131ms)

    ✓ Vp updates register content (195ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (first line) (234ms)

    ✓ Vp does not append unnecessary newlines (middle line) (133ms)

    ✓ Vp does not append unnecessary newlines (last line) (229ms)

    Vim's EOL handling is weird

      ✓ delete through eol (63ms)

      ✓ join 2 lines by deleting through eol (133ms)

      ✓ d$ doesn't delete whole line (48ms)

      ✓ vd$ does delete whole line (52ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (75ms)

      ✓ Can handle <down> key (221ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (180ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'gj' (231ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (56ms)

      ✓ Can handle d key (109ms)

      ✓ Can handle d key (39ms)

      ✓ Can handle d key (38ms)

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (68ms)

      ✓ Can do a multi visual line replace (52ms)

      ✓ Can do a multi visual line replace from the bottom up (78ms)

    search works in visual line mode

      ✓ Works with / (69ms)

      ✓ Works with ? (103ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (318ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (91ms)

      ✓ linewise visual put works also in the end of document (40ms)

      ✓ gv selects the last pasted text (which is shorter than original) (240ms)

      ✓ gv selects the last pasted text (which is longer than original) (336ms)

      ✓ gv selects the last pasted text (multiline) (102ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (65ms)

      ✓ multiline insert from top down selection (38ms)

      ✓ skips blank lines (96ms)

    can append text with A

      ✓ multiline append from bottom up selection (181ms)

      ✓ multiline append from top down selection (66ms)

      ✓ skips blank lines (45ms)

  Mode Normal

    ✓ Can handle 'x' (67ms)

    ✓ Can handle 'Nx' (63ms)

    ✓ Can handle 'Nx' and paste (53ms)

    ✓ Can handle 'x' at end of line (193ms)

    ✓ Can handle 'Ns' (79ms)

    ✓ Can handle 'Ns' at end of line (67ms)

    ✓ Can handle '<Del>' (41ms)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (49ms)

    ✓ Can handle '<Del>' at end of line (106ms)

    ✓ Can handle 'cc' (52ms)

    ✓ Can handle 'Ncc' (88ms)

    ✓ Can handle 'yy' (58ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'D' (237ms)

    ✓ Can handle 'D' on empty lines (47ms)

    ✓ Can handle 'DD' (49ms)

    ✓ Can handle 'C' (80ms)

    ✓ Can handle 'NC' (47ms)

    ✓ Can handle 'NC' and put (101ms)

    ✓ Can handle 'r'

    ✓ Can handle '<Count>r' (114ms)

    ✓ Can handle '<Count>r'

    ✓ Can handle 'r' after 'dd' (135ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'r
' (230ms)

    ✓ Can handle '<Count>r
' (63ms)

    ✓ Can handle 'J' once (40ms)

    ✓ Can handle 'J' twice (78ms)

    ✓ Can handle 'J' with empty last line (73ms)

    ✓ Can handle 'J's with multiple empty last lines (212ms)

    ✓ Can handle 'J' with leading white space on next line (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J' with only white space on next line (610ms)

    ✓ Can handle 'J' with TWO indented lines

    ✓ Can handle 'J' with ')' first character on next line (53ms)

    ✓ Can handle 'J' with a following delete (71ms)

    ✓ Can handle 'J' in Visual Line mode (61ms)

    ✓ Can handle 'gJ' once (200ms)

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (174ms)

    ✓ Can handle '~' (205ms)

    ✓ Can handle 'g~{motion}' (269ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<BS>' in insert mode

    ✓ Can handle undo with P (224ms)

    ✓ Can handle 'ge' in multiple lines case1 (133ms)

    ✓ Can handle 'ge' in multiple lines case2 (67ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (183ms)

    ✓ Can repeat '~' with dot (127ms)

    ✓ Can repeat 'x' (198ms)

    ✓ Can repeat 'J' (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle dot with A (257ms)

    ✓ Can handle dot with I (252ms)

    ✓ Can repeat actions that require selections (124ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (55ms)

    ✓ Can repeat insert change and '<C-t>' (118ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat change by `<C-a>` (268ms)

    ✓ Only one arrow key can be repeated in Insert Mode (145ms)

    ✓ Cached content change will be cleared by arrow keys (250ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (132ms)

    ✓ inside parenthesis (113ms)

    ✓ nested parenthesis beginning (111ms)

    ✓ nested parenthesis end

    ✓ nested bracket and parenthesis beginning

    ✓ nested bracket, parenthesis, braces beginning (151ms)

    ✓ nested bracket, parenthesis, braces end (163ms)

    ✓ parentheses after > (51ms)

    ✓ parentheses after " (40ms)

  Motions in Normal Mode

    ✓ Can handle [( (86ms)

    ✓ Can handle nested [( (102ms)

    ✓ Can handle <number>[( (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle [( and character under cursor exclusive (220ms)

    ✓ Can handle ]) (181ms)

    ✓ Can handle nested ]) (121ms)

    ✓ Can handle <number>]) (144ms)

    ✓ Can handle ]) and character under cursor exclusive (203ms)

    ✓ Can handle [{ (188ms)

    ✓ Can handle nested [{ (119ms)

    ✓ Can handle <number>[{ (104ms)

    ✓ Can handle [{ and character under cursor exclusive (49ms)

    ✓ Can handle ]} (103ms)

    ✓ Can handle nested ]}

    ✓ Can handle <number>]} (96ms)

    ✓ Can handle ]} and character under cursor exclusive (131ms)

    ✓ Can handle 'ge' (142ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'gg' (222ms)

    ✓ Can handle 'gg' to first non blank char on random line (193ms)

    ✓ Can handle 'gg' to first non blank char on first line (151ms)

    ✓ 'gg' obeys startofline (148ms)

    ✓ Retain same column when moving up/down (139ms)

    ✓ Can handle <enter> (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ $ always keeps cursor on EOL (139ms)

    ✓ Can handle $ with a count (68ms)

    ✓ Can handle $ with a count at end of file (58ms)

    ✓ Can handle <End> with a count (127ms)

    ✓ Can handle <D-right> with a count (159ms)

    ✓ Can handle 'f' (147ms)

    ✓ Can handle 'f' twice (67ms)

    ✓ Can handle 'f' with <tab> (65ms)

    ✓ Can handle 'f' and find back search (48ms)

    ✓ Can handle 'F' (183ms)

    ✓ Can handle 'F' twice (161ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' and find back search (220ms)

    ✓ Can handle 'f' and multiple back searches (148ms)

    ✓ Can handle 't' (194ms)

    ✓ Can handle 't' twice (49ms)

    ✓ Can handle 't' and find back search (83ms)

    ✓ Can handle 'T' (161ms)

    ✓ Can handle 'T' twice (109ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'T' and find back search (220ms)

    ✓ Can run a forward search (48ms)

    ✓ Can run a forward and find next search (62ms)

    ✓ Can run a forward and find previous search from end of word (216ms)

    ✓ Can run a reverse search (320ms)

    ✓ Can run a reverse and find next search (61ms)

    ✓ cancelled search reverts to previous search state (66ms)

    ✓ Backspace on empty search cancels (74ms)

    ✓ Search offsets: b does nothing (218ms)

    ✓ Search offsets: b2 goes 2 to the right (63ms)

    ✓ Search offsets: b+3 goes 3 to the right (46ms)

    ✓ Search offsets: e goes to the end (39ms)

    ✓ Search offsets: character offset goes across line boundaries (50ms)

    ✓ Search offsets: 2 goes 2 down

    ✓ Search offsets: -2 goes 2 up (39ms)

    ✓ maintains column position correctly (113ms)

    ✓ maintains column position correctly with $ (106ms)

    ✓ Can handle G  (132ms)

    ✓ Can handle G with number prefix (51ms)

    ✓ Can handle G with number prefix (53ms)

    ✓ Can handle gg (75ms)

    ✓ Can handle gg with number prefix (51ms)

    ✓ Can handle 0 (57ms)

    ✓ Can handle 0 as part of a repeat (75ms)

    ✓ Can handle g* (51ms)

    ✓ Can handle g*n (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle * (398ms)

    ✓ Can handle **

    ✓ Can handle # on whitespace

    ✓ Can handle # on EOL (47ms)

    ✓ Can handle g# (69ms)

    ✓ Can handle g#n (70ms)

    ✓ Can handle # (126ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (54ms)

    ✓ * adds to search history

    ✓ # adds to search history (80ms)

    ✓ Can handle | (49ms)

    ✓ Can handle <number> | (47ms)

    ✓ Can handle + (71ms)

    ✓ Can handle + indent (45ms)

    ✓ Can handle + with count prefix (94ms)

    ✓ Can handle -

    ✓ Can handle - indent (60ms)

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix (172ms)

    ✓ Can handle <up> key

    ✓ Can handle <down> key (71ms)

    ✓ Can handle <left> key

    ✓ Can handle <right> key (38ms)

    ✓ Can handle 'gk' (76ms)

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'
  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location
    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin
    ✓ line end
    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

      ✓ move to word right

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left
      ✓ move cursor word left across spaces
      ✓ move cursor word left within word
      ✓ first word should move to previous line, beginning of last word
      ✓ first word should move to previous line, stops on empty line
      ✓ first word should move to previous line, skips whitespace only line
    WORD right
      ✓ move to WORD right
      ✓ last WORD should move to next line
      ✓ last WORD should move to next line stops on empty line
      ✓ last WORD should move to next line skips whitespace only line
    WORD left
      ✓ move cursor WORD left across spaces
      ✓ move cursor WORD left within WORD
      ✓ first WORD should move to previous line, beginning of last WORD
      ✓ first WORD should move to previous line, stops on empty line
      ✓ first WORD should move to previous line, skips whitespace only line
    end of word right
      ✓ move to end of current word right
      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text

      ✓ move cursor word right recognizes a latin string which has diacritics as a single word

      ✓ move cursor word right recognizes a latin-1 symbol as punctuation

      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word

    word left

      ✓ move cursor word left across the different char kind

      ✓ move cursor word left within the same char kind

      ✓ move cursor word left across spaces on non-ascii text

      ✓ move cursor word left within word on non-ascii text

      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward

      ✓ current sentence begin

      ✓ sentence forward when cursor is at the beginning of the second sentence

      ✓ current sentence begin with no concrete sentense inside

      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph

      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph
      ✓ move up longer paragraph
      ✓ move up starting inside empty line

  motion line wrapping
    whichwrap enabled
      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line (48ms)

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line

      insert mode

        ✓ <left> wraps to previous line (43ms)

        ✓ <right> once goes to end of line (81ms)

        ✓ <right> twice wraps to next line (38ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ l does not wrap to next line (218ms)

        ✓ <left> does not wrap to previous line

        ✓ <right> does not wrap to next line (68ms)

      insert mode

        ✓ <left> does not wrap to previous line (65ms)

        ✓ <right> does not wrap to next line (61ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (186ms)

      ✓ search wraps around the start of the file (184ms)

    wrapscan disabled

      ✓ search stops at the end of the file (62ms)

      ✓ search stops at the start of the file (69ms)

  Multicursor

    ✓ can add multiple cursors below (65ms)

    ✓ can add multiple cursors above (202ms)

  numeric string

    ✓ fails on non-string

    ✓ handles hex round trip

    ✓ handles decimal round trip

    ✓ handles octal trip

  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (239ms)

    ✓ gcj comments in current and next line (217ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment with motion (570ms)

    ✓ block comment in Visual Mode (223ms)

    ✓ comment in visual line mode (55ms)

    ✓ comment in visual block mode (215ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (392ms)

    ✓ =$ formats entire line (210ms)

    ✓ =j formats two lines (191ms)

    ✓ 3=k formats three lines (183ms)

    ✓ =gg formats to top of file (210ms)

    ✓ =G formats to bottom of file (122ms)

    ✓ =ip formats paragraph (74ms)

    ✓ format in visual mode (73ms)

  put operator

    ✓ basic put test (162ms)

    ✓ test yy end of line (49ms)

    ✓ test yy first line (39ms)

    ✓ test yy middle line (115ms)

    ✓ test yy with correct positon movement (203ms)

    ✓ test visual block single line yank p (159ms)

    ✓ test visual block single line yank P (121ms)

    ✓ test visual block single line delete p (154ms)

    ✓ test visual block single line delete P (83ms)

  rot13 operator

    ✓ rot13() unit test

    2) g?j works

    ✓ g? in visual mode works (134ms)

    ✓ g? in visual line mode works (172ms)

    ✓ g? in visual block mode works (133ms)

  shift operator

    ✓ basic shift left test (61ms)

    ✓ shift left goto end test (52ms)

    ✓ shift left goto line test (52ms)

    ✓ shift right goto end test (180ms)

    ✓ shift right goto line test (96ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (78ms)

  camelCaseMotion plugin

    handles <leader>w for camelCaseText

      ✓ step over whitespace (209ms)

      ✓ step to Camel word (175ms)

      ✓ step to CAP word (67ms)

      ✓ step after CAP word (63ms)

      ✓ step from middle of word to Camel word (212ms)

      ✓ step to number word (139ms)

      ✓ step to operator word (152ms)

      ✓ step from inside operator word (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step to operator and then over (219ms)

    handles <leader>w for underscore_var

      ✓ step to _word (111ms)

      ✓ step over whitespace to word (111ms)

      ✓ step from inside word to _word (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step form _word to number (179ms)

      ✓ step from nubmer word to _word (180ms)

      ✓ step from in whitespace to word (64ms)

      ✓ step in ALL_CAPS_WORD (47ms)

    handles d<leader>w

      ✓ delete from start of camelWord (87ms)

      ✓ delete from middle of camelWord (153ms)

      ✓ delete from start of CamelWord (157ms)

      ✓ delete two words from camelWord (190ms)

      ✓ delete from start of underscore_word (115ms)

      ✓ delete from middle of underscore_word (130ms)

      ✓ delete two words from camel_word (51ms)

    handles di<leader>w

      ✓ delete from start of camelWord (132ms)

      ✓ delete from middle of camelWord (104ms)

      ✓ delete from start of CamelWord (54ms)

      ✓ delete two words from camelWord (57ms)

      ✓ delete from start of underscore_word (61ms)

      ✓ delete from middle of underscore_word (140ms)

      ✓ delete two words from camel_word (222ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    handles <leader>b

      ✓ back from middle of word (73ms)

      ✓ back over whitespace to camelWord (197ms)

      ✓ back twice over operator (172ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ from middle to end of underscore_word (214ms)

      ✓ twice to end of word over operator (179ms)

  easymotion plugin

    ✓ Can handle s move (230ms)

    ✓ Can handle 2s move (66ms)

    ✓ Can handle f move (115ms)

    ✓ Can handle 2f move (55ms)

    ✓ Can handle F move (66ms)

    ✓ Can handle 2F move (160ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle t move (219ms)

    ✓ Can handle bd-t move (94ms)

    ✓ Can handle 2t move (215ms)

    ✓ Can handle bd-t2 move (86ms)

    ✓ Can handle T move (63ms)

    ✓ Can handle 2T move (72ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle w move (201ms)

    ✓ Can handle bd-w move (74ms)

    ✓ Can handle b move (78ms)

    ✓ Can handle e move

    ✓ Can handle bd-e move (135ms)

    ✓ Can handle ge move (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle n-char move (309ms)

    ✓ Can handle j move (96ms)

    ✓ Can handle k move (232ms)

    ✓ Can handle bd-jk move (1) (74ms)

    ✓ Can handle bd-jk move (2) (209ms)

    ✓ Can handle lineforward move (1) (192ms)

    ✓ Can handle lineforward move (2) (192ms)

    ✓ Can handle linebackward move (1) (152ms)

    ✓ Can handle linebackward move (2) (153ms)

    ✓ Can handle searching for backslash (\) (134ms)

    ✓ Can handle searching for carat (^) (210ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for dot (.) (179ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (108ms)

    ✓ Replaces within inner Word (171ms)

    ✓ Replaces within '' (112ms)

    ✓ Replaces within '' including spaces (184ms)

    ✓ Replaces within () (180ms)

    ✓ Replaces within () including spaces (128ms)

    ✓ Replaces within a paragraph (131ms)

    ✓ Replaces using a specified register (51ms)

    ✓ Replaces within {} over multiple lines (69ms)

    ✓ Replaces a multiline register within {} over multiple lines (61ms)

    ✓ Replaces a multiline register within {} over multiple lines (63ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (142ms)

    ✓ grr replaces the entire line with the register (75ms)

    ✓ grr can replace multiple lines (214ms)

    ✓ Replaces in visual mode (133ms)

    ✓ Replaces in visual mode using a specified register (201ms)

    ✓ Replaces in visual line mode (104ms)

    ✓ grj is linewise (113ms)

  sneak plugin

    ✓ Can handle s motion (204ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle S motion (243ms)

    ✓ Can handle <operator>z motion (206ms)

    ✓ Can handle <operator>Z motion (114ms)

    ✓ Can handle s; motion (210ms)

    ✓ Can handle s, motion (61ms)

    ✓ Can handle S; motion (119ms)

    ✓ Can handle S, motion (50ms)

    ✓ Can handle single letter s motion (43ms)

    ✓ Can handle single letter S motion (142ms)

    ✓ Can handle single letter <operator>z motion (147ms)

    ✓ Can handle single letter <operator>Z motion (152ms)

    ✓ Can handle single letter s; motion (176ms)

    ✓ Can handle single letter s, motion (185ms)

    ✓ Can handle single letter S; motion (169ms)

    ✓ Can handle single letter S, motion (51ms)

    ✓ Can handle multiline single char <number>s motion (136ms)

  surround plugin

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw)' surrounds word without space (162ms)

    ✓ 'ysiw(' surrounds word with space (186ms)

    ✓ 'ysw)' surrounds word without space (163ms)

    ✓ 'ysw(' surrounds word with space (144ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysaw)' surrounds word without space (205ms)

    ✓ 'ysaw(' surrounds word with space (125ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (114ms)

    ✓ 'ysiw<' surrounds word with tags (107ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (80ms)

    ✓ 'cst<' surrounds word with tags that have a dot in them (85ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (222ms)

    ✓ change surround (112ms)

    ✓ change surround with two pairs of quotes (158ms)

    ✓ change surround with two pairs of parens (149ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with alias (178ms)

    ✓ change surround to tags (83ms)

    ✓ delete surround (152ms)

    ✓ delete surround with quotes (139ms)

    ✓ delete surround with nested of quotes (212ms)

    ✓ delete surround with inconsistent quotes (146ms)

    ✓ delete surround with mixed quotes (130ms)

    ✓ delete surround with empty quotes cursor at start (127ms)

    ✓ delete surround with empty quotes cursor at end (138ms)

    ✓ don't delete surround if cursor is after closing match (78ms)

    ✓ delete surround if cursor is before opening match (106ms)

    ✓ delete surround with two pairs of parens (105ms)

    ✓ delete surround with alias (106ms)

    ✓ delete surround with tags (193ms)

    ✓ change surround brackets at end of line (122ms)

    ✓ changing brackets with surround works again (194ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround with tags that contain an attribute and preserve them (242ms)

    ✓ change surround with tags that contain an attribute and remove them (209ms)

  register

    ✓ Can copy to a register (258ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can use two registers together (586ms)

    ✓ Can use black hole register (65ms)

    ✓ System clipboard works with chinese characters (58ms)

    ✓ Yank stores text in Register '0' (183ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (192ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (137ms)

    ✓ Register '1'-'9' stores delete content (265ms)

    ✓ "A appends linewise text to "a (200ms)

    ✓ "A appends character wise text to "a (259ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (145ms)

    ✓ Small deletion using Del is stored in small delete register (108ms)

    ✓ Small deletion using X is stored in small delete register (164ms)

    ✓ Search register (/) is set by forward search (206ms)

    ✓ Search register (/) is set by backward search (205ms)

    ✓ Search register (/) is set by star search (252ms)

    ✓ Command register (:) is set by command line (70ms)

    ✓ Read-only registers cannot be written to (150ms)

    clipboard

      ✓ Can access '*' (clipboard) register (161ms)

      ✓ Can access '+' (clipboard) register (187ms)

  Repeatable movements with f and t

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can repeat f<character> (298ms)

    ✓ Can repeat reversed F<character> (51ms)

    ✓ Can repeat t<character> (190ms)

    ✓ Can repeat N times reversed t<character>

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (119ms)

      ✓ move one sentence backward (196ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move [count] sentences backward (289ms)

      ✓ move one sentence backward single line - middle (121ms)

      ✓ move one sentence backward no space (190ms)

      ✓ move one sentence backward no space - middle (57ms)

      ✓ move one sentence backward - multiline (68ms)

      ✓ move one sentence backward - multiline - period (181ms)

      ✓ move one sentence backward - multiline - previous line (69ms)

      ✓ move one sentence backward - multiline - previous line - period (160ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line

    ✓ try to read lines that don't exist

  util path
    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1303 passing (4m)

  4 pending

  2 failing

  1) Mode Visual
       search works in visual mode
         Works with ?:

      Content does not match; Expected=z. Actual=foo.
      + expected - actual

      -foo
      +z
      
      at Suite.<anonymous> (test/mode/modeVisual.test.ts:920:5)


  2) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=abc.
      + expected - actual

      -abc
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:29:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 2677f650-27a3-11ea-8215-356b6c757fb9

@TravisBuddy
Copy link

Travis tests have failed

Hey @J-Fields,
Please read the following log in order to understand the failure reason.
It'll be awesome if you fix what's wrong and commit the changes.

Node.js: 8

View build log

if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi
The command "if [[ $(git diff-index HEAD -- *.js *.ts *.md) ]]; then git diff; echo "Prettier Failed. Run `gulp forceprettier` and commit changes to resolve."; exit 1; fi" exited with 0.
$ npm run build

> vim@1.12.3 build /home/travis/build/VSCodeVim/Vim
> gulp build

[06:17:37] Using gulpfile ~/build/VSCodeVim/Vim/gulpfile.js
[06:17:38] Starting 'build'...
[06:17:38] Starting 'prettier'...
[06:17:38] Finished 'prettier' after 30 ms
[06:17:38] Starting 'tsc'...
[06:17:38] Starting 'tslint'...
[06:17:45] Finished 'tslint' after 7.04 s
[06:17:52] Finished 'tsc' after 15 s
[06:17:52] Starting 'commit-hash'...
[06:17:52] Finished 'commit-hash' after 30 ms
[06:17:52] Finished 'build' after 15 s
The command "npm run build" exited with 0.
$ npm test

> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T06:17:56.910Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (41ms)

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line (40ms)

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (44ms)

    ✓ <C-p>/<C-n> go to the previous/next command (54ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (77ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (79ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (64ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (55ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma
    ✓ can lex percent
    ✓ can lex dollar
    ✓ can lex dot
    ✓ can lex one number
    ✓ can lex longer number
    ✓ can lex plus

    ✓ can lex minus
    ✓ can lex forward search
    ✓ can lex forward search escaping
    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args
    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (1224ms)

  command-line parser
    ✓ can parse empty string
    ✓ can parse left - dot
    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar
  command line scanner
    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (546ms)

    ✓ :smile editor contains smile text (531ms)

  Basic sort

    ✓ Sort whole file, asc (83ms)

    ✓ Sort whole file, asc, ignoreCase (123ms)

    ✓ Sort whole file, dsc (105ms)

    ✓ Sort whole file, dsc, ignoreCase (115ms)

    ✓ Sort range, asc (146ms)

    ✓ Sort range, asc, ignoreCase (91ms)

    ✓ Sort range, dsc (149ms)

    ✓ Sort range, dsc, ignoreCase (128ms)

    ✓ Sort whole file, asc, unique (154ms)

  Horizontal split

    ✓ :sp creates a second split (147ms)

    ✓ :split creates a second split (72ms)

    ✓ :new creates a second split (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (54ms)

    ✓ Replace with `g` flag

    ✓ Replace with flags AND count (91ms)

    ✓ Replace with `c` flag (48ms)

    ✓ Replace with `gc` flag (76ms)

    ✓ Replace across all lines (105ms)

    ✓ Replace on specific single line (75ms)

    ✓ Replace on current line using dot (88ms)

    ✓ Replace single relative line using dot and plus (101ms)

    ✓ Replace across specific line range (88ms)

    ✓ Replace across relative line range using dot, plus, and minus (162ms)

    ✓ Replace across relative line range using numLines+colon shorthand (64ms)

    ✓ Repeat replacement across relative line range (81ms)

    ✓ Replace with range AND count but no flags (112ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (78ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (77ms)

    ✓ Undocumented: trailing operators use 1 as RHS (95ms)

    ✓ Replace specific single equal lines (52ms)

    ✓ Replace current line with no active selection (91ms)

    ✓ Replace text in selection (90ms)

    ✓ Substitute support marks (82ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (39ms)

      ✓ Replace with `g` flag inverts global flag (46ms)

      ✓ Replace with `c` flag inverts global flag (79ms)

      ✓ Replace multiple lines (75ms)

      ✓ Replace across specific lines (156ms)

      ✓ Replace current line with no active selection (61ms)

      ✓ Replace text in selection (127ms)

      ✓ Substitute support marks (101ms)

      ✓ Substitute with escaped delimiter
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (201ms)

      ✓ Substitute with previous search using # (302ms)

      ✓ Substitute with previous search using / (187ms)

      ✓ Substitute with parameters should update search state (112ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (201ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (282ms)

      ✓ Substitute repeat previous should accept flags (176ms)

      ✓ Substitute with empty search string should use last searched pattern (309ms)

      ✓ Ampersand (&) should repeat the last substitution (114ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (67ms)

    ✓ tabe with current file path does nothing (40ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (63ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (69ms)

    ✓ command line file tab completion with space in file path (107ms)

  Vertical split

    ✓ :vs creates a second split (82ms)

    ✓ :vsp creates a second split (67ms)

    ✓ :vsplit creates a second split (81ms)

    ✓ :vnew creates a second split (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ :vne creates a second split (283ms)

  Basic write-quit

    ✓ Run write and quit (46ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (84ms)

      ✓ Can complete lines in file with different indentation (87ms)

      ✓ Returns no completions for unmatched line

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (58ms)

  Notation
    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (90ms)

    ✓ getMatchingRemap (58ms)

    ✓ jj -> <Esc> through modehandler (70ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (84ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (94ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (79ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (87ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (129ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (144ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (127ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (74ms)

        ✓ Can track jumps for keys: GggG (83ms)

        ✓ Can track jumps for keys: GggGgg (65ms)

        ✓ Can track jumps for keys: /b<CR>n (74ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (102ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%% (224ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (160ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (195ms)

        ✓ Can track jumps for keys: j%%<C-o>% (181ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (100ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can enter number to jump back multiple times (232ms)

        ✓ Can track one-line `` jumps (223ms)

        ✓ Can track one-line double `` jumps (204ms)

        ✓ Can track one-line '' jumps (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line double '' jumps (271ms)

        ✓ Can handle '' jumps with no previous jump (114ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

[main 2019-12-26T06:18:26.913Z] update#setState checking for updates

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (121ms)

[main 2019-12-26T06:18:26.993Z] update#setState idle

        ✓ Can track jumps for keys: /^<CR>nnnkdd (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (249ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (204ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (264ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (273ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (208ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (269ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (195ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (217ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (122ms)

      Can track jumps from marks

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: maG`a (239ms)

  Record and execute a macro

    ✓ Can record and execute (259ms)

    ✓ Can repeat last invoked macro (310ms)

    ✓ Can play back with count (335ms)

    ✓ Can play back with count, abort when a motion fails (554ms)

    ✓ Repeat change on contiguous lines (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Append command to a macro (328ms)

    ✓ Can record Ctrl Keys and repeat (167ms)

    ✓ Can execute macros with dot commands properly (274ms)

    ✓ : (command) register can be used as a macro (166ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (105ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert (53ms)

    ✓ <Esc> can exit insert (84ms)

    ✓ Stay in insert when entering characters (62ms)

    ✓ Can handle 'O'

    ✓ 'i' puts you in insert mode before the cursor (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'I' puts you in insert mode at start of line (231ms)

    ✓ 'a' puts you in insert mode after the cursor (82ms)

    ✓ 'A' appends to end of line (66ms)

    ✓ '<C-w>' deletes a word (61ms)

    ✓ Can handle <C-w> on leading whitespace (46ms)

    ✓ Can handle <C-w> at beginning of line (64ms)

    ✓ <C-u> deletes to start of line (61ms)

    ✓ Can handle <C-u> on leading characters (56ms)

    ✓ Can handle <C-u> on leading whitespace (120ms)

    ✓ Correctly places the cursor after deleting the previous line break (80ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Backspace works on end of whitespace only lines (234ms)

    ✓ Backspace works at beginning of file (111ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (107ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (95ms)

    ✓ Can perform insert command prefixed with count (48ms)

    ✓ Can perform append command prefixed with count (106ms)

    ✓ Can perform insert at start of line command prefixed with count (188ms)

    ✓ Can perform append to end of line command prefixed with count (84ms)

    ✓ Can perform change char (s) command prefixed with count (112ms)

    ✓ Can perform command prefixed with count with <C-[> (65ms)

    ✓ Can handle 'o' with count (128ms)

    ✓ Can handle 'O' with count (163ms)

    ✓ Can handle backspace at beginning of line with all spaces (65ms)

    ✓ Can handle digraph insert (82ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (44ms)

    ✓ Can handle dw (51ms)

    ✓ Can handle dw (54ms)

    ✓ Can handle dw across lines (1) (62ms)

    ✓ Can handle dw across lines (2) (45ms)

    ✓ Can handle dd last line (97ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (93ms)

    ✓ Can handle 3dd (117ms)

    ✓ Can handle 3dd off end of document (67ms)

    ✓ Can handle d2d (42ms)

    ✓ Can handle dd empty line (83ms)

    ✓ Can handle ddp (45ms)

    ✓ Can handle 'de' (68ms)

    ✓ Can handle 'de' then 'de' again (94ms)

    ✓ Can handle 'db' (64ms)

    ✓ Can handle 'db then 'db' again (80ms)

    ✓ Can handle 'dl' at end of line (84ms)

    ✓ Can handle 'dF' (92ms)

    ✓ Can handle 'dT' (50ms)

    ✓ Can handle 'd3' then <enter> (83ms)

    ✓ Can handle 'dj' (50ms)

    ✓ Can handle 'dk' (52ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (91ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (200ms)

    ✓ Can handle 'cw' without deleting following white spaces (49ms)

    ✓ Can handle 'c2w'

    ✓ Can handle 'cw' without removing EOL (81ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (83ms)

    ✓ Can handle 'c]}' without deleting closing bracket (174ms)

    ✓ Can handle 's' (58ms)

    ✓ Can handle 'yiw' with correct cursor ending position (49ms)

    ✓ Can handle 'ciw' (72ms)

    ✓ Can handle 'ciw' on blanks (112ms)

    ✓ Can handle 'caw' (115ms)

    ✓ Can handle 'caw' on first letter (148ms)

    ✓ Can handle 'caw' on blanks (128ms)

    ✓ Can handle 'caw' on blanks (40ms)

    ✓ Can handle 'ci(' on first parentheses (93ms)

    ✓ Can handle 'ci(' with nested parentheses (40ms)

    ✓ Can handle 'ci(' backwards through nested parens (71ms)

    ✓ Can handle 'cib' on first parentheses (73ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (58ms)

    ✓ Can handle count prefixed 'ci)' (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle count prefixed 'ca)' (237ms)

    ✓ Can handle 'ca(' spanning multiple lines (172ms)

    ✓ Can handle 'cab' spanning multiple lines (83ms)

    ✓ Can handle 'ci{' spanning multiple lines (42ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (63ms)

    ✓ Can handle 'ci(' on the closing bracket (53ms)

    ✓ Can handle 'ciB' spanning multiple lines

    ✓ will fail when ca( with no () (68ms)

    ✓ will fail when ca{ with no {} (53ms)

    ✓ will fail when caB with no {} (75ms)

    ✓ Can handle 'ci[' spanning multiple lines

    ✓ Can handle 'ci]' on first bracket (68ms)

    ✓ Can handle 'ca[' on first bracket (57ms)

    ✓ Can handle 'ca]' on first bracket (64ms)

    ✓ Can handle 'ci'' on first quote (60ms)

    ✓ Can handle 'ci'' inside quoted string (82ms)

    ✓ Can handle 'ci'' on closing quote (107ms)

    ✓ Can handle 'ci'' when string is ahead (52ms)

    ✓ Can handle 'ci"' on opening quote (70ms)

    ✓ Can handle 'ci"' starting behind the quoted word (64ms)

    ✓ Can handle 'ca"' starting behind the quoted word (69ms)

    ✓ Can handle 'ca"' starting on the opening quote (69ms)

    ✓ Can handle 'ci"' with escaped quotes (77ms)

    ✓ Can handle 'ci"' with a single escaped quote (43ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (97ms)

    ✓ Can handle 'ci"' with an escaped backslash (43ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (114ms)

    ✓ Can handle 'ca"' starting on the closing quote (78ms)

    ✓ Can handle 'ci"' with complex escape sequences (45ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (93ms)

    ✓ will fail when ca" ahead of quoted string (41ms)

    ✓ Can handle 'ca`' inside word (75ms)

    ✓ can handle cj (82ms)

    ✓ can handle ck (62ms)

    ✓ can handle c2j (117ms)

    ✓ can handle c2k (165ms)

    ✓ can handle cj on last line (94ms)

    ✓ can handle ck on first line (124ms)

    ✓ can handle c2j on last line (77ms)

    ✓ can handle c2k on first line (64ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (43ms)

    ✓ Can handle 'daw' on word with trailing spaces (83ms)

    ✓ Can handle 'daw' on word with leading spaces (64ms)

    ✓ Can handle 'daw' on word with numeric prefix (66ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (144ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (78ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on end of word (256ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (45ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (51ms)

    ✓ Can handle 'daw' on word at beginning of file (53ms)

    ✓ Can handle 'daw' on word at beginning of line (66ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (98ms)

    ✓ Can handle 'daw' around word at end of line (152ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (91ms)

    ✓ Can handle 'daW' around word at whitespace (78ms)

    ✓ Can handle 'daW' on word with trailing spaces (79ms)

    ✓ Can handle 'daW' on word with leading spaces (53ms)

    ✓ Can handle 'daW' on word with numeric prefix (39ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (87ms)

    ✓ Can handle 'daW' on beginning of word (50ms)

    ✓ Can handle 'daW' on end of one line (51ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (84ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (51ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (69ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (67ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (71ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (44ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (104ms)

    ✓ Can handle 'diw' on word (179ms)

    ✓ Can handle 'diw' on word with numeric prefix (55ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (98ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (100ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (110ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (64ms)

    ✓ Can handle 'diW' on word with trailing spaces (70ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diW' on word with leading spaces (260ms)

    ✓ Can handle 'diW' on word with numeric prefix (40ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (135ms)

    ✓ Can handle 'diW' on beginning of word (41ms)

    ✓ Can handle d} (69ms)

    ✓ Can handle y} at beginning of line (41ms)

    ✓ Select sentence with trailing spaces (82ms)

    ✓ Select sentence with leading spaces (140ms)

    ✓ Select inner sentence with trailing spaces (87ms)

    ✓ Select inner sentence with leading spaces (104ms)

    ✓ Select spaces between sentences (88ms)

    ✓ Can handle 'df' (49ms)

    ✓ Can handle 'dt' (94ms)

    ✓ Can handle backspace (40ms)

    ✓ Can handle backspace across lines (120ms)

    ✓ Can handle A and backspace (87ms)

    ✓ Can handle 'yy' without changing cursor position (53ms)

    ✓ Can handle 'P' after 'yy' (70ms)

    ✓ Can handle 'p' after 'yy' (56ms)

    ✓ Can handle 'P' after 'Nyy' (38ms)

    ✓ Can handle 'p' after 'Nyy' (58ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (68ms)

    ✓ Can handle 'gp' after 'yy' (56ms)

    ✓ Can handle 'gp' after 'Nyy' (40ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (89ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (65ms)

    ✓ Can handle 'gP' after 'yy' (84ms)

    ✓ Can handle 'gP' after 'Nyy' (53ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (55ms)

    ✓ Can handle ']p' after yy (71ms)

    ✓ Can handle ']p' after 'Nyy'

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (50ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (59ms)

    ✓ Can handle '[p' after yy (84ms)

    ✓ Can handle '[p' after 'Nyy' (52ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (49ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (82ms)

    ✓ Can handle 'p' after y'a (66ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (51ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (213ms)

    ✓ Can handle pasting in visual mode over selection (199ms)

    ✓ Can repeat w (129ms)

    ✓ Can repeat p (60ms)

    ✓ I works correctly (77ms)

    ✓ gI works correctly (49ms)

    ✓ gi works correctly (112ms)

    ✓ `. works correctly (186ms)

    ✓ '. works correctly (130ms)

    ✓ g; works correctly (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g, works correctly (281ms)

    ✓ g_ works correctly (89ms)

    ✓ 3g_ works correctly (218ms)

    ✓ gq handles spaces after single line comments correctly (298ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces before single line comments correctly (340ms)

    ✓ gq handles tabs before single line comments correctly (374ms)

    ✓ Can handle space (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (239ms)

    ✓ Undo 1 (234ms)

    ✓ Undo 2 (237ms)

    ✓ Undo cursor (233ms)

    ✓ Undo cursor 2 (193ms)

    ✓ Undo cursor 3 (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Undo with movement first (285ms)

    ✓ Can handle 'U' (120ms)

    ✓ Can handle 'U' for multiple changes (283ms)

    ✓ Can handle 'U' for new line below (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' for new line above (474ms)

    ✓ Can handle 'U' for consecutive changes only (248ms)

    ✓ Can handle 'u' to undo 'U' (145ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' to undo 'U' (247ms)

    ✓ Can handle 'u' after :s/abc/def (110ms)

    ✓ Redo (126ms)

    ✓ Redo (353ms)

    ✓ Redo (88ms)

    ✓ Can handle u (60ms)

    ✓ Can handle guw (92ms)

    ✓ Can handle gUw (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle u over line breaks (233ms)

    ✓ can handle s in visual mode (167ms)

    ✓ can handle p with selection (250ms)

    ✓ can handle P with selection (199ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle p in visual to end of line (263ms)

    ✓ can repeat backspace twice (213ms)

    ✓ can delete linewise with d2G (187ms)

    ✓ can delete with + motion and count (219ms)

    ✓ can delete with - motion and count (137ms)

    ✓ can dE correctly (182ms)

    ✓ can dE correctly (192ms)

    ✓ can dE correctly (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a correctly behind a word (220ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (109ms)

    ✓ can ctrl-a on word (213ms)

    ✓ can ctrl-a on a hex number (73ms)

    ✓ can ctrl-a on decimal (48ms)

    ✓ can ctrl-a with numeric prefix (74ms)

    ✓ can ctrl-a on a decimal (71ms)

    ✓ can ctrl-a on an octal  (47ms)

    ✓ Correctly increments in the middle of a number (72ms)

    ✓ can ctrl-x correctly behind a word (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a on an number with word before  (221ms)

    ✓ can ctrl-a on an number with word before and after  (167ms)

    ✓ can ctrl-x on a negative number with word before and after  (235ms)

    ✓ can ctrl-a properly on multiple lines (89ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (213ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (152ms)

    ✓ can <C-a> on word with - in front of it (223ms)

    ✓ can do Y (155ms)

    ✓ Can do S (205ms)

    ✓ / does not affect mark (158ms)

    ✓ / can search with regex (184ms)

    ✓ / can search with newline (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ / can search through multiple newlines (271ms)

    ✓ / matches ^ per line (86ms)

    ✓ / matches $ per line (198ms)

    ✓ Can search for forward slash (83ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can search backward for question mark (220ms)

    ✓ /\c forces case insensitive search (158ms)

    ✓ /\C forces case sensitive search (213ms)

    ✓ <BS> deletes the last character in search in progress mode (171ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <S-BS> deletes the last character in search in progress mode (215ms)

    ✓ <C-h> deletes the last character in search in progress mode (188ms)

    ✓ Can do C (43ms)

    ✓ Can do cit on a matching tag (218ms)

    ✓ Ignores cit on a non-matching tag (142ms)

    ✓ Ignores cit on a nested tag (213ms)

    ✓ Can do cit on a tag with an attribute tag (169ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cat on a matching tag (227ms)

    ✓ Can do cit on a multiline tag (118ms)

    ✓ Can do cit on a multiline tag with nested tags (81ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (72ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (84ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (186ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (167ms)

    ✓ can do cit with self closing tags (77ms)

    ✓ Respects indentation with cc (206ms)

    ✓ Resets cursor to indent end with cc (185ms)

    ✓ can handle 'cc' on empty line (141ms)

    ✓ cc copies linewise (226ms)

    ✓ Indent current line with correct Vim Mode (87ms)

    ✓ Can handle <Esc> and do nothing

    ✓ Can handle # on consecutive words (127ms)

    ✓ Can handle # on skipped words (98ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (113ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (234ms)

    ✓ cc on whitespace-only treats whitespace as indent (207ms)

    ✓ Can do cai (158ms)

    ✓ Can do cii (74ms)

    ✓ Can do caI (99ms)

    ✓ Can do dai (106ms)

    ✓ Can do dii (51ms)

    ✓ Can do daI (83ms)

    ✓ `] go to the end of the previously operated or put text (118ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '] go to the end of the previously operated or put text (252ms)

    ✓ `[ go to the start of the previously operated or put text (124ms)

    ✓ '[ go to the start of the previously operated or put text (470ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (318ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (171ms)

    can handle gn

      ✓ gn selects the next match text (186ms)

      ✓ gn selects the current word at |hello (221ms)

      ✓ gn selects the current word at h|ello (188ms)

      ✓ gn selects the current word at hel|lo (232ms)

      ✓ gn selects the current word at hell|o (184ms)

      ✓ gn selects the next word at hello| (213ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (141ms)

      ✓ dgn deletes the current word when cursor is at |hello (153ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at h|ello (290ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (175ms)

      ✓ dgn deletes the current word when cursor is at hell|o (243ms)

      ✓ dgn deletes the next word when cursor is at hello| (177ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (262ms)

      ✓ cgn deletes the current word when cursor is at |hello (186ms)

      ✓ cgn deletes the current word when cursor is at h|ello (79ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (169ms)

      ✓ cgn deletes the current word when cursor is at hell|o (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next word when cursor is at hello| (250ms)

    can handle gN

      ✓ gN selects the previous match text (223ms)

      ✓ gN selects the current word at hell|o (211ms)

      ✓ gN selects the current word at hel|lo (231ms)

      ✓ gN selects the current word at h|ello (168ms)

      ✓ gN selects the current word at |hello (318ms)

      ✓ gN selects the previous word at | hello (218ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (68ms)

      ✓ dgN deletes the current word when cursor is at hell|o (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at hel|lo (253ms)

      ✓ dgN deletes the current word when cursor is at h|ello (184ms)

      ✓ dgN deletes the current word when cursor is at |hello (199ms)

      ✓ dgN deletes the previous word when cursor is at | hello (187ms)

    can handle cgN

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the previous match text (from first line) (247ms)

      ✓ cgN deletes the current word when cursor is at hell|o (169ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (263ms)

      ✓ cgN deletes the current word when cursor is at h|ello (204ms)

      ✓ cgN deletes the current word when cursor is at |hello (111ms)

      ✓ cgN deletes the previous word when cursor is at | hello (239ms)

  Mode Replace

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can activate with <Insert> from Insert mode (183ms)

    ✓ Can activate with R from Normal mode (142ms)

    ✓ Can handle R (218ms)

    ✓ Can handle R past current line (144ms)

    ✓ Can handle R and exit Replace Mode (208ms)

    ✓ Can handle R across lines (112ms)

    ✓ Can handle R across lines and exit Replace Mode (217ms)

    ✓ Can handle R with {count} (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle backspace (235ms)

    ✓ Can handle backspace (82ms)

    ✓ Can handle backspace across lines (249ms)

    ✓ Can handle arrows (112ms)

    ✓ Can handle . (120ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle . across lines (436ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (99ms)

    ✓ Can handle wd (61ms)

    ✓ Can handle x (98ms)

    ✓ Can handle x across a selection (85ms)

    ✓ Can do vwd in middle of sentence (130ms)

    ✓ Can do vwd in middle of sentence (90ms)

    ✓ Can do vwd multiple times (300ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (118ms)

    ✓ Can handle H key (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle backspace key (129ms)

    ✓ handles case where we delete over a newline (170ms)

    ✓ handles change operator (116ms)

    ✓ Can do vat on multiple matching tags (205ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (189ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (235ms)

    ✓ Repeat-prefixed vat does not bleed below (195ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (48ms)

    ✓ Can do vi) on a matching parenthesis (113ms)

    ✓ Can do vi) on multiple matching parens (237ms)

    ✓ Can do va) on a matching parenthesis (151ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va) on multiple matching parens (242ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (116ms)

    ✓ Repeat-prefixed va) does not bleed below (240ms)

    ✓ Can do va} on a matching bracket as first character (44ms)

    ✓ Can do va} on multiple matching brackets (64ms)

    ✓ Can do vi( on a matching bracket near first character (65ms)

    ✓ Can do vi{ on outer pair of nested braces (49ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (52ms)

    ✓ Can do va] on multiple matching brackets (61ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (248ms)

    ✓ Repeat-prefixed vaf does not bleed below (91ms)

    ✓ vaf only expands to enclosing pairs (107ms)

    ✓ Can use . to repeat indent in visual (108ms)

    ✓ Can do v_x to delete to first char (231ms)

    ✓ Can do vg_x to delete to last char with no EOL (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v3g_x to delete to last char with no EOL with count (252ms)

    ✓ Can do v$x to delete to last char including EOL (109ms)

    ✓ Can do gv to reselect previous selection (233ms)

    Vim's EOL handling is weird

      ✓ delete through eol (87ms)

      ✓ join 2 lines by deleting through eol (169ms)

      ✓ d$ doesn't delete whole line (53ms)

      ✓ vd$ does delete whole line (61ms)

      ✓ Paste over selection copies the selection (229ms)

      ✓ Paste over selection copies the selection linewise (183ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (175ms)

      ✓ Can handle <down> key (183ms)

      ✓ Can handle <left> key (61ms)

      ✓ Can handle <right> key

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (87ms)

      ✓ Can handle 'gj' (51ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (234ms)

      ✓ Can handle 'vawd' on word with trailing spaces (140ms)

      ✓ Can handle 'vawd' on word with leading spaces (178ms)

      ✓ Can handle 'vawd' on word with numeric prefix (235ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (148ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (98ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (233ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (185ms)

      ✓ Can handle 'vaWd' on word with leading spaces (83ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (280ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (164ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (230ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (133ms)

      ✓ Can handle 'vaWd' on word with leading spaces (222ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (134ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (123ms)

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (227ms)

      ✓ Can handle 'vawd' on word with trailing spaces (173ms)

      ✓ Can handle 'vawd' on word with leading spaces (209ms)

      ✓ Can handle 'vawd' on word with numeric prefix (70ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (95ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (204ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (172ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (282ms)

      ✓ Can handle 'vaWd' on word with leading spaces (327ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (119ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (197ms)

      ✓ Can handle 'Y' in visual mode (170ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (220ms)

      ✓ Select multiple sentences in visual mode (145ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (197ms)

      ✓ Select inner sentence with leading spaces in visual mode (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select spaces between sentences in visual mode (243ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (133ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (202ms)

      ✓ Can do vat on a matching tag (72ms)

    handles replace in visual mode

      ✓ Can do a single line replace (227ms)

      ✓ Can do a multi line replace (184ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (95ms)

      ✓ D deletes the current line (219ms)

    handles indent blocks in visual mode

      ✓ Can do vai (165ms)

      ✓ Can do vii (66ms)

      ✓ Doesn't naively select the next line (209ms)

      ✓ Searches backwards if cursor line is empty (132ms)

      ✓ Can do vaI (121ms)

    visualstar

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with * (219ms)

      ✓ Works with # (91ms)

    search works in visual mode

      ✓ Works with / (79ms)

      ✓ Works with ? (63ms)

      ✓ Selects correct range (80ms)

    X will delete linewise

      ✓ normal selection (199ms)

      ✓ normal selection (151ms)

    C will delete linewise

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (234ms)

      ✓ normal selection (149ms)

    R will delete linewise

      ✓ normal selection (178ms)

      ✓ normal selection (201ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (142ms)

      ✓ upward selection (79ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (107ms)

      ✓ multiline indent bottom up selection (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent top down selection (233ms)

      ✓ repeat multiline indent bottom up selection (176ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (53ms)

      ✓ multiline outdent bottom up selection (51ms)

      ✓ repeat multiline outdent top down selection (232ms)

      ✓ repeat multiline outdent bottom up selection (124ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (128ms)

    vi{ will go to end of second to last line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ select (239ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode (51ms)

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (346ms)

      ✓ gv selects the last pasted text (which is longer than original) (272ms)

      ✓ gv selects the last pasted text (multiline) (145ms)

    can handle gn

      ✓ gn selects the next match text (230ms)

      ✓ gn selects the current word at |hello (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the current word at h|ello (234ms)

      ✓ gn selects the current word at hel|lo (191ms)

      ✓ gn selects the next word at hell|o (175ms)

      ✓ gn selects the next word at hello| (181ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (53ms)

      ✓ multiline insert from top down selection (74ms)

      ✓ skips blank lines (69ms)

    can append text with A

      ✓ multiline append from bottom up selection (74ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (234ms)

      ✓ skips blank lines (114ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (596ms)

      ✓ U/gU across a selection (207ms)

      ✓ U/gU across a selection (reverse) (202ms)

      ✓ u/gu on single character (205ms)

      ✓ u/gu across a selection (226ms)

      ✓ u/gu across a selection (reverse) (165ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (248ms)

    ✓ Can handle I forward select (140ms)

    ✓ Can handle I backwards select (81ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (245ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (183ms)

    ✓ Can handle c forward select (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle c backwards select (613ms)

    ✓ Can handle C (155ms)

    ✓ Can do a multi line replace (223ms)

    ✓ Can handle 'D' (150ms)

    ✓ Can handle 'gj' (68ms)

    ✓ Properly add to end of lines j then $ (94ms)

    ✓ Properly add to end of lines $ then j (49ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ o works in visual block mode (230ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (130ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (110ms)

    ✓ Can handle wd (67ms)

    ✓ Can handle x (199ms)

    ✓ Can handle x across a selection (103ms)

    ✓ Can do vwd in middle of sentence (115ms)

    ✓ Can do vwd in middle of sentence (89ms)

    ✓ Can do vwd multiple times (137ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (104ms)

    ✓ handles case where we delete over a newline (117ms)

    ✓ handles change operator (114ms)

    ✓ Vp updates register content (218ms)

    ✓ Vp does not append unnecessary newlines (first line) (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (226ms)

    ✓ Vp does not append unnecessary newlines (last line) (183ms)

    Vim's EOL handling is weird

      ✓ delete through eol (57ms)

      ✓ join 2 lines by deleting through eol (54ms)

      ✓ d$ doesn't delete whole line (56ms)

      ✓ vd$ does delete whole line (50ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (64ms)

      ✓ Can handle <down> key (216ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (210ms)

      ✓ Can handle 'gj' (50ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (63ms)

      ✓ Can handle d key (56ms)

      ✓ Can handle d key (43ms)

      ✓ Can handle d key (39ms)

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (104ms)

      ✓ Can do a multi visual line replace (39ms)

      ✓ Can do a multi visual line replace from the bottom up (112ms)

    search works in visual line mode

      ✓ Works with / (77ms)

      ✓ Works with ? (47ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (94ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (42ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ linewise visual put works also in the end of document (228ms)

      ✓ gv selects the last pasted text (which is shorter than original) (340ms)

      ✓ gv selects the last pasted text (which is longer than original) (237ms)

      ✓ gv selects the last pasted text (multiline) (131ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (56ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline insert from top down selection (311ms)

      ✓ skips blank lines (171ms)

    can append text with A

      ✓ multiline append from bottom up selection (76ms)

      ✓ multiline append from top down selection (49ms)

      ✓ skips blank lines (79ms)

  Mode Normal

    ✓ Can handle 'x'

    ✓ Can handle 'Nx' (105ms)

    ✓ Can handle 'Nx' and paste (135ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'x' at end of line (251ms)

    ✓ Can handle 'Ns' (146ms)

    ✓ Can handle 'Ns' at end of line (201ms)

    ✓ Can handle '<Del>' (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (219ms)

    ✓ Can handle '<Del>' at end of line (202ms)

    ✓ Can handle 'cc' (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'Ncc' (311ms)

    ✓ Can handle 'yy' (231ms)

    ✓ Can handle 'D' (126ms)

    ✓ Can handle 'D' on empty lines (211ms)

    ✓ Can handle 'DD' (140ms)

    ✓ Can handle 'C' (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'NC' (215ms)

    ✓ Can handle 'NC' and put (169ms)

    ✓ Can handle 'r' (208ms)

    ✓ Can handle '<Count>r' (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<Count>r' (215ms)

    ✓ Can handle 'r' after 'dd' (193ms)

    ✓ Can handle 'r
' (182ms)

    ✓ Can handle '<Count>r
' (216ms)

    ✓ Can handle 'J' once (161ms)

    ✓ Can handle 'J' twice (149ms)

    ✓ Can handle 'J' with empty last line (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J's with multiple empty last lines (267ms)

    ✓ Can handle 'J' with leading white space on next line (340ms)

    ✓ Can handle 'J' with only white space on next line (64ms)

    ✓ Can handle 'J' with TWO indented lines (48ms)

    ✓ Can handle 'J' with ')' first character on next line (77ms)

    ✓ Can handle 'J' with a following delete

    ✓ Can handle 'J' in Visual Line mode (91ms)

    ✓ Can handle 'gJ' once

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (106ms)

    ✓ Can handle '~' (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'g~{motion}' (235ms)

    ✓ Can handle '<BS>' in insert mode (134ms)

    ✓ Can handle undo with P (172ms)

    ✓ Can handle 'ge' in multiple lines case1 (70ms)

    ✓ Can handle 'ge' in multiple lines case2 (68ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (52ms)

    ✓ Can repeat '~' with dot (76ms)

    ✓ Can repeat 'x' (50ms)

    ✓ Can repeat 'J' (69ms)

    ✓ Can handle dot with A (73ms)

    ✓ Can handle dot with I (81ms)

    ✓ Can repeat actions that require selections (80ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (73ms)

    ✓ Can repeat insert change and '<C-t>' (72ms)

    ✓ Can repeat change by `<C-a>` (355ms)

    ✓ Only one arrow key can be repeated in Insert Mode (117ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Cached content change will be cleared by arrow keys (278ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (78ms)

    ✓ inside parenthesis (74ms)

    ✓ nested parenthesis beginning (49ms)

    ✓ nested parenthesis end (81ms)

    ✓ nested bracket and parenthesis beginning (231ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested bracket, parenthesis, braces beginning (167ms)

    ✓ nested bracket, parenthesis, braces end (47ms)

    ✓ parentheses after > (210ms)

    ✓ parentheses after " (177ms)

  Motions in Normal Mode

    ✓ Can handle [( (116ms)

    ✓ Can handle nested [( (190ms)

    ✓ Can handle <number>[( (193ms)

    ✓ Can handle [( and character under cursor exclusive (40ms)

    ✓ Can handle ]) (81ms)

    ✓ Can handle nested ]) (46ms)

    ✓ Can handle <number>]) (82ms)

    ✓ Can handle ]) and character under cursor exclusive

    ✓ Can handle [{ (211ms)

    ✓ Can handle nested [{ (152ms)

    ✓ Can handle <number>[{ (201ms)

    ✓ Can handle [{ and character under cursor exclusive (180ms)

    ✓ Can handle ]} (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle nested ]} (41ms)

    ✓ Can handle <number>]} (49ms)

    ✓ Can handle ]} and character under cursor exclusive (71ms)

    ✓ Can handle 'ge' (43ms)

    ✓ Can handle 'gg' (211ms)

    ✓ Can handle 'gg' to first non blank char on random line (43ms)

    ✓ Can handle 'gg' to first non blank char on first line (51ms)

    ✓ 'gg' obeys startofline (67ms)

    ✓ Retain same column when moving up/down (54ms)

    ✓ Can handle <enter> (70ms)

    ✓ $ always keeps cursor on EOL (68ms)

    ✓ Can handle $ with a count (66ms)

    ✓ Can handle $ with a count at end of file (48ms)

    ✓ Can handle <End> with a count (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <D-right> with a count (702ms)

    ✓ Can handle 'f' (187ms)

    ✓ Can handle 'f' twice (202ms)

    ✓ Can handle 'f' with <tab> (177ms)

    ✓ Can handle 'f' and find back search (87ms)

    ✓ Can handle 'F' (50ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' twice (225ms)

    ✓ Can handle 'F' and find back search (172ms)

    ✓ Can handle 'f' and multiple back searches (68ms)

    ✓ Can handle 't' (48ms)

    ✓ Can handle 't' twice (95ms)

    ✓ Can handle 't' and find back search (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'T' (161ms)

    ✓ Can handle 'T' twice (48ms)

    ✓ Can handle 'T' and find back search (48ms)

    ✓ Can run a forward search (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a forward and find next search (328ms)

    ✓ Can run a forward and find previous search from end of word (197ms)

    ✓ Can run a reverse search (55ms)

    ✓ Can run a reverse and find next search (62ms)

    ✓ cancelled search reverts to previous search state (64ms)

    ✓ Backspace on empty search cancels (44ms)

    ✓ Search offsets: b does nothing (89ms)

    ✓ Search offsets: b2 goes 2 to the right (49ms)

    ✓ Search offsets: b+3 goes 3 to the right (67ms)

    ✓ Search offsets: e goes to the end (59ms)

    ✓ Search offsets: character offset goes across line boundaries (67ms)

    ✓ Search offsets: 2 goes 2 down (61ms)

    ✓ Search offsets: -2 goes 2 up (41ms)

    ✓ maintains column position correctly (101ms)

    ✓ maintains column position correctly with $

    ✓ Can handle G  (83ms)

    ✓ Can handle G with number prefix

    ✓ Can handle G with number prefix (94ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix (86ms)

    ✓ Can handle 0 (66ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 0 as part of a repeat (653ms)

    ✓ Can handle g* (77ms)

    ✓ Can handle g*n

    ✓ Can handle * (77ms)

    ✓ Can handle **

    ✓ Can handle # on whitespace (40ms)

    ✓ Can handle # on EOL (47ms)

    ✓ Can handle g# (81ms)

    ✓ Can handle g#n (63ms)

    ✓ Can handle # (64ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (65ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ * adds to search history (227ms)

    ✓ # adds to search history (101ms)

    ✓ Can handle | (124ms)

    ✓ Can handle <number> | (57ms)

    ✓ Can handle + (44ms)

    ✓ Can handle + indent (71ms)

    ✓ Can handle + with count prefix (54ms)

    ✓ Can handle -

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key (42ms)

    ✓ Can handle <right> key

    ✓ Can handle 'gk' (42ms)

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

      ✓ move to word right

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph
      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (51ms)

      insert mode

        ✓ <left> wraps to previous line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <right> once goes to end of line (288ms)

        ✓ <right> twice wraps to next line (134ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (209ms)

        ✓ l does not wrap to next line (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <left> does not wrap to previous line (215ms)

        ✓ <right> does not wrap to next line (128ms)

      insert mode

        ✓ <left> does not wrap to previous line (215ms)

        ✓ <right> does not wrap to next line (187ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (188ms)

      ✓ search wraps around the start of the file (78ms)

    wrapscan disabled

      ✓ search stops at the end of the file (47ms)

      ✓ search stops at the start of the file (85ms)

  Multicursor

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can add multiple cursors below (458ms)

    ✓ can add multiple cursors above (223ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (337ms)

    ✓ gcj comments in current and next line (194ms)

    ✓ block comment with motion (173ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment in Visual Mode (226ms)

    ✓ comment in visual line mode (62ms)

    ✓ comment in visual block mode (170ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (502ms)

    ✓ =$ formats entire line (354ms)

    ✓ =j formats two lines (128ms)

    ✓ 3=k formats three lines (118ms)

    ✓ =gg formats to top of file (134ms)

    ✓ =G formats to bottom of file (212ms)

    ✓ =ip formats paragraph (86ms)

    ✓ format in visual mode (112ms)

  put operator

    ✓ basic put test (88ms)

    ✓ test yy end of line (103ms)

    ✓ test yy first line (93ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test yy middle line (216ms)

    ✓ test yy with correct positon movement (168ms)

    ✓ test visual block single line yank p (248ms)

    ✓ test visual block single line yank P (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line delete p (315ms)

    ✓ test visual block single line delete P (189ms)

  rot13 operator

    ✓ rot13() unit test

    1) g?j works

    ✓ g? in visual mode works (48ms)

    ✓ g? in visual line mode works (73ms)

    ✓ g? in visual block mode works

  shift operator

    ✓ basic shift left test (96ms)

    ✓ shift left goto end test (67ms)

    ✓ shift left goto line test (48ms)

    ✓ shift right goto end test (67ms)

    ✓ shift right goto line test (57ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (71ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (42ms)

      ✓ step to Camel word (85ms)

      ✓ step to CAP word (49ms)

      ✓ step after CAP word (116ms)

      ✓ step from middle of word to Camel word (212ms)

      ✓ step to number word (169ms)

      ✓ step to operator word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (218ms)

      ✓ step to operator and then over (176ms)

    handles <leader>w for underscore_var

      ✓ step to _word (140ms)

      ✓ step over whitespace to word (213ms)

      ✓ step from inside word to _word (184ms)

      ✓ step form _word to number (206ms)

      ✓ step from nubmer word to _word (76ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from in whitespace to word (217ms)

      ✓ step in ALL_CAPS_WORD (180ms)

    handles d<leader>w

      ✓ delete from start of camelWord (128ms)

      ✓ delete from middle of camelWord (147ms)

      ✓ delete from start of CamelWord (74ms)

      ✓ delete two words from camelWord (214ms)

      ✓ delete from start of underscore_word (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete from middle of underscore_word (716ms)

      ✓ delete two words from camel_word

    handles di<leader>w

      ✓ delete from start of camelWord (63ms)

      ✓ delete from middle of camelWord

      ✓ delete from start of CamelWord (85ms)

      ✓ delete two words from camelWord (204ms)

      ✓ delete from start of underscore_word (62ms)

      ✓ delete from middle of underscore_word

      ✓ delete two words from camel_word (77ms)

    handles <leader>b

      ✓ back from middle of word (71ms)

      ✓ back over whitespace to camelWord (195ms)

      ✓ back twice over operator (178ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (154ms)

      ✓ from middle to end of underscore_word (119ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ twice to end of word over operator (220ms)

  easymotion plugin

    ✓ Can handle s move (123ms)

    ✓ Can handle 2s move (192ms)

    ✓ Can handle f move (211ms)

    ✓ Can handle 2f move (182ms)

    ✓ Can handle F move (137ms)

    ✓ Can handle 2F move (203ms)

    ✓ Can handle t move (171ms)

    ✓ Can handle bd-t move (223ms)

    ✓ Can handle 2t move (165ms)

    ✓ Can handle bd-t2 move (201ms)

    ✓ Can handle T move (182ms)

    ✓ Can handle 2T move (145ms)

    ✓ Can handle w move (204ms)

    ✓ Can handle bd-w move (189ms)

    ✓ Can handle b move (201ms)

    ✓ Can handle e move (43ms)

    ✓ Can handle bd-e move (215ms)

    ✓ Can handle ge move (188ms)

    ✓ Can handle n-char move (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle j move (243ms)

    ✓ Can handle k move (110ms)

    ✓ Can handle bd-jk move (1) (249ms)

    ✓ Can handle bd-jk move (2) (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle lineforward move (1) (218ms)

    ✓ Can handle lineforward move (2)

    ✓ Can handle linebackward move (1) (146ms)

    ✓ Can handle linebackward move (2) (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for backslash (\) (625ms)

    ✓ Can handle searching for carat (^) (183ms)

    ✓ Can handle searching for dot (.) (198ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (58ms)

    ✓ Replaces within inner Word (81ms)

    ✓ Replaces within '' (231ms)

    ✓ Replaces within '' including spaces (114ms)

    ✓ Replaces within () (207ms)

    ✓ Replaces within () including spaces (112ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces within a paragraph (236ms)

    ✓ Replaces using a specified register (175ms)

    ✓ Replaces within {} over multiple lines (219ms)

    ✓ Replaces a multiline register within {} over multiple lines (163ms)

    ✓ Replaces a multiline register within {} over multiple lines (205ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (178ms)

    ✓ grr replaces the entire line with the register (64ms)

    ✓ grr can replace multiple lines (64ms)

    ✓ Replaces in visual mode (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode using a specified register (260ms)

    ✓ Replaces in visual line mode (181ms)

    ✓ grj is linewise (85ms)

  sneak plugin

    ✓ Can handle s motion (210ms)

    ✓ Can handle S motion (163ms)

    ✓ Can handle <operator>z motion (234ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <operator>Z motion (740ms)

    ✓ Can handle s; motion (93ms)

    ✓ Can handle s, motion (179ms)

    ✓ Can handle S; motion (187ms)

    ✓ Can handle S, motion (227ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter s motion (42ms)

    ✓ Can handle single letter S motion (49ms)

    ✓ Can handle single letter <operator>z motion (61ms)

    ✓ Can handle single letter <operator>Z motion (57ms)

    ✓ Can handle single letter s; motion (218ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter s, motion (182ms)

    ✓ Can handle single letter S; motion (163ms)

    ✓ Can handle single letter S, motion (51ms)

    ✓ Can handle multiline single char <number>s motion (70ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (108ms)

    ✓ 'ysiw(' surrounds word with space (191ms)

    ✓ 'ysw)' surrounds word without space (129ms)

    ✓ 'ysw(' surrounds word with space (197ms)

    ✓ 'ysaw)' surrounds word without space (104ms)

    ✓ 'ysaw(' surrounds word with space (163ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (75ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw<' surrounds word with tags (174ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'cst<' surrounds word with tags that have a dot in them (477ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (147ms)

    ✓ change surround (144ms)

    ✓ change surround with two pairs of quotes (179ms)

    ✓ change surround with two pairs of parens (114ms)

    ✓ change surround with alias (179ms)

    ✓ change surround to tags (76ms)

    ✓ delete surround (186ms)

    ✓ delete surround with quotes (63ms)

    ✓ delete surround with nested of quotes (210ms)

    ✓ delete surround with inconsistent quotes (114ms)

    ✓ delete surround with mixed quotes (180ms)

    ✓ delete surround with empty quotes cursor at start (103ms)

    ✓ delete surround with empty quotes cursor at end (123ms)

    ✓ don't delete surround if cursor is after closing match (129ms)

    ✓ delete surround if cursor is before opening match (208ms)

    ✓ delete surround with two pairs of parens (145ms)

    ✓ delete surround with alias (132ms)

    ✓ delete surround with tags (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (342ms)

    ✓ changing brackets with surround works again (117ms)

    ✓ change surround with tags that contain an attribute and preserve them (133ms)

    ✓ change surround with tags that contain an attribute and remove them (144ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (233ms)

    ✓ Can use two registers together (77ms)

    ✓ Can use black hole register (140ms)

    ✓ System clipboard works with chinese characters

    ✓ Yank stores text in Register '0' (189ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (128ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (131ms)

    ✓ Register '1'-'9' stores delete content (146ms)

    ✓ "A appends linewise text to "a (130ms)

    ✓ "A appends character wise text to "a (172ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (88ms)

    ✓ Small deletion using Del is stored in small delete register (103ms)

    ✓ Small deletion using X is stored in small delete register (103ms)

    ✓ Search register (/) is set by forward search (193ms)

    ✓ Search register (/) is set by backward search (196ms)

    ✓ Search register (/) is set by star search (163ms)

    ✓ Command register (:) is set by command line (73ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Read-only registers cannot be written to (521ms)

    clipboard

      ✓ Can access '*' (clipboard) register (44ms)

      ✓ Can access '+' (clipboard) register (73ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character>

    ✓ Can repeat reversed F<character> (110ms)

    ✓ Can repeat t<character> (80ms)

    ✓ Can repeat N times reversed t<character> (44ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (127ms)

      ✓ move one sentence backward (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move [count] sentences backward (333ms)

      ✓ move one sentence backward single line - middle (147ms)

      ✓ move one sentence backward no space (158ms)

      ✓ move one sentence backward no space - middle (162ms)

      ✓ move one sentence backward - multiline (109ms)

      ✓ move one sentence backward - multiline - period (159ms)

      ✓ move one sentence backward - multiline - previous line (190ms)

      ✓ move one sentence backward - multiline - previous line - period (155ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line
    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1304 passing (4m)

  4 pending

  1 failing

  1) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=aop.
      + expected - actual

      -aop
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:29:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
The command "npm test" exited with 1.
store build cache
nothing changed


Done. Your build exited with 1.
npm test
> vim@1.12.3 test /home/travis/build/VSCodeVim/Vim
> node ./node_modules/vscode/bin/test

### VS Code Extension Test Run ###

Current working directory: /home/travis/build/VSCodeVim/Vim
Downloading VS Code 1.41.1 into .vscode-test/vscode-1.41.1.
Downloading VS Code from: https://update.code.visualstudio.com/1.41.1/linux-x64/stable
Downloaded VS Code 1.41.1
Running extension tests: /home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/code /home/travis/build/VSCodeVim/Vim/out/test --extensionDevelopmentPath=/home/travis/build/VSCodeVim/Vim --extensionTestsPath=/home/travis/build/VSCodeVim/Vim/out/test --locale=en
[main 2019-12-26T06:17:56.910Z] update#setState idle

bash: cannot set terminal process group (-1): Inappropriate ioctl for device

bash: no job control in this shell

nvm is not compatible with the "npm_config_prefix" environment variable: currently set to "/home/travis/.nvm/versions/node/v8.17.0"

Run `unset npm_config_prefix` to unset it.



  base action

    ✓ compare key presses

    ✓ couldActionApply 1D keys positive

    ✓ couldActionApply 1D keys negative

    ✓ couldActionApply 2D keys positive

    ✓ couldActionApply 2D keys negative

    ✓ doesActionApply 1D keys positive

    ✓ doesActionApply 1D keys negative

    ✓ doesActionApply 2D keys positive

    ✓ doesActionApply 2D keys negative

  cmd_line/search command

    ✓ command <C-w> can remove word in cmd line (41ms)

    ✓ command <C-w> can remove word in search mode

    ✓ command <C-w> can remove word in cmd line while retrain cmd on the right of the cursor

    ✓ command <C-w> can remove word in search mode while retrain cmd on the right of the cursor

    ✓ <C-u> deletes from cursor to first character

    ✓ <C-b> puts cursor at start of command line (40ms)

    ✓ <Home> puts cursor at start of command line

    ✓ <C-e> puts cursor at end of command line

    ✓ <End> puts cursor at end of command line (44ms)

    ✓ <C-p>/<C-n> go to the previous/next command (54ms)

    ✓ <C-r> <C-w> insert word under cursor on command line (77ms)

    ✓ <C-r> <C-w> insert word right of cursor on command line (79ms)

    ✓ <C-r> <C-w> insert word under cursor in search mode (64ms)

  cursor location

    ✓ cursor location in command line

    ✓ cursor location in search

  HistoryFile

    ✓ add command

    ✓ add empty command

    ✓ add command over configuration.history

    ✓ add command that exists in history

    ✓ file system

    ✓ change configuration.history (55ms)

  command-line lexer
    ✓ can lex empty string
    ✓ can lex comma
    ✓ can lex percent
    ✓ can lex dollar
    ✓ can lex dot
    ✓ can lex one number
    ✓ can lex longer number
    ✓ can lex plus

    ✓ can lex minus
    ✓ can lex forward search
    ✓ can lex forward search escaping
    ✓ can lex reverse search

    ✓ can lex reverse search escaping

    ✓ can lex command name

    ✓ can lex command args
    ✓ can lex command args with leading whitespace

    ✓ can lex long command name and args

    ✓ can lex left and right line refs

  :only command

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Run :only (1224ms)

  command-line parser
    ✓ can parse empty string
    ✓ can parse left - dot
    ✓ can parse left - dollar

    ✓ can parse left - percent

    ✓ can parse separator - comma

    ✓ can parse right - dollar
  command line scanner
    ✓ ctor

    ✓ can detect EOF with empty input

    ✓ next() returns EOF at EOF

    ✓ can scan

    ✓ can emit

    ✓ can ignore

    ✓ can skip whitespace

    ✓ can skip whitespace with one char before EOF

    ✓ can skip whitespace at EOF

    ✓ nextWord() return EOF at EOF

    ✓ nextWord() return word before trailing spaces

    ✓ nextWord() can skip whitespaces and return word 

    ✓ nextWord() return word before EOF

    ✓ can expect one of a set

    ✓ can expect only one of a set

  Smile command

    ✓ :smile creates new tab (546ms)

    ✓ :smile editor contains smile text (531ms)

  Basic sort

    ✓ Sort whole file, asc (83ms)

    ✓ Sort whole file, asc, ignoreCase (123ms)

    ✓ Sort whole file, dsc (105ms)

    ✓ Sort whole file, dsc, ignoreCase (115ms)

    ✓ Sort range, asc (146ms)

    ✓ Sort range, asc, ignoreCase (91ms)

    ✓ Sort range, dsc (149ms)

    ✓ Sort range, dsc, ignoreCase (128ms)

    ✓ Sort whole file, asc, unique (154ms)

  Horizontal split

    ✓ :sp creates a second split (147ms)

    ✓ :split creates a second split (72ms)

    ✓ :new creates a second split (254ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

  :close args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :quit args parser

    ✓ can parse empty args

    ✓ ignores trailing white space

    ✓ can parse !

    ✓ throws if space before !

    ✓ ignores space after !

    ✓ throws if bad input

  :substitute args parser

    ✓ can parse pattern, replace, and flags

    ✓ can parse count

    ✓ can parse custom delimiter

    ✓ can escape delimiter

    ✓ can parse flag KeepPreviousFlags

  :tabm[ove] args parser

    ✓ has :tabm alias

    ✓ can parse empty args

    ✓ can parse an absolute position

    ✓ can parse a relative position

    ✓ fails with invalid inputs

  getParser

    ✓ empty

    ✓ :marks

    ✓ :write

    ✓ :nohlsearch

    ✓ :quitall

    :write args parser

      ✓ can parse empty args

      ✓ can parse ++opt

      ✓ throws if bad ++opt name

      ✓ can parse bang

      ✓ can parse ' !cmd'

      ✓ can parse ' !cmd' when cmd is empty

  Basic substitute

    ✓ Replace single word once (54ms)

    ✓ Replace with `g` flag

    ✓ Replace with flags AND count (91ms)

    ✓ Replace with `c` flag (48ms)

    ✓ Replace with `gc` flag (76ms)

    ✓ Replace across all lines (105ms)

    ✓ Replace on specific single line (75ms)

    ✓ Replace on current line using dot (88ms)

    ✓ Replace single relative line using dot and plus (101ms)

    ✓ Replace across specific line range (88ms)

    ✓ Replace across relative line range using dot, plus, and minus (162ms)

    ✓ Replace across relative line range using numLines+colon shorthand (64ms)

    ✓ Repeat replacement across relative line range (81ms)

    ✓ Replace with range AND count but no flags (112ms)

    ✓ Undocumented: operator without LHS assumes dot as LHS (78ms)

    ✓ Undocumented: multiple consecutive operators use 1 as RHS (77ms)

    ✓ Undocumented: trailing operators use 1 as RHS (95ms)

    ✓ Replace specific single equal lines (52ms)

    ✓ Replace current line with no active selection (91ms)

    ✓ Replace text in selection (90ms)

    ✓ Substitute support marks (82ms)

    Effects of gdefault=true

      ✓ Replace all matches in the line (39ms)

      ✓ Replace with `g` flag inverts global flag (46ms)

      ✓ Replace with `c` flag inverts global flag (79ms)

      ✓ Replace multiple lines (75ms)

      ✓ Replace across specific lines (156ms)

      ✓ Replace current line with no active selection (61ms)

      ✓ Replace text in selection (127ms)

      ✓ Substitute support marks (101ms)

      ✓ Substitute with escaped delimiter
    Substitute should use various previous search/substitute states

      ✓ Substitute with previous search using * (201ms)

      ✓ Substitute with previous search using # (302ms)

      ✓ Substitute with previous search using / (187ms)

      ✓ Substitute with parameters should update search state (112ms)

      ✓ Substitute with empty replacement should delete previous substitution (all variants) and accepts flags (201ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Substitute with no pattern should repeat previous substitution and not alter search state (282ms)

      ✓ Substitute repeat previous should accept flags (176ms)

      ✓ Substitute with empty search string should use last searched pattern (309ms)

      ✓ Ampersand (&) should repeat the last substitution (114ms)

  cmd_line tab

    ✓ tabe with no arguments when not in workspace opens an untitled file

    ✓ tabedit with no arguments when not in workspace opens an untitled file

    ✓ tabe with absolute path when not in workspace opens file (67ms)

    ✓ tabe with current file path does nothing (40ms)

  cmd_line tabComplete

    ✓ command line command tab completion

    ✓ command line command shift+tab

    ✓ command line file tab completion with no base path

    ✓ command line file tab completion with / as base path

    ✓ command line file tab completion with ~/ as base path

    ✓ command line file tab completion with ./ as base path

    ✓ command line file tab completion with ../ as base path

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ command line file tab completion directory with / at the end

    ✓ command line file navigate tab completion (63ms)

    ✓ command line tab completion on the content on the left of the cursor

    ✓ command line file tab completion with . (69ms)

    ✓ command line file tab completion with space in file path (107ms)

  Vertical split

    ✓ :vs creates a second split (82ms)

    ✓ :vsp creates a second split (67ms)

    ✓ :vsplit creates a second split (81ms)

    ✓ :vnew creates a second split (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ :vne creates a second split (283ms)

  Basic write-quit

    ✓ Run write and quit (46ms)

  Provide line completions

    Line Completion Provider unit tests

      ✓ Can complete lines in file, prioritizing above cursor, near cursor (84ms)

      ✓ Can complete lines in file with different indentation (87ms)

      ✓ Returns no completions for unmatched line

  Configuration

    ✓ remappings are normalized

    ✓ whichwrap is parsed into wrapKeys

    ✓ Can handle long key chords (58ms)

  Notation
    ✓ Normalize

  Remapper

    ✓ getLongestedRemappedKeySequence (90ms)

    ✓ getMatchingRemap (58ms)

    ✓ jj -> <Esc> through modehandler (70ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ 0 -> :wq through modehandler (84ms)

    ✓ <c-e> -> <esc> in insert mode should go to normal mode (94ms)

    ✓ leader, w -> closeActiveEditor in normal mode through modehandler (79ms)

    ✓ leader, c -> closeActiveEditor in visual mode through modehandler (87ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (129ms)

TextEditor is closed/disposed
TextEditor is closed/disposed

    ✓ d -> black hole register delete in normal mode through modehandler (144ms)

    ✓ jj -> <Esc> after ciw operator through modehandler (127ms)

  Neovim Validator

    ✓ neovim enabled without path

    ✓ neovim disabled

  Remapping Validator

    ✓ no remappings

    ✓ jj->esc

    ✓ remapping missing after and command

    ✓ remappings are de-duped

  VimrcKeyRemappingBuilder

    ✓ Build IKeyRemapping objects from .vimrc lines

  Error

    ✓ error code has message

  package.json

    ✓ all keys have handlers

    ✓ all defined configurations in package.json have handlers

  Record and navigate jumps

    Jump Tracker unit tests

      ✓ Can record jumps between files

      ✓ Can handle file jump events sent by vscode in response to recordJumpBack

      ✓ Can record jumps between files after switching files

      ✓ Can handle jumps to the same file multiple times

      ✓ Can record up to 100 jumps, the fixed length in vanilla Vim

      ✓ Can handle text deleted from a file

    Can record jumps for actions the same as vanilla Vim

      Can track basic jumps

        ✓ Can track jumps for keys: Ggg (74ms)

        ✓ Can track jumps for keys: GggG (83ms)

        ✓ Can track jumps for keys: GggGgg (65ms)

        ✓ Can track jumps for keys: /b<CR>n (74ms)

        ✓ Can track jumps for keys: G?b<CR>ggG (102ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: j%% (224ms)

      Can track jumps with back/forward

        ✓ Can track jumps for keys: j%%<C-o> (160ms)

        ✓ Can track jumps for keys: j%%<C-o><C-i> (195ms)

        ✓ Can track jumps for keys: j%%<C-o>% (181ms)

        ✓ Can track jumps for keys: j%%<C-o>gg (100ms)

        ✓ Can track jumps for keys: j%%<C-o><C-o>gg

        ✓ Can track jumps for keys: /^<CR>nnn<C-o><C-o><C-o><C-i>gg (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can enter number to jump back multiple times (232ms)

        ✓ Can track one-line `` jumps (223ms)

        ✓ Can track one-line double `` jumps (204ms)

        ✓ Can track one-line '' jumps (200ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track one-line double '' jumps (271ms)

        ✓ Can handle '' jumps with no previous jump (114ms)

      Can shifts jump lines up after deleting a line with Visual Line Mode

[main 2019-12-26T06:18:26.913Z] update#setState checking for updates

        ✓ Can track jumps for keys: /^<CR>nnnkkdd (121ms)

[main 2019-12-26T06:18:26.993Z] update#setState idle

        ✓ Can track jumps for keys: /^<CR>nnnkdd (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: /^<CR>nnnnn<C-o><C-o><C-o><C-o>dd (249ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkdd (204ms)

      Can shifts jump lines up after deleting a line with Visual Mode

        ✓ Can track jumps for keys: /^<CR>nnnkklvjjhx (264ms)

      Can shift jump lines down after inserting a line

        ✓ Can track jumps for keys: /^<CR>nnnkkoINSERTED<Esc>0 (273ms)

        ✓ Can track jumps for keys: /^<CR>nnnkoINSERTED<Esc>0 (208ms)

        ✓ Can track jumps for keys: /^<CR>nnnkOINSERTED<Esc>0 (269ms)

        ✓ Can track jumps for keys: /a4<CR>/a5<CR>kkkoINSERTED<Esc>0 (195ms)

      Can track jumps from substitutes

        ✓ Can track jumps for keys: :%s/a/b<CR> (217ms)

      Can track jumps from macros

        ✓ Can track jumps for keys: qq/^<CR>nq@q@q<C-o><C-o> (122ms)

      Can track jumps from marks

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ Can track jumps for keys: maG`a (239ms)

  Record and execute a macro

    ✓ Can record and execute (259ms)

    ✓ Can repeat last invoked macro (310ms)

    ✓ Can play back with count (335ms)

    ✓ Can play back with count, abort when a motion fails (554ms)

    ✓ Repeat change on contiguous lines (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Append command to a macro (328ms)

    ✓ Can record Ctrl Keys and repeat (167ms)

    ✓ Can execute macros with dot commands properly (274ms)

    ✓ : (command) register can be used as a macro (166ms)

  Mode Handler

    ✓ ctor

    ✓ can set current mode

  Mode Handler Map

    ✓ getOrCreate
  Mode Insert

    ✓ can be activated (105ms)

    ✓ can handle key events

    ✓ <Esc> should change cursor position

    ✓ <C-c> can exit insert (53ms)

    ✓ <Esc> can exit insert (84ms)

    ✓ Stay in insert when entering characters (62ms)

    ✓ Can handle 'O'

    ✓ 'i' puts you in insert mode before the cursor (114ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'I' puts you in insert mode at start of line (231ms)

    ✓ 'a' puts you in insert mode after the cursor (82ms)

    ✓ 'A' appends to end of line (66ms)

    ✓ '<C-w>' deletes a word (61ms)

    ✓ Can handle <C-w> on leading whitespace (46ms)

    ✓ Can handle <C-w> at beginning of line (64ms)

    ✓ <C-u> deletes to start of line (61ms)

    ✓ Can handle <C-u> on leading characters (56ms)

    ✓ Can handle <C-u> on leading whitespace (120ms)

    ✓ Correctly places the cursor after deleting the previous line break (80ms)

    ✓ will not remove leading spaces input by user

    ✓ will remove closing bracket

    ✓ Backspace works on whitespace only lines (107ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Backspace works on end of whitespace only lines (234ms)

    ✓ Backspace works at beginning of file (111ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal (107ms)

    ✓ Can perform <ctrl+o> to exit and perform one command in normal at the beginning of a row (95ms)

    ✓ Can perform insert command prefixed with count (48ms)

    ✓ Can perform append command prefixed with count (106ms)

    ✓ Can perform insert at start of line command prefixed with count (188ms)

    ✓ Can perform append to end of line command prefixed with count (84ms)

    ✓ Can perform change char (s) command prefixed with count (112ms)

    ✓ Can perform command prefixed with count with <C-[> (65ms)

    ✓ Can handle 'o' with count (128ms)

    ✓ Can handle 'O' with count (163ms)

    ✓ Can handle backspace at beginning of line with all spaces (65ms)

    ✓ Can handle digraph insert (82ms)

    ✓ Can handle custom digraph insert

  Mode Normal

    ✓ Can be activated

    ✓ Can handle dw (44ms)

    ✓ Can handle dw (51ms)

    ✓ Can handle dw (54ms)

    ✓ Can handle dw across lines (1) (62ms)

    ✓ Can handle dw across lines (2) (45ms)

    ✓ Can handle dd last line (97ms)

    ✓ Can handle dd single line

    ✓ Can handle dd (93ms)

    ✓ Can handle 3dd (117ms)

    ✓ Can handle 3dd off end of document (67ms)

    ✓ Can handle d2d (42ms)

    ✓ Can handle dd empty line (83ms)

    ✓ Can handle ddp (45ms)

    ✓ Can handle 'de' (68ms)

    ✓ Can handle 'de' then 'de' again (94ms)

    ✓ Can handle 'db' (64ms)

    ✓ Can handle 'db then 'db' again (80ms)

    ✓ Can handle 'dl' at end of line (84ms)

    ✓ Can handle 'dF' (92ms)

    ✓ Can handle 'dT' (50ms)

    ✓ Can handle 'd3' then <enter> (83ms)

    ✓ Can handle 'dj' (50ms)

    ✓ Can handle 'dk' (52ms)

    ✓ Can handle 'd])' without deleting closing parenthesis (91ms)

    ✓ Can handle 'd]}' without deleting closing bracket (65ms)

    ✓ Can handle 'cw' (200ms)

    ✓ Can handle 'cw' without deleting following white spaces (49ms)

    ✓ Can handle 'c2w'

    ✓ Can handle 'cw' without removing EOL (81ms)

    ✓ Can handle 'c])' without deleting closing parenthesis (83ms)

    ✓ Can handle 'c]}' without deleting closing bracket (174ms)

    ✓ Can handle 's' (58ms)

    ✓ Can handle 'yiw' with correct cursor ending position (49ms)

    ✓ Can handle 'ciw' (72ms)

    ✓ Can handle 'ciw' on blanks (112ms)

    ✓ Can handle 'caw' (115ms)

    ✓ Can handle 'caw' on first letter (148ms)

    ✓ Can handle 'caw' on blanks (128ms)

    ✓ Can handle 'caw' on blanks (40ms)

    ✓ Can handle 'ci(' on first parentheses (93ms)

    ✓ Can handle 'ci(' with nested parentheses (40ms)

    ✓ Can handle 'ci(' backwards through nested parens (71ms)

    ✓ Can handle 'cib' on first parentheses (73ms)

    ✓ Can handle 'ci(' across multiple lines with last character at beginning (58ms)

    ✓ Can handle count prefixed 'ci)' (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle count prefixed 'ca)' (237ms)

    ✓ Can handle 'ca(' spanning multiple lines (172ms)

    ✓ Can handle 'cab' spanning multiple lines (83ms)

    ✓ Can handle 'ci{' spanning multiple lines (42ms)

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly

    ✓ Can handle 'ci{' spanning multiple lines and handle whitespaces correctly (63ms)

    ✓ Can handle 'ci(' on the closing bracket (53ms)

    ✓ Can handle 'ciB' spanning multiple lines

    ✓ will fail when ca( with no () (68ms)

    ✓ will fail when ca{ with no {} (53ms)

    ✓ will fail when caB with no {} (75ms)

    ✓ Can handle 'ci[' spanning multiple lines

    ✓ Can handle 'ci]' on first bracket (68ms)

    ✓ Can handle 'ca[' on first bracket (57ms)

    ✓ Can handle 'ca]' on first bracket (64ms)

    ✓ Can handle 'ci'' on first quote (60ms)

    ✓ Can handle 'ci'' inside quoted string (82ms)

    ✓ Can handle 'ci'' on closing quote (107ms)

    ✓ Can handle 'ci'' when string is ahead (52ms)

    ✓ Can handle 'ci"' on opening quote (70ms)

    ✓ Can handle 'ci"' starting behind the quoted word (64ms)

    ✓ Can handle 'ca"' starting behind the quoted word (69ms)

    ✓ Can handle 'ca"' starting on the opening quote (69ms)

    ✓ Can handle 'ci"' with escaped quotes (77ms)

    ✓ Can handle 'ci"' with a single escaped quote (43ms)

    ✓ Can handle 'ci"' with a single escaped quote behind (97ms)

    ✓ Can handle 'ci"' with an escaped backslash (43ms)

    ✓ Can handle 'ci"' with an escaped backslash on closing quote (114ms)

    ✓ Can handle 'ca"' starting on the closing quote (78ms)

    ✓ Can handle 'ci"' with complex escape sequences (45ms)

    ✓ Can pick the correct open quote between two strings for 'ci"' (93ms)

    ✓ will fail when ca" ahead of quoted string (41ms)

    ✓ Can handle 'ca`' inside word (75ms)

    ✓ can handle cj (82ms)

    ✓ can handle ck (62ms)

    ✓ can handle c2j (117ms)

    ✓ can handle c2k (165ms)

    ✓ can handle cj on last line (94ms)

    ✓ can handle ck on first line (124ms)

    ✓ can handle c2j on last line (77ms)

    ✓ can handle c2k on first line (64ms)

    ✓ Can handle 'daw' on word with cursor inside spaces (43ms)

    ✓ Can handle 'daw' on word with trailing spaces (83ms)

    ✓ Can handle 'daw' on word with leading spaces (64ms)

    ✓ Can handle 'daw' on word with numeric prefix (66ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (144ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines (78ms)

    ✓ Can handle 'daw' on word with numeric prefix and across lines, containing words end with `.` (116ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'daw' on end of word (256ms)

    ✓ Can handle 'daw' on words at beginning of line with leading whitespace (45ms)

    ✓ Can handle 'daw' on words at ends of lines in the middle of whitespace (51ms)

    ✓ Can handle 'daw' on word at beginning of file (53ms)

    ✓ Can handle 'daw' on word at beginning of line (66ms)

    ✓ Can handle 'daw' on word at end of line with trailing whitespace (98ms)

    ✓ Can handle 'daw' around word at end of line (152ms)

    ✓ Can handle 'daW' on big word with cursor inside spaces (91ms)

    ✓ Can handle 'daW' around word at whitespace (78ms)

    ✓ Can handle 'daW' on word with trailing spaces (79ms)

    ✓ Can handle 'daW' on word with leading spaces (53ms)

    ✓ Can handle 'daW' on word with numeric prefix (39ms)

    ✓ Can handle 'daW' on word with numeric prefix and across lines (87ms)

    ✓ Can handle 'daW' on beginning of word (50ms)

    ✓ Can handle 'daW' on end of one line (51ms)

    ✓ Can handle 'daW' around word at the last WORD (t|wo) (84ms)

    ✓ Can handle 'daW' around word at the last WORD (tw|o) (51ms)

    ✓ Can handle 'daW' around word at the last WORD (class="btn"|>) (69ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (class="btn"|>) (67ms)

    ✓ Can handle 'daW' around word at the last WORD (c|lass="btn">) (71ms)

    ✓ Can handle 'daW' around word at the last WORD of the end of document (c|lass="btn">) (44ms)

    ✓ Can handle 'diw' on word with cursor inside spaces (104ms)

    ✓ Can handle 'diw' on word (179ms)

    ✓ Can handle 'diw' on word with numeric prefix (55ms)

    ✓ Can handle 'diw' on trailing spaces at the end of line (98ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines (100ms)

    ✓ Can handle 'diw' on word with numeric prefix and across lines, containing words end with `.` (110ms)

    ✓ Can handle 'diW' on big word with cursor inside spaces (64ms)

    ✓ Can handle 'diW' on word with trailing spaces (70ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'diW' on word with leading spaces (260ms)

    ✓ Can handle 'diW' on word with numeric prefix (40ms)

    ✓ Can handle 'diW' on word with numeric prefix and across lines (135ms)

    ✓ Can handle 'diW' on beginning of word (41ms)

    ✓ Can handle d} (69ms)

    ✓ Can handle y} at beginning of line (41ms)

    ✓ Select sentence with trailing spaces (82ms)

    ✓ Select sentence with leading spaces (140ms)

    ✓ Select inner sentence with trailing spaces (87ms)

    ✓ Select inner sentence with leading spaces (104ms)

    ✓ Select spaces between sentences (88ms)

    ✓ Can handle 'df' (49ms)

    ✓ Can handle 'dt' (94ms)

    ✓ Can handle backspace (40ms)

    ✓ Can handle backspace across lines (120ms)

    ✓ Can handle A and backspace (87ms)

    ✓ Can handle 'yy' without changing cursor position (53ms)

    ✓ Can handle 'P' after 'yy' (70ms)

    ✓ Can handle 'p' after 'yy' (56ms)

    ✓ Can handle 'P' after 'Nyy' (38ms)

    ✓ Can handle 'p' after 'Nyy' (58ms)

    ✓ Can handle 'p' after 'yy' with correct cursor position (68ms)

    ✓ Can handle 'gp' after 'yy' (56ms)

    ✓ Can handle 'gp' after 'Nyy' (40ms)

    ✓ Can handle 'gp' after 'Nyy' if pasting more than three lines (89ms)

    ✓ Can handle 'gp' after 'Nyy' if cursor is on the last line (65ms)

    ✓ Can handle 'gP' after 'yy' (84ms)

    ✓ Can handle 'gP' after 'Nyy' (53ms)

    ✓ Can handle 'gP' after 'Nyy' if pasting more than three lines (55ms)

    ✓ Can handle ']p' after yy (71ms)

    ✓ Can handle ']p' after 'Nyy'

    ✓ Can handle ']p' after 'Nyy' and indent with tabs first (50ms)

    ✓ Can handle ']p' after 'Nyy' and decrease indents if possible (59ms)

    ✓ Can handle '[p' after yy (84ms)

    ✓ Can handle '[p' after 'Nyy' (52ms)

    ✓ Can handle '[p' after 'Nyy' and indent with tabs first (49ms)

    ✓ Can handle '[p' after 'Nyy' and decrease indents if possible (82ms)

    ✓ Can handle 'p' after y'a (66ms)

    ✓ Can handle 'p' after 'y])' without including closing parenthesis (51ms)

    ✓ Can handle 'p' after 'y]}' without including closing bracket (213ms)

    ✓ Can handle pasting in visual mode over selection (199ms)

    ✓ Can repeat w (129ms)

    ✓ Can repeat p (60ms)

    ✓ I works correctly (77ms)

    ✓ gI works correctly (49ms)

    ✓ gi works correctly (112ms)

    ✓ `. works correctly (186ms)

    ✓ '. works correctly (130ms)

    ✓ g; works correctly (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ g, works correctly (281ms)

    ✓ g_ works correctly (89ms)

    ✓ 3g_ works correctly (218ms)

    ✓ gq handles spaces after single line comments correctly (298ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gq handles spaces before single line comments correctly (340ms)

    ✓ gq handles tabs before single line comments correctly (374ms)

    ✓ Can handle space (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle space (239ms)

    ✓ Undo 1 (234ms)

    ✓ Undo 2 (237ms)

    ✓ Undo cursor (233ms)

    ✓ Undo cursor 2 (193ms)

    ✓ Undo cursor 3 (183ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Undo with movement first (285ms)

    ✓ Can handle 'U' (120ms)

    ✓ Can handle 'U' for multiple changes (283ms)

    ✓ Can handle 'U' for new line below (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' for new line above (474ms)

    ✓ Can handle 'U' for consecutive changes only (248ms)

    ✓ Can handle 'u' to undo 'U' (145ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'U' to undo 'U' (247ms)

    ✓ Can handle 'u' after :s/abc/def (110ms)

    ✓ Redo (126ms)

    ✓ Redo (353ms)

    ✓ Redo (88ms)

    ✓ Can handle u (60ms)

    ✓ Can handle guw (92ms)

    ✓ Can handle gUw (193ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle u over line breaks (233ms)

    ✓ can handle s in visual mode (167ms)

    ✓ can handle p with selection (250ms)

    ✓ can handle P with selection (199ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle p in visual to end of line (263ms)

    ✓ can repeat backspace twice (213ms)

    ✓ can delete linewise with d2G (187ms)

    ✓ can delete with + motion and count (219ms)

    ✓ can delete with - motion and count (137ms)

    ✓ can dE correctly (182ms)

    ✓ can dE correctly (192ms)

    ✓ can dE correctly (148ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a correctly behind a word (220ms)

    ✓ can ctrl-a the right word (always the one AFTER the cursor) (109ms)

    ✓ can ctrl-a on word (213ms)

    ✓ can ctrl-a on a hex number (73ms)

    ✓ can ctrl-a on decimal (48ms)

    ✓ can ctrl-a with numeric prefix (74ms)

    ✓ can ctrl-a on a decimal (71ms)

    ✓ can ctrl-a on an octal  (47ms)

    ✓ Correctly increments in the middle of a number (72ms)

    ✓ can ctrl-x correctly behind a word (166ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can ctrl-a on an number with word before  (221ms)

    ✓ can ctrl-a on an number with word before and after  (167ms)

    ✓ can ctrl-x on a negative number with word before and after  (235ms)

    ✓ can ctrl-a properly on multiple lines (89ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can <C-a> on word with multiple numbers (incrementing first number) (213ms)

    ✓ can <C-a> on word with multiple numbers (incrementing second number) (152ms)

    ✓ can <C-a> on word with - in front of it (223ms)

    ✓ can do Y (155ms)

    ✓ Can do S (205ms)

    ✓ / does not affect mark (158ms)

    ✓ / can search with regex (184ms)

    ✓ / can search with newline (207ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ / can search through multiple newlines (271ms)

    ✓ / matches ^ per line (86ms)

    ✓ / matches $ per line (198ms)

    ✓ Can search for forward slash (83ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can search backward for question mark (220ms)

    ✓ /\c forces case insensitive search (158ms)

    ✓ /\C forces case sensitive search (213ms)

    ✓ <BS> deletes the last character in search in progress mode (171ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ <S-BS> deletes the last character in search in progress mode (215ms)

    ✓ <C-h> deletes the last character in search in progress mode (188ms)

    ✓ Can do C (43ms)

    ✓ Can do cit on a matching tag (218ms)

    ✓ Ignores cit on a non-matching tag (142ms)

    ✓ Ignores cit on a nested tag (213ms)

    ✓ Can do cit on a tag with an attribute tag (169ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do cat on a matching tag (227ms)

    ✓ Can do cit on a multiline tag (118ms)

    ✓ Can do cit on a multiline tag with nested tags (81ms)

    ✓ Can do cit inside of a tag with another non closing tag inside tags (72ms)

    ✓ Can do cit inside of a tag with another empty closing tag inside tags (84ms)

    ✓ Can do dit on empty tag block, cursor moves to inside (186ms)

    ✓ Can do cit on empty tag block, cursor moves to inside (167ms)

    ✓ can do cit with self closing tags (77ms)

    ✓ Respects indentation with cc (206ms)

    ✓ Resets cursor to indent end with cc (185ms)

    ✓ can handle 'cc' on empty line (141ms)

    ✓ cc copies linewise (226ms)

    ✓ Indent current line with correct Vim Mode (87ms)

    ✓ Can handle <Esc> and do nothing

    ✓ Can handle # on consecutive words (127ms)

    ✓ Can handle # on skipped words (98ms)

    ✓ Can 'D'elete the characters under the cursor until the end of the line (113ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can 'D'elete the characters under multiple cursors until the end of the line (234ms)

    ✓ cc on whitespace-only treats whitespace as indent (207ms)

    ✓ Can do cai (158ms)

    ✓ Can do cii (74ms)

    ✓ Can do caI (99ms)

    ✓ Can do dai (106ms)

    ✓ Can do dii (51ms)

    ✓ Can do daI (83ms)

    ✓ `] go to the end of the previously operated or put text (118ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ '] go to the end of the previously operated or put text (252ms)

    ✓ `[ go to the start of the previously operated or put text (124ms)

    ✓ '[ go to the start of the previously operated or put text (470ms)

    ✓ can handle <C-u> when first line is visible and starting column is at the beginning (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can handle <C-u> when first line is visible and starting column is at the end (318ms)

    ✓ can handle <C-u> when first line is visible and starting column is in the middle (171ms)

    can handle gn

      ✓ gn selects the next match text (186ms)

      ✓ gn selects the current word at |hello (221ms)

      ✓ gn selects the current word at h|ello (188ms)

      ✓ gn selects the current word at hel|lo (232ms)

      ✓ gn selects the current word at hell|o (184ms)

      ✓ gn selects the next word at hello| (213ms)

    can handle dgn

      ✓ dgn deletes the next match text (from first line) (141ms)

      ✓ dgn deletes the current word when cursor is at |hello (153ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgn deletes the current word when cursor is at h|ello (290ms)

      ✓ dgn deletes the current word when cursor is at hel|lo (175ms)

      ✓ dgn deletes the current word when cursor is at hell|o (243ms)

      ✓ dgn deletes the next word when cursor is at hello| (177ms)

    can handle cgn

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next match text (from first line) (262ms)

      ✓ cgn deletes the current word when cursor is at |hello (186ms)

      ✓ cgn deletes the current word when cursor is at h|ello (79ms)

      ✓ cgn deletes the current word when cursor is at hel|lo (169ms)

      ✓ cgn deletes the current word when cursor is at hell|o (168ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgn deletes the next word when cursor is at hello| (250ms)

    can handle gN

      ✓ gN selects the previous match text (223ms)

      ✓ gN selects the current word at hell|o (211ms)

      ✓ gN selects the current word at hel|lo (231ms)

      ✓ gN selects the current word at h|ello (168ms)

      ✓ gN selects the current word at |hello (318ms)

      ✓ gN selects the previous word at | hello (218ms)

    can handle dgN

      ✓ dgN deletes the previous match text (from first line) (68ms)

      ✓ dgN deletes the current word when cursor is at hell|o (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ dgN deletes the current word when cursor is at hel|lo (253ms)

      ✓ dgN deletes the current word when cursor is at h|ello (184ms)

      ✓ dgN deletes the current word when cursor is at |hello (199ms)

      ✓ dgN deletes the previous word when cursor is at | hello (187ms)

    can handle cgN

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ cgN deletes the previous match text (from first line) (247ms)

      ✓ cgN deletes the current word when cursor is at hell|o (169ms)

      ✓ cgN deletes the current word when cursor is at hel|lo (263ms)

      ✓ cgN deletes the current word when cursor is at h|ello (204ms)

      ✓ cgN deletes the current word when cursor is at |hello (111ms)

      ✓ cgN deletes the previous word when cursor is at | hello (239ms)

  Mode Replace

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can activate with <Insert> from Insert mode (183ms)

    ✓ Can activate with R from Normal mode (142ms)

    ✓ Can handle R (218ms)

    ✓ Can handle R past current line (144ms)

    ✓ Can handle R and exit Replace Mode (208ms)

    ✓ Can handle R across lines (112ms)

    ✓ Can handle R across lines and exit Replace Mode (217ms)

    ✓ Can handle R with {count} (175ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle backspace (235ms)

    ✓ Can handle backspace (82ms)

    ✓ Can handle backspace across lines (249ms)

    ✓ Can handle arrows (112ms)

    ✓ Can handle . (120ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle . across lines (436ms)

  Mode Visual

    ✓ can be activated

    ✓ Can handle w (99ms)

    ✓ Can handle wd (61ms)

    ✓ Can handle x (98ms)

    ✓ Can handle x across a selection (85ms)

    ✓ Can do vwd in middle of sentence (130ms)

    ✓ Can do vwd in middle of sentence (90ms)

    ✓ Can do vwd multiple times (300ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (118ms)

    ✓ Can handle H key (209ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle backspace key (129ms)

    ✓ handles case where we delete over a newline (170ms)

    ✓ handles change operator (116ms)

    ✓ Can do vat on multiple matching tags (205ms)

    ✓ Can maintain selection on failure with vat on multiple matching tags (189ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can maintain selection on failure with repeat-prefixed vat on multiple matching tags (235ms)

    ✓ Repeat-prefixed vat does not bleed below (195ms)

    ✓ Failed vat does not expand or move selection, remains in visual mode (48ms)

    ✓ Can do vi) on a matching parenthesis (113ms)

    ✓ Can do vi) on multiple matching parens (237ms)

    ✓ Can do va) on a matching parenthesis (151ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do va) on multiple matching parens (242ms)

    ✓ Failed va) does not expand or move selection, remains in visual mode (116ms)

    ✓ Repeat-prefixed va) does not bleed below (240ms)

    ✓ Can do va} on a matching bracket as first character (44ms)

    ✓ Can do va} on multiple matching brackets (64ms)

    ✓ Can do vi( on a matching bracket near first character (65ms)

    ✓ Can do vi{ on outer pair of nested braces (49ms)

    ✓ Can do vi{ on braces indented by 1 and preserve indent (52ms)

    ✓ Can do va] on multiple matching brackets (61ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do repeat-prefixed vaf on multiple matching pairs of different types (248ms)

    ✓ Repeat-prefixed vaf does not bleed below (91ms)

    ✓ vaf only expands to enclosing pairs (107ms)

    ✓ Can use . to repeat indent in visual (108ms)

    ✓ Can do v_x to delete to first char (231ms)

    ✓ Can do vg_x to delete to last char with no EOL (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can do v3g_x to delete to last char with no EOL with count (252ms)

    ✓ Can do v$x to delete to last char including EOL (109ms)

    ✓ Can do gv to reselect previous selection (233ms)

    Vim's EOL handling is weird

      ✓ delete through eol (87ms)

      ✓ join 2 lines by deleting through eol (169ms)

      ✓ d$ doesn't delete whole line (53ms)

      ✓ vd$ does delete whole line (61ms)

      ✓ Paste over selection copies the selection (229ms)

      ✓ Paste over selection copies the selection linewise (183ms)

    Arrow keys work perfectly in Visual Mode

      ✓ Can handle <up> key (175ms)

      ✓ Can handle <down> key (183ms)

      ✓ Can handle <left> key (61ms)

      ✓ Can handle <right> key

    Screen line motions in Visual Mode

      ✓ Can handle 'gk' (87ms)

      ✓ Can handle 'gj' (51ms)

      - Preserves cursor position when handling 'gk'

      - Preserves cursor position when handling 'gj'

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (234ms)

      ✓ Can handle 'vawd' on word with trailing spaces (140ms)

      ✓ Can handle 'vawd' on word with leading spaces (178ms)

      ✓ Can handle 'vawd' on word with numeric prefix (235ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (148ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (98ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (233ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (185ms)

      ✓ Can handle 'vaWd' on word with leading spaces (83ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (280ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (164ms)

    handles aW in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (230ms)

      ✓ Can handle 'vaWd' on word with trailing spaces (133ms)

      ✓ Can handle 'vaWd' on word with leading spaces (222ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (134ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (123ms)

    handles aw in visual mode

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vawd' on word with cursor inside spaces (227ms)

      ✓ Can handle 'vawd' on word with trailing spaces (173ms)

      ✓ Can handle 'vawd' on word with leading spaces (209ms)

      ✓ Can handle 'vawd' on word with numeric prefix (70ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines (95ms)

      ✓ Can handle 'vawd' on word with numeric prefix and across lines, containing words end with `.` (204ms)

    handles aW in visual mode

      ✓ Can handle 'vaWd' on big word with cursor inside spaces (172ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Can handle 'vaWd' on word with trailing spaces (282ms)

      ✓ Can handle 'vaWd' on word with leading spaces (327ms)

      ✓ Can handle 'vaWd' on word with numeric prefix (119ms)

      ✓ Can handle 'vaWd' on word with numeric prefix and across lines (197ms)

      ✓ Can handle 'Y' in visual mode (170ms)

    handles as in visual mode

      ✓ Select sentence with trailing spaces in visual mode (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select sentence with leading spaces in visual mode (220ms)

      ✓ Select multiple sentences in visual mode (145ms)

    handles is in visual mode

      ✓ Select inner sentence with trailing spaces in visual mode (197ms)

      ✓ Select inner sentence with leading spaces in visual mode (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Select spaces between sentences in visual mode (243ms)

    handles tag blocks in visual mode

      ✓ Can do vit on a matching tag (133ms)

      ✓ Count-prefixed vit alternates expanding selection between inner and outer tag brackets (202ms)

      ✓ Can do vat on a matching tag (72ms)

    handles replace in visual mode

      ✓ Can do a single line replace (227ms)

      ✓ Can do a multi line replace (184ms)

    D command will remove all selected lines

      ✓ D deletes all selected lines (95ms)

      ✓ D deletes the current line (219ms)

    handles indent blocks in visual mode

      ✓ Can do vai (165ms)

      ✓ Can do vii (66ms)

      ✓ Doesn't naively select the next line (209ms)

      ✓ Searches backwards if cursor line is empty (132ms)

      ✓ Can do vaI (121ms)

    visualstar

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ Works with * (219ms)

      ✓ Works with # (91ms)

    search works in visual mode

      ✓ Works with / (79ms)

      ✓ Works with ? (63ms)

      ✓ Selects correct range (80ms)

    X will delete linewise

      ✓ normal selection (199ms)

      ✓ normal selection (151ms)

    C will delete linewise

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ normal selection (234ms)

      ✓ normal selection (149ms)

    R will delete linewise

      ✓ normal selection (178ms)

      ✓ normal selection (201ms)

    Linewise Registers will be inserted properly

      ✓ downward selection (142ms)

      ✓ upward selection (79ms)

    Indent Tests using > on visual selections

      ✓ multiline indent top down selection (107ms)

      ✓ multiline indent bottom up selection (126ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ repeat multiline indent top down selection (233ms)

      ✓ repeat multiline indent bottom up selection (176ms)

    Outdent Tests using < on visual selections

      ✓ multiline outdent top down selection (53ms)

      ✓ multiline outdent bottom up selection (51ms)

      ✓ repeat multiline outdent top down selection (232ms)

      ✓ repeat multiline outdent bottom up selection (124ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (128ms)

    vi{ will go to end of second to last line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ select (239ms)

    Transition between visual mode

      ✓ vv will back to normal mode

      ✓ vV will transit to visual line mode

      ✓ v<C-v> will transit to visual block mode

      ✓ Vv will transit to visual (char) mode

      ✓ VV will back to normal mode

      ✓ V<C-v> will transit to visual block mode

      ✓ <C-v>v will transit to visual (char) mode

      ✓ <C-v>V will back to visual line mode (51ms)

      ✓ <C-v><C-v> will back to normal mode

    replace text in characterwise visual-mode with characterwise register content

      ✓ gv selects the last pasted text (which is shorter than original) (346ms)

      ✓ gv selects the last pasted text (which is longer than original) (272ms)

      ✓ gv selects the last pasted text (multiline) (145ms)

    can handle gn

      ✓ gn selects the next match text (230ms)

      ✓ gn selects the current word at |hello (138ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ gn selects the current word at h|ello (234ms)

      ✓ gn selects the current word at hel|lo (191ms)

      ✓ gn selects the next word at hell|o (175ms)

      ✓ gn selects the next word at hello| (181ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (53ms)

      ✓ multiline insert from top down selection (74ms)

      ✓ skips blank lines (69ms)

    can append text with A

      ✓ multiline append from bottom up selection (74ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline append from top down selection (234ms)

      ✓ skips blank lines (114ms)

    Can handle u/gu, U/gU

      ✓ U/gU on single character (596ms)

      ✓ U/gU across a selection (207ms)

      ✓ U/gU across a selection (reverse) (202ms)

      ✓ u/gu on single character (205ms)

      ✓ u/gu across a selection (226ms)

      ✓ u/gu across a selection (reverse) (165ms)

  Mode Visual Block

    ✓ can be activated

    ✓ Can handle A forward select (133ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle A backwards select (248ms)

    ✓ Can handle I forward select (140ms)

    ✓ Can handle I backwards select (81ms)

    ✓ Can handle I with empty lines on first character (inserts on empty line) (245ms)

    ✓ Can handle I with empty lines on non-first character (does not insert on empty line) (183ms)

    ✓ Can handle c forward select (220ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle c backwards select (613ms)

    ✓ Can handle C (155ms)

    ✓ Can do a multi line replace (223ms)

    ✓ Can handle 'D' (150ms)

    ✓ Can handle 'gj' (68ms)

    ✓ Properly add to end of lines j then $ (94ms)

    ✓ Properly add to end of lines $ then j (49ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ o works in visual block mode (230ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (130ms)

  Mode Visual Line

    ✓ can be activated

    ✓ Can handle w (110ms)

    ✓ Can handle wd (67ms)

    ✓ Can handle x (199ms)

    ✓ Can handle x across a selection (103ms)

    ✓ Can do vwd in middle of sentence (115ms)

    ✓ Can do vwd in middle of sentence (89ms)

    ✓ Can do vwd multiple times (137ms)

    ✓ handles case where we go from selecting on right side to selecting on left side (104ms)

    ✓ handles case where we delete over a newline (117ms)

    ✓ handles change operator (114ms)

    ✓ Vp updates register content (218ms)

    ✓ Vp does not append unnecessary newlines (first line) (167ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Vp does not append unnecessary newlines (middle line) (226ms)

    ✓ Vp does not append unnecessary newlines (last line) (183ms)

    Vim's EOL handling is weird

      ✓ delete through eol (57ms)

      ✓ join 2 lines by deleting through eol (54ms)

      ✓ d$ doesn't delete whole line (56ms)

      ✓ vd$ does delete whole line (50ms)

    Arrow keys work perfectly in Visual Line Mode

      ✓ Can handle <up> key (64ms)

      ✓ Can handle <down> key (216ms)

    Screen line motions in Visual Line Mode

      ✓ Can handle 'gk' (210ms)

      ✓ Can handle 'gj' (50ms)

    Can handle d/c correctly in Visual Line Mode

      ✓ Can handle d key (63ms)

      ✓ Can handle d key (56ms)

      ✓ Can handle d key (43ms)

      ✓ Can handle d key (39ms)

      ✓ can handle 'c'

    handles replace in visual line mode

      ✓ Can do a single line replace (104ms)

      ✓ Can do a multi visual line replace (39ms)

      ✓ Can do a multi visual line replace from the bottom up (112ms)

    search works in visual line mode

      ✓ Works with / (77ms)

      ✓ Works with ? (47ms)

    Non-darwin <C-c> tests

      ✓ <C-c> copies and sets mode to normal (94ms)

    replace text in linewise visual-mode with linewise register content

      ✓ yyVp does not change the content but changes cursor position (42ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ linewise visual put works also in the end of document (228ms)

      ✓ gv selects the last pasted text (which is shorter than original) (340ms)

      ✓ gv selects the last pasted text (which is longer than original) (237ms)

      ✓ gv selects the last pasted text (multiline) (131ms)

    can prepend text with I

      ✓ multiline insert from bottom up selection (56ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ multiline insert from top down selection (311ms)

      ✓ skips blank lines (171ms)

    can append text with A

      ✓ multiline append from bottom up selection (76ms)

      ✓ multiline append from top down selection (49ms)

      ✓ skips blank lines (79ms)

  Mode Normal

    ✓ Can handle 'x'

    ✓ Can handle 'Nx' (105ms)

    ✓ Can handle 'Nx' and paste (135ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'x' at end of line (251ms)

    ✓ Can handle 'Ns' (146ms)

    ✓ Can handle 'Ns' at end of line (201ms)

    ✓ Can handle '<Del>' (156ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<Del>' with counts, which removes the last character of the count (219ms)

    ✓ Can handle '<Del>' at end of line (202ms)

    ✓ Can handle 'cc' (159ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'Ncc' (311ms)

    ✓ Can handle 'yy' (231ms)

    ✓ Can handle 'D' (126ms)

    ✓ Can handle 'D' on empty lines (211ms)

    ✓ Can handle 'DD' (140ms)

    ✓ Can handle 'C' (157ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'NC' (215ms)

    ✓ Can handle 'NC' and put (169ms)

    ✓ Can handle 'r' (208ms)

    ✓ Can handle '<Count>r' (152ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle '<Count>r' (215ms)

    ✓ Can handle 'r' after 'dd' (193ms)

    ✓ Can handle 'r
' (182ms)

    ✓ Can handle '<Count>r
' (216ms)

    ✓ Can handle 'J' once (161ms)

    ✓ Can handle 'J' twice (149ms)

    ✓ Can handle 'J' with empty last line (141ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'J's with multiple empty last lines (267ms)

    ✓ Can handle 'J' with leading white space on next line (340ms)

    ✓ Can handle 'J' with only white space on next line (64ms)

    ✓ Can handle 'J' with TWO indented lines (48ms)

    ✓ Can handle 'J' with ')' first character on next line (77ms)

    ✓ Can handle 'J' with a following delete

    ✓ Can handle 'J' in Visual Line mode (91ms)

    ✓ Can handle 'gJ' once

    ✓ Can handle 'gJ' once and ALL WHITESPACE IS ELIMINATED (106ms)

    ✓ Can handle '~' (115ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'g~{motion}' (235ms)

    ✓ Can handle '<BS>' in insert mode (134ms)

    ✓ Can handle undo with P (172ms)

    ✓ Can handle 'ge' in multiple lines case1 (70ms)

    ✓ Can handle 'ge' in multiple lines case2 (68ms)

  Dot Operator

    ✓ Can repeat '~' with <num> (52ms)

    ✓ Can repeat '~' with dot (76ms)

    ✓ Can repeat 'x' (50ms)

    ✓ Can repeat 'J' (69ms)

    ✓ Can handle dot with A (73ms)

    ✓ Can handle dot with I (81ms)

    ✓ Can repeat actions that require selections (80ms)

  Repeat content change

    ✓ Can repeat '<C-t>' (73ms)

    ✓ Can repeat insert change and '<C-t>' (72ms)

    ✓ Can repeat change by `<C-a>` (355ms)

    ✓ Only one arrow key can be repeated in Insert Mode (117ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Cached content change will be cleared by arrow keys (278ms)

  Matching Bracket (%)

    ✓ before opening parenthesis (78ms)

    ✓ inside parenthesis (74ms)

    ✓ nested parenthesis beginning (49ms)

    ✓ nested parenthesis end (81ms)

    ✓ nested bracket and parenthesis beginning (231ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ nested bracket, parenthesis, braces beginning (167ms)

    ✓ nested bracket, parenthesis, braces end (47ms)

    ✓ parentheses after > (210ms)

    ✓ parentheses after " (177ms)

  Motions in Normal Mode

    ✓ Can handle [( (116ms)

    ✓ Can handle nested [( (190ms)

    ✓ Can handle <number>[( (193ms)

    ✓ Can handle [( and character under cursor exclusive (40ms)

    ✓ Can handle ]) (81ms)

    ✓ Can handle nested ]) (46ms)

    ✓ Can handle <number>]) (82ms)

    ✓ Can handle ]) and character under cursor exclusive

    ✓ Can handle [{ (211ms)

    ✓ Can handle nested [{ (152ms)

    ✓ Can handle <number>[{ (201ms)

    ✓ Can handle [{ and character under cursor exclusive (180ms)

    ✓ Can handle ]} (211ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle nested ]} (41ms)

    ✓ Can handle <number>]} (49ms)

    ✓ Can handle ]} and character under cursor exclusive (71ms)

    ✓ Can handle 'ge' (43ms)

    ✓ Can handle 'gg' (211ms)

    ✓ Can handle 'gg' to first non blank char on random line (43ms)

    ✓ Can handle 'gg' to first non blank char on first line (51ms)

    ✓ 'gg' obeys startofline (67ms)

    ✓ Retain same column when moving up/down (54ms)

    ✓ Can handle <enter> (70ms)

    ✓ $ always keeps cursor on EOL (68ms)

    ✓ Can handle $ with a count (66ms)

    ✓ Can handle $ with a count at end of file (48ms)

    ✓ Can handle <End> with a count (67ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <D-right> with a count (702ms)

    ✓ Can handle 'f' (187ms)

    ✓ Can handle 'f' twice (202ms)

    ✓ Can handle 'f' with <tab> (177ms)

    ✓ Can handle 'f' and find back search (87ms)

    ✓ Can handle 'F' (50ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'F' twice (225ms)

    ✓ Can handle 'F' and find back search (172ms)

    ✓ Can handle 'f' and multiple back searches (68ms)

    ✓ Can handle 't' (48ms)

    ✓ Can handle 't' twice (95ms)

    ✓ Can handle 't' and find back search (214ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 'T' (161ms)

    ✓ Can handle 'T' twice (48ms)

    ✓ Can handle 'T' and find back search (48ms)

    ✓ Can run a forward search (88ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can run a forward and find next search (328ms)

    ✓ Can run a forward and find previous search from end of word (197ms)

    ✓ Can run a reverse search (55ms)

    ✓ Can run a reverse and find next search (62ms)

    ✓ cancelled search reverts to previous search state (64ms)

    ✓ Backspace on empty search cancels (44ms)

    ✓ Search offsets: b does nothing (89ms)

    ✓ Search offsets: b2 goes 2 to the right (49ms)

    ✓ Search offsets: b+3 goes 3 to the right (67ms)

    ✓ Search offsets: e goes to the end (59ms)

    ✓ Search offsets: character offset goes across line boundaries (67ms)

    ✓ Search offsets: 2 goes 2 down (61ms)

    ✓ Search offsets: -2 goes 2 up (41ms)

    ✓ maintains column position correctly (101ms)

    ✓ maintains column position correctly with $

    ✓ Can handle G  (83ms)

    ✓ Can handle G with number prefix

    ✓ Can handle G with number prefix (94ms)

    ✓ Can handle gg

    ✓ Can handle gg with number prefix (86ms)

    ✓ Can handle 0 (66ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle 0 as part of a repeat (653ms)

    ✓ Can handle g* (77ms)

    ✓ Can handle g*n

    ✓ Can handle * (77ms)

    ✓ Can handle **

    ✓ Can handle # on whitespace (40ms)

    ✓ Can handle # on EOL (47ms)

    ✓ Can handle g# (81ms)

    ✓ Can handle g#n (63ms)

    ✓ Can handle # (64ms)

    ✓ Can handle # already on the word

    ✓ Can handle ## (65ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ * adds to search history (227ms)

    ✓ # adds to search history (101ms)

    ✓ Can handle | (124ms)

    ✓ Can handle <number> | (57ms)

    ✓ Can handle + (44ms)

    ✓ Can handle + indent (71ms)

    ✓ Can handle + with count prefix (54ms)

    ✓ Can handle -

    ✓ Can handle - indent

    ✓ Can handle - with count prefix

    ✓ Can handle _

    ✓ Can handle _ with count prefix

    ✓ Can handle g_

    ✓ Can handle g_ with count prefix

    ✓ Can handle <up> key

    ✓ Can handle <down> key

    ✓ Can handle <left> key (42ms)

    ✓ Can handle <right> key

    ✓ Can handle 'gk' (42ms)

    ✓ Can handle 'gj'

    - Preserves cursor position when handling 'gk'

    - Preserves cursor position when handling 'gj'

  basic motion

    ✓ char right: should move one column right

    ✓ char right

    ✓ char left: should move cursor one column left

    ✓ char left: left-most column should stay at the same location

    ✓ line down: should move cursor one line down

    ✓ line down: bottom-most line should stay at the same location

    ✓ line begin

    ✓ line end

    ✓ document begin

    ✓ document end

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    line up

      ✓ should move cursor one line up

      ✓ top-most line should stay at the same location

  word motion

    ✓ line begin cursor on first non-blank character

    ✓ last line begin cursor on first non-blank character

    word right

      ✓ move to word right

      ✓ last word should move to next line

      ✓ last word should move to next line stops on empty line

      ✓ last word should move to next line skips whitespace only line

      ✓ last word on last line should go to end of document (special case!)

    word left

      ✓ move cursor word left across spaces

      ✓ move cursor word left within word

      ✓ first word should move to previous line, beginning of last word

      ✓ first word should move to previous line, stops on empty line

      ✓ first word should move to previous line, skips whitespace only line

    WORD right

      ✓ move to WORD right

      ✓ last WORD should move to next line

      ✓ last WORD should move to next line stops on empty line

      ✓ last WORD should move to next line skips whitespace only line

    WORD left

      ✓ move cursor WORD left across spaces

      ✓ move cursor WORD left within WORD

      ✓ first WORD should move to previous line, beginning of last WORD

      ✓ first WORD should move to previous line, stops on empty line

      ✓ first WORD should move to previous line, skips whitespace only line

    end of word right

      ✓ move to end of current word right

      ✓ move to end of next word right

      ✓ end of last word should move to next line

      ✓ end of last word should move to next line skips empty line

      ✓ end of last word should move to next line skips whitespace only line

    end of WORD right

      ✓ move to end of current WORD right

      ✓ move to end of next WORD right

      ✓ end of last WORD should move to next line

      ✓ end of last WORD should move to next line skips empty line

      ✓ end of last WORD should move to next line skips whitespace only line

  unicode word motion

    word right

      ✓ move cursor word right stops at different kind of character (ideograph -> hiragana)

      ✓ move cursor word right stops at different kind of character (katakana -> ascii)

      ✓ move cursor word right stops at different kind of chararacter (ascii -> punctuation)

      ✓ move cursor word right on non-ascii text
      ✓ move cursor word right recognizes a latin string which has diacritics as a single word
      ✓ move cursor word right recognizes a latin-1 symbol as punctuation
      ✓ move cursor word right recognizes a sequence of latin-1 symbols and other symbols as a word
    word left
      ✓ move cursor word left across the different char kind
      ✓ move cursor word left within the same char kind
      ✓ move cursor word left across spaces on non-ascii text
      ✓ move cursor word left within word on non-ascii text
      ✓ move cursor word left recognizes a latin string which has diacritics as a single word

  sentence motion

    sentence forward

      ✓ next concrete sentence

      ✓ next sentence that ends with paragraph ending

      ✓ next sentence when cursor is at the end of previous paragraph

      ✓ next sentence when paragraph contains a line of whilte spaces

    sentence backward
      ✓ current sentence begin
      ✓ sentence forward when cursor is at the beginning of the second sentence
      ✓ current sentence begin with no concrete sentense inside
      ✓ current sentence begin when it's not the same as current paragraph begin

      ✓ current sentence begin when previous line ends with a concrete sentence

  paragraph motion

    paragraph down

      ✓ move down normally

      ✓ move down longer paragraph
      ✓ move down starting inside empty line

      ✓ paragraph at end of document

    paragraph up

      ✓ move up short paragraph

      ✓ move up longer paragraph

      ✓ move up starting inside empty line

  motion line wrapping

    whichwrap enabled

      normal mode

        ✓ h wraps to previous line

        ✓ l wraps to next line

        ✓ <left> wraps to previous line

        ✓ <right> wraps to next line (51ms)

      insert mode

        ✓ <left> wraps to previous line

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <right> once goes to end of line (288ms)

        ✓ <right> twice wraps to next line (134ms)

    whichwrap disabled

      normal mode

        ✓ h does not wrap to previous line (209ms)

        ✓ l does not wrap to next line (128ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

        ✓ <left> does not wrap to previous line (215ms)

        ✓ <right> does not wrap to next line (128ms)

      insert mode

        ✓ <left> does not wrap to previous line (215ms)

        ✓ <right> does not wrap to next line (187ms)

    wrapscan enabled

      ✓ search wraps around the end of the file (188ms)

      ✓ search wraps around the start of the file (78ms)

    wrapscan disabled

      ✓ search stops at the end of the file (47ms)

      ✓ search stops at the start of the file (85ms)

  Multicursor

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ can add multiple cursors below (458ms)

    ✓ can add multiple cursors above (223ms)

  numeric string
    ✓ fails on non-string
    ✓ handles hex round trip

    ✓ handles decimal round trip
    ✓ handles octal trip
  comment operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ gcc comments out current line (337ms)

    ✓ gcj comments in current and next line (194ms)

    ✓ block comment with motion (173ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ block comment in Visual Mode (226ms)

    ✓ comment in visual line mode (62ms)

    ✓ comment in visual block mode (170ms)

  format operator

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ == formats current line (502ms)

    ✓ =$ formats entire line (354ms)

    ✓ =j formats two lines (128ms)

    ✓ 3=k formats three lines (118ms)

    ✓ =gg formats to top of file (134ms)

    ✓ =G formats to bottom of file (212ms)

    ✓ =ip formats paragraph (86ms)

    ✓ format in visual mode (112ms)

  put operator

    ✓ basic put test (88ms)

    ✓ test yy end of line (103ms)

    ✓ test yy first line (93ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test yy middle line (216ms)

    ✓ test yy with correct positon movement (168ms)

    ✓ test visual block single line yank p (248ms)

    ✓ test visual block single line yank P (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ test visual block single line delete p (315ms)

    ✓ test visual block single line delete P (189ms)

  rot13 operator

    ✓ rot13() unit test

    1) g?j works

    ✓ g? in visual mode works (48ms)

    ✓ g? in visual line mode works (73ms)

    ✓ g? in visual block mode works

  shift operator

    ✓ basic shift left test (96ms)

    ✓ shift left goto end test (67ms)

    ✓ shift left goto line test (48ms)

    ✓ shift right goto end test (67ms)

    ✓ shift right goto line test (57ms)

  camelCaseMotion plugin if not enabled

    ✓ basic motion doesn't work (71ms)

  camelCaseMotion plugin
    handles <leader>w for camelCaseText

      ✓ step over whitespace (42ms)

      ✓ step to Camel word (85ms)

      ✓ step to CAP word (49ms)

      ✓ step after CAP word (116ms)

      ✓ step from middle of word to Camel word (212ms)

      ✓ step to number word (169ms)

      ✓ step to operator word (124ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from inside operator word (218ms)

      ✓ step to operator and then over (176ms)

    handles <leader>w for underscore_var

      ✓ step to _word (140ms)

      ✓ step over whitespace to word (213ms)

      ✓ step from inside word to _word (184ms)

      ✓ step form _word to number (206ms)

      ✓ step from nubmer word to _word (76ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ step from in whitespace to word (217ms)

      ✓ step in ALL_CAPS_WORD (180ms)

    handles d<leader>w

      ✓ delete from start of camelWord (128ms)

      ✓ delete from middle of camelWord (147ms)

      ✓ delete from start of CamelWord (74ms)

      ✓ delete two words from camelWord (214ms)

      ✓ delete from start of underscore_word (165ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ delete from middle of underscore_word (716ms)

      ✓ delete two words from camel_word

    handles di<leader>w

      ✓ delete from start of camelWord (63ms)

      ✓ delete from middle of camelWord

      ✓ delete from start of CamelWord (85ms)

      ✓ delete two words from camelWord (204ms)

      ✓ delete from start of underscore_word (62ms)

      ✓ delete from middle of underscore_word

      ✓ delete two words from camel_word (77ms)

    handles <leader>b

      ✓ back from middle of word (71ms)

      ✓ back over whitespace to camelWord (195ms)

      ✓ back twice over operator (178ms)

    handles <leader>e

      ✓ from start to middle of underscore_word (154ms)

      ✓ from middle to end of underscore_word (119ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ twice to end of word over operator (220ms)

  easymotion plugin

    ✓ Can handle s move (123ms)

    ✓ Can handle 2s move (192ms)

    ✓ Can handle f move (211ms)

    ✓ Can handle 2f move (182ms)

    ✓ Can handle F move (137ms)

    ✓ Can handle 2F move (203ms)

    ✓ Can handle t move (171ms)

    ✓ Can handle bd-t move (223ms)

    ✓ Can handle 2t move (165ms)

    ✓ Can handle bd-t2 move (201ms)

    ✓ Can handle T move (182ms)

    ✓ Can handle 2T move (145ms)

    ✓ Can handle w move (204ms)

    ✓ Can handle bd-w move (189ms)

    ✓ Can handle b move (201ms)

    ✓ Can handle e move (43ms)

    ✓ Can handle bd-e move (215ms)

    ✓ Can handle ge move (188ms)

    ✓ Can handle n-char move (103ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle j move (243ms)

    ✓ Can handle k move (110ms)

    ✓ Can handle bd-jk move (1) (249ms)

    ✓ Can handle bd-jk move (2) (162ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle lineforward move (1) (218ms)

    ✓ Can handle lineforward move (2)

    ✓ Can handle linebackward move (1) (146ms)

    ✓ Can handle linebackward move (2) (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle searching for backslash (\) (625ms)

    ✓ Can handle searching for carat (^) (183ms)

    ✓ Can handle searching for dot (.) (198ms)

  Input method plugin

    ✓ use default im in insert mode

    ✓ use other im in insert mode

  replaceWithRegister plugin

    ✓ Replaces within inner word (58ms)

    ✓ Replaces within inner Word (81ms)

    ✓ Replaces within '' (231ms)

    ✓ Replaces within '' including spaces (114ms)

    ✓ Replaces within () (207ms)

    ✓ Replaces within () including spaces (112ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces within a paragraph (236ms)

    ✓ Replaces using a specified register (175ms)

    ✓ Replaces within {} over multiple lines (219ms)

    ✓ Replaces a multiline register within {} over multiple lines (163ms)

    ✓ Replaces a multiline register within {} over multiple lines (205ms)

    ✓ Yanking inside {} then replacing inside {} in a noop, besides the cursor movement (178ms)

    ✓ grr replaces the entire line with the register (64ms)

    ✓ grr can replace multiple lines (64ms)

    ✓ Replaces in visual mode (80ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Replaces in visual mode using a specified register (260ms)

    ✓ Replaces in visual line mode (181ms)

    ✓ grj is linewise (85ms)

  sneak plugin

    ✓ Can handle s motion (210ms)

    ✓ Can handle S motion (163ms)

    ✓ Can handle <operator>z motion (234ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle <operator>Z motion (740ms)

    ✓ Can handle s; motion (93ms)

    ✓ Can handle s, motion (179ms)

    ✓ Can handle S; motion (187ms)

    ✓ Can handle S, motion (227ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter s motion (42ms)

    ✓ Can handle single letter S motion (49ms)

    ✓ Can handle single letter <operator>z motion (61ms)

    ✓ Can handle single letter <operator>Z motion (57ms)

    ✓ Can handle single letter s; motion (218ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can handle single letter s, motion (182ms)

    ✓ Can handle single letter S; motion (163ms)

    ✓ Can handle single letter S, motion (51ms)

    ✓ Can handle multiline single char <number>s motion (70ms)

  surround plugin

    ✓ 'ysiw)' surrounds word without space (108ms)

    ✓ 'ysiw(' surrounds word with space (191ms)

    ✓ 'ysw)' surrounds word without space (129ms)

    ✓ 'ysw(' surrounds word with space (197ms)

    ✓ 'ysaw)' surrounds word without space (104ms)

    ✓ 'ysaw(' surrounds word with space (163ms)

    ✓ 'ysiw(' surrounds word with space and ignores punctuation (75ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'ysiw<' surrounds word with tags (174ms)

    ✓ 'ysiw<' surrounds word with tags and attributes (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ 'cst<' surrounds word with tags that have a dot in them (477ms)

    ✓ 'yss)' surrounds entire line respecting whitespace (147ms)

    ✓ change surround (144ms)

    ✓ change surround with two pairs of quotes (179ms)

    ✓ change surround with two pairs of parens (114ms)

    ✓ change surround with alias (179ms)

    ✓ change surround to tags (76ms)

    ✓ delete surround (186ms)

    ✓ delete surround with quotes (63ms)

    ✓ delete surround with nested of quotes (210ms)

    ✓ delete surround with inconsistent quotes (114ms)

    ✓ delete surround with mixed quotes (180ms)

    ✓ delete surround with empty quotes cursor at start (103ms)

    ✓ delete surround with empty quotes cursor at end (123ms)

    ✓ don't delete surround if cursor is after closing match (129ms)

    ✓ delete surround if cursor is before opening match (208ms)

    ✓ delete surround with two pairs of parens (145ms)

    ✓ delete surround with alias (132ms)

    ✓ delete surround with tags (179ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ change surround brackets at end of line (342ms)

    ✓ changing brackets with surround works again (117ms)

    ✓ change surround with tags that contain an attribute and preserve them (133ms)

    ✓ change surround with tags that contain an attribute and remove them (144ms)

  register

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Can copy to a register (233ms)

    ✓ Can use two registers together (77ms)

    ✓ Can use black hole register (140ms)

    ✓ System clipboard works with chinese characters

    ✓ Yank stores text in Register '0' (189ms)

    ✓ Multiline yank (`[count]yy`) stores text in Register '0' (128ms)

    ✓ Multiline yank (`[count]Y`) stores text in Register '0' (131ms)

    ✓ Register '1'-'9' stores delete content (146ms)

    ✓ "A appends linewise text to "a (130ms)

    ✓ "A appends character wise text to "a (172ms)

    ✓ Can put and get to register

    ✓ Small deletion using x is stored in small delete register (88ms)

    ✓ Small deletion using Del is stored in small delete register (103ms)

    ✓ Small deletion using X is stored in small delete register (103ms)

    ✓ Search register (/) is set by forward search (193ms)

    ✓ Search register (/) is set by backward search (196ms)

    ✓ Search register (/) is set by star search (163ms)

    ✓ Command register (:) is set by command line (73ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

    ✓ Read-only registers cannot be written to (521ms)

    clipboard

      ✓ Can access '*' (clipboard) register (44ms)

      ✓ Can access '+' (clipboard) register (73ms)

  Repeatable movements with f and t

    ✓ Can repeat f<character>

    ✓ Can repeat reversed F<character> (110ms)

    ✓ Can repeat t<character> (80ms)

    ✓ Can repeat N times reversed t<character> (44ms)

  sentence motion

    [count] sentences backward

      ✓ move one sentence backward (127ms)

      ✓ move one sentence backward (184ms)

Unable to read file (EntryNotFound (FileSystemError)): Error: Unable to read file (EntryNotFound (FileSystemError))
    at _.doReadAsFileStream (file:///home/travis/build/VSCodeVim/Vim/.vscode-test/vscode-1.41.1/VSCode-linux-x64/resources/app/out/vs/workbench/workbench.desktop.main.js:1591:434)
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (internal/process/task_queues.js:89:5)

      ✓ move [count] sentences backward (333ms)

      ✓ move one sentence backward single line - middle (147ms)

      ✓ move one sentence backward no space (158ms)

      ✓ move one sentence backward no space - middle (162ms)

      ✓ move one sentence backward - multiline (109ms)

      ✓ move one sentence backward - multiline - period (159ms)

      ✓ move one sentence backward - multiline - previous line (190ms)

      ✓ move one sentence backward - multiline - previous line - period (155ms)

  VimState

    ✓ de-dupes cursors

    ✓ cursorStart/cursorStop should be first cursor in cursors

  text editor

    ✓ insert 'Hello World'

    ✓ replace 'World' with 'Foo Bar'

    ✓ delete `Hello`

    ✓ delete the whole line
    ✓ try to read lines that don't exist

  util path

    separatePath

      ✓ can separate drive letter path on Windows

      ✓ can separate UNC path on Windows

      ✓ can separate relative path on Windows

      ✓ can separate absolute path on posix

      ✓ can separate relative path on posix

    resolveUri

      ✓ posix

      ✓ win32

  1304 passing (4m)

  4 pending

  1 failing

  1) rot13 operator
       g?j works:

      Content does not match; Expected=nop. Actual=aop.
      + expected - actual

      -aop
      +nop
      
      at Suite.<anonymous> (test/operator/rot13.test.ts:29:3)


Tests exited with code: 1
npm ERR! Test failed.  See above for more details.
TravisBuddy Request Identifier: 1a064930-27a8-11ea-8215-356b6c757fb9

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Support g? operator (rot13)
2 participants