本番確認手順の標準化:curlヘルスチェックスクリプト追加
MCP キャッシュ問題の対処として、偽装不可能なcurl確認を標準化。 - scripts/check_prod.sh: JWT認証を含む9項目のヘルスチェック - CLAUDE.md: 「本番確認手順」セクション追加(curl優先、Playwright補助) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
91
scripts/check_prod.sh
Normal file
91
scripts/check_prod.sh
Normal file
@@ -0,0 +1,91 @@
|
||||
#!/usr/bin/env bash
|
||||
# 本番環境ヘルスチェック
|
||||
# 使い方: bash scripts/check_prod.sh [username] [password]
|
||||
# 例: bash scripts/check_prod.sh claude keina1234
|
||||
|
||||
BASE="https://main.keinafarm.net"
|
||||
USER="${1:-claude}"
|
||||
PASS="${2:-keina1234}"
|
||||
|
||||
OK=0
|
||||
NG=0
|
||||
|
||||
check() {
|
||||
local label="$1"
|
||||
local expected="$2"
|
||||
local actual="$3"
|
||||
if [ "$actual" = "$expected" ]; then
|
||||
echo " PASS $label (HTTP $actual)"
|
||||
OK=$((OK+1))
|
||||
else
|
||||
echo " FAIL $label (expected $expected, got $actual)"
|
||||
NG=$((NG+1))
|
||||
fi
|
||||
}
|
||||
|
||||
echo "=== 本番ヘルスチェック: $BASE ==="
|
||||
echo "--- $(date '+%Y-%m-%d %H:%M:%S') ---"
|
||||
echo ""
|
||||
|
||||
# 1. フロントエンド到達確認
|
||||
echo "[1] フロントエンド"
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 "$BASE/")
|
||||
check "トップページ" "200" "$STATUS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 "$BASE/login")
|
||||
check "ログインページ" "200" "$STATUS"
|
||||
|
||||
# 2. バックエンドAPI(認証不要)
|
||||
echo ""
|
||||
echo "[2] バックエンドAPI(認証なし)"
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 "$BASE/api/auth/jwt/create/")
|
||||
check "認証エンドポイント到達" "405" "$STATUS" # GETは405が正常
|
||||
|
||||
# 3. JWT取得
|
||||
echo ""
|
||||
echo "[3] JWT認証"
|
||||
TOKEN_RESP=$(curl -s --max-time 10 -X POST "$BASE/api/auth/jwt/create/" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d "{\"username\":\"$USER\",\"password\":\"$PASS\"}")
|
||||
ACCESS=$(echo "$TOKEN_RESP" | grep -o '"access":"[^"]*"' | cut -d'"' -f4)
|
||||
|
||||
if [ -n "$ACCESS" ]; then
|
||||
echo " PASS JWTトークン取得"
|
||||
OK=$((OK+1))
|
||||
else
|
||||
echo " FAIL JWTトークン取得失敗 (レスポンス: $TOKEN_RESP)"
|
||||
NG=$((NG+1))
|
||||
echo ""
|
||||
echo "=== 結果: PASS $OK / FAIL $NG (認証失敗のため以降の確認をスキップ) ==="
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 4. 認証が必要なAPI
|
||||
echo ""
|
||||
echo "[4] 認証済みAPI"
|
||||
AUTH="Authorization: Bearer $ACCESS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 -H "$AUTH" "$BASE/api/fields/")
|
||||
check "圃場一覧 API" "200" "$STATUS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 -H "$AUTH" "$BASE/api/plans/crops/")
|
||||
check "品種一覧 API" "200" "$STATUS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 -H "$AUTH" "$BASE/api/fertilizer/fertilizers/")
|
||||
check "肥料マスタ API" "200" "$STATUS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 -H "$AUTH" "$BASE/api/fertilizer/plans/?year=2026")
|
||||
check "施肥計画一覧 API" "200" "$STATUS"
|
||||
|
||||
STATUS=$(curl -s -o /dev/null -w "%{http_code}" --max-time 10 -H "$AUTH" "$BASE/api/weather/summary/?year=2025")
|
||||
check "気象データサマリー API" "200" "$STATUS"
|
||||
|
||||
# 5. 結果サマリー
|
||||
echo ""
|
||||
TOTAL=$((OK+NG))
|
||||
if [ $NG -eq 0 ]; then
|
||||
echo "=== 結果: 全 $TOTAL 項目 PASS ==="
|
||||
else
|
||||
echo "=== 結果: PASS $OK / FAIL $NG (合計 $TOTAL) ==="
|
||||
exit 1
|
||||
fi
|
||||
Reference in New Issue
Block a user