⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 alltests.cpp

📁 ICE-3.2 一个开源的中间件
💻 CPP
📖 第 1 页 / 共 2 页
字号:
        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server3";        instantiateServer(admin, "Server", "localnode", params);        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Random"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(0));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        set<string> replicaIds = serverReplicaIds;        while(!replicaIds.empty())        {            try            {                replicaIds.erase(obj->getReplicaId());            }            catch(const Ice::LocalException& ex)            {                cerr << ex << endl;                test(false);            }        }        removeServer(admin, "Server1");        removeServer(admin, "Server2");        removeServer(admin, "Server3");    }    {        map<string, string> params;        params["replicaGroup"] = "Random";        params["id"] = "IceBox1";        instantiateServer(admin, "IceBox", "localnode", params);        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Random"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(0));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        set<string> replicaIds = svcReplicaIds;        while(!replicaIds.empty())        {            try            {                replicaIds.erase(obj->getReplicaId());            }            catch(const Ice::ConnectionRefusedException&)            {            }            catch(const Ice::LocalException& ex)            {                cerr << ex << endl;                test(false);            }        }        removeServer(admin, "IceBox1");    }    cout << "ok" << endl;    cout << "testing replication with adaptive load balancing... " << flush;    {        map<string, string> params;        params["replicaGroup"] = "Adaptive";        params["id"] = "Server1";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server3";        instantiateServer(admin, "Server", "localnode", params);        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Adaptive"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(0));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        set<string> replicaIds = serverReplicaIds;        while(!replicaIds.empty())        {            try            {                replicaIds.erase(obj->getReplicaId());            }            catch(const Ice::LocalException& ex)            {                cerr << ex << endl;                test(false);            }        }        removeServer(admin, "Server1");        removeServer(admin, "Server2");        removeServer(admin, "Server3");    }    {        map<string, string> params;        params["replicaGroup"] = "Adaptive";        params["id"] = "IceBox1";        instantiateServer(admin, "IceBox", "localnode", params);        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Adaptive"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(0));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        set<string> replicaIds = svcReplicaIds;        while(!replicaIds.empty())        {            try            {                replicaIds.erase(obj->getReplicaId());            }            catch(const Ice::ConnectionRefusedException&)            {            }            catch(const Ice::LocalException& ex)            {                cerr << ex << endl;                test(false);            }        }        removeServer(admin, "IceBox1");    }    cout << "ok" << endl;    cout << "testing load balancing n-replicas..." << flush;    {        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("RoundRobin-2"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(-1));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        try        {            obj->ice_ping();            test(false);        }        catch(const Ice::NoEndpointException&)        {        }        map<string, string> params;        params["replicaGroup"] = "RoundRobin-2";        params["id"] = "Server1";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server3";        instantiateServer(admin, "Server", "localnode", params);        try        {            set<string> replicaIds;            set<string> expected;            replicaIds.insert("Server1.ReplicatedAdapter");            replicaIds.insert("Server2.ReplicatedAdapter");            expected = replicaIds;            while(!replicaIds.empty())            {                string replicaId = obj->getReplicaId();                test(expected.find(replicaId) != expected.end());                replicaIds.erase(replicaId);            }            obj->ice_locatorCacheTimeout(0)->ice_ping();            replicaIds.insert("Server2.ReplicatedAdapter");            replicaIds.insert("Server3.ReplicatedAdapter");            expected = replicaIds;            while(!replicaIds.empty())            {                string replicaId = obj->getReplicaId();                test(expected.find(replicaId) != expected.end());                replicaIds.erase(replicaId);            }            obj->ice_locatorCacheTimeout(0)->ice_ping();            replicaIds.insert("Server3.ReplicatedAdapter");            replicaIds.insert("Server1.ReplicatedAdapter");            expected = replicaIds;            while(!replicaIds.empty())            {                string replicaId = obj->getReplicaId();                test(expected.find(replicaId) != expected.end());                replicaIds.erase(replicaId);            }        }        catch(const Ice::LocalException& ex)        {            cerr << ex << endl;            test(false);        }        removeServer(admin, "Server1");        removeServer(admin, "Server2");        removeServer(admin, "Server3");    }    {        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("RoundRobin-All"));        obj = TestIntfPrx::uncheckedCast(obj->ice_locatorCacheTimeout(-1));        obj = TestIntfPrx::uncheckedCast(obj->ice_connectionCached(false));        try        {            obj->ice_ping();            test(false);        }        catch(const Ice::NoEndpointException&)        {        }        map<string, string> params;        params["replicaGroup"] = "RoundRobin-All";        params["id"] = "Server1";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        params["id"] = "Server3";        instantiateServer(admin, "Server", "localnode", params);        try        {            set<string> replicaIds;            set<string> expected;            replicaIds.insert("Server1.ReplicatedAdapter");            replicaIds.insert("Server2.ReplicatedAdapter");            replicaIds.insert("Server3.ReplicatedAdapter");            expected = replicaIds;            while(!replicaIds.empty())            {                string replicaId = obj->getReplicaId();                test(expected.find(replicaId) != expected.end());                replicaIds.erase(replicaId);            }            obj->ice_locatorCacheTimeout(0)->ice_ping();            replicaIds.insert("Server1.ReplicatedAdapter");            replicaIds.insert("Server2.ReplicatedAdapter");            replicaIds.insert("Server3.ReplicatedAdapter");            expected = replicaIds;            while(!replicaIds.empty())            {                string replicaId = obj->getReplicaId();                test(expected.find(replicaId) != expected.end());                replicaIds.erase(replicaId);            }        }        catch(const Ice::LocalException& ex)        {            cerr << ex << endl;            test(false);        }        removeServer(admin, "Server1");        removeServer(admin, "Server2");        removeServer(admin, "Server3");    }    cout << "ok" << endl;    cout << "testing replication with inactive nodes... " << flush;    {        map<string, string> params;        params["replicaGroup"] = "Random";        params["id"] = "Server1";        instantiateServer(admin, "Server", "inactivenode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        TestIntfPrx obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Random"));        test(obj->getReplicaId() == "Server2.ReplicatedAdapter");        //        // Also make sure that findObjectByTypeOnLeastLoadedNode still work.        //        QueryPrx query = IceGrid::QueryPrx::checkedCast(comm->stringToProxy("IceGrid/Query"));        obj = TestIntfPrx::uncheckedCast(query->findObjectByTypeOnLeastLoadedNode("::Test::TestIntf", LoadSample1));        test(obj->getReplicaId() == "Server2.ReplicatedAdapter");                removeServer(admin, "Server1");        removeServer(admin, "Server2");        params["replicaGroup"] = "RoundRobin";        params["id"] = "Server1";        instantiateServer(admin, "Server", "inactivenode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("RoundRobin"));        test(obj->getReplicaId() == "Server2.ReplicatedAdapter");        removeServer(admin, "Server1");        removeServer(admin, "Server2");        params["replicaGroup"] = "Adaptive";        params["id"] = "Server1";        instantiateServer(admin, "Server", "inactivenode", params);        params["id"] = "Server2";        instantiateServer(admin, "Server", "localnode", params);        obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Adaptive"));        test(obj->getReplicaId() == "Server2.ReplicatedAdapter");        removeServer(admin, "Server1");        removeServer(admin, "Server2");        params["replicaGroup"] = "Random";        params["id"] = "IceBox1";        instantiateServer(admin, "IceBox", "localnode", params);        params["id"] = "Server1";        instantiateServer(admin, "Server", "inactivenode", params);        obj = TestIntfPrx::uncheckedCast(comm->stringToProxy("Random"));        test(svcReplicaIds.find(obj->getReplicaId()) != svcReplicaIds.end());        removeServer(admin, "IceBox1");        removeServer(admin, "Server1");    };    cout << "ok" << endl;    keepAlive->destroy();    keepAlive->getThreadControl().join();    keepAlive = 0;    session->destroy();}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -