Skip to content

Commit

Permalink
Added testcase for react file
Browse files Browse the repository at this point in the history
  • Loading branch information
Shubh942 committed Jun 29, 2024
1 parent 79e9f35 commit c0de184
Show file tree
Hide file tree
Showing 14 changed files with 3,116 additions and 64 deletions.
2,888 changes: 2,831 additions & 57 deletions webapp/package-lock.json

Large diffs are not rendered by default.

12 changes: 10 additions & 2 deletions webapp/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,10 @@
"dev": "vite",
"build": "vite build",
"lint": "eslint . --ext js,jsx --report-unused-disable-directives --max-warnings 0",
"preview": "vite preview"
"preview": "vite preview",
"test": "vitest",
"test:watch": "vitest --watch",
"coverage": "vitest run --coverage"
},
"dependencies": {
"react": "^18.2.0",
Expand All @@ -18,14 +21,19 @@
"terminal-in-react": "^4.3.1"
},
"devDependencies": {
"@testing-library/jest-dom": "^6.4.6",
"@testing-library/react": "^16.0.0",
"@types/react": "^18.2.66",
"@types/react-dom": "^18.2.22",
"@vitejs/plugin-react": "^4.2.1",
"@vitest/coverage-v8": "^1.6.0",
"eslint": "^8.57.0",
"eslint-plugin-react": "^7.34.1",
"eslint-plugin-react-hooks": "^4.6.0",
"eslint-plugin-react-refresh": "^0.4.6",
"jsdom": "^24.1.0",
"vite": "^5.2.0",
"vite-plugin-terminal": "^1.2.0"
"vite-plugin-terminal": "^1.2.0",
"vitest": "^1.6.0"
}
}
79 changes: 79 additions & 0 deletions webapp/src/__tests__/App.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
// App.test.jsx
import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import { MemoryRouter } from "react-router-dom";
import App from "../App";

import Breakpoint from "../components/Breakpoint/Breakpoint";

// App.jsx

test("renders Footer component", () => {
render(
<MemoryRouter>
<App />
</MemoryRouter>
);
expect(
screen.getByText(/Designed & Built with 💖 by Shubh Mehta/i)
).toBeInTheDocument();
});

test("renders Threads component within Debug route", () => {
render(
<MemoryRouter initialEntries={["/debug/threads"]}>
<App />
</MemoryRouter>
);
expect(screen.getByText(/Threads/i)).toBeInTheDocument();
const threadsComponent = screen.getByText(/Threads/i);
expect(threadsComponent).toBeInTheDocument();
expect(threadsComponent).toHaveClass("gdb-header-content active");
});

test("renders LocalVariable component within Debug route", () => {
render(
<MemoryRouter initialEntries={["/debug/localVariable"]}>
<App />
</MemoryRouter>
);
expect(screen.getByText(/Local Variable/i)).toBeInTheDocument();
const localVariableComponent = screen.getByText(/Local Variable/i);
expect(localVariableComponent).toBeInTheDocument();
expect(localVariableComponent).toHaveClass("gdb-header-content active");
});

test("renders Context component within Debug route", () => {
render(
<MemoryRouter initialEntries={["/debug/context"]}>
<App />
</MemoryRouter>
);
expect(screen.getByText(/Context/i)).toBeInTheDocument();
const contextComponent = screen.getByText(/Context/i);
expect(contextComponent).toBeInTheDocument();
expect(contextComponent).toHaveClass("gdb-header-content active");
});

test("renders MemoryMap component within Debug route", () => {
render(
<MemoryRouter initialEntries={["/debug/memoryMap"]}>
<App />
</MemoryRouter>
);
expect(screen.getByText(/Memory Map/i)).toBeInTheDocument();
const memoryMapComponent = screen.getByText(/Memory Map/i);
expect(memoryMapComponent).toBeInTheDocument();
expect(memoryMapComponent).toHaveClass("gdb-header-content active");
});

test("renders BreakPoints component within Debug route", () => {
render(
<MemoryRouter initialEntries={["/debug/breakPoints"]}>
<App />
</MemoryRouter>
);
const breakpointsComponent = screen.getByText(/Break Points/i);
expect(breakpointsComponent).toBeInTheDocument();
expect(breakpointsComponent).toHaveClass("gdb-header-content active");
});
4 changes: 2 additions & 2 deletions webapp/src/components/Breakpoint/Breakpoint.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@ const Breakpoint = () => {
<div className="add-breakpoint">Add Breakpoint</div>
<div className="lower-breakpoint">
<div className="line-breakpoint">
<a>Line</a>
<input type="text" name="" id="" />
<label>Line</label>
<input type="text" name="" id="breakpoint-line" />
</div>
<div className="line-breakpoint">
<a>Function</a>
Expand Down
29 changes: 29 additions & 0 deletions webapp/src/components/Breakpoint/__tests__/Breakpoint.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import Breakpoint from "../Breakpoint.jsx";

// Breakpoint
test("renders Breakpoint component with basic structure", () => {
render(<Breakpoint />);

const addBreakpointElement = screen.getByText(/Add Breakpoint/i);
expect(addBreakpointElement).toBeInTheDocument();

const lineInputs = screen.getAllByRole("textbox");
expect(lineInputs).toHaveLength(2);
});

test("renders Breakpoint component and checks about text Line", async () => {
render(<Breakpoint />);
const lineLabel = screen.getByText(/Line/i);
expect(lineLabel).toBeInTheDocument();
});

test("typing in Line input updates the value correctly", () => {
render(<Breakpoint />);

const lineInput = screen.getAllByRole("textbox");
fireEvent.change(lineInput[0], { target: { value: "123" } });

expect(lineInput[0]).toHaveValue("123");
});
26 changes: 26 additions & 0 deletions webapp/src/components/DebugHeader/__tests__/DebugHeader.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
// DebugHeader.test.jsx

import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import DebugHeader from "../DebugHeader.jsx";

describe("DebugHeader Component", () => {
test("renders DebugHeader component with icons and filename", async () => {
render(<DebugHeader />);

const filenameContent = screen.getByText(/filename/i);
expect(filenameContent).toBeInTheDocument();

const saveContent = screen.getByRole("button");
expect(saveContent).toBeInTheDocument();
});

test("clicking Save button triggers save action", () => {
render(<DebugHeader />);

const saveButton = screen.getByText(/Save/i);
expect(saveButton).toBeInTheDocument();

// fireEvent.click(saveButton);
});
});
14 changes: 14 additions & 0 deletions webapp/src/components/Footer/__tests__/Footer.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import React from "react";
import { render, screen } from "@testing-library/react";
import Footer from "../Footer.jsx";

describe("Footer Component", () => {
test("renders Footer component with correct text content", () => {
render(<Footer />);

const footerText = screen.getByText(
/Designed & Built with 💖 by Shubh Mehta/i
);
expect(footerText).toBeInTheDocument();
});
});
11 changes: 11 additions & 0 deletions webapp/src/components/Functions/__tests__/Functions.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import React from "react";
import { render, screen } from "@testing-library/react";
import Functions from "../Functions.jsx"; // Adjust the import path as per your project structure

test("renders Functions component with correct heading and function names", () => {
render(<Functions />);

// Assert the presence of the heading
const headingElement = screen.getByText(/Functions/i);
expect(headingElement).toBeInTheDocument();
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import FunctionsBottom from "../FunctionsBottom.jsx";

test("renders FunctionsBottom component with search input", () => {
render(<FunctionsBottom />);

// Assert the presence of the heading
const headingElement = screen.getByText(/Search/i);
expect(headingElement).toBeInTheDocument();

const searchInput = screen.getByPlaceholderText("Search");
expect(searchInput).toBeInTheDocument();
expect(searchInput).toHaveAttribute("type", "text");

fireEvent.change(searchInput, { target: { value: "kernel" } });

expect(searchInput).toHaveValue("kernel");
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import React from "react";
import { render, screen, fireEvent } from "@testing-library/react";
import { MemoryRouter } from "react-router-dom";
import GdbComponents from "../GdbComponents.jsx";

describe("GdbComponents", () => {
test("renders all navigation links correctly", () => {
render(
<MemoryRouter>
<GdbComponents />
</MemoryRouter>
);

// Assert the presence of all navigation links
const threadsLink = screen.getByText(/Threads/i);
const localVariableLink = screen.getByText(/Local Variable/i);
const contextLink = screen.getByText(/Context/i);
const memoryMapLink = screen.getByText(/Memory Map/i);
const breakPointsLink = screen.getByText(/Break Points/i);

expect(threadsLink).toBeInTheDocument();
expect(localVariableLink).toBeInTheDocument();
expect(contextLink).toBeInTheDocument();
expect(memoryMapLink).toBeInTheDocument();
expect(breakPointsLink).toBeInTheDocument();
});

test("clicking on navigation links updates active state", () => {
render(
<MemoryRouter>
<GdbComponents />
</MemoryRouter>
);

// Click on a navigation link
fireEvent.click(screen.getByText(/Memory Map/i));

// Assert the active state is updated correctly
const memoryMapLink = screen.getByText(/Memory Map/i);
expect(memoryMapLink).toHaveClass("gdb-header-content active");

// Ensure other links are not active
const threadsLink = screen.getByText(/Threads/i);
const localVariableLink = screen.getByText(/Local Variable/i);
const contextLink = screen.getByText(/Context/i);
const breakPointsLink = screen.getByText(/Break Points/i);

expect(threadsLink).not.toHaveClass("gdb-header-content active");
expect(localVariableLink).not.toHaveClass("gdb-header-content active");
expect(contextLink).not.toHaveClass("gdb-header-content active");
expect(breakPointsLink).not.toHaveClass("gdb-header-content active");
});
});
10 changes: 10 additions & 0 deletions webapp/src/components/Stack/__tests__/Stack.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import React from "react";
import { render, screen } from "@testing-library/react";
import Stack from "../Stack.jsx";

test("renders Stack component with stack items", () => {
render(<Stack />);

const stackContainer = screen.getByText(/Stack/i);
expect(stackContainer).toBeInTheDocument();
});
16 changes: 16 additions & 0 deletions webapp/src/components/StackBottom/__tests__/StackBottom.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import React from "react";
import { render, screen } from "@testing-library/react";
import StackBottom from "../StackBottom.jsx";

test("renders StackBottom component with headings", () => {
render(<StackBottom />);

const heading = screen.getByText(/Registors/i);
expect(heading).toBeInTheDocument();

const parts = ["func", "file", "addr", "args"];
parts.forEach((part) => {
const partElement = screen.getByText(part);
expect(partElement).toBeInTheDocument();
});
});
12 changes: 12 additions & 0 deletions webapp/src/setupTests.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
// Import jest-dom to extend Jest with custom matchers for DOM node assertions
import "@testing-library/jest-dom";

// Optional: Configure or set up global settings if needed

// For example, you might want to configure a mock server or add global variables.
// If you're using MSW (Mock Service Worker) for API mocking, you can set it up here:

// import { server } from './mocks/server';
// beforeAll(() => server.listen());
// afterEach(() => server.resetHandlers());
// afterAll(() => server.close());
7 changes: 4 additions & 3 deletions webapp/vite.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,9 @@ import react from "@vitejs/plugin-react";
// https://vitejs.dev/config/
export default defineConfig({
plugins: [react()],
server: {
host: "0.0.0.0",
port: 5173,
test: {
globals: true,
environment: "jsdom",
setupFiles: "./src/setupTests.js",
},
});

0 comments on commit c0de184

Please sign in to comment.