2020-02-17 17:30:55 -05:00
import os
2021-01-06 11:17:41 -05:00
import json
2020-04-17 11:27:12 -04:00
2020-08-13 15:19:55 -04:00
from werkzeug . datastructures import MultiDict
2020-03-23 17:05:34 -04:00
os . environ [ " TESTING " ] = " true "
2020-02-17 17:30:55 -05:00
import unittest
2020-05-25 11:41:39 -04:00
import random
import string
2020-08-13 15:19:55 -04:00
from pb import app , db , session
from pb . forms import StudyForm , StudySponsorForm
2021-01-06 11:17:41 -05:00
from pb . ldap . ldap_service import LdapService
2021-04-13 12:07:34 -04:00
from pb . models import Study , RequiredDocument , Sponsor , StudySponsor , IRBStatus , Investigator , IRBInfo , StudyDetails
2020-08-13 15:19:55 -04:00
from example_data import ExampleDataLoader
2020-02-17 17:30:55 -05:00
2021-04-13 12:07:34 -04:00
2020-02-17 17:30:55 -05:00
class Sanity_Check_Test ( unittest . TestCase ) :
auths = { }
@classmethod
def setUpClass ( cls ) :
cls . ctx = app . test_request_context ( )
cls . app = app . test_client ( )
db . create_all ( )
@classmethod
def tearDownClass ( cls ) :
2021-03-25 13:14:17 -04:00
db . drop_all ( )
2020-02-17 17:30:55 -05:00
def setUp ( self ) :
2020-08-13 15:19:55 -04:00
ExampleDataLoader ( ) . clean_db ( )
2020-02-17 17:30:55 -05:00
self . ctx . push ( )
def tearDown ( self ) :
2020-08-13 15:19:55 -04:00
ExampleDataLoader ( ) . clean_db ( )
2020-02-17 17:30:55 -05:00
self . ctx . pop ( )
self . auths = { }
2020-08-13 15:19:55 -04:00
def load_sponsors ( self ) :
ExampleDataLoader ( ) . load_sponsors ( )
sponsors = session . query ( Sponsor ) . all ( )
num_lines = sum ( 1 for line in open ( ' pb/static/csv/sponsors.csv ' ) )
self . assertIsNotNone ( sponsors )
self . assertEqual ( len ( sponsors ) , num_lines - 1 )
return sponsors
2021-02-22 12:36:10 -05:00
def add_study ( self , title = None ) :
if title is None :
study_title = " My Test Document " + ' ' . join ( random . choices ( string . digits , k = 8 ) )
else :
study_title = title
2020-05-25 11:41:39 -04:00
study = Study ( TITLE = study_title , NETBADGEID = " dhf8r " )
2020-02-17 17:30:55 -05:00
form = StudyForm ( formdata = None , obj = study )
2020-04-17 11:27:12 -04:00
num_reqs = len ( form . requirements . choices )
self . assertGreater ( num_reqs , 0 )
for r in form . requirements :
form . data [ ' requirements ' ] . append ( r . data )
2021-04-06 12:23:13 -04:00
form . Q_COMPLETE . data = " ( ' No Error ' , ' Passed validation. ' ) "
2020-05-25 11:41:39 -04:00
r = self . app . post ( ' /new_study ' , data = form . data , follow_redirects = False )
assert r . status_code == 302
added_study = Study . query . filter ( Study . TITLE == study_title ) . first ( )
2020-02-17 17:30:55 -05:00
assert added_study
2020-04-17 11:27:12 -04:00
num_docs_before = RequiredDocument . query . filter ( Study . STUDYID == added_study . STUDYID ) . count ( )
self . assertEqual ( num_reqs , num_docs_before )
2020-08-13 15:19:55 -04:00
return added_study
def test_add_and_edit_study ( self ) :
""" Add and edit a study """
added_study : Study = self . add_study ( )
num_studies_before = Study . query . count ( )
num_docs_before = RequiredDocument . query . filter ( Study . STUDYID == added_study . STUDYID ) . count ( )
2020-04-17 11:27:12 -04:00
""" Edit an existing study """
2020-05-25 11:41:39 -04:00
added_study . title = " New Title " + ' ' . join ( random . choices ( string . digits , k = 8 ) )
2020-04-17 11:27:12 -04:00
form_2 = StudyForm ( formdata = None , obj = added_study )
for r in form_2 . requirements :
form_2 . data [ ' requirements ' ] . append ( r . data )
2021-04-06 12:23:13 -04:00
form_2 . Q_COMPLETE . data = " ( ' No Error ' , ' Passed validation. ' ) "
2020-04-17 11:27:12 -04:00
2020-05-25 11:41:39 -04:00
r_2 = self . app . post ( ' /study/ %i ' % added_study . STUDYID , data = form_2 . data , follow_redirects = False )
assert r_2 . status_code == 302
2020-04-17 11:27:12 -04:00
num_studies_after = Study . query . count ( )
edited_study = Study . query . filter ( Study . STUDYID == added_study . STUDYID ) . first ( )
assert edited_study
2020-02-17 17:30:55 -05:00
2020-04-17 11:27:12 -04:00
num_docs_after = RequiredDocument . query . filter ( Study . STUDYID == edited_study . STUDYID ) . count ( )
self . assertEqual ( num_docs_before , num_docs_after )
self . assertEqual ( num_studies_before , num_studies_after )
2020-08-13 15:19:55 -04:00
2021-04-13 12:07:34 -04:00
def test_delete_study ( self ) :
# Create study
study = self . add_study ( )
# Add requirements and Q_COMPLETE
form = StudyForm ( formdata = None , obj = study )
for r in form . requirements :
form . data [ ' requirements ' ] . append ( r . data )
form . Q_COMPLETE . data = " ( ' No Error ' , ' Passed validation. ' ) "
self . app . post ( ' /study/ %i ' % study . STUDYID , data = form . data , follow_redirects = False )
# Assert we have them
count = RequiredDocument . query . filter ( Study . STUDYID == study . STUDYID ) . count ( )
self . assertGreater ( count , 0 )
status = IRBStatus . query . filter ( IRBStatus . STUDYID == study . STUDYID ) . first ( )
self . assertEqual ( ' No Error ' , status . STATUS )
self . assertEqual ( ' Passed validation. ' , status . DETAIL )
# Add Investigator
self . app . post ( f ' /investigator/ { study . STUDYID } ' , data = { ' NETBADGEID ' : ' dhf8r ' , ' INVESTIGATORTYPE ' : ' PI ' } )
count = Investigator . query . filter ( Investigator . STUDYID == study . STUDYID ) . count ( )
self . assertEqual ( 1 , count )
# Add Sponsor
2021-04-13 12:47:42 -04:00
self . load_sponsors ( )
self . app . post ( f ' /study_sponsor/ { study . STUDYID } ' , data = { ' SPONSOR_IDS ' : [ 101 , 102 ] } )
2021-04-13 12:07:34 -04:00
count = StudySponsor . query . filter ( StudySponsor . SS_STUDY == study . STUDYID ) . count ( )
self . assertEqual ( 2 , count )
# Add IRB Info
self . app . post ( f ' /irb_info/ { study . STUDYID } ' , data = { ' UVA_STUDY_TRACKING ' : ' asdf ' } )
irb_info = IRBInfo . query . filter ( IRBInfo . SS_STUDY_ID == study . STUDYID ) . first ( )
self . assertEqual ( irb_info . UVA_STUDY_TRACKING , ' asdf ' )
# Delete the study
self . app . post ( f ' /del_study/ { study . STUDYID } ' , data = { ' confirm ' : True } )
u = Study . query . filter ( Study . STUDYID == study . STUDYID ) . first ( )
self . assertIsNone ( u )
status = IRBStatus . query . filter ( IRBStatus . STUDYID == study . STUDYID ) . first ( )
self . assertIsNone ( status )
count = Investigator . query . filter ( Investigator . STUDYID == study . STUDYID ) . count ( )
self . assertEqual ( 0 , count )
count = StudySponsor . query . filter ( StudySponsor . SS_STUDY == study . STUDYID ) . count ( )
self . assertEqual ( 0 , count )
count = IRBInfo . query . filter ( IRBInfo . SS_STUDY_ID == study . STUDYID ) . count ( )
self . assertEqual ( 0 , count )
2020-08-14 09:39:05 -04:00
def test_add_sponsors ( self ) :
""" Load sponsors twice in a row to make sure duplicates aren ' t created. """
self . load_sponsors ( )
self . load_sponsors ( )
2020-08-13 15:19:55 -04:00
def test_add_and_edit_study_sponsor ( self ) :
""" Add and edit a study sponsor """
num_sponsors = 5
all_sponsors = self . load_sponsors ( )
study : Study = self . add_study ( )
self . assertIsNotNone ( study )
num_study_sponsors_before = len ( study . sponsors )
self . assertEqual ( num_study_sponsors_before , 0 )
study_sponsors_before = session . query ( StudySponsor ) . filter ( StudySponsor . SS_STUDY == study . STUDYID ) . all ( )
self . assertEqual ( len ( study_sponsors_before ) , 0 )
""" Add sponsors to an existing study """
random_sponsor_ids = random . choices ( [ s . SPONSOR_ID for s in all_sponsors ] , k = num_sponsors )
self . assertEqual ( len ( random_sponsor_ids ) , num_sponsors )
formdata = MultiDict ( )
formdata . add ( ' SS_STUDY ' , study . STUDYID )
for sponsor_id in random_sponsor_ids :
formdata . add ( ' SPONSOR_IDS ' , sponsor_id )
form = StudySponsorForm ( formdata = formdata , obj = study )
form . SPONSOR_IDS . choices = [ ( s . SPONSOR_ID , f ' { s . SP_NAME } ( { s . SP_TYPE } ) ' ) for s in all_sponsors ]
self . assertEqual ( len ( form . data [ ' SPONSOR_IDS ' ] ) , num_sponsors )
rv = self . app . post ( f ' /study_sponsor/ { study . STUDYID } ' , data = form . data , follow_redirects = False )
assert rv . status_code == 302
edited_study = Study . query . filter ( Study . STUDYID == study . STUDYID ) . first ( )
assert edited_study
num_study_sponsors_after = len ( edited_study . sponsors )
self . assertGreater ( num_study_sponsors_after , 0 )
self . assertEqual ( num_study_sponsors_after , num_sponsors )
study_sponsors_after = session . query ( StudySponsor ) . filter ( StudySponsor . SS_STUDY == study . STUDYID ) . all ( )
self . assertGreater ( len ( study_sponsors_after ) , 0 )
self . assertEqual ( len ( study_sponsors_after ) , num_sponsors )
2021-01-06 11:17:41 -05:00
def test_ldap_search ( self ) :
needle = ' funk '
result = LdapService . users_as_json ( needle )
users = json . loads ( result )
print ( f ' len of users: { len ( users ) } ' )
# self.assertEqual(2, len(users))
uids = [ ]
for user in users :
uids . append ( user [ ' uid ' ] )
self . assertIn ( ' dhf8r ' , uids )
2021-02-19 10:55:44 -05:00
def test_user_studies ( self ) :
studies1 = self . app . get ( f ' /user_studies ' )
self . assertEqual ( ' 308 PERMANENT REDIRECT ' , studies1 . status )
for header in studies1 . headers :
if header [ 0 ] == ' Location ' :
2021-02-23 14:01:19 -05:00
self . assertIn ( ' user_studies ' , header [ 1 ] )
2021-02-19 10:55:44 -05:00
studies2 = self . app . get ( f ' /user_studies/ ' )
2021-05-11 17:00:43 -04:00
self . assertEqual ( ' 200 OK ' , studies2 . status )
2021-02-19 10:55:44 -05:00
for header in studies2 . headers :
if header [ 0 ] == ' Location ' :
2021-02-23 14:01:19 -05:00
self . assertNotIn ( ' user_studies ' , header [ 1 ] )
2021-02-23 11:02:22 -05:00
2021-02-22 12:36:10 -05:00
def test_long_study_name ( self ) :
title = ' Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla egestas quam id ullamcorper facilisis. Praesent ultricies urna malesuada velit ultricies efficitur. Nam eu eleifend libero. Mauris ac erat augue. Curabitur ac fringilla tellus. Morbi sem quam, consectetur sit amet eros non, semper congue metus. Sed sollicitudin augue eu justo fermentum volutpat at sit amet metus. Vestibulum hendrerit pharetra ante. Sed porttitor diam nibh, quis elementum est placerat sit amet. Phasellus magna libero, porta quis euismod et, commodo eu nisl. Quisque consectetur sagittis interdum. Nullam congue consectetur elementum. In hac habitasse platea dictumst. Duis placerat iaculis odio, ac faucibus felis vehicula nec. Praesent cursus id turpis ac maximus. '
study = self . add_study ( title = title )
self . assertEqual ( title , study . TITLE )
2021-02-23 11:02:22 -05:00
2021-04-13 12:07:34 -04:00
# This test fails because SQLite has an issue with date data from csv file
2021-03-30 11:00:40 -04:00
# def test_update_study_from_csv(self):
# study = self.add_study()
# f = open('tests/data/ExampleStudyID15370.csv', 'rb')
# r = self.app.post(f'/study_details/{study.STUDYID}', data={'file': [f]}, follow_redirects=False)
#
# print(r)
# print('test_update_study_from_csv')
2021-04-13 12:07:34 -04:00
def test_study_details_validation ( self ) :
test_study = self . add_study ( )
data = { ' IS_IND ' : 1 , ' IND_1 ' : 1234 }
self . app . post ( f ' /study_details/ { test_study . STUDYID } ' , data = data , follow_redirects = False )
detail = StudyDetails . query . filter ( StudyDetails . STUDYID == test_study . STUDYID ) . first ( )
self . assertEqual ( detail . IS_IND , 1 )
self . assertEqual ( detail . IND_1 , ' 1234 ' )
# Can't figure out a good way to test failing state.
# We may not really need this, because validation happens in the front end, not in python
2021-03-25 13:14:17 -04:00
# def test_study_details_validation_fail(self):
# test_study = self.add_study()
# data = {'IS_IND': 1, 'IND_1': 1234, 'IS_IDE': 'b'}
2021-04-13 12:07:34 -04:00
# with self.assertRaises(Exception) as ex:
# r = self.app.post(f'/study_details/{test_study.STUDYID}', data=data, follow_redirects=False)
# self.assertEqual(r.errors['IS_IDE'], 'Not a valid integer value')
# print('test_study_details_validation_fail')
# detail = StudyDetails.query.filter(StudyDetails.STUDYID == test_study.STUDYID).first()
# self.assertIsNone(detail)
2021-03-25 13:14:17 -04:00
# print('test_study_details_validation_fail')