aboutsummaryrefslogtreecommitdiff
path: root/test/functional/legacy/002_filename_recognition_spec.lua
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2014-10-02 09:49:11 -0400
committerJustin M. Keyes <justinkz@gmail.com>2014-10-02 09:49:11 -0400
commit60e5d8d1ccd5a07038138f18752620edebeb8a3d (patch)
tree1633766a082252e2b1074968377d1fd98481e496 /test/functional/legacy/002_filename_recognition_spec.lua
parent1f622d63bcd3018e5e714c02e6d0b58431c658e4 (diff)
parent45525853d3521e73512f68bb390aae0e385ef66c (diff)
downloadrneovim-60e5d8d1ccd5a07038138f18752620edebeb8a3d.tar.gz
rneovim-60e5d8d1ccd5a07038138f18752620edebeb8a3d.tar.bz2
rneovim-60e5d8d1ccd5a07038138f18752620edebeb8a3d.zip
Merge pull request #1260 from tarruda/system-specs
Fix coverity defect(Resource leak) and add some specs which expose the bug to valgrind
Diffstat (limited to 'test/functional/legacy/002_filename_recognition_spec.lua')
-rw-r--r--test/functional/legacy/002_filename_recognition_spec.lua42
1 files changed, 42 insertions, 0 deletions
diff --git a/test/functional/legacy/002_filename_recognition_spec.lua b/test/functional/legacy/002_filename_recognition_spec.lua
new file mode 100644
index 0000000000..569e748631
--- /dev/null
+++ b/test/functional/legacy/002_filename_recognition_spec.lua
@@ -0,0 +1,42 @@
+-- Test if URLs are recognized as filenames by commands such as "gf". Here
+-- we'll use `expand("<cfile>")` since "gf" would need to open the file.
+
+local helpers = require('test.functional.helpers')
+local clear, feed, insert = helpers.clear, helpers.feed, helpers.insert
+local execute, expect = helpers.execute, helpers.expect
+
+describe('filename recognition', function()
+ setup(clear)
+
+ it('is working', function()
+ -- insert some lines containing URLs
+ insert([[
+ first test for URL://machine.name/tmp/vimtest2a and other text
+ second test for URL://machine.name/tmp/vimtest2b. And other text
+ third test for URL:\\machine.name\vimtest2c and other text
+ fourth test for URL:\\machine.name\tmp\vimtest2d, and other text]])
+
+ -- Go to the first URL and append it to the beginning
+ execute('/^first', '/tmp', 'call append(0, expand("<cfile>"))')
+
+ -- Repeat for the second URL
+ -- this time, navigate to the word "URL" instead of "tmp"
+ execute('/^second', '/URL', 'call append(1, expand("<cfile>"))')
+
+ -- Repeat for the remaining URLs. This time, the 'isfname' option must be
+ -- set to allow '\' in filenames
+ execute('set isf=@,48-57,/,.,-,_,+,,,$,:,~,\\')
+ execute('/^third', '/name', 'call append(2, expand("<cfile>"))')
+ execute('/^fourth', '/URL', 'call append(3, expand("<cfile>"))')
+
+ -- Delete the initial text, which now starts at line 5
+ feed('5GdG')
+
+ -- The buffer should now contain:
+ expect([[
+ URL://machine.name/tmp/vimtest2a
+ URL://machine.name/tmp/vimtest2b
+ URL:\\machine.name\vimtest2c
+ URL:\\machine.name\tmp\vimtest2d]])
+ end)
+end)