This cli helps with bulk tests to the Autopilot infraestructure. It uses csv file fixtures as input and returns a json report if needed.
npm install -g ta-bulk-testing
In order for this application to run, it requires you to set three twilio variables.
How to get them?:
There are three ways that the cli will try to get those variables from:
- The
Environment variables
given by the OS, with the names ofACCOUNT_SID
,AUTH_TOKEN
andASSISTANT_SID
. - The cli parametes as
account_sid
,auth_token
,assistant_sid
. - A file generated by
twilio autopilot cli
which is located in ~/.twilio/config.json.
If any of those three places have the variables, it will raise an exception instead of running.
Now you're able to run the project in the cli.
This is a cli program that helps you make bulk testing to
twilio's autopilot infraestructure. It uses a csv file fixtures
as input and returns a json report if needed.
Usage
$ ta-bulk-testing <action>
Options
--expand, -e Take the fixtures file and expand it.
This process relies on "intent-utterance-expander"
project.
--export, -x Export report to a given name.
Eg. --export report.json.
If you send 'export' without a filename,
it will output the report in output.json.
--fixtures, -f Import an specific fixture file. CSV Format
is mandatory.
--language, -l Language for the testing. Default: 'en-US'
--account_sid, -s Twilio's account SID, default will try to
lookup for it in ~/.twilio/config.json.
--auth_token, -t Twilio's authorization token, default will
try to lookup for it in ~/.twilio/config.json.
--assistant_sid, -a Twilio's specific assistant ID for this testing.
Examples
$ ta-bulk-testing --expand --fixtures ./fixtures/en-US.csv --export
In order to generate the fixtures, this project relies on Intent Utterance Expander in order to expand the samples in your file. The first row, should be task, intent
so that the library can match correctly the sample to the task that the bot should respond.
task, samples
hello_world, (Hi | Hello | Hey) I am Erick
task, samples
hello_world, Hi I am Erick
hello_world, Hello I am Erick
hello_world, Hey I am Erick
hello_world, Hey I am Erick
Note: It's suggested that you use the expander to minimize the size of your fixture file.
In the folder fixtures
of this project, there's an example .csv
file using the expander feature.
In case you want to add test cases that resolves as null
, you should do the following:
task, samples
null, this is a samples that should not be resolved by the NLR.
In order to install it, just clone the project and install the dependencies.
git clone <repo>
yarn install # I'm using yarn, but you can you npm to install the dependencies.
In order to be able to run this project, you'll need to have an .env
file with your credentials.
cp .env.example .env
- Fill your
ACCOUNT_SID
,AUTHO_TOKEN
andASSISTANT_SID
.
- [ ] Refactor the code to receive the twilio's variables from the command.
- [ ] Add testing