52
Contratos Modelagem Funcional

Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Embed Size (px)

Citation preview

Page 1: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contratos

Modelagem Funcional

Page 2: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Modelagem Funcional

Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Page 3: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Artefatos necessários

Modelo conceitual Diagramas de seqüência ou casos de

uso expandidos

Page 4: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato de Operação de Sistema Pré-condições Pós-condições Exceções

Page 5: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato de Consulta de Sistema Pré-condições Resultados

Page 6: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Pré-condições

definem o que deve ser verdadeiro na estrutura da informação armazenada para que a operação ou consulta possa ser executada

elas não serão testadas durante a execução algum mecanismo externo deverá garantir

sua validade antes de habilitar a execução da operação ou consulta de sistema correspondente

Page 7: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Pós-condições

estabelecem o que uma operação de sistema muda na estrutura da informação armazenada

Page 8: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Resultados

Conjunto de informações retornado por uma consulta

Page 9: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Exceções

eventos que, se ocorrerem, impedem o prosseguimento correto da operação

usualmente não podem ser garantidas a priori

serão testadas durante a execução

Page 10: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Tipos de Pré-condições

Garantia de parâmetros: pré-condições que garantem que os parâmetros da operação ou consulta correspondem a elementos válidos do sistema de informação

Restrição complementar: pré-condições que garantem que a informação se encontra em uma determinada situação desejada

Page 11: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Pré-condição de garantia de parâmetros é semântica Verificações sintáticas são feitas por

tipagem Ex.: Ao invés de escrever “x deve ser

maior do que zero”, usar x:InteiroPositivo na declaração do parâmetro

Uma pré-condição é semântica se para testa-la for necessário consultar informações gerenciadas pelo sistema

Page 12: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Garantia de Parâmetros

Classe Videolocadora

operação: identificaCliente(nomeCliente:String)

pré:

Existe uma instância da classe Cliente tal que o atributo nome desta instância é igual ao parâmetro nomeCliente.

self.cadastroexists(cliente|cliente.nome=nomeCliente)

Page 13: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em um contexto não ambíguo

é possível simplificar a escrita da pré-condição

Classe Videolocadora

operação: identificaCliente(nomeCliente:String)

pré:

Existe um Cliente cujo nome é igual a nomeCliente.

self.cadastroexists(nome=nomeCliente)

Page 14: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Restrição complementar exemplo: se o modelo conceitual

especifica que uma associação tem multiplicidade de papel 0..1, uma pré-condição complementar poderá especificar que, para uma instância específica, a associação efetivamente existe (ou não existe)

uma pré-condição nunca poderá contradizer as especificações do modelo conceitual, apenas complementá-las

Page 15: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Tipos de restrições complementares Existe (ou não existe) uma instância (ou um conjunto

de instâncias) com determinadas propriedades. Todas as instâncias (ou nenhuma das instâncias) de

uma determinada classe (ou um conjunto definido por uma associação) têm determinadas propriedades.

Uma associação não obrigatória (com multiplicidade de papel 0..1 ou *) existe (ou não existe) entre determinadas instâncias.

Um determinado atributo de uma instância tem um certo valor.

Page 16: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Exemplo

Classe Videolocadora

operação: identificaCliente(nomeCliente:String)

pré:

Existe um Cliente cujo nome é igual a nomeCliente.

Este Cliente possui débito igual a zero.

Alias: cliente = self.cadastroselect(nome=nomeCliente)

Pré:

clientesize() == 1

cliente.debito == 0

Page 17: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Como garantir pré-condições

Considere a seguinte interface

Page 18: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Diagrama de seqüência com exceções

Operação: identificaCliente(nome:String)

Alias: cliente = self.cadastroselect(nome=nomeCliente)

Pré: -

Exceções:

“Nome invalido” se clientesize == 0

“Cliente com debito” se cliente.debito != 0

Page 19: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Convertendo uma possível exceção em pré-condição Interface modificada

Page 20: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

DS modificado para garantir uma pré-condição

Operação: identificaCliente(nome:String)

Alias: cliente = self.cadastroselect(nome=nomeCliente)

Pré: clientesize() == 1

Exceções:

“Cliente com debito” se cliente.debito != 0

Page 21: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

DS modificado para garantir ambas

Operação: identificaCliente(nome:String)

Alias: cliente = self.cadastroselect(nome=nomeCliente)

Pré:

clientesize() == 1

cliente.debito == 0

Exceções: -

Page 22: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Associações temporárias

são usadas para representar informações que não precisam persistir

Page 23: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Uso da associação temporária no contrato

Classe Videolocadora

operação: emprestaFita(codigoFita:String)

pré:

Existe um clienteCorrente.

self.clienteCorrentesize()==1

Page 24: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Pós-condições semânticas

Instância: criação e destruição Associação: criação e destruição Atributo: modificação de valor

Page 25: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Criação de uma instância e sua associação com outra instância preexistente

Pós: foi criado um Cliente e associado à Videolocadora

Pós: cliente = Cliente.new() self.addToCadastro(cliente).

Page 26: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Destruição de uma instância

Pós: “foi destruído um Cliente cujo nome é igual a nomeCliente”.

Presume-se que quando uma instância é destruída, todas as associações ligadas a ela também o sejam. Deve-se tomar cuidado com questões estruturais (associações obrigatórias) quando um objeto é destruído.

Alias: cliente = self.cadastroselect(nome=nomeCliente)

Pós:

self.cadastroremove(cliente)

cliente.destroy()

Page 27: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Criação de uma associação entre duas instâncias

Pós: O cliente cujo nome é nomeCliente foi associado à VideoLocadora como clienteCorrente

Alias: cliente = self.cadastroselect(nome=nomeCliente) Pós: self.clienteCorrente = cliente

Page 28: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Destruição de uma associação

Pós: foi destruída a associação de VideoLocadora com clienteCorrente

Pós: self.setClienteCorrente(null)

Page 29: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Modificação do valor de um atributo de uma instância

Pós: O débito do cliente corrente foi alterado para R$50,00

Pós: self.clienteCorrente.debito = 50

Page 30: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Pós-condição condicional

Pós: se não havia nenhum emprestimoAberto associado ao clienteCorrente, então um novo Emprestimo foi criado e associado ao clienteCorrente como emprestimoAberto.

Pós: self.clienteCorrente.emprestimoAberto@presize==0 IMPLIES self.clienteCorrente.emprestimoAberto=Emprestimo.new()

Page 31: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato para Inserção

Classe Videolocadora

operação: cadastraCliente(nomeC,enderecoC,telefoneC:String)

pré:

Não existe nenhum Cliente com nome = nomeC.

pós:

Foi criado um Cliente e adicionado ao cadastro.

Os atributos nome, endereco e telefone do Cliente foram alterados para nomeC, enderecoC e telefoneC.

O atributo debito do Cliente foi alterado para 0,00.

Page 32: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em OCL

Classe Videolocadora

operação: cadastraCliente(nomeC,enderecoC,telefoneC:String)

pré:

self.cadastro select(nome=nomeC) size==0

pós:

cliente = Cliente.new()

self.addToCadastro(cliente)

cliente.nome = nomeC

cliente.endereco = enderecoC

cliente.telefone = telefoneC

cliente.debito = 0

Page 33: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato para Alteração

Classe Videolocadora

operação: alteraCliente(nomeC,enderecoC,telefoneC:String)

pré:

Existe um Cliente com nome = nomeC.

pós:

Os atributos endereco e telefone do Cliente foram alterados para enderecoC e telefoneC.

Page 34: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em OCL

Classe Videolocadora

operação: alteraCliente(nomeC,enderecoC,telefoneC:String)

alias:

cliente = self.cadastro select(nome=nomeC)

pré:

cliente size() == 1

pós:

cliente.endereco = enderecoC

cliente.telefone = telefoneC

Page 35: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato para Exclusão

Classe Videolocadora

operação: excluiCliente(nomeC:String)

pré:

Existe um Cliente com nome = nomeC.

Esse Cliente não possui associação com nenhum Emprestimo.

pós:

O Cliente com nome = nomeC foi destruído.

Page 36: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em OCL

Classe Videolocadora

operação: excluiCliente(nomeC:String)

alias:

cliente = self.cadastro select(nome=nomeC)

pré:

cliente size=1.

cliente.emprestimos size=0.

pós:

self.removeFromCadastro(cliente).

Page 37: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Três opções para destruir uma instância com segurança

Garantir, via pré-condição, que ela não tenha associações obrigatórias.

Propagar a exclusão através das associações obrigatórias.

Gerar uma exceção, se a operação de exclusão for tentada em uma instância com associações obrigatórias

Page 38: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato para Consulta

Classe Videolocadora

consulta: consultaCliente(nomeC:String)

pré:

Existe um Cliente com nome = nomeC.

resultado:

Retorna o endereco e o telefone do Cliente

Page 39: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em OCL

Classe Videolocadora

consulta: consultaCliente(nomeC:String)

alias:

cliente = self.cadastro select(nome=nomeC)

pré:

cliente size==1

retorno:

cliente collect(Sequence{endereco,telefone})

Page 40: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Contrato para uma Consulta de Listagem

Classe Videolocadora

consulta: listaClientes()

pré:

retorno:

retorna os nomes de todos os Clientes do cadastro.

Page 41: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Em OCL

Classe Videolocadora

consulta: listaClientes()

pré:

retorno:

self.cadastro collect(nome)

Page 42: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Outras Consultas e Operações (específicas dos casos de uso) Freqüentemente haverá uma cadeia de

execução ao longo de um dos fluxos, explicitada no diagrama de seqüência.

Verificar: Qual é o objetivo de cada operação? O que cada uma delas espera que tenha sido

produzido pelas anteriores? O que cada uma delas produz? Que exceções poderiam ocorrer durante a

execução?

Page 43: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Exemplo

Page 44: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

consulta: listaNomesDeClientes()

pré:

resultado:

this.cadastro collect(nome)

Page 45: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

operação: identificaCliente(nomeC:String)

alias:

cliente = self.cadastro select(nome=nomeC)

pré:

cliente size() == 1

self.clienteCorrente size() == 0

pós:

self.setClienteCorrente(cliente)

Page 46: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

consulta: listaCodigosDeFitasDisponiveis()

pré:

retorno:

self.fitas select(emAndamento size() == 0) collect(codigo)

Page 47: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora operação: emprestaFita(codigoF:String) alias: fita = self.fitas select(codigo=codigoF) pré: self.clienteCorrente size() == 1 fita size() == 1 pós:

self.clienteCorrente.emprestimoAberto size() == 0 IMPLIES emprestimo = Emprestimo.new() emprestimo.data = today() emprestimo.valorTotal = 0 self.clienteCorrente.setEmprestimoAberto(emprestimo) item = ItemDeEmprestimo.new() emprestimo.addItem(item) estado = EmAndamento.new() item.addEstado(estado) estado.setFita(fita) item.setPrazo(fita.filme.tipoDeFilme.prazo) item.setValor(fita.filme.tipoDeFilme.valor) emprestimo.setValorTotal(emprestimo.valorTotal@pre + item.valor)

Page 48: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

consulta: consultaValorDoEmprestimoAberto()

pré:

self.clienteCorrente.emprestimoAberto size() == 1

resultado:

self.clienteCorrente.emprestimoAberto.valorTotal

Page 49: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

consulta: consultaPrazosDoEmprestimoAberto()

pré:

self.clienteCorrente.emprestimoAberto size() == 1

retorno:

self.clienteCorrente.emprestimoAberto.itensDeEmprestimo collect(prazo)

Page 50: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Classe Videolocadora

operação: finalizaEmprestimo()

pré:

self.clienteCorrente.emprestimoAberto size() == 1

self.clienteCorrente.emprestimoAberto.itensDeEmprestimo size() > 0

pós:

self.clienteCorrente.setEmprestimoAberto(null)

self.setClienteCorrente(null)

Page 51: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Trabalho a ser entregue no próximo módulo

1. Escolher um sistema qualquer. Selecionar um caso de uso não trivial. Expandir o caso de uso e fazer o diagrama de seqüência.

2. Fazer o modelo conceitual.3. Escrever os contratos das operações

e consultas do caso de uso.

Page 52: Contratos Modelagem Funcional. Especificação das funções externas do sistema Operações de Sistema - inputs Consultas de Sistema - outputs

Equipes de 3 pessoas

Cada equipe entregará 3 trabalhos Cada membro executa o passo 1

individualmente. Em seguida cada um repassa o resultado do

passo 1 para outro membro da equipe executar o passo 2.

Em seguida cada um repassa o resultado do passo 2 para o outro membro executar o passo 3.

Identificar em cada trabalho quem fez o que