Tim Emiola 2ab3998251 Merge pull request #1296 from yugui/fix/static 11 anni fa
..
bin b5bcca44df Adds interop cancellation tests 11 anni fa
ext f0eee5f250 Make some functions static 11 anni fa
lib a10a8432f3 Corrects handling of status during bidi call orchestration. 11 anni fa
spec 1b39916bba Adds an explicit Cancellation exception 11 anni fa
.gitignore 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 anni fa
.rspec 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 anni fa
.rubocop.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 anni fa
.rubocop_todo.yml 1e0981262c Correct style errors identified by the latest version of RuboCop 11 anni fa
CHANGELOG.md 51a4c0846b Corrects the Changelog date 11 anni fa
Gemfile 0f0a6bc4f0 Switches to using protobuf-ruby. 11 anni fa
README.md 5cdf37eb7b Removed execute permissions from README files. 11 anni fa
Rakefile f20d760972 Updates the Rakefile 11 anni fa
grpc.gemspec 4907df078e Update the version of googleauth to 0.4 11 anni fa

README.md

gRPC Ruby

A Ruby implementation of gRPC.

Status

Alpha : Ready for early adopters

INSTALLATION PREREQUISITES

This requires Ruby 2.1, as the RPC API surface uses keyword args.

QUICK - INSTALL

  • Clone this repository.
  • Follow the instructions in INSTALL to install the gRPC C core.
  • If you don't have Ruby 2.1 installed, switch to the more detailed instructions below
  • Use bundler to install

    $ # from this directory
    $ gem install bundler && bundle install
    

Installing from source

  • Build the gRPC C core E.g, from the root of the gRPC git repo

    $ cd ../..
    $ make && sudo make install
    
  • Install Ruby 2.1. Consider doing this with RVM, it's a nice way of controlling the exact ruby version that's used.

    $ command curl -sSL https://rvm.io/mpapis.asc | gpg --import -
    $ \curl -sSL https://get.rvm.io | bash -s stable --ruby=ruby-2.1
    $
    $ # follow the instructions to ensure that your're using the latest stable version of Ruby
    $ # and that the rvm command is installed
    
  • Make sure your run source $HOME/.rvm/scripts/rvm as instructed to complete the set up of RVM

  • Install bundler

    $ gem install bundler
    
  • Finally, install the gRPC gem locally.

    $ # from this directory
    $ bundle install  # creates the ruby bundle, including building the grpc extension
    $ rake  # runs the unit tests, see rake -T for other options
    

CONTENTS

Directory structure is the layout for ruby extensions

  • ext: the gRPC ruby extension
  • lib: the entrypoint gRPC ruby library to be used in a 'require' statement
  • spec: Rspec unittest
  • bin: example gRPC clients and servers, e.g,

    stub = Math::Math::Stub.new('my.test.math.server.com:8080')
    req = Math::DivArgs.new(dividend: 7, divisor: 3)
    logger.info("div(7/3): req=#{req.inspect}")
    resp = stub.div(req)
    logger.info("Answer: #{resp.inspect}")