Project

com-client

0.0
No commit activity in last 3 years
No release in over 3 years
Client abstractions for different types of client libraries.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 1.12.5
>= 11.2
>= 3.5

Runtime

>= 0.2.1
 Project Readme

::Com::Client

Common parts of clients of any sort. Mostly it will be different kinds of web API clients, but there is also an example of using same structure to built binary protocol client to create and send data frames through RS-485 port.

Overview

This library(gem) contains common abstractions (base classes and modules) for concrete clients. Those concrete clients implement interfaces and modules of the current library and use them to wire distinct componenets together.

Dependencies

Runtime

Development

  • Bundler version 1.12.5 or higher
  • Other dependencies will be installed automatically by running bundle install from library's root directory.

Installation

Production

You can install this library manually with

gem install com-client

with resolving all of their dependencies manually.

The preffered way to install it is to rely on Bundler in your application.

Assuming that, add follow to your Gemfile.

gem "com-client", ">= 0.2.0"

And then execute from the directory with Gemfile (likely it should be your application's root directory):

$ bundle

Adding this library(gem) as a runtime dependency to other libraries(gems)

This is the most common use case of that library. Likely you already know how to do that, but for clarity sake here is some tips and links.

Add follow line to your library's gemspec file:

spec.add_runtime_dependency 'com-client', '>= 0.2'

See also official documentation on rubygems about adding runtime dependencies.

Development

While developming new library which depends on changes to com-client you likely want to test you changes to com-client with your own library.

To do this add runtime dependency in your library's gemspec file like described in previous section.

Then add gem definition for com-client to your library's Gemfile with :path parameter which points to root directory of your local copy of com-client.

If we assume that you have follow directory structure of git repositories:

~
|- projects
   |- com-client
   |- your-library

Then you have to add to your Gemfile something like follows:

gem "com-client",
  path: "../com-client"

After all run bundle install to let your changes to make affect.

Usage

Library's interactive prompt

To experiment with that code, run bin/console for an interactive prompt from project's root directory.

Documentation

Exceptions modules and classes hierarchy

Introduced namespace modules:

Introduced error tagging modules:

Development

After checking out the repo, run bin/setup to install dependencies. Then, run bin/console for an interactive prompt that will allow you to experiment. Run bundle exec com-client to use the code located in this directory, ignoring other installed copies of this gem.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in lib/com/client/version.rb, and then run bundle exec rake release to create a git tag for the version, push git commits and tags.

Testing

There are different ways to run tests. You can use the one which you used to.

$ rake # uses default rake task which is spec

or

$ rspec

or

$ rake spec

or

$ rspec spec/

Contributing

  1. Clone it: git clone git@github.com:com-rb/com-client.git
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Ensure all tests pass successfully
  5. Push to the branch (git push origin my-new-feature)
  6. Create a new Pull Request