File size: 1,561 Bytes
09ec238
 
 
 
 
 
 
 
 
 
 
 
 
0fb8bd2
 
 
09ec238
 
 
 
 
 
 
 
 
 
0fb8bd2
09ec238
 
 
 
 
 
 
 
 
 
 
 
0fb8bd2
09ec238
 
 
0fb8bd2
09ec238
 
 
 
 
 
 
 
 
 
0fb8bd2
09ec238
 
bbf592c
09ec238
 
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
# Copyright (c) Meta Platforms, Inc. and affiliates.
# All rights reserved.
#
# This source code is licensed under the BSD-style license found in the
# LICENSE file in the root directory of this source tree.

"""
Data models for the Code Review Environment.

The code_review environment is a simple test environment that echoes back messages.
"""

from openenv.core.env_server.types import Action, Observation
from pydantic import Field, BaseModel
from typing import Optional, List, Any, Dict


class CodeReviewAction(Action):
    """Action for the Code Review environment - just a message to echo."""

    # message: str = Field(..., description="Message to echo back")
    action_type: str  # comment / suggest_fix / final_decision
    comment: Optional[str] = None
    suggested_code: Optional[str] = None
    decision: Optional[str] = None


class CodeDiff(BaseModel):
    file_name: str
    diff: str


class CodeReviewPullRequest(BaseModel):
    id: str
    title: str
    description: str
    diffs: List[CodeDiff]
    language: str


class CodeReviewObservation(Observation):
    """Observation from the Code Review environment - the echoed message."""

    # echoed_message: str = Field(default="", description="The echoed message")
    pr: CodeReviewPullRequest
    previous_comments: List[str]
    step_count: int
    max_steps: int


class CodeReviewReward(BaseModel):
    score: float
    feedback: str


class CodeReviewStepResponse(BaseModel):
    observation: CodeReviewObservation
    reward: float
    done: bool
    info: Dict[str, Any] = {}