data:image/s3,"s3://crabby-images/48dbd/48dbd4e838582c20f24876caecc7dd7c33d68b5c" alt=""
data:image/s3,"s3://crabby-images/ad4ec/ad4ec0d81dd97aa79802d6d579047113edc99320" alt=""
//weather.tsx
import type { NextPage } from "next";
import React, {useState, useEffect} from "react";
const PageComponentWeather: NextPage = () => {
const WeatherComponent = (props: WeatherProps) => {
const [count, setCount] = useState(0);
useEffect(() => {
setCount(1);
}, []);
return (
<h1 onClick={() => setCount(count + 1)}>
The weather is {props.weather},
and the counter shows {count}
</h1>
)
}
return (<WeatherComponent weather="sunny" />);
}
export default PageComponentWeather;
data:image/s3,"s3://crabby-images/03822/03822645859975e4fc22737ddfadea795d6c147b" alt=""
/**
* @jest-environment jsdom
*/
import { render, screen, fireEvent } from '@testing-library/react';
import '@testing-library/jest-dom';
import PageComponentWeather from '@/pages/components/weather';
describe("PageComponentWeather", () => {
test("renders correctly", () => {
render(<PageComponentWeather />);
expect(screen.getByText(/The weather is/i)).toBeInTheDocument();
expect(screen.getByText(/sunny/i)).toBeInTheDocument();
expect(screen.getByText(/and the counter shows/i)).toBeInTheDocument();
});
test("clicks the h1 element and updates the state", () => {
render(<PageComponentWeather />);
// 測試點擊 h1 元素
const h1Element = screen.getByText(/The weather is/i); // 你可以根據具體的文本修改
fireEvent.click(h1Element);
fireEvent.click(h1Element);
// 根據點擊後的效果進行驗證
expect(screen.getByText(/3/i)).toBeInTheDocument();
});
});
data:image/s3,"s3://crabby-images/e48bc/e48bc831b43c476456c840a7d57887c3eb0fc019" alt=""