/** * Copyright (C) 2015 MongoDB Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * As a special exception, the copyright holders give permission to link the * code of portions of this program with the OpenSSL library under certain * conditions as described in each individual source file and distribute * linked combinations including the program with the OpenSSL library. You * must comply with the GNU Affero General Public License in all respects for * all of the code used other than as permitted herein. If you modify file(s) * with this exception, you may extend this exception to your version of the * file(s), but you are not obligated to do so. If you do not wish to do so, * delete this exception statement from your version. If you delete this * exception statement from all source files in the program, then also delete * it in the license file. */ #include "mongo/platform/basic.h" #include "mongo/client/read_preference.h" #include "mongo/db/jsobj.h" #include "mongo/unittest/unittest.h" namespace { using namespace mongo; void checkParse(const BSONObj& rpsObj, const ReadPreferenceSetting& expected) { const auto swRps = ReadPreferenceSetting::fromBSON(rpsObj); ASSERT_OK(swRps.getStatus()); const auto rps = swRps.getValue(); ASSERT_TRUE(rps.equals(expected)); } TEST(ReadPreferenceSetting, ParseValid) { checkParse(BSON("mode" << "primary"), ReadPreferenceSetting(ReadPreference::PrimaryOnly, TagSet::primaryOnly())); // Check that primary with wildcard tags is accepted for backwards compatibility, but // that the tags are parsed as the empty TagSet. checkParse(BSON("mode" << "primary" << "tags" << BSON_ARRAY(BSONObj())), ReadPreferenceSetting(ReadPreference::PrimaryOnly, TagSet::primaryOnly())); checkParse(BSON("mode" << "secondaryPreferred" << "tags" << BSON_ARRAY(BSON("dc" << "ny"))), ReadPreferenceSetting(ReadPreference::SecondaryPreferred, TagSet(BSON_ARRAY(BSON("dc" << "ny"))))); } void checkParseFails(const BSONObj& rpsObj) { auto swRps = ReadPreferenceSetting::fromBSON(rpsObj); ASSERT_NOT_OK(swRps.getStatus()); } TEST(ReadPreferenceSetting, ParseInvalid) { // mode primary can not have tags checkParseFails(BSON("mode" << "primary" << "tags" << BSON_ARRAY(BSON("foo" << "bar")))); // bad mode checkParseFails(BSON("mode" << "khalesi")); // no mode checkParseFails(BSON("foo" << "bar")); // tags not an array checkParseFails(BSON("mode" << "nearest" << "tags" << "bad")); } void checkRoundtrip(const ReadPreferenceSetting& rps) { auto parsed = ReadPreferenceSetting::fromBSON(rps.toBSON()); ASSERT_OK(parsed.getStatus()); ASSERT_TRUE(parsed.getValue().equals(rps)); } TEST(ReadPreferenceSetting, Roundtrip) { checkRoundtrip(ReadPreferenceSetting(ReadPreference::Nearest, TagSet(BSON_ARRAY(BSON("dc" << "ca") << BSON("foo" << "bar"))))); checkRoundtrip(ReadPreferenceSetting(ReadPreference::PrimaryOnly)); checkRoundtrip(ReadPreferenceSetting(ReadPreference::PrimaryPreferred, TagSet())); checkRoundtrip(ReadPreferenceSetting(ReadPreference::SecondaryOnly, TagSet(BSON_ARRAY(BSON("dc" << "ca" << "rack" << "bar"))))); } } // namespace