Mercurial > vim
view src/testdir/test_assert.vim @ 13262:69278c25429d v8.0.1505
patch 8.0.1505: debugger can't break on a condition
commit https://github.com/vim/vim/commit/c6f9f739d32084923c3031cbf6f581f8c8bf7fd2
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Feb 11 19:06:26 2018 +0100
patch 8.0.1505: debugger can't break on a condition
Problem: Debugger can't break on a condition. (Charles Campbell)
Solution: Add ":breakadd expr". (Christian Brabandt, closes https://github.com/vim/vim/issues/859)
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sun, 11 Feb 2018 19:15:05 +0100 |
parents | 1c4ebbae41d2 |
children | abaebba89fd4 |
line wrap: on
line source
" Test that the methods used for testing work. func Test_assert_false() call assert_false(0) call assert_false(v:false) endfunc func Test_assert_true() call assert_true(1) call assert_true(123) call assert_true(v:true) endfunc func Test_assert_equal() let s = 'foo' call assert_equal('foo', s) let n = 4 call assert_equal(4, n) let l = [1, 2, 3] call assert_equal([1, 2, 3], l) let s = 'foo' call assert_equal('bar', s) call assert_match("Expected 'bar' but got 'foo'", v:errors[0]) call remove(v:errors, 0) endfunc func Test_assert_notequal() let n = 4 call assert_notequal('foo', n) let s = 'foo' call assert_notequal([1, 2, 3], s) call assert_notequal('foo', s) call assert_match("Expected not equal to 'foo'", v:errors[0]) call remove(v:errors, 0) endfunc func Test_assert_report() call assert_report('something is wrong') call assert_match('something is wrong', v:errors[0]) call remove(v:errors, 0) endfunc func Test_assert_exception() try nocommand catch call assert_exception('E492:') endtry try nocommand catch try " illegal argument, get NULL for error call assert_exception([]) catch call assert_exception('E730:') endtry endtry endfunc func Test_wrong_error_type() let save_verrors = v:errors let v:['errors'] = {'foo': 3} call assert_equal('yes', 'no') let verrors = v:errors let v:errors = save_verrors call assert_equal(type([]), type(verrors)) endfunc func Test_compare_fail() let s:v = {} let s:x = {"a": s:v} let s:v["b"] = s:x let s:w = {"c": s:x, "d": ''} try call assert_equal(s:w, '') catch call assert_exception('E724:') call assert_match("Expected NULL but got ''", v:errors[0]) call remove(v:errors, 0) endtry endfunc func Test_match() call assert_match('^f.*b.*r$', 'foobar') call assert_match('bar.*foo', 'foobar') call assert_match("Pattern 'bar.*foo' does not match 'foobar'", v:errors[0]) call remove(v:errors, 0) call assert_match('bar.*foo', 'foobar', 'wrong') call assert_match('wrong', v:errors[0]) call remove(v:errors, 0) endfunc func Test_notmatch() call assert_notmatch('foo', 'bar') call assert_notmatch('^foobar$', 'foobars') call assert_notmatch('foo', 'foobar') call assert_match("Pattern 'foo' does match 'foobar'", v:errors[0]) call remove(v:errors, 0) endfunc func Test_assert_fail_fails() call assert_fails('xxx', {}) call assert_match("Expected {} but got 'E731:", v:errors[0]) call remove(v:errors, 0) endfunc func Test_assert_inrange() call assert_inrange(7, 7, 7) call assert_inrange(5, 7, 5) call assert_inrange(5, 7, 6) call assert_inrange(5, 7, 7) call assert_inrange(5, 7, 4) call assert_match("Expected range 5 - 7, but got 4", v:errors[0]) call remove(v:errors, 0) call assert_inrange(5, 7, 8) call assert_match("Expected range 5 - 7, but got 8", v:errors[0]) call remove(v:errors, 0) call assert_fails('call assert_inrange(1, 1)', 'E119:') endfunc func Test_assert_with_msg() call assert_equal('foo', 'bar', 'testing') call assert_match("testing: Expected 'foo' but got 'bar'", v:errors[0]) call remove(v:errors, 0) endfunc func Test_override() call test_override('char_avail', 1) call test_override('redraw', 1) call test_override('ALL', 0) call assert_fails("call test_override('xxx', 1)", 'E475') call assert_fails("call test_override('redraw', 'yes')", 'E474') endfunc func Test_user_is_happy() smile sleep 300m endfunc