This application demostrates how to use Twilio and TwiML to perform automatic phone surveys.
- Clone the repository, copy the included
env.example
as.env
and customize it to your needs. The application only requires a running database - Use composer to install the app's dependencies by running
composer install
in the repo's root - Run the database migrations using
php artisan migrate
. If the database is configured correctly in.env
this will get you a working database - In order to run the application you will need at least one
survey. The repository includes a sample survey you can use to test
the application. Run
php artisan surveys:load bear_survey.json
to load a survey about bears into your database. If you have deployed to Heroku using the button you already have this survey loaded.
For this demo it's necessary that your local application instance is
accessible from the Internet. The easiest way to accomplish this
during development is using ngrok. If you're
running OS X you can install ngrok using Homebrew by running brew install ngrok
. First you will need to run the application:
php artisan serve
After this you can expose the application to the wider Internet by running (port 8000 is the default for Laravel):
ngrok 8000
You will need to provision at least one Twilio number with voice capabilities so the application's users can take surveys. You can do that here. Once you have a number you need to configure your number to work with your application. Open the number management page and open a number's configuration by clicking on it.
Next, edit the "Request URL" field under the "Voice" section and point
it towards your ngrok-exposed application /first_survey
route. Make
sure the method is set to POST. If you have are trying out the Heroku
application you need to point Twilio to
http://<your-app-name>.herokuapp.com/first_survey
. See the image
below for an example:
Give your number a call, answer the questions about bears and then go to:
http://localhost:8000/survey/1/results
The results of the survey should be there.
The tests interact with the database so you'll first need to migrate
your test database. First, set the DATABASE_URL_TEST
and then run:
php artisan migrate
The tests then can be run using
phpunit