grpc 1.7.3-universal-darwin → 1.8.0-universal-darwin
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of grpc might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/src/ruby/ext/grpc/extconf.rb +4 -2
- data/src/ruby/ext/grpc/rb_byte_buffer.c +5 -5
- data/src/ruby/ext/grpc/rb_byte_buffer.h +2 -2
- data/src/ruby/ext/grpc/rb_call.c +41 -42
- data/src/ruby/ext/grpc/rb_call.h +6 -6
- data/src/ruby/ext/grpc/rb_call_credentials.c +30 -30
- data/src/ruby/ext/grpc/rb_channel.c +87 -87
- data/src/ruby/ext/grpc/rb_channel_credentials.c +23 -23
- data/src/ruby/ext/grpc/rb_completion_queue.c +11 -11
- data/src/ruby/ext/grpc/rb_completion_queue.h +3 -3
- data/src/ruby/ext/grpc/rb_compression_options.c +20 -20
- data/src/ruby/ext/grpc/rb_event_thread.c +14 -14
- data/src/ruby/ext/grpc/rb_event_thread.h +1 -1
- data/src/ruby/ext/grpc/rb_grpc.c +8 -8
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.c +16 -58
- data/src/ruby/ext/grpc/rb_grpc_imports.generated.h +242 -306
- data/src/ruby/ext/grpc/rb_server.c +23 -23
- data/src/ruby/ext/grpc/rb_server_credentials.c +13 -13
- data/src/ruby/lib/grpc/2.0/grpc_c.bundle +0 -0
- data/src/ruby/lib/grpc/2.1/grpc_c.bundle +0 -0
- data/src/ruby/lib/grpc/2.2/grpc_c.bundle +0 -0
- data/src/ruby/lib/grpc/2.3/grpc_c.bundle +0 -0
- data/src/ruby/lib/grpc/2.4/grpc_c.bundle +0 -0
- data/src/ruby/lib/grpc/generic/rpc_server.rb +25 -12
- data/src/ruby/lib/grpc/version.rb +1 -1
- data/src/ruby/pb/grpc/health/checker.rb +14 -0
- data/src/ruby/spec/pb/health/checker_spec.rb +29 -0
- metadata +2 -2
| @@ -44,12 +44,12 @@ static VALUE id_insecure_server; | |
| 44 44 | 
             
            /* grpc_rb_server wraps a grpc_server. */
         | 
| 45 45 | 
             
            typedef struct grpc_rb_server {
         | 
| 46 46 | 
             
              /* The actual server */
         | 
| 47 | 
            -
              grpc_server  | 
| 48 | 
            -
              grpc_completion_queue  | 
| 47 | 
            +
              grpc_server* wrapped;
         | 
| 48 | 
            +
              grpc_completion_queue* queue;
         | 
| 49 49 | 
             
              gpr_atm shutdown_started;
         | 
| 50 50 | 
             
            } grpc_rb_server;
         | 
| 51 51 |  | 
| 52 | 
            -
            static void destroy_server(grpc_rb_server  | 
| 52 | 
            +
            static void destroy_server(grpc_rb_server* server, gpr_timespec deadline) {
         | 
| 53 53 | 
             
              grpc_event ev;
         | 
| 54 54 | 
             
              // This can be started by app or implicitly by GC. Avoid a race between these.
         | 
| 55 55 | 
             
              if (gpr_atm_full_fetch_add(&server->shutdown_started, (gpr_atm)1) == 0) {
         | 
| @@ -70,13 +70,13 @@ static void destroy_server(grpc_rb_server *server, gpr_timespec deadline) { | |
| 70 70 | 
             
            }
         | 
| 71 71 |  | 
| 72 72 | 
             
            /* Destroys server instances. */
         | 
| 73 | 
            -
            static void grpc_rb_server_free(void  | 
| 74 | 
            -
              grpc_rb_server  | 
| 73 | 
            +
            static void grpc_rb_server_free(void* p) {
         | 
| 74 | 
            +
              grpc_rb_server* svr = NULL;
         | 
| 75 75 | 
             
              gpr_timespec deadline;
         | 
| 76 76 | 
             
              if (p == NULL) {
         | 
| 77 77 | 
             
                return;
         | 
| 78 78 | 
             
              };
         | 
| 79 | 
            -
              svr = (grpc_rb_server | 
| 79 | 
            +
              svr = (grpc_rb_server*)p;
         | 
| 80 80 |  | 
| 81 81 | 
             
              deadline = gpr_time_add(gpr_now(GPR_CLOCK_REALTIME),
         | 
| 82 82 | 
             
                                      gpr_time_from_seconds(2, GPR_TIMESPAN));
         | 
| @@ -105,7 +105,7 @@ static const rb_data_type_t grpc_rb_server_data_type = { | |
| 105 105 |  | 
| 106 106 | 
             
            /* Allocates grpc_rb_server instances. */
         | 
| 107 107 | 
             
            static VALUE grpc_rb_server_alloc(VALUE cls) {
         | 
| 108 | 
            -
              grpc_rb_server  | 
| 108 | 
            +
              grpc_rb_server* wrapper = ALLOC(grpc_rb_server);
         | 
| 109 109 | 
             
              wrapper->wrapped = NULL;
         | 
| 110 110 | 
             
              wrapper->shutdown_started = (gpr_atm)0;
         | 
| 111 111 | 
             
              return TypedData_Wrap_Struct(cls, &grpc_rb_server_data_type, wrapper);
         | 
| @@ -117,9 +117,9 @@ static VALUE grpc_rb_server_alloc(VALUE cls) { | |
| 117 117 |  | 
| 118 118 | 
             
              Initializes server instances. */
         | 
| 119 119 | 
             
            static VALUE grpc_rb_server_init(VALUE self, VALUE channel_args) {
         | 
| 120 | 
            -
              grpc_completion_queue  | 
| 121 | 
            -
              grpc_rb_server  | 
| 122 | 
            -
              grpc_server  | 
| 120 | 
            +
              grpc_completion_queue* cq = NULL;
         | 
| 121 | 
            +
              grpc_rb_server* wrapper = NULL;
         | 
| 122 | 
            +
              grpc_server* srv = NULL;
         | 
| 123 123 | 
             
              grpc_channel_args args;
         | 
| 124 124 | 
             
              MEMZERO(&args, grpc_channel_args, 1);
         | 
| 125 125 |  | 
| @@ -153,7 +153,7 @@ typedef struct request_call_stack { | |
| 153 153 |  | 
| 154 154 | 
             
            /* grpc_request_call_stack_init ensures the request_call_stack is properly
         | 
| 155 155 | 
             
             * initialized */
         | 
| 156 | 
            -
            static void grpc_request_call_stack_init(request_call_stack  | 
| 156 | 
            +
            static void grpc_request_call_stack_init(request_call_stack* st) {
         | 
| 157 157 | 
             
              MEMZERO(st, request_call_stack, 1);
         | 
| 158 158 | 
             
              grpc_metadata_array_init(&st->md_ary);
         | 
| 159 159 | 
             
              grpc_call_details_init(&st->details);
         | 
| @@ -161,7 +161,7 @@ static void grpc_request_call_stack_init(request_call_stack *st) { | |
| 161 161 |  | 
| 162 162 | 
             
            /* grpc_request_call_stack_cleanup ensures the request_call_stack is properly
         | 
| 163 163 | 
             
             * cleaned up */
         | 
| 164 | 
            -
            static void grpc_request_call_stack_cleanup(request_call_stack  | 
| 164 | 
            +
            static void grpc_request_call_stack_cleanup(request_call_stack* st) {
         | 
| 165 165 | 
             
              grpc_metadata_array_destroy(&st->md_ary);
         | 
| 166 166 | 
             
              grpc_call_details_destroy(&st->details);
         | 
| 167 167 | 
             
            }
         | 
| @@ -171,14 +171,14 @@ static void grpc_request_call_stack_cleanup(request_call_stack *st) { | |
| 171 171 |  | 
| 172 172 | 
             
               Requests notification of a new call on a server. */
         | 
| 173 173 | 
             
            static VALUE grpc_rb_server_request_call(VALUE self) {
         | 
| 174 | 
            -
              grpc_rb_server  | 
| 175 | 
            -
              grpc_call  | 
| 174 | 
            +
              grpc_rb_server* s = NULL;
         | 
| 175 | 
            +
              grpc_call* call = NULL;
         | 
| 176 176 | 
             
              grpc_event ev;
         | 
| 177 177 | 
             
              grpc_call_error err;
         | 
| 178 178 | 
             
              request_call_stack st;
         | 
| 179 179 | 
             
              VALUE result;
         | 
| 180 | 
            -
              void  | 
| 181 | 
            -
              grpc_completion_queue  | 
| 180 | 
            +
              void* tag = (void*)&st;
         | 
| 181 | 
            +
              grpc_completion_queue* call_queue =
         | 
| 182 182 | 
             
                  grpc_completion_queue_create_for_pluck(NULL);
         | 
| 183 183 | 
             
              gpr_timespec deadline;
         | 
| 184 184 |  | 
| @@ -222,7 +222,7 @@ static VALUE grpc_rb_server_request_call(VALUE self) { | |
| 222 222 | 
             
            }
         | 
| 223 223 |  | 
| 224 224 | 
             
            static VALUE grpc_rb_server_start(VALUE self) {
         | 
| 225 | 
            -
              grpc_rb_server  | 
| 225 | 
            +
              grpc_rb_server* s = NULL;
         | 
| 226 226 | 
             
              TypedData_Get_Struct(self, grpc_rb_server, &grpc_rb_server_data_type, s);
         | 
| 227 227 | 
             
              if (s->wrapped == NULL) {
         | 
| 228 228 | 
             
                rb_raise(rb_eRuntimeError, "destroyed!");
         | 
| @@ -244,10 +244,10 @@ static VALUE grpc_rb_server_start(VALUE self) { | |
| 244 244 | 
             
                server.destroy(timeout)
         | 
| 245 245 |  | 
| 246 246 | 
             
              Destroys server instances. */
         | 
| 247 | 
            -
            static VALUE grpc_rb_server_destroy(int argc, VALUE  | 
| 247 | 
            +
            static VALUE grpc_rb_server_destroy(int argc, VALUE* argv, VALUE self) {
         | 
| 248 248 | 
             
              VALUE timeout = Qnil;
         | 
| 249 249 | 
             
              gpr_timespec deadline;
         | 
| 250 | 
            -
              grpc_rb_server  | 
| 250 | 
            +
              grpc_rb_server* s = NULL;
         | 
| 251 251 |  | 
| 252 252 | 
             
              /* "01" == 0 mandatory args, 1 (timeout) is optional */
         | 
| 253 253 | 
             
              rb_scan_args(argc, argv, "01", &timeout);
         | 
| @@ -277,8 +277,8 @@ static VALUE grpc_rb_server_destroy(int argc, VALUE *argv, VALUE self) { | |
| 277 277 | 
             
                Adds a http2 port to server */
         | 
| 278 278 | 
             
            static VALUE grpc_rb_server_add_http2_port(VALUE self, VALUE port,
         | 
| 279 279 | 
             
                                                       VALUE rb_creds) {
         | 
| 280 | 
            -
              grpc_rb_server  | 
| 281 | 
            -
              grpc_server_credentials  | 
| 280 | 
            +
              grpc_rb_server* s = NULL;
         | 
| 281 | 
            +
              grpc_server_credentials* creds = NULL;
         | 
| 282 282 | 
             
              int recvd_port = 0;
         | 
| 283 283 |  | 
| 284 284 | 
             
              TypedData_Get_Struct(self, grpc_rb_server, &grpc_rb_server_data_type, s);
         | 
| @@ -335,8 +335,8 @@ void Init_grpc_server() { | |
| 335 335 | 
             
            }
         | 
| 336 336 |  | 
| 337 337 | 
             
            /* Gets the wrapped server from the ruby wrapper */
         | 
| 338 | 
            -
            grpc_server  | 
| 339 | 
            -
              grpc_rb_server  | 
| 338 | 
            +
            grpc_server* grpc_rb_get_wrapped_server(VALUE v) {
         | 
| 339 | 
            +
              grpc_rb_server* wrapper = NULL;
         | 
| 340 340 | 
             
              TypedData_Get_Struct(v, grpc_rb_server, &grpc_rb_server_data_type, wrapper);
         | 
| 341 341 | 
             
              return wrapper->wrapped;
         | 
| 342 342 | 
             
            }
         | 
| @@ -38,16 +38,16 @@ typedef struct grpc_rb_server_credentials { | |
| 38 38 | 
             
              /* Holder of ruby objects involved in constructing the server credentials */
         | 
| 39 39 | 
             
              VALUE mark;
         | 
| 40 40 | 
             
              /* The actual server credentials */
         | 
| 41 | 
            -
              grpc_server_credentials  | 
| 41 | 
            +
              grpc_server_credentials* wrapped;
         | 
| 42 42 | 
             
            } grpc_rb_server_credentials;
         | 
| 43 43 |  | 
| 44 44 | 
             
            /* Destroys the server credentials instances. */
         | 
| 45 | 
            -
            static void grpc_rb_server_credentials_free(void  | 
| 46 | 
            -
              grpc_rb_server_credentials  | 
| 45 | 
            +
            static void grpc_rb_server_credentials_free(void* p) {
         | 
| 46 | 
            +
              grpc_rb_server_credentials* wrapper = NULL;
         | 
| 47 47 | 
             
              if (p == NULL) {
         | 
| 48 48 | 
             
                return;
         | 
| 49 49 | 
             
              };
         | 
| 50 | 
            -
              wrapper = (grpc_rb_server_credentials | 
| 50 | 
            +
              wrapper = (grpc_rb_server_credentials*)p;
         | 
| 51 51 |  | 
| 52 52 | 
             
              /* Delete the wrapped object if the mark object is Qnil, which indicates that
         | 
| 53 53 | 
             
                 no other object is the actual owner. */
         | 
| @@ -60,12 +60,12 @@ static void grpc_rb_server_credentials_free(void *p) { | |
| 60 60 | 
             
            }
         | 
| 61 61 |  | 
| 62 62 | 
             
            /* Protects the mark object from GC */
         | 
| 63 | 
            -
            static void grpc_rb_server_credentials_mark(void  | 
| 64 | 
            -
              grpc_rb_server_credentials  | 
| 63 | 
            +
            static void grpc_rb_server_credentials_mark(void* p) {
         | 
| 64 | 
            +
              grpc_rb_server_credentials* wrapper = NULL;
         | 
| 65 65 | 
             
              if (p == NULL) {
         | 
| 66 66 | 
             
                return;
         | 
| 67 67 | 
             
              }
         | 
| 68 | 
            -
              wrapper = (grpc_rb_server_credentials | 
| 68 | 
            +
              wrapper = (grpc_rb_server_credentials*)p;
         | 
| 69 69 |  | 
| 70 70 | 
             
              /* If it's not already cleaned up, mark the mark object */
         | 
| 71 71 | 
             
              if (wrapper->mark != Qnil) {
         | 
| @@ -90,7 +90,7 @@ static const rb_data_type_t grpc_rb_server_credentials_data_type = { | |
| 90 90 |  | 
| 91 91 | 
             
               Provides safe initial defaults for the instance fields. */
         | 
| 92 92 | 
             
            static VALUE grpc_rb_server_credentials_alloc(VALUE cls) {
         | 
| 93 | 
            -
              grpc_rb_server_credentials  | 
| 93 | 
            +
              grpc_rb_server_credentials* wrapper = ALLOC(grpc_rb_server_credentials);
         | 
| 94 94 | 
             
              wrapper->wrapped = NULL;
         | 
| 95 95 | 
             
              wrapper->mark = Qnil;
         | 
| 96 96 | 
             
              return TypedData_Wrap_Struct(cls, &grpc_rb_server_credentials_data_type,
         | 
| @@ -128,9 +128,9 @@ static VALUE sym_private_key; | |
| 128 128 | 
             
            static VALUE grpc_rb_server_credentials_init(VALUE self, VALUE pem_root_certs,
         | 
| 129 129 | 
             
                                                         VALUE pem_key_certs,
         | 
| 130 130 | 
             
                                                         VALUE force_client_auth) {
         | 
| 131 | 
            -
              grpc_rb_server_credentials  | 
| 132 | 
            -
              grpc_server_credentials  | 
| 133 | 
            -
              grpc_ssl_pem_key_cert_pair  | 
| 131 | 
            +
              grpc_rb_server_credentials* wrapper = NULL;
         | 
| 132 | 
            +
              grpc_server_credentials* creds = NULL;
         | 
| 133 | 
            +
              grpc_ssl_pem_key_cert_pair* key_cert_pairs = NULL;
         | 
| 134 134 | 
             
              VALUE cert = Qnil;
         | 
| 135 135 | 
             
              VALUE key = Qnil;
         | 
| 136 136 | 
             
              VALUE key_cert = Qnil;
         | 
| @@ -235,8 +235,8 @@ void Init_grpc_server_credentials() { | |
| 235 235 | 
             
            }
         | 
| 236 236 |  | 
| 237 237 | 
             
            /* Gets the wrapped grpc_server_credentials from the ruby wrapper */
         | 
| 238 | 
            -
            grpc_server_credentials  | 
| 239 | 
            -
              grpc_rb_server_credentials  | 
| 238 | 
            +
            grpc_server_credentials* grpc_rb_get_wrapped_server_credentials(VALUE v) {
         | 
| 239 | 
            +
              grpc_rb_server_credentials* wrapper = NULL;
         | 
| 240 240 | 
             
              TypedData_Get_Struct(v, grpc_rb_server_credentials,
         | 
| 241 241 | 
             
                                   &grpc_rb_server_credentials_data_type, wrapper);
         | 
| 242 242 | 
             
              return wrapper->wrapped;
         | 
| Binary file | 
| Binary file | 
| Binary file | 
| Binary file | 
| Binary file | 
| @@ -92,9 +92,13 @@ module GRPC | |
| 92 92 | 
             
                # Stops the jobs in the pool
         | 
| 93 93 | 
             
                def stop
         | 
| 94 94 | 
             
                  GRPC.logger.info('stopping, will wait for all the workers to exit')
         | 
| 95 | 
            -
                   | 
| 96 | 
            -
                  @stop_mutex.synchronize do  # wait @keep_alive for works to stop
         | 
| 95 | 
            +
                  @stop_mutex.synchronize do  # wait @keep_alive seconds for workers to stop
         | 
| 97 96 | 
             
                    @stopped = true
         | 
| 97 | 
            +
                    loop do
         | 
| 98 | 
            +
                      break unless ready_for_work?
         | 
| 99 | 
            +
                      worker_queue = @ready_workers.pop
         | 
| 100 | 
            +
                      worker_queue << [proc { throw :exit }, []]
         | 
| 101 | 
            +
                    end
         | 
| 98 102 | 
             
                    @stop_cond.wait(@stop_mutex, @keep_alive) if @workers.size > 0
         | 
| 99 103 | 
             
                  end
         | 
| 100 104 | 
             
                  forcibly_stop_workers
         | 
| @@ -138,7 +142,10 @@ module GRPC | |
| 138 142 | 
             
                    end
         | 
| 139 143 | 
             
                    # there shouldn't be any work given to this thread while its busy
         | 
| 140 144 | 
             
                    fail('received a task while busy') unless worker_queue.empty?
         | 
| 141 | 
            -
                    @ | 
| 145 | 
            +
                    @stop_mutex.synchronize do
         | 
| 146 | 
            +
                      return if @stopped
         | 
| 147 | 
            +
                      @ready_workers << worker_queue
         | 
| 148 | 
            +
                    end
         | 
| 142 149 | 
             
                  end
         | 
| 143 150 | 
             
                end
         | 
| 144 151 | 
             
              end
         | 
| @@ -186,8 +193,13 @@ module GRPC | |
| 186 193 | 
             
                # * max_waiting_requests: Deprecated due to internal changes to the thread
         | 
| 187 194 | 
             
                # pool. This is still an argument for compatibility but is ignored.
         | 
| 188 195 | 
             
                #
         | 
| 189 | 
            -
                # * poll_period:  | 
| 190 | 
            -
                #  | 
| 196 | 
            +
                # * poll_period: The amount of time in seconds to wait for
         | 
| 197 | 
            +
                # currently-serviced RPC's to finish before cancelling them when shutting
         | 
| 198 | 
            +
                # down the server.
         | 
| 199 | 
            +
                #
         | 
| 200 | 
            +
                # * pool_keep_alive: The amount of time in seconds to wait
         | 
| 201 | 
            +
                # for currently busy thread-pool threads to finish before
         | 
| 202 | 
            +
                # forcing an abrupt exit to each thread.
         | 
| 191 203 | 
             
                #
         | 
| 192 204 | 
             
                # * connect_md_proc:
         | 
| 193 205 | 
             
                # when non-nil is a proc for determining metadata to to send back the client
         | 
| @@ -202,17 +214,18 @@ module GRPC | |
| 202 214 | 
             
                # intercepting server handlers to provide extra functionality.
         | 
| 203 215 | 
             
                # Interceptors are an EXPERIMENTAL API.
         | 
| 204 216 | 
             
                #
         | 
| 205 | 
            -
                def initialize(pool_size:DEFAULT_POOL_SIZE,
         | 
| 206 | 
            -
                               max_waiting_requests:DEFAULT_MAX_WAITING_REQUESTS,
         | 
| 207 | 
            -
                               poll_period:DEFAULT_POLL_PERIOD,
         | 
| 208 | 
            -
                                | 
| 209 | 
            -
                                | 
| 210 | 
            -
                                | 
| 217 | 
            +
                def initialize(pool_size: DEFAULT_POOL_SIZE,
         | 
| 218 | 
            +
                               max_waiting_requests: DEFAULT_MAX_WAITING_REQUESTS,
         | 
| 219 | 
            +
                               poll_period: DEFAULT_POLL_PERIOD,
         | 
| 220 | 
            +
                               pool_keep_alive: GRPC::RpcServer::DEFAULT_POOL_SIZE,
         | 
| 221 | 
            +
                               connect_md_proc: nil,
         | 
| 222 | 
            +
                               server_args: {},
         | 
| 223 | 
            +
                               interceptors: [])
         | 
| 211 224 | 
             
                  @connect_md_proc = RpcServer.setup_connect_md_proc(connect_md_proc)
         | 
| 212 225 | 
             
                  @max_waiting_requests = max_waiting_requests
         | 
| 213 226 | 
             
                  @poll_period = poll_period
         | 
| 214 227 | 
             
                  @pool_size = pool_size
         | 
| 215 | 
            -
                  @pool = Pool.new(@pool_size)
         | 
| 228 | 
            +
                  @pool = Pool.new(@pool_size, keep_alive: pool_keep_alive)
         | 
| 216 229 | 
             
                  @run_cond = ConditionVariable.new
         | 
| 217 230 | 
             
                  @run_mutex = Mutex.new
         | 
| 218 231 | 
             
                  # running_state can take 4 values: :not_started, :running, :stopping, and
         | 
| @@ -48,6 +48,20 @@ module Grpc | |
| 48 48 | 
             
                    @status_mutex.synchronize { @statuses["#{service}"] = status }
         | 
| 49 49 | 
             
                  end
         | 
| 50 50 |  | 
| 51 | 
            +
                  # Adds given health status for all given services
         | 
| 52 | 
            +
                  def set_status_for_services(status, *services)
         | 
| 53 | 
            +
                    @status_mutex.synchronize do
         | 
| 54 | 
            +
                      services.each { |service| @statuses["#{service}"] = status }
         | 
| 55 | 
            +
                    end
         | 
| 56 | 
            +
                  end
         | 
| 57 | 
            +
             | 
| 58 | 
            +
                  # Adds health status for each service given within hash
         | 
| 59 | 
            +
                  def add_statuses(service_statuses = {})
         | 
| 60 | 
            +
                    @status_mutex.synchronize do
         | 
| 61 | 
            +
                      service_statuses.each_pair { |service, status| @statuses["#{service}"] = status }
         | 
| 62 | 
            +
                    end
         | 
| 63 | 
            +
                  end
         | 
| 64 | 
            +
             | 
| 51 65 | 
             
                  # Clears the status for the given service.
         | 
| 52 66 | 
             
                  def clear_status(service)
         | 
| 53 67 | 
             
                    @status_mutex.synchronize { @statuses.delete("#{service}") }
         | 
| @@ -99,6 +99,35 @@ describe Grpc::Health::Checker do | |
| 99 99 | 
             
                end
         | 
| 100 100 | 
             
              end
         | 
| 101 101 |  | 
| 102 | 
            +
              context 'method `add_statuses`' do
         | 
| 103 | 
            +
                it 'should add status to each service' do
         | 
| 104 | 
            +
                  checker = Grpc::Health::Checker.new
         | 
| 105 | 
            +
                  checker.add_statuses(
         | 
| 106 | 
            +
                    'service1' => ServingStatus::SERVING,
         | 
| 107 | 
            +
                    'service2' => ServingStatus::NOT_SERVING
         | 
| 108 | 
            +
                  )
         | 
| 109 | 
            +
                  service1_health = checker.check(HCReq.new(service: 'service1'), nil)
         | 
| 110 | 
            +
                  service2_health = checker.check(HCReq.new(service: 'service2'), nil)
         | 
| 111 | 
            +
                  expect(service1_health).to eq(HCResp.new(status: ServingStatus::SERVING))
         | 
| 112 | 
            +
                  expect(service2_health).to eq(HCResp.new(status: ServingStatus::NOT_SERVING))
         | 
| 113 | 
            +
                end
         | 
| 114 | 
            +
              end
         | 
| 115 | 
            +
             | 
| 116 | 
            +
              context 'method `set_status_for_services`' do
         | 
| 117 | 
            +
                it 'should add given status to all given services' do
         | 
| 118 | 
            +
                  checker = Grpc::Health::Checker.new
         | 
| 119 | 
            +
                  checker.set_status_for_services(
         | 
| 120 | 
            +
                    ServingStatus::SERVING,
         | 
| 121 | 
            +
                    'service1',
         | 
| 122 | 
            +
                    'service2'
         | 
| 123 | 
            +
                  )
         | 
| 124 | 
            +
                  service1_health = checker.check(HCReq.new(service: 'service1'), nil)
         | 
| 125 | 
            +
                  service2_health = checker.check(HCReq.new(service: 'service2'), nil)
         | 
| 126 | 
            +
                  expect(service1_health).to eq(HCResp.new(status: ServingStatus::SERVING))
         | 
| 127 | 
            +
                  expect(service2_health).to eq(HCResp.new(status: ServingStatus::SERVING))
         | 
| 128 | 
            +
                end
         | 
| 129 | 
            +
              end
         | 
| 130 | 
            +
             | 
| 102 131 | 
             
              context 'method `check`' do
         | 
| 103 132 | 
             
                success_tests.each do |t|
         | 
| 104 133 | 
             
                  it "should fail with NOT_FOUND when #{t[:desc]}" do
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: grpc
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1. | 
| 4 | 
            +
              version: 1.8.0
         | 
| 5 5 | 
             
            platform: universal-darwin
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - gRPC Authors
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: src/ruby/bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2017-12- | 
| 11 | 
            +
            date: 2017-12-13 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: google-protobuf
         |