diff options
author | James McCoy <jamessan@jamessan.com> | 2016-05-25 16:59:52 -0400 |
---|---|---|
committer | James McCoy <jamessan@jamessan.com> | 2016-05-25 17:13:05 -0400 |
commit | bc306ab5aa0d2ee7a4653cb1d47615a3f04478a1 (patch) | |
tree | ba9a822c8bde433c34f4ea5282cce8b9cb500abd /src | |
parent | 2115fcdfd5a6b32b62dcd280c59843437c4702d6 (diff) | |
download | rneovim-bc306ab5aa0d2ee7a4653cb1d47615a3f04478a1.tar.gz rneovim-bc306ab5aa0d2ee7a4653cb1d47615a3f04478a1.tar.bz2 rneovim-bc306ab5aa0d2ee7a4653cb1d47615a3f04478a1.zip |
vim-patch:7.4.1096
Problem: Need several lines to verify a command produces an error.
Solution: Add assert_fails(). (suggested by Nikolay Pavlov)
Make the quickfix alloc test actually work.
https://github.com/vim/vim/commit/a260b87d9da17f605666630f18c1ed909c2b8bae
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/eval.c | 37 | ||||
-rw-r--r-- | src/nvim/version.c | 2 |
2 files changed, 38 insertions, 1 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 0d060e5b70..ec53de3269 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -6680,6 +6680,7 @@ static struct fst { { "asin", 1, 1, f_asin }, // WJMc { "assert_equal", 2, 3, f_assert_equal }, { "assert_exception", 1, 2, f_assert_exception }, + { "assert_fails", 1, 2, f_assert_fails }, { "assert_false", 1, 2, f_assert_false }, { "assert_true", 1, 2, f_assert_true }, { "atan", 1, 1, f_atan }, @@ -7667,6 +7668,42 @@ static void f_assert_exception(typval_T *argvars, typval_T *rettv) } } +/// "assert_fails(cmd [, error])" function +static void f_assert_fails(typval_T *argvars, typval_T *rettv) +{ + char_u *cmd = get_tv_string_chk(&argvars[0]); + garray_T ga; + + called_emsg = false; + suppress_errthrow = true; + emsg_silent = true; + do_cmdline_cmd((char *)cmd); + if (!called_emsg) { + prepare_assert_error(&ga); + ga_concat(&ga, (char_u *)"command did not fail: "); + ga_concat(&ga, cmd); + assert_error(&ga); + ga_clear(&ga); + } else if (argvars[1].v_type != VAR_UNKNOWN) { + char_u buf[NUMBUFLEN]; + char *error = (char *)get_tv_string_buf_chk(&argvars[1], buf); + + if (strstr((char *)vimvars[VV_ERRMSG].vv_str, error) == NULL) { + prepare_assert_error(&ga); + fill_assert_error(&ga, &argvars[2], NULL, &argvars[1], + &vimvars[VV_ERRMSG].vv_tv); + assert_error(&ga); + ga_clear(&ga); + } + } + + called_emsg = false; + suppress_errthrow = false; + emsg_silent = false; + emsg_on_display = false; + set_vim_var_string(VV_ERRMSG, NULL, 0); +} + // Common for assert_true() and assert_false(). static void assert_bool(typval_T *argvars, bool is_true) { diff --git a/src/nvim/version.c b/src/nvim/version.c index d34df421f3..7400385d2d 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -590,7 +590,7 @@ static int included_patches[] = { // 1099 NA // 1098 NA // 1097, - // 1096, + 1096, // 1095 NA // 1094, 1093, |