2015-09-07 11:44:36 -06:00
|
|
|
// annotations/UseCaseTracker.java
|
2015-06-15 17:47:35 -07:00
|
|
|
import java.lang.reflect.*;
|
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
public class UseCaseTracker {
|
|
|
|
public static void
|
|
|
|
trackUseCases(List<Integer> useCases, Class<?> cl) {
|
|
|
|
for(Method m : cl.getDeclaredMethods()) {
|
|
|
|
UseCase uc = m.getAnnotation(UseCase.class);
|
|
|
|
if(uc != null) {
|
|
|
|
System.out.println("Found Use Case:" + uc.id() +
|
|
|
|
" " + uc.description());
|
|
|
|
useCases.remove(new Integer(uc.id()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for(int i : useCases) {
|
|
|
|
System.out.println("Warning: Missing use case-" + i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public static void main(String[] args) {
|
2015-11-03 12:00:44 -08:00
|
|
|
// <* Can't use Arrays.asList() for some reason *>
|
2015-06-15 17:47:35 -07:00
|
|
|
List<Integer> useCases = new ArrayList<>();
|
|
|
|
Collections.addAll(useCases, 47, 48, 49, 50);
|
|
|
|
trackUseCases(useCases, PasswordUtils.class);
|
|
|
|
}
|
2015-09-07 11:44:36 -06:00
|
|
|
}
|
|
|
|
/* Output:
|
2015-06-15 17:47:35 -07:00
|
|
|
Found Use Case:49 New passwords can't equal previously used
|
|
|
|
ones
|
|
|
|
Found Use Case:47 Passwords must contain at least one
|
|
|
|
numeric
|
|
|
|
Found Use Case:48 no description
|
|
|
|
Warning: Missing use case-50
|
2015-09-07 11:44:36 -06:00
|
|
|
*/
|