mirror of
https://github.com/block/goose.git
synced 2026-04-29 12:09:38 +00:00
201 lines
6.7 KiB
Markdown
201 lines
6.7 KiB
Markdown
---
|
|
title: Container Use Extension
|
|
description: Use Container-Use MCP as a Goose Extension
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs';
|
|
import TabItem from '@theme/TabItem';
|
|
import GooseDesktopInstaller from '@site/src/components/GooseDesktopInstaller';
|
|
import CLIExtensionInstructions from '@site/src/components/CLIExtensionInstructions';
|
|
import YouTubeShortEmbed from '@site/src/components/YouTubeShortEmbed';
|
|
|
|
<YouTubeShortEmbed videoUrl="https://www.youtube.com/embed/X3tf61_Tak0" />
|
|
|
|
This tutorial covers how to add the [Container Use MCP Server](https://container-use.com) as a Goose extension enabling Goose to work in an isolated environment.
|
|
|
|
:::tip TLDR
|
|
<Tabs groupId="interface">
|
|
<TabItem value="ui" label="goose Desktop" default>
|
|
[Launch the installer](goose://extension?cmd=container-use&arg=stdio&id=container-use&name=container%20use&description=use%20containers%20with%20dagger%20and%20git%20for%20isolated%20environments)
|
|
</TabItem>
|
|
<TabItem value="cli" label="goose CLI">
|
|
**Command**
|
|
```sh
|
|
container-use stdio
|
|
```
|
|
</TabItem>
|
|
</Tabs>
|
|
:::
|
|
|
|
## Configuration
|
|
|
|
:::info
|
|
You'll need [Docker](https://www.docker.com/) installed on your system. If you want to use the remote MCP server, you'll also need [Node.js](https://nodejs.org/) installed.
|
|
:::
|
|
|
|
<Tabs groupId="online_offline">
|
|
<TabItem value="remote-mcp" label="Remote MCP" default>
|
|
|
|
<Tabs groupId="interface">
|
|
<TabItem value="ui" label="goose Desktop" default>
|
|
<GooseDesktopInstaller
|
|
extensionId="container-use"
|
|
extensionName="Container Use"
|
|
description="Run container automation with container-use"
|
|
command="npx"
|
|
args={["-y", "mcp-remote", "https://container-use.com/mcp"]}
|
|
cliCommand="npx -y mcp-remote https://container-use.com/mcp"
|
|
timeout={300}
|
|
note="Requires Node.js and Docker installed; see [container-use.com/quickstart](https://container-use.com/quickstart)."
|
|
/>
|
|
</TabItem>
|
|
<TabItem value="cli" label="goose CLI">
|
|
<CLIExtensionInstructions
|
|
name="Container Use"
|
|
command="npx -y mcp-remote https://container-use.com/mcp"
|
|
timeout={300}
|
|
/>
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
</TabItem>
|
|
<TabItem value="local-mcp" label="Local MCP">
|
|
|
|
<Tabs groupId="interface">
|
|
<TabItem value="ui" label="goose Desktop" default>
|
|
<GooseDesktopInstaller
|
|
extensionId="container-use"
|
|
extensionName="Container Use"
|
|
description="Run container automation with container-use"
|
|
command="container-use"
|
|
args={["stdio"]}
|
|
cliCommand="container-use stdio"
|
|
timeout={300}
|
|
note="Requires Docker installed; see [container-use.com/quickstart](https://container-use.com/quickstart)."
|
|
/>
|
|
</TabItem>
|
|
<TabItem value="cli" label="goose CLI">
|
|
<CLIExtensionInstructions
|
|
name="Container Use"
|
|
command="container-use stdio"
|
|
timeout={300}
|
|
/>
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
## Example Usage
|
|
|
|
Here's a simple example of updating a file-based to-do app to use a SQLite database plus full testing - all within an isolated container environment.
|
|
|
|
#### Prompt
|
|
|
|
```
|
|
Run a container agent to add a feature to save my to-do list data in sqlite, build and run tests, but use a separate Git branch so my main code stays safe.
|
|
```
|
|
|
|
#### Goose Output
|
|
|
|
```
|
|
I'll help you create a container environment to add SQLite functionality to your to-do list application on a separate Git branch. Let me start by creating the environment and examining your current code structure.
|
|
─── environment_create | containeruse ──────────────────────────
|
|
environment_source: ./examples/todo-list
|
|
explanation: ...
|
|
title: ...
|
|
|
|
Now let me set up the environment with the necessary tools and then proceed with the SQLite feature development:
|
|
─── environment_config | containeruse ──────────────────────────
|
|
config:
|
|
base_image: python:3.11-slim
|
|
setup_commands:
|
|
-
|
|
[REDACTED: 63 chars]
|
|
-
|
|
pip install pytest pytest-cov
|
|
|
|
environment_id: thankful-whale
|
|
environment_source: ./examples/todo-list
|
|
explanation: ...
|
|
|
|
Let me install pytest after the environment is running:
|
|
|
|
---
|
|
|
|
Great! I've created a container environment for safely adding SQLite functionality to your to-do list app. Let me first explore the current code structure and then create a new Git branch.
|
|
|
|
---
|
|
|
|
Now I'll create the SQLite-based storage implementation. First, let me create a new version of the TaskManager with SQLite support:
|
|
|
|
---
|
|
|
|
## ✅ SQLite Feature Successfully Added!
|
|
|
|
I've successfully created a container environment and added SQLite functionality to your to-do list application! Here's what was accomplished:
|
|
|
|
### 🎯 **Features Implemented**
|
|
|
|
1. **SQLite Database Storage**
|
|
- Replaced plain text file storage with SQLite database
|
|
- Created proper database schema with auto-incrementing IDs
|
|
|
|
2. **Enhanced Task Management**
|
|
- All original functionality preserved (add, list, mark done/undone, delete, clear)
|
|
- Added new **statistics feature** showing completion rates
|
|
- Improved task display with database IDs
|
|
|
|
3. **Two Implementation Versions**
|
|
- `taskman_sqlite.py` - Full-featured with Rich UI
|
|
- `taskman_sqlite_simple.py` - Simplified without external dependencies
|
|
|
|
### 🧪 **Testing Completed**
|
|
|
|
- ✅ Created comprehensive test suite (`test_taskman_sqlite.py`)
|
|
- ✅ Built simple test runner (`test_simple.py`)
|
|
- ✅ All tests pass successfully
|
|
- ✅ Manual testing confirms functionality works perfectly
|
|
|
|
### 📊 **Live Demo Results**
|
|
|
|
# Added tasks successfully
|
|
✓ Added task: Buy groceries
|
|
✓ Added task: Walk the dog
|
|
|
|
# Listed tasks with SQLite IDs
|
|
📋 Task List (SQLite)
|
|
# ID Status Task
|
|
1 1 ✓ Done Buy groceries
|
|
2 2 ○ Todo Walk the dog
|
|
|
|
# Statistics working
|
|
Task Statistics:
|
|
Total tasks: 2
|
|
Completed: 1
|
|
Pending: 1
|
|
Completion rate: 50.0%
|
|
|
|
# Database verified
|
|
sqlite3 tasks.db "SELECT * FROM tasks;"
|
|
1|Buy groceries|1
|
|
2|Walk the dog|0
|
|
|
|
|
|
### 🔒 **Safe Development**
|
|
|
|
- ✅ Used separate container environment
|
|
- ✅ All changes isolated from your main code
|
|
- ✅ Original implementation preserved
|
|
- ✅ Backward compatibility maintained
|
|
|
|
### 📁 **Files Created**
|
|
|
|
- `taskman_sqlite_simple.py` - Main SQLite implementation
|
|
- `test_simple.py` - Test suite
|
|
- `SQLITE_FEATURE_README.md` - Comprehensive documentation
|
|
- `tasks.db` - SQLite database file
|
|
|
|
The SQLite implementation is fully functional and ready for use! The original file-based version remains untouched, so you can safely evaluate the new SQLite features without any risk to your existing code.
|
|
|
|
```
|