mirror of
https://github.com/scratchfoundation/scratch-www.git
synced 2024-11-23 15:47:53 -05:00
Make all times be in ms.
This commit is contained in:
parent
7eeb63cb3f
commit
fac3ccad57
2 changed files with 14 additions and 12 deletions
|
@ -37,14 +37,16 @@ class Navigation extends React.Component {
|
|||
componentDidMount () {
|
||||
if (this.props.user) {
|
||||
// Setup polling for messages to start in 2 minutes.
|
||||
setTimeout(this.pollForMessages.bind(this, 2), 2 * 60 * 1000);
|
||||
const twoMinInMs = 2 * 60 * 1000;
|
||||
setTimeout(this.pollForMessages.bind(this, twoMinInMs), twoMinInMs);
|
||||
}
|
||||
}
|
||||
componentDidUpdate (prevProps) {
|
||||
if (prevProps.user !== this.props.user) {
|
||||
this.props.handleCloseAccountNav();
|
||||
if (this.props.user) {
|
||||
setTimeout(this.pollForMessages.bind(this, 2), 2 * 60 * 1000);
|
||||
const twoMinInMs = 2 * 60 * 1000;
|
||||
setTimeout(this.pollForMessages.bind(this, twoMinInMs), twoMinInMs);
|
||||
} else {
|
||||
// clear message count check, and set to default id.
|
||||
clearTimeout(this.state.messageCountIntervalId);
|
||||
|
@ -70,16 +72,16 @@ class Navigation extends React.Component {
|
|||
return `/users/${this.props.user.username}/`;
|
||||
}
|
||||
|
||||
pollForMessages (minutes) {
|
||||
pollForMessages (ms) {
|
||||
this.props.getMessageCount(this.props.user.username);
|
||||
// We only poll if it has been less than 30 minutes.
|
||||
// Chances of someone actively using the page for that long without
|
||||
// a navigation is low.
|
||||
if (minutes < 32) {
|
||||
const nextFetch = minutes * 2;
|
||||
if (ms < 32 * 60 * 1000) { // 32 minutes
|
||||
const nextFetch = ms * 2; // exponentially back off next fetch time.
|
||||
const timeoutId = setTimeout(() => {
|
||||
this.pollForMessages(nextFetch);
|
||||
}, nextFetch * 60000);
|
||||
}, nextFetch);
|
||||
this.setState({ // eslint-disable-line react/no-did-mount-set-state
|
||||
messageCountIntervalId: timeoutId
|
||||
});
|
||||
|
|
|
@ -167,16 +167,16 @@ describe('Navigation', () => {
|
|||
// has already called pollForMessages.
|
||||
jest.clearAllTimers();
|
||||
jest.clearAllMocks();
|
||||
|
||||
navInstance.pollForMessages(2);
|
||||
let twoMinInMs = 2 * 60 * 1000; // 2 minutes in ms.
|
||||
navInstance.pollForMessages(twoMinInMs);
|
||||
|
||||
// Check that we set the timeout to backoff exponentially
|
||||
let minutes = 2 * 60 * 1000;
|
||||
|
||||
for (let count = 1; count < 5; ++count) {
|
||||
jest.advanceTimersByTime(minutes + 1);
|
||||
expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), minutes * 2);
|
||||
jest.advanceTimersByTime(twoMinInMs + 1);
|
||||
expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), twoMinInMs * 2);
|
||||
expect(props.getMessageCount).toHaveBeenCalledTimes(count);
|
||||
minutes = minutes * 2;
|
||||
twoMinInMs = twoMinInMs * 2;
|
||||
}
|
||||
|
||||
// Exhaust all timers (there shouldn't be any left)
|
||||
|
|
Loading…
Reference in a new issue