Skip to content

Commit

Permalink
tests(helpers): separate grpc functions
Browse files Browse the repository at this point in the history
  • Loading branch information
chronolaw committed Aug 22, 2024
1 parent 5f68365 commit eafe6a0
Show file tree
Hide file tree
Showing 2 changed files with 94 additions and 74 deletions.
90 changes: 90 additions & 0 deletions spec/details/grpc.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
local pl_path = require("pl.path")
local shell = require("resty.shell")
local resty_signal = require("resty.signal")


local CONSTANTS = require("spec.details.constants")


local function isnewer(path_a, path_b)
if not pl_path.exists(path_a) then
return true
end
if not pl_path.exists(path_b) then
return false
end
return assert(pl_path.getmtime(path_b)) > assert(pl_path.getmtime(path_a))
end


local function make(workdir, specs)
workdir = pl_path.normpath(workdir or pl_path.currentdir())

for _, spec in ipairs(specs) do
local targetpath = pl_path.join(workdir, spec.target)
for _, src in ipairs(spec.src) do
local srcpath = pl_path.join(workdir, src)
if isnewer(targetpath, srcpath) then
local ok, _, stderr = shell.run(string.format("cd %s; %s", workdir, spec.cmd), nil, 0)
assert(ok, stderr)
if isnewer(targetpath, srcpath) then
error(string.format("couldn't make %q newer than %q", targetpath, srcpath))
end
break
end
end
end

return true
end


local grpc_target_proc


local function start_grpc_target()
local ngx_pipe = require("ngx.pipe")
assert(make(CONSTANTS.GRPC_TARGET_SRC_PATH, {
{
target = "targetservice/targetservice.pb.go",
src = { "../targetservice.proto" },
cmd = "protoc --go_out=. --go-grpc_out=. -I ../ ../targetservice.proto",
},
{
target = "targetservice/targetservice_grpc.pb.go",
src = { "../targetservice.proto" },
cmd = "protoc --go_out=. --go-grpc_out=. -I ../ ../targetservice.proto",
},
{
target = "target",
src = { "grpc-target.go", "targetservice/targetservice.pb.go", "targetservice/targetservice_grpc.pb.go" },
cmd = "go mod tidy && go mod download all && go build",
},
}))
grpc_target_proc = assert(ngx_pipe.spawn({ CONSTANTS.GRPC_TARGET_SRC_PATH .. "/target" }, {
merge_stderr = true,
}))

return true
end


local function stop_grpc_target()
if grpc_target_proc then
grpc_target_proc:kill(resty_signal.signum("QUIT"))
grpc_target_proc = nil
end
end


local function get_grpc_target_port()
return 15010
end


return {
start_grpc_target = start_grpc_target,
stop_grpc_target = stop_grpc_target,
get_grpc_target_port = get_grpc_target_port,
}

78 changes: 4 additions & 74 deletions spec/helpers.lua
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
-- @module spec.helpers

local CONSTANTS = require("spec.details.constants")
local grpc = require("spec.details.grpc")

local PLUGINS_LIST

Expand Down Expand Up @@ -42,7 +43,6 @@ local ws_client = require "resty.websocket.client"
local table_clone = require "table.clone"
local https_server = require "spec.fixtures.https_server"
local stress_generator = require "spec.fixtures.stress_generator"
local resty_signal = require "resty.signal"
local lfs = require "lfs"
local luassert = require "luassert.assert"
local uuid = require("kong.tools.uuid").uuid
Expand Down Expand Up @@ -3627,76 +3627,6 @@ local function build_go_plugins(path)
end
end

local function isnewer(path_a, path_b)
if not pl_path.exists(path_a) then
return true
end
if not pl_path.exists(path_b) then
return false
end
return assert(pl_path.getmtime(path_b)) > assert(pl_path.getmtime(path_a))
end

local function make(workdir, specs)
workdir = pl_path.normpath(workdir or pl_path.currentdir())

for _, spec in ipairs(specs) do
local targetpath = pl_path.join(workdir, spec.target)
for _, src in ipairs(spec.src) do
local srcpath = pl_path.join(workdir, src)
if isnewer(targetpath, srcpath) then
local ok, _, stderr = shell.run(string.format("cd %s; %s", workdir, spec.cmd), nil, 0)
assert(ok, stderr)
if isnewer(targetpath, srcpath) then
error(string.format("couldn't make %q newer than %q", targetpath, srcpath))
end
break
end
end
end

return true
end

local grpc_target_proc
local function start_grpc_target()
local ngx_pipe = require "ngx.pipe"
assert(make(CONSTANTS.GRPC_TARGET_SRC_PATH, {
{
target = "targetservice/targetservice.pb.go",
src = { "../targetservice.proto" },
cmd = "protoc --go_out=. --go-grpc_out=. -I ../ ../targetservice.proto",
},
{
target = "targetservice/targetservice_grpc.pb.go",
src = { "../targetservice.proto" },
cmd = "protoc --go_out=. --go-grpc_out=. -I ../ ../targetservice.proto",
},
{
target = "target",
src = { "grpc-target.go", "targetservice/targetservice.pb.go", "targetservice/targetservice_grpc.pb.go" },
cmd = "go mod tidy && go mod download all && go build",
},
}))
grpc_target_proc = assert(ngx_pipe.spawn({ CONSTANTS.GRPC_TARGET_SRC_PATH .. "/target" }, {
merge_stderr = true,
}))

return true
end

local function stop_grpc_target()
if grpc_target_proc then
grpc_target_proc:kill(resty_signal.signum("QUIT"))
grpc_target_proc = nil
end
end

local function get_grpc_target_port()
return 15010
end


--- Start the Kong instance to test against.
-- The fixtures passed to this function can be 3 types:
--
Expand Down Expand Up @@ -4394,9 +4324,9 @@ end
get_kong_workers = get_kong_workers,
wait_until_no_common_workers = wait_until_no_common_workers,

start_grpc_target = start_grpc_target,
stop_grpc_target = stop_grpc_target,
get_grpc_target_port = get_grpc_target_port,
start_grpc_target = grpc.start_grpc_target,
stop_grpc_target = grpc.stop_grpc_target,
get_grpc_target_port = grpc.get_grpc_target_port,
generate_keys = generate_keys,

-- plugin compatibility test
Expand Down

0 comments on commit eafe6a0

Please sign in to comment.