Final close session 5 — bao gồm: ==== Tests Phase 3 mini (NEW) ==== tests/SolutionErp.Infrastructure.Tests/Application/PeWorkflowAdminTests.cs - 6 test CreatePeWorkflowDefinitionCommandHandler: - First version → IsActive=true, Version=1, ActivatedAt set - Second version same Code → auto-increment v2 + deactivate v1 (atomic) - Different EvaluationType (A vs B) → independent active state - Persists steps ordered by Order field - Persists approvers per step - Third version → v1 + v2 deactivate, v3 active Total tests: 71 → 77 pass / ~2s (54 Domain + 23 Infra). Skip Phase 3 full (UpsertOpinion + Budget link validation) — cần Identity UserManager DI helper, defer session sau. ==== 3 gotcha CI mới (#39 #40 #41) ==== - #39 act_runner github.com TCP timeout 21s → manual checkout fix (run #108/#109 fail, #110 pass) - #40 npm junction cache `tsc not found` after Move-Item — rolled back, hypothesis nested junctions trong node_modules disrupt .bin/ paths. TODO debug session sau với robocopy hoặc act_runner cache.host - #41 Gitea Actions paths-ignore behavior — workflow file change vẫn trigger (correct), commit MD-only skip 100% (verify512880c→ no run #113) + Checklist debug bug mới items 18-20 referencing 3 gotcha trên. ==== Doc updates (8 file) ==== - STATUS.md: header Phase 8 update + 3 row Recently Done CI fixes + cumulative test 71→77 - HANDOFF.md: TL;DR + CI optimize section + Phase status + gotcha count 38→41 - migration-todos.md: Phase 8 §E updated với Phase 3 mini done + CI fixes - rules.md §7 Testing: rewrite full — stack + test pyramid + quy tắc bổ sung mỗi feature + workflow user end-of-task (`dotnet test` local trước push) + CI gate behavior - architecture.md §11: update test pyramid + phased priority + CI optimization sub-section (3 fix manual checkout / path filter / npm cache rollback) + tốc độ deploy table - gotchas.md: + #39 #40 #41 đầy đủ (triệu chứng + nguyên nhân + fix + reference) - ef-core-migration SKILL: Phase 8 update note thêm CI fixes + 77 test - CLAUDE.md root: test count 71→77 + folder structure + CI/CD pipeline 3 fix section - memory project_solution_erp.md: session 5 summary + workflow user mới - session log 2026-04-29-2300-chot-final-ci-tests-gotchas.md (NEW — 9 section detail) ==== Skill audit cron ==== `solution-erp-skill-audit-monthly` next fire 2026-05-01 (2 ngày sau). Cron survives across sessions (setup commitb904a25). Khi fire sẽ: - Cross-check 6 skill với STATUS/gotchas/migration-todos - Auto-refresh stale + đề xuất add/archive cho human approve - Log vào docs/changelog/skill-audit-2026-05.md - ABORT nếu repo dirty ==== Verify ==== - dotnet test SolutionErp.slnx → 77 pass / ~2s (54 Domain + 23 Infra) - git status clean sau commit này - CI: commit này chứa code (test + workflow) → trigger CI test gate Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
13 KiB
Migration To-dos — Atomic Roadmap
Tick
[x]khi xong. Phase 0-8 đã DONE — collapsed. Detail xem session logs trongdocs/changelog/sessions/. Active work: Phase 9 (UAT + Ops + carry over PE PDF export + Tests Phase 3-5).
✅ Phase 0-5 + Tier 3 — Done (2026-04-21..22)
| Phase | Focus | Trạng thái |
|---|---|---|
| 0 Draft | Scaffold .NET 10 + 2 Vite + parse FORM/QT + docs | ✅ |
| 1 Alpha Core | Auth + 12 role + Permission Matrix + 3 master CRUD + Contract draft | ✅ |
| 2 Form Engine | OpenXml + ClosedXML render + LibreOffice PDF + DynamicForm | ✅ |
| 3 Workflow | State machine 9 phase + RG-001 code gen + SLA job + attachments + SignalR realtime | ✅ |
| 4 Reporting | Dashboard KPI + Excel export + MyDashboard role-aware + brand identity #1F7DC1 | ✅ |
| 5 Production | CI/CD Gitea Actions + 3 IIS site + Let's Encrypt + Security headers + Users CRUD | ✅ |
| Tier 3 | Versioned workflow + 3-panel layout + 4-bảng overhaul + 4 master catalogs + 16 demo users + RolesPage CRUD + 7 demo HĐ varied | ✅ |
Detail chi tiết: docs/changelog/sessions/2026-04-21-*.md + 2026-04-22-0300-tier3-feature-complete.md + 2026-04-23-*.md.
✅ Phase 6 — Module Duyệt NCC (tiền-HĐ) — Done
Iter 1 (2026-04-23)
- Migration 12
AddPurchaseEvaluations— 10 bảng (Header/Suppliers/Details/Quotes/Approvals/Changelogs/Attachments/WorkflowDefinitions/Steps/StepApprovers) - Domain — 2 enum (Type A/B, Phase 7-state) + Policy record + Registry + FromDefinition builder
- Seed — 13 menu Pe_/PeWf_ + 2 WorkflowDefinition v01 (QT-DN-A 3-step, QT-DN-B 5-step)
- Application CQRS ~900 LOC — Create/Update/Transition/List/Inbox/Get/Delete + Supplier CRUD + Detail CRUD + Quote Upsert + SelectWinner + Changelog
- PurchaseEvaluationWorkflowService — policy guard + approval + notification + changelog
- PurchaseEvaluationsController — 17 endpoint REST
- FE 2 app — Types + PurchaseEvaluationsListPage 3-panel + Create page + PeDetailTabs + PeWorkflowPanel + Menu resolver Pe_*
- Kế thừa HĐ —
CreateContractFromEvaluationCommand(guard DaDuyet + SelectedSupplier + !ContractId) → Contract draft. FE CreateContractDialog pick ContractType. - Migration 13
AddPurchaseEvaluationCodeSequences— atomic MaPhieu sequencePE/{YYYY}/{A|B}/{Seq:D3} - Demo PE seed — 4 phiếu varied phase (A-001/A-002/A-003/B-001) + Pe_* permission defaults 7 role × 9 menu key
Session log: 2026-04-23-2300-purchase-evaluations.md + 2026-04-24-1030-pe-polish-demo-maphieu-perms.md.
Iter 2 — UX polish (2026-04-24)
- Rename menu "Phương Án" → "Giải pháp" + backfill DB (zero breaking change)
- Menu tree inheritance extend Pe_/PeWf_ (
GetMyMenuTreeQuery+ 4 root) - Accordion mutex Pe_* groups + sidebar w-72 + label nowrap
- NavLink active check query string (queryMatches helper) — fix 2 leaf cùng highlight
- PE detail flat layout: Panel 2 = 4 section (Thông tin/NCC/Hạng mục/Bảng so sánh), Panel 3 += Approvals + Changelog
- Upload file đính kèm per-NCC (SupplierAttachmentsCell) + Bảng so sánh tổng (GeneralAttachmentsSection, supplierRowId=null) + enum
ComparisonTable=4 - readOnly mode menu "Duyệt" (pendingMe=1) — hide Sửa/Xóa/Thêm/Edit/Upload/Delete, giữ download + transition + comment
- Contract: move Lịch sử điều chỉnh Panel 2 → Panel 3 (Chi tiết HĐ full-width)
- Demo email rebrand
@solutionerp.local→@solutions.com.vn+BackfillUserEmailDomainAsync(idempotent rename 4 field Email/NormalizedEmail/UserName/NormalizedUserName)
Session log: 2026-04-24-chot-session-3-pe-polish.md.
✅ Domain rebrand .huypham.vn → .solutions.com.vn (2026-04-24)
- 18 file repo (FE env + scripts + CI/CD + docs + skill + code comments)
scripts/migrate-domains.ps1(ASCII-only #30) — 3 IIS binding + 3 cert Let's Encrypt + auto HTTPS + redirect- CI/CD auto rebuild BE CORS + FE bundle VITE_API_BASE_URL
- E2E verified 3 domain live + preflight OK
Sub: api.solutions.com.vn · admin.solutions.com.vn · eoffice.solutions.com.vn. Old .huypham.vn vẫn fallback (chưa remove).
📝 Phase 7 — PE feature gap + Budget BE (Session 4 partial done)
A. PE feature gap (3 task MISSING — carry over session 5)
- PE Workflow admin designer UI
/system/pe-workflows/:typeCode- BE
Application/PurchaseEvaluations/PeWorkflowAdminFeatures.cs(mirrorWorkflowAdminFeatures.cs) Api/Controllers/PeWorkflowsController.cs- FE
fe-admin/src/pages/system/PeWorkflowsPage.tsx+PeWorkflowDesigner.tsx - Route
/system/pe-workflows/:typeCode(menu PeWf_* + resolver đã sẵn)
- BE
- Ý kiến 4 phòng ban (Phê duyệt / P.CCM / P.MuaHàng / SM-PM) ở tab Thông tin
- Option A: 4 text field + signoff date + UserId vào header
- Option B: dùng
PurchaseEvaluationApprovalsvới roleKind extra field - UX: 4 box sign-off như Excel mẫu
- Export phiếu PDF/Excel — tái dùng
IDocumentConverter+ templatePE-TrinhDuyet.docx
B. Optional polish
- Auto-map PE Details → Contract per-type Details khi gen HĐ (phức tạp vì 7 schema khác nhau)
- Payment terms tách field từ JSON → 6 column (Tạm ứng/TT tạm/Quyết toán/Bảo hành/Hạn mức/Đánh giá)
- Matrix Quotes bulk paste từ Excel
- fe-user Inbox thêm section "Phiếu Duyệt NCC chờ tôi"
C. Ops
- Remove binding cũ
.huypham.vnsau verify stable:ssh vietreport-vps ; cd C:\solution-erp\scripts ; .\migrate-domains.ps1 -RemoveOld -SkipCert - win-acme scheduled task fix unhealthy (cert expire 2026-06-18)
- UAT thật 1 tuần với 2-3 user (30 demo user — 16 sample + 14 Solutions thật)
- SMTP config → Email outbox
- Rotate credentials (admin + 30 demo + SA + vrapp + JWT)
- Schedule SQL backup Task Scheduler
D. Module Ngân sách (Budget) — Session 4 ✅ partial done
- Migration 14
AddBudgets— 4 bảng (Budgets/BudgetDetails/BudgetApprovals/BudgetChangelogs) + index BudgetId nullable trên Contract & PurchaseEvaluation - Domain —
Budget(Header) +BudgetDetail(flat row) +BudgetApproval+BudgetChangelog+ enumBudgetPhase5-state +BudgetEntityTypeHeader/Detail/Workflow BudgetPolicy.Defaulthardcoded simple 3-step (Drafter→CCM→CEO + Reject từ ChoCCM/ChoCEO về DangSoanThao)- Application CQRS ~340 LOC — Create + UpdateDraft + Transition + List + GetDetail + Delete (only DangSoanThao/TuChoi) + Detail CRUD (auto-recompute TongNganSach) + ListChangelogs
BudgetsController11 endpoint REST- Menu seed
Budgetsroot + 3 leaf (Bg_List/Bg_Create/Bg_Pending) order=27 icon Wallet - 14 demo user Solutions thật — PRO 5 + CCM 7 + ISO 1 + CEO 1 (pwd
User@123456)
Session log: 2026-04-28-chot-session-4-budget.md.
E. Pending migrations
AddPePaymentTermFields(nếu chốt UX tách field — JSON blob → 6 column)AddPurchaseEvaluationDepartmentOpinions✅ migration 15 (S5)AddBudgetCodeSequences(nếu chốt format MaNganSach atomic — hiện Random.Shared)AddBudgetVersionedWorkflow(nếu user cần admin config UI thay vì hardcodedBudgetPolicy.Default)
✅ Phase 8 — Budget FE + PE/HD integration (Session 5 done)
A. FE Budget pages — done ✅
fe-admin/src/types/budget.ts(BudgetPhase 5-state enum + DTO types)fe-admin/src/pages/budgets/BudgetsListPage.tsx(3-panel[340px_1fr_360px]+ filter Phase/Năm + ?phase=Pending alias + readOnly mode + BudgetDetailPage fullpage mobile)fe-admin/src/pages/budgets/BudgetCreatePage.tsx(form Header — Tên/Năm/Dự án/Phòng ban/Mô tả)fe-admin/src/components/budgets/BudgetDetailTabs.tsx(Section Thông tin Header + Section Hạng mục table CRUD inline auto-compute ThanhTien=KL×ĐG)fe-admin/src/components/budgets/BudgetWorkflowPanel.tsx(Panel 3 timeline activePhases + nextPhases buttons + Dialog comment + Approvals/Changelog)- Mirror tất cả sang
fe-user/ - App.tsx routes
/budgets,/budgets/new,/budgets/:idcả 2 app - Menu resolver
Bg_*(Bg_List →/budgets, Bg_Pending →/budgets?phase=Pending, Bg_Create →/budgets/new)
B. PE/Contract → Budget integration — done ✅
- PE form + Select "Ngân sách" filter Phase=DaDuyet, ProjectId match, BE validate
- Contract form (Header + Edit) tương tự, EditForm read-only link card khi !isDraft
- PE Detail Hạng mục thêm cột "NS link · Δ" — match per-row qua
groupCode|itemCode+ footer aggregate (xanh dưới / đỏ vượt / xám khớp) - PE Detail UI restructure 4 section đánh số match form spec PHIẾU TRÌNH KÝ
- BE: BudgetSummaryDto shared + Create/Update PE+Contract commands + BudgetId? + GetQueries load Budget
- CreateContractFromEvaluation carry forward pe.BudgetId → contract.BudgetId
C. PE Workflow Designer admin UI — done ✅
- BE
PeWorkflowAdminFeatures.cs~250 LOC mirror Contract pattern - BE
PeWorkflowsController2 endpoint reuse policyWorkflows.* - FE
PeWorkflowsPage.tsx~500 LOC + designer dialog (clone/edit/+Role/+User) - App.tsx route
/system/pe-workflows/:typeCode
D. Ý kiến 4 phòng ban — done ✅
- Migration 15
AddPurchaseEvaluationDepartmentOpinions(UNIQUE PEId+Kind) - Domain entity + enum
PeDepartmentKind(PheDuyet/Ccm/MuaHang/SmPm) - BE Upsert (sign=true → set SignedAt+UserId, sign=false giữ chữ ký cũ) + Delete + 2 endpoint
- FE Section "5. Ý kiến 4 phòng ban (sign-off)" 2x2 grid OpinionBox
E. Tests Phase 1-2-3mini + CI optimize — done ✅
- Phase 1 —
tests/SolutionErp.Domain.Tests/(xUnit + FluentAssertions 7.2): 54 test policy state machine (Contract WF + PE WF + Budget) + Registry + FromDefinition versioned + UserKindApprover - Phase 2 —
tests/SolutionErp.Infrastructure.Tests/(EF SQLite + TestApplicationDbContext overridenvarchar(max) → TEXT): 17 test code generator format + sequence + year boundary + persistence verify - Phase 3 mini —
tests/.../Application/PeWorkflowAdminTests.cs: 6 test CreatePeWorkflowDefinitionCommand versioning (auto-increment + deactivate cũ + EvaluationType independence + steps/approvers persistence) - CI gate
.gitea/workflows/deploy.yml— 2 stepdotnet testtrước build, fail → no deploy - Total 77 test pass / ~3s
- CI manual checkout bypass github.com — fix gotcha #39 (act_runner TCP timeout 21s)
- CI path filter docs-only skip — gotcha #41 (paths-ignore behavior)
- Tests Phase 3 full — Opinion Upsert + Budget link validation (cần Identity UserManager setup helper)
- npm junction cache CI optimize (rollback ở
a21790d— gotcha #40 chưa debug)
📝 Phase 9 — UAT + Ops + carry over (Session 6+ active)
A. Hard blockers (chờ user / ops)
- UAT thật 1 tuần với 2-3 user (30 demo: 16 sample + 14 Solutions thật)
- SMTP config → Email outbox (BLOCKED chờ user cấp host/user/pass)
- Rotate credentials (admin + 30 demo + SA + vrapp + JWT secret + Gitea runner token)
- Schedule SQL backup daily Task Scheduler
B. PE feature gap còn lại
- Export phiếu PDF/Excel —
IDocumentConverter+ templatePE-TrinhDuyet.docx(user pending — không quan trọng lắm)
C. Optional polish (làm khi UAT phát sinh)
- Budget MaNganSach atomic sequence + migration
AddBudgetCodeSequences - Budget versioned workflow + migration
AddBudgetVersionedWorkflow - Payment terms PE tách field (JSON → 6 column)
- Auto-map PE Details → Contract Details khi gen HĐ
- Matrix Quotes bulk paste từ Excel
- fe-user Inbox thêm section "Phiếu Duyệt NCC chờ tôi"
D. Tests Phase 3-5 (làm khi gặp bug recurring để justify ROI)
- Phase 3 — Application handler tests (CQRS + EF InMemory) ~15 test
- Phase 4 — API smoke tests (WebApplicationFactory) ~7 test
- Phase 5 — FE Vitest cho lib utility (queryMatches, fmtMoney) ~10 test
E. Ops chưa xong
- Remove binding cũ
.huypham.vnsau verify stable - win-acme scheduled task fix unhealthy (cert expire 2026-06-18)
🔁 Skill governance (recurring)
Quy tắc: docs/rules.md §9. Audit định kỳ mỗi đầu tháng — workflow §9.4.
- Setup ban đầu — 6 skill (3 domain + 3 ops), rules §9 ←
661f859 - Audit 2026-05-01 — log
docs/changelog/skill-audit-2026-05.md - Audit 2026-06-01
- Audit 2026-07-01
Cron task solution-erp-skill-audit-monthly fire 9:00 AM ngày 1 mỗi tháng.
📦 Post-launch (Phase 10+ — future)
- Email outbox (MailKit + SMTP) — blocked chờ SMTP config
- E-signature integration (VNPT CA hoặc FPT CA)
- Tích hợp Bravo / SAP ERP import NCC
- Mobile app (React Native?) cho BOD duyệt ngoài giờ
- AI: gợi ý điền form dựa HĐ cũ, OCR scan HĐ đối tác
- Multi-tenant nếu có công ty thứ 2