Skip to content

Commit

Permalink
config: move role start and stop to _post_apply()
Browse files Browse the repository at this point in the history
Roles are now started and stopped at the "post_apply" stage rather than
at the "apply" stage. This allows require('config'):get() to correctly
return the configuration that is being applied.

Closes tarantool#9649

NO_DOC=bugfix
  • Loading branch information
ImeevMA committed Feb 5, 2024
1 parent 64afe49 commit 4356ac3
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 4 deletions.
4 changes: 4 additions & 0 deletions changelogs/unreleased/gh-9649-config-get-in-roles.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
## bugfix/config

* Now `require('config'):get()` returns the configuration that is currently
applied (gh-9649).
13 changes: 9 additions & 4 deletions src/box/lua/config/applier/roles.lua
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,10 @@ local log = require('internal.config.utils.log')
local last_loaded = {}
local last_roles_ordered = {}

local function apply(_config)
log.verbose('roles.apply: do nothing')
end

local function stop_roles(roles_to_skip)
local roles_to_stop = {}
for id = #last_roles_ordered, 1, -1 do
Expand Down Expand Up @@ -44,7 +48,7 @@ local function stop_roles(roles_to_skip)
end
end
for _, role_name in ipairs(roles_to_stop) do
log.verbose('roles.apply: stop role ' .. role_name)
log.verbose('roles.post_apply: stop role ' .. role_name)
local ok, err = pcall(last_loaded[role_name].stop)
if not ok then
error(('Error stopping role %s: %s'):format(role_name, err), 0)
Expand Down Expand Up @@ -106,7 +110,7 @@ local function resort_roles(original_order, roles)
return ordered
end

local function apply(config)
local function post_apply(config)
local configdata = config._configdata
local role_names = configdata:get('roles', {use_default = true})
if role_names == nil or next(role_names) == nil then
Expand All @@ -132,7 +136,7 @@ local function apply(config)
for _, role_name in ipairs(roles_ordered) do
local role = last_loaded[role_name]
if not role then
log.verbose('roles.apply: load role ' .. role_name)
log.verbose('roles.post_apply: load role ' .. role_name)
role = require(role_name)
local funcs = {'validate', 'apply', 'stop'}
for _, func_name in pairs(funcs) do
Expand Down Expand Up @@ -164,7 +168,7 @@ local function apply(config)

-- Apply configs for all roles.
for _, role_name in ipairs(roles_ordered) do
log.verbose('roles.apply: apply config for role ' .. role_name)
log.verbose('roles.post_apply: apply config for role ' .. role_name)
local ok, err = pcall(loaded[role_name].apply, roles_cfg[role_name])
if not ok then
error(('Error applying role %s: %s'):format(role_name, err), 0)
Expand All @@ -178,4 +182,5 @@ end
return {
name = 'roles',
apply = apply,
post_apply = post_apply,
}
30 changes: 30 additions & 0 deletions test/config-luatest/roles_test.lua
Original file line number Diff line number Diff line change
Expand Up @@ -572,3 +572,33 @@ g.test_role_dependencies_stop_required_role = function(g)
'"one", "two" depend on it'
})
end

-- Make sure that role was started after config was fully loaded.
g.test_role_applid_after_loading = function(g)
local one = [[
local function apply(cfg)
local config = require('config')
_G.foo = config:info().status
_G.bar = config:get('roles')
end
_G.foo = nil
_G.bar = nil
return {
validate = function() end,
apply = apply,
stop = function() end,
}
]]
local verify = function()
t.assert_equals(_G.foo, 'ready')
t.assert_equals(_G.bar, {'one'})
end

helpers.success_case(g, {
roles = {one = one},
options = {roles = {'one'}},
verify = verify,
})
end

0 comments on commit 4356ac3

Please sign in to comment.