work in progress commit for defaulttenant in restarting tests
This commit is contained in:
parent
9795347aa9
commit
3c7d17e2bb
|
@ -312,12 +312,20 @@ class TestConfig : public BasicTestConfig {
|
||||||
if (attrib == "blobGranulesEnabled") {
|
if (attrib == "blobGranulesEnabled") {
|
||||||
blobGranulesEnabled = strcmp(value.c_str(), "true") == 0;
|
blobGranulesEnabled = strcmp(value.c_str(), "true") == 0;
|
||||||
}
|
}
|
||||||
|
if (attrib == "allowDefaultTenant") {
|
||||||
|
allowDefaultTenant = strcmp(value.c_str(), "true") == 0;
|
||||||
|
}
|
||||||
|
if (attrib == "allowDisablingTenants") {
|
||||||
|
allowDisablingTenants = strcmp(value.c_str(), "true") == 0;
|
||||||
|
}
|
||||||
|
if (attrib == "allowCreatingTenants") {
|
||||||
|
allowCreatingTenants = strcmp(value.c_str(), "true") == 0;
|
||||||
|
}
|
||||||
if (attrib == "injectSSTargetedRestart") {
|
if (attrib == "injectSSTargetedRestart") {
|
||||||
injectTargetedSSRestart = strcmp(value.c_str(), "true") == 0;
|
injectTargetedSSRestart = strcmp(value.c_str(), "true") == 0;
|
||||||
}
|
}
|
||||||
|
if (attrib == "defaultTenant") {
|
||||||
if (attrib == "injectSSDelay") {
|
defaultTenant = value;
|
||||||
injectSSDelay = strcmp(value.c_str(), "true") == 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -369,6 +377,7 @@ public:
|
||||||
bool allowCreatingTenants = true;
|
bool allowCreatingTenants = true;
|
||||||
bool injectTargetedSSRestart = false;
|
bool injectTargetedSSRestart = false;
|
||||||
bool injectSSDelay = false;
|
bool injectSSDelay = false;
|
||||||
|
Optional<std::string> defaultTenant;
|
||||||
std::string testClass; // unused -- used in TestHarness
|
std::string testClass; // unused -- used in TestHarness
|
||||||
float testPriority; // unused -- used in TestHarness
|
float testPriority; // unused -- used in TestHarness
|
||||||
|
|
||||||
|
@ -435,7 +444,8 @@ public:
|
||||||
.add("allowCreatingTenants", &allowCreatingTenants)
|
.add("allowCreatingTenants", &allowCreatingTenants)
|
||||||
.add("randomlyRenameZoneId", &randomlyRenameZoneId)
|
.add("randomlyRenameZoneId", &randomlyRenameZoneId)
|
||||||
.add("injectTargetedSSRestart", &injectTargetedSSRestart)
|
.add("injectTargetedSSRestart", &injectTargetedSSRestart)
|
||||||
.add("injectSSDelay", &injectSSDelay);
|
.add("injectSSDelay", &injectSSDelay)
|
||||||
|
.add("defaultTenant", &defaultTenant);
|
||||||
try {
|
try {
|
||||||
auto file = toml::parse(testFile);
|
auto file = toml::parse(testFile);
|
||||||
if (file.contains("configuration") && toml::find(file, "configuration").is_table()) {
|
if (file.contains("configuration") && toml::find(file, "configuration").is_table()) {
|
||||||
|
@ -1116,18 +1126,18 @@ ACTOR Future<Void> restartSimulatedSystem(std::vector<Future<Void>>* systemActor
|
||||||
int* pTesterCount,
|
int* pTesterCount,
|
||||||
Optional<ClusterConnectionString>* pConnString,
|
Optional<ClusterConnectionString>* pConnString,
|
||||||
Standalone<StringRef>* pStartingConfiguration,
|
Standalone<StringRef>* pStartingConfiguration,
|
||||||
TestConfig testConfig,
|
TestConfig* testConfig,
|
||||||
std::string whitelistBinPaths,
|
std::string whitelistBinPaths,
|
||||||
ProtocolVersion protocolVersion) {
|
ProtocolVersion protocolVersion) {
|
||||||
CSimpleIni ini;
|
CSimpleIni ini;
|
||||||
ini.SetUnicode();
|
ini.SetUnicode();
|
||||||
ini.LoadFile(joinPath(baseFolder, "restartInfo.ini").c_str());
|
ini.LoadFile(joinPath(baseFolder, "restartInfo.ini").c_str());
|
||||||
|
|
||||||
auto configDBType = testConfig.getConfigDBType();
|
auto configDBType = testConfig->getConfigDBType();
|
||||||
|
|
||||||
// Randomly change data center id names to test that localities
|
// Randomly change data center id names to test that localities
|
||||||
// can be modified on cluster restart
|
// can be modified on cluster restart
|
||||||
bool renameZoneIds = testConfig.randomlyRenameZoneId ? deterministicRandom()->random01() < 0.1 : false;
|
bool renameZoneIds = testConfig->randomlyRenameZoneId ? deterministicRandom()->random01() < 0.1 : false;
|
||||||
CODE_PROBE(renameZoneIds, "Zone ID names altered in restart test");
|
CODE_PROBE(renameZoneIds, "Zone ID names altered in restart test");
|
||||||
|
|
||||||
// allows multiple ipAddr entries
|
// allows multiple ipAddr entries
|
||||||
|
@ -1144,26 +1154,30 @@ ACTOR Future<Void> restartSimulatedSystem(std::vector<Future<Void>>* systemActor
|
||||||
int desiredCoordinators = atoi(ini.GetValue("META", "desiredCoordinators"));
|
int desiredCoordinators = atoi(ini.GetValue("META", "desiredCoordinators"));
|
||||||
int testerCount = atoi(ini.GetValue("META", "testerCount"));
|
int testerCount = atoi(ini.GetValue("META", "testerCount"));
|
||||||
auto tssModeStr = ini.GetValue("META", "tssMode");
|
auto tssModeStr = ini.GetValue("META", "tssMode");
|
||||||
|
std::string defaultTenant = ini.GetValue("META", "defaultTenant", "");
|
||||||
|
if (!defaultTenant.empty()) {
|
||||||
|
testConfig->defaultTenant = defaultTenant;
|
||||||
|
}
|
||||||
if (tssModeStr != nullptr) {
|
if (tssModeStr != nullptr) {
|
||||||
g_simulator->tssMode = (ISimulator::TSSMode)atoi(tssModeStr);
|
g_simulator->tssMode = (ISimulator::TSSMode)atoi(tssModeStr);
|
||||||
}
|
}
|
||||||
ClusterConnectionString conn(ini.GetValue("META", "connectionString"));
|
ClusterConnectionString conn(ini.GetValue("META", "connectionString"));
|
||||||
if (testConfig.extraDatabaseMode == ISimulator::ExtraDatabaseMode::Local) {
|
if (testConfig->extraDatabaseMode == ISimulator::ExtraDatabaseMode::Local) {
|
||||||
g_simulator->extraDatabases.clear();
|
g_simulator->extraDatabases.clear();
|
||||||
g_simulator->extraDatabases.push_back(conn.toString());
|
g_simulator->extraDatabases.push_back(conn.toString());
|
||||||
}
|
}
|
||||||
if (!testConfig.disableHostname) {
|
if (!testConfig->disableHostname) {
|
||||||
auto mockDNSStr = ini.GetValue("META", "mockDNS");
|
auto mockDNSStr = ini.GetValue("META", "mockDNS");
|
||||||
if (mockDNSStr != nullptr) {
|
if (mockDNSStr != nullptr) {
|
||||||
INetworkConnections::net()->parseMockDNSFromString(mockDNSStr);
|
INetworkConnections::net()->parseMockDNSFromString(mockDNSStr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
auto& g_knobs = IKnobCollection::getMutableGlobalKnobCollection();
|
auto& g_knobs = IKnobCollection::getMutableGlobalKnobCollection();
|
||||||
if (testConfig.disableRemoteKVS) {
|
if (testConfig->disableRemoteKVS) {
|
||||||
g_knobs.setKnob("remote_kv_store", KnobValueRef::create(bool{ false }));
|
g_knobs.setKnob("remote_kv_store", KnobValueRef::create(bool{ false }));
|
||||||
TraceEvent(SevDebug, "DisableRemoteKVS");
|
TraceEvent(SevDebug, "DisableRemoteKVS");
|
||||||
}
|
}
|
||||||
if (testConfig.disableEncryption) {
|
if (testConfig->disableEncryption) {
|
||||||
g_knobs.setKnob("enable_encryption", KnobValueRef::create(bool{ false }));
|
g_knobs.setKnob("enable_encryption", KnobValueRef::create(bool{ false }));
|
||||||
g_knobs.setKnob("enable_tlog_encryption", KnobValueRef::create(bool{ false }));
|
g_knobs.setKnob("enable_tlog_encryption", KnobValueRef::create(bool{ false }));
|
||||||
g_knobs.setKnob("enable_storage_server_encryption", KnobValueRef::create(bool{ false }));
|
g_knobs.setKnob("enable_storage_server_encryption", KnobValueRef::create(bool{ false }));
|
||||||
|
@ -2457,8 +2471,8 @@ ACTOR void setupAndRun(std::string dataFolder,
|
||||||
|
|
||||||
// Disable the default tenant in restarting tests for now
|
// Disable the default tenant in restarting tests for now
|
||||||
// TODO: persist the chosen default tenant in the restartInfo.ini file for the second test
|
// TODO: persist the chosen default tenant in the restartInfo.ini file for the second test
|
||||||
allowDefaultTenant = false;
|
// allowDefaultTenant = false;
|
||||||
allowCreatingTenants = false;
|
// allowCreatingTenants = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Currently backup and restore related simulation tests are failing when run with rocksDB storage engine
|
// TODO: Currently backup and restore related simulation tests are failing when run with rocksDB storage engine
|
||||||
|
@ -2510,7 +2524,6 @@ ACTOR void setupAndRun(std::string dataFolder,
|
||||||
state TenantMode tenantMode = TenantMode::DISABLED;
|
state TenantMode tenantMode = TenantMode::DISABLED;
|
||||||
if (allowDefaultTenant && deterministicRandom()->random01() < 0.5) {
|
if (allowDefaultTenant && deterministicRandom()->random01() < 0.5) {
|
||||||
defaultTenant = "SimulatedDefaultTenant"_sr;
|
defaultTenant = "SimulatedDefaultTenant"_sr;
|
||||||
tenantsToCreate.push_back_deep(tenantsToCreate.arena(), defaultTenant.get());
|
|
||||||
if (deterministicRandom()->random01() < 0.9) {
|
if (deterministicRandom()->random01() < 0.9) {
|
||||||
tenantMode = TenantMode::REQUIRED;
|
tenantMode = TenantMode::REQUIRED;
|
||||||
} else {
|
} else {
|
||||||
|
@ -2520,19 +2533,6 @@ ACTOR void setupAndRun(std::string dataFolder,
|
||||||
tenantMode = TenantMode::OPTIONAL_TENANT;
|
tenantMode = TenantMode::OPTIONAL_TENANT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (allowCreatingTenants && tenantMode != TenantMode::DISABLED && deterministicRandom()->random01() < 0.5) {
|
|
||||||
int numTenants = deterministicRandom()->randomInt(1, 6);
|
|
||||||
for (int i = 0; i < numTenants; ++i) {
|
|
||||||
tenantsToCreate.push_back_deep(tenantsToCreate.arena(),
|
|
||||||
TenantNameRef(format("SimulatedExtraTenant%04d", i)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
TraceEvent("SimulatedClusterTenantMode")
|
|
||||||
.detail("UsingTenant", defaultTenant)
|
|
||||||
.detail("TenantRequired", tenantMode.toString())
|
|
||||||
.detail("TotalTenants", tenantsToCreate.size());
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// systemActors.push_back( startSystemMonitor(dataFolder) );
|
// systemActors.push_back( startSystemMonitor(dataFolder) );
|
||||||
if (rebooting) {
|
if (rebooting) {
|
||||||
|
@ -2541,7 +2541,7 @@ ACTOR void setupAndRun(std::string dataFolder,
|
||||||
&testerCount,
|
&testerCount,
|
||||||
&connectionString,
|
&connectionString,
|
||||||
&startingConfiguration,
|
&startingConfiguration,
|
||||||
testConfig,
|
&testConfig,
|
||||||
whitelistBinPaths,
|
whitelistBinPaths,
|
||||||
protocolVersion),
|
protocolVersion),
|
||||||
100.0));
|
100.0));
|
||||||
|
@ -2562,6 +2562,25 @@ ACTOR void setupAndRun(std::string dataFolder,
|
||||||
tenantMode);
|
tenantMode);
|
||||||
wait(delay(1.0)); // FIXME: WHY!!! //wait for machines to boot
|
wait(delay(1.0)); // FIXME: WHY!!! //wait for machines to boot
|
||||||
}
|
}
|
||||||
|
if (testConfig.defaultTenant.present() && tenantMode != TenantMode::DISABLED && allowDefaultTenant) {
|
||||||
|
// Default tenant set by testConfig or restarting data in restartInfo.ini
|
||||||
|
defaultTenant = testConfig.defaultTenant.get();
|
||||||
|
tenantsToCreate.push_back_deep(tenantsToCreate.arena(), defaultTenant.get());
|
||||||
|
} else if (defaultTenant.present()) {
|
||||||
|
// Default tenant set randomly from above
|
||||||
|
tenantsToCreate.push_back_deep(tenantsToCreate.arena(), defaultTenant.get());
|
||||||
|
}
|
||||||
|
if (allowCreatingTenants && tenantMode != TenantMode::DISABLED && deterministicRandom()->random01() < 0.5) {
|
||||||
|
int numTenants = deterministicRandom()->randomInt(1, 6);
|
||||||
|
for (int i = 0; i < numTenants; ++i) {
|
||||||
|
tenantsToCreate.push_back_deep(tenantsToCreate.arena(),
|
||||||
|
TenantNameRef(format("SimulatedExtraTenant%04d", i)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
TraceEvent("SimulatedClusterTenantMode")
|
||||||
|
.detail("UsingTenant", defaultTenant)
|
||||||
|
.detail("TenantRequired", tenantMode.toString())
|
||||||
|
.detail("TotalTenants", tenantsToCreate.size());
|
||||||
std::string clusterFileDir = joinPath(dataFolder, deterministicRandom()->randomUniqueID().toString());
|
std::string clusterFileDir = joinPath(dataFolder, deterministicRandom()->randomUniqueID().toString());
|
||||||
platform::createDirectory(clusterFileDir);
|
platform::createDirectory(clusterFileDir);
|
||||||
writeFile(joinPath(clusterFileDir, "fdb.cluster"), connectionString.get().toString());
|
writeFile(joinPath(clusterFileDir, "fdb.cluster"), connectionString.get().toString());
|
||||||
|
|
|
@ -1272,7 +1272,9 @@ std::map<std::string, std::function<void(const std::string&)>> testSpecGlobalKey
|
||||||
{ "disableRemoteKVS",
|
{ "disableRemoteKVS",
|
||||||
[](const std::string& value) { TraceEvent("TestParserTest").detail("ParsedRemoteKVS", ""); } },
|
[](const std::string& value) { TraceEvent("TestParserTest").detail("ParsedRemoteKVS", ""); } },
|
||||||
{ "disableEncryption",
|
{ "disableEncryption",
|
||||||
[](const std::string& value) { TraceEvent("TestParserTest").detail("ParsedRemoteKVS", ""); } }
|
[](const std::string& value) { TraceEvent("TestParserTest").detail("ParsedEncryption", ""); } },
|
||||||
|
{ "allowDefaultTenant",
|
||||||
|
[](const std::string& value) { TraceEvent("TestParserTest").detail("ParsedDefaultTenant", ""); } }
|
||||||
};
|
};
|
||||||
|
|
||||||
std::map<std::string, std::function<void(const std::string& value, TestSpec* spec)>> testSpecTestKeys = {
|
std::map<std::string, std::function<void(const std::string& value, TestSpec* spec)>> testSpecTestKeys = {
|
||||||
|
|
|
@ -50,9 +50,9 @@ struct SaveAndKillWorkload : TestWorkload {
|
||||||
g_simulator->disableSwapsToAll();
|
g_simulator->disableSwapsToAll();
|
||||||
return Void();
|
return Void();
|
||||||
}
|
}
|
||||||
Future<Void> start(Database const& cx) override { return _start(this); }
|
Future<Void> start(Database const& cx) override { return _start(this, cx); }
|
||||||
|
|
||||||
ACTOR Future<Void> _start(SaveAndKillWorkload* self) {
|
ACTOR Future<Void> _start(SaveAndKillWorkload* self, Database cx) {
|
||||||
state int i;
|
state int i;
|
||||||
wait(delay(deterministicRandom()->random01() * self->testDuration));
|
wait(delay(deterministicRandom()->random01() * self->testDuration));
|
||||||
|
|
||||||
|
@ -68,6 +68,9 @@ struct SaveAndKillWorkload : TestWorkload {
|
||||||
ini.SetValue("META", "testerCount", format("%d", g_simulator->testerCount).c_str());
|
ini.SetValue("META", "testerCount", format("%d", g_simulator->testerCount).c_str());
|
||||||
ini.SetValue("META", "tssMode", format("%d", g_simulator->tssMode).c_str());
|
ini.SetValue("META", "tssMode", format("%d", g_simulator->tssMode).c_str());
|
||||||
ini.SetValue("META", "mockDNS", INetworkConnections::net()->convertMockDNSToString().c_str());
|
ini.SetValue("META", "mockDNS", INetworkConnections::net()->convertMockDNSToString().c_str());
|
||||||
|
if (cx->defaultTenant.present()) {
|
||||||
|
ini.SetValue("META", "defaultTenant", cx->defaultTenant.get().toString().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
ini.SetBoolValue("META", "enableEncryption", SERVER_KNOBS->ENABLE_ENCRYPTION);
|
ini.SetBoolValue("META", "enableEncryption", SERVER_KNOBS->ENABLE_ENCRYPTION);
|
||||||
ini.SetBoolValue("META", "enableTLogEncryption", SERVER_KNOBS->ENABLE_TLOG_ENCRYPTION);
|
ini.SetBoolValue("META", "enableTLogEncryption", SERVER_KNOBS->ENABLE_TLOG_ENCRYPTION);
|
||||||
|
|
Loading…
Reference in New Issue