This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the testing category.
Last Updated: 2025-01-18
I had a system test in Selenium that was supposed to work with a pop-up that displayed only after a certain amount of time.
Here was the test code for triggering it:
def trigger_popup
travel 5.minutes
page.execute_script('window.scrollBy(0,1)')
end
The corresponding JavaScript for creating the pop-up was:
startDate = new Date()
window.addEventListener('scroll', function() {
let secondsOnPage = (new Date() - startDate) / 1000;
isScrolledFarEnough = window.scrollY > 1000;
if(!gaveEmail() && !isDismissed() && (isScrolledFarEnough && secondsOnPage > 90)) {
email_subscribe_modal.modal('show');
} else {
email_subscribe_modal.modal('hide');
}
});
My test did not trigger the JavaScript, however. This was because the time in the Ruby process had no bearing on the time in my JavaScript process. The working solution involved created a script, using Ruby, to modify time in my JavaScript process:
page.execute_script(
<<-JAVASCRIPT
currentTime = new Date().getTime();
window.oldDateClass = Date;
Date = function (_)
{
let seconds = 300
return new oldDateClass(currentTime + (seconds * 1000));
};
Date.now = Date;
JAVASCRIPT
)