feat: Sandboxing for tool execution #2041
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Run Docker integration tests | |
on: | |
push: | |
branches: [ main ] | |
pull_request: | |
branches: [ main ] | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
timeout-minutes: 15 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.12' | |
- name: Set permissions for log directory | |
run: | | |
mkdir -p /home/runner/.letta/logs | |
sudo chown -R $USER:$USER /home/runner/.letta/logs | |
chmod -R 755 /home/runner/.letta/logs | |
- name: Build and run docker dev server | |
env: | |
LETTA_PG_DB: letta | |
LETTA_PG_USER: letta | |
LETTA_PG_PASSWORD: letta | |
LETTA_PG_PORT: 8888 | |
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | |
run: docker compose -f dev-compose.yaml up --build -d | |
#- name: "Setup Python, Poetry and Dependencies" | |
# uses: packetcoders/[email protected] | |
# with: | |
# python-version: "3.12" | |
# poetry-version: "1.8.2" | |
# install-args: "--all-extras" | |
- name: Wait for service | |
run: bash scripts/wait_for_service.sh http://localhost:8283 -- echo "Service is ready" | |
- name: Run tests with pytest | |
env: | |
LETTA_PG_DB: letta | |
LETTA_PG_USER: letta | |
LETTA_PG_PASSWORD: letta | |
LETTA_PG_PORT: 8888 | |
LETTA_SERVER_PASS: test_server_token | |
LETTA_SERVER_URL: http://localhost:8283 | |
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | |
PYTHONPATH: ${{ github.workspace }}:${{ env.PYTHONPATH }} | |
run: | | |
pipx install poetry==1.8.2 | |
poetry install -E dev -E postgres | |
poetry run pytest -s tests/test_client.py | |
- name: Print docker logs if tests fail | |
if: failure() | |
run: | | |
echo "Printing Docker Logs..." | |
docker compose -f dev-compose.yaml logs |