在前后端开发联调前 的提交20260223

This commit is contained in:
Neo
2026-02-23 23:02:20 +08:00
parent 254ccb1e77
commit fafc95e64c
1142 changed files with 10366960 additions and 36957 deletions

View File

@@ -0,0 +1,132 @@
- [P20260220-075312] 2026-02-20 07:53:12 +0800
- summary: CONTEXT TRANSFER: We are continuing a conversation that had gotten too long. Here is a summary: --- ## TASK 1: Run All T…
- prompt:
```text
CONTEXT TRANSFER: We are continuing a conversation that had gotten too long. Here is a summary:
---
## TASK 1: Run All Tasks for dataflow-field-completion spec
**STATUS**: done
**USER QUERIES**: Previous conversation context
**DETAILS**: All 13 tasks completed in prior sessions including field audit, mapping fixes, A/B/C class tables, DWS inventory summary, backend ETL execution API, frontend TaskManager, timer/checker modules, property tests, end-to-end integration, and browser-based front-end/back-end integration test.
**FILEPATHS**: `.kiro/specs/dataflow-field-completion/tasks.md`
---
## TASK 2: First Browser Integration Test (dry-run, ods_dwd)
**STATUS**: done
**DETAILS**: Successfully completed browser-based integration test using Playwright with dry-run + local JSON + ods_dwd flow. Result: status=success, duration=22.5s, exit_code=0.
**FILEPATHS**:
- `export/ETL-Connectors/feiqiu/REPORTS/etl_timing_20260220_073610.md`
- `export/ETL-Connectors/feiqiu/REPORTS/consistency_report_20260220_073610.md`
---
## TASK 3: Full Production Integration Test (api_full, verify_only, custom window)
**STATUS**: in-progress
**USER QUERIES**: "任务2web-admin 前后端联调:全部门店, api_full, 仅校验修复 且 校验前从 API 获取, 自定义范围 2025-11-01 到 2026-02-20, 窗口切分 10天, force-full, 全选常用"
**DETAILS**:
- Successfully configured and submitted the task via Playwright browser automation:
- Flow: `api_full` ✓
- Processing mode: `verify_only` ✓
- `fetch_before_verify`: enabled ✓
- Custom window: 2025-11-01 ~ 2026-02-20 ✓
- Window split: 10 days ✓
- `force-full`: enabled ✓
- "全选常用" clicked: 40/43 tasks selected ✓
- Clicked "直接执行" → task started at 2026/2/20 07:48:39
- CLI command confirmed: `python -m cli.main --flow api_full --processing-mode verify_only --tasks ODS_ASSISTANT_ACCOUNT,...,DWD_LOAD_FROM_ODS --fetch-before-verify --window-start 2025-11-01 --window-end 2026-02-20 --window-split day --window-split-days 10 --force-full --store-id 2790685415443269`
- Task is running in background (not quick-exit, good sign)
- **BUG FOUND AND FIXED**: `ODS_ASSISTANT_LEDGER` failed with `psycopg2.ProgrammingError: can't adapt type 'dict'`
- Root cause: `_mark_missing_as_deleted` in `ods_tasks.py` only wrapped `payload` column with `Json()` adapter, but table `assistant_service_records` has another JSONB column `siteprofile` whose dict values weren't wrapped
- **Fix applied**: Modified `_mark_missing_as_deleted` to detect ALL JSONB columns via `cols_info` (which contains `udt_name`), and wrap any dict/list values with `Json()` adapter for all JSONB columns, not just `payload`
- The fix is in `apps/etl/connectors/feiqiu/tasks/ods/ods_tasks.py` around line 654
- This fix will take effect on the NEXT run (current run is still executing with old code since it's a subprocess)
- Other tasks observed running successfully: `ODS_ASSISTANT_ACCOUNT` (828 fetched/updated), `ODS_ASSISTANT_ABOLISH` (78 fetched/inserted), `ODS_SETTLEMENT_RECORDS` (in progress with 12 window segments)
- The execution modal was open showing real-time WebSocket logs, then closed
- Task was still `running` status when last checked after ~90 seconds
**NEXT STEPS**:
1. Wait for the current execution to complete (it's a long-running task with 22 ODS tasks × 12 windows + DWD + DWS + INDEX layers)
2. Check execution history for final status/duration/exit_code
3. The current run will have `ODS_ASSISTANT_LEDGER` as failed (old code) — this is expected
4. Review execution logs for any other errors
5. Check generated reports: `etl_timing_*.md` and `consistency_report_*.md` in `export/ETL-Connectors/feiqiu/REPORTS/`
6. Analyze timing report for slow steps
7. Analyze consistency report for field type mismatches (number vs string)
8. Consider re-running just `ODS_ASSISTANT_LEDGER` to verify the fix works
9. If more field type issues found in consistency report, fix them
**FILEPATHS**:
- `apps/etl/connectors/feiqiu/tasks/ods/ods_tasks.py` (MODIFIED - JSONB column fix)
- `apps/admin-web/src/pages/TaskConfig.tsx`
- `apps/admin-web/src/pages/TaskManager.tsx`
- `apps/admin-web/src/components/TaskSelector.tsx`
- `apps/admin-web/src/types/index.ts`
- `apps/backend/app/services/cli_builder.py`
- `apps/backend/app/schemas/tasks.py`
- `apps/backend/app/services/task_executor.py`
- `apps/backend/app/routers/execution.py`
- `apps/etl/connectors/feiqiu/orchestration/flow_runner.py`
- `apps/etl/connectors/feiqiu/quality/consistency_checker.py`
- `apps/etl/connectors/feiqiu/utils/timer.py`
---
## KEY ARCHITECTURE (for new agent reference):
- Frontend: React + Vite + Ant Design at `apps/admin-web/` (localhost:5173)
- Backend: FastAPI at `apps/backend/` (localhost:8000)
- Vite proxy: `/api` → `http://localhost:8000`, `/ws` → `ws://localhost:8000`
- ETL subprocess launched by backend `task_executor.py`, logs streamed via WebSocket
- Auth: JWT tokens in localStorage (user already logged in as admin)
- Frontend dev server running as processId 6 (`pnpm dev` in `apps/admin-web`)
- Backend started by user manually (`uv run uvicorn app.main:app --reload` in `apps/backend`)
- ETL timer outputs to `ETL_REPORT_ROOT` env var
- Consistency checker outputs to `ETL_REPORT_ROOT` env var
## USER CORRECTIONS AND INSTRUCTIONS:
- All output text must be in simplified Chinese (language-zh.md steering)
- All file outputs must go through `export/` directory structure via `.env` environment variables (export-paths.md steering)
- Changes to high-risk paths require `/audit` trigger
- Python scripts preferred over PowerShell for complex operations
- "如果极短时间内退出,则一定有问题" — if ETL exits very quickly, something is wrong
- "之前的报告,很多是字段类型数字/字符不一样,需要你标准化字段类型" — previous consistency reports showed field type mismatches (number vs string), need to standardize field types
- Audit reminder is pending for: root-file, dir:admin-web, dir:backend, dir:db, db-schema-change (plus now dir:tasks due to ods_tasks.py fix)
- There are 6 pre-existing test failures unrelated to this spec
## Files to read
- `apps/etl/connectors/feiqiu/tasks/ods/ods_tasks.py` (the JSONB fix around line 654, method `_mark_missing_as_deleted`)
- `apps/etl/connectors/feiqiu/orchestration/flow_runner.py` (timer + checker integration)
- `apps/etl/connectors/feiqiu/quality/consistency_checker.py`
- `apps/etl/connectors/feiqiu/utils/timer.py`
- `apps/admin-web/src/pages/TaskManager.tsx` (HistoryTab for checking results)
- `apps/backend/app/services/task_executor.py` (how ETL subprocess is managed)
USER QUERIES(most recent first):
1. Output:
Command executed successfully with no output.
Exit Code: 0
2. Output:
Command executed successfully with no output.
Exit Code: 0
---
METADATA:
The previous conversation had 2 messages.
INSTRUCTIONS:
Continue working until the user query has been fully addressed. Do not ask for clarification - proceed with the work based on the context provided.
IMPORTANT: you need to read from the files to Read section
```