Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
2c820f8f
Commit
2c820f8f
authored
Apr 17, 2019
by
zhujiashun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
revived_from_all_failed: enhance UT
parent
30d1fbb0
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
11 deletions
+21
-11
brpc_load_balancer_unittest.cpp
test/brpc_load_balancer_unittest.cpp
+21
-11
No files found.
test/brpc_load_balancer_unittest.cpp
View file @
2c820f8f
...
@@ -882,8 +882,8 @@ public:
...
@@ -882,8 +882,8 @@ public:
butil
::
atomic
<
int
>
_num_request
;
butil
::
atomic
<
int
>
_num_request
;
};
};
butil
::
atomic
<
int32_t
>
num_failed
;
butil
::
atomic
<
int32_t
>
num_failed
(
0
)
;
butil
::
atomic
<
int32_t
>
num_reject
;
butil
::
atomic
<
int32_t
>
num_reject
(
0
)
;
class
Done
:
public
google
::
protobuf
::
Closure
{
class
Done
:
public
google
::
protobuf
::
Closure
{
public
:
public
:
...
@@ -915,6 +915,8 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -915,6 +915,8 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
options
.
protocol
=
"http"
;
options
.
protocol
=
"http"
;
options
.
timeout_ms
=
300
;
options
.
timeout_ms
=
300
;
options
.
enable_circuit_breaker
=
true
;
options
.
enable_circuit_breaker
=
true
;
// Disable retry to make health check happen one by one
options
.
max_retry
=
0
;
ASSERT_EQ
(
channel
.
Init
(
"list://127.0.0.1:7777 50, 127.0.0.1:7778 50"
,
ASSERT_EQ
(
channel
.
Init
(
"list://127.0.0.1:7777 50, 127.0.0.1:7778 50"
,
lb_algo
[
butil
::
fast_rand_less_than
(
ARRAY_SIZE
(
lb_algo
))],
lb_algo
[
butil
::
fast_rand_less_than
(
ARRAY_SIZE
(
lb_algo
))],
&
options
),
0
);
&
options
),
0
);
...
@@ -922,9 +924,16 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -922,9 +924,16 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
req
.
set_message
(
"123"
);
req
.
set_message
(
"123"
);
test
::
EchoResponse
res
;
test
::
EchoResponse
res
;
test
::
EchoService_Stub
stub
(
&
channel
);
test
::
EchoService_Stub
stub
(
&
channel
);
int64_t
start_ms
=
butil
::
gettimeofday_ms
();
// trigger to health check
{
{
// trigger one server to health check
brpc
::
Controller
cntl
;
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
}
// This sleep make one server revived 700ms earlier than the other server, which
// can make the server down again if no request limit policy are applied here.
bthread_usleep
(
700000
);
{
// trigger the other server to health check
brpc
::
Controller
cntl
;
brpc
::
Controller
cntl
;
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
stub
.
Echo
(
&
cntl
,
&
req
,
&
res
,
NULL
);
}
}
...
@@ -941,20 +950,21 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
...
@@ -941,20 +950,21 @@ TEST_F(LoadBalancerTest, revived_from_all_failed_intergrated) {
ASSERT_EQ
(
0
,
server2
.
AddService
(
&
service2
,
brpc
::
SERVER_DOESNT_OWN_SERVICE
));
ASSERT_EQ
(
0
,
server2
.
AddService
(
&
service2
,
brpc
::
SERVER_DOESNT_OWN_SERVICE
));
ASSERT_EQ
(
0
,
server2
.
Start
(
point2
,
NULL
));
ASSERT_EQ
(
0
,
server2
.
Start
(
point2
,
NULL
));
// keep sending for 2900ms(100ms less than hc interval) to make sure all requests
int64_t
start_ms
=
butil
::
gettimeofday_ms
();
// are sent during hc. Those requests should be all failed and error code should
while
((
butil
::
gettimeofday_ms
()
-
start_ms
)
<
3500
)
{
// be brpc::EREJECT.
while
((
butil
::
gettimeofday_ms
()
-
start_ms
)
<
2900
)
{
Done
*
done
=
new
Done
;
Done
*
done
=
new
Done
;
done
->
req
.
set_message
(
"123"
);
done
->
req
.
set_message
(
"123"
);
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
stub
.
Echo
(
&
done
->
cntl
,
&
done
->
req
,
&
done
->
res
,
done
);
bthread_usleep
(
1000
);
bthread_usleep
(
1000
);
}
}
ASSERT_EQ
(
num_reject
.
load
(
butil
::
memory_order_relaxed
),
// All error code should be equal to EREJECT, except when the situation
num_failed
.
load
(
butil
::
memory_order_relaxed
));
// all servers are down, the very first call that trigger recovering would
// fail with EHOSTDOWN instead of EREJECT. This is where the number 1 comes
// in following ASSERT.
ASSERT_TRUE
(
num_failed
.
load
(
butil
::
memory_order_relaxed
)
-
num_reject
.
load
(
butil
::
memory_order_relaxed
)
==
1
);
num_failed
.
store
(
0
,
butil
::
memory_order_relaxed
);
num_failed
.
store
(
0
,
butil
::
memory_order_relaxed
);
bthread_usleep
(
500000
);
// should recover now
// should recover now
for
(
int
i
=
0
;
i
<
1000
;
++
i
)
{
for
(
int
i
=
0
;
i
<
1000
;
++
i
)
{
Done
*
done
=
new
Done
;
Done
*
done
=
new
Done
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment