Réparation branche dev

This commit is contained in:
SylvanCourtiol
2021-05-08 18:38:44 +02:00
parent 9bf6910e72
commit 8993389bfd
30 changed files with 0 additions and 237 deletions
-25
View File
@@ -1,25 +0,0 @@
/**
* InterpreteurException.java 7 mai 2021
* IUT Rodez info1 2020-2021, pas de copyright, aucun droit
*/
package outils;
/**
* Exception levée lors d'une erreur dans l'interpreteur LIR.
* (Erreur de syntaxe, erreur de types)
* @author Nicolas Caminade
* @author Sylvan Courtiol
* @author Pierre Debas
* @author Heïa Dexter
* @author Lucas Vabre
*/
public class InterpreteurException extends RuntimeException {
/**
* Une exception de syntaxe expliquée par un message
* @param message explication succincte de cette exception
*/
public InterpreteurException(String message) {
super(message);
}
}
-42
View File
@@ -1,42 +0,0 @@
/*
* Assertions.java 7 avr. 2021
* IUT info1 2020-2021, groupe 2, aucun droit d'auteur
*/
package outils.glg;
/**
* Propositions logiques de test qui propage EchecTest
* si elles ne sont pas vérifiées
* @author info1 202-2021
*/
public class Assertions {
/**
* Assertion vérifiant qu'une expression booléenne est vraie.
* Ce test échoue si elle est fausse
* @param condition expression booléenne à tester
*/
public static void assertTrue(boolean condition) {
if (!condition) {
throw new EchecTest();
}
}
/**
* Assertion testant l'équivalence de 2 objets selon la relation
* d'équivalence de base equals (@see java.lang.Object#equals)
* @param attendu valeur attendue pour le test
* @param obtenu valeur obtenue à tester
*/
public static void assertEquivalent(Object attendu, Object obtenu) {
assertTrue(obtenu.equals(attendu));
}
/**
* Echec systématique de test
* (signaler que une série de test est insuffisante)
*/
public static void echec() {
assertTrue(false);
}
}
-19
View File
@@ -1,19 +0,0 @@
/*
* EchecTest.java 7 avr. 2021
* IUT info1 2020-2021, groupe 2, aucun droit d'auteur
*/
package outils.glg;
/**
* Exception lancée si un test unitaire échoue : comportement obtenu n'étant pas
* le comportement attendu
* @author info1 2020-2021
*/
public class EchecTest extends RuntimeException {
// constructeur par défaut généré par le compilateur
public EchecTest() {
super();
}
}
-86
View File
@@ -1,86 +0,0 @@
/*
* ExecuteurDeTest.java 13 avr. 2021
* IUT info1 2020-2021, groupe 2, aucun droit d'auteur
*/
package outils.glg;
import java.lang.reflect.Method;
/**
* Lanceur de test automatique ("test runner") qui exécute les méthodes de tests
* unitaires d'une classe de test telle que :
* <ul><li>La classe de test doit être instanciable avec des méthodes de tests
* unitaires qui sont des méthodes d'instance</li>
* <li>Les jeux d'essai mis en champ d'instance sont régénérés
* automatiquement à chaque instanciation de la classe de test
* = "fixture de test" (fix picture of test)</li>
* <li>Chaque méthode de test s'exécute dans sa propre instance donc avec
* la fixture remise dans son état initial</li>
* <li>Chaque méthode de test unitaire ne doit tester qu'une seule méthode
* de la classe à tester</li>
* <li>Chaque méthode de test unitaire s'arrête en cas d'échec
* de test (failure) ou de crash (error)</li>
* </ul>
*
* @author info1 2020-2021
*/
public class ExecuteurDeTest {
/** préfixe des méthodes de tests unitaires à lancer */
public final static String PREFIXE_TEST = "test";
/** Code erreur si la ligne de commande est mal formatée */
public static final int ERR_NB_ARGUMENT = 1;
/** Code erreur si la classe de test (argument) n'est pas trouvée */
public static final int ERR_CLASSE_INACCESSIBLE = 2;
/** Message d'aide à l'usage de l'outil */
private static final String MESSAGE_USAGE
= "usage : info1.outils.glg.ExecuteurDeTest nom.complet.de.classe.de.Test";
/**
* Lancement automatique des méthodes de test
* d'une classe de test passée en argument
* @param args nom java complet de la classe de test à exécuter
*/
public static void main(String[] args) {
/* Analyse de la ligne de commande */
if (args.length != 1) {
System.err.println("Nombre d'arguments incorrects");
System.err.println(MESSAGE_USAGE);
System.exit(ERR_NB_ARGUMENT);
}
Class<?> deTest = null;
try {
deTest = Class.forName(args[0]);
} catch (ClassNotFoundException e) {
System.err.println("Classe " + args[0] + " non accessible");
System.err.println(MESSAGE_USAGE);
System.exit(ERR_CLASSE_INACCESSIBLE);
}
/* Lancement des méthodes de tests unitaires */
Method[] aFiltrer = deTest.getDeclaredMethods();
for (Method aExecuter : aFiltrer) {
String nomMethode = aExecuter.getName();
if (nomMethode.startsWith(PREFIXE_TEST)) {
try {
aExecuter.invoke(deTest.getConstructor().newInstance());
/* test Ok */
System.out.println("Réussite de " + nomMethode);
} catch (Exception aAnalyser) {
if (aAnalyser.getCause() instanceof EchecTest) {
System.out.println("Echec de " + nomMethode);
} else {
System.err.println("Crash de " + nomMethode + " : "
+ aAnalyser.getCause().getMessage());
}
}
System.out.println("-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-");
}
}
}
}
@@ -1,25 +0,0 @@
/**
* InterpreteurException.java 7 mai 2021
* IUT Rodez info1 2020-2021, pas de copyright, aucun droit
*/
package interpreteurlir;
/**
* Exception levée lors d'une erreur dans l'interpreteur LIR.
* (Erreur de syntaxe, erreur de types)
* @author Nicolas Caminade
* @author Sylvan Courtiol
* @author Pierre Debas
* @author Heïa Dexter
* @author Lucas Vabre
*/
public class InterpreteurException extends RuntimeException {
/**
* Une exception de syntaxe expliquée par un message
* @param message explication succincte de cette exception
*/
public InterpreteurException(String message) {
super(message);
}
}
@@ -1,40 +0,0 @@
/**
* EssaiInterpreteurException.java 7 mai 2021
* IUT Rodez info1 2020-2021, pas de copyright, aucun droit
*/
package interpreteurlir.tests;
import interpreteurlir.InterpreteurException;
/**
* Essai des {@link InterpreteurException}
* @author Nicolas Caminade
* @author Sylvan Courtiol
* @author Pierre Debas
* @author Heïa Dexter
* @author Lucas Vabre
*/
public class EssaiInterpreteurException {
/**
* Lancement des essais.
* @param args non utilisé
*/
public static void main(String[] args) {
String[] messages = {
null,
"",
"la commande fin n'accepte pas d'arguments"
};
for (String msg : messages) {
System.out.print("Message de l'exception : ");
try {
throw new InterpreteurException(msg);
} catch (InterpreteurException lancee) {
System.out.println(lancee.getMessage());
}
}
}
}