init app of test arena
This commit is contained in:
52
asf-cloud-server/testarena/backend/app/crud.py
Normal file
52
asf-cloud-server/testarena/backend/app/crud.py
Normal file
@@ -0,0 +1,52 @@
|
||||
from sqlalchemy.orm import Session
|
||||
from . import models, schemas
|
||||
|
||||
def get_user(db: Session, user_id: int):
|
||||
return db.query(models.User).filter(models.User.id == user_id).first()
|
||||
|
||||
def get_user_by_username(db: Session, username: str):
|
||||
return db.query(models.User).filter(models.User.username == username).first()
|
||||
|
||||
def get_users(db: Session, skip: int = 0, limit: int = 100):
|
||||
return db.query(models.User).offset(skip).limit(limit).all()
|
||||
|
||||
def create_user(db: Session, user: schemas.UserCreate, hashed_password: str):
|
||||
db_user = models.User(username=user.username, hashed_password=hashed_password, role=user.role)
|
||||
db.add(db_user)
|
||||
db.commit()
|
||||
db.refresh(db_user)
|
||||
return db_user
|
||||
|
||||
def delete_user(db: Session, user_id: int):
|
||||
db_user = db.query(models.User).filter(models.User.id == user_id).first()
|
||||
if db_user:
|
||||
db.delete(db_user)
|
||||
db.commit()
|
||||
return db_user
|
||||
|
||||
def get_jobs(db: Session, skip: int = 0, limit: int = 100, user_id: int = None):
|
||||
if user_id:
|
||||
return db.query(models.Job).filter(models.Job.user_id == user_id).order_by(models.Job.created_at.desc()).offset(skip).limit(limit).all()
|
||||
return db.query(models.Job).order_by(models.Job.created_at.desc()).offset(skip).limit(limit).all()
|
||||
|
||||
def get_job(db: Session, job_id: int):
|
||||
return db.query(models.Job).filter(models.Job.id == job_id).first()
|
||||
|
||||
def create_job(db: Session, job: schemas.JobCreate, user_id: int):
|
||||
db_job = models.Job(**job.dict(), user_id=user_id)
|
||||
db.add(db_job)
|
||||
db.commit()
|
||||
db.refresh(db_job)
|
||||
return db_job
|
||||
|
||||
def update_job_status(db: Session, job_id: int, status: str, result_path: str = None, duration: str = None):
|
||||
job = db.query(models.Job).filter(models.Job.id == job_id).first()
|
||||
if job:
|
||||
job.status = status
|
||||
if result_path:
|
||||
job.result_path = result_path
|
||||
if duration:
|
||||
job.duration = duration
|
||||
db.commit()
|
||||
db.refresh(job)
|
||||
return job
|
||||
Reference in New Issue
Block a user