diff --git a/src/box/box.cc b/src/box/box.cc index ac10c21ad5979dc08bd99da30d42bfbb69d03ebb..cf6d96e58d22aff882350007d69f4e7d1940b66c 100644 --- a/src/box/box.cc +++ b/src/box/box.cc @@ -1734,6 +1734,10 @@ engine_init() static void bootstrap_master(const struct tt_uuid *replicaset_uuid) { + /* Do not allow to bootstrap a readonly instance as master. */ + if (cfg_geti("read_only") == 1) { + tnt_raise(ClientError, ER_BOOTSTRAP_READONLY); + } engine_bootstrap_xc(); uint32_t replica_id = 1; diff --git a/src/box/errcode.h b/src/box/errcode.h index 0c1310bdf5e99fed630a27bc18d439e384484186..dcb90f6789a103fd097c015d1ea7eec264d826c5 100644 --- a/src/box/errcode.h +++ b/src/box/errcode.h @@ -255,6 +255,7 @@ struct errcode_record { /*200 */_(ER_FUNC_INDEX_PARTS, "Wrong functional index definition: %s") \ /*201 */_(ER_NO_SUCH_FIELD_NAME, "Field '%s' was not found in the tuple") \ /*202 */_(ER_FUNC_WRONG_ARG_COUNT, "Wrong number of arguments is passed to %s(): expected %s, got %d") \ + /*203 */_(ER_BOOTSTRAP_READONLY, "Trying to bootstrap a local read-only instance as master") \ /* * !IMPORTANT! Please follow instructions at start of the file diff --git a/test/app-tap/cfg.test.lua b/test/app-tap/cfg.test.lua index 7d8e9a05e39a91d51f546eff7efc4240a4ba4d3b..a2cbed8ddedf8dcfaae039ca141d81db16fb7393 100755 --- a/test/app-tap/cfg.test.lua +++ b/test/app-tap/cfg.test.lua @@ -3,7 +3,7 @@ local fiber = require('fiber') local tap = require('tap') local test = tap.test("cfg") -test:plan(8) +test:plan(9) test:is(type(box.ctl), "table", "box.ctl is available before box.cfg") test:is(type(box.ctl.wait_ro), "function", "box.ctl.wait_ro is available") @@ -15,17 +15,19 @@ local f_rw = fiber.create(function() box.ctl.wait_rw() end) test:is(f_ro:status(), "suspended", "initially the server is neither read only nor read-write") test:is(f_rw:status(), "suspended", "initially the server is neither read only nor read-write") -box.cfg{read_only=true} +box.cfg{} while f_ro:status() ~= "dead" do fiber.sleep(0.01) end -test:is(f_ro:status(), "dead", "entered read-only mode") - -test:is(f_rw:status(), "suspended", "the read-write waiter is still blocked") +test:is(f_ro:status(), "dead", "initialized read-write mode. read-only waiter dies.") +while f_rw:status() ~= "dead" do fiber.sleep(0.01) end +test:is(f_rw:status(), "dead", "initialized read-write mode. read-write waiter dies.") +f_ro = fiber.create(function() box.ctl.wait_ro() end) +test:is(f_ro:status(), "suspended", "new read-only waiter is blocked") -box.cfg{read_only=false} +box.cfg{read_only=true} -while f_rw:status() ~= "dead" do fiber.sleep(0.01) end -test:is(f_rw:status(), "dead", "initialized read-write mode") +while f_ro:status() ~= "dead" do fiber.sleep(0.01) end +test:is(f_ro:status(), "dead", "entered read-only mode") test:check() os.exit(0) diff --git a/test/box-tap/cfg.test.lua b/test/box-tap/cfg.test.lua index 55de5e41c00e2104471cd2d626b77b1272074bd8..8faedaec602c89f3d95375c6fc4966fdc8296255 100755 --- a/test/box-tap/cfg.test.lua +++ b/test/box-tap/cfg.test.lua @@ -6,7 +6,7 @@ local socket = require('socket') local fio = require('fio') local uuid = require('uuid') local msgpack = require('msgpack') -test:plan(104) +test:plan(105) -------------------------------------------------------------------------------- -- Invalid values @@ -585,5 +585,14 @@ test:is(run_script(code1), 0, "create huge tuple") test:is(run_script(code2), PANIC, "panic on huge tuple recovery") fio.rmtree(dir) +-- +-- gh-4321 don't bootstrap a readonly instance as master +-- +code=[[ +box.cfg{read_only=true} +]] +test:is(run_script(code), PANIC, "panic on bootstrapping a read-only instance as master") + + test:check() os.exit(0) diff --git a/test/box/misc.result b/test/box/misc.result index c46c5a9d6aff05ec264b5dacea0734efd6b7e34d..c0e031642da1964d581567ff6541891e90d47829 100644 --- a/test/box/misc.result +++ b/test/box/misc.result @@ -532,6 +532,7 @@ t; 200: box.error.FUNC_INDEX_PARTS 201: box.error.NO_SUCH_FIELD_NAME 202: box.error.FUNC_WRONG_ARG_COUNT + 203: box.error.BOOTSTRAP_READONLY ... test_run:cmd("setopt delimiter ''"); ---