aboutsummaryrefslogtreecommitdiff
path: root/test/functional/cmdline/history_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/cmdline/history_spec.lua')
-rw-r--r--test/functional/cmdline/history_spec.lua36
1 files changed, 36 insertions, 0 deletions
diff --git a/test/functional/cmdline/history_spec.lua b/test/functional/cmdline/history_spec.lua
new file mode 100644
index 0000000000..20f9cf06a2
--- /dev/null
+++ b/test/functional/cmdline/history_spec.lua
@@ -0,0 +1,36 @@
+local helpers = require('test.functional.helpers')(after_each)
+local clear, meths, funcs, eq =
+ helpers.clear, helpers.meths, helpers.funcs, helpers.eq
+
+describe('history support code', function()
+ before_each(clear)
+
+ it('correctly clears start of the history', function()
+ -- Regression test: check absense of the memory leak when clearing start of
+ -- the history using ex_getln.c/clr_history().
+ eq(1, funcs.histadd(':', 'foo'))
+ eq(1, funcs.histdel(':'))
+ eq('', funcs.histget(':', -1))
+ end)
+
+ it('correctly clears end of the history', function()
+ -- Regression test: check absense of the memory leak when clearing end of
+ -- the history using ex_getln.c/clr_history().
+ meths.set_option('history', 1)
+ eq(1, funcs.histadd(':', 'foo'))
+ eq(1, funcs.histdel(':'))
+ eq('', funcs.histget(':', -1))
+ end)
+
+ it('correctly removes item from history', function()
+ -- Regression test: check that ex_getln.c/del_history_idx() correctly clears
+ -- history index after removing history entry. If it does not then deleting
+ -- history will result in a double free.
+ eq(1, funcs.histadd(':', 'foo'))
+ eq(1, funcs.histadd(':', 'bar'))
+ eq(1, funcs.histadd(':', 'baz'))
+ eq(1, funcs.histdel(':', -2))
+ eq(1, funcs.histdel(':'))
+ eq('', funcs.histget(':', -1))
+ end)
+end)