StdJsonIo
Starts a pool of workers that communicate with an external script via JSON over STDIN/STDOUT.
Originally written to use react-stdio but can be used with any process that reads a JSON object from STDIN and outputs JSON on STDOUT.
Installation
- Add
std_json_io
to your list of dependencies inmix.exs
:
def deps do
[{:std_json_io, "~> 0.1.0"}]
end
- Ensure
std_json_io
is started before your application:
def application do
[applications: [:std_json_io]]
end
Configuration
You can either configure as additional arguments of the use statement, or in your config file.
config :std_json_io,
pool_size: 5,
pool_max_overflow: 10,
script: Path.expand("node_modules/.bin/react-stdio", __DIR__)
pool_size
- see Poolboy options, option "size"pool_max_overflow
- See Poolboy options, option "max_overflow"script
- the script to run for the IO server
Usage example
{:ok, data} = StdJsonIo.json_call(%{"component" => "my/component.js"}
# or
data = StdJsonIo.json_call!(%{"component" => "my/component.js"}
Development
There are some tests taking long to run (testing timeouts, long replies, etc.) with tag long: true
which are excluded by default. To run all the tests including long, you have to run mix test --include long:true