use std::sync::Arc;
use chrono::Utc;
use everruns_core::capabilities::AgentInstructionsCapability;
use everruns_core::llm_driver_registry::DriverRegistry;
use everruns_core::llmsim_driver::LlmSimConfig;
use everruns_core::{
Agent, AgentCapabilityConfig, AgentStatus, CapabilityRegistry, Harness, HarnessStatus,
LlmProviderType, ModelWithProvider, PlatformDefinition, Session, SessionStatus,
};
use everruns_runtime::{InProcessRuntimeBuilder, RealDiskSessionFileSystemFactory};
use tempfile::TempDir;
use uuid::Uuid;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let workspace = TempDir::new()?;
println!("workspace root: {}", workspace.path().display());
std::fs::write(
workspace.path().join("AGENTS.md"),
"## Project rules\nPrefer snake_case identifiers.",
)?;
let mut capabilities = CapabilityRegistry::new();
capabilities.register(AgentInstructionsCapability);
let platform = PlatformDefinition::builder()
.capability_registry(capabilities)
.driver_registry(DriverRegistry::new())
.session_file_system_factory(Arc::new(RealDiskSessionFileSystemFactory::new(
workspace.path(),
)))
.build();
let harness_id = "harness_00000000000000000000000000000091".parse().unwrap();
let agent_id = "agent_00000000000000000000000000000091".parse().unwrap();
let session_id = "session_00000000000000000000000000000091".parse().unwrap();
let runtime = InProcessRuntimeBuilder::new()
.platform_definition(platform)
.llm_sim(LlmSimConfig::fixed("ack"))
.default_model(ModelWithProvider {
model: "llmsim-model".into(),
provider_type: LlmProviderType::LlmSim,
api_key: Some("fake-key".into()),
base_url: None,
})
.harness(Harness {
id: harness_id,
name: "coding".into(),
display_name: Some("Coding".into()),
description: Some("Harness that respects AGENTS.md".into()),
system_prompt: "You are a coding assistant.".into(),
parent_harness_id: None,
default_model_id: None,
tags: vec![],
capabilities: vec![AgentCapabilityConfig::new("agent_instructions")],
initial_files: vec![],
network_access: None,
mcp_servers: Default::default(),
is_built_in: false,
status: HarnessStatus::Active,
created_at: Utc::now(),
updated_at: Utc::now(),
archived_at: None,
deleted_at: None,
})
.agent(Agent {
public_id: agent_id,
internal_id: Uuid::nil(),
name: "coding-agent".into(),
display_name: Some("Coding Agent".into()),
description: None,
system_prompt: "Use tools when needed.".into(),
default_model_id: None,
default_version_id: None,
forked_from_agent_id: None,
forked_from_version_id: None,
root_agent_id: None,
tags: vec![],
capabilities: vec![],
initial_files: vec![],
network_access: None,
max_iterations: Some(8),
tools: vec![],
mcp_servers: Default::default(),
status: AgentStatus::Active,
created_at: Utc::now(),
updated_at: Utc::now(),
archived_at: None,
deleted_at: None,
usage: None,
})
.session(Session {
id: session_id,
organization_id: everruns_core::DEFAULT_ORG_PUBLIC_ID.to_string(),
harness_id,
agent_id: Some(agent_id),
agent_version_id: None,
agent_identity_id: None,
owner_principal_id: everruns_core::PrincipalId::from_seed(1),
resolved_owner_user_id: None,
owner: None,
effective_owner: None,
title: Some("Coding Session".into()),
locale: None,
preview: None,
output_preview: None,
tags: vec![],
model_id: None,
capabilities: vec![],
tools: vec![],
mcp_servers: Default::default(),
system_prompt: None,
initial_files: vec![],
hints: None,
network_access: None,
max_iterations: None,
status: SessionStatus::Started,
created_at: Utc::now(),
updated_at: Utc::now(),
started_at: None,
finished_at: None,
usage: None,
is_pinned: None,
active_schedule_count: None,
features: vec![],
parent_session_id: None,
subagent_name: None,
subagent_task: None,
subagent_status: None,
blueprint_id: None,
blueprint_config: None,
})
.build()
.await?;
let ctx = runtime.load_context(session_id).await?;
println!("\n--- system prompt (initial) ---");
println!("{}", ctx.runtime_agent.system_prompt);
assert!(
ctx.runtime_agent.system_prompt.contains("snake_case"),
"AGENTS.md content should be in the system prompt"
);
std::fs::write(
workspace.path().join("AGENTS.md"),
"## Project rules\nPrefer camelCase identifiers.",
)?;
let ctx = runtime.load_context(session_id).await?;
println!("\n--- system prompt (after editing AGENTS.md on disk) ---");
println!("{}", ctx.runtime_agent.system_prompt);
assert!(
ctx.runtime_agent.system_prompt.contains("camelCase"),
"edited AGENTS.md should appear on the next turn"
);
println!("\nok: AGENTS.md flows from real disk through AgentInstructionsCapability");
Ok(())
}