J'ai une classe Java. Comment puis-je le tester unitaire ?
Dans mon cas, j'ai classe fait une somme binaire. Il prend deux byte[]
tableaux, les additionne et retourne un nouveau tableau binaire.
J'ai une classe Java. Comment puis-je le tester unitaire ?
Dans mon cas, j'ai classe fait une somme binaire. Il prend deux byte[]
tableaux, les additionne et retourne un nouveau tableau binaire.
Réponses:
Définissez la sortie attendue et souhaitée pour un cas normal, avec une entrée correcte.
Maintenant, implémentez le test en déclarant une classe, donnez-lui un nom (généralement quelque chose comme TestAddingModule), et ajoutez-y la méthode testAdd (c'est-à-dire comme celle ci-dessous):
assertEquals(expectedVal,calculatedVal)
.Testez votre méthode en l'exécutant (dans Eclipse, clic droit, sélectionnez Exécuter en tant que → Test JUnit).
//for normal addition
@Test
public void testAdd1Plus1()
{
int x = 1 ; int y = 1;
assertEquals(2, myClass.add(x,y));
}
Ajoutez d'autres cas comme vous le souhaitez.
Vérifiez que votre méthode gère correctement les entrées Null (exemple ci-dessous).
//if you are using 0 as default for null, make sure your class works in that case.
@Test
public void testAdd1Plus1()
{
int y = 1;
assertEquals(0, myClass.add(null,y));
}
@Test
notation est requise. Ceci est fait pour signaler au lanceur de test unitaire que cette méthode représente un test unitaire et doit être exécutée. Les méthodes qui ne sont pas annotées avec @Test
ne sont pas exécutées par le testeur.
null
pour y
simplement vous donner y
?
static
au modificateur de la méthode de test.
Je propose cet article pour IntelliJ et Eclipse .
Éclipse:
Pour faire un test unitaire pour votre projet, veuillez suivre ces étapes (j'utilise Eclipse pour écrire ce test):
1- Cliquez sur Nouveau -> Projet Java.
2- Notez le nom de votre projet et cliquez sur Terminer.
3- Faites un clic droit sur votre projet. Ensuite, cliquez sur Nouveau -> Classe.
4- Notez le nom de votre classe et cliquez sur Terminer.
Ensuite, terminez le cours comme ceci:
public class Math {
int a, b;
Math(int a, int b) {
this.a = a;
this.b = b;
}
public int add() {
return a + b;
}
}
5- Cliquez sur Fichier -> Nouveau -> Cas de test JUnit.
6- Cochez setUp () et cliquez sur Terminer. SetUp () sera l'endroit où vous initialiserez votre test.
7- Cliquez sur OK.
8- Ici, j'ajoute simplement 7 et 10. Donc, je m'attends à ce que la réponse soit 17. Complétez votre classe de test comme ceci:
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
public class MathTest {
Math math;
@Before
public void setUp() throws Exception {
math = new Math(7, 10);
}
@Test
public void testAdd() {
Assert.assertEquals(17, math.add());
}
}
9- Écrivez, cliquez sur votre classe de test dans l'explorateur de packages et cliquez sur Exécuter en tant que -> JUnit Test.
10- C'est le résultat du test.
IntelliJ: Notez que j'ai utilisé la communauté IntelliJ IDEA 2020.1 pour les captures d'écran. En outre, vous devez configurer votre jre avant ces étapes. J'utilise JDK 11.0.4.
1- Faites un clic droit sur le dossier principal de votre projet-> nouveau -> répertoire. Vous devriez appeler cela «test». 2- Faites un clic droit sur le dossier de test et créez le package approprié. Je suggère de créer les mêmes noms d'emballage que la classe d'origine. Ensuite, vous cliquez avec le bouton droit sur le répertoire de test -> marquer le répertoire comme -> racine des sources de test. 3- Dans le bon package dans le répertoire de test, vous devez créer une classe Java (je suggère d'utiliser Test.java). 4- Dans la classe créée, saisissez '@Test'. Ensuite, parmi les options offertes par IntelliJ, sélectionnez Ajouter 'JUnitx' au chemin de classe. 5- Écrivez votre méthode de test dans votre classe de test. La signature de la méthode est comme:
@Test
public void test<name of original method>(){
...
}
Vous pouvez faire vos affirmations comme ci-dessous:
Assertions.assertTrue(f.flipEquiv(node1_1, node2_1));
Voici les importations que j'ai ajoutées:
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
Vous pouvez vérifier vos méthodes comme ci-dessous:
Assertions.assertEquals(<Expected>,<actual>);
Assertions.assertTrue(<actual>);
...
Pour exécuter vos tests unitaires, faites un clic droit sur le test et cliquez sur Exécuter.
Si votre test réussit, le résultat sera comme ci-dessous:
J'espère que cela aide. Vous pouvez voir la structure du projet dans GitHub https://github.com/m-vahidalizadeh/problem_solving_project .
C'est une question très générique et il y a de nombreuses façons d'y répondre.
Si vous souhaitez utiliser JUnit pour créer les tests, vous devez créer votre classe de cas de test, puis créer des méthodes de test individuelles qui testent des fonctionnalités spécifiques de votre classe / module sous tests (les classes de cas de test uniques sont généralement associées à une seule classe de "production" qui est en cours de test) et à l'intérieur de ces méthodes, exécutez diverses opérations et comparez les résultats avec ce qui serait correct. Il est particulièrement important d'essayer de couvrir autant de caisses d'angle que possible.
Dans votre exemple spécifique, vous pouvez par exemple tester les éléments suivants:
Pour vérifier les résultats, vous pouvez utiliser diverses méthodes assertXXX de la classe org.junit.Assert (pour plus de commodité, vous pouvez faire 'import static org.junit.Assert. *'). Ces méthodes testent une condition particulière et échouent au test si elle ne valide pas (avec un message spécifique, éventuellement).
Exemple de classe de cas de test dans votre cas (sans le contenu des méthodes défini):
import static org.junit.Assert.*;
public class AdditionTests {
@Test
public void testSimpleAddition() { ... }
@Test
public void testPositiveNegativeAddition() { ... }
@Test
public void testNegativePositiveAddition() { ... }
@Test
public void testNegativeAddition() { ... }
@Test
public void testOverflow() { ... }
}
Si vous n'êtes pas habitué à écrire des tests unitaires mais que vous testez votre code en écrivant des tests ad-hoc que vous validez ensuite «visuellement» (par exemple, vous écrivez une méthode principale simple qui accepte les arguments saisis à l'aide du clavier puis imprime les résultats - puis vous continuez à saisir des valeurs et à vous valider vous-même si les résultats sont corrects), alors vous pouvez commencer par écrire ces tests dans le format ci-dessus et valider les résultats avec la méthode assertXXX correcte au lieu de le faire manuellement. De cette façon, vous pouvez réexécuter le test beaucoup plus facilement que si vous deviez faire des tests manuels.
Comme @CoolBeans mentionné, jetez un œil à jUnit . Voici un petit tutoriel pour vous aider à démarrer également avec jUnit 4.x
Enfin, si vous voulez vraiment en savoir plus sur les tests et le développement piloté par les tests (TDD), je vous recommande de consulter le livre suivant de Kent Beck: Test-Driven Development By Example .
D'autres réponses vous ont montré comment utiliser JUnit pour configurer des classes de test. JUnit n'est pas le seul framework de test Java. Cependant, se concentrer sur les détails techniques de l'utilisation d'un cadre nuit aux concepts les plus importants qui devraient guider vos actions, je vais donc en parler.
Le test (de toutes sortes de toutes sortes de choses) compare le comportement réel de quelque chose (le système sous test, SUT) avec son comportement attendu .
Les tests automatisés peuvent être effectués à l'aide d'un programme informatique. Parce que cette comparaison est effectuée par un programme informatique inflexible et peu intelligent, le comportement attendu doit être connu avec précision et sans ambiguïté.
Ce qu'un programme ou une partie de programme (une classe ou une méthode) est censé faire est sa spécification . Le logiciel de test nécessite donc que vous ayez une spécification pour le SUT. Cela peut être une description explicite ou une spécification implicite dans votre tête de ce qui est attendu.
Les tests unitaires automatisés nécessitent donc une spécification précise et sans ambiguïté de la classe ou de la méthode que vous testez.
Mais vous aviez besoin de cette spécification lorsque vous avez décidé d'écrire ce code. Ainsi, une partie de ce que sont les tests commence réellement avant que vous n'écriviez ne serait-ce qu'une seule ligne du SUT. La technique de test de Test Driven Development (TDD) pousse cette idée à l'extrême et vous demande de créer le code de test unitaire avant d'écrire le code à tester.
Les frameworks de tests unitaires testent votre SUT à l'aide d' assertions . Une assertion est une expression logique (une expression avec un boolean
type de résultat; un prédicat ) qui doit être true
si le SUT se comporte correctement. La spécification doit donc être exprimée (ou ré-exprimée) sous forme d'assertions.
Une technique utile pour exprimer une spécification sous forme d'assertions est la programmation par contrat . Ces spécifications sont en termes de postconditions . Une postcondition est une assertion sur l'état publiquement visible du SUT après le retour d'une méthode ou d'un constructeur. Certaines méthodes ont des postconditions qui sont des invariants , qui sont des prédicats qui sont vrais avant et après l'exécution de la méthode. On peut également dire qu'une classe a des invariants, qui sont des postconditions de chaque constructeur et méthode de la classe, et devraient donc toujours être vraies. Les postconditions (et invariants) ne sont exprimées qu'en termes d'état visible de publicité:public
et protected
champs, les valeurs renvoyées parpublic
et lesprotected
méthodes (telles que les getters) et l'état publiquement visible des objets passés (par référence) aux méthodes.
De nombreux débutants postent ici des questions demandant comment ils peuvent tester du code, en présentant le code mais sans indiquer les spécifications de ce code. Comme le montre cette discussion, il est impossible pour quiconque de donner une bonne réponse à une telle question, car au mieux les répondants potentiels doivent deviner la spécification, et pourraient le faire de manière incorrecte. Le demandeur de la question ne comprend évidemment pas l'importance d'une spécification, et est donc un novice qui a besoin de comprendre les principes fondamentaux que j'ai décrits ici avant d' essayer d'écrire du code de test.