Cargando…

Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software

BACKGROUND: Moving to electronic health records (EHRs) confers substantial benefits but risks unintended consequences. Modern EHRs consist of complex software code with extensive local configurability options, which can introduce defects. Defects in clinical decision support (CDS) tools are surprisi...

Descripción completa

Detalles Bibliográficos
Autores principales: Basit, Mujeeb A, Baldwin, Krystal L, Kannan, Vaishnavi, Flahaven, Emily L, Parks, Cassandra J, Ott, Jason M, Willett, Duwayne L
Formato: Online Artículo Texto
Lenguaje:English
Publicado: JMIR Publications 2018
Materias:
Acceso en línea:https://www.ncbi.nlm.nih.gov/pmc/articles/PMC5924365/
https://www.ncbi.nlm.nih.gov/pubmed/29653922
http://dx.doi.org/10.2196/medinform.9679
_version_ 1783318543444475904
author Basit, Mujeeb A
Baldwin, Krystal L
Kannan, Vaishnavi
Flahaven, Emily L
Parks, Cassandra J
Ott, Jason M
Willett, Duwayne L
author_facet Basit, Mujeeb A
Baldwin, Krystal L
Kannan, Vaishnavi
Flahaven, Emily L
Parks, Cassandra J
Ott, Jason M
Willett, Duwayne L
author_sort Basit, Mujeeb A
collection PubMed
description BACKGROUND: Moving to electronic health records (EHRs) confers substantial benefits but risks unintended consequences. Modern EHRs consist of complex software code with extensive local configurability options, which can introduce defects. Defects in clinical decision support (CDS) tools are surprisingly common. Feasible approaches to prevent and detect defects in EHR configuration, including CDS tools, are needed. In complex software systems, use of test–driven development and automated regression testing promotes reliability. Test–driven development encourages modular, testable design and expanding regression test coverage. Automated regression test suites improve software quality, providing a “safety net” for future software modifications. Each automated acceptance test serves multiple purposes, as requirements (prior to build), acceptance testing (on completion of build), regression testing (once live), and “living” design documentation. Rapid-cycle development or “agile” methods are being successfully applied to CDS development. The agile practice of automated test–driven development is not widely adopted, perhaps because most EHR software code is vendor-developed. However, key CDS advisory configuration design decisions and rules stored in the EHR may prove amenable to automated testing as “executable requirements.” OBJECTIVE: We aimed to establish feasibility of acceptance test–driven development of clinical decision support advisories in a commonly used EHR, using an open source automated acceptance testing framework (FitNesse). METHODS: Acceptance tests were initially constructed as spreadsheet tables to facilitate clinical review. Each table specified one aspect of the CDS advisory’s expected behavior. Table contents were then imported into a test suite in FitNesse, which queried the EHR database to automate testing. Tests and corresponding CDS configuration were migrated together from the development environment to production, with tests becoming part of the production regression test suite. RESULTS: We used test–driven development to construct a new CDS tool advising Emergency Department nurses to perform a swallowing assessment prior to administering oral medication to a patient with suspected stroke. Test tables specified desired behavior for (1) applicable clinical settings, (2) triggering action, (3) rule logic, (4) user interface, and (5) system actions in response to user input. Automated test suite results for the “executable requirements” are shown prior to building the CDS alert, during build, and after successful build. CONCLUSIONS: Automated acceptance test–driven development and continuous regression testing of CDS configuration in a commercial EHR proves feasible with open source software. Automated test–driven development offers one potential contribution to achieving high-reliability EHR configuration. Vetting acceptance tests with clinicians elicits their input on crucial configuration details early during initial CDS design and iteratively during rapid-cycle optimization.
format Online
Article
Text
id pubmed-5924365
institution National Center for Biotechnology Information
language English
publishDate 2018
publisher JMIR Publications
record_format MEDLINE/PubMed
spelling pubmed-59243652018-05-03 Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software Basit, Mujeeb A Baldwin, Krystal L Kannan, Vaishnavi Flahaven, Emily L Parks, Cassandra J Ott, Jason M Willett, Duwayne L JMIR Med Inform Original Paper BACKGROUND: Moving to electronic health records (EHRs) confers substantial benefits but risks unintended consequences. Modern EHRs consist of complex software code with extensive local configurability options, which can introduce defects. Defects in clinical decision support (CDS) tools are surprisingly common. Feasible approaches to prevent and detect defects in EHR configuration, including CDS tools, are needed. In complex software systems, use of test–driven development and automated regression testing promotes reliability. Test–driven development encourages modular, testable design and expanding regression test coverage. Automated regression test suites improve software quality, providing a “safety net” for future software modifications. Each automated acceptance test serves multiple purposes, as requirements (prior to build), acceptance testing (on completion of build), regression testing (once live), and “living” design documentation. Rapid-cycle development or “agile” methods are being successfully applied to CDS development. The agile practice of automated test–driven development is not widely adopted, perhaps because most EHR software code is vendor-developed. However, key CDS advisory configuration design decisions and rules stored in the EHR may prove amenable to automated testing as “executable requirements.” OBJECTIVE: We aimed to establish feasibility of acceptance test–driven development of clinical decision support advisories in a commonly used EHR, using an open source automated acceptance testing framework (FitNesse). METHODS: Acceptance tests were initially constructed as spreadsheet tables to facilitate clinical review. Each table specified one aspect of the CDS advisory’s expected behavior. Table contents were then imported into a test suite in FitNesse, which queried the EHR database to automate testing. Tests and corresponding CDS configuration were migrated together from the development environment to production, with tests becoming part of the production regression test suite. RESULTS: We used test–driven development to construct a new CDS tool advising Emergency Department nurses to perform a swallowing assessment prior to administering oral medication to a patient with suspected stroke. Test tables specified desired behavior for (1) applicable clinical settings, (2) triggering action, (3) rule logic, (4) user interface, and (5) system actions in response to user input. Automated test suite results for the “executable requirements” are shown prior to building the CDS alert, during build, and after successful build. CONCLUSIONS: Automated acceptance test–driven development and continuous regression testing of CDS configuration in a commercial EHR proves feasible with open source software. Automated test–driven development offers one potential contribution to achieving high-reliability EHR configuration. Vetting acceptance tests with clinicians elicits their input on crucial configuration details early during initial CDS design and iteratively during rapid-cycle optimization. JMIR Publications 2018-04-13 /pmc/articles/PMC5924365/ /pubmed/29653922 http://dx.doi.org/10.2196/medinform.9679 Text en ©Mujeeb A Basit, Krystal L Baldwin, Vaishnavi Kannan, Emily L Flahaven, Cassandra J Parks, Jason M Ott, Duwayne L Willett. Originally published in JMIR Medical Informatics (http://medinform.jmir.org), 13.04.2018. https://creativecommons.org/licenses/by/4.0/This is an open-access article distributed under the terms of the Creative Commons Attribution License (https://creativecommons.org/licenses/by/4.0/), which permits unrestricted use, distribution, and reproduction in any medium, provided the original work, first published in JMIR Medical Informatics, is properly cited. The complete bibliographic information, a link to the original publication on http://medinform.jmir.org/, as well as this copyright and license information must be included.
spellingShingle Original Paper
Basit, Mujeeb A
Baldwin, Krystal L
Kannan, Vaishnavi
Flahaven, Emily L
Parks, Cassandra J
Ott, Jason M
Willett, Duwayne L
Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title_full Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title_fullStr Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title_full_unstemmed Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title_short Agile Acceptance Test–Driven Development of Clinical Decision Support Advisories: Feasibility of Using Open Source Software
title_sort agile acceptance test–driven development of clinical decision support advisories: feasibility of using open source software
topic Original Paper
url https://www.ncbi.nlm.nih.gov/pmc/articles/PMC5924365/
https://www.ncbi.nlm.nih.gov/pubmed/29653922
http://dx.doi.org/10.2196/medinform.9679
work_keys_str_mv AT basitmujeeba agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT baldwinkrystall agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT kannanvaishnavi agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT flahavenemilyl agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT parkscassandraj agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT ottjasonm agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware
AT willettduwaynel agileacceptancetestdrivendevelopmentofclinicaldecisionsupportadvisoriesfeasibilityofusingopensourcesoftware