diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-03-01 19:23:24 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-03-01 19:23:24 +0000 |
commit | 7a2222487507eb13cccdb9a66397092775d62b8c (patch) | |
tree | c5878917461a22b48ec7a38cb6356352b8e57895 /src/testdir/test_vim9_expr.vim | |
parent | f01af9c4e6f1438cd1112cfff42f3837028c7846 (diff) | |
download | vim-git-7a2222487507eb13cccdb9a66397092775d62b8c.tar.gz |
patch 8.2.4487: Vim9: cannot compare with v:nullv8.2.4487
Problem: Vim9: cannot compare with v:null.
Solution: Allow comparing anything with v:null. (closes #9866)
Diffstat (limited to 'src/testdir/test_vim9_expr.vim')
-rw-r--r-- | src/testdir/test_vim9_expr.vim | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/src/testdir/test_vim9_expr.vim b/src/testdir/test_vim9_expr.vim index 4aad9c98c..a38254f7d 100644 --- a/src/testdir/test_vim9_expr.vim +++ b/src/testdir/test_vim9_expr.vim @@ -712,6 +712,81 @@ def Test_expr4_equal() unlet g:notReached enddef +def Test_expr4_compare_null() + g:null_dict = test_null_dict() + g:not_null_list = [] + var lines =<< trim END + assert_true(test_null_blob() == v:null) + assert_true(v:null == test_null_blob()) + assert_false(test_null_blob() != v:null) + assert_false(v:null != test_null_blob()) + + if has('channel') + assert_true(test_null_channel() == v:null) + assert_true(v:null == test_null_channel()) + assert_false(test_null_channel() != v:null) + assert_false(v:null != test_null_channel()) + endif + + assert_true(test_null_dict() == v:null) + assert_true(v:null == test_null_dict()) + assert_false(test_null_dict() != v:null) + assert_false(v:null != test_null_dict()) + + assert_true(g:null_dict == v:null) + assert_true(v:null == g:null_dict) + assert_false(g:null_dict != v:null) + assert_false(v:null != g:null_dict) + + assert_true(test_null_function() == v:null) + assert_true(v:null == test_null_function()) + assert_false(test_null_function() != v:null) + assert_false(v:null != test_null_function()) + + if has('job') + assert_true(test_null_job() == v:null) + assert_true(v:null == test_null_job()) + assert_false(test_null_job() != v:null) + assert_false(v:null != test_null_job()) + endif + + assert_true(test_null_list() == v:null) + assert_true(v:null == test_null_list()) + assert_false(test_null_list() != v:null) + assert_false(v:null != test_null_list()) + + assert_false(g:not_null_list == v:null) + assert_false(v:null == g:not_null_list) + assert_true(g:not_null_list != v:null) + assert_true(v:null != g:not_null_list) + + assert_true(test_null_partial() == v:null) + assert_true(v:null == test_null_partial()) + assert_false(test_null_partial() != v:null) + assert_false(v:null != test_null_partial()) + + assert_true(test_null_string() == v:null) + assert_true(v:null == test_null_string()) + assert_false(test_null_string() != v:null) + assert_false(v:null != test_null_string()) + END + v9.CheckDefAndScriptSuccess(lines) + unlet g:null_dict + unlet g:not_null_list + + v9.CheckDefAndScriptFailure(['echo 123 == v:null'], 'E1072: Cannot compare number with special') + v9.CheckDefAndScriptFailure(['echo v:null == 123'], 'E1072: Cannot compare special with number') + v9.CheckDefAndScriptFailure(['echo 123 != v:null'], 'E1072: Cannot compare number with special') + v9.CheckDefAndScriptFailure(['echo v:null != 123'], 'E1072: Cannot compare special with number') + v9.CheckDefAndScriptFailure(['echo true == v:null'], 'E1072: Cannot compare bool with special') + v9.CheckDefAndScriptFailure(['echo v:null == true'], 'E1072: Cannot compare special with bool') + v9.CheckDefAndScriptFailure(['echo true != v:null'], 'E1072: Cannot compare bool with special') + v9.CheckDefAndScriptFailure(['echo v:null != true'], 'E1072: Cannot compare special with bool') + v9.CheckDefAndScriptFailure(['echo false == v:null'], 'E1072: Cannot compare bool with special') + + v9.CheckDefExecAndScriptFailure(['echo [] == v:none'], ['E1072: Cannot compare list with special', 'E691: Can only compare List with List']) +enddef + def Test_expr4_wrong_type() for op in ['>', '>=', '<', '<=', '=~', '!~'] v9.CheckDefExecAndScriptFailure([ |