# Member Center Test Site `src/MemberCenter.TestSite` 是手動 happy-path 測試用網站,用來先驗證外部網站整合會員中心的最小流程。 ## 啟動 ```bash dotnet run --project src/MemberCenter.TestSite ``` 預設 HTTP URL: ```text http://localhost:5243 ``` ## 必要設定 在 `src/MemberCenter.TestSite/appsettings.Development.json` 或環境變數設定: ```json { "MemberCenter": { "ApiBaseUrl": "http://localhost:7850", "WebLoginClientId": "", "ServiceClientId": "", "ServiceClientSecret": "" } } ``` `web_login` OAuth client: - `usage=web_login` - `client_type=public` - redirect URI: `http://localhost:5243/auth/callback` - scopes: `openid email profile profile:basic.read profile:basic.write profile:addresses.read profile:addresses.write profile:subscriptions.read profile:subscriptions.write` service OAuth client: - 建議使用 `tenant_api` 或 `platform_service` - `client_type=confidential` - scopes 至少包含 `profile:basic.read profile:addresses.read` 若 Member Center API 與 Web login 不同 origin,Member Center 需設定: ```text Auth__WebLoginUrl= Auth__AllowedLoginReturnUrlPrefixes= Auth__CookieDomain= ``` ## 第一批 Happy Path 測試站目前包含: 1. Redirect login 拿 token 2. API login 拿 token 3. `GET /user/profile` 4. `POST /user/profile` 5. `GET /user/addresses` 6. `POST /user/addresses` 7. `GET /user/subscriptions` 8. `POST /user/subscriptions/{id}/unsubscribe` 9. service token 呼叫 `GET /user/profile/by-email` 10. service token 呼叫 `GET /user/addresses/by-email` 測試站只做 happy path,不取代完整自動化測試。