multi-round chat
This commit is contained in:
parent
331e2e434d
commit
c20be407d5
@ -10,59 +10,62 @@ if __name__ == "__main__":
|
|||||||
# Create the supervisor
|
# Create the supervisor
|
||||||
supervisor = create_sysadmin_supervisor()
|
supervisor = create_sysadmin_supervisor()
|
||||||
|
|
||||||
# Example run - demonstrating both invoke and streaming with debug output
|
# Interactive conversation loop
|
||||||
query = {
|
messages = []
|
||||||
"messages": [
|
print("Welcome to the multi-agent sysadmin assistant!")
|
||||||
{
|
print("Type your sysadmin question below. Type 'exit' to quit.")
|
||||||
"role": "user",
|
while True:
|
||||||
"content": "Nginx returns 502 Bad Gateway on my server. What can I do?",
|
user_input = input("\n📝 User: ")
|
||||||
}
|
if user_input.strip().lower() == 'exit':
|
||||||
]
|
print("Goodbye!")
|
||||||
}
|
break
|
||||||
|
messages.append({"role": "user", "content": user_input})
|
||||||
|
query = {"messages": messages}
|
||||||
|
|
||||||
print("🚀 Starting multi-agent sysadmin analysis...")
|
print("\n=== Using invoke() method ===")
|
||||||
print(f"📝 User Query: {query['messages'][0]['content']}")
|
result = supervisor.invoke(query)
|
||||||
print("=" * 80)
|
|
||||||
|
|
||||||
# Show explanation of the supervisor pattern
|
print("\n📊 FINAL RESULT:")
|
||||||
explain_supervisor_pattern()
|
print("-" * 40)
|
||||||
|
print(result["messages"][-1].content)
|
||||||
|
print("-" * 40)
|
||||||
|
print(f"\n📈 Total messages exchanged: {len(result['messages'])}")
|
||||||
|
|
||||||
print("\n=== Using invoke() method ===")
|
# Add the assistant's reply to the conversation history
|
||||||
result = supervisor.invoke(query)
|
messages.append({"role": "assistant", "content": result["messages"][-1].content})
|
||||||
|
|
||||||
print("\n📊 FINAL RESULT:")
|
# Ask if the user wants to continue
|
||||||
print("-" * 40)
|
cont = input("\nWould you like to continue the conversation? (y/n): ")
|
||||||
print(result["messages"][-1].content)
|
if cont.strip().lower() not in ('y', 'yes'):
|
||||||
print("-" * 40)
|
print("Session ended.")
|
||||||
|
break
|
||||||
|
|
||||||
print(f"\n📈 Total messages exchanged: {len(result['messages'])}")
|
print("\n=== Using stream() method for detailed step-by-step analysis ===")
|
||||||
|
step_count = 0
|
||||||
|
max_steps = 20 # Prevent infinite loops
|
||||||
|
|
||||||
print("\n=== Using stream() method for detailed step-by-step analysis ===")
|
try:
|
||||||
step_count = 0
|
chunks_processed = []
|
||||||
max_steps = 20 # Prevent infinite loops
|
for chunk in supervisor.stream(query):
|
||||||
|
step_count += 1
|
||||||
|
chunks_processed.append(chunk)
|
||||||
|
print_step_info(step_count, chunk)
|
||||||
|
|
||||||
try:
|
# Safety check to prevent infinite loops
|
||||||
chunks_processed = []
|
if step_count >= max_steps:
|
||||||
for chunk in supervisor.stream(query):
|
print(f"\n⚠️ Reached maximum steps ({max_steps}), stopping stream...")
|
||||||
step_count += 1
|
break
|
||||||
chunks_processed.append(chunk)
|
|
||||||
print_step_info(step_count, chunk)
|
|
||||||
|
|
||||||
# Safety check to prevent infinite loops
|
print(f"\n✅ Streaming completed successfully with {step_count} steps")
|
||||||
if step_count >= max_steps:
|
print(f"📊 Total chunks processed: {len(chunks_processed)}")
|
||||||
print(f"\n⚠️ Reached maximum steps ({max_steps}), stopping stream...")
|
|
||||||
break
|
|
||||||
|
|
||||||
print(f"\n✅ Streaming completed successfully with {step_count} steps")
|
# Check if the last chunk contains a complete final response
|
||||||
print(f"📊 Total chunks processed: {len(chunks_processed)}")
|
if chunks_processed:
|
||||||
|
last_chunk = chunks_processed[-1]
|
||||||
|
print(f"🔍 Last chunk keys: {list(last_chunk.keys()) if isinstance(last_chunk, dict) else type(last_chunk)}")
|
||||||
|
|
||||||
# Check if the last chunk contains a complete final response
|
except Exception as e:
|
||||||
if chunks_processed:
|
print(f"\n❌ Streaming error after {step_count} steps: {e}")
|
||||||
last_chunk = chunks_processed[-1]
|
print("💡 The invoke() method worked fine, so the supervisor itself is functional.")
|
||||||
print(f"🔍 Last chunk keys: {list(last_chunk.keys()) if isinstance(last_chunk, dict) else type(last_chunk)}")
|
import traceback
|
||||||
|
traceback.print_exc()
|
||||||
except Exception as e:
|
|
||||||
print(f"\n❌ Streaming error after {step_count} steps: {e}")
|
|
||||||
print("💡 The invoke() method worked fine, so the supervisor itself is functional.")
|
|
||||||
import traceback
|
|
||||||
traceback.print_exc()
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user