41 mensagens, 21 participantes
Nomes 'complexos/descritivos' no modelo?
#design #java #model #mvc #csharp
|
29 mensagens |
Bom dia a todos. Lendo alguns exemplos de Restfulie (em especial), vi que a nomeclatura dos controllers, em especial, são até certo ponto minimalista. Nomes curtos e expressivos. Diante disso, tenho uma curiosidade: o que vocês estabelecem como padrão para usarem nos models? Nomes curtos (e.g. class User, método buscar) ou nomes mais complexos e descritivos, semelhantes aos recomendados para TDD (e.g. class User, método buscarPeloId). Qual idéia/metodologia vocês usam? |
| Share | | |
|
64 mensagens |
Em testes eu uso o mais claro possivel. Nos meus modelos também prefiro utilizar nomes de métodos que façam sentido ao ler, mas também tomo cuidado para ser redudando como no caso: 1 public class ContatoDAO(){ 2 3 public void insereContato(){} 4 5 } 6No caso acima o nome do método está redudando já que estamos em um DAO de contato, IMHO o nome do método deveria ser apenas insere() e não insereContato(). Outra caso que você citou é o busca() ou buscaPeloID(). Eu sempre utilizo os parametros como complemento para expressar o método, nomenclaturas dos parametros são bem importantes para a expressividade da assinatura do método. 1 public class ContatoDAO(){ 2 3 public void busca(Long id){} 4 // ao inves de, 5 public void buscaPorId(Long id){} 6 }Sobre o tamanho, eu não me preocupo tanto com isso, me preocupo sim se o nome do método está grande pq ele está fazendo coisas de mais (hora de quebrar em outros metodos). |
|
20 mensagens |
As vezes a expressividade prejudica a legibilidade, como no caso: @Test acho q tudo deve ser um balanceamento entre expressividade e legibilidade |
|
Líder técnico 354 mensagens |
Oi Anderson, Pode me linkar os testes para que eu possa ver se eu gostaria de renomea-los? Seria uma grande ajuda. Em geral, prefiro nomes longos e que digam exatamente o que deveriam fazer, como por exemplo: 1 it "deveria enviar um email caso ocorra um erro" do 2 endAo inves do que não gosto, que não deixa claro as condições e a situação exata, além de sua expectativa: 1 it "envia email" do 2 endOu ainda outra forma que não gosto, mais direta ainda: 1 it "email" do 2 end
--
Guilherme Silveira |
|
29 mensagens |
Olá Guilherme. Não há nada de testes a linkar não hehe E, também, pelo motivo já citado acima. Eu estava lendo os docs do Restfulie e parei para pensar nisso. Então, percebi que normalmente utilizo nomes bem descritivos em meus modelos. Já nos controles, gosto de nomes mais minimalistas mesmo, ainda mais pelo fato de o mesmo ficar ‘disponível’ para o usuário final dos sistemas. ;) Abraços! |
|
97 mensagens |
Gosto de ser expressivo também, usando o junit faço os testes um pouco diferentes mais bem expressivos: 1 public class GerenciamentoClientesManagedBeanTest { 2 @Test public void filtrandoClientes(){ 3 dadoQueEstouAcessandoComoGerenteDaLoja(); 4 eEstouGerenciandoMeusClientes(); 5 ePossuoClientesCadastrados(); 6 quandoInformarCriteriosDeBusca(); 7 eSolicitarPesquisaPorClientes(); 8 oSistemaDeveriaApresentarAListaDeClientes(); 9 10 masSeEuNaoTiverClientesParaOsCriteriosInformados(); 11 eSolicitarPesquisaPorClientes(); 12 oSistemaDeveriaExibirMensagem("Não a Clientes para os critérios informados"); 13 14 masSeAlgumCampoDoCriterioDeBuscaFoiInformadoIncorretamente(); 15 eSolicitarPesquisaPorClientes(); 16 oSistemaDeveriaEmitirMensagem("Informe Critérios de busca corretamente"); 17 18 masSeEuEstiverComAlgumErroNoSistemaDeBuscasPorClientes(); 19 eSolicitarPesquisaPorClientes(); 20 oSistemaDeveriaExibirMensagem("Erro no sistema, não foi possível efetuar busca"); 21 oSistemaDeveriaLogarOErroNoLog(); 22 } 23 } |
|
4 mensagens |
No Calopsita (http://calopsitaproject.org), usamos uma nomenclatura pra JUnit num esquema parecido com esse, Alberto, mas fizemos uma sintaxezinha própria pra permitir trabalhar com objetos mais especializado nesses métodos de suporte: 1 @Test 2 public void addACardInAnIteration() { 3 given.thereIsAnUserNamed("sergio").and() 4 .thereIsAProjectNamed("IEs4Linux") 5 .ownedBy("sergio") 6 .withACardNamed("support IE8") 7 .planningCard() 8 .whichDescriptionIs("IE8 must be supported").and() 9 .withAnIterationWhichGoalIs("new release").and() 10 .iAmLoggedInAs("sergio"); 11 when.iOpenProjectPageOf("IEs4Linux").and() 12 .iOpenThePageOfIterationWithGoal("new release").and() 13 .iAddTheCard("support IE8").inThisIteration(); 14 then.theCard("support IE8").appearsOnList("iteration_cards"); 15 }Esses objetos given, when e then é que contém os métodos chamados e temos alguns tipos de givens, então, pra navegar de um pra outro, os conectivos and, which, in nos ajudam. Mas com foco na discussão inicial, os testes, gosto de descrever muito bem o que está acontecendo, mas em métodos e classes de produção, prefiro (inconscientemente, acho) nomes o mais curtos possível que digam o que aquilo faz. |
|
97 mensagens |
Muito bom ver isso, estou sempre procurando ver referenciais para comparar e gostei do que o calopsita faz. Parabéns. |
|
29 mensagens |
Digo o mesmo Carlos. É bom ver, através de discussões e exemplos como os expostos aqui, um bom caminho (das pedras) a seguir ;) |
|
1 mensagem |
Alguém ja uso o JBehave? Eu usei uma vez e achei bem bacana o resultado, pelo eu acho melhor do que o exemplo postado pelo Carlos. |
|
105 mensagens |
Só um ponto, Carlos Alberto: olhando para o seu teste não dá pra saber direito se o que vc setou na segunda parte tem efeitos na terceira ou na quarta… mesmo que vc tenha que repetir alguns comandos (os que descrevem o contexto atual) é bom que as 4 asserções que vc fez no teste sejam 4 testes diferentes |
|
13 mensagens |
Eu sou a favor do equilíbrio. Gosto de nomes claros que aumentam a fluência e legibibilidade do código sem ser redundantes. Cada vez mais tento escrever códigos que se aproximem de algo natural.
--
Lennon Jesus. |
|
2 mensagens |
Costumo fazer métodos como: 1 public interface UsuarioRepository { 2 3 void loadById(Long id); 4 5 }@Pedro e @Lennon. Outra coisa que costumo ver muito em códigos e vi aqui também é a falta do infinitivo nos nomes dos métodos: 1 public interface UsuarioRepository { 2 3 void buscaPorNome(String nome); // O que o método faz. 4 5 void buscarPorNome(String nome); // O que o método irá fazer. Infinitivo, Ok! 6 7 }As vezes ocorre de um nome ser muito grande por conta de um acoplamento também muito grande. Talvez um extract para dividir o método resolveria. É sempre bom utilizar o contexto para expressar suas ações, outras vezes não há para onde correr, ai o jeito é procurar sinônimos curtos e expressivos. |
|
7 mensagens |
Anderson, eu uso nomes expressivos no model, mas com alguma nomenclatura. Os métodos “buscar…()” retornam ou carregam uma instância do objeto. Já os métodos “listar…()” retornam uma lista de objetos. |
|
64 mensagens |
@wbotelhos Opa concordo, nesse caso de sobrecarga inválida eu geralmente utilizo o loadByNome(String nome) mesmo, pq ai não tem jeito. |
|
29 mensagens |
Vinicius, abordagem interessante. Assim, quem vê já sabe até o tipo que ele retorna. Bem bacana! :D |
|
97 mensagens |
Boa dica Lucas, vou fazer isso mesmo decompor em testes menores, e gostei muito do que vocês fizeram no calopsita, vou tentar usar um modelo semelhante aqui em meus projetos. Obrigado a todos. |
|
53 mensagens |
Nossa, que nomes pequenos! Hehehe. Eu sempre tento passar o máximo da funcionalidade do método no nome. Algo do tipo: Uma coisa que comecei a fazer de uns tempos pra cá, mesmo colocando nomes significativos nos métodos é usar JavaDoc. Existem algumas classes *Utils que não tenho a chance de mudar o nome, então coloquei JavaDoc (são métodos com descrição suficiente, mas eu colocaria outro nome). Vocês apoiam o uso do JavaDoc? Lendo o livro Clean Code, eu acho que existe uma certa aversão ao comentário, mas acho que existem casos em que é interessante o uso do mesmo (nessas classes *Utils, por exemplo, que não tenho a oportunidade de mudar o nome do método… Não vejo outro jetio de facilitar a vida dos programadores que usam essas *Utils). |
|
105 mensagens |
nomes de métodos devem descrever o que eles fazem, e não como eles fazem. Assim você consegue trabalhar voltado à interface e não à implementação. Qto a usar javadocs, o problema é que documentação está sempre desatualizada, vc não pode depender disso na sua aplicação. O ideal é que as classes e os métodos sejam expressivos o suficiente para vc não precisar da documentação para usar. |
|
53 mensagens |
Lucas, eu concordo com você. É muito mais saudável e interessante fazer da maneira como você falou. Mas vamos supor uma situação… Por algum motivo (seja lá qual for), o cliente quer que apareçam diversos valores de uma venda na tela. Baseado nos preços unitários brutos (ou seja, sem desconto), com desconto, com desconto na venda de forma geral, com acréscimo dependendo de um cálculo de juros, e por aí vai. Eu teria que criar o método que falei, deixar público para apresentar o valor calculado na tela e ainda, usar ele em um outro método de cálculo (calcular o valor total bruto e depois o valor total da venda com base em um desconto geral). Teria uma maneira mais fácil de escrever o nome como disse? Eu não poderia deixar simplesmente |
