tests: Fix CI failures

This commit is contained in:
ZyX
2017-03-17 10:57:19 +03:00
parent 0320a58082
commit 0e9286a19e
3 changed files with 34 additions and 32 deletions

View File

@@ -9,7 +9,7 @@ local nvim_prog = helpers.nvim_prog
local write_file = helpers.write_file local write_file = helpers.write_file
local popen_w = global_helpers.popen_w 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('Command-line option', function()
describe('-s', function() describe('-s', function()
@@ -48,13 +48,13 @@ describe('Command-line option', function()
eq(nil, lfs.attributes(fname)) eq(nil, lfs.attributes(fname))
eq(true, not not dollar_fname:find('%$%w+')) eq(true, not not dollar_fname:find('%$%w+'))
write_file(dollar_fname, ':call setline(1, "100500")\n:wqall!\n') 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, nvim_prog, '-u', 'NONE', '-i', 'NONE', '--headless', '-s', dollar_fname,
fname) fname)
local stdout = pipe:read('*a') local stdout = pipe:read('*a')
eq('', stdout) eq('', stdout)
local attrs = lfs.attributes(fname) local attrs = lfs.attributes(fname)
eq(#('100500\n'), attrs.size) eq(#('100500\n'), attrs.size)
end) end)
end) end)
end) end)

View File

@@ -17,8 +17,8 @@ local function argss_to_cmd(...)
if type(arg) == 'string' then if type(arg) == 'string' then
cmd = cmd .. ' ' ..shell_quote(arg) cmd = cmd .. ' ' ..shell_quote(arg)
else else
for _, arg in ipairs(arg) do for _, subarg in ipairs(arg) do
cmd = cmd .. ' ' .. shell_quote(arg) cmd = cmd .. ' ' .. shell_quote(subarg)
end end
end end
end end
@@ -257,6 +257,19 @@ local function which(exe)
end end
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 { return {
eq = eq, eq = eq,
neq = neq, neq = neq,
@@ -273,4 +286,5 @@ return {
argss_to_cmd = argss_to_cmd, argss_to_cmd = argss_to_cmd,
popen_r = popen_r, popen_r = popen_r,
popen_w = popen_w, popen_w = popen_w,
repeated_popen_r = repeated_popen_r,
} }

View File

@@ -4,8 +4,8 @@
local ffi = require("ffi") local ffi = require("ffi")
local global_helpers = require('test.helpers') local global_helpers = require('test.helpers')
local popen_r = global_helpers.popen_r
local argss_to_cmd = global_helpers.argss_to_cmd local argss_to_cmd = global_helpers.argss_to_cmd
local repeated_popen_r = global_helpers.repeated_popen_r
local ccs = {} local ccs = {}
@@ -157,28 +157,15 @@ function Gcc:dependencies(hdr)
end end
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) function Gcc:filter_standard_defines(defines)
if not self.standard_defines then if not self.standard_defines then
local pseudoheader_fname = 'tmp_empty_pseudoheader.h' local pseudoheader_fname = 'tmp_empty_pseudoheader.h'
local pseudoheader_file = io.open(pseudoheader_fname, 'w') local pseudoheader_file = io.open(pseudoheader_fname, 'w')
pseudoheader_file:close() pseudoheader_file:close()
local standard_defines = repeated_call(self.path, local standard_defines = repeated_popen_r(self.path,
self.preprocessor_extra_flags, self.preprocessor_extra_flags,
self.get_defines_extra_flags, self.get_defines_extra_flags,
{pseudoheader_fname}) {pseudoheader_fname})
os.remove(pseudoheader_fname) os.remove(pseudoheader_fname)
self.standard_defines = {} self.standard_defines = {}
for line in standard_defines:gmatch('[^\n]+') do for line in standard_defines:gmatch('[^\n]+') do
@@ -207,9 +194,9 @@ function Gcc:preprocess(previous_defines, ...)
pseudoheader_file:flush() pseudoheader_file:flush()
pseudoheader_file:close() pseudoheader_file:close()
local defines = repeated_call(self.path, self.preprocessor_extra_flags, local defines = repeated_popen_r(self.path, self.preprocessor_extra_flags,
self.get_defines_extra_flags, self.get_defines_extra_flags,
{pseudoheader_fname}) {pseudoheader_fname})
defines = self:filter_standard_defines(defines) defines = self:filter_standard_defines(defines)
-- lfs = require("lfs") -- lfs = require("lfs")
@@ -218,9 +205,10 @@ function Gcc:preprocess(previous_defines, ...)
-- io.stderr\write("CWD: #{lfs.currentdir!}\n") -- io.stderr\write("CWD: #{lfs.currentdir!}\n")
-- io.stderr\write("CMD: #{cmd}\n") -- io.stderr\write("CMD: #{cmd}\n")
local declarations = repeated_call(self.path, self.preprocessor_extra_flags, local declarations = repeated_popen_r(self.path,
self.get_declarations_extra_flags, self.preprocessor_extra_flags,
{pseudoheader_fname}) self.get_declarations_extra_flags,
{pseudoheader_fname})
os.remove(pseudoheader_fname) os.remove(pseudoheader_fname)