# SDK - CLI
Welcome to the SDK CLI! This section focuses on how you can use Workato's Connector SDK Ruby gem (SDK gem) to bring your connector development local.
# What is the SDK gem?
The SDK Gem is a Ruby software package that emulates how Workato would parse and execute your connector code.
The gem is:
- Easy to install
- Can be run on the command line
- Allows you to develop connectors from the comfort of your chosen IDE (integrated development environment)
To use the SDK gem, you should be familiar with:
- The Connector SDK at an intermediate level
- Command line tools and how to use them
- rSpec for unit testing. Check out the rSpec docs (opens new window) to learn more.
- VCR. Check out this general guide (opens new window) to learn more about VCR, or this getting started guide (opens new window) to dive right in.
# Benefits of using CLI
- Develop in your chosen IDE by bringing connector development local
- Enhanced debugging tools
- Improved collaboration with teammates
- Ability to implement unit tests and CI/CD processes, improving deployment stability
- Ability to implement automated deployments
# SDK gem features
Still not sure if the SDK gem is right for you? Below, we highlight some key differences between building a connector with the Cloud SDK console and the SDK gem.
|Cloud SDK Console||SDK Gem|
|Testing specificity||Able to test connections, actions and triggers in their entirety||Able to test specific keys of a connector separately. For example: |
|UI testing||Able to test the exact look and feel of input and output fields. For example: Dynamic input and output fields||No UI, but able to quickly evaluate resultant Workato schema of input and output fields using CLI Utils|
|Unit testing||Not available||Able to convert CLI commands into unit tests quickly|
|Environment properties and lookup tables||No access to ||Able to store |
As we continue to improve on the SDK Gem and its capabilities, more features will be added.
# Connector development with the CLI
So, what does connector development look like for a team?
Below is an example process, though it could always be modified to fit your team's specific needs and workflows.
Let's look at this step by step:
Local development. Run your connector locally. The SDK gem's handy CLI commands can help you build, test, and debug your connector as you work.
Test in your Workato workspace. Ensuring functionality is important, but so is the UX of your connector. You can push your connector to your personal Workato workspace, allowing you to test your connector in an actual recipe.
Push to Git. To collaborate with others, push your code to a Git repository. This might be GitHub, Gitlab, Bitbucket, or another provider.
Review and test. Review the changes made by your teammates and ensure the connector passes all unit tests.
Automated push to DEV. If desired, you can set up automated workflows in your repository to automatically push changes to your DEV workspace when pull requests are merged. This would allow you to trigger additional tests. For example: Recipe builders can conduct user acceptance testing to ensure the connector works as expected.
Release to production. Transition your connector through DEV > UAT > PROD environments through your standard recipe lifecycle management processes, ensuring that the connector - like your recipes - is fully tested before being released to production.
# Get started
Ready to start developing? Check out the Getting Started guide to get up and running!