Skip to content

Commit

Permalink
chore: disable collapse-simple-statements
Browse files Browse the repository at this point in the history
  • Loading branch information
mpolitzer committed Sep 4, 2024
1 parent d567919 commit a8ab50b
Show file tree
Hide file tree
Showing 15 changed files with 605 additions and 223 deletions.
2 changes: 1 addition & 1 deletion tests/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ RUN_ARCH_TEST = $(LUA) $(abspath ./lua/run-rv64i-arch-test.lua)
CARTESI_IMAGES = $(CARTESI_IMAGES_PATH)/linux.bin

STYLUA=stylua
STYLUA_FLAGS=--indent-type Spaces --collapse-simple-statement Always
STYLUA_FLAGS=--indent-type Spaces

build-tests-all: misc build-tests-machine-with-toolchain build-tests-uarch-with-toolchain images $(CARTESI_CMIO_PATH)

Expand Down
145 changes: 110 additions & 35 deletions tests/lua/cartesi-machine-tests.lua
Original file line number Diff line number Diff line change
Expand Up @@ -418,61 +418,77 @@ local options = {
{
"^%-%-h$",
function(all)
if not all then return false end
if not all then
return false
end
help()
end,
},
{
"^%-%-help$",
function(all)
if not all then return false end
if not all then
return false
end
help()
end,
},
{
"^%-%-remote%-address%=(.*)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
remote_address = o
return true
end,
},
{
"^%-%-output%=(.*)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
output = o
return true
end,
},
{
"^%-%-json%-test%-list$",
function(all)
if not all then return false end
if not all then
return false
end
json_list = true
return true
end,
},
{
"^%-%-test%-path%=(.*)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
test_path = o
return true
end,
},
{
"^%-%-test%=(.*)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
test_pattern = o
return true
end,
},
{
"^%-%-jobs%=([0-9]+)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
jobs = tonumber(o)
assert(jobs and jobs >= 1, "invalid number of jobs")
return true
Expand All @@ -481,23 +497,29 @@ local options = {
{
"^%-%-log%-proofs$",
function(o)
if not o then return false end
if not o then
return false
end
log_proofs = true
return true
end,
},
{
"^%-%-log%-annotations$",
function(o)
if not o then return false end
if not o then
return false
end
log_annotations = true
return true
end,
},
{
"^(%-%-periodic%-action%=(.*))$",
function(all, v)
if not v then return false end
if not v then
return false
end
string.gsub(v, "^([^%,]+),(.+)$", function(p, s)
periodic_action_period = assert(util.parse_number(p), "invalid period " .. all)
periodic_action_start = assert(util.parse_number(s), "invalid start " .. all)
Expand All @@ -514,7 +536,9 @@ local options = {
{
"^(%-%-concurrency%=(.+))$",
function(all, opts)
if not opts then return false end
if not opts then
return false
end
local c = util.parse_options(opts, {
update_merkle_tree = true,
})
Expand All @@ -527,14 +551,21 @@ local options = {
{
"^%-%-uarch%-ram%-image%=(.*)$",
function(o)
if not o or #o < 1 then return false end
if not o or #o < 1 then
return false
end
uarch = uarch or {}
uarch.ram = uarch.ram or {}
uarch.ram.image_filename = o
return true
end,
},
{ ".*", function(all) error("unrecognized option " .. all) end },
{
".*",
function(all)
error("unrecognized option " .. all)
end,
},
}

local values = {}
Expand All @@ -543,7 +574,9 @@ local values = {}
for _, argument in ipairs({ ... }) do
if argument:sub(1, 1) == "-" then
for _, option in ipairs(options) do
if option[2](argument:match(option[1])) then break end
if option[2](argument:match(option[1])) then
break
end
end
else
values[#values + 1] = argument
Expand All @@ -553,23 +586,31 @@ end
local command = assert(values[1], "missing command")
assert(test_path, "missing test path")

if remote_address then protocol = require("cartesi." .. remote_protocol) end
if remote_address then
protocol = require("cartesi." .. remote_protocol)
end

local function advance_machine(machine, max_mcycle) return machine:run(max_mcycle) end
local function advance_machine(machine, max_mcycle)
return machine:run(max_mcycle)
end

local function run_machine(machine, ctx, max_mcycle, advance_machine_fn)
advance_machine_fn = advance_machine_fn or advance_machine
local mcycle = machine:read_mcycle()
while math.ult(mcycle, max_mcycle) do
advance_machine_fn(machine, max_mcycle)
mcycle = machine:read_mcycle()
if machine:read_iflags_H() then break end
if machine:read_iflags_H() then
break
end
end
ctx.read_htif_tohost_data = machine:read_htif_tohost_data()
end

local function advance_machine_with_uarch(machine)
if machine:run_uarch() == cartesi.UARCH_BREAK_REASON_UARCH_HALTED then machine:reset_uarch() end
if machine:run_uarch() == cartesi.UARCH_BREAK_REASON_UARCH_HALTED then
machine:reset_uarch()
end
end

local function run_machine_with_uarch(machine, ctx, max_mcycle)
Expand All @@ -580,8 +621,14 @@ local function connect()
local remote_stub = protocol.stub(remote_address)
local version =
assert(remote_stub.get_version(), "could not connect to remote cartesi machine at " .. remote_address)
local shutdown = function() remote_stub.shutdown() end
local mt = { __gc = function() pcall(shutdown) end }
local shutdown = function()
remote_stub.shutdown()
end
local mt = {
__gc = function()
pcall(shutdown)
end,
}
setmetatable(cleanup, mt)
return remote_stub, version
end
Expand All @@ -608,14 +655,18 @@ local function build_machine(ram_image)
length = 0x40000,
} },
}
if uarch then config.uarch = uarch end
if uarch then
config.uarch = uarch
end
local runtime = {
concurrency = {
update_merkle_tree = concurrency_update_merkle_tree,
},
}
if remote_address then
if not remote then remote = connect() end
if not remote then
remote = connect()
end
return assert(remote.machine(config, runtime))
end
return assert(cartesi.machine(config, runtime))
Expand Down Expand Up @@ -647,8 +698,12 @@ local function print_machine(test_name, expected_cycles)
end
end

local function stderr(fmt, ...) io.stderr:write(string.format(fmt, ...)) end
local function fatal(fmt, ...) error(string.format(fmt, ...)) end
local function stderr(fmt, ...)
io.stderr:write(string.format(fmt, ...))
end
local function fatal(fmt, ...)
error(string.format(fmt, ...))
end
local function check_and_print_result(machine, ctx)
local halt_payload = machine:read_htif_tohost_data() >> 1
local expected_halt_payload = ctx.expected_halt_payload or 0
Expand All @@ -667,7 +722,9 @@ end

local function hash(tests)
local out = io.stdout
if output then out = assert(io.open(output, "w"), "error opening file: " .. output) end
if output then
out = assert(io.open(output, "w"), "error opening file: " .. output)
end
for _, test in ipairs(tests) do
local ram_image = test[1]
local expected_cycles = test[2]
Expand Down Expand Up @@ -697,7 +754,9 @@ local function hash(tests)
end
if status == cartesi.UARCH_BREAK_REASON_UARCH_HALTED then
machine:reset_uarch()
if machine:read_iflags_H() then break end
if machine:read_iflags_H() then
break
end
end
end
if machine:read_htif_tohost_data() >> 1 ~= expected_payload or machine:read_mcycle() ~= expected_cycles then
Expand Down Expand Up @@ -725,7 +784,9 @@ end

local function step(tests)
local out = io.stdout
if output then out = assert(io.open(output, "w"), "error opening file: " .. output) end
if output then
out = assert(io.open(output, "w"), "error opening file: " .. output)
end
local indentout = util.indentout
local log_type = { annotations = log_annotations, proofs = log_proofs }
out:write("[\n")
Expand Down Expand Up @@ -764,21 +825,27 @@ local function step(tests)
total_uarch_cycles = total_uarch_cycles + (final_uarch_cycle - init_uarch_cycle)
if machine:read_uarch_halt_flag() then
machine:reset_uarch()
if machine:read_iflags_H() then break end
if machine:read_iflags_H() then
break
end
end
if not periodic_action or total_uarch_cycles == next_action_uarch_cycle then
local init_mcycle = machine:read_mcycle()
init_uarch_cycle = machine:read_uarch_cycle()
local log = machine:log_uarch_step(log_type)
local final_mcycle = machine:read_mcycle()
final_uarch_cycle = machine:read_uarch_cycle()
if total_logged_steps > 0 then out:write(",\n") end
if total_logged_steps > 0 then
out:write(",\n")
end
util.dump_json_log(log, init_mcycle, init_uarch_cycle, final_mcycle, final_uarch_cycle, out, 3)
total_uarch_cycles = total_uarch_cycles + 1
total_logged_steps = total_logged_steps + 1
if machine:read_uarch_halt_flag() then
machine:reset_uarch()
if machine:read_iflags_H() then break end
if machine:read_iflags_H() then
break
end
end
end
end
Expand Down Expand Up @@ -813,7 +880,9 @@ local function list(tests)
local indentout = util.indentout
out:write('{\n "tests": [\n')
for i, test in ipairs(tests) do
if i ~= 1 then out:write(",\n") end
if i ~= 1 then
out:write(",\n")
end
indentout(out, 2, "{\n")
indentout(out, 3, '"file": "' .. test[1] .. '",\n')
indentout(out, 3, '"mcycle": ' .. test[2] .. "\n")
Expand All @@ -829,14 +898,18 @@ end

local function select_test(test_name, patt)
local i, j = test_name:find(patt)
if i == 1 and j == #test_name then return true end
if i == 1 and j == #test_name then
return true
end
i, j = test_name:find(patt, 1, true)
return i == 1 and j == #test_name
end

local selected_tests = {}
for _, test in ipairs(riscv_tests) do
if select_test(test[1], test_pattern) then selected_tests[#selected_tests + 1] = test end
if select_test(test[1], test_pattern) then
selected_tests[#selected_tests + 1] = test
end
end

local function run_host_and_uarch_machines(target, ctx, max_mcycle)
Expand Down Expand Up @@ -877,7 +950,9 @@ local function run_host_and_uarch_machines(target, ctx, max_mcycle)
tostring(uarch_iflags_H)
)
end
if host_iflags_H then break end
if host_iflags_H then
break
end
end
local host_htif_tohost_data = host_machine:read_htif_tohost_data()
local uarch_htif_tohost_data = uarch_machine:read_htif_tohost_data()
Expand Down
8 changes: 6 additions & 2 deletions tests/lua/cartesi/parallel.lua
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,9 @@ local function parallel(list, jobs, fn)
local pid, reason, rc = syswait.wait(any_children)
while pid and pid ~= (opt and 0) do
if reason == "exited" or reason == "killed" then -- ignore 'stopped'
if rc ~= 0 then num_errors = num_errors + 1 end
if rc ~= 0 then
num_errors = num_errors + 1
end
running = running - 1
end
pid, reason, rc = syswait.wait(any_children, syswait[opt])
Expand All @@ -59,7 +61,9 @@ local function parallel(list, jobs, fn)
while true do
while running < jobs do
i, row = iter(list, i)
if not row then goto done end
if not row then
goto done
end
spawn_run_one(row)
running = running + 1
end
Expand Down
Loading

0 comments on commit a8ab50b

Please sign in to comment.