Seer is a service that provides AI capabilities to Sentry by running inference on Sentry issues and providing user insights.
📣 Seer is currently in early development and not yet compatible with self-hosted Sentry instances. Stay tuned for updates!
These instructions require access to internal Sentry resources and are intended for internal Sentry employees.
pyenv install 3.11
pyenv local 3.11
- Install Docker. Note that if you want to install Docker from brew instead of Docker Desktop, then you would need to install docker-compose as well.
- Install Google Cloud SDK and authenticate.
- Clone the repository and navigate to the project root
- Run
direnv allow
to set up the Python environment - Create a
.env
file based on.env.example
and set the required values - (Optional) Add
SENTRY_AUTH_TOKEN=<your token>
to your.env
file
Download model artifacts:
gsutil cp -r gs://sentry-ml/seer/models .
If you see a prompt "Reauthentication required. Please insert your security key and press enter...", re-authenticate using the command gcloud auth login
and set the project id to the one for Seer.
-
Start the development environment:
make dev
-
If you encounter database errors, run:
make update
-
If you encounter authentication errors, run:
gcloud auth application-default login
-
Expose port 9091 in your local Sentry configuration
-
Add the following to
~/.sentry/sentry.conf.py
:SEER_RPC_SHARED_SECRET = ["seers-also-very-long-value-haha"] SENTRY_FEATURES['projects:ai-autofix'] = True SENTRY_FEATURES['organizations:issue-details-autofix-ui'] = True
-
For local development, you may need to bypass certain checks in the Sentry codebase
-
Restart both Sentry and Seer
Note
Set NO_SENTRY_INTEGRATION=1
in .env
to ignore Local Sentry Integration
- Apply database migrations:
make update
- Create new migrations:
make migration
- Run type checker:
make mypy
- Run tests:
make test
- Open a shell:
make shell
- Update
requirements.txt
based onrequirements-constraints.txt
:make upgrade-package-versions
To start fresh:
bash
docker compose down --volumes
make update && make dev
To enable Langfuse tracing, set these environment variables:
LANGFUSE_SECRET_KEY=...
LANGFUSE_PUBLIC_KEY=...
LANGFUSE_HOST=...
Autofix is an AI agent that identifies root causes of Sentry issues and suggests fixes.
Send a POST request to /v1/automation/autofix/evaluations/start
with the following JSON body:
{
"dataset_name": "string", // Name of the dataset to run on (currently only internal datasets available)
"run_name": "string", // Custom name for your evaluation run
"run_description": "string", // Description of your evaluation run
"run_type": "full | root_cause | execution", // Type of evaluation to perform
"test": boolean, // Set to true to run on a single item (for testing)
"random_for_test": boolean, // Set to true to use a random item when testing (requires "test": true)
"run_on_item_id": "string", // Specific item ID to run on (optional)
"n_runs_per_item": int // Number of runs to perform per item (optional, default 1)
}
Note: Currently, only internal datasets are available.
It is possible to run and deploy seer to a sandbox staging environment. An example of such a deployment is in this PR.
To get started, use the #proj-tf-sandbox
channel and request direction or help on scaffolding a new sandbox in the
sandbox repo.
You then can use the iap,
and seer-staging
modules to scaffold a public load balancer pointing to a compute running the docker-compose.staging.yml
file.
After scaffolding your environment, you'll want to set your SBX_PROJECT
environment variable in your .env
file, and
run make push-staging
to submit a cloud build for your image.
!!!!NOTE!!!!
The staging cloud build uses your current local environment to build the image, not CI, which means it will use all your
src files and your local .env
file to configure the image that will be hosted in your sandbox. Make sure you don't
accidentally include any sensitive personal files in your source tree before using this.
Each time you push with make push-staging
there will be a period of time while the VM polls and unpacks the new image
before it is loaded. If you have a SENTRY_DSN
and SENTRY_ENVIRONMENT
set, a release will be created by the push,
allowing you to track when the server has loaded that release version.
You can run all tests with make test
.
Make sure you have the test database running when running individual tests, do that via docker compose up --remove-orphans -d test-db
.
To run a single test, make sure you're in a shell, by doing make shell
, and then run pytest tests/path/to/test.py::test_name
.
VCRs are a way to record and replay HTTP requests. They are useful for recording requests from external services that you don't control instead of mocking them.
To use VCRs, add the @pytest.mark.vcr()
decorator to your test.
To record new VCRs, delete the existing cassettes and run the test. Subsequent test runs will use the cassette instead of making requests.
You must not commit the raw VCRs to the repo. Instead, you must encrypt them using make vcr-encrypt
and decrypt them using make vcr-decrypt
.
Before first time running encryption or decryption, you will need to run make vcr-encrypt-prep
to install the required libraries and authenticate with GCP.
Before committing the VCRs, you must run make vcr-encrypt
to encrypt them.
By default, the
CLEAN=1
flag is set, so the encrypted cassettes will match exactly what you have in your local. If you want to not overwrite files, runmake vcr-encrypt CLEAN=0
.
If you want to run tests with VCRs enabled, you must run make vcr-decrypt
to decrypt them.
By default, the
CLEAN
flag is not set, so files in your local that don't exist in the repo will not be deleted. If you want your local to match exactly what is in the encrypted cassettes, run withCLEAN=1
.
You can set the queue that the celery worker listens on via the CELERY_WORKER_QUEUE
environment variable.
If not set, the default queue name is "seer"
.