Commit 443b0c2b authored by TousakaRin's avatar TousakaRin

update unit-test

parent b67ef038
...@@ -60,14 +60,10 @@ struct FeedbackControl { ...@@ -60,14 +60,10 @@ struct FeedbackControl {
: _req_num(req_num) : _req_num(req_num)
, _error_percent(error_percent) , _error_percent(error_percent)
, _circuit_breaker(circuit_breaker) , _circuit_breaker(circuit_breaker)
, _healthy_cnt(0)
, _unhealthy_cnt(0)
, _healthy(true) {} , _healthy(true) {}
int _req_num; int _req_num;
int _error_percent; int _error_percent;
brpc::CircuitBreaker* _circuit_breaker; brpc::CircuitBreaker* _circuit_breaker;
int _healthy_cnt;
int _unhealthy_cnt;
bool _healthy; bool _healthy;
}; };
...@@ -91,10 +87,8 @@ protected: ...@@ -91,10 +87,8 @@ protected:
healthy = fc->_circuit_breaker->OnCallEnd(kErrorCodeForSucc, kLatency); healthy = fc->_circuit_breaker->OnCallEnd(kErrorCodeForSucc, kLatency);
} }
fc->_healthy = healthy; fc->_healthy = healthy;
if (healthy) { if (!healthy) {
++fc->_healthy_cnt; break;
} else {
++fc->_unhealthy_cnt;
} }
} }
return fc; return fc;
...@@ -126,9 +120,11 @@ TEST_F(CircuitBreakerTest, should_not_isolate) { ...@@ -126,9 +120,11 @@ TEST_F(CircuitBreakerTest, should_not_isolate) {
void* ret_data = NULL; void* ret_data = NULL;
EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0); EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0);
FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data); FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data);
EXPECT_EQ(fc->_unhealthy_cnt, 0);
EXPECT_TRUE(fc->_healthy); EXPECT_TRUE(fc->_healthy);
} }
// MarkAsBroken shoul be called only once.
_circuit_breaker.MarkAsBroken();
_circuit_breaker.Reset();
} }
TEST_F(CircuitBreakerTest, should_isolate) { TEST_F(CircuitBreakerTest, should_isolate) {
...@@ -139,12 +135,15 @@ TEST_F(CircuitBreakerTest, should_isolate) { ...@@ -139,12 +135,15 @@ TEST_F(CircuitBreakerTest, should_isolate) {
void* ret_data = NULL; void* ret_data = NULL;
EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0); EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0);
FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data); FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data);
EXPECT_GT(fc->_unhealthy_cnt, 0);
EXPECT_FALSE(fc->_healthy); EXPECT_FALSE(fc->_healthy);
} }
// MarkAsBroken shoul be called only once.
_circuit_breaker.MarkAsBroken();
_circuit_breaker.Reset();
} }
TEST_F(CircuitBreakerTest, isolation_duration_grow) { TEST_F(CircuitBreakerTest, isolation_duration_grow) {
EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs);
_circuit_breaker.Reset(); _circuit_breaker.Reset();
std::vector<pthread_t> thread_list; std::vector<pthread_t> thread_list;
std::vector<std::unique_ptr<FeedbackControl>> fc_list; std::vector<std::unique_ptr<FeedbackControl>> fc_list;
...@@ -154,9 +153,9 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) { ...@@ -154,9 +153,9 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) {
EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0); EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0);
FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data); FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data);
EXPECT_FALSE(fc->_healthy); EXPECT_FALSE(fc->_healthy);
EXPECT_LE(fc->_healthy_cnt, kShortWindowSize);
EXPECT_GT(fc->_unhealthy_cnt, 0);
} }
// MarkAsBroken shoul be called only once.
_circuit_breaker.MarkAsBroken();
EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs * 2); EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs * 2);
_circuit_breaker.Reset(); _circuit_breaker.Reset();
...@@ -167,9 +166,9 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) { ...@@ -167,9 +166,9 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) {
EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0); EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0);
FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data); FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data);
EXPECT_FALSE(fc->_healthy); EXPECT_FALSE(fc->_healthy);
EXPECT_LE(fc->_healthy_cnt, kShortWindowSize);
EXPECT_GT(fc->_unhealthy_cnt, 0);
} }
// MarkAsBroken shoul be called only once.
_circuit_breaker.MarkAsBroken();
EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs * 4); EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs * 4);
_circuit_breaker.Reset(); _circuit_breaker.Reset();
...@@ -180,8 +179,8 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) { ...@@ -180,8 +179,8 @@ TEST_F(CircuitBreakerTest, isolation_duration_grow) {
EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0); EXPECT_EQ(pthread_join(thread_list[i], &ret_data), 0);
FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data); FeedbackControl* fc = static_cast<FeedbackControl*>(ret_data);
EXPECT_FALSE(fc->_healthy); EXPECT_FALSE(fc->_healthy);
EXPECT_LE(fc->_healthy_cnt, kShortWindowSize);
EXPECT_GT(fc->_unhealthy_cnt, 0);
} }
// MarkAsBroken shoul be called only once.
_circuit_breaker.MarkAsBroken();
EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs); EXPECT_EQ(_circuit_breaker.isolation_duration_ms(), kMinIsolationDurationMs);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment