RUN asdl/examples/typed_arith_parse_test.py > _test/py-unit/asdl/examples/typed_arith_parse_test.py.log OK RUN asdl/format_test.py > _test/py-unit/asdl/format_test.py.log OK RUN asdl/front_end_test.py > _test/py-unit/asdl/front_end_test.py.log OK RUN asdl/gen_python_test.py > _test/py-unit/asdl/gen_python_test.py.log OK RUN asdl/target_lang_test.py > _test/py-unit/asdl/target_lang_test.py.log OK RUN benchmarks/uftrace_allocs_test.py > _test/py-unit/benchmarks/uftrace_allocs_test.py.log OK RUN build/dynamic_deps_test.py > _test/py-unit/build/dynamic_deps_test.py.log OK RUN build/ninja_lib_test.py > _test/py-unit/build/ninja_lib_test.py.log OK RUN builtin/bracket_osh_test.py > _test/py-unit/builtin/bracket_osh_test.py.log OK RUN builtin/completion_osh_test.py > _test/py-unit/builtin/completion_osh_test.py.log OK RUN builtin/func_misc_test.py > _test/py-unit/builtin/func_misc_test.py.log OK RUN builtin/misc_osh_test.py > _test/py-unit/builtin/misc_osh_test.py.log OK RUN builtin/read_osh_test.py > _test/py-unit/builtin/read_osh_test.py.log OK RUN builtin/readline_osh_test.py > _test/py-unit/builtin/readline_osh_test.py.log OK RUN client/py_fanos_test.py > _test/py-unit/client/py_fanos_test.py.log OK RUN core/alloc_test.py > _test/py-unit/core/alloc_test.py.log OK RUN core/comp_ui_test.py > _test/py-unit/core/comp_ui_test.py.log OK RUN core/completion_test.py > _test/py-unit/core/completion_test.py.log === /home/uke/oil/_test/py-unit/core/completion_test.py.log === . -- PREFIX 'm' -- PREFIX 'opy/doc' -- PREFIX o -- PREFIX nonexistent/ -- PREFIX README. -- PREFIX core -- PREFIX asdl/R -- PREFIX opy/doc -- PREFIX opy/doc/ -- PREFIX /bi -- PREFIX /tmp/oil_comp_test/ -- PREFIX ./o -- PREFIX i ..Running completion function 'f' with 3 arguments comp.first '', commands_changed: ... --- Case 3: 'noflags foo:bar --color=auto\t' with flags [] [] ['../oil/'] py <core.completion.UserSpec object at 0x7ff82cb7cf50> rb (None, None) words: (w <Lit_Chars noflags>) (w <Lit_Chars foo> <Lit_Colon ":"> <Lit_Chars bar>) (w <Lit_Chars --color> <Lit_Equals "="> <Lit_Chars auto> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars noflags> <WS_Space " "> <Lit_Chars foo> <Lit_Colon ":"> <Lit_Chars bar> <WS_Space " "> <Lit_Chars --color> <Lit_Equals "="> <Lit_Chars auto> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'noflags foo:bar --color=auto' rl_slice from byte 0 to 28: 'noflags foo:bar --color=auto' Completing words partial_argv: [noflags,foo:bar,--color=auto] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:7 col:16 line:(SourceLine line_num:1 content:"noflags foo:bar --color=auto" src:(source.MainFile path:"<test_lib>") ) tval:--color ) (Token id:Lit_Equals length:1 col:23 line:...0x7ff82cab4b50 tval:"=") (Token id:Lit_Chars length:4 col:24 line:...0x7ff82cab4b50 tval:auto) (Token id:Lit_CompDummy length:0 col:28 line:...0x7ff82cab4b50 tval:"") ] ) ] display_pos 16 Completing 'noflags foo:bar --color=auto' ... (Ctrl-C to cancel) Running completion function 'my_complete' with 3 arguments E words: (w <Lit_Chars ls>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars ls> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'ls ' rl_slice from byte 0 to 3: 'ls ' Completing words partial_argv: [ls,] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:3 line:(SourceLine line_num:1 content:"ls " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 3 Completing 'ls ' ... (Ctrl-C to cancel) Found 2 matches for 'ls ' in 0 ms words: (w <Lit_Chars ll>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars ll> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: (w <Lit_Chars ls>) (w <Lit_Chars -l>) line: 'll ' rl_slice from byte 0 to 3: 'll ' Completing words partial_argv: [ll,] alias_words: [[(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ll " src:(source.MainFile path:"<test_lib>") ) tval:ll ) ] ) ) ) ) ) ] ) , (CompoundWord parts:[ (Token id:Lit_Chars length:2 col:3 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ll " src:(source.MainFile path:"<test_lib>") ) tval:ll ) ] ) ) ) ) ) ] ) ]] alias_first: ls words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:3 line:(SourceLine line_num:1 content:"ll " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 3 Completing 'll ' ... (Ctrl-C to cancel) Found 2 matches for 'll ' in 0 ms words: (w <Lit_Chars ll_classify>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars ll_classify> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: (w <Lit_Chars ls>) (w <Lit_Chars -l>) (w <Lit_Chars --classify>) line: 'll_classify ' rl_slice from byte 0 to 12: 'll_classify ' Completing words partial_argv: [ll_classify,] alias_words: [[(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ls -l --classify" src:(source.Alias argv0:ll argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ll --classify " src:(source.Alias argv0:ll_classify argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:11 col:0 line:(SourceLine line_num:1 content:"ll_classify " src:(source.MainFile path:"<test_lib>") ) tval:ll_classify ) ] ) ) ) ) ) ] ) ) ) ) ) ] ) , (CompoundWord parts:[ (Token id:Lit_Chars length:2 col:3 line:(SourceLine line_num:1 content:"ls -l --classify" src:(source.Alias argv0:ll argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ll --classify " src:(source.Alias argv0:ll_classify argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:11 col:0 line:(SourceLine line_num:1 content:"ll_classify " src:(source.MainFile path:"<test_lib>") ) tval:ll_classify ) ] ) ) ) ) ) ] ) ) ) ) ) ] ) , (CompoundWord parts:[ (Token id:Lit_Chars length:10 col:6 line:(SourceLine line_num:1 content:"ls -l --classify" src:(source.Alias argv0:ll argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ll --classify " src:(source.Alias argv0:ll_classify argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:11 col:0 line:(SourceLine line_num:1 content:"ll_classify " src:(source.MainFile path:"<test_lib>") ) tval:ll_classify ) ] ) ) ) ) ) ] ) ) ) ) ) ] ) ]] alias_first: ls words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:12 line:(SourceLine line_num:1 content:"ll_classify " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 12 Completing 'll_classify ' ... (Ctrl-C to cancel) Found 2 matches for 'll_classify ' in 0 ms words: (w <Lit_Chars ll_trailing>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars ll_trailing> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: (w <Lit_Chars ls>) (w <Lit_Chars -l>) line: 'll_trailing ' rl_slice from byte 0 to 12: 'll_trailing ' Completing words partial_argv: [ll_trailing,] alias_words: [[(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll_trailing argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:11 col:0 line:(SourceLine line_num:1 content:"ll_trailing " src:(source.MainFile path:"<test_lib>") ) tval:ll_trailing ) ] ) ) ) ) ) ] ) , (CompoundWord parts:[ (Token id:Lit_Chars length:2 col:3 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll_trailing argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:11 col:0 line:(SourceLine line_num:1 content:"ll_trailing " src:(source.MainFile path:"<test_lib>") ) tval:ll_trailing ) ] ) ) ) ) ) ] ) ]] alias_first: ls words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:12 line:(SourceLine line_num:1 content:"ll_trailing " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 12 Completing 'll_trailing ' ... (Ctrl-C to cancel) Found 2 matches for 'll_trailing ' in 0 ms words: (w <Lit_Chars ll_own_completion>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars ll_own_completion> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: (w <Lit_Chars ls>) (w <Lit_Chars -l>) line: 'll_own_completion ' rl_slice from byte 0 to 18: 'll_own_completion ' Completing words partial_argv: [ll_own_completion,] alias_words: [[(CompoundWord parts:[ (Token id:Lit_Chars length:2 col:0 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll_own_completion argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:17 col:0 line:(SourceLine line_num:1 content:"ll_own_completion " src:(source.MainFile path:"<test_lib>") ) tval:ll_own_completion ) ] ) ) ) ) ) ] ) , (CompoundWord parts:[ (Token id:Lit_Chars length:2 col:3 line:(SourceLine line_num:1 content:"ls -l " src:(source.Alias argv0:ll_own_completion argv0_loc:(loc.Word w:(CompoundWord parts:[ (Token id:Lit_Chars length:17 col:0 line:(SourceLine line_num:1 content:"ll_own_completion " src:(source.MainFile path:"<test_lib>") ) tval:ll_own_completion ) ] ) ) ) ) ) ] ) ]] alias_first: ls words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:18 line:(SourceLine line_num:1 content:"ll_own_completion " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 18 Completing 'll_own_completion ' ... (Ctrl-C to cancel) Found 2 matches for 'll_own_completion ' in 0 ms . words: (w <Lit_Chars gre> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars gre> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'gre' rl_slice from byte 0 to 3: 'gre' Completing words partial_argv: [gre] alias_words: [[]] ** DISPLAY_POS = 0 Completing 'gre' ... (Ctrl-C to cancel) Found 1 match for 'gre' in 0 ms words: (w <Lit_Chars gre> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DollarParen "$("> <Lit_Chars gre> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo $(gre' rl_slice from byte 0 to 10: 'echo $(gre' Completing words partial_argv: [gre] alias_words: [[]] ** DISPLAY_POS = 7 Completing 'echo $(gre' ... (Ctrl-C to cancel) Found 1 match for 'echo $(gre' in 0 ms words: (w <Lit_Chars gre> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_Backtick "`"> <Lit_Chars gre> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo `gre' rl_slice from byte 0 to 9: 'echo `gre' Completing words partial_argv: [gre] alias_words: [[]] ** DISPLAY_POS = 6 Completing 'echo `gre' ... (Ctrl-C to cancel) Found 1 match for 'echo `gre' in 0 ms words: (w <Lit_Chars grep>) (w <Lit_Chars f> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_Backtick "`"> <Lit_Chars grep> <WS_Space " "> <Lit_Chars f> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo `grep f' rl_slice from byte 0 to 12: 'echo `grep f' Completing words partial_argv: [grep,f] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:11 line:(SourceLine line_num:1 content:"echo `grep f" src:(source.MainFile path:"<test_lib>") ) tval:f ) (Token id:Lit_CompDummy length:0 col:12 line:...0x7ff82c9bf8e8 tval:"") ] ) ] display_pos 11 Completing 'echo `grep f' ... (Ctrl-C to cancel) Found 2 matches for 'echo `grep f' in 0 ms .<Api 'echo ~r' 0-7> words: (w <Lit_Chars echo>) (w <Lit_Tilde "~"> <Lit_Chars r> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Tilde "~"> <Lit_Chars r> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo ~r' rl_slice from byte 0 to 7: 'echo ~r' <Api 'echo ~' 0-6> words: (w <Lit_Chars echo>) (w <Lit_Tilde "~"> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Tilde "~"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo ~' rl_slice from byte 0 to 6: 'echo ~' words: (w <Lit_Chars echo>) (w <Lit_Chars a> <Lit_Tilde "~"> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Chars a> <Lit_Tilde "~"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo a~' rl_slice from byte 0 to 7: 'echo a~' Completing words partial_argv: [echo,a~] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:5 line:(SourceLine line_num:1 content:"echo a~" src:(source.MainFile path:"<test_lib>") ) tval:a ) (Token id:Lit_Tilde length:1 col:6 line:...0x7ff82c9bfba8 tval:"~") (Token id:Lit_CompDummy length:0 col:7 line:...0x7ff82c9bfba8 tval:"") ] ) ] display_pos 5 Completing 'echo a~' ... (Ctrl-C to cancel) Found 0 matches for 'echo a~' in 0 ms . words: (w <Lit_Chars cat>) redirects: (Redir op:<Redir_Less "<"> loc:(redir_loc.Fd fd:0) arg:(w <Lit_Chars b> <Lit_CompDummy "">) ) tokens: <Lit_Chars cat> <WS_Space " "> <Redir_Less "<"> <WS_Space " "> <Lit_Chars b> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'cat < b' rl_slice from byte 0 to 7: 'cat < b' Completing redirect arg words: (w <Lit_Chars echo>) redirects: (Redir op:<Redir_GreatAnd ">&"> loc:(redir_loc.Fd fd:1) arg:(w <Lit_CompDummy "">) ) tokens: <Lit_Chars echo> <WS_Space " "> <Redir_GreatAnd ">&"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo >&' rl_slice from byte 0 to 7: 'echo >&' Didn't find anything to complete ..<Api 'echo $' 0-6> words: (w <Lit_Chars echo>) (w <Lit_Dollar "$"> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Dollar "$"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo $' rl_slice from byte 0 to 6: 'echo $' <Api 'echo $P' 0-7> words: (w <Lit_Chars echo>) (w ($ P) <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <VSub_DollarName "$P"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo $P' rl_slice from byte 0 to 7: 'echo $P' <Api 'echo _${' 0-8> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Chars _> <Left_DollarBrace "${"> <Lit_CompDummy ""> alias_words: line: 'echo _${' rl_slice from byte 0 to 8: 'echo _${' <Api 'echo ${P' 0-8> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DollarBrace "${"> <VSub_Name P> <Lit_CompDummy ""> alias_words: line: 'echo ${P' rl_slice from byte 0 to 8: 'echo ${P' <Api 'echo ${undef:-$P' 0-16> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DollarBrace "${"> <VSub_Name undef> <VTest_ColonHyphen ":-"> <VSub_DollarName "$P"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo ${undef:-$P' rl_slice from byte 0 to 16: 'echo ${undef:-$P' <Api 'echo ${undef:-$' 0-15> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DollarBrace "${"> <VSub_Name undef> <VTest_ColonHyphen ":-"> <Lit_Dollar "$"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo ${undef:-$' rl_slice from byte 0 to 15: 'echo ${undef:-$' <Api 'echo "$' 0-7> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DoubleQuote "\""> <Lit_Dollar "$"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo "$' rl_slice from byte 0 to 7: 'echo "$' <Api 'echo "$P' 0-8> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DoubleQuote "\""> <VSub_DollarName "$P"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo "$P' rl_slice from byte 0 to 8: 'echo "$P' <Api 'echo "${#P' 0-10> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DoubleQuote "\""> <Left_DollarBrace "${"> <VSub_Pound "#"> <VSub_Name P> <Lit_CompDummy ""> alias_words: line: 'echo "${#P' rl_slice from byte 0 to 10: 'echo "${#P' <Api 'echo "$((PWD +P' 0-15> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DoubleQuote "\""> <Left_DollarDParen "$(("> <Lit_ArithVarLike PWD> <Ignored_Space " "> <Arith_Plus "+"> <Lit_ArithVarLike P> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo "$((PWD +P' rl_slice from byte 0 to 15: 'echo "$((PWD +P' <Api 'echo "$(( $P' 0-12> words: redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Left_DoubleQuote "\""> <Left_DollarDParen "$(("> <Ignored_Space " "> <VSub_DollarName "$P"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo "$(( $P' rl_slice from byte 0 to 12: 'echo "$(( $P' . words: (w <Lit_Chars grep>) (w <Lit_Chars f> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars grep> <WS_Space " "> <Lit_Chars f> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'grep f' rl_slice from byte 0 to 6: 'grep f' Completing words partial_argv: [grep,f] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:5 line:(SourceLine line_num:1 content:"grep f" src:(source.MainFile path:"<test_lib>") ) tval:f ) (Token id:Lit_CompDummy length:0 col:6 line:...0x7ff82c9bf940 tval:"") ] ) ] display_pos 5 Completing 'grep f' ... (Ctrl-C to cancel) Found 2 matches for 'grep f' in 0 ms words: (w <Lit_Chars grep>) (w <Lit_Chars g> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars grep> <WS_Space " "> <Lit_Chars g> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'grep g' rl_slice from byte 0 to 6: 'grep g' Completing words partial_argv: [grep,g] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:5 line:(SourceLine line_num:1 content:"grep g" src:(source.MainFile path:"<test_lib>") ) tval:g ) (Token id:Lit_CompDummy length:0 col:6 line:...0x7ff82c9bfcb0 tval:"") ] ) ] display_pos 5 Completing 'grep g' ... (Ctrl-C to cancel) Found 0 matches for 'grep g' in 0 ms words: (w <Lit_Chars g> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars g> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'g' rl_slice from byte 0 to 1: 'g' Completing words partial_argv: [g] alias_words: [[]] ** DISPLAY_POS = 0 Completing 'g' ... (Ctrl-C to cancel) Found 1 match for 'g' in 0 ms words: (w <Lit_CompDummy "">) redirects: tokens: <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: '' rl_slice from byte 0 to 0: '' Completing words partial_argv: [] alias_words: [[]] ** DISPLAY_POS = 0 Completing '' ... (Ctrl-C to cancel) Found 3 matches for '' in 0 ms words: (w <Lit_Chars grep>) (w <Lit_Chars f> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Chars hi> <WS_Space " "> <Op_DPipe "||"> <WS_Space " "> <Lit_Chars grep> <WS_Space " "> <Lit_Chars f> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo hi || grep f' rl_slice from byte 0 to 17: 'echo hi || grep f' Completing words partial_argv: [grep,f] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:16 line:(SourceLine line_num:1 content:"echo hi || grep f" src:(source.MainFile path:"<test_lib>") ) tval:f ) (Token id:Lit_CompDummy length:0 col:17 line:...0x7ff82ca9f208 tval:"") ] ) ] display_pos 16 Completing 'echo hi || grep f' ... (Ctrl-C to cancel) Found 2 matches for 'echo hi || grep f' in 0 ms words: (w <Lit_Chars grep>) (w <Lit_Chars f> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars echo> <WS_Space " "> <Lit_Chars hi> <Op_Semi ";"> <WS_Space " "> <Lit_Chars grep> <WS_Space " "> <Lit_Chars f> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'echo hi; grep f' rl_slice from byte 0 to 15: 'echo hi; grep f' Completing words partial_argv: [grep,f] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:14 line:(SourceLine line_num:1 content:"echo hi; grep f" src:(source.MainFile path:"<test_lib>") ) tval:f ) (Token id:Lit_CompDummy length:0 col:15 line:...0x7ff82ca9f158 tval:"") ] ) ] display_pos 14 Completing 'echo hi; grep f' ... (Ctrl-C to cancel) Found 2 matches for 'echo hi; grep f' in 0 ms words: (w <Lit_Chars grep>) (w <Lit_Chars f> <Lit_CompDummy "">) redirects: tokens: <Lit_LBrace "{"> <WS_Space " "> <Lit_Chars echo> <WS_Space " "> <Lit_Chars hi> <Op_Semi ";"> <WS_Space " "> <Lit_Chars grep> <WS_Space " "> <Lit_Chars f> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: '{ echo hi; grep f' rl_slice from byte 0 to 17: '{ echo hi; grep f' Completing words partial_argv: [grep,f] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:16 line:(SourceLine line_num:1 content:"{ echo hi; grep f" src:(source.MainFile path:"<test_lib>") ) tval:f ) (Token id:Lit_CompDummy length:0 col:17 line:...0x7ff82ca9f100 tval:"") ] ) ] display_pos 16 Completing '{ echo hi; grep f' ... (Ctrl-C to cancel) Found 2 matches for '{ echo hi; grep f' in 0 ms words: redirects: tokens: <Lit_VarLike "var="> <VSub_DollarName "$v"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'var=$v' rl_slice from byte 0 to 6: 'var=$v' words: (w <Lit_Chars local>) (w <Lit_VarLike "var="> ($ v) <Lit_CompDummy "">) redirects: tokens: <Lit_Chars local> <WS_Space " "> <Lit_VarLike "var="> <VSub_DollarName "$v"> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'local var=$v' rl_slice from byte 0 to 12: 'local var=$v' . words: (w <Lit_Chars bad>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars bad> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'bad ' rl_slice from byte 0 to 4: 'bad ' Completing words partial_argv: [bad,] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:4 line:(SourceLine line_num:1 content:"bad " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 4 Completing 'bad ' ... (Ctrl-C to cancel) Running completion function '_bad' with 3 arguments _bad returning 124 comp.first 'bad', commands_changed: Function '_bad' returned 124, but the completion spec for 'bad' wasn't changed Found 0 matches for 'bad ' in 0 ms words: (w <Lit_Chars both>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars both> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'both ' rl_slice from byte 0 to 5: 'both ' Completing words partial_argv: [both,] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:5 line:(SourceLine line_num:1 content:"both " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 5 Completing 'both ' ... (Ctrl-C to cancel) Running completion function '_both' with 3 arguments comp.first 'both', commands_changed: Function '_both' returned 124, but the completion spec for 'both' wasn't changed Found 0 matches for 'both ' in 0 ms words: (w <Lit_Chars both2>) (w <Lit_CompDummy "">) redirects: tokens: <Lit_Chars both2> <WS_Space " "> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'both2 ' rl_slice from byte 0 to 6: 'both2 ' Completing words partial_argv: [both2,] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_CompDummy length:0 col:6 line:(SourceLine line_num:1 content:"both2 " src:(source.MainFile path:"<test_lib>") ) tval:"" ) ] ) ] display_pos 6 Completing 'both2 ' ... (Ctrl-C to cancel) Running completion function '_both2' with 3 arguments comp.first 'both2', commands_changed: both2 Got 124, trying again ... Completing 'both2 ' ... (Ctrl-C to cancel) Found 2 matches for 'both2 ' in 0 ms . words: (w <Lit_Chars mywords>) (w <Lit_Chars t> <Lit_CompDummy "">) redirects: tokens: <Lit_Chars mywords> <WS_Space " "> <Lit_Chars t> <Lit_CompDummy ""> <Eof_Real ""> alias_words: line: 'mywords t' rl_slice from byte 0 to 9: 'mywords t' Completing words partial_argv: [mywords,t] alias_words: [[]] words[-1]: [(CompoundWord parts:[ (Token id:Lit_Chars length:1 col:8 line:(SourceLine line_num:1 content:"mywords t" src:(source.MainFile path:"<test_lib>") ) tval:t ) (Token id:Lit_CompDummy length:0 col:9 line:...0x7ff82c97a470 tval:"") ] ) ] display_pos 8 Completing 'mywords t' ... (Ctrl-C to cancel) Running completion function 'complete_mywords' with 3 arguments E ====================================================================== ERROR: testMatchesOracle (__main__.InitCompletionTest) ---------------------------------------------------------------------- Traceback (most recent call last): File "/home/uke/oil/core/completion_test.py", line 787, in testMatchesOracle m = list(r.Matches(comp)) File "/home/uke/oil/core/completion.py", line 1312, in Matches user_spec, comp): File "/home/uke/oil/core/completion.py", line 1354, in _PostProcess for candidate, action_kind in user_spec.AllMatches(comp): File "/home/uke/oil/core/completion.py", line 894, in AllMatches for match in a.Matches(comp): File "/home/uke/oil/core/completion.py", line 601, in Matches status = self.cmd_ev.RunFuncForCompletion(self.func, argv) File "/home/uke/oil/osh/cmd_eval.py", line 2349, in RunFuncForCompletion status = self.RunProc(proc, cmd_val) File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc status = self._Execute(proc.body) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch status = self._ExecuteList(node.children) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1771, in _Dispatch status = self._DoIf(node) File "/home/uke/oil/osh/cmd_eval.py", line 1419, in _DoIf b = self._EvalCondition(if_arm.cond, if_arm.keyword) File "/home/uke/oil/osh/cmd_eval.py", line 644, in _EvalCondition cond_status = self._ExecuteList(cond) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1653, in _Dispatch status = self._Execute(node.child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1635, in _Dispatch status = self._DoSimple(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 914, in _DoSimple status = self._RunSimpleCommand(cmd_val, cmd_st, run_flags) File "/home/uke/oil/osh/cmd_eval.py", line 575, in _RunSimpleCommand run_flags) File "/home/uke/oil/core/executor.py", line 420, in RunSimpleCommand status = self.cmd_ev.RunProc(proc, cmd_val) File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc status = self._Execute(proc.body) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch status = self._ExecuteList(node.children) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1801, in _Dispatch status = self._DoForExpr(node) File "/home/uke/oil/osh/cmd_eval.py", line 1372, in _DoForExpr self.arith_ev.Eval(update) File "/home/uke/oil/osh/sh_expr_eval.py", line 611, in Eval old_big, lval = self._EvalLhsAndLookupArith(node.child) File "/home/uke/oil/osh/sh_expr_eval.py", line 520, in _EvalLhsAndLookupArith location.TokenForArith(node)) File "/home/uke/oil/osh/sh_expr_eval.py", line 130, in OldValue cell = mem.GetCellDeref(var_name) File "/home/uke/oil/core/state.py", line 2318, in GetCellDeref cell, _ = self._ResolveNameOrRef(name, which_scopes) ValueError: too many values to unpack ====================================================================== ERROR: testRunsUserDefinedFunctions (__main__.RootCompleterTest) ---------------------------------------------------------------------- Traceback (most recent call last): File "/home/uke/oil/core/completion_test.py", line 453, in testRunsUserDefinedFunctions m = list(r.Matches(MockApi('mywords t'))) File "/home/uke/oil/core/completion.py", line 1312, in Matches user_spec, comp): File "/home/uke/oil/core/completion.py", line 1354, in _PostProcess for candidate, action_kind in user_spec.AllMatches(comp): File "/home/uke/oil/core/completion.py", line 894, in AllMatches for match in a.Matches(comp): File "/home/uke/oil/core/completion.py", line 601, in Matches status = self.cmd_ev.RunFuncForCompletion(self.func, argv) File "/home/uke/oil/osh/cmd_eval.py", line 2349, in RunFuncForCompletion status = self.RunProc(proc, cmd_val) File "/home/uke/oil/osh/cmd_eval.py", line 2323, in RunProc status = self._Execute(proc.body) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1754, in _Dispatch status = self._ExecuteList(node.children) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1795, in _Dispatch status = self._DoForEach(node) File "/home/uke/oil/osh/cmd_eval.py", line 1333, in _DoForEach status = self._Execute(node.body) # last one wins File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1750, in _Dispatch status = self._ExecuteList(node.children) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1771, in _Dispatch status = self._DoIf(node) File "/home/uke/oil/osh/cmd_eval.py", line 1421, in _DoIf status = self._ExecuteList(if_arm.action) File "/home/uke/oil/osh/cmd_eval.py", line 1985, in _ExecuteList status = self._Execute(child) File "/home/uke/oil/osh/cmd_eval.py", line 1908, in _Execute status = self._Dispatch(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 1645, in _Dispatch status = self._DoShAssignment(node, cmd_st) File "/home/uke/oil/osh/cmd_eval.py", line 988, in _DoShAssignment node.left) File "/home/uke/oil/osh/sh_expr_eval.py", line 130, in OldValue cell = mem.GetCellDeref(var_name) File "/home/uke/oil/core/state.py", line 2318, in GetCellDeref cell, _ = self._ResolveNameOrRef(name, which_scopes) ValueError: too many values to unpack ---------------------------------------------------------------------- Ran 16 tests in 0.165s FAILED (errors=2) FAIL: core/completion_test.py with code 1