-
Notifications
You must be signed in to change notification settings - Fork 17
Expand file tree
/
Copy pathevaluation_row_store.py
More file actions
63 lines (49 loc) · 1.42 KB
/
Copy pathevaluation_row_store.py
File metadata and controls
63 lines (49 loc) · 1.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
from abc import ABC, abstractmethod
from typing import List, Optional
class EvaluationRowStore(ABC):
"""
Abstract base class for evaluation row storage.
Stores arbitrary row data as JSON keyed by a unique string `rollout_id`.
Implementations can use different storage backends (SQLite, TinyDB, etc.)
"""
@property
@abstractmethod
def db_path(self) -> str:
"""Return the path to the database file."""
pass
@abstractmethod
def upsert_row(self, data: dict) -> None:
"""
Insert or update a row by rollout_id.
Args:
data: Row data containing execution_metadata.rollout_id
"""
pass
@abstractmethod
def read_rows(self, rollout_id: Optional[str] = None) -> List[dict]:
"""
Read rows, optionally filtered by rollout_id.
Args:
rollout_id: If provided, filter to this specific rollout
Returns:
List of row data dictionaries
"""
pass
@abstractmethod
def delete_row(self, rollout_id: str) -> int:
"""
Delete a row by rollout_id.
Args:
rollout_id: The rollout_id to delete
Returns:
Number of rows deleted
"""
pass
@abstractmethod
def delete_all_rows(self) -> int:
"""
Delete all rows.
Returns:
Number of rows deleted
"""
pass