diff options
author | ZyX <kp-pav@yandex.ru> | 2017-03-17 10:57:19 +0300 |
---|---|---|
committer | ZyX <kp-pav@yandex.ru> | 2017-03-19 14:13:21 +0300 |
commit | 0e9286a19ed51ba9a2d6bfd06432c90e36cad4bd (patch) | |
tree | 60ebcc8135631a28cec7ecc40b1094e0a2770e97 | |
parent | 0320a58082f922b54cb36ce57064c07a9e781aa8 (diff) | |
download | rneovim-0e9286a19ed51ba9a2d6bfd06432c90e36cad4bd.tar.gz rneovim-0e9286a19ed51ba9a2d6bfd06432c90e36cad4bd.tar.bz2 rneovim-0e9286a19ed51ba9a2d6bfd06432c90e36cad4bd.zip |
tests: Fix CI failures
-rw-r--r-- | test/functional/core/main_spec.lua | 12 | ||||
-rw-r--r-- | test/helpers.lua | 18 | ||||
-rw-r--r-- | test/unit/preprocess.lua | 36 |
3 files changed, 34 insertions, 32 deletions
diff --git a/test/functional/core/main_spec.lua b/test/functional/core/main_spec.lua index 50c6009b53..a374b4c040 100644 --- a/test/functional/core/main_spec.lua +++ b/test/functional/core/main_spec.lua @@ -9,7 +9,7 @@ local nvim_prog = helpers.nvim_prog local write_file = helpers.write_file local popen_w = global_helpers.popen_w -local popen_r = global_helpers.popen_r +local repeated_popen_r = global_helpers.repeated_popen_r describe('Command-line option', function() describe('-s', function() @@ -48,13 +48,13 @@ describe('Command-line option', function() eq(nil, lfs.attributes(fname)) eq(true, not not dollar_fname:find('%$%w+')) write_file(dollar_fname, ':call setline(1, "100500")\n:wqall!\n') - local pipe = popen_r( + local pipe = repeated_popen_r( nvim_prog, '-u', 'NONE', '-i', 'NONE', '--headless', '-s', dollar_fname, fname) - local stdout = pipe:read('*a') - eq('', stdout) - local attrs = lfs.attributes(fname) - eq(#('100500\n'), attrs.size) + local stdout = pipe:read('*a') + eq('', stdout) + local attrs = lfs.attributes(fname) + eq(#('100500\n'), attrs.size) end) end) end) diff --git a/test/helpers.lua b/test/helpers.lua index 6ee95a4396..be83ff314b 100644 --- a/test/helpers.lua +++ b/test/helpers.lua @@ -17,8 +17,8 @@ local function argss_to_cmd(...) if type(arg) == 'string' then cmd = cmd .. ' ' ..shell_quote(arg) else - for _, arg in ipairs(arg) do - cmd = cmd .. ' ' .. shell_quote(arg) + for _, subarg in ipairs(arg) do + cmd = cmd .. ' ' .. shell_quote(subarg) end end end @@ -257,6 +257,19 @@ local function which(exe) end end +local function repeated_popen_r(...) + for _ = 1, 10 do + local stream = popen_r(...) + local ret = stream:read('*a') + stream:close() + if ret then + return ret + end + end + print('ERROR: Failed to execute ' .. argss_to_cmd(...) .. ': nil return after 10 attempts') + return nil +end + return { eq = eq, neq = neq, @@ -273,4 +286,5 @@ return { argss_to_cmd = argss_to_cmd, popen_r = popen_r, popen_w = popen_w, + repeated_popen_r = repeated_popen_r, } diff --git a/test/unit/preprocess.lua b/test/unit/preprocess.lua index 18b2284e3d..ac0c5a85c1 100644 --- a/test/unit/preprocess.lua +++ b/test/unit/preprocess.lua @@ -4,8 +4,8 @@ local ffi = require("ffi") local global_helpers = require('test.helpers') -local popen_r = global_helpers.popen_r local argss_to_cmd = global_helpers.argss_to_cmd +local repeated_popen_r = global_helpers.repeated_popen_r local ccs = {} @@ -157,28 +157,15 @@ function Gcc:dependencies(hdr) end end -local function repeated_call(...) - for _ = 1, 10 do - local stream = popen_r(...) - local ret = stream:read('*a') - stream:close() - if ret then - return ret - end - end - print('ERROR: preprocess.lua: Failed to execute ' .. cmd .. ': nil return after 10 attempts') - return nil -end - function Gcc:filter_standard_defines(defines) if not self.standard_defines then local pseudoheader_fname = 'tmp_empty_pseudoheader.h' local pseudoheader_file = io.open(pseudoheader_fname, 'w') pseudoheader_file:close() - local standard_defines = repeated_call(self.path, - self.preprocessor_extra_flags, - self.get_defines_extra_flags, - {pseudoheader_fname}) + local standard_defines = repeated_popen_r(self.path, + self.preprocessor_extra_flags, + self.get_defines_extra_flags, + {pseudoheader_fname}) os.remove(pseudoheader_fname) self.standard_defines = {} for line in standard_defines:gmatch('[^\n]+') do @@ -207,9 +194,9 @@ function Gcc:preprocess(previous_defines, ...) pseudoheader_file:flush() pseudoheader_file:close() - local defines = repeated_call(self.path, self.preprocessor_extra_flags, - self.get_defines_extra_flags, - {pseudoheader_fname}) + local defines = repeated_popen_r(self.path, self.preprocessor_extra_flags, + self.get_defines_extra_flags, + {pseudoheader_fname}) defines = self:filter_standard_defines(defines) -- lfs = require("lfs") @@ -218,9 +205,10 @@ function Gcc:preprocess(previous_defines, ...) -- io.stderr\write("CWD: #{lfs.currentdir!}\n") -- io.stderr\write("CMD: #{cmd}\n") - local declarations = repeated_call(self.path, self.preprocessor_extra_flags, - self.get_declarations_extra_flags, - {pseudoheader_fname}) + local declarations = repeated_popen_r(self.path, + self.preprocessor_extra_flags, + self.get_declarations_extra_flags, + {pseudoheader_fname}) os.remove(pseudoheader_fname) |