data:image/s3,"s3://crabby-images/a9972/a9972cb79c7252d354deb85ae2dd9aabd8e1fe82" alt="boojs: A unix tool to execute headless browser javascript"
[data:image/s3,"s3://crabby-images/22ff5/22ff54c3a9603a93e6f5fd9aa5a7bd6255260a46" alt="Gem Version"](http://badge.fury.io/rb/boojs)
[data:image/s3,"s3://crabby-images/bc93c/bc93c2f8ba1abe5ad07e7f8407905e8c1d57020c" alt="Build Status"](https://travis-ci.org/sotownsend/boojs)
[data:image/s3,"s3://crabby-images/a976a/a976aa884808881640c75809471527dad09dd5a8" alt="Bitdeli Badge"](https://bitdeli.com/free "Bitdeli Badge")
[data:image/s3,"s3://crabby-images/ce9cc/ce9cc4f237b58b2e152b1bac233ddca90cefc765" alt="License"](https://github.com/sotownsend/BooJS/blob/master/LICENSE)
# What is this?
A simple tool that allows you to execute javascript in the command line as if you were in a browser. Built on-top of [PhantomJS](http://phantomjs.org/) and
acts as a well-behaved unix tool.
**Wait, isn't this just NodeJS? No, they are for different things. BooJS gives you the full DOM, you can call `document` in BooJS and import arbitrary browser javascript libraries.**
# Setup
```sh
#Setup
gem install boojs
```
# Usage
#### SYNOPSIS
```sh
boojs [-e statement] [-t timeout] [-v file] [file]
```
#### DESCRIPTION
The following options are available:
* `-e` - Pass a javascript statement to execute after the file (if a file is provided) and then immediately terminate unless `-t` is set.
* `-t` - Close the program after N seconds have passed, unless an exception is raised
* `-v` - Verify that a file contains no javascript syntax errors. Returns 0 if there are no errors.
#### EXAMPLES
Open a javascript pipe that reads from stdin, writes via console.log to stdout, prints exceptions via stderr, and exits with a return code of 1 if there are errors.
```sh
(sh)>boojs
```
Same as `boojs` but read the javascript file before reading from stdin. (i.e. preload a javascript file into your environment)
```sh
(sh)>boojs code.js
```
Execute a javascript statement, and then immediately exit. Exceptions will return 1.
```sh
(sh)>boojs -e "console.log(document);"
```
Execute a javascript statement, and then wait 4 seconds before exiting. Exceptions will return 1 and end execution early.
```sh
(sh)>boojs -e "console.log(document); -t 4"
```
Verify that a file contains no javascript runtime initialization errors
```sh
(sh)>boojs -v code.js
(sh)>echo $?
0
```
## Requirements
- Ruby 2.1 or Higher
## Communication
- If you **found a bug**, submit a pull request.
- If you **have a feature request**, submit a pull request.
- If you **want to contribute**, submit a pull request.
---
## FAQ
### When should I use boojs?
When you need to test javascript code that needs to run in a browser but don't necessarily need to test the UI components.
### What's Fittr?
Fittr is a SaaS company that focuses on providing personalized workouts and health information to individuals and corporations through phenomenal interfaces and algorithmic data-collection and processing.
* * *
### Creator
- [Seo Townsend](http://github.com/sotownsend) ([@seotownsend](https://twitter.com/seotownsend))
## License
boojs is released under the MIT license. See LICENSE for details.