Fixes e2e tests.

This commit is contained in:
Aaron Louie 2020-09-23 17:40:58 -04:00
parent 3357150421
commit f5c374ebc8
3 changed files with 17 additions and 103 deletions

@ -1,7 +1,7 @@
import {HttpClient} from 'protractor-http-client'; import {HttpClient} from 'protractor-http-client';
import {AppPage} from './app.po'; import {AppPage} from './app.po';
describe('Clinical Research Coordinator App', () => { describe('COVID19 Testing Kiosk App', () => {
let page: AppPage; let page: AppPage;
let http: HttpClient; let http: HttpClient;
@ -12,114 +12,26 @@ describe('Clinical Research Coordinator App', () => {
it('should automatically sign-in and redirect to home screen', () => { it('should automatically sign-in and redirect to home screen', () => {
page.navigateTo(); page.navigateTo();
expect(page.getRoute()).toEqual('/home'); expect(page.getRoute()).toEqual('/');
expect(page.getElements('#cta_protocol_builder').count()).toBeGreaterThan(0);
}); });
it('should navigate to help screen', () => { it('should navigate to settings screen', () => {
page.clickAndExpectRoute('#nav_help', '/help'); page.clickAndExpectRoute('#nav_settings', '/settings');
}); });
it('should navigate to profile', () => { it('should navigate to home screen', () => {
page.clickElement('#nav_account'); page.clickAndExpectRoute('#nav_home', '/');
page.clickAndExpectRoute('#nav_profile', '/profile');
}); });
it('should navigate to notifications', () => { it('should navigate to occupancy count input screen', () => {
page.clickElement('#nav_account'); page.clickAndExpectRoute('#nav_count', '/count');
page.clickAndExpectRoute('#nav_notifications', '/notifications');
}); });
it('should navigate back to home screen', () => { it('should navigate back to home screen', () => {
page.setLocalStorageVar('numstudy', '1'); page.clickAndExpectRoute('#nav_home', '/');
expect(page.getLocalStorageVar('numstudy')).toEqual('1');
page.clickAndExpectRoute('#nav_home', '/home');
expect(page.getElements('#cta_protocol_builder').count()).toBeGreaterThan(0);
}); });
it('should open Protocol Builder in new window', async () => { it('should navigate to sample input screen', () => {
expect(page.getElements('#cta_protocol_builder').count()).toEqual(1); page.clickAndExpectRoute('#nav_sample', '/sample');
expect(page.getElements('#cta_reload_studies').count()).toEqual(1);
// Open Protocol Builder in new tab.
const numTabsBefore = await page.getNumTabs();
page.clickElement('#cta_protocol_builder');
const numTabsAfter = await page.getNumTabs();
expect(numTabsAfter).toBeGreaterThan(numTabsBefore);
// Close Protocol Builder tab.
await page.switchFocusToTab(1);
await page.closeTab();
await page.switchFocusToTab(0);
}); });
it('should load new study from Protocol Builder', async () => {
const numStudiesBefore = await page.getElements('.study-row').count();
// Add a new study to Protocol Builder.
http.post('/new_study', '' +
`STUDYID=${Math.floor(Math.random() * 100000)}&` +
`TITLE=${encodeURIComponent('New study title')}&` +
`NETBADGEID=dhf8r&` +
`DATE_MODIFIED=${encodeURIComponent(new Date().toISOString())}&` +
`requirements=9&` +
`requirements=21&` +
`requirements=40&` +
`requirements=44&` +
`requirements=52&` +
`requirements=53&` +
`Q_COMPLETE=y`,
{'Content-Type': 'application/x-www-form-urlencoded'}
).catch(error => {
console.error(error);
});
http.failOnHttpError = false;
// Reload the list of studies.
await page.clickElement('#cta_reload_studies');
await page.waitForNotVisible('.loading');
await page.waitForClickable('.study-row');
const numStudiesAfter = await page.getElements('.study-row').count();
expect(numStudiesAfter).toBeGreaterThan(numStudiesBefore);
});
it('should navigate to a study', async () => {
const studyRow = page.getElement('.study-row');
const studyId = await studyRow.getAttribute('data-study-id');
await expect(studyId).not.toBeUndefined();
await expect(studyId).not.toBeNull();
page.clickAndExpectRoute('.study-row', '/study/' + studyId);
});
it('should display workflow spec categories in tiles', async () => {
const numTiles = await page.getElements('.workflow-list-item').count();
expect(numTiles).toBeGreaterThan(0);
});
it('should navigate to a workflow', async () => {
const wfSelector = '.workflow-list-item .workflow-action';
expect(page.getElements(wfSelector).count()).toBeGreaterThan(0);
const workflow = await page.getElement(wfSelector);
const studyId = await workflow.getAttribute('data-study-id');
const catId = await workflow.getAttribute('data-category-id');
const workflowId = await workflow.getAttribute('data-workflow-id');
console.log('studyId', studyId);
console.log('catId', catId);
console.log('workflowId', workflowId);
const expectedRoute = `/study/${studyId}?category=${catId}&workflow=${workflowId}`;
await page.clickElement(wfSelector);
const newRoute = await page.getRoute();
expect(newRoute.slice(0, expectedRoute.length)).toEqual(expectedRoute);
});
// TODO: CATCH 401/403 ERRORS AND VERIFY THAT THEY REDIRECT TO LOGIN
// afterEach(async () => {
// // Assert that there are no errors emitted from the browser
// const logs = await browser.manage().logs().get(logging.Type.BROWSER);
// expect(logs).not.toContain(jasmine.objectContaining({
// level: logging.Level.SEVERE,
// } as logging.Entry));
// });
}); });

@ -5,6 +5,7 @@
fxLayoutGap="40px" fxLayoutGap="40px"
> >
<button <button
id="nav_sample"
mat-flat-button mat-flat-button
color="accent" color="accent"
class="btn-xl" class="btn-xl"
@ -12,6 +13,7 @@
autofocus autofocus
>New sample</button> >New sample</button>
<button <button
id="nav_count"
mat-flat-button mat-flat-button
class="btn-xl" class="btn-xl"
routerLink="/count" routerLink="/count"

@ -1,9 +1,9 @@
<mat-toolbar color="primary"> <mat-toolbar color="primary">
<mat-toolbar-row> <mat-toolbar-row>
<button mat-button routerLink="/" class="logo">BeSAFE</button> <button id="nav_logo" mat-button routerLink="/" class="logo">BeSAFE</button>
<button mat-button routerLink="/settings">{{testingLocation ? testingLocation.name : 'No location found'}} ({{locationId}})</button> <button id="nav_location" mat-button routerLink="/settings">{{testingLocation ? testingLocation.name : 'No location found'}} ({{locationId}})</button>
<span fxFlex></span> <span fxFlex></span>
<button mat-icon-button routerLink="/"><mat-icon>home</mat-icon></button> <button id="nav_home" mat-icon-button routerLink="/"><mat-icon>home</mat-icon></button>
<button mat-icon-button routerLink="/settings"><mat-icon>settings</mat-icon></button> <button id="nav_settings" mat-icon-button routerLink="/settings"><mat-icon>settings</mat-icon></button>
</mat-toolbar-row> </mat-toolbar-row>
</mat-toolbar> </mat-toolbar>