3.1 KiB
3.1 KiB
Sofiia Console Redis Smoke
Мета: швидко перевірити distributed idempotency для sofiia-console з Redis, включно з replay між двома інстансами BFF.
1) Підняти Redis
docker compose -f docker-compose.redis-smoke.yml up -d
2) Запустити sofiia-console з env
cd services/sofiia-console
export SOFIIA_IDEMPOTENCY_BACKEND=redis
export SOFIIA_REDIS_URL=redis://127.0.0.1:6379/0
export SOFIIA_REDIS_PREFIX=sofiia:idem:
export SOFIIA_IDEMPOTENCY_TTL_S=900
export ENV=dev
python3 -m uvicorn app.main:app --host 0.0.0.0 --port 8002
3) Smoke curl: 1 send + replay
CHAT_ID=$(curl -s -X POST "http://127.0.0.1:8002/api/chats" \
-H "Content-Type: application/json" \
-d '{"agent_id":"sofiia","node_id":"NODA2","source":"web","external_chat_ref":"redis-smoke"}' | jq -r '.chat.chat_id')
curl -s -X POST "http://127.0.0.1:8002/api/chats/${CHAT_ID}/send" \
-H "Content-Type: application/json" \
-H "Idempotency-Key: redis-smoke-key-1" \
-d '{"text":"ping"}'
curl -s -X POST "http://127.0.0.1:8002/api/chats/${CHAT_ID}/send" \
-H "Content-Type: application/json" \
-H "Idempotency-Key: redis-smoke-key-1" \
-d '{"text":"ping"}'
Очікування: другий виклик повертає idempotency.replayed=true і той самий message.message_id.
Перевірка між двома інстансами BFF (A/B)
- Інстанс A:
cd services/sofiia-console
export SOFIIA_IDEMPOTENCY_BACKEND=redis
export SOFIIA_REDIS_URL=redis://127.0.0.1:6379/0
export SOFIIA_REDIS_PREFIX=sofiia:idem:
export SOFIIA_IDEMPOTENCY_TTL_S=900
export ENV=dev
python3 -m uvicorn app.main:app --host 0.0.0.0 --port 8002
- Інстанс B (в іншому терміналі, той самий env, інший порт):
cd services/sofiia-console
export SOFIIA_IDEMPOTENCY_BACKEND=redis
export SOFIIA_REDIS_URL=redis://127.0.0.1:6379/0
export SOFIIA_REDIS_PREFIX=sofiia:idem:
export SOFIIA_IDEMPOTENCY_TTL_S=900
export ENV=dev
python3 -m uvicorn app.main:app --host 0.0.0.0 --port 8003
- Записати перший send через A, повторити через B з тим самим
Idempotency-Key:
CHAT_ID=$(curl -s -X POST "http://127.0.0.1:8002/api/chats" \
-H "Content-Type: application/json" \
-d '{"agent_id":"sofiia","node_id":"NODA2","source":"web","external_chat_ref":"redis-smoke-ab"}' | jq -r '.chat.chat_id')
A=$(curl -s -X POST "http://127.0.0.1:8002/api/chats/${CHAT_ID}/send" \
-H "Content-Type: application/json" \
-H "Idempotency-Key: redis-shared-key-1" \
-d '{"text":"ping-from-a"}')
B=$(curl -s -X POST "http://127.0.0.1:8003/api/chats/${CHAT_ID}/send" \
-H "Content-Type: application/json" \
-H "Idempotency-Key: redis-shared-key-1" \
-d '{"text":"ping-from-b"}')
echo "$A" | jq '{message_id: .message.message_id, replayed: .idempotency.replayed, node_id}'
echo "$B" | jq '{message_id: .message.message_id, replayed: .idempotency.replayed, node_id}'
Очікування:
A.idempotency.replayed == falseB.idempotency.replayed == trueA.message.message_id == B.message.message_id