test: 同步报销审批流与预算分析测试
- 新增预算审批合并、风险标记去重与占位条目校验用例 - 补充预算分析对当前审核人与财务的可见性断言 - 调整单据删除权限测试以匹配 admin 限制
This commit is contained in:
@@ -48,6 +48,8 @@ function extractFunction(source, name) {
|
||||
|
||||
test('detail submit opens a confirmation dialog before calling submit API', () => {
|
||||
assert.match(detailViewTemplate, /<ConfirmDialog[\s\S]*:open="submitConfirmDialogOpen"[\s\S]*:confirm-text="submitConfirmText"[\s\S]*@close="closeSubmitConfirmDialog"[\s\S]*@confirm="confirmSubmitRequest"/)
|
||||
assert.match(detailViewTemplate, /:secondary-text="submitConfirmSecondaryText"/)
|
||||
assert.match(detailViewTemplate, /@secondary="confirmStandardAdjustment"/)
|
||||
assert.match(detailViewTemplate, /:open="submitConfirmDialogOpen"[\s\S]*size="review"/)
|
||||
assert.match(detailViewTemplate, /cancel-text="返回核对"/)
|
||||
assert.match(detailViewTemplate, /@click="handleSubmit"/)
|
||||
@@ -56,6 +58,7 @@ test('detail submit opens a confirmation dialog before calling submit API', () =
|
||||
assert.match(detailViewTemplate, /v-if="submitBusy" class="expense-recognition-banner submit-progress-banner"/)
|
||||
assert.doesNotMatch(detailViewScript, /preReviewExpenseClaim\(request\.value\.claimId\)/)
|
||||
assert.match(detailViewScript, /const submitActionLabel = computed/)
|
||||
assert.match(detailViewScript, /const submitConfirmSecondaryText = computed/)
|
||||
assert.match(detailViewScript, /submitConfirmDialogOpen\.value = true/)
|
||||
assert.match(detailViewScript, /submitConfirmDialogOpen\.value = false/)
|
||||
assert.match(detailViewScript, /submitConfirmDialogOpen,/)
|
||||
@@ -78,23 +81,38 @@ test('detail submit warns on missing risk explanation and supports standard adju
|
||||
assert.match(detailViewTemplate, /:open="riskOverrideDialogOpen"/)
|
||||
assert.match(detailViewTemplate, /:open="riskOverrideDialogOpen"[\s\S]*size="review"/)
|
||||
assert.match(detailViewTemplate, /异常说明/)
|
||||
assert.match(detailViewTemplate, /按职级标准重算/)
|
||||
assert.match(detailViewTemplate, /:title="riskOverrideDialogTitle"/)
|
||||
assert.match(detailViewTemplate, /:description="riskOverrideDialogDescription"/)
|
||||
assert.match(detailViewTemplate, /:confirm-text="riskOverrideConfirmText"/)
|
||||
assert.match(detailViewTemplate, /@confirm="confirmRiskOverrideDialog"/)
|
||||
assert.match(detailViewTemplate, /class="risk-override-card-shell"/)
|
||||
assert.match(detailViewTemplate, /class="risk-override-side-nav risk-override-side-nav--previous"/)
|
||||
assert.match(detailViewTemplate, /class="risk-override-side-nav risk-override-side-nav--next"/)
|
||||
assert.match(detailViewTemplate, /class="risk-override-guidance"/)
|
||||
assert.match(detailViewTemplate, /goToPreviousSubmitRisk/)
|
||||
assert.match(detailViewTemplate, /goToNextSubmitRisk/)
|
||||
assert.doesNotMatch(detailViewTemplate, /class="risk-override-nav"/)
|
||||
assert.doesNotMatch(detailViewTemplate, /v-model="riskOverrideReasons\[currentSubmitRiskWarning\.id\]"/)
|
||||
assert.doesNotMatch(detailViewTemplate, /risk-override-save-btn/)
|
||||
assert.doesNotMatch(detailViewTemplate, /confirmRiskOverrideReasons/)
|
||||
assert.match(detailViewScript, /const submitRiskWarnings = computed/)
|
||||
assert.match(detailViewScript, /const submitExplainedRiskWarnings = computed/)
|
||||
assert.match(detailViewScript, /const submitRiskReviewWarnings = computed/)
|
||||
assert.match(detailViewScript, /const hasMissingSubmitRiskWarnings = computed/)
|
||||
assert.match(detailViewScript, /const riskOverrideConfirmText = computed\(\(\) =>[\s\S]*确认说明/)
|
||||
const handleSubmit = extractFunction(detailViewScript, 'handleSubmit')
|
||||
const confirmSubmitRequest = extractFunction(detailViewScript, 'confirmSubmitRequest')
|
||||
assert.match(handleSubmit, /submitRiskWarnings\.value\.length[\s\S]*openRiskOverrideDialog\(\)/)
|
||||
assert.match(handleSubmit, /submitRiskReviewWarnings\.value\.length[\s\S]*openRiskOverrideDialog\(\)/)
|
||||
assert.doesNotMatch(confirmSubmitRequest, /openRiskOverrideDialog/)
|
||||
assert.doesNotMatch(detailViewScript, /riskOverrideReasons/)
|
||||
assert.doesNotMatch(detailViewScript, /function confirmRiskOverrideReasons\(\)/)
|
||||
assert.match(detailViewScript, /function confirmRiskOverrideDialog\(\)/)
|
||||
assert.match(detailViewScript, /function confirmRiskExplanation\(\)/)
|
||||
assert.match(detailViewScript, /function confirmStandardAdjustment\(\)/)
|
||||
assert.match(detailViewTemplate, /v-if="standardAdjustmentBusy" class="expense-recognition-banner standard-adjustment-banner"/)
|
||||
assert.match(detailViewScript, /const standardAdjustmentBusy = ref\(false\)/)
|
||||
const confirmRiskExplanation = extractFunction(detailViewScript, 'confirmRiskExplanation')
|
||||
assert.match(confirmRiskExplanation, /riskOverrideDialogOpen\.value = false[\s\S]*submitConfirmDialogOpen\.value = true/)
|
||||
const confirmStandardAdjustment = extractFunction(detailViewScript, 'confirmStandardAdjustment')
|
||||
assert.match(confirmStandardAdjustment, /const claimId = String\(request\.value\?\.claimId/)
|
||||
assert.match(confirmStandardAdjustment, /riskOverrideDialogOpen\.value = false[\s\S]*standardAdjustmentBusy\.value = true[\s\S]*void runStandardAdjustmentRecalculation\(claimId, taskSeq\)/)
|
||||
@@ -103,6 +121,7 @@ test('detail submit warns on missing risk explanation and supports standard adju
|
||||
const runStandardAdjustmentRecalculation = extractFunction(detailViewScript, 'runStandardAdjustmentRecalculation')
|
||||
assert.match(runStandardAdjustmentRecalculation, /acceptExpenseClaimStandardAdjustment\(claimId, payload\)/)
|
||||
assert.doesNotMatch(runStandardAdjustmentRecalculation, /submitConfirmDialogOpen\.value = true/)
|
||||
assert.match(detailViewScript, /buildStandardAdjustmentPayloadModel\(\{[\s\S]*warnings:\s*submitRiskCards\.value/)
|
||||
const actionBusyStart = detailViewScript.indexOf('const actionBusy = computed')
|
||||
const actionBusyEnd = detailViewScript.indexOf('const profile = computed', actionBusyStart)
|
||||
assert.ok(actionBusyStart > -1 && actionBusyEnd > actionBusyStart)
|
||||
@@ -126,20 +145,15 @@ test('detail header and fallback progress use reimbursement wording', () => {
|
||||
assert.doesNotMatch(detailViewScript, /label:\s*'保存草稿'/)
|
||||
})
|
||||
|
||||
test('archived detail delete action is gated by admin-only permission', () => {
|
||||
assert.match(detailViewScript, /canDeleteArchivedExpenseClaims/)
|
||||
assert.match(detailViewScript, /isArchivedRequestView/)
|
||||
assert.match(detailViewScript, /if \(isArchivedRequest\.value\) {\s*return canDeleteArchivedExpenseClaims\(currentUser\.value\)/)
|
||||
test('detail delete action is gated by admin-only permission', () => {
|
||||
assert.match(detailViewScript, /const canDeleteRequest = computed\(\(\) => isPlatformAdminUser\(currentUser\.value\)\)/)
|
||||
assert.match(detailViewTemplate, /v-else-if="canReturnRequest \|\| canApproveRequest \|\| canPayRequest \|\| canDeleteRequest"/)
|
||||
assert.doesNotMatch(detailViewTemplate, /v-if="canManageCurrentClaim"/)
|
||||
})
|
||||
|
||||
test('editable detail delete action is limited to applicant or claim manager', () => {
|
||||
assert.match(detailViewScript, /const isCurrentApplicant = computed/)
|
||||
assert.match(detailViewScript, /isPlatformAdminUser/)
|
||||
assert.match(detailViewScript, /if \(isApplicationDocument\.value\) {\s*return isPlatformAdminUser\(currentUser\.value\) \|\| \(isEditableRequest\.value && isCurrentApplicant\.value\)\s*}/)
|
||||
assert.match(detailViewScript, /if \(canManageCurrentClaim\.value\) {\s*return true\s*}/)
|
||||
assert.match(detailViewScript, /return isEditableRequest\.value && isCurrentApplicant\.value/)
|
||||
test('detail delete action does not allow applicant or claim manager fallback', () => {
|
||||
assert.doesNotMatch(detailViewScript, /const canDeleteRequest = computed\(\(\) => \{[\s\S]*isCurrentApplicant[\s\S]*\}\)/)
|
||||
assert.doesNotMatch(detailViewScript, /const canDeleteRequest = computed\(\(\) => \{[\s\S]*canManageCurrentClaim[\s\S]*\}\)/)
|
||||
assert.match(detailViewScript, /if \(isApplicationDocument\.value\) {\s*return '删除申请'\s*}/)
|
||||
assert.match(detailViewScript, /当前申请单已进入审批流程,只有退回后申请人本人或系统管理员可以删除。/)
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user