Booktique is a system that implements an online book store.
In particular, the application involves querying books according to the ISBN, title and author fields. A customer is also able to order books and can manage and review his purchases.
The source code is available on GitLab at https://gitlab.com/GiorgiaAuroraAdorni/3rdAssignment/.
This project has been developed by Giorgia Adorni (806787).
$ git clone https://gitlab.com/GiorgiaAuroraAdorni/3rdAssignment.git
$ cd booktique
$ docker-compose up
An alternative to docker-compose up
is the command docker-compose up --build
that allows the rebuild of the app.
The database is available at http://localhost:5432/, (you can find the necessary credentials to access pgAdmin and interact with the model in the docker-compose.yml
).
Docker Compose also allows to run the unit tests locally:
$ docker-compose run app mvn test
It is also possible to generate the API Reference using Javadoc:
$ mvn javadoc:javadoc
$ mvn javadoc:test-javadoc
The application is composed of two main components:
- app: the Java application, developed using the Spring Boot framework, that provides many convenient features such as the built-in dependency resolver, and the ORM Hibernate.
- database: a PostgreSQL instance responsible for persistently storing the user's data.
Docker is used to containerize the two components, allowing to simplify the setup process of the development environment, creating images that contain all the dependencies needed.
Docker Compose produces three images: the DB, pgAdmin and the application.
The model is composed of 10 entities:
- book - items available in the online store. The book object provides a set of information such as the title, ISBN, authors, publisher, format etc. A unique id is used as the primary key. Despite this, the ISBN is a Natural Id.
- person - an individual. The Person object provides personal information such as name, surname, fiscal code, date of birth, email and telephone number. A unique id is used as a primary key. In addition, the fiscal code is marked as a natural identifier as it identifies a person in the real world.
- author - the author of a book. Because an author is also a person, the object inherits the same attributes of the person superclass. More information about the author is provided, for example, an optional biography and a web site URL.
- customer – people who buy books in the online store. Every customer has a basic set of data inherited from the person superclass, as for the authors. Mandatory attributes, such as login credentials and postal address, are added to customers. Can be also provided a VAT number.
- employee – is a person who carries out activities related to fulfilling orders. An employee has the same properties of its parent class Person, in addition, it is associated with another employee as a supervisor. More information about the employee is stored, such as the login credentials, the hire date and his postal address.
- supplier - an organization that supplies books to the online store. To the supplier object are associated a unique id as primary key, the company name and other information, such as email, telephone number and postal address.
- address - postal information about customers and suppliers. In this object are stored the street address, the postal code, the city, region and country name.
- item – articles selected by the customer for purchase in the online store. To each item is assigned a reference to the book in the catalogue that the customer wants to buy, its unit price, the desired quantity and its supplier.
- purchase - items ordered. To every purchase is associated a hypothetically unlimited number of items, the customer, the employee who takes charge of the order, order and shipping dates, the total amount, order status and the transaction information (payment type and date).
- payment - the transaction information associated to all purchases. Every payment details provide information about the cardholder, the card used and the date of the payment.
Between these entities there are 15 relations, in particular:
- two self-relations:
- the first one is a One-to-One bidirectional relation between a book and his prequel, in one direction and between the book and his sequel in the other;
- the second is a Many-to-One relation between employees and supervisors (each employee is associated with only one supervisor).
- one Many-to-Many relation between books and authors, handled with lazy loading.
- one inheritance hierarchy that involves 4 entities: the person class serves as a superclass for the employee, author and customer subclasses.
All entities also inherit from an Auditable abstract class that provides the createdDate
and modifiedDate
attributes using JPA Auditing. This allows to tracking changes to the entities made from the Java application.
The application consists of two parts:
-
booktique/src/main
contains the source code files of the application:-
BooktiqueApplication is the class that serves as the entry point of the app.
-
model
contains the models used by the application. The domain models are the java classes that are mapped to the corresponding tables in the database. Every model is decorated with JPA annotations in order to perform operations on the relational database. -
repository
contains repository interfaces for all models, excluding abstract classes. Spring Data JPA automatically create an implementation from the repository interface. Extending JpaRepository, every repository inherits several methods for working by entity persistence, including methods that implement CRUD operations such as save and delete, but also search operations.
Spring Data JPA also allows to define other custom query methods by simply declaring their method signature. For all models, customizedfindBy{...}()
methods have been implemented, such as thefindByAuthors_Name()
method in the case of BookRepository. -
utility
contains useful classes and interface for operating on associations and entities:- Associations a class containing a static method that returns
true
if two associations are equal to each other. - EntityEqualsByAttributes an interface that compares two instances and returns
true
if the entities are equal to each other. - EntityToDict an interface the trasforms an entity to a dictionary.
- Associations a class containing a static method that returns
-
-
booktique/src/test
contains the JUnit tests that exercise all the functionalities of the Java application. The package has the same structure as the source code directory:- BooktiqueApplicationTest is the test class that verifies the correct start of the application.
model
contains a EntityFactory interface used by the test suite to create instances. In particular, it implements thecreateValidEntity()
method that creates a default instance, and thecreateValidEntities()
method that creates a list of valid instances.
For each domain class, there’s a class that implements the EntityFactory methods. In order to respect the unique constraints in case of the creation of multiple instances, an index is used as param for the methods.repository
contains tests on repositories and on the associated models. In particular, for every model are defined:- tests on the proper behaviour of the CRUD operations implemented by the repository, like inserting, updating, deleting and reading the data;
- tests on the proper functioning of the search operations implemented by the repository and the customized ones;
- tests on the associations between the various models, in particular on cascade the policies;
- tests that throw exceptions in case you try to insert data that violates the domain rules.
utility
contains the definition of two useful assertions:- assertAssociationEquals that asserts that the expected set of entities and the actual ones are equal. This assertion is used in the test suite to compare associations;
- assertAttributesEquals that asserts that expected attributes of an entity and the actual one are equal.