You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
153 lines
6.2 KiB
153 lines
6.2 KiB
import io
|
|
import unittest
|
|
|
|
import pandas as pd
|
|
from fastapi.testclient import TestClient
|
|
from sqlalchemy import create_engine
|
|
from sqlalchemy.orm import sessionmaker
|
|
|
|
from pick_student import crud, schemas
|
|
from pick_student.database import Base
|
|
from pick_student.login import get_password_hash
|
|
from pick_student.main import get_db
|
|
from run import app # 从 run.py 导入主 app
|
|
from pick_student.crud import create_teacher, create_class
|
|
|
|
# 设置测试数据库
|
|
SQLALCHEMY_DATABASE_URL = "sqlite:///./test_test.db" # 使用不同的数据库文件名
|
|
engine = create_engine(SQLALCHEMY_DATABASE_URL, connect_args={"check_same_thread": False})
|
|
TestingSessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
|
|
|
# 创建所有表
|
|
Base.metadata.create_all(bind=engine)
|
|
|
|
# 重写 get_db 函数用于测试
|
|
def override_get_db():
|
|
db = TestingSessionLocal()
|
|
try:
|
|
yield db
|
|
except Exception as e:
|
|
db.close()
|
|
raise e # 重新抛出异常
|
|
finally:
|
|
db.close() # 确保数据库连接被正确关闭
|
|
|
|
# 覆盖 app 中的依赖项
|
|
app.dependency_overrides[get_db] = override_get_db
|
|
|
|
# 创建测试客户端
|
|
client = TestClient(app)
|
|
class TestMainRoutes(unittest.TestCase):
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
# 在测试开始时设置初始数据库状态
|
|
db = TestingSessionLocal()
|
|
hashed_password = get_password_hash("password") # 假设已经生成一个哈希密码
|
|
create_teacher(db, user_name="test_teacher", password_hash=hashed_password)
|
|
crud.create_class(db, cclass=schemas.create_class(class_name="2班", user_name="test_teacher",class_time="周三 5-6节"))
|
|
crud.create_class(db, cclass=schemas.create_class(class_name="3班", user_name="test_teacher",class_time="周三 5-6节"))
|
|
crud.create_student(db, student=schemas.create_student(class_name="2班", name="Alice", student_id=101, user_name="test_teacher"))
|
|
crud.create_student(db, student=schemas.create_student(class_name="2班", name="Bob", student_id=102,user_name="test_teacher"))
|
|
crud.create_student(db, student=schemas.create_student(class_name="2班", name="Charlie", student_id=103, user_name="test_teacher"))
|
|
crud.create_student(db, student=schemas.create_student(class_name="3班", name="David", student_id=104, user_name="test_teacher"))
|
|
db.close()
|
|
|
|
def test_create_classroom(self):
|
|
# 测试创建班级的成功情况
|
|
response = client.post(
|
|
"/teacher/pick_student/create_class/",
|
|
params={"class_name": "1班","class_time":"周三 5-6节"},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.json()["message"], "班级创建成功")
|
|
|
|
def test_upload_students(self):
|
|
# 测试上传学生信息的成功情况
|
|
class_name = "1班"
|
|
data = {
|
|
'name': ['Alice', 'Bob'],
|
|
'student_id': [101, 102]
|
|
, 'user_name': ['test_teacher', 'test_teacher']
|
|
}
|
|
df = pd.DataFrame(data)
|
|
excel_buffer = io.BytesIO()
|
|
df.to_excel(excel_buffer, index=False)
|
|
excel_buffer.seek(0)
|
|
|
|
response = client.post(
|
|
"/teacher/pick_student/upload_students/",
|
|
files={"file": ("students.xlsx", excel_buffer, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")},
|
|
params={"class_name": class_name},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.json()["message"], "Student list uploaded successfully.")
|
|
def test_get_students(self):
|
|
response = client.get(
|
|
"/teacher/pick_student/get_students/",
|
|
params={"class_name": "2班"},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
def test_update_score(self):
|
|
response = client.put(
|
|
"/teacher/pick_student/update_score/",
|
|
params={"class_name": "2班", "student_id": 101, "arrival": True, "question_repeated": False, "question_correct": 2.5},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
print(response.json())
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertIn("scores", response.json())
|
|
def test_is_reverse_day(self):
|
|
response = client.put(
|
|
"/teacher/pick_student/is_reverse_day/",
|
|
params={"flag": True},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
print(response.json())
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.json(), {"message": "Flag has been set True"})
|
|
def test_random_pick(self):
|
|
# 测试随机点名的功能
|
|
response = client.get(
|
|
"/teacher/pick_student/random_pick/",
|
|
params={"class_name": "2班"},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
print(response.json())
|
|
self.assertEqual(response.status_code, 200)
|
|
data = response.json()
|
|
self.assertIn("name", data)
|
|
self.assertIn("student_id", data)
|
|
|
|
def test_get_classes(self):
|
|
response = client.get(
|
|
"/teacher/pick_student/getclasses/",
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
data = response.json()
|
|
def test_delete_class(self):
|
|
response = client.delete(
|
|
"/teacher/pick_student/delete_class/",
|
|
params={"class_name": "3班"},
|
|
headers={"Authorization": "Bearer " + self.get_access_token()}
|
|
)
|
|
self.assertEqual(response.status_code, 200)
|
|
def get_access_token(self):
|
|
# 获取访问令牌
|
|
response = client.post(
|
|
"/teacher/jwt/token",
|
|
data={"username": "test_teacher", "password": "password"},
|
|
)
|
|
return response.json()["access_token"]
|
|
|
|
@classmethod
|
|
def tearDownClass(cls):
|
|
# 清理测试数据库
|
|
Base.metadata.drop_all(bind=engine)
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main() |