Commit 38a6ddb7 authored by Martin Wortschack's avatar Martin Wortschack Committed by Mike Greiling

Fix getDateInPast method

- Avoid mutating the original date reference
parent 17fc6231
...@@ -555,5 +555,9 @@ export const calculateRemainingMilliseconds = endDate => { ...@@ -555,5 +555,9 @@ export const calculateRemainingMilliseconds = endDate => {
* @param {number} daysInPast number of days that are subtracted from a given date * @param {number} daysInPast number of days that are subtracted from a given date
* @returns {String} Date string in ISO format * @returns {String} Date string in ISO format
*/ */
export const getDateInPast = (date, daysInPast) => export const getDateInPast = (date, daysInPast) => {
new Date(date.setTime(date.getTime() - daysInPast * 24 * 60 * 60 * 1000)).toISOString(); const dateClone = newDate(date);
return new Date(
dateClone.setTime(dateClone.getTime() - daysInPast * 24 * 60 * 60 * 1000),
).toISOString();
};
...@@ -428,11 +428,16 @@ describe('newDate', () => { ...@@ -428,11 +428,16 @@ describe('newDate', () => {
}); });
describe('getDateInPast', () => { describe('getDateInPast', () => {
const date = new Date(1563235200000); // 2019-07-16T00:00:00.000Z;
const daysInPast = 90;
it('returns the correct date in the past', () => { it('returns the correct date in the past', () => {
const date = new Date(1563235200000); // 2019-07-16T00:00:00.00Z
const daysInPast = 90;
const dateInPast = datetimeUtility.getDateInPast(date, daysInPast); const dateInPast = datetimeUtility.getDateInPast(date, daysInPast);
expect(dateInPast).toBe('2019-04-17T00:00:00.000Z'); expect(dateInPast).toBe('2019-04-17T00:00:00.000Z');
}); });
it('does not modifiy the original date', () => {
datetimeUtility.getDateInPast(date, daysInPast);
expect(date).toStrictEqual(new Date(1563235200000));
});
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment