mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 19:03:30 -05:00
* Removed all govuk css * Updated reference files * Removing govuk js * Fixed casing for modules, removed unused page * Got more reference images * Updated template page * Removed govuk padding util * Updated hint to uswds hint * More govuk cleanup * Commiting backstopjs ref files * Fixed all unit tests that broke due to brittleness around govuk styling * Added new ref images * Final removal of govuk * Officially removed all govuk references * Updated reference file * Updated link to button * UI modernization * Cleanup * removed govuk escaping tests since they are no longer needed * Fix CodeQL security issue in escapeElementName function - Escape backslashes first before other special characters - Prevents potential double-escaping vulnerability - Addresses CodeQL alert about improper string escaping * Found more govuk removal. Fixed unit tests * Add missing pipeline check to pre-commit * updated test * Updated e2e test * More update to e2e test * Fixed another e2e test * Simple PR comments addressed * More updates * Updated backstop ref files * Refactored folder selection for non-admins * Updated redundant line * Updated tests to include correct mocks * Added more ref files * Addressing carlos comments * Addressing Carlo comments, cleanup of window initing * More cleanup and addressing carlo comments * Fixing a11 scan * Fixed a few issues with javascript * Fixed for pr * Fixing e2e tests * Tweaking e2e test * Added more ref files and cleaned up urls.js * Fixed bug with creating new template * Removed brittle test - addressed code ql comment * e2e race condition fix * More e2e test fixes * Updated e2e tests to not wait for text sent * Updated test to not wait for button click response * Made tear down more resilent if staging is down * reverted e2e test to what was working before main merge * Updated backstopRef images * Updated gulp to include job-polling differently
139 lines
4.3 KiB
JavaScript
139 lines
4.3 KiB
JavaScript
beforeAll(() => {
|
|
jest.spyOn(global, 'setTimeout');
|
|
|
|
document.body.innerHTML = `
|
|
<dialog class="usa-modal" id="sessionTimer" aria-labelledby="sessionTimerHeading" aria-describedby="timeLeft">
|
|
<div class="usa-modal__content">
|
|
<div class="usa-modal__main">
|
|
<h2 class="usa-modal__heading font-body-lg" id="sessionTimerHeading">
|
|
Your session will end soon.
|
|
<span class="usa-sr-only">Please choose to extend your session or sign out. Your session will expire in 5 minutes or less.</span>
|
|
</h2>
|
|
<div class="usa-prose">
|
|
<p>You have been inactive for too long.
|
|
Your session will expire in <span id="timeLeft" role="timer"></span>.
|
|
</p>
|
|
</div>
|
|
<div class="usa-modal__footer">
|
|
<ul class="usa-button-group">
|
|
<li class="usa-button-group__item">
|
|
<button type="button" class="usa-button" id="extendSessionTimer" data-close-modal>
|
|
Extend Session
|
|
</button>
|
|
</li>
|
|
<li class="usa-button-group__item">
|
|
<button type="button" class="usa-button usa-button--unstyled padding-105 text-center" id="logOutTimer"
|
|
data-close-modal>
|
|
Sign out
|
|
</button>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</dialog>
|
|
`;
|
|
|
|
const sessionTimerModule = require('../../app/assets/javascripts/timeoutPopup.js');
|
|
window.NotifyModules.start();
|
|
});
|
|
|
|
afterAll(() => {
|
|
document.body.innerHTML = '';
|
|
});
|
|
|
|
describe('When the session timer module is loaded', () => {
|
|
beforeEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
test('everything initializes properly', () => {
|
|
const sessionTimer = document.getElementById('sessionTimer');
|
|
sessionTimer.showModal = jest.fn();
|
|
sessionTimer.close = jest.fn();
|
|
|
|
jest.runAllTimers();
|
|
});
|
|
});
|
|
|
|
describe('The session timer ', () => {
|
|
beforeEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.useFakeTimers();
|
|
});
|
|
|
|
test('signoutUser method logs the user out', () => {
|
|
const restore = mockWindowLocation();
|
|
|
|
// Test the actual function, not a mock
|
|
const signoutUserMethod = window.NotifyModules.TimeoutPopup.signoutUser;
|
|
|
|
// This will try to set location.href but our mock will catch it
|
|
expect(() => signoutUserMethod()).not.toThrow();
|
|
|
|
restore();
|
|
});
|
|
|
|
test('expireUserSession method logs the user out with next query parameter', () => {
|
|
const restore = mockWindowLocation();
|
|
|
|
// Test the actual function, not a mock
|
|
const expireUserSessionMethod = window.NotifyModules.TimeoutPopup.expireUserSession;
|
|
|
|
// This will try to set location.href but our mock will catch it
|
|
expect(() => expireUserSessionMethod()).not.toThrow();
|
|
|
|
restore();
|
|
});
|
|
|
|
test('extendSession method reloads the page', () => {
|
|
const restore = mockWindowLocation();
|
|
|
|
// Test the actual function, not a mock
|
|
const extendSessionMethod = window.NotifyModules.TimeoutPopup.extendSession;
|
|
|
|
// This will try to call location.reload but our mock will catch it
|
|
expect(() => extendSessionMethod()).not.toThrow();
|
|
|
|
restore();
|
|
});
|
|
|
|
test('showTimer method shows the session timer modal', () => {
|
|
const sessionTimer = document.getElementById('sessionTimer');
|
|
sessionTimer.showModal = jest.fn();
|
|
|
|
const showTimerMock = jest.spyOn(sessionTimer, 'showModal');
|
|
|
|
window.NotifyModules.TimeoutPopup.showTimer();
|
|
|
|
expect(showTimerMock).toHaveBeenCalled();
|
|
});
|
|
|
|
test('closeTimer method closes the session timer modal', () => {
|
|
const sessionTimer = document.getElementById('sessionTimer');
|
|
sessionTimer.close = jest.fn();
|
|
|
|
const closeTimerMock = jest.spyOn(sessionTimer, 'close');
|
|
|
|
window.NotifyModules.TimeoutPopup.closeTimer();
|
|
|
|
expect(closeTimerMock).toHaveBeenCalled();
|
|
});
|
|
|
|
test('checkTimer is called', () => {
|
|
const checkTimerMock = jest.spyOn(
|
|
window.NotifyModules.TimeoutPopup,
|
|
'checkTimer'
|
|
);
|
|
window.NotifyModules.TimeoutPopup.checkTimer();
|
|
expect(checkTimerMock).toHaveBeenCalled();
|
|
});
|
|
});
|