generated from Real-Dev-Squad/website-template
-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
c24ede7
commit f93eb2c
Showing
4 changed files
with
105 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
import { render, screen, act, fireEvent } from '@testing-library/react'; | ||
import Redirect from '../../src/pages/[redirect]/index'; | ||
import { useRouter } from 'next/router'; | ||
|
||
jest.mock('next/router', () => ({ | ||
useRouter: jest.fn(), | ||
})); | ||
|
||
describe('Redirect Component', () => { | ||
const mockRouterPush = jest.fn(); | ||
const mockRouterReplace = jest.fn(); | ||
const mockRouter = { | ||
push: mockRouterPush, | ||
replace: mockRouterReplace, | ||
query: { redirect: 'ffdsfds' }, | ||
}; | ||
|
||
beforeEach(() => { | ||
(useRouter as jest.Mock).mockReturnValue(mockRouter); | ||
}); | ||
|
||
test('renders the Redirect component with countdown and Go button', () => { | ||
render(<Redirect />); | ||
const goButton = screen.getByText('Go'); | ||
|
||
expect(goButton).toBeInTheDocument(); | ||
}); | ||
|
||
test('redirects to original URL on Go button click', async () => { | ||
render(<Redirect />); | ||
const goButton = screen.getByText('Go'); | ||
await act(async () => { | ||
fireEvent.click(goButton); | ||
}); | ||
expect(mockRouterPush).toHaveBeenCalled(); | ||
}); | ||
|
||
test('redirects to original URL on Go button click', async () => { | ||
render(<Redirect />); | ||
const goButton = screen.getByText('Go'); | ||
await act(async () => { | ||
fireEvent.click(goButton); | ||
}); | ||
expect(mockRouterPush).toHaveBeenCalled(); | ||
}); | ||
|
||
test('show tooltip on Go button click', async () => { | ||
render(<Redirect />); | ||
const goButton = screen.getByText('Go'); | ||
await act(async () => { | ||
fireEvent.click(goButton); | ||
}); | ||
expect(mockRouterPush).toHaveBeenCalled(); | ||
}); | ||
|
||
test('fetchOriginalUrl function returns original URL', async () => { | ||
const mockFetchOriginalUrl = jest.fn(); | ||
mockFetchOriginalUrl.mockReturnValue('https://www.google.com'); | ||
const originalUrl = await mockFetchOriginalUrl(); | ||
expect(originalUrl).toBe('https://www.google.com'); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
import fetchMock from 'jest-fetch-mock'; | ||
import fetchOriginalUrl from '../../src/utils/fetchOriginalUrl'; | ||
import { act } from 'react-dom/test-utils'; | ||
|
||
fetchMock.enableMocks(); | ||
|
||
describe('fetchOriginalUrl', () => { | ||
const shortUrlCode = '442d39ac'; | ||
const originalUrl = 'https://github.com/Real-Dev-Squad/tiny-site-frontend/pull/40'; | ||
|
||
it('fetches and displays the original URL if the response is successful', async () => { | ||
const responseData = { url: { OriginalUrl: originalUrl } }; | ||
|
||
fetchMock.mockResponse(JSON.stringify(responseData), { status: 200 }); | ||
|
||
await act(async () => { | ||
const result = await fetchOriginalUrl(shortUrlCode); | ||
expect(result).toEqual(originalUrl); | ||
}); | ||
}); | ||
|
||
it('returns null if the response is not successful', async () => { | ||
fetchMock.mockResponse('', { status: 404 }); | ||
|
||
await act(async () => { | ||
const result = await fetchOriginalUrl(shortUrlCode); | ||
expect(result).toBeNull(); | ||
}); | ||
}); | ||
|
||
it('handles errors gracefully', async () => { | ||
fetchMock.mockReject(new Error('Network error')); | ||
|
||
await act(async () => { | ||
const result = await fetchOriginalUrl(shortUrlCode); | ||
expect(result).toBeNull(); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters