Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dafalcon/subshell

Easily run shell commands from within ruby
https://github.com/dafalcon/subshell

Last synced: 26 days ago
JSON representation

Easily run shell commands from within ruby

Awesome Lists containing this project

README

        

# Subshell

This gem makes it easy to run shell commands from within ruby. It will
raise an exception if the command fails with an unexpected exit status. By
default it automatically redirects STDERR to STDOUT when executing the
command. The return value is the output of the command with whitespace
automatically stripped.

Example usage:
```ruby
Subshell.exec 'echo hello world' # => "hello world"
Subshell.exec 'echo hello world', strip_whitespace: false # => "hello world\n"
Subshell.exec 'exit 1' # => raises RuntimeError
```

## Options

|Option|Default|Description|
|------|-------|-----------|
| redirect_stderr_to_stdout | true | append 2>&1 to the command |
| expected_status | 0 | raise if the exit status of the command does not equal this value |
| strip_whitespace | true | strip whitespace from the command's output |
| logger | Rails logger (if available) or nil | log debug info, if set |
| debug | false | print debug info to STDOUT. does not affect logger output |
| quiet | false | disable logger and STDOUT logging. useful to suppress sensitive or verbose data from being logged |

These options can be set per call. For convenience, the defaults can be changed with a call to Subshell.set_defaults:

```
Subshell.set_defaults(strip_whitespace: false)
Subshell.exec 'echo hello world' # => 'hello world\n'
```

## Installation

Add this line to your application's Gemfile:

```ruby
gem 'subshell'
```

And then execute:

$ bundle

Or install it yourself as:

$ gem install subshell

## Development

After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.

## Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/falconed/subshell. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.

## License

The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).