Skip to content

Commit

Permalink
Merge branch 'main' into issue-1584/-hide-cost-and-usage-in-playgroun…
Browse files Browse the repository at this point in the history
…d-and-evaluation-when-these-are-not-specified
  • Loading branch information
bekossy committed May 9, 2024
2 parents 715ea9f + f115323 commit 0263ffe
Show file tree
Hide file tree
Showing 12 changed files with 266 additions and 198 deletions.
15 changes: 15 additions & 0 deletions agenta-backend/agenta_backend/routers/variants_router.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import os
import inspect
import logging
from typing import Any, Optional, Union, List

Expand All @@ -24,11 +25,13 @@
Image_ as Image,
AppVariantResponse_ as AppVariantResponse,
)
from agenta_backend.cloud.services import logs_manager
else:
from agenta_backend.models.api.api_models import (
Image,
AppVariantResponse,
)
from agenta_backend.services import logs_manager

from agenta_backend.models.api.api_models import (
URI,
Expand Down Expand Up @@ -312,6 +315,18 @@ async def start_variant(
return url


@router.get("/{variant_id}/logs/", operation_id="retrieve_variant_logs")
async def retrieve_variant_logs(variant_id: str, request: Request):
try:
app_variant = await db_manager.fetch_app_variant_by_id(variant_id)
deployment = await db_manager.get_deployment_by_appid(str(app_variant.app.id))
logs_result = await logs_manager.retrieve_logs(deployment.container_id)
return logs_result
except Exception as exc:
logger.exception(f"An error occurred: {str(exc)}")
raise HTTPException(500, {"message": str(exc)})


@router.get(
"/{variant_id}/",
operation_id="get_variant",
Expand Down
18 changes: 18 additions & 0 deletions agenta-backend/agenta_backend/services/logs_manager.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import aiodocker


async def retrieve_logs(container_id: str) -> str:
"""
Retrieves and returns the last 10 lines of logs (both stdout and stderr)
for a specified Docker container.
Args:
container_id (str): The docker container identifier
Returns:
the last 10 lines of logs
"""

async with aiodocker.Docker() as client:
container = await client.containers.get(container_id)
logs = await container.log(stdout=True, stderr=True)
outputs = logs[::-1][:10]
return "".join(outputs)
2 changes: 1 addition & 1 deletion agenta-backend/pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[tool.poetry]
name = "agenta_backend"
version = "0.14.2"
version = "0.14.4"
description = ""
authors = ["Mahmoud Mabrouk <[email protected]>"]
readme = "README.md"
Expand Down
19 changes: 13 additions & 6 deletions agenta-cli/agenta/cli/variant_commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ def variant():


def add_variant(
app_folder: str, file_name: str, host: str, config_name="default"
app_folder: str, file_name: str, host: str, overwrite: bool, config_name="default"
) -> str:
"""
Adds a variant to the backend. Sends the code as a tar to the backend, which then containerizes it and adds it to the backend store.
Expand Down Expand Up @@ -97,14 +97,13 @@ def add_variant(

# update the config file with the variant names from the backend
variant_name = f"{base_name}.{config_name}"
overwrite = False

client = AgentaApi(
base_url=f"{host}/{BACKEND_URL_SUFFIX}",
api_key=api_key,
)

if variant_name in config["variants"]:
if variant_name in config["variants"] and not overwrite:
overwrite = questionary.confirm(
"This variant already exists. Do you want to overwrite it?"
).ask()
Expand Down Expand Up @@ -443,9 +442,15 @@ def remove_variant_cli(variant_name: str, app_folder: str):
)
@click.option("--app_folder", default=".")
@click.option("--file_name", default=None, help="The name of the file to run")
@click.option(
"--overwrite",
is_flag=True,
default=False,
help="Overwrite the existing variant if it exists",
)
@click.pass_context
def serve_cli(ctx, app_folder: str, file_name: str):
"""Adds a variant to the web ui and serves the API locally."""
def serve_cli(ctx, app_folder: str, file_name: str, overwrite: bool):
"""Adds a variant to the web UI and serves the API locally."""

if not file_name:
if ctx.args:
Expand Down Expand Up @@ -480,7 +485,9 @@ def serve_cli(ctx, app_folder: str, file_name: str):
return

try:
variant_id = add_variant(app_folder=app_folder, file_name=file_name, host=host)
variant_id = add_variant(
app_folder=app_folder, file_name=file_name, host=host, overwrite=overwrite
)
except Exception as e:
click.echo(click.style("Failed to add variant.", fg="red"))
click.echo(click.style(f"Error message: {str(e)}", fg="red"))
Expand Down
2 changes: 1 addition & 1 deletion agenta-cli/agenta/docker/docker-assets/Dockerfile.template
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,5 @@ RUN pip install --no-cache-dir --disable-pip-version-check -r requirements.txt

EXPOSE 80

RUN ["chmod", "+x", "./entrypoint.sh"]
CMD ["./entrypoint.sh"]
# uvicorn agenta_backend.main:app --reload --host 0.0.0.0 --port 8881
326 changes: 160 additions & 166 deletions agenta-cli/poetry.lock

Large diffs are not rendered by default.

3 changes: 2 additions & 1 deletion agenta-cli/pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[tool.poetry]
name = "agenta"
version = "0.14.2"
version = "0.14.4"
description = "The SDK for agenta is an open-source LLMOps platform."
readme = "README.md"
authors = ["Mahmoud Mabrouk <[email protected]>"]
Expand Down Expand Up @@ -34,6 +34,7 @@ cachetools = "^5.3.3"

[tool.poetry.dev-dependencies]
pytest = "^6.2"
setuptools = "^69.5.1"

[build-system]
requires = ["poetry-core"]
Expand Down
4 changes: 2 additions & 2 deletions agenta-web/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion agenta-web/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "agenta",
"version": "0.14.2",
"version": "0.14.4",
"private": true,
"engines": {
"node": ">=18"
Expand Down
59 changes: 39 additions & 20 deletions agenta-web/src/components/Playground/ViewNavigation.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import React, {useEffect, useRef} from "react"
import {Col, Row, Divider, Button, Tooltip, Spin, notification} from "antd"
import {Col, Row, Divider, Button, Tooltip, Spin, notification, Typography} from "antd"
import TestView from "./Views/TestView"
import ParametersView from "./Views/ParametersView"
import {useVariant} from "@/lib/hooks/useVariant"
Expand All @@ -9,6 +9,7 @@ import {useState} from "react"
import axios from "axios"
import {createUseStyles} from "react-jss"
import {
fetchVariantLogs,
getAppContainerURL,
removeVariant,
restartAppVariantContainer,
Expand All @@ -18,6 +19,8 @@ import {useAppsData} from "@/contexts/app.context"
import {isDemo} from "@/lib/helpers/utils"
import ResultComponent from "../ResultComponent/ResultComponent"

const {Text} = Typography

interface Props {
variant: Variant
handlePersistVariant: (variantName: string) => void
Expand All @@ -36,6 +39,9 @@ const useStyles = createUseStyles({
restartBtnMargin: {
marginRight: "10px",
},
errorLogs: {
whiteSpace: "pre-wrap",
},
})

const ViewNavigation: React.FC<Props> = ({
Expand Down Expand Up @@ -69,6 +75,7 @@ const ViewNavigation: React.FC<Props> = ({
const [retrying, setRetrying] = useState(false)
const [isParamsCollapsed, setIsParamsCollapsed] = useState("1")
const [containerURI, setContainerURI] = useState("")
const [variantErrorLogs, setVariantErrorLogs] = useState("")
const [restarting, setRestarting] = useState<boolean>(false)
const {currentApp} = useAppsData()
const retriedOnce = useRef(false)
Expand Down Expand Up @@ -101,7 +108,15 @@ const ViewNavigation: React.FC<Props> = ({
setRetrying(false)
})
}
}, [netWorkError])

if (isError) {
const getLogs = async () => {
const logs = await fetchVariantLogs(variant.variantId)
setVariantErrorLogs(logs)
}
getLogs()
}
}, [netWorkError, isError, variant.variantId])

if (retrying || (!retriedOnce.current && netWorkError)) {
return (
Expand All @@ -115,7 +130,8 @@ const ViewNavigation: React.FC<Props> = ({

if (isError) {
let variantDesignator = variant.templateVariantName
let imageName = `agentaai/${(currentApp?.app_name || "").toLowerCase()}_`
let appName = currentApp?.app_name || ""
let imageName = `agentaai/${appName.toLowerCase()}_`

if (!variantDesignator || variantDesignator === "") {
variantDesignator = variant.variantName
Expand Down Expand Up @@ -165,31 +181,34 @@ const ViewNavigation: React.FC<Props> = ({
<p>
Error connecting to the variant {variant.variantName}.{" "}
{(axios.isAxiosError(error) && error.response?.status === 404 && (
<span>Container is not running.</span>
<span>
Container is not running. <b>See logs below:</b>
</span>
)) || <span>{error.message}</span>}
</p>
<p>To debug this issue, please follow the steps below:</p>
<ul>
<li>
Verify whether the API is up by checking if {apiAddress} is
accessible.
</li>
<li>
Check if the Docker container for the variant {variantDesignator} is
running. The image should be called {imageName}.
</li>
<div>
<Text code className={classes.errorLogs}>
{variantErrorLogs}
</Text>
</div>
</ul>
<p>
{" "}
In case the docker container is not running. Please check the logs from
docker to understand the issue. Most of the time it is a missing
requirements. Also, please attempt restarting it (using cli or docker
desktop)
Verify API accessibility at{" "}
<a href={apiAddress} target="_blank">
{apiAddress}
</a>
</p>
<p>
{" "}
If the issue persists please file an issue in github here:
https://github.com/Agenta-AI/agenta/issues/new?title=Issue%20in%20ViewNavigation.tsx
If the issue persists please file an issue in github
<a
href="https://github.com/Agenta-AI/agenta/issues/new?title=Issue%20in%20ViewNavigation.tsx"
target="_blank"
>
{" "}
here
</a>
</p>

<Button
Expand Down
7 changes: 7 additions & 0 deletions agenta-web/src/lib/services/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,13 @@ export async function fetchVariants(
return []
}

export const fetchVariantLogs = async (variantId: string, ignoreAxiosError: boolean = false) => {
const response = await axios.get(`${getAgentaApiUrl()}/api/variants/${variantId}/logs`, {
_ignoreError: ignoreAxiosError,
} as any)
return response.data
}

export function restartAppVariantContainer(variantId: string) {
return axios.post(`${getAgentaApiUrl()}/api/containers/restart_container/`, {
variant_id: variantId,
Expand Down
7 changes: 7 additions & 0 deletions docs/developer_guides/cli/quick-usage.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -44,3 +44,10 @@ agenta variant serve myapp.py
```

This command deploys a new variant to the Agenta platform. It processes the code in the specified folder, with `myapp.py` as the entrypoint. This command builds a Docker image and deploys a container based on it. As a result, the variant becomes accessible in the web UI, allowing for prediction generation and API calls. The variant is named as `myapp.default` in the UI.


## Overwrite an application

```bash
agenta variant serve --file_name myapp.py --overwrite
```

0 comments on commit 0263ffe

Please sign in to comment.