• src/main/java — каталог для всех компонентов, квалификаторов, перехватчиков и класса Main;
• src/main/resources — пустой файл beans.xml, поэтому мы можем инициировать CDI без альтернатив и перехватчиков;
• src/test/java — каталог для интеграционных тестов BookServiceIT и альтернативы MockGenerator;
• src/test/resources — файл beans.xml, обеспечивающий работу альтернативы MockGenerator и перехватчика LoggingInterceptor;
• pom.xml — модель объекта проекта Maven (POM), описывающая проект и его зависимости.
Написание классов Book и BookService
Приложение CD-Bookstore использует класс BookService для создания книг (листинг 2.40). Java-объект Book (листинг 2.41) имеет название, описание и цену. Номер книги (ISBN или ISSN) генерируется внешним сервисом.
@Loggable
public class BookService {
··@Inject @ThirteenDigits
··private NumberGenerator numberGenerator;
··public Book createBook(String title, Float price, String description) {
····Book book = new Book(title, price, description);
····book.setNumber(numberGenerator.generateNumber());
····return book;
··}
}
BookService располагает одним методом, который берет название, цену и описание и возвращает POJO Book. Чтобы задать ISBN-номер книги, этот класс использует внедрение (@Inject) и квалификаторы (@ThirteenDigits) для вызова метода generateNumber, принадлежащего IsbnGenerator.
public class Book {
··private String title;
··private Float price;
··private String description;
··private String number;
··//Конструкторы, геттеры, сеттеры
}
В листинге 2.40 BookService аннотирован связкой с перехватчиком @Loggable (листинг 2.50). Когда эта связка действует, она регистрирует момент входа в метод и выхода из него.
Написание классов NumberGenerator
Класс BookService в листинге 2.40 зависит от интерфейса NumberGenerator (листинг 2.42). Этот интерфейс обладает методом, который генерирует и возвращает номер книги. Интерфейс реализуется классами IsbnGenerator, IssnGenerator и MockGenerator.
public interface NumberGenerator {
··String generateNumber();
}
Класс IsbnGenerator (листинг 2.43) сопровождается квалификатором @ThirteenDigits. Это сообщает CDI о том, что сгенерированный номер состоит из 13 цифр. Заметьте, что класс IsbnGenerator также использует внедрение для получения java.util.logging.Logger (произведенного в листинге 2.48) и связывание с перехватчиком @Loggable для регистрации момента входа в метод и выхода из него.
@ThirteenDigits
public class IsbnGenerator implements NumberGenerator {
··@Inject
··private Logger logger;
··@Loggable
··public String generateNumber() {
····String isbn = "13-84356-" + Math.abs(new Random(). nextInt());
····logger.info("Сгенерирован ISBN: " + isbn);
····return isbn;
··}
}
Класс IssnGenerator в листинге 2.44 — это восьмизначная реализация NumberGenerator.
@EightDigits
public class IssnGenerator implements NumberGenerator{
··@Inject
··private Logger logger;
··@Loggable
··public String generateNumber() {
····String issn = "8-" + Math.abs(new Random(). nextInt());
····logger.info("Сгенерирован ISBN: " + issn);
····return issn;
··}
}
Класс MockGenerator в листинге 2.45 является альтернативой IsbnGenerator (поскольку также сопровождается квалификатором @ThirteenDigits). MockGenerator используется только для интеграционных тестов, так как его можно активизировать только в файле beans.xml тестовой среды (см. листинг 2.55).