2018-01-10 19:18:03 +08:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2018-01-24 19:16:14 +08:00
|
|
|
#include "communication/rpc/server.hpp"
|
2018-01-10 19:18:03 +08:00
|
|
|
#include "database/counters.hpp"
|
|
|
|
|
|
|
|
const std::string kLocal = "127.0.0.1";
|
|
|
|
|
|
|
|
TEST(CountersDistributed, All) {
|
2018-02-23 17:56:56 +08:00
|
|
|
communication::rpc::Server master_server({kLocal, 0});
|
|
|
|
database::MasterCounters master(master_server);
|
2018-02-28 23:02:45 +08:00
|
|
|
communication::rpc::ClientPool master_client_pool(master_server.endpoint());
|
2018-01-10 19:18:03 +08:00
|
|
|
|
2018-02-28 23:02:45 +08:00
|
|
|
database::WorkerCounters w1(master_client_pool);
|
|
|
|
database::WorkerCounters w2(master_client_pool);
|
2018-01-10 19:18:03 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(w1.Get("a"), 0);
|
|
|
|
EXPECT_EQ(w1.Get("a"), 1);
|
|
|
|
EXPECT_EQ(w2.Get("a"), 2);
|
|
|
|
EXPECT_EQ(w1.Get("a"), 3);
|
|
|
|
EXPECT_EQ(master.Get("a"), 4);
|
|
|
|
|
|
|
|
EXPECT_EQ(master.Get("b"), 0);
|
|
|
|
EXPECT_EQ(w2.Get("b"), 1);
|
|
|
|
w1.Set("b", 42);
|
|
|
|
EXPECT_EQ(w2.Get("b"), 42);
|
|
|
|
}
|