This is a virtual coach system that will coach users into being more physically active and stop smoking. This is the main repository for running the full application. Individual components of the app are in separate repositories:
- virtual-coach-rasa
Contains code for rasa bot, the core of the virtual coach system.
Also includes
scheduler
, andonboarding
- niceday-components Components for interfacing the virtual-coach with the niceday app and sensehealth server.
- niceday_client Python package for interacting with the niceday-api component of the PerfectFit virtual coach.
- virtual-coach-db Code around database for virtual coach system
Please cite this software based on the entry in zenodo
See software development planning document
Details about the architecture design and the interactions among the components can be found here.
- Ask any of this project's contributors to request an invitation for installing NiceDay alpha version
- Download and install the NiceDay alpha version on your phone using the link in the invitation email
- Open the downloaded app and create a client account. This is the account you will use to test functionality in the app and talk to the virtual coach. It is possible to use the same credentials for both the alpha and normal NiceDay app. NB: In the creation process, select "I want to use the app independently" when asked.
- Login to the downloaded app on your phone with the account you just created.
- Ask any of the project's contributors to provide you with a personal development 'Virtual Test Therapist' account. The virtual coach system will use this account.
- Send a connection request to your 'Virtual Test Therapist' account from the app: Go to the 'support' panel in the app. Click on the '+' symbol at the top right of the panel. Search for the name of the therapist account you want to connect with. Send a connection request.
- Login with the therapist account credentials on https://alpha.niceday.app/ and accept the connection request from the client account.
- Create a file called
.env
in the root of this app. Save the therapist email address, password and ID in your.env
file as THERAPIST_EMAIL_ADDRESS, THERAPIST_PASSWORD and THERAPIST_ID, respectively. In the .env file theTEST_USER_ID
must be also contained. This id will be used to populate the DB with test data How to get the ID is explained here. The .env file must also containDATABASE_URL
, which points to the location of the perfectfit database on a running postgres server. For local development this will normally be:postgresql+psycopg2://root:root@db/perfectfit
See .env-example for a template. The values in.env-example
are already set to work for local runs with docker compose (with the exception of THERAPIST_EMAIL_ADDRESS, THERAPIST_ID and THERAPIST_PASSWORD, which must be provided). - Some of the resources needed to run the application are to be pulled from the GitHub repositories. To allow the pulling, a SSH key has to be created and added to the ssh-agent
- Since the goalie-js repository is private, access to the senseobservationsystems/goalie-js.git repository has to be obtained.
Run script/server
script to serve the application.
NB: If you get a problem about "subdir not supported" during execution of script/server
,
set the buildkit feature to false in Docker.
On Windows, you can do this in Docker Desktop>Settings>Build engine. In addition, make sure that "Use Docker Compose V2" in the General settings in Docker Desktop is not selected.
On Mac, you can do this in Docker Desktop>Preferences>Docker Engine. Edit the displayed JSON so that "buildkit": false
, then restart Docker Desktop.
NB: On Windows, make sure that core.autocrlf for git is set to false, by running : git config --global core.autocrlf false
Configure functionality depending on the deployment environment by setting the ENVIRONMENT
variable in your .env
file.
Possible values are ('prod', 'test', 'dev')
This will:
- toggle whether you want to have a delay in between messages ('prod'), or not ('test', 'dev').
To run the tests, Node.js has to be installed, using the installer.
NB: On Windows, make sure that the path to nodejs (default C:\Program Files\nodejs) is correctly added to the Path environment variable.
Run script/test
, or follow these steps:
- Run
npm install
- Run
script/bootstrap
script - Start everything with
docker compose up
. - Once all containers are initialised and healthy, run the tests by typing
script/cucumber
To run a specific feature, add the path to the specific .feature file to the script/cucumber
script.
For example, to run the selfdialog feature, the following command has to be used: ./node_modules/.bin/cucumber-js features/selfdialog.feature
The testing procedure is build using cucumber.
By running the tests, the features implemented in the .feature files contained in feature folder are executed, using the implementation contained in features/agenda_steps.js
.
Each scenario in the feature represents all the steps of one dialog, and the testing executes all of them and verifies that the result is the expected one.
In case of modifications to the dialogs, the testing steps have to be updated accordingly, by modifying the steps in the .feature file and their implementation in the agenda_steps.js file.
A troubleshooting guide is written to help debugging when running in problems with the full system. It is found in
docs/troubleshooting_guide.md
or here.
By default this setup use the main branch for each component. As a developer you often want to use a different branch, or a local clone of the repository.
If you want to use a local clone, we suggest the following steps.
We use the virtual-coach-db
repository as an example.
- Build a docker image based on your local repository.
cd
into your localvirtual-coach-db
repository, then dodocker build . -t virtual-coach-db-local
. - In
docker-compose.yml
replacebuild: https://github.com/PerfectFit-project/virtual-coach-db.git#main
withimage: virtual-coach-db-local
. Note that the name of the image should correspond with the tag that you gave to it in the previous step
NB: Don't commit changes to docker-compose.yml
Alternatively you can point docker-compose
to a different branch:
In docker-compose.yml
replace build: https://github.com/PerfectFit-project/virtual-coach-db.git#main
with build: https://github.com/PerfectFit-project/virtual-coach-db.git#feature-branch
.
NB: Don't commit changes to docker-compose.yml
If you want to rebuild the images that docker-compose uses
(often you want this, because you want the latest changes to take effect), run:
docker compose up --build
If you want to completely make sure that all docker images are rebuilt without cache, and the database will be reinitialized, do:
docker compose down --volumes && docker compose build --no-cache && docker compose up
Test data is automatically loaded into the database using a script in
virtual-coach-db
helper/populate_db.py.
So if you want to test with different data (particularly if you have updated the db schema by changing models.py
) you have to update this.
Or spin up the database and manipulate the data in the running database.
NB: The database is saved automatically by docker. To empty the volume that stores the database do:
docker compose down --volumes
Next time you run the application the database will be reinitialized.
For deployment of the virtual coach to cloud, please read the instructions in the README in the ansible/ directory of this repository.