Skip to content
This repository has been archived by the owner on Jun 28, 2024. It is now read-only.

Guide to Bonnie Rake Tasks

Matt Mayer edited this page Aug 20, 2019 · 61 revisions

General

Rails rake tasks are by default run against the development database; to run a rake task against a different environment such as production add RAILS_ENV=<environment>, for example

bundle exec rake bonnie:db:resave_measures RAILS_ENV=production 

Granting and Revoking Access

Rake tasks can be used to grant and revoke access to the admin role (used for administering the site), the portfolio role (used for creating sets of test patients across measures, such as for Cypress test decks), the dashboard role (which makes the complexity and change dashboard available to a user) and the dashboard_set role (which makes all measures loaded in a user account available on the complexity and change dashboard). The various tasks include

bundle exec rake bonnie:users:grant_admin EMAIL="<user-email>"
bundle exec rake bonnie:users:revoke_admin EMAIL="<user-email>"

bundle exec rake bonnie:users:grant_portfolio EMAIL="<user-email>"
bundle exec rake bonnie:users:revoke_portfolio EMAIL="<user-email>"

bundle exec rake bonnie:users:grant_dashboard EMAIL="<user-email>"
bundle exec rake bonnie:users:revoke_dashboard EMAIL="<user-email>"

bundle exec rake bonnie:users:grant_dashboard_set EMAIL="<user-email>"
bundle exec rake bonnie:users:revoke_dashboard_set EMAIL="<user-email>"

Moving Measures Between Accounts

It's possible to move a measure from one user account to another, moving all test patient records and copying all value sets:

bundle exec rake bonnie:users:move_measure SOURCE_EMAIL="<source-user-email>" DEST_EMAIL="<destination-user-email>" CMS_ID="<measure-cms-id>"

Copying Patients between Measures and (optionally) Accounts (Currently only available on the cql4bonnie branch)

This will copy (not move) patients from one measure on one user account to the same (or another) measure on another account (optionally the same account).

bundle exec rake bonnie:users:copy_measure_patients SOURCE_EMAIL="<source-user-email>" DEST_EMAIL="<destination-user-email>" SOURCE_CMS_ID="<source-measure-cms-id>" DEST_CMS_ID="<destination-measure-cms-id>"

Copying test cases (e.g. patients) from production to alpha (a.k.a. Patient Transfers)

  1. First export the patients from production, something like:

    bundle exec rake bonnie:patients:export_patients [email protected] HQMF_SET_ID=93F3479F-75D8-4731-9A3F-B7749D8BCD37 FILENAME=CMS72_patients.json

    Substitute in the appropriate email, HQMF set id, and a unique filename. Note: on the AHRQ-hosted sites you must also include the flag RAILS_ENV=production

  2. Test locally, and after there are no issues, import patients into alpha, something like:

    bundle exec rake bonnie:patients:import_patients [email protected] HQMF_SET_ID=93F3479F-75D8-4731-9A3F-B7749D8BCD37 FILENAME=CMS72_patients.json MEASURE_TYPE=CQL

Exporting a User's Test Patient Record Spreadsheets

Users can export their test patient data with corresponding calculation results in excel format using the web interface; there's a rake task that allows the same spreadsheets to be generated for a user account, one spreadsheet per measure:

bundle exec rake bonnie:users:export_spreadsheets USER_EMAIL="<user-email>"

The measures are exported into files with the name <measure-cms-id>.xlsx

Resetting a Database and Loading Basic Data

For development or demonstration purposes it can be useful to reset a Bonnie database and populate it with some basic data:

bundle exec rake bonnie:db:reset

This can be limited to a smaller set of data by using the DEMO flag

bundle exec rake bonnie:db:reset DEMO=true

This task clears all existing data and populates the database with a single user account with some measures loaded:

Username: [email protected]
Password: b0nn13

Re-run Measure Post-save Processing Steps

When measures are saved, some actions are completed triggered by the save just prior to writing the measure to the database, such as calculating measure complexity. This rake task re-saves all measures in the database:

bundle exec rake bonnie:db:resave_measures

Note that this does not regenerate the measure calculation JavaScript, to do that see the reset_js task.

Backup the Bonnie Database

The contents of a Bonnie MongoDB database can be dumped to a backup file using

bundle exec rake bonnie:db:dump

This can be used for creating snapshots for, say, debugging or as part of a regular backup process. If used as part of a regular backup process there's a companion rake task that prunes the database dumps, keeping daily snapshots for the most recent month but deleting older files so as to only keep weekly snapshots for older backups:

bundle exec rake bonnie:db:prune_dumps

Shifting Dates in Patient Records

Bonnie provides the same measure period for all users; historically this has been set to the full year of 2012, and typically isn't changed on deployed servers because changing it would change the results of most calculations. When using Bonnie to generate patient data for specific purposes, such as Cypress test decks, it can be useful to change the measure period. When making that change, it can be necessary to shift the date information within patient records. This can be done via a rake task:

bundle exec rake bonnie:patients:date_shift EMAIL="<user-email>" DIR=<forward|backward> YEARS=<number> MONTHS=<number> WEEKS=<number> DAYS=<number> HOURS=<number> MINUTES=<number> SECONDS=<number>

Working with VSAC

Value sets are sets of codes (ICD-9, ICD-10, SNOMED, LOINC, etc) grouped together to represent a single concept for use in the context of a measure, and represented by an OID (Object IDentifier). Bonnie loads value set information from VSAC (the NLM Value Set Authority Center, at https://vsac.nlm.nih.gov/). There are two rake tasks for working with value sets. The first allows the contents of a value set to be looked up given the OID:

bundle exec rake bonnie:vsac:lookup_oid OID=<oid> USERNAME=<vsac-username> PASSWORD=<vsac-password>

The second retrieves the current listing of VSAC expansion profiles from VSAC. Expansion profiles (ie "MU2 Update 2015-05-01") are a type of versioning, needed to allow different sets of codes to be present in value sets at different times. Retrieve the list of these using

bundle exec rake bonnie:vsac:get_profiles USERNAME=<vsac-username> PASSWORD=<vsac-password>

Creating Complexity and Change Dashboard Datasets

The complexity and change dashboard allows users with dashboard access to compare sets of measures. The way Bonnie handles these sets of measures is via special purpose user accounts, not intended for login but just used as a way of aggregating measures. Sets of measures can be loaded into these accounts via a rake task:

bundle exec rake bonnie:dashboard:load_measures FILE=<zip-of-zipped-measures-file> EMAIL=<user-account> VSAC_USERNAME=<vsac-username> VSAC_PASSWORD=<vsac-password>

This task takes the zip files that CMS uses to distribute sets of measures (ie the 2016 EP measures available at https://ecqi.healthit.gov/system/files/ecqm/2016/EP/2014_eCQM_EligibleProfessional_April2016.zip) which contain further zip files, one for each measure. The task will create a new user account with the email provided if necessary (otherwise using an existing account), generate a random password for that account (the password is not needed since the account does not need to be logged into), set the account to be a dashboard set account, and load each measure into the account.

Running Calculation and Colorization Regression Tests

The eCQM calculation engine used by Bonnie, https://github.com/projecttacoma/hqmf2js, is an extremely complex piece of software. When changes need to be made, it is very useful to be able to perform regression testing to ensure that only the desired targeted behavior changes occur. There are some rake tasks in Bonnie that allow all the patient records loaded into a Bonnie instance to be used as a regression test.

There are two sets of regression tests, which operate in a very similar fashion but target slightly different parts of the calculation process. The first (Calculation Tests) targets the simple end results of the calculation on a population level (ie IPP, NUMER, DENOM, etc), while the second (Colorization Tests) targets the calculation rationale, which includes detailed information on intermediate calculation results, and the specificsRationale, which factors the results of specific occurrence calculations into the intermediate calculation results and is used when highlighting the logic when displayed in Bonnie.

Calculation Tests

To run the calculation tests, first set up the development environment to a state before any code changes are present, then run

bundle exec rake bonnie:calculation_tests:prime_regression

This calculates every patient record in the Bonnie DB against the measure it's associated with and stores the calculation result in the database. After the prime step completes, update the development environment to a state that includes the code changes to be tested and run

bundle exec rake bonnie:calculation_tests:test_regression

This will compare the calculation results to the stored calculation results and display any discrepancies.

If the goal is to just run all the calculations and see if there are execution errors, without actually considering results, run the following task:

bundle exec rake bonnie:calculation_tests:calculate_all

Colorization Tests

To run the colorization tests, first set up the development environment to a state before any code changes are present, then run

bundle exec rake bonnie:colorization_tests:prime_regression

This calculates every patient record in the Bonnie DB against the measure it's associated with and stores the rationale and specificsRationale in the database. After the prime step completes, update the development environment to a state that includes the code changes to be tested and run

bundle exec rake bonnie:colorization_tests:test_regression

This will compare the calculation results to the stored calculation results and display any discrepancies.

HQMF and SimpleXML Parser Comparison

Note: These tasks have mostly been superseded by tests in HealthDataStandards which compare models generated from HQMF with SimpleXML, but may still be useful.

QDM logic based eCQMs are represented using the HQMF standard. The MAT also exports eCQMs in a format called SimpleXML, which while not a standard is still a useful representation of eCQMs since it can be compared to the HQMF format. Bonnie can import measures in SimpleXML format because support was implemented during a period when the MAT was not exporting any HQMF, only SimpleXML. Two rake tasks allow some comparisons to be made between SimpleXML and HQMF measures. The first creates an HTML file that, when opened, displays the human readable QDM logic derived from each measure format:

bundle exec rake bonnie:parser_comparison:create_html FILE=<measure-zip-file> VSAC_USERNAME=<vsac-username> VSAC_PASSWORD=<vsac-password>

The <measure-zip-file> is a MAT file that contains both the HQMF and SimpleXML XML files. The second task takes the two measure formats and finds any existing appropriate patients created for these measures (based on the hqmf_set_id) and calculates each patient against the model generated from each format, and reports on any discrepancies:

bundle exec rake bonnie:parser_comparison:compare_calculation FILE=<measure-zip-file> VSAC_USERNAME=<vsac-username> VSAC_PASSWORD=<vsac-password>

Fixture Export Tool

The fixture export tool will create test-ready fixtures from an extant database. Before using this tool, make sure to load a copy of the desired database and set the database property in config/mongoid.yml

The fixture export task can be run from the command line as follows:

bundle exec rake bonnie:fixtures:generate_backend_fixtures

This command takes the following arguments:

cms_hqmf: Use cms or hqmf id.
   values: cms, hqmf
path: Fixture path.
user_email: email of user to export
measure_id: id of measuer to export

Ex: bundle exec rake bonnie:fixtures:generate_backend_fixtures[cms,test/CMS55v5,fake@fake,CMS55v5]

It is also possible to generate frontend fixtures using this tool using:

bundle exec rake HDS:test:generate_frontend_fixtures

With the arguments

cms_hqmf: Use cms or hqmf id.
   values: cms, hqmf
path: Fixture path.
user_email: email of user to export
measure_id: id of measure to export

Ex: bundle exec rake bonnie:fixtures:generate_frontend_fixtures[cms,test/CMS55v5,initialLoad,fake@fake,CMS55v5]

On the cql4bonnie branch, cql measures can be exported in a similar manner with one notable exception: Frontend fixtures add two fields to allow the user to define a single patient to export. The cql frontend export arguments are:

cms_hqmf: Use cms or hqmf id.
   values: cms, hqmf
path: Fixture path.
user_email: email of user to export
measure_id: id of measure to export
patient_first_name: first name of patient to export.  Do not include this argument if you want to export all patients.
patient_last_name: last name of the patient to export. Do not include this argument if you want to export all patients.

Ex: Export with all patients 
bonnie:fixtures:generate_frontend_cql_fixtures[cms,test/CMS55v5,fake@fake,CMS55v5]

Ex: Export with specific patient
bonnie:fixtures:generate_frontend_cql_fixtures[cms,test/CMS55v5,fake@fake,CMS55v5,fakeFirst,fakeLast]

For the CQL-based measures, we have adopted a convention of exporting measures to the "CQL/CMSxxx" folder, where xxx is the measure ID without version, i.e. CQL/CMS741

Generating VCR Cassettes

VCR cassettes allow you to replay the network traffic for unit tests, useful for when you need to upload a measure in a unit test. They are stored in bonnie/test/fixtures/vcr_cassettes.

First, go on outernet, turn on alwaysonsuspend, and reset your http_proxy and https_proxy environmental variables.

To generate them, wrap the code you want to use the cassette in this:

VCR.use_cassette("valid_vsac_response_<unique_name_here>") do
  post :create, {vsac_date: '11/07/2017 <CHANGE ME>', include_draft: true, measure_file: measure_file, measure_type: 'ep', calculation_type: 'patient', vsac_username: ENV['VSAC_USERNAME'], vsac_password: ENV['VSAC_PASSWORD']}
   ...
end

Note you need to change the vsac_date to be the date of the creation of the cassette.

When you run the test, it will generate the .yml file that is the cassette. You may need to comment out all other tests in order to get around proxy issues, but that may not be necessary if it doesn't need to use the JAR.

You have to pass in your VSAC credentials in the command line like this:

$ bundle exec rake test TEST=/Users/lwosborne/git/bonnie/test/functional/measures_controller_test.rb VSAC_USERNAME=<your username here> VSAC_PASSWORD=<your password here>

Update the .yml file to remove your username and password, replacing the line with:

string: username=<VSAC_USERNAME>&password=<VSAC_PASSWORD>

You should verify that they do not appear there before committing the cassette to github. Also, clear your BASH history (history -c on mac) or at least remove the line containing your password.

For an example see test "measure show with period or special chars in key" in bonnie/test/functional/measures_controller_test.rb