Files
vibn-frontend/test-handoff-persistence.sh

57 lines
3.1 KiB
Bash
Executable File

#!/bin/bash
# Test Collector Handoff Persistence
# Sends messages and checks if handoff data is being persisted
GREEN='\033[0;32m'
BLUE='\033[0;34m'
YELLOW='\033[1;33m'
RED='\033[0;31m'
NC='\033[0m'
PROJECT_ID="lyOZxelSkjAB6XisIzup"
BASE_URL="http://localhost:3000"
TOKEN="Bearer eyJhbGciOiJSUzI1NiIsImtpZCI6IjM4MDI5MzRmZTBlZWM0NmE1ZWQwMDA2ZDE0YTFiYWIwMWUzNDUwODMiLCJ0eXAiOiJKV1QifQ.eyJuYW1lIjoiTWFyayBIZW5kZXJzb24iLCJwaWN0dXJlIjoiaHR0cHM6Ly9hdmF0YXJzLmdpdGh1YnVzZXJjb250ZW50LmNvbS91LzUzOTU0MjEzP3Y9NCIsImlzcyI6Imh0dHBzOi8vc2VjdXJldG9rZW4uZ29vZ2xlLmNvbS9nZW4tbGFuZy1jbGllbnQtMDk4MDA3OTQxMCIsImF1ZCI6Imdlbi1sYW5nLWNsaWVudC0wOTgwMDc5NDEwIiwiYXV0aF90aW1lIjoxNzYzMzI1MDEyLCJ1c2VyX2lkIjoiMmhDdmdXQzJaV2RJMGVlTm5SQVM3SWVKcmg1MiIsInN1YiI6IjJoQ3ZnV0MyWldkSTBlZU5uUkFTN0llSnJoNTIiLCJpYXQiOjE3NjM0MjI1NDUsImV4cCI6MTc2MzQyNjE0NSwiZW1haWwiOiJtYXJrQGdldGFjcXVpcmVkLmNvbSIsImVtYWlsX3ZlcmlmaWVkIjpmYWxzZSwiZmlyZWJhc2UiOnsiaWRlbnRpdGllcyI6eyJnaXRodWIuY29tIjpbIjUzOTU0MjEzIl0sImVtYWlsIjpbIm1hcmtAZ2V0YWNxdWlyZWQuY29tIl19LCJzaWduX2luX3Byb3ZpZGVyIjoiZ2l0aHViLmNvbSJ9fQ.TpMOORDnPUKkbLlg-KtYBmbarEjAijJ3W4vN8tWT6OslOfwaeDJAtPXIahyQk38UvKY4ZGognQG6t-laSATB8yIC8IdkYbD699axfPSGQqC8Lbux1P6YrFKOPLGDD2XemBtJ-Gb5Ql-nK_DbXKAmygLxIwz019XpLJEucGkBPAN_Rj2xC7125DVexkDSIb6ZnbLiDgCpR_IkImyQb08tqlOoBiHVUa-4VGDhraoBPACJfQXwPToJ1W3nhBiVtMvSq7s_Ekd8Otn8AB_1teu5lxC-rhLdgJuNrmlxO-H6xIMBFZ72bwq7wrvdWd_EijqFQCU99oEhphTNoISoJ3wK-g"
echo -e "${BLUE}========================================${NC}"
echo -e "${BLUE} Testing Handoff Persistence${NC}"
echo -e "${BLUE}========================================${NC}\n"
# Send a message and capture full response with verbose logging
echo -e "${YELLOW}[Test]${NC} Sending message to AI with verbose logging enabled...\n"
# Enable curl verbose output and check server response
curl -v -X POST "${BASE_URL}/api/ai/chat" \
-H "Authorization: ${TOKEN}" \
-H "Content-Type: application/json" \
-d '{"projectId": "'"${PROJECT_ID}"'", "message": "I have uploaded 1 document. I do not have GitHub or the extension yet."}' \
2>&1 | tee /tmp/curl-output.txt
echo -e "\n\n${BLUE}========================================${NC}"
echo -e "${BLUE}Analysis${NC}"
echo -e "${BLUE}========================================${NC}\n"
# Check if the response contains expected fields
if grep -q '"mode":"collector_mode"' /tmp/curl-output.txt; then
echo -e "${GREEN}✓ Mode is collector_mode${NC}"
else
echo -e "${RED}✗ Mode not detected${NC}"
fi
if grep -q '"projectPhase"' /tmp/curl-output.txt; then
echo -e "${GREEN}✓ Project phase returned${NC}"
else
echo -e "${RED}✗ Project phase not returned${NC}"
fi
# Look for any indication of handoff data in server logs
echo -e "\n${YELLOW}Note:${NC} The collectorHandoff data is persisted to Firestore,"
echo -e "but not returned in the API response. This is expected."
echo -e "\nTo verify persistence, check:"
echo -e " 1. Server console logs for '[AI Chat] Collector handoff persisted'"
echo -e " 2. Firebase Console: projects/${PROJECT_ID}/phaseData/phaseHandoffs/collector"
echo -e " 3. UI checklist: ${BASE_URL}/default/project/${PROJECT_ID}/v_ai_chat\n"
rm -f /tmp/curl-output.txt