SCW图标
英雄背景无分隔线
博客

Ajout de paramètres à des annotations à l'aide d'actions de réécriture

艾伦-理查德森
发布于 2020 年 10 月 26 日
最后更新于 2026年3月8日

Dans cet article de blog, nous allons :

  • Démontrer la recherche et la correspondance des annotations
  • Annotations d'amen à l'aide de modèles de moustache

Sensei permet de faire correspondre des modèles de code problématiques, puis de les modifier selon les implémentations convenues. Dans cet exemple, j'utilise @Disabled sans paramètre comme modèle de code problématique.

Annotation de test désactivée

Les tests désactivés sans raison précise peuvent s'avérer problématiques à long terme car nous oublions pourquoi nous les avons désactivés.


@Disabled
annuler ThisTestMethodHasNoDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Le risque est qu'au fil du temps, la base de code évolue, que le test désactivé ne soit pas mis à jour en fonction de l'objectif du code et finisse par devenir redondant et non pertinent, et potentiellement jamais réactivé.

Lors des révisions de code, nous soulignerons souvent qu'il est judicieux d'ajouter une description explicative en tant que paramètre d'annotation.


@Disabled (« Désactivé pour montrer l'ajout d'une raison »)
annuler ThisTestMethodHasDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Une recette de Sensei

Nous pouvons écrire une recette pour détecter quand @Disabled est ajouté sans explication et un correctif rapide qui nous rappelle d'ajouter la véritable raison expliquant pourquoi nous l'avons désactivé.

Quand je pense à ce que je vais faire, je dois :

  • correspond à l'annotation Disabled sans aucun paramètre
  • modifiez l'annotation Disabled pour avoir un paramètre avec le texte du marqueur « À FAIRE : ajoutez une description ici »

Création d'une recette d'avertissement

J'utilise Alt+Entrée pour créer une nouvelle recette.

创建一个新的配方功能

Ajoutez ensuite le texte descriptif de base dans les informations générales.

一般设置

En faisant de la règle un avertissement, tout code correspondant est surligné mais n'apparaît pas comme une erreur flagrante.

让规则成为一种警告

Trouvez l'annotation

Dans l'éditeur de recettes, je modifie la recherche pour qu'elle corresponde à une annotation.

Cela mettra en évidence toutes les annotations dans l'aperçu.

食谱编辑

Cela fait, je souhaite filtrer en fonction du type d'annotation.

Je pourrais simplement utiliser Disabled mais je qualifie complètement la classe avec le package afin qu'elle ne corresponde qu'à l'annotation de JUnit 5. Comme le code source est affiché dans l'aperçu, je peux facilement le copier et le coller à partir du code réel pour éviter toute faute de frappe.

Je souhaite ensuite ne faire correspondre que les annotations sans paramètres, et je peux utiliser l'interface graphique pour le faire.

食谱设置

c'est-à-dire Rechercher :

recherche :
annotation :
tapez : « org.junit.Jupiter.API.Disabled »
sans :
paramètres :
- {}

Création d'une action de correction rapide de réécriture

Pour mon QuickFix, je vais utiliser une action de réécriture.

J'utilise le Afficher les variables fonctionnalité pour me montrer les variables Mustache et prévisualiser le contenu.

快速修复设置

Et puis j'ajoute le code supplémentaire nécessaire pour créer le commentaire du marqueur de position.

添加额外的代码来创建地点标记注释

c'est-à-dire QuickFix :

Correctifs disponibles :
- nom : « Ajouter un paramètre de commentaire todo »
actions :
- réécrire :
à : « {{{.}}} (\" À FAIRE : ajoutez une description ici \ ») »
cible : « soi »

Sensei en action

Nous avons créé une courte vidéo montrant le processus de création de recettes en action.

Résumé

Lors de la création d'un Quick Fix de réécriture, il est plus facile de rechercher l'élément de code que nous voulons réécrire, car c'est alors l'entité elle-même sur laquelle nous pouvons agir.

Dans cet exemple, j'ai utilisé une action de réécriture pour modifier l'annotation. La réécriture est une action générale qui peut s'appliquer à n'importe quel élément de code et constitue une bonne option d'exploration par défaut.

显示资源
显示资源

Apprenez à utiliser Sensei pour faire correspondre des modèles de code problématiques, puis à les modifier selon les implémentations convenues à l'aide d'exemples de correspondance d'annotations.

您想了解更多吗?

Alan Richardson possède plus de vingt ans d'expérience professionnelle en informatique. Il a travaillé en tant que développeur et a occupé tous les niveaux de la hiérarchie des tests, du testeur au responsable des tests. Responsable des relations avec les développeurs chez Secure Code Warrior, il travaille directement avec les équipes, pour améliorer le développement d'un code sécurisé de qualité. Alan est l'auteur de quatre livres, dont « Dear Evil Tester » et « Java For Testers ». Alan a également créé des cours de formation en ligne pour aider les utilisateurs à apprendre les tests techniques sur le Web et Selenium WebDriver avec Java. Alan publie ses vidéos d'écriture et de formation sur SeleniumSimplified.com, EvilTester.com, JavaForTesters.com et CompendiumDev.co.uk.

了解更多

Secure Code Warrior 在整个软件开发周期中保障代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全负责人、开发人员、信息安全主管,还是其他任何参与安全工作的人员,我们都能协助您的组织降低不安全代码带来的风险。

预约演示
分享到:
领英品牌社交x 标志
作者
艾伦-理查德森
2020年10月26日发布

Alan Richardson possède plus de vingt ans d'expérience professionnelle en informatique. Il a travaillé en tant que développeur et a occupé tous les niveaux de la hiérarchie des tests, du testeur au responsable des tests. Responsable des relations avec les développeurs chez Secure Code Warrior, il travaille directement avec les équipes, pour améliorer le développement d'un code sécurisé de qualité. Alan est l'auteur de quatre livres, dont « Dear Evil Tester » et « Java For Testers ». Alan a également créé des cours de formation en ligne pour aider les utilisateurs à apprendre les tests techniques sur le Web et Selenium WebDriver avec Java. Alan publie ses vidéos d'écriture et de formation sur SeleniumSimplified.com, EvilTester.com, JavaForTesters.com et CompendiumDev.co.uk.

分享到:
领英品牌社交x 标志

Dans cet article de blog, nous allons :

  • Démontrer la recherche et la correspondance des annotations
  • Annotations d'amen à l'aide de modèles de moustache

Sensei permet de faire correspondre des modèles de code problématiques, puis de les modifier selon les implémentations convenues. Dans cet exemple, j'utilise @Disabled sans paramètre comme modèle de code problématique.

Annotation de test désactivée

Les tests désactivés sans raison précise peuvent s'avérer problématiques à long terme car nous oublions pourquoi nous les avons désactivés.


@Disabled
annuler ThisTestMethodHasNoDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Le risque est qu'au fil du temps, la base de code évolue, que le test désactivé ne soit pas mis à jour en fonction de l'objectif du code et finisse par devenir redondant et non pertinent, et potentiellement jamais réactivé.

Lors des révisions de code, nous soulignerons souvent qu'il est judicieux d'ajouter une description explicative en tant que paramètre d'annotation.


@Disabled (« Désactivé pour montrer l'ajout d'une raison »)
annuler ThisTestMethodHasDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Une recette de Sensei

Nous pouvons écrire une recette pour détecter quand @Disabled est ajouté sans explication et un correctif rapide qui nous rappelle d'ajouter la véritable raison expliquant pourquoi nous l'avons désactivé.

Quand je pense à ce que je vais faire, je dois :

  • correspond à l'annotation Disabled sans aucun paramètre
  • modifiez l'annotation Disabled pour avoir un paramètre avec le texte du marqueur « À FAIRE : ajoutez une description ici »

Création d'une recette d'avertissement

J'utilise Alt+Entrée pour créer une nouvelle recette.

创建一个新的配方功能

Ajoutez ensuite le texte descriptif de base dans les informations générales.

一般设置

En faisant de la règle un avertissement, tout code correspondant est surligné mais n'apparaît pas comme une erreur flagrante.

让规则成为一种警告

Trouvez l'annotation

Dans l'éditeur de recettes, je modifie la recherche pour qu'elle corresponde à une annotation.

Cela mettra en évidence toutes les annotations dans l'aperçu.

食谱编辑

Cela fait, je souhaite filtrer en fonction du type d'annotation.

Je pourrais simplement utiliser Disabled mais je qualifie complètement la classe avec le package afin qu'elle ne corresponde qu'à l'annotation de JUnit 5. Comme le code source est affiché dans l'aperçu, je peux facilement le copier et le coller à partir du code réel pour éviter toute faute de frappe.

Je souhaite ensuite ne faire correspondre que les annotations sans paramètres, et je peux utiliser l'interface graphique pour le faire.

食谱设置

c'est-à-dire Rechercher :

recherche :
annotation :
tapez : « org.junit.Jupiter.API.Disabled »
sans :
paramètres :
- {}

Création d'une action de correction rapide de réécriture

Pour mon QuickFix, je vais utiliser une action de réécriture.

J'utilise le Afficher les variables fonctionnalité pour me montrer les variables Mustache et prévisualiser le contenu.

快速修复设置

Et puis j'ajoute le code supplémentaire nécessaire pour créer le commentaire du marqueur de position.

添加额外的代码来创建地点标记注释

c'est-à-dire QuickFix :

Correctifs disponibles :
- nom : « Ajouter un paramètre de commentaire todo »
actions :
- réécrire :
à : « {{{.}}} (\" À FAIRE : ajoutez une description ici \ ») »
cible : « soi »

Sensei en action

Nous avons créé une courte vidéo montrant le processus de création de recettes en action.

Résumé

Lors de la création d'un Quick Fix de réécriture, il est plus facile de rechercher l'élément de code que nous voulons réécrire, car c'est alors l'entité elle-même sur laquelle nous pouvons agir.

Dans cet exemple, j'ai utilisé une action de réécriture pour modifier l'annotation. La réécriture est une action générale qui peut s'appliquer à n'importe quel élément de code et constitue une bonne option d'exploration par défaut.

显示资源
显示资源

请填写以下表格以下载报告

我们希望获得您的授权,以便向您发送有关我们产品和/或安全编码相关主题的信息。我们将始终以最高标准谨慎处理您的个人数据,绝不会将其出售给其他企业用于营销目的。

提交
scw 成功图标
SCW 错误图标
要提交表单,请启用「Analytics」Cookie。完成操作后,请随时将其重新禁用。

Dans cet article de blog, nous allons :

  • Démontrer la recherche et la correspondance des annotations
  • Annotations d'amen à l'aide de modèles de moustache

Sensei permet de faire correspondre des modèles de code problématiques, puis de les modifier selon les implémentations convenues. Dans cet exemple, j'utilise @Disabled sans paramètre comme modèle de code problématique.

Annotation de test désactivée

Les tests désactivés sans raison précise peuvent s'avérer problématiques à long terme car nous oublions pourquoi nous les avons désactivés.


@Disabled
annuler ThisTestMethodHasNoDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Le risque est qu'au fil du temps, la base de code évolue, que le test désactivé ne soit pas mis à jour en fonction de l'objectif du code et finisse par devenir redondant et non pertinent, et potentiellement jamais réactivé.

Lors des révisions de code, nous soulignerons souvent qu'il est judicieux d'ajouter une description explicative en tant que paramètre d'annotation.


@Disabled (« Désactivé pour montrer l'ajout d'une raison »)
annuler ThisTestMethodHasDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Une recette de Sensei

Nous pouvons écrire une recette pour détecter quand @Disabled est ajouté sans explication et un correctif rapide qui nous rappelle d'ajouter la véritable raison expliquant pourquoi nous l'avons désactivé.

Quand je pense à ce que je vais faire, je dois :

  • correspond à l'annotation Disabled sans aucun paramètre
  • modifiez l'annotation Disabled pour avoir un paramètre avec le texte du marqueur « À FAIRE : ajoutez une description ici »

Création d'une recette d'avertissement

J'utilise Alt+Entrée pour créer une nouvelle recette.

创建一个新的配方功能

Ajoutez ensuite le texte descriptif de base dans les informations générales.

一般设置

En faisant de la règle un avertissement, tout code correspondant est surligné mais n'apparaît pas comme une erreur flagrante.

让规则成为一种警告

Trouvez l'annotation

Dans l'éditeur de recettes, je modifie la recherche pour qu'elle corresponde à une annotation.

Cela mettra en évidence toutes les annotations dans l'aperçu.

食谱编辑

Cela fait, je souhaite filtrer en fonction du type d'annotation.

Je pourrais simplement utiliser Disabled mais je qualifie complètement la classe avec le package afin qu'elle ne corresponde qu'à l'annotation de JUnit 5. Comme le code source est affiché dans l'aperçu, je peux facilement le copier et le coller à partir du code réel pour éviter toute faute de frappe.

Je souhaite ensuite ne faire correspondre que les annotations sans paramètres, et je peux utiliser l'interface graphique pour le faire.

食谱设置

c'est-à-dire Rechercher :

recherche :
annotation :
tapez : « org.junit.Jupiter.API.Disabled »
sans :
paramètres :
- {}

Création d'une action de correction rapide de réécriture

Pour mon QuickFix, je vais utiliser une action de réécriture.

J'utilise le Afficher les variables fonctionnalité pour me montrer les variables Mustache et prévisualiser le contenu.

快速修复设置

Et puis j'ajoute le code supplémentaire nécessaire pour créer le commentaire du marqueur de position.

添加额外的代码来创建地点标记注释

c'est-à-dire QuickFix :

Correctifs disponibles :
- nom : « Ajouter un paramètre de commentaire todo »
actions :
- réécrire :
à : « {{{.}}} (\" À FAIRE : ajoutez une description ici \ ») »
cible : « soi »

Sensei en action

Nous avons créé une courte vidéo montrant le processus de création de recettes en action.

Résumé

Lors de la création d'un Quick Fix de réécriture, il est plus facile de rechercher l'élément de code que nous voulons réécrire, car c'est alors l'entité elle-même sur laquelle nous pouvons agir.

Dans cet exemple, j'ai utilisé une action de réécriture pour modifier l'annotation. La réécriture est une action générale qui peut s'appliquer à n'importe quel élément de code et constitue une bonne option d'exploration par défaut.

查看网络研讨会
开始
了解更多

点击下方链接,下载此资源的PDF文件。

Secure Code Warrior 在整个软件开发周期中保障代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全负责人、开发人员、信息安全主管,还是其他任何参与安全工作的人员,我们都能协助您的组织降低不安全代码带来的风险。

显示报告预约演示
下载PDF文件
显示资源
分享到:
领英品牌社交x 标志
您想了解更多吗?

分享到:
领英品牌社交x 标志
作者
艾伦-理查德森
2020年10月26日发布

Alan Richardson possède plus de vingt ans d'expérience professionnelle en informatique. Il a travaillé en tant que développeur et a occupé tous les niveaux de la hiérarchie des tests, du testeur au responsable des tests. Responsable des relations avec les développeurs chez Secure Code Warrior, il travaille directement avec les équipes, pour améliorer le développement d'un code sécurisé de qualité. Alan est l'auteur de quatre livres, dont « Dear Evil Tester » et « Java For Testers ». Alan a également créé des cours de formation en ligne pour aider les utilisateurs à apprendre les tests techniques sur le Web et Selenium WebDriver avec Java. Alan publie ses vidéos d'écriture et de formation sur SeleniumSimplified.com, EvilTester.com, JavaForTesters.com et CompendiumDev.co.uk.

分享到:
领英品牌社交x 标志

Dans cet article de blog, nous allons :

  • Démontrer la recherche et la correspondance des annotations
  • Annotations d'amen à l'aide de modèles de moustache

Sensei permet de faire correspondre des modèles de code problématiques, puis de les modifier selon les implémentations convenues. Dans cet exemple, j'utilise @Disabled sans paramètre comme modèle de code problématique.

Annotation de test désactivée

Les tests désactivés sans raison précise peuvent s'avérer problématiques à long terme car nous oublions pourquoi nous les avons désactivés.


@Disabled
annuler ThisTestMethodHasNoDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Le risque est qu'au fil du temps, la base de code évolue, que le test désactivé ne soit pas mis à jour en fonction de l'objectif du code et finisse par devenir redondant et non pertinent, et potentiellement jamais réactivé.

Lors des révisions de code, nous soulignerons souvent qu'il est judicieux d'ajouter une description explicative en tant que paramètre d'annotation.


@Disabled (« Désactivé pour montrer l'ajout d'une raison »)
annuler ThisTestMethodHasDisabledReason () {
Assertions.fail (« Ce test est désactivé et ne devrait pas être exécuté ») ;
}

Une recette de Sensei

Nous pouvons écrire une recette pour détecter quand @Disabled est ajouté sans explication et un correctif rapide qui nous rappelle d'ajouter la véritable raison expliquant pourquoi nous l'avons désactivé.

Quand je pense à ce que je vais faire, je dois :

  • correspond à l'annotation Disabled sans aucun paramètre
  • modifiez l'annotation Disabled pour avoir un paramètre avec le texte du marqueur « À FAIRE : ajoutez une description ici »

Création d'une recette d'avertissement

J'utilise Alt+Entrée pour créer une nouvelle recette.

创建一个新的配方功能

Ajoutez ensuite le texte descriptif de base dans les informations générales.

一般设置

En faisant de la règle un avertissement, tout code correspondant est surligné mais n'apparaît pas comme une erreur flagrante.

让规则成为一种警告

Trouvez l'annotation

Dans l'éditeur de recettes, je modifie la recherche pour qu'elle corresponde à une annotation.

Cela mettra en évidence toutes les annotations dans l'aperçu.

食谱编辑

Cela fait, je souhaite filtrer en fonction du type d'annotation.

Je pourrais simplement utiliser Disabled mais je qualifie complètement la classe avec le package afin qu'elle ne corresponde qu'à l'annotation de JUnit 5. Comme le code source est affiché dans l'aperçu, je peux facilement le copier et le coller à partir du code réel pour éviter toute faute de frappe.

Je souhaite ensuite ne faire correspondre que les annotations sans paramètres, et je peux utiliser l'interface graphique pour le faire.

食谱设置

c'est-à-dire Rechercher :

recherche :
annotation :
tapez : « org.junit.Jupiter.API.Disabled »
sans :
paramètres :
- {}

Création d'une action de correction rapide de réécriture

Pour mon QuickFix, je vais utiliser une action de réécriture.

J'utilise le Afficher les variables fonctionnalité pour me montrer les variables Mustache et prévisualiser le contenu.

快速修复设置

Et puis j'ajoute le code supplémentaire nécessaire pour créer le commentaire du marqueur de position.

添加额外的代码来创建地点标记注释

c'est-à-dire QuickFix :

Correctifs disponibles :
- nom : « Ajouter un paramètre de commentaire todo »
actions :
- réécrire :
à : « {{{.}}} (\" À FAIRE : ajoutez une description ici \ ») »
cible : « soi »

Sensei en action

Nous avons créé une courte vidéo montrant le processus de création de recettes en action.

Résumé

Lors de la création d'un Quick Fix de réécriture, il est plus facile de rechercher l'élément de code que nous voulons réécrire, car c'est alors l'entité elle-même sur laquelle nous pouvons agir.

Dans cet exemple, j'ai utilisé une action de réécriture pour modifier l'annotation. La réécriture est une action générale qui peut s'appliquer à n'importe quel élément de code et constitue une bonne option d'exploration par défaut.

目录

下载PDF文件
显示资源
您想了解更多吗?

Alan Richardson possède plus de vingt ans d'expérience professionnelle en informatique. Il a travaillé en tant que développeur et a occupé tous les niveaux de la hiérarchie des tests, du testeur au responsable des tests. Responsable des relations avec les développeurs chez Secure Code Warrior, il travaille directement avec les équipes, pour améliorer le développement d'un code sécurisé de qualité. Alan est l'auteur de quatre livres, dont « Dear Evil Tester » et « Java For Testers ». Alan a également créé des cours de formation en ligne pour aider les utilisateurs à apprendre les tests techniques sur le Web et Selenium WebDriver avec Java. Alan publie ses vidéos d'écriture et de formation sur SeleniumSimplified.com, EvilTester.com, JavaForTesters.com et CompendiumDev.co.uk.

了解更多

Secure Code Warrior 在整个软件开发周期中保障代码安全,并营造将网络安全置于首位的企业文化。无论您是应用安全负责人、开发人员、信息安全主管,还是其他任何参与安全工作的人员,我们都能协助您的组织降低不安全代码带来的风险。

预约演示下载
分享到:
领英品牌社交x 标志
资源中心

帮助您入门的资源

更多帖子
资源中心

帮助您入门的资源

更多帖子