Skip to content

Commit

Permalink
Revert "Adapt code to work with PyTA (#103)"
Browse files Browse the repository at this point in the history
This reverts commit 2fb167f.
  • Loading branch information
yoonieaj committed Nov 21, 2024
1 parent baadd94 commit 70d7694
Show file tree
Hide file tree
Showing 8 changed files with 34 additions and 146 deletions.
6 changes: 1 addition & 5 deletions jest.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -103,11 +103,7 @@ const config: Config = {
// preset: undefined,

// Run tests from one or more projects
projects: [
"./demo/jest.config.ts",
"./memory-viz/jest.config.ts",
"./webstepper/jest.config.ts",
],
projects: ["./demo/jest.config.ts", "./memory-viz/jest.config.ts"],

// Use this configuration option to add custom reporters to Jest
// reporters: undefined,
Expand Down
22 changes: 0 additions & 22 deletions webstepper/CHANGELOG.md

This file was deleted.

1 change: 0 additions & 1 deletion webstepper/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
"test-cov": "jest --no-cache --coverage",
"build-dev": "webpack --config webpack.dev.js",
"build": "webpack --config webpack.prod.js",
"build-copy": "webpack --config webpack.prod.js && cp -r dist/*",
"start": "webpack serve --config webpack.dev.js"
},
"repository": {
Expand Down
36 changes: 13 additions & 23 deletions webstepper/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,57 +3,47 @@ import Header from "./Header";
import { Button, Box, Typography, Stack } from "@mui/material";
import SvgDisplay from "./SvgDisplay";
import CodeDisplay from "./CodeDisplay";
import placeholder from "./placeholder";
import "./css/styles.css";

if (typeof window === "object" && process.env.NODE_ENV !== "production") {
window.svgArray = placeholder.svgArray;
window.codeText = placeholder.codeText;
}

export default function App() {
const [step, setStep] = useState<number>(0);
const codeText = window.codeText;
const limit = window.svgArray.length;

// TODO: replace this with actual code to display
const codeText = `num = 123
some_string = "Hello, world"
num2 = 321
arr = [some_string, "string 123321"]`;
const limit = codeText.split("\n").length;
const handleStep = (newStep: number) => {
setStep(Math.min(Math.max(newStep, 0), limit - 1));
};
const svgPath = `/images/snapshot-${step}.svg`;

return (
<main className="container">
<Header />
<Stack direction="row" spacing={2}>
<Box sx={{ width: "40%" }}>
<h2>Code</h2>
<Typography>
Step {step + 1}/{limit}
</Typography>
<Typography>Line: {step + 1}</Typography>
<Box className="code-display">
<CodeDisplay
text={codeText}
startingLineNumber={window.svgArray[0].lineNumber}
highlightLine={window.svgArray[step].lineNumber}
startingLineNumber={Math.max(step - 10, 1)}
highlightLine={step + 1}
/>
<Box className="button-container">
<Button
disabled={step === 0}
onClick={() => handleStep(step - 1)}
>
<Button onClick={() => handleStep(step - 1)}>
Back
</Button>
<Button
disabled={step === limit - 1}
onClick={() => handleStep(step + 1)}
>
<Button onClick={() => handleStep(step + 1)}>
Next
</Button>
</Box>
</Box>
</Box>
<Box sx={{ width: "60%" }}>
<h2>Memory diagrams</h2>
<SvgDisplay step={step} />
<SvgDisplay svgPath={svgPath} />
</Box>
</Stack>
</main>
Expand Down
11 changes: 5 additions & 6 deletions webstepper/src/SvgDisplay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { TransformWrapper, TransformComponent } from "react-zoom-pan-pinch";
import "./css/styles.css";

type SvgDisplayPropTypes = {
step: number;
svgPath: string;
};

export default function SvgDisplay(props: SvgDisplayPropTypes) {
Expand All @@ -13,11 +13,10 @@ export default function SvgDisplay(props: SvgDisplayPropTypes) {
useEffect(() => {
const loadAndDrawSvg = async () => {
try {
const svgString = window.svgArray[props.step].svg;
const response = await fetch(props.svgPath);
const blob = await response.blob();
const image = new Image();
let data =
"data:image/svg+xml;base64," + window.btoa(svgString);
image.src = data;
image.src = URL.createObjectURL(blob);
image.onload = () => {
const canvas = canvasRef.current;
const context = canvas.getContext("2d");
Expand All @@ -31,7 +30,7 @@ export default function SvgDisplay(props: SvgDisplayPropTypes) {
}
};
loadAndDrawSvg();
}, [props.step]);
}, [props.svgPath]);

return (
<Paper
Expand Down
36 changes: 15 additions & 21 deletions webstepper/src/__tests__/App.spec.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,6 @@ global.fetch = jest.fn(() =>

URL.createObjectURL = jest.fn(() => "mock-url");

const getStepString = (): string => {
return screen.getByText(/Step \d+\/\d+/).textContent;
};

const getMaxStep = (): number => {
return Number(getStepString().split("/")[1]);
};

describe("App", () => {
beforeEach(() => {
global.fetch = jest.fn(() =>
Expand All @@ -32,50 +24,52 @@ describe("App", () => {
});

it("renders initial state correctly", async () => {
expect(screen.getByText(/Step \d+\/\d+/)).toBeInTheDocument();
expect(screen.getByText("Line: 1")).toBeInTheDocument();
expect(screen.getByText("Code")).toBeInTheDocument();
expect(screen.getByText("Memory diagrams")).toBeInTheDocument();
await waitFor(() => {
expect(global.fetch).toHaveBeenCalledWith("/images/snapshot-0.svg");
});
});

it("handles next button click correctly", () => {
const maxStep = getMaxStep();
const nextButton = screen.getByText("Next");
fireEvent.click(nextButton);

expect(screen.getByText(`Step 2/${maxStep}`)).toBeInTheDocument();
expect(screen.getByText("Line: 2")).toBeInTheDocument();
expect(global.fetch).toHaveBeenCalledWith("/images/snapshot-1.svg");
});

it("handles back button click correctly", () => {
const maxStep = getMaxStep();
// First go forward
const nextButton = screen.getByText("Next");
fireEvent.click(nextButton);

expect(screen.getByText(`Step 2/${maxStep}`)).toBeInTheDocument();

// Then go back
const backButton = screen.getByText("Back");
fireEvent.click(backButton);

expect(screen.getByText(`Step 1/${maxStep}`)).toBeInTheDocument();
expect(screen.getByText("Line: 1")).toBeInTheDocument();
expect(global.fetch).toHaveBeenCalledWith("/images/snapshot-0.svg");
});

it("prevents going below step 0", () => {
const backButton = screen.getByText("Back");
fireEvent.click(backButton);

expect(screen.getByText(`Step 1/${getMaxStep()}`)).toBeInTheDocument();
expect(screen.getByText("Line: 1")).toBeInTheDocument();
expect(global.fetch).toHaveBeenCalledWith("/images/snapshot-0.svg");
});

it("prevents going above maximum steps", () => {
const maxStep = getMaxStep();
// The limit is 4 (defined in App.tsx)
const nextButton = screen.getByText("Next");
for (let i = 0; i < maxStep; i++) {
for (let i = 0; i < 5; i++) {
fireEvent.click(nextButton);
}

expect(
screen.getByText(`Step ${maxStep}/${maxStep}`)
).toBeInTheDocument();
expect(screen.getByText("Line: 4")).toBeInTheDocument();
expect(global.fetch).toHaveBeenCalledWith("/images/snapshot-3.svg");
});

it("highlights the correct line in code display", async () => {
Expand Down
8 changes: 0 additions & 8 deletions webstepper/src/declarations.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,3 @@ declare module "*.svg" {
const value: string;
export default value;
}

declare interface Window {
svgArray: {
lineNumber: number;
svg: string;
}[];
codeText: string;
}
60 changes: 0 additions & 60 deletions webstepper/src/placeholder.js

This file was deleted.

0 comments on commit 70d7694

Please sign in to comment.