Skip to content

Sprint 7: Venda com workflow de aprovacao + Comissao 1:N#29

Merged
gustavograciano merged 1 commit into
mainfrom
feat/sprint-7-venda
Apr 22, 2026
Merged

Sprint 7: Venda com workflow de aprovacao + Comissao 1:N#29
gustavograciano merged 1 commit into
mainfrom
feat/sprint-7-venda

Conversation

@gustavograciano

Copy link
Copy Markdown
Owner

Summary

Sprint 7 do PLANO-DESENVOLVIMENTO.md. Venda deixa de ser registro simples e vira processo com aprovação + comissões múltiplas + transação atômica que garante consistência quando apto muda para Vendido.

Domain

  • Enums `StatusVenda`, `TipoComissao`, `StatusComissao`
  • `Usuario` ganhou `Creci`, `PercentualComissao`, `UltimoLoginEm`
  • Venda reescrita: `Numero` único por tenant, `PropostaId` nullable, `CorretorCaptacaoId`, `GerenteAprovadorId`, `CondicaoFinal` snapshot (owned type, cópia congelada da Proposta)
  • Comissao 1:N em Venda — unique `(VendaId, UsuarioId, Tipo)`

Api — VendasController

  • `POST` cria Negociada, gera `VEND-YYYY-NNNNN`, calcula comissões automáticas de Captação + Venda via `PercentualComissao`
  • `POST /{id}/aprovar` (`Admin,Gerente`) — transação atômica:
    • Status → EmContrato, Apto → Vendido, grava GerenteAprovadorId
    • Cancela todas reservas e propostas concorrentes do apto com histórico
    • Marca Proposta ligada como Aceita
  • `POST /{id}/contrato-assinado` — Status = Assinada, comissões Pendentes viram Aprovadas
  • `POST /{id}/cancelar` (`Admin,Gerente`) — libera apto, cancela comissões não-pagas
  • `PUT /comissoes/{id}/pagar` (`Admin`) — só paga se Aprovada
  • `GET /comissoes/abertas` — lista Pendentes/Aprovadas

Testes — 86 total (+6)

VendaWorkflowTests cobre:

  • Aprovação muda apto+venda corretamente
  • Rejeita aprovação fora de Negociada
  • Cancela propostas concorrentes automaticamente
  • Contrato-assinado aprova comissões pendentes
  • Cancelar libera apto + cancela comissões
  • Pagar só libera comissão Aprovada (rejeita Pendente)

Warning `InMemoryEventId.TransactionIgnoredWarning` silenciado em TestDbContextFactory — controllers usam `BeginTransactionAsync`.

Próximo PR (Sprint 8) ⭐⭐⭐

Espelho de vendas PDF com QuestPDF (diferencial #1 do produto).

🤖 Generated with Claude Code

Sprint 7 do PLANO-DESENVOLVIMENTO.md: venda deixa de ser registro simples
e vira processo com aprovacao, comissoes multiplas e transacao atomica
que garante consistencia quando o apto muda pra Vendido.

Domain:
- Enums StatusVenda (Negociada/EmContrato/Assinada/Cancelada/Distratada),
  TipoComissao (Captacao/Venda/OverrideGerente/Parceria), StatusComissao
- Usuario ganhou Creci, PercentualComissao, UltimoLoginEm
- Venda reescrita: Numero unico por tenant, PropostaId nullable,
  CorretorCaptacaoId, GerenteAprovadorId, DataFechamento, DataAprovacao,
  ValorFinal, Status enum (era string), ContratoUrl, CondicaoFinal
  (snapshot OwnsOne - copia congelada da condicao, nao compartilha
  ref com Proposta)
- Comissao 1:N em Venda com unique (VendaId, UsuarioId, Tipo)

Application:
- Dtos (VendaCreateRequest, VendaResponse, ComissaoResponse,
  ContratoAssinadoRequest, CancelarVendaRequest)
- MappingRegistry com Venda e Comissao

Infrastructure:
- DbContext com OwnsOne CondicaoFinal, FKs + precisao decimal;
  Comissao cascade ao apagar Venda
- Migration VendaWorkflow (drop das colunas antigas string/decimal,
  add novas cols + tabela Comissoes)
- Warning InMemoryEventId.TransactionIgnoredWarning silenciado em
  TestDbContextFactory (InMemory nao tem tx real, mas controllers
  usam BeginTransactionAsync)

Api:
- VendasController reescrito:
  - POST cria Negociada, gera Numero VEND-YYYY-NNNNN, calcula comissoes
    automaticas via PercentualComissao dos corretores (Captacao + Venda)
  - POST /{id}/aprovar [Admin,Gerente]: TRANSACAO ATOMICA - muda
    Status pra EmContrato, apto pra Vendido, grava GerenteAprovadorId,
    cancela todas as reservas/propostas concorrentes do apto, marca
    a Proposta ligada como Aceita (com historico)
  - POST /{id}/contrato-assinado: Status = Assinada, comissoes
    Pendentes viram Aprovadas (liberadas pra pagamento)
  - POST /{id}/cancelar [Admin,Gerente]: libera apto, cancela comissoes
    nao-pagas, append do motivo nas Observacoes
  - PUT /comissoes/{id}/pagar [Admin]: so paga se Aprovada
  - GET /comissoes/abertas [Admin,Gerente]: lista pendentes/aprovadas

Tests (86 total, +6):
- VendaWorkflowTests: aprovacao muda apto+venda corretamente; rejeita
  aprovacao fora de Negociada; cancela propostas concorrentes
  automaticamente; contrato-assinado aprova comissoes; cancelar
  libera apto e comissoes nao-pagas; pagar so aprova se estiver
  Aprovada (rejeita Pendente)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
@gustavograciano gustavograciano merged commit c095ed7 into main Apr 22, 2026
gustavograciano added a commit that referenced this pull request May 3, 2026
Sprint 7: Venda com workflow de aprovacao + Comissao 1:N
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant