Je suis en train de refactoriser l'ensemble existant de classes de test java pour des tests d'interface utilisateur automatisés. Parfois, je finis par apporter des modifications massives au fichier de classe ou à le réorganiser complètement. Cela me fait penser que lorsque je réécris toute la classe, devrais-je changer le nom de l'auteur dans la section des commentaires pour le mien?
Suis-je gourmand? ou est-ce que ça va être utile pour quelqu'un de voir mon nom et de me demander en cas de doute?
refactoring
Tarun
la source
la source
Réponses:
Cela dépend vraiment ...
Si vous pensez qu'il y a une légère chance que quelqu'un d'autre soit intéressé plus tard à demander à l'auteur d'origine, laissez son nom dans le code. Si vous pensez que quelqu'un pourrait être intéressé à vous demander en personne, indiquez votre nom. Et si vous pensez que les deux pourraient être possibles, laissez entrer les deux noms (ou un commentaire comme "basé sur le travail de ...).
Bien sûr, lorsque l'utilisation du contrôle de source est obligatoire sur votre lieu de travail, et que c'est le seul moyen d'accéder aux sources, enregistrez le brouhaha et supprimez chaque commentaire d'auteur de la source. Dans mon lieu de travail, par exemple, nous avons beaucoup de fichiers source dans le contrôle de source où nous ne prenons pas la peine d'écrire des noms dans les sources. Si je veux savoir qui est responsable du fichier, ou était dans le passé, ou pour un changement spécifique, TortoiseSVN me produira facilement un journal pour cela.
D'un autre côté, nous avons beaucoup de macros VBA, écrites par des gars, transmises à d'autres (certains d'entre eux ont quitté l'entreprise au fil des ans) et ont été beaucoup modifiées, le tout sans utiliser le contrôle de source. Heureusement, les commentaires de ces fichiers contiennent souvent des noms d'auteur et une sorte de journal d'historique.
la source
Je suis juste tombé sur un autre post où OP demandait si le nom de l'auteur devait même être dans l'en-tête du fichier et semble qu'au moins 2/3 des personnes qui ont répondu ont dit que le nom ne devrait même pas être répertorié et que vous devriez utiliser le contrôle de version pour gardez simplement une trace de qui a changé le fichier. Je ne sais pas ce qui est arrivé à ce message, mais maintenant je ne le trouve pas. <- (d'où "OP" anonyme)
Personnellement, je trouve que l'auteur répertorié dans l'en-tête du fichier est utile mais pour une raison légèrement différente (et cela peut ne pas concerner les autres dans leur environnement). Même si nous essayons de nous approprier la communauté et travaillons souvent sur diverses parties du projet, nous avons tendance à avoir peu de membres de l'équipe qui connaissent certains domaines du code beaucoup plus intimement que d'autres. Ainsi, lorsque quelqu'un (en particulier de nombreux entrepreneurs qui vont et viennent) ouvre un fichier qu'il n'a jamais vu auparavant, l'auteur devient la personne de référence. Il peut ne pas être le seul contributeur, ni même le contributeur majoritaire, mais ayant son nom en haut, il reconnaît avoir une certaine responsabilité dans la diffusion des connaissances / informations sur le code au reste de l'équipe. On peut lister plus d'une personne dans l'en-tête si plusieurs personnes ont en effet contribué et se sentent responsables.
Je trouve cela frustrant lorsque j'ai une question sur un fichier et que je dois recourir au contrôle de version pour identifier la personne principale ou la plus compétente. Ensuite, ils finissent par passer d'un gars à l'autre car ils nient tous vraiment savoir ce que fait le code ... ils devaient juste aller corriger un bogue ou deux.
Cette pratique fonctionne dans notre équipe car nous n'avons pas de transferts. Sauf si une personne quitte ou passe à une autre équipe, ce code / projet restera avec la personne et avec notre équipe. Évidemment, si les personnes qui gèrent le code ne sont pas les mêmes que celles qui l'écrivent, personne ne se soucierait de qui était répertorié dans l'en-tête.
Donc, à la lumière de mon point de vue sur les en-têtes de fichiers, je dirais que si vous avez modifié 80% du fichier et que vous vous sentez comme maintenant vous êtes le go-to guy pour toutes les questions (et vous devriez probablement ressentir la même chose), oui, allez avant et mettez à jour l'en-tête du fichier pour y avoir votre nom. Si vous vous sentez mal à l'idée de retirer la personne précédente, vous pouvez également y laisser son nom, du moins pour le moment. Vous pouvez toujours demander à l'auteur d'origine et je suis sûr que cela ne vous gênera pas du tout que vous ayez changé le nom, car je suppose qu'il n'y a aucune difficulté à changer 80% du fichier lui-même.
MISE À JOUR: Trouvé ce poste . Je ne sais pas comment j'ai réussi à retirer quelque chose d'août. Je viens de terminer la lecture de The Pragmatic Programmer et dans le dernier chapitre, les auteurs parlent de travail de signature et de responsabilité (l'autre post l'a mentionné, c'est pourquoi je l'ai recherché). Le livre est parfaitement logique et maintenant que j'y pense, nous devrions peut-être introduire une politique d'équipe selon laquelle quiconque est répertorié comme auteur devrait être inclus dans toutes les révisions de code du fichier en question. Peu importe qui a modifié le fichier en dernier ou le plus dans SVN, l'auteur est le propriétaire et le gardien.
la source
Je ne trouve pas le nom de l'auteur terriblement utile. Comme le montre cette question, il n’existe souvent pas d’auteur unique, il n’est donc pas possible de nommer «l’auteur».
Vous pouvez bien sûr inclure une liste de toutes les personnes qui ont apporté des contributions importantes, mais vous pouvez déjà l'obtenir à partir du journal de contrôle des révisions - alors à quoi ça sert?
Sur mon projet, il n'y a pas d'informations d'auteur dans la plupart des fichiers. Si vous avez une question, il vous suffit de consulter les journaux, et il est généralement évident qu'une ou deux personnes ont effectué la majeure partie du travail, alors posez-les.
Éditer
La réponse suppose un projet utilisant le contrôle de version. Si vous n'utilisez pas (régulièrement) VC, alors mettre un auteur (liste), et peut-être un historique des modifications dans un fichier peut être une solution de contournement viable. Néanmoins, vous devriez probablement commencer à utiliser VC le plus rapidement possible, auquel cas voir ci-dessus :-).
la source
so what's the point?
Projets qui ne sont pas sous un vcs, projets qui à un moment donné ont migré vers un vcs différent (tous les schémas de migration ne permettent pas la migration d'historique, malheureusement), et projets qui utilisent plus d'un vcs en même temps - certains projets FLOSS adoptent cela approche pour faciliter la contribution des gens, sans les limiter à un seul vcs (les gens svn trouvent git difficile, les gens git trouvent svn inutilisable, et nous hg les gens se moquent des deux)Si le fichier a été modifié de manière significative, il devrait être acceptable d'ajouter votre nom dans le fichier en tant que personne qui en sait quelque chose.
la source
Le créateur du fichier source doit / doit toujours (à mon humble avis) être mentionné dans le fichier source. Ceci, avec de bons commentaires d'en-tête, devrait montrer pourquoi l'auteur a développé la source et ce qu'il pensait pour écrire le code. Quant au responsable du code, l'ajout du nom du responsable est crucial pour le suivi du contrôle des sources.
La dénomination de l'auteur, à mon humble avis à nouveau, devrait inclure la version source du code, en dehors du système de contrôle de version, la première date à laquelle le changement s'est produit, ainsi que le numéro de demande de changement. La raison en est que si la décision de changer VCS survient, il y a l'historique de la version du code, qui était l'auteur ainsi que le numéro de demande de changement auquel les développeurs peuvent se référer (s'ils ont besoin de savoir pourquoi le responsable a fait ce qu'il / elle l'a fait). Ainsi, dans notre organisation, notre format est le suivant:
la source
J'aime voir le nom de l'auteur d'origine, ne serait-ce que pour trouver quelqu'un pour commencer ma quête de réponses sur le code. (L'auteur n'a généralement aucun souvenir, mais c'est au moins une photo!)
Je recommanderais simplement d'ajouter votre nom en dessous de l'auteur d'origine.
Il n'est pas nécessaire de remplacer le nom de l'autre personne, car elle peut connaître un aspect du besoin commercial d' origine que vous n'avez pas, et d'autres qui suivent après vous devrez peut-être également parler à cette personne.
la source
Ma politique sur les commentaires @author est la suivante:
Si vous avez des questions sur quelque chose, peu importe qui est @l'auteur du fichier - peu importe qui est @l'auteur de la partie du fichier que vous modifiez. C'est pour ça
[git/svn/whatever] blame
.OMI, @author doit s'en aller.
la source