|
14 | 14 |
|
15 | 15 | using namespace cb::throttle; |
16 | 16 |
|
17 | | -TEST(ThrottleLimitPayload, AllDefault) { |
| 17 | +TEST(SetThrottleLimitPayload, AllDefault) { |
18 | 18 | SetThrottleLimitPayload limits = nlohmann::json::parse("{}"); |
19 | 19 | EXPECT_EQ(std::numeric_limits<std::size_t>::max(), limits.reserved); |
20 | 20 | EXPECT_EQ(std::numeric_limits<std::size_t>::max(), limits.hard_limit); |
21 | 21 | } |
22 | 22 |
|
23 | | -TEST(ThrottleLimitPayload, NumericValues) { |
| 23 | +TEST(SetThrottleLimitPayload, NumericValues) { |
24 | 24 | SetThrottleLimitPayload limits = |
25 | 25 | nlohmann::json::parse(R"({"reserved": 1, "hard_limit": 2})"); |
26 | 26 | EXPECT_EQ(1, limits.reserved); |
27 | 27 | EXPECT_EQ(2, limits.hard_limit); |
28 | 28 | } |
29 | 29 |
|
30 | | -TEST(ThrottleLimitPayload, StringValues) { |
| 30 | +TEST(SetThrottleLimitPayload, StringValues) { |
31 | 31 | SetThrottleLimitPayload limits = nlohmann::json::parse( |
32 | 32 | R"({"reserved": 1, "hard_limit": "unlimited"})"); |
33 | 33 | EXPECT_EQ(1, limits.reserved); |
34 | 34 | EXPECT_EQ(std::numeric_limits<std::size_t>::max(), limits.hard_limit); |
35 | 35 | } |
36 | 36 |
|
37 | | -TEST(ThrottleLimitPayload, ToJson) { |
| 37 | +TEST(SetThrottleLimitPayload, ToJson) { |
38 | 38 | nlohmann::json json = SetThrottleLimitPayload(); |
39 | 39 | EXPECT_EQ(R"({"hard_limit":"unlimited","reserved":"unlimited"})", |
40 | 40 | json.dump()); |
41 | 41 | json = SetThrottleLimitPayload(1, 2); |
42 | 42 | EXPECT_EQ(R"({"hard_limit":2,"reserved":1})", json.dump()); |
43 | 43 | } |
| 44 | + |
| 45 | +TEST(SetNodeThrottleLimitPayload, AllDefault) { |
| 46 | + SetNodeThrottleLimitPayload limits = nlohmann::json::parse("{}"); |
| 47 | + EXPECT_FALSE(limits.capacity); |
| 48 | + EXPECT_FALSE(limits.default_throttle_reserved_units); |
| 49 | + EXPECT_FALSE(limits.default_throttle_hard_limit); |
| 50 | +} |
| 51 | + |
| 52 | +TEST(SetNodeThrottleLimitPayload, Capacity) { |
| 53 | + SetNodeThrottleLimitPayload limits = |
| 54 | + nlohmann::json::parse(R"({"capacity":1})"); |
| 55 | + EXPECT_TRUE(limits.capacity); |
| 56 | + EXPECT_EQ(1, limits.capacity.value()); |
| 57 | + EXPECT_FALSE(limits.default_throttle_reserved_units); |
| 58 | + EXPECT_FALSE(limits.default_throttle_hard_limit); |
| 59 | + |
| 60 | + limits = nlohmann::json::parse(R"({"capacity":0})"); |
| 61 | + EXPECT_TRUE(limits.capacity); |
| 62 | + EXPECT_EQ(0, limits.capacity.value()); |
| 63 | + |
| 64 | + limits = nlohmann::json::parse(R"({"capacity":"unlimited"})"); |
| 65 | + EXPECT_TRUE(limits.capacity); |
| 66 | + EXPECT_EQ(std::numeric_limits<std::size_t>::max(), limits.capacity.value()); |
| 67 | +} |
| 68 | + |
| 69 | +TEST(SetNodeThrottleLimitPayload, DefaultThrottle) { |
| 70 | + SetNodeThrottleLimitPayload limits = |
| 71 | + nlohmann::json{{"default_throttle_reserved_units", 10}, |
| 72 | + {"default_throttle_hard_limit", 25}}; |
| 73 | + EXPECT_FALSE(limits.capacity); |
| 74 | + EXPECT_TRUE(limits.default_throttle_reserved_units); |
| 75 | + EXPECT_TRUE(limits.default_throttle_hard_limit); |
| 76 | + EXPECT_EQ(10, limits.default_throttle_reserved_units.value()); |
| 77 | + EXPECT_EQ(25, limits.default_throttle_hard_limit.value()); |
| 78 | + |
| 79 | + // They may be equal |
| 80 | + limits = nlohmann::json{{"default_throttle_reserved_units", 40}, |
| 81 | + {"default_throttle_hard_limit", 40}}; |
| 82 | + EXPECT_FALSE(limits.capacity); |
| 83 | + EXPECT_TRUE(limits.default_throttle_reserved_units); |
| 84 | + EXPECT_TRUE(limits.default_throttle_hard_limit); |
| 85 | + EXPECT_EQ(40, limits.default_throttle_reserved_units.value()); |
| 86 | + EXPECT_EQ(40, limits.default_throttle_hard_limit.value()); |
| 87 | + |
| 88 | + // They may be string |
| 89 | + limits = nlohmann::json{{"default_throttle_reserved_units", "unlimited"}, |
| 90 | + {"default_throttle_hard_limit", "unlimited"}}; |
| 91 | + EXPECT_FALSE(limits.capacity); |
| 92 | + EXPECT_TRUE(limits.default_throttle_reserved_units); |
| 93 | + EXPECT_TRUE(limits.default_throttle_hard_limit); |
| 94 | + EXPECT_EQ(std::numeric_limits<std::size_t>::max(), |
| 95 | + limits.default_throttle_reserved_units.value()); |
| 96 | + EXPECT_EQ(std::numeric_limits<std::size_t>::max(), |
| 97 | + limits.default_throttle_hard_limit.value()); |
| 98 | + |
| 99 | + // but reserved cannot exceed hard |
| 100 | + try { |
| 101 | + limits = |
| 102 | + nlohmann::json{{"default_throttle_reserved_units", "unlimited"}, |
| 103 | + {"default_throttle_hard_limit", 100}}; |
| 104 | + FAIL() << "reserved must be less or equal to hard limit"; |
| 105 | + } catch (const std::exception&) { |
| 106 | + } |
| 107 | +} |
0 commit comments