Skip to content

Commit

Permalink
Fix issues in Toast component refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
julianguyen committed Nov 29, 2024
1 parent 966860b commit f1af519
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 21 deletions.
15 changes: 3 additions & 12 deletions client/app/components/Toast/__tests__/Toast.spec.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,20 +9,14 @@ describe('Toast', () => {
describe('Toast Type: Alert', () => {
it('renders correctly', () => {
render(
<Toast
alert="Invalid username or password."
appendDashboardClass="true"
/>,
<Toast alert="Invalid username or password." appendDashboardClass />,
);
expect(screen).not.toBeNull();
});

it('closes correctly on button click', () => {
const { getByRole, container } = render(
<Toast
alert="Invalid username or password."
appendDashboardClass="true"
/>,
<Toast alert="Invalid username or password." appendDashboardClass />,
);

const toastContent = getByRole('alert');
Expand All @@ -35,10 +29,7 @@ describe('Toast', () => {

it('closes automatically after 7 seconds', async () => {
const { getByRole } = render(
<Toast
alert="Invalid username or password."
appendDashboardClass="true"
/>,
<Toast alert="Invalid username or password." appendDashboardClass />,
);

const toastContent = getByRole('alert');
Expand Down
6 changes: 5 additions & 1 deletion client/app/components/Toast/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,16 @@ export const Toast = ({ alert, notice, appendDashboardClass }: Props): Node => {
};

useEffect(() => {
let timer;
if (showAlert || showNotice) {
setTimeout(() => {
timer = setTimeout(() => {
hideNotice();
hideAlert();
}, 7000);
}
return () => {
clearTimeout(timer);
};
}, [showAlert, showNotice]);

return (
Expand Down
2 changes: 1 addition & 1 deletion client/app/stories/Toast.stories.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ export const noticeToast = Template.bind({});

noticeToast.args = {
notice: 'Login successful.',
appendDashboardClass: 'true',
appendDashboardClass: true,
};
noticeToast.storyName = 'Toast Type: Notice';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,21 +10,22 @@ const button = <button type="button">Notifications</button>;

describe('Notifications', () => {
it('gets notifications and clears them', async (done) => {
jest
const axiosGetSpy = jest
.spyOn(axios, 'get')
.mockReturnValueOnce(Promise.resolve({ data: { signed_in: 1 } }))
.mockReturnValueOnce(
Promise.resolve({ data: { fetch_notifications: ['Hello'] } }),
);
)
.mockReturnValue(Promise.resolve());
jest
.spyOn(axios, 'delete')
.mockReturnValue(Promise.resolve({ data: { ok: true } }));
render(<Notifications element={button} />);
await waitFor(() => expect(axios.get).toHaveBeenCalledWith('/notifications/signed_in'));
await waitFor(() => expect(axios.get).toHaveBeenCalledWith(
await waitFor(() => expect(axiosGetSpy).toHaveBeenCalledWith('/notifications/signed_in'));
await waitFor(() => expect(axiosGetSpy).toHaveBeenCalledWith(
'/notifications/fetch_notifications',
));
expect(axios.get).toHaveBeenCalledTimes(3);
expect(axiosGetSpy).toHaveBeenCalledTimes(3);
expect(screen.getByText('Hello')).toBeInTheDocument();
fireEvent.click(screen.getByText('Clear'));
await waitFor(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,18 @@ describe('ToggleLocale', () => {
});

it('does nothing if the previous locale is the same as the selected', async () => {
const axiosPostSpy = jest.spyOn(axios, 'post').mockImplementation(() => Promise.resolve());
const axiosPostSpy = jest
.spyOn(axios, 'post')
.mockImplementation(() => Promise.resolve());
render(component);
await userEvent.selectOptions(screen.getByRole('combobox'), 'en');
expect(axiosPostSpy).not.toHaveBeenCalled();
});

it('sets the locale cookie and makes a post request if the selected locale is different from the previous', async () => {
const axiosPostSpy = jest.spyOn(axios, 'post').mockImplementation(() => Promise.resolve());
const axiosPostSpy = jest
.spyOn(axios, 'post')
.mockImplementation(() => Promise.resolve());
render(component);
await userEvent.selectOptions(screen.getByRole('combobox'), 'es');
expect(Cookies.set).toHaveBeenCalledWith('locale', 'es');
Expand Down

0 comments on commit f1af519

Please # to comment.