From bae21c9e00ea72a5750a6b8251ed9e04c76d2d21 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Tue, 5 Jul 2022 11:53:05 -0500 Subject: [PATCH] Datepicker: fix test failing due to date matching today --- .../datepicker/__tests__/datepicker.test.tsx | 21 ++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/app/soapbox/components/ui/datepicker/__tests__/datepicker.test.tsx b/app/soapbox/components/ui/datepicker/__tests__/datepicker.test.tsx index 5fe6ca9d69..c4f94c89f9 100644 --- a/app/soapbox/components/ui/datepicker/__tests__/datepicker.test.tsx +++ b/app/soapbox/components/ui/datepicker/__tests__/datepicker.test.tsx @@ -56,26 +56,41 @@ describe('', () => { it('calls the onChange function when the inputs change', async() => { const handler = jest.fn(); render(); + const today = new Date(); + + /** + * A date with a different day, month, and year than today + * so this test will always pass! + */ + const notToday = new Date( + today.getFullYear() - 1, // last year + (today.getMonth() + 2) % 11, // two months from now (mod 11 because it's 0-indexed) + (today.getDate() + 2) % 28, // 2 days from now (for timezone stuff) + ); + + const month = notToday.toLocaleString('en-us', { month: 'long' }); + const year = String(notToday.getFullYear()); + const day = String(notToday.getDate()); expect(handler.mock.calls.length).toEqual(1); await userEvent.selectOptions( screen.getByTestId('datepicker-month'), - screen.getByRole('option', { name: 'February' }), + screen.getByRole('option', { name: month }), ); expect(handler.mock.calls.length).toEqual(2); await userEvent.selectOptions( screen.getByTestId('datepicker-year'), - screen.getByRole('option', { name: '2020' }), + screen.getByRole('option', { name: year }), ); expect(handler.mock.calls.length).toEqual(3); await userEvent.selectOptions( screen.getByTestId('datepicker-day'), - screen.getByRole('option', { name: '5' }), + screen.getByRole('option', { name: day }), ); expect(handler.mock.calls.length).toEqual(4);