1" Tests for ->method() 2 3source check.vim 4 5func Test_list_method() 6 let l = [1, 2, 3] 7 call assert_equal([1, 2, 3, 4], [1, 2, 3]->add(4)) 8 eval l->assert_equal(l) 9 eval l->assert_equal(l, 'wrong') 10 eval l->assert_notequal([3, 2, 1]) 11 eval l->assert_notequal([3, 2, 1], 'wrong') 12 call assert_equal(l, l->copy()) 13 call assert_equal(l, l->deepcopy()) 14 call assert_equal(1, l->count(2)) 15 call assert_false(l->empty()) 16 call assert_true([]->empty()) 17 call assert_equal(579, ['123', '+', '456']->join()->eval()) 18 call assert_equal([1, 2, 3, 4, 5], [1, 2, 3]->extend([4, 5])) 19 call assert_equal([1, 3], [1, 2, 3]->filter('v:val != 2')) 20 call assert_equal(2, l->get(1)) 21 call assert_equal(1, l->index(2)) 22 call assert_equal([0, 1, 2, 3], [1, 2, 3]->insert(0)) 23 call assert_fails('eval l->items()', 'E715:') 24 call assert_equal('1 2 3', l->join()) 25 call assert_fails('eval l->keys()', 'E715:') 26 call assert_equal(3, l->len()) 27 call assert_equal([2, 3, 4], [1, 2, 3]->map('v:val + 1')) 28 call assert_equal(3, l->max()) 29 call assert_equal(1, l->min()) 30 call assert_equal(2, [1, 2, 3]->remove(1)) 31 call assert_equal([1, 2, 3, 1, 2, 3], l->repeat(2)) 32 call assert_equal([3, 2, 1], [1, 2, 3]->reverse()) 33 call assert_equal([1, 2, 3, 4], [4, 2, 3, 1]->sort()) 34 call assert_equal('[1, 2, 3]', l->string()) 35 call assert_equal(v:t_list, l->type()) 36 call assert_equal([1, 2, 3], [1, 1, 2, 3, 3]->uniq()) 37 call assert_fails('eval l->values()', 'E715:') 38 call assert_fails('echo []->len', 'E107:') 39endfunc 40 41func Test_dict_method() 42 let d = #{one: 1, two: 2, three: 3} 43 44 call assert_equal(d, d->copy()) 45 call assert_equal(d, d->deepcopy()) 46 call assert_equal(1, d->count(2)) 47 call assert_false(d->empty()) 48 call assert_true({}->empty()) 49 call assert_equal(#{one: 1, two: 2, three: 3, four: 4}, d->extend(#{four: 4})) 50 call assert_equal(#{one: 1, two: 2, three: 3}, d->filter('v:val != 4')) 51 call assert_equal(2, d->get('two')) 52 call assert_fails("let x = d->index(2)", 'E897:') 53 call assert_fails("let x = d->insert(0)", 'E899:') 54 call assert_true(d->has_key('two')) 55 call assert_equal([['one', 1], ['two', 2], ['three', 3]], d->items()) 56 call assert_fails("let x = d->join()", 'E714:') 57 call assert_equal(['one', 'two', 'three'], d->keys()) 58 call assert_equal(3, d->len()) 59 call assert_equal(#{one: 2, two: 3, three: 4}, d->map('v:val + 1')) 60 call assert_equal(#{one: 1, two: 2, three: 3}, d->map('v:val - 1')) 61 call assert_equal(3, d->max()) 62 call assert_equal(1, d->min()) 63 call assert_equal(2, d->remove("two")) 64 let d.two = 2 65 call assert_fails('let x = d->repeat(2)', 'E731:') 66 call assert_fails('let x = d->reverse()', 'E899:') 67 call assert_fails('let x = d->sort()', 'E686:') 68 call assert_equal("{'one': 1, 'two': 2, 'three': 3}", d->string()) 69 call assert_equal(v:t_dict, d->type()) 70 call assert_fails('let x = d->uniq()', 'E686:') 71 call assert_equal([1, 2, 3], d->values()) 72endfunc 73 74func Test_string_method() 75 eval '1 2 3'->split()->assert_equal(['1', '2', '3']) 76 eval '1 2 3'->split()->map({i, v -> str2nr(v)})->assert_equal([1, 2, 3]) 77 eval 'ABC'->str2list()->assert_equal([65, 66, 67]) 78 eval 'ABC'->strlen()->assert_equal(3) 79 eval "a\rb\ec"->strtrans()->assert_equal('a^Mb^[c') 80 eval "aあb"->strwidth()->assert_equal(4) 81 eval 'abc'->substitute('b', 'x', '')->assert_equal('axc') 82 83 eval 'abc'->printf('the %s arg')->assert_equal('the abc arg') 84endfunc 85 86func Test_method_append() 87 new 88 eval ['one', 'two', 'three']->append(1) 89 call assert_equal(['', 'one', 'two', 'three'], getline(1, '$')) 90 91 %del 92 let bnr = bufnr('') 93 wincmd w 94 eval ['one', 'two', 'three']->appendbufline(bnr, 1) 95 call assert_equal(['', 'one', 'two', 'three'], getbufline(bnr, 1, '$')) 96 97 exe 'bwipe! ' .. bnr 98endfunc 99 100func Test_method_funcref() 101 func Concat(one, two, three) 102 return a:one .. a:two .. a:three 103 endfunc 104 let FuncRef = function('Concat') 105 eval 'foo'->FuncRef('bar', 'tail')->assert_equal('foobartail') 106 107 " not enough arguments 108 call assert_fails("eval 'foo'->FuncRef('bar')", 'E119:') 109 " too many arguments 110 call assert_fails("eval 'foo'->FuncRef('bar', 'tail', 'four')", 'E118:') 111 112 let Partial = function('Concat', ['two']) 113 eval 'one'->Partial('three')->assert_equal('onetwothree') 114 115 " not enough arguments 116 call assert_fails("eval 'one'->Partial()", 'E119:') 117 " too many arguments 118 call assert_fails("eval 'one'->Partial('three', 'four')", 'E118:') 119 120 delfunc Concat 121endfunc 122 123func Test_method_float() 124 CheckFeature float 125 eval 1.234->string()->assert_equal('1.234') 126 eval -1.234->string()->assert_equal('-1.234') 127endfunc 128 129func Test_method_syntax() 130 eval [1, 2, 3] ->sort( ) 131 eval [1, 2, 3] 132 \ ->sort( 133 \ ) 134 call assert_fails('eval [1, 2, 3]-> sort()', 'E15:') 135 call assert_fails('eval [1, 2, 3]->sort ()', 'E274:') 136 call assert_fails('eval [1, 2, 3]-> sort ()', 'E15:') 137endfunc 138 139func Test_method_lambda() 140 eval "text"->{x -> x .. " extended"}()->assert_equal('text extended') 141 eval "text"->{x, y -> x .. " extended " .. y}('more')->assert_equal('text extended more') 142 143 call assert_fails('eval "text"->{x -> x .. " extended"} ()', 'E274:') 144 145 " todo: lambda accepts more arguments than it consumes 146 " call assert_fails('eval "text"->{x -> x .. " extended"}("more")', 'E99:') 147 148 let l = [1, 2, 3] 149 eval l->{x -> x}() 150 call assert_equal(1, test_refcount(l)) 151endfunc 152 153func Test_method_not_supported() 154 call assert_fails('eval 123->changenr()', 'E276:') 155 call assert_fails('echo "abc"->invalidfunc()', 'E117:') 156 " Test for too many or too few arguments to a method 157 call assert_fails('let n="abc"->len(2)', 'E118:') 158 call assert_fails('let n=10->setwinvar()', 'E119:') 159endfunc 160 161" Test for passing optional arguments to methods 162func Test_method_args() 163 let v:errors = [] 164 let n = 10->assert_inrange(1, 5, "Test_assert_inrange") 165 if v:errors[0] !~ 'Test_assert_inrange' 166 call assert_report(v:errors[0]) 167 else 168 " Test passed 169 let v:errors = [] 170 endif 171endfunc 172 173" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker 174