* Create rate limiter using factory function in the test.

* Convert function local statics in option helper to a C array
  that does not perform dynamic memory allocation. This is helpful
  when you try to memory isolate different DB instances.
main
Dmitri Smirnov 9 years ago committed by Islam AbdelRahman
parent 2a2ebb6f5e
commit 3981345be1
  1. 23
      util/options_helper.cc
  2. 4
      util/rate_limiter_test.cc

@ -34,23 +34,34 @@ bool isSpecialChar(const char c) {
return false; return false;
} }
namespace {
using
CharMap = std::pair<char, char>;
}
char UnescapeChar(const char c) { char UnescapeChar(const char c) {
static const std::unordered_map<char, char> convert_map = {{'r', '\r'}, static const CharMap convert_map[] = {{'r', '\r'},
{'n', '\n'}}; {'n', '\n'}};
auto iter = convert_map.find(c); auto iter = std::find_if(std::begin(convert_map),
if (iter == convert_map.end()) { std::end(convert_map),
[c](const CharMap& p) { return p.first == c; });
if (iter == std::end(convert_map)) {
return c; return c;
} }
return iter->second; return iter->second;
} }
char EscapeChar(const char c) { char EscapeChar(const char c) {
static const std::unordered_map<char, char> convert_map = {{'\n', 'n'}, static const CharMap convert_map[] = {{'\n', 'n'},
{'\r', 'r'}}; {'\r', 'r'}};
auto iter = convert_map.find(c); auto iter = std::find_if(std::begin(convert_map),
if (iter == convert_map.end()) { std::end(convert_map),
[c](const CharMap& p) { return p.first == c; });
if (iter == std::end(convert_map)) {
return c; return c;
} }
return iter->second; return iter->second;

@ -29,14 +29,14 @@ TEST_F(RateLimiterTest, OverflowRate) {
} }
TEST_F(RateLimiterTest, StartStop) { TEST_F(RateLimiterTest, StartStop) {
std::unique_ptr<RateLimiter> limiter(new GenericRateLimiter(100, 100, 10)); std::unique_ptr<RateLimiter> limiter(NewGenericRateLimiter(100, 100, 10));
} }
TEST_F(RateLimiterTest, Rate) { TEST_F(RateLimiterTest, Rate) {
auto* env = Env::Default(); auto* env = Env::Default();
struct Arg { struct Arg {
Arg(int32_t _target_rate, int _burst) Arg(int32_t _target_rate, int _burst)
: limiter(new GenericRateLimiter(_target_rate, 100 * 1000, 10)), : limiter(NewGenericRateLimiter(_target_rate, 100 * 1000, 10)),
request_size(_target_rate / 10), request_size(_target_rate / 10),
burst(_burst) {} burst(_burst) {}
std::unique_ptr<RateLimiter> limiter; std::unique_ptr<RateLimiter> limiter;

Loading…
Cancel
Save