@ -84,14 +84,18 @@ static void check_peer_identity(grpc_auth_context *ctx,
GPR_ASSERT ( strcmp ( expected_identity , prop - > value ) = = 0 ) ;
GPR_ASSERT ( grpc_auth_property_iterator_next ( & it ) = = NULL ) ;
}
static void process_auth_md_success ( grpc_auth_ticket * t ,
static void process_auth_md_success ( void * state , grpc_auth_ticket * t ,
grpc_auth_context * channel_ctx ,
const grpc_metadata * md , size_t md_count ,
grpc_process_auth_metadata_done_cb cb ,
void * user_data ) {
override_mode * mode ;
GPR_ASSERT ( state ! = NULL ) ;
mode = ( override_mode * ) state ;
if ( * mode ! = DESTROY ) {
grpc_auth_context * new_auth_ctx = grpc_auth_context_create ( channel_ctx ) ;
const grpc_metadata * custom_creds_md =
find_metadata ( md , md_count , custom_creds_md_name , custom_creds_md_value ) ;
const grpc_metadata * custom_creds_md = find_metadata (
md , md_count , custom_creds_md_name , custom_creds_md_value ) ;
GPR_ASSERT ( custom_creds_md ! = NULL ) ;
grpc_auth_context_add_cstring_property (
new_auth_ctx , client_identity_property_name , client_identity ) ;
@ -99,30 +103,32 @@ static void process_auth_md_success(grpc_auth_ticket *t,
new_auth_ctx , client_identity_property_name ) = = 1 ) ;
cb ( user_data , custom_creds_md , 1 , 1 , new_auth_ctx ) ;
grpc_auth_context_release ( new_auth_ctx ) ;
} else {
cb ( user_data , NULL , 0 , 1 , channel_ctx ) ;
}
}
#if 0
static void process_auth_md_failure ( grpc_auth_ticket * t ,
static void process_auth_md_failure ( void * state , grpc_auth_ticket * t ,
grpc_auth_context * channel_ctx ,
const grpc_metadata * md , size_t md_count ,
grpc_process_auth_metadata_done_cb cb ,
void * user_data ) {
const grpc_metadata * custom_creds_md =
find_metadata ( md , md_count , custom_creds_md_name , custom_creds_md_value ) ;
override_mode * mode ;
GPR_ASSERT ( state ! = NULL ) ;
mode = ( override_mode * ) state ;
if ( * mode ! = DESTROY ) {
const grpc_metadata * custom_creds_md = find_metadata (
md , md_count , custom_creds_md_name , custom_creds_md_value ) ;
GPR_ASSERT ( custom_creds_md ! = NULL ) ;
}
cb ( user_data , NULL , 0 , 0 , NULL ) ; /* Fail. */
}
# endif
static grpc_end2end_test_fixture begin_test (
grpc_end2end_test_config config , const char * test_name ,
grpc_process_auth_metadata_func md_func , override_mode mode ) {
grpc_auth_metadata_processor processor ) {
grpc_end2end_test_fixture f ;
if ( mode ! = DESTROY ) {
grpc_server_auth_context_register_process_metadata_func ( md_func ) ;
} else {
grpc_server_auth_context_register_process_metadata_func ( NULL ) ;
}
grpc_server_register_auth_metadata_processor ( processor ) ;
gpr_log ( GPR_INFO , " %s/%s " , test_name , config . name ) ;
f = config . create_fixture ( NULL , NULL ) ;
config . init_client ( & f , NULL ) ;
@ -200,8 +206,9 @@ static grpc_credentials *iam_custom_composite_creds_create(
static void test_call_creds_failure ( grpc_end2end_test_config config ) {
grpc_call * c ;
grpc_credentials * creds = NULL ;
grpc_auth_metadata_processor p = { NULL , NULL } ;
grpc_end2end_test_fixture f =
begin_test ( config , " test_call_creds_failure " , NULL , NONE ) ;
begin_test ( config , " test_call_creds_failure " , p ) ;
gpr_timespec deadline = five_seconds_time ( ) ;
c = grpc_channel_create_call ( f . client , f . cq , " /foo " , " foo.test.google.fr " ,
deadline ) ;
@ -230,10 +237,9 @@ static void request_response_with_payload_and_call_creds(
grpc_byte_buffer * response_payload =
grpc_raw_byte_buffer_create ( & response_payload_slice , 1 ) ;
gpr_timespec deadline = five_seconds_time ( ) ;
grpc_end2end_test_fixture f =
begin_test ( config , test_name , process_auth_md_success , mode ) ;
cq_verifier * cqv = cq_verifier_create ( f . cq ) ;
grpc_auth_metadata_processor p ;
grpc_end2end_test_fixture f ;
cq_verifier * cqv ;
grpc_op ops [ 6 ] ;
grpc_op * op ;
grpc_metadata_array initial_metadata_recv ;
@ -250,6 +256,11 @@ static void request_response_with_payload_and_call_creds(
grpc_auth_context * s_auth_context = NULL ;
grpc_auth_context * c_auth_context = NULL ;
p . process = process_auth_md_success ;
p . state = & mode ;
f = begin_test ( config , test_name , p ) ;
cqv = cq_verifier_create ( f . cq ) ;
c = grpc_channel_create_call ( f . client , f . cq , " /foo " , " foo.test.google.fr " ,
deadline ) ;
GPR_ASSERT ( c ) ;
@ -446,54 +457,41 @@ static void test_request_response_with_payload_and_deleted_call_creds(
DESTROY ) ;
}
static void test_request_with_bad_creds ( void ) {
#if 0
grpc_call * c ;
grpc_call * s ;
gpr_slice request_payload_slice = gpr_slice_from_copied_string ( " hello world " ) ;
grpc_byte_buffer * request_payload =
grpc_raw_byte_buffer_create ( & request_payload_slice , 1 ) ;
gpr_timespec deadline = five_seconds_time ( ) ;
grpc_end2end_test_fixture f =
begin_test ( config , test_name , process_auth_md_failure , NONE ) ;
cq_verifier * cqv = cq_verifier_create ( f . cq ) ;
static void test_request_with_server_rejecting_client_creds (
grpc_end2end_test_config config ) {
grpc_op ops [ 6 ] ;
grpc_op * op ;
grpc_call * c ;
grpc_auth_metadata_processor p ;
grpc_end2end_test_fixture f ;
gpr_timespec deadline = five_seconds_time ( ) ;
cq_verifier * cqv ;
grpc_metadata_array initial_metadata_recv ;
grpc_metadata_array trailing_metadata_recv ;
grpc_metadata_array request_metadata_recv ;
grpc_byte_buffer * request_payload_recv = NULL ;
grpc_byte_buffer * response_payload_recv = NULL ;
grpc_call_details call_details ;
grpc_status_code status ;
char * details = NULL ;
size_t details_capacity = 0 ;
int was_cancelled = 2 ;
grpc_credentials * creds = NULL ;
grpc_auth_context * s_auth_context = NULL ;
grpc_auth_context * c_auth_context = NULL ;
grpc_byte_buffer * response_payload_recv = NULL ;
gpr_slice request_payload_slice = gpr_slice_from_copied_string ( " hello world " ) ;
grpc_byte_buffer * request_payload =
grpc_raw_byte_buffer_create ( & request_payload_slice , 1 ) ;
override_mode mode = NONE ;
grpc_credentials * creds ;
p . process = process_auth_md_failure ;
p . state = & mode ;
f = begin_test ( config , " test_request_with_server_rejecting_client_creds " , p ) ;
cqv = cq_verifier_create ( f . cq ) ;
c = grpc_channel_create_call ( f . client , f . cq , " /foo " , " foo.test.google.fr " ,
deadline ) ;
GPR_ASSERT ( c ) ;
creds = iam_custom_composite_creds_create ( iam_token , iam_selector ) ;
GPR_ASSERT ( creds ! = NULL ) ;
GPR_ASSERT ( grpc_call_set_credentials ( c , creds ) = = GRPC_CALL_OK ) ;
switch ( mode ) {
case NONE :
break ;
case OVERRIDE :
grpc_credentials_release ( creds ) ;
creds = iam_custom_composite_creds_create ( overridden_iam_token ,
overridden_iam_selector ) ;
GPR_ASSERT ( creds ! = NULL ) ;
GPR_ASSERT ( grpc_call_set_credentials ( c , creds ) = = GRPC_CALL_OK ) ;
break ;
case DESTROY :
GPR_ASSERT ( grpc_call_set_credentials ( c , NULL ) = = GRPC_CALL_OK ) ;
break ;
}
grpc_credentials_release ( creds ) ;
grpc_metadata_array_init ( & initial_metadata_recv ) ;
@ -502,6 +500,13 @@ static void test_request_with_bad_creds(void) {
grpc_call_details_init ( & call_details ) ;
op = ops ;
op - > op = GRPC_OP_RECV_STATUS_ON_CLIENT ;
op - > data . recv_status_on_client . trailing_metadata = & trailing_metadata_recv ;
op - > data . recv_status_on_client . status = & status ;
op - > data . recv_status_on_client . status_details = & details ;
op - > data . recv_status_on_client . status_details_capacity = & details_capacity ;
op - > flags = 0 ;
op + + ;
op - > op = GRPC_OP_SEND_INITIAL_METADATA ;
op - > data . send_initial_metadata . count = 0 ;
op - > flags = 0 ;
@ -521,134 +526,31 @@ static void test_request_with_bad_creds(void) {
op - > data . recv_message = & response_payload_recv ;
op - > flags = 0 ;
op + + ;
op - > op = GRPC_OP_RECV_STATUS_ON_CLIENT ;
op - > data . recv_status_on_client . trailing_metadata = & trailing_metadata_recv ;
op - > data . recv_status_on_client . status = & status ;
op - > data . recv_status_on_client . status_details = & details ;
op - > data . recv_status_on_client . status_details_capacity = & details_capacity ;
op - > flags = 0 ;
op + + ;
GPR_ASSERT ( GRPC_CALL_OK = = grpc_call_start_batch ( c , ops , op - ops , tag ( 1 ) ) ) ;
GPR_ASSERT ( GRPC_CALL_OK = = grpc_server_request_call (
f . server , & s , & call_details ,
& request_metadata_recv , f . cq , f . cq , tag ( 101 ) ) ) ;
cq_expect_completion ( cqv , tag ( 101 ) , 1 ) ;
cq_verify ( cqv ) ;
s_auth_context = grpc_call_auth_context ( s ) ;
GPR_ASSERT ( s_auth_context ! = NULL ) ;
print_auth_context ( 0 , s_auth_context ) ;
grpc_auth_context_release ( s_auth_context ) ;
c_auth_context = grpc_call_auth_context ( c ) ;
GPR_ASSERT ( c_auth_context ! = NULL ) ;
print_auth_context ( 1 , c_auth_context ) ;
grpc_auth_context_release ( c_auth_context ) ;
/* Cannot set creds on the server call object. */
GPR_ASSERT ( grpc_call_set_credentials ( s , NULL ) ! = GRPC_CALL_OK ) ;
op = ops ;
op - > op = GRPC_OP_SEND_INITIAL_METADATA ;
op - > data . send_initial_metadata . count = 0 ;
op - > flags = 0 ;
op + + ;
op - > op = GRPC_OP_RECV_MESSAGE ;
op - > data . recv_message = & request_payload_recv ;
op - > flags = 0 ;
op + + ;
GPR_ASSERT ( GRPC_CALL_OK = = grpc_call_start_batch ( s , ops , op - ops , tag ( 102 ) ) ) ;
cq_expect_completion ( cqv , tag ( 102 ) , 1 ) ;
cq_verify ( cqv ) ;
op = ops ;
op - > op = GRPC_OP_RECV_CLOSE_ON_SERVER ;
op - > data . recv_close_on_server . cancelled = & was_cancelled ;
op - > flags = 0 ;
op + + ;
op - > op = GRPC_OP_SEND_MESSAGE ;
op - > data . send_message = response_payload ;
op - > flags = 0 ;
op + + ;
op - > op = GRPC_OP_SEND_STATUS_FROM_SERVER ;
op - > data . send_status_from_server . trailing_metadata_count = 0 ;
op - > data . send_status_from_server . status = GRPC_STATUS_OK ;
op - > data . send_status_from_server . status_details = " xyz " ;
op - > flags = 0 ;
op + + ;
GPR_ASSERT ( GRPC_CALL_OK = = grpc_call_start_batch ( s , ops , op - ops , tag ( 103 ) ) ) ;
cq_expect_completion ( cqv , tag ( 103 ) , 1 ) ;
cq_expect_completion ( cqv , tag ( 1 ) , 1 ) ;
cq_verify ( cqv ) ;
GPR_ASSERT ( status = = GRPC_STATUS_OK ) ;
GPR_ASSERT ( 0 = = strcmp ( details , " xyz " ) ) ;
GPR_ASSERT ( 0 = = strcmp ( call_details . method , " /foo " ) ) ;
GPR_ASSERT ( 0 = = strcmp ( call_details . host , " foo.test.google.fr " ) ) ;
GPR_ASSERT ( was_cancelled = = 0 ) ;
GPR_ASSERT ( byte_buffer_eq_string ( request_payload_recv , " hello world " ) ) ;
GPR_ASSERT ( byte_buffer_eq_string ( response_payload_recv , " hello you " ) ) ;
/* Has been processed by the auth metadata processor. */
GPR_ASSERT ( ! contains_metadata ( & request_metadata_recv , custom_creds_md_name ,
custom_creds_md_value ) ) ;
switch ( mode ) {
case NONE :
GPR_ASSERT ( contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY ,
iam_token ) ) ;
GPR_ASSERT ( contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY ,
iam_selector ) ) ;
check_peer_identity ( s_auth_context , client_identity ) ;
break ;
case OVERRIDE :
GPR_ASSERT ( contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY ,
overridden_iam_token ) ) ;
GPR_ASSERT ( contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY ,
overridden_iam_selector ) ) ;
check_peer_identity ( s_auth_context , client_identity ) ;
break ;
case DESTROY :
GPR_ASSERT ( ! contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY ,
iam_token ) ) ;
GPR_ASSERT ( ! contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY ,
iam_selector ) ) ;
GPR_ASSERT ( ! contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORIZATION_TOKEN_METADATA_KEY ,
overridden_iam_token ) ) ;
GPR_ASSERT ( ! contains_metadata ( & request_metadata_recv ,
GRPC_IAM_AUTHORITY_SELECTOR_METADATA_KEY ,
overridden_iam_selector ) ) ;
break ;
}
/* XXX Should be GRPC_STATUS_UNAUTHENTICATED but it looks like there is a bug
( probably in the server_auth_context . c code ) where this error on the server
does not get to the client . The current error code we are getting is
GRPC_STATUS_INTERNAL . */
GPR_ASSERT ( status ! = GRPC_STATUS_OK ) ;
gpr_free ( details ) ;
grpc_metadata_array_destroy ( & initial_metadata_recv ) ;
grpc_metadata_array_destroy ( & trailing_metadata_recv ) ;
grpc_metadata_array_destroy ( & request_metadata_recv ) ;
grpc_call_details_destroy ( & call_details ) ;
grpc_call_destroy ( c ) ;
grpc_call_destroy ( s ) ;
cq_verifier_destroy ( cqv ) ;
grpc_byte_buffer_destroy ( request_payload ) ;
grpc_byte_buffer_destroy ( response_payload ) ;
grpc_byte_buffer_destroy ( request_payload_recv ) ;
grpc_byte_buffer_destroy ( response_payload_recv ) ;
gpr_free ( details ) ;
grpc_call_destroy ( c ) ;
cq_verifier_destroy ( cqv ) ;
end_test ( & f ) ;
config . tear_down_data ( & f ) ;
# endif
}
void grpc_end2end_tests ( grpc_end2end_test_config config ) {
@ -657,6 +559,6 @@ void grpc_end2end_tests(grpc_end2end_test_config config) {
test_request_response_with_payload_and_call_creds ( config ) ;
test_request_response_with_payload_and_overridden_call_creds ( config ) ;
test_request_response_with_payload_and_deleted_call_creds ( config ) ;
test_request_with_bad_creds ( ) ;
test_request_with_server_rejecting_client_creds ( config ) ;
}
}