Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a578a96347 | |||
| 5749dd825f | |||
| 86c6c14502 | |||
| 561004a49c | |||
| 7d75a15de1 | |||
| eca98c4469 | |||
| c553384ce7 | |||
| 1bf5687505 | |||
| 0d9dcef994 |
+13
-2
@@ -48,7 +48,9 @@ async def websocket_endpoint(websocket: WebSocket, user_id: int):
|
|||||||
try:
|
try:
|
||||||
# send already available data
|
# send already available data
|
||||||
r = processed_agent_data.select().order_by(processed_agent_data.c.timestamp)
|
r = processed_agent_data.select().order_by(processed_agent_data.c.timestamp)
|
||||||
stored_data = SessionLocal().execute(r).fetchall()
|
session = SessionLocal()
|
||||||
|
stored_data = session.execute(r).fetchall()
|
||||||
|
session.close()
|
||||||
|
|
||||||
jsonable_data = [{c.name: getattr(i, c.name) for c in processed_agent_data.columns} for i in stored_data]
|
jsonable_data = [{c.name: getattr(i, c.name) for c in processed_agent_data.columns} for i in stored_data]
|
||||||
for i in jsonable_data:
|
for i in jsonable_data:
|
||||||
@@ -198,9 +200,13 @@ def update_processed_agent_data(processed_agent_data_id: int, data: ProcessedAge
|
|||||||
session.commit()
|
session.commit()
|
||||||
|
|
||||||
updated_result = session.execute(query).fetchone()
|
updated_result = session.execute(query).fetchone()
|
||||||
|
|
||||||
return ProcessedAgentDataInDB(**updated_result._mapping)
|
return ProcessedAgentDataInDB(**updated_result._mapping)
|
||||||
|
|
||||||
|
except Exception as err:
|
||||||
|
session.rollback()
|
||||||
|
print(f"Database error: {err}")
|
||||||
|
raise HTTPException(status_code=500, detail="Internal Server Error")
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
session.close()
|
session.close()
|
||||||
|
|
||||||
@@ -231,6 +237,11 @@ def delete_processed_agent_data(processed_agent_data_id: int):
|
|||||||
|
|
||||||
return ProcessedAgentDataInDB(**result._mapping)
|
return ProcessedAgentDataInDB(**result._mapping)
|
||||||
|
|
||||||
|
except Exception as err:
|
||||||
|
session.rollback()
|
||||||
|
print(f"Database error: {err}")
|
||||||
|
raise HTTPException(status_code=500, detail="Internal Server Error")
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
session.close()
|
session.close()
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,45 @@
|
|||||||
|
from fastapi.testclient import TestClient
|
||||||
|
from main import app, processed_agent_data
|
||||||
|
from database import SessionLocal
|
||||||
|
from sqlalchemy import select
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
client = TestClient(app)
|
||||||
|
|
||||||
|
|
||||||
|
def test_create_processed_agent_data():
|
||||||
|
db = SessionLocal()
|
||||||
|
before = db.execute(select(processed_agent_data)).fetchall()
|
||||||
|
before_count = len(before)
|
||||||
|
payload = {
|
||||||
|
"user_id": 123,
|
||||||
|
"data": [
|
||||||
|
{
|
||||||
|
"road_state": "normal",
|
||||||
|
"agent_data": {
|
||||||
|
"user_id": 999,
|
||||||
|
"accelerometer": {
|
||||||
|
"x": 1.1,
|
||||||
|
"y": 2.2,
|
||||||
|
"z": 3.3
|
||||||
|
},
|
||||||
|
"gps": {
|
||||||
|
"latitude": 50.45,
|
||||||
|
"longitude": 30.52
|
||||||
|
},
|
||||||
|
"timestamp": datetime.now().isoformat()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
response = client.post("/processed_agent_data/", json=payload)
|
||||||
|
|
||||||
|
assert response.status_code == 200
|
||||||
|
|
||||||
|
after = db.execute(select(processed_agent_data)).fetchall()
|
||||||
|
after_count = len(after)
|
||||||
|
|
||||||
|
assert after_count == before_count + 1
|
||||||
|
|
||||||
|
db.close()
|
||||||
Reference in New Issue
Block a user