- Requirement Brief
- Goals and Non-Goals
- Project Plan and Task Assignment
- Use Cases and Features
- Test Plan
- UML Diagrams
For this project you are required to use inheritance to develop a simple web based, Java Object Orientated, Point of Sale application which allows the user to enter credit card details and a cash amount for a transaction.
When your program runs it should have a simple menu system that allows an administrator to configure the Point of Sale device. The menu should also have the option to use the Point of Sale device which will open the device interface for the user to input their information in order to make the transaction.
The Point of Sale should allow an admin to log in and configure the Point of Sale identity data, which the transactions require to successfully transfer funds to or from the correct account.
The Point of Sale Device should first present the user with a choice about what type of transaction they would like to make, either a payment or a refund option should be available. The user should then be asked to enter their credit card information at which point the account details for the account the user is making a transaction with should be retrieved.
The application should communicate using a ReST interface to a mock banking service supplied. The service will confirm or deny the transaction. A transaction will be unsuccessful if the credit card number is entered incorrectly, in which case the user should be prompted to enter their card details correctly.
Once a transaction has been completed the user account should be updated with the new balance of the account.
The device should record all successful and unsuccessful transactions locally in a log file, cvv codes must not be recorded.
The full assessment brief can be viewed here.
- The UI will be a user-friendly web interface.
- The identity of the device will be enterable by an administrator.
- The device will record all successful and unsuccessful transactions.
- Users will be able to enter their credit card details (name, credit card number, expiry date, cvv code).
- Users will be able to make a payment.
- Users will be able to make a refund.
- The application will interact with the bank service using a ReST service.
- Money will be transferred between accounts correctly.
- Data input validation will be implemented throughout.
- Authentication will be implemented on the administrator account.
- Authentication will be implemented on transaction request.
- All error messages will be user-friendly and informative.
- CVV codes will not be recorded.
- The PoS device will not validate the CVV code.
The team decided to use the ICONIX Process to detail and map out the application, as it allowed them to move from use cases to coding the application quickly and reliably. As this is only a small project, proper agile methodologies have not been implemented. However, if in the future the application were to be developed into a large scale program, the use of agile would be effective in ensuring fast and reliable development.
It is important to note that the ICONIX process does not completely follow agile methodology. Contrasting Agile, the philosophy behind ICONIX is that UML diagrams are vital in keeping the code structured correctly and therefore as close to the customer requirements as possible.
A key principle of agile methodology is improving collaboration and communication within the team, something that the development team for this project upheld throughout, with daily meetings for expressing any potential concerns and to discuss about what had and what needed to be done to complete the task.
In the ICONIX process, it is important that the requirements are correct from the beginning. This was achieved by creating and analysing UML diagrams as recorded later in this document. The analysis of the UML created a robust definition of the application requirements by removing all ambiguity. To sustain the integrity of the application design, the code and UML diagrams were compared and analysed throughout the development process, keeping the code as accurate as possible to the requirements.
Once the UML diagrams were initially drafted, the project was broken down into smaller, manageable tasks that only addressed one requirement at a time and recorded on GitHub Projects. These were divided up into three To Do categories - front-end, back-end, and documentation. Tasks were originally recorded as notes within the project, and were updated to include the relevant name of the person doing the task when it was moved to In Progress. However, GitHub Issues were later used for all outstanding tasks.
Screenshot of GitHub Project in progress
The team then decided to use Spring MVC for the project structure, as this separated back-end code from the front-end, making it easier to read and maintain and also future-proofing the application. It also meant that work could be done on the UI and on the MVC Controller simultaneously, with less concern of merge conflicts.
All the following tasks are also available on GitHub Projects:
Owner | Task | Description |
---|---|---|
Merlin | Created use case UML diagram. | |
Jake / Jo | Jake initially created a new project in NetBeans. This was then replaced by Jo to use a class exercise with all the client packages included. | |
Jo | All imported client packages needed to refactored to the team name. | |
Jo | A standalone bank client module became available so project was started again without multi-modules. | |
Merlin | Created robustness UML diagram. | |
Tom | Designed and implemented a user-friendly UI that resembles a real PoS device, using JavaScript and CSS where appropriate. | |
Jo | Designed and implemented a basic administrator page that allows entry of the identity for the PoS device. | |
Jo | Implemented a basic index page which allows easy access to both admin and PoS pages. | |
Jo | Created default.properties file with valid data so the PoS would not need configuring every time it was tested. | |
Jo | Created the MVC Controller class. | |
Tom / Jo | Basic functionality implemented with GET requests to access all JSP pages. | |
Jo | Implemented functionality of the admin page, with data retrieved and updated in the .properties file. Also implemented functionality for transactions, reading in PoS identity data and input data to make a ReST call to the bank service. | |
Jo | Implemented workflow through GitHub actions so all code is tested as soon as pushed to repo. | |
Tom | Ensured all error messages are user-friendly and informative. | |
Tom | Updated formatting on PoS to be more user-friendly and readable. | |
Jo / Jake | Jo updated Log4J to include transaction logs. However, this would not work so Jake created a bespoke logging class with corresponding unit test. | |
Jo | Updated MVC Controller to perform the Luhn Algorithm on inputted credit card numbers within both Admin and PoS pages and ensured only credit card numbers that passed would be accepted. | |
Jo | Created use cases and included them within the design documentation. | |
Jo | Created test cases and included them within the design documentation. | |
Tom | Updated Admin page to use JavaScript to validate form input. | |
Jo | Created all documentation required for project, including use and test cases. | |
Merlin | Created sequence diagram. | |
Tom | Created error JSP for in case exception is thrown. | |
Jake | Implemented authentication on admin page, utilising the Password class to encrypt the password. | |
Jake | Created all javadocs within code. | |
Jake / Tom | Ensured exception handling used throughout. | |
Merlin | Created class UML diagrams. | |
Tom | Implemented unit tests. | |
Merlin | Added explanation of all UML diagrams to design documentation. | |
Merlin | Added key to UML diagrams. |
NOTE:
An index page has been included for ease of the assessor for this assessment only. In a real-life situation, the user would only have access to the PoS device itself.
The following uses cases describe how users will use the application and outlines the system behaviour in response.
ID | Actor | Action | System Behaviour |
---|---|---|---|
UC1 | Admin | Admin enters the correct password and username. | The admin page is opened. |
UC2 | Admin | Admin enters the incorrect password and username, or leaves a field blank. | An error message is displayed and access to the admin page is denied. |
UC3 | Admin | Admin configures the PoS device. | The identity of the device is updated locally. |
UC4 | Admin | Admin configures the PoS device but misses a field. | An error message is displayed and the identity of the device is not updated. |
UC5 | Admin | Admin enters an incorrect credit card number. | The credit card number fails the Luhn check, an error message is displayed and the identity of the device is not updated. |
UC6 | User | User enters option that is neither payment or refund. | The device displays an error message and they are prompted to input again. |
UC7 | User | User enters option for a payment. | The device prompts them to enter their credit card details. |
UC8 | User | User enters option for a refund. | The device prompts them to enter their credit card details. |
UC9 | User | User enters incorrectly formatted card data. | The device displays an error message, and prompts them to input again. |
UC10 | User | User enters incorrect card number. | The application checks validity of the card number using the Luhn check, and displays an error message |
UC11 | User | User enters no card data. | The device displays an error message and they are prompted to input again. |
UC12 | User | User confirms transaction. | The device displays an "Approved" message and the transaction is completed. The application transfers money between accounts and logs the transaction to the local log file (excluding cvv code). |
UC13 | User | User does not have sufficient balance in account to complete transaction. | The device displays a "Declined" message and the transaction is aborted. The application logs the transaction to the local log file (excluding cvv code and with the amount as null). |
UC14 | User | User cancels a transaction before it is completed. | The device returns to main menu. No monies are transferred and nothing is logged. |
UC15 | User | User enters an incorrect path in the URL. | An error page is displayed and they are prompted to return to the home page. |
Test Case ID | Use Case ID | Preconditions | Test Steps | Expected Post Conditions to Pass |
---|---|---|---|---|
TC1 | UC1 | Tomcat server is running and Tester is on index page. | All steps as per TC1 except: 1. "admin" is entered in the username field. 2. "admin" is entered in the password field. 3. Login as Admin button is clicked. |
Admin page is opened. |
TC2 | UC2 | Tomcat server is running and Tester is on index page. | All steps as per TC1 except: 1. "test" is entered in the username field. 2. Nothing is entered in the password field. 3. Login as Admin button is clicked. |
"Invalid username or password" error message is displayed and admin page is not opened. |
TC3 | UC3 | Tomcat server is running and Tester is on admin page. | 1. "http://com528bank.ukwest.cloudapp.azure.com:8080/rest" is entered into Bank URL field. 2. "admin" is entered into Admin Username field. 3. "admin" is entered into Admin Password field. 4."test" is entered into Name on Credit Card field. 5."11/21" is entered into Credit Card End Date field. 6."4285860000000021" is entered into Credit Card Number field. 7."123" is entered into CVV Number field. 8. "01" is entered into Issue Number field. 10. "admin" is entered into username. 11. "admin" is entered into password. 12. Submit Configuration button is clicked. |
Page displays "PoS now configured" message. Local application.properties file updated to match inputted data. |
TC4 | UC4 | Tomcat server is running and Tester is on admin page. | All steps as per TC1 except: 1. Any required field is left empty. |
Page displays "Please fill all required fields" message. Local application.properties file is not updated. |
TC5 | UC5 | Tomcat server is running and Tester is on admin page. | All steps as per TC1 except: 5. "1234567891234567" is entered into Credit Card Number field. |
Credit card number fails Luhn check within MVC Controller. Page displays "Invalid credit card number" message. Local application.properties file is not updated. |
TC6 | UC6 | Tomcat server is running. Tester is on PoS page and the PoS displays reads "Please select an option: 1) Payment 2) Refund" |
1. "8" is entered. 2. Accept button is clicked. |
"Not a valid entry" is displayed at the top of the screen and the user is prompted to input again. |
TC7 | UC7 | Tomcat server is running. Tester is on PoS page and the PoS displays reads "Please select an option: 1) Payment 2) Refund" |
1. "1" is entered. 2. Accept button is clicked. |
The display of the PoS changes to "Please enter amount:" |
TC8 | UC8 | Tomcat server is running. Tester is on PoS page and the PoS displays reads "Please select an option: 1) Payment 2) Refund" |
1. "2" is entered. 2. Accept button is clicked. |
The display of the PoS changes to "Please enter amount:" |
TC9.1 | UC9 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. "/" or "." is inputted for amount. 2. Accept button is clicked. |
"Please enter a number" is displayed at the top of the screen. |
TC9.2 | UC9 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. "10.00" is inputted for amount. 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "1234" is inputted for credit card number. 6. Accept button is clicked. |
"Card numbers must be 16 digits" is displayed at the top of the screen and the user is prompted to input again. |
TC9.3 | UC9 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. "10.00" is inputted for amount. 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "5133880000000012" is inputted for card number. 6. Accept button is clicked. 7. "1" is inputted for expiry date. 8. Accept button is clicked. |
"Date must be formatted as MM/YY" is displayed at the top of the screen and the user is prompted to input again. |
TC9.4 | UC9 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. "10.00" is inputted for amount. 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "5133880000000012" is inputted for card number. 6. Accept button is clicked. 7. "11/21" is inputted for expiry date. 8. Accept button is clicked. 9. "1" is inputted for cvv. 10. Accept button is clicked. |
"CVV should be 3 or 4 digits" is displayed at the top of the screen and the user is prompted to input again. |
TC9.5 | UC9 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. "10.00" is inputted for amount. 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "5133880000000012" is inputted for card number. 6. Accept button is clicked. 7. "11/21" is inputted for expiry date. 8. Accept button is clicked. 9. "123" is inputted for cvv. 10. Accept button is clicked. 11. "1234" is inputted for issue number. 12. Accept button is clicked. |
"Issue Number should be 0-2 digits" is displayed at the top of the screen and the user is prompted to input again. |
TC10 | UC10 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" Amount = "10.00" Name = "Bob" |
1. "1234567891234567" is inputted for card number. 2. Accept button is clicked. 3. "11/24" is inputted for expiry date. 5. Accept button is clicked. 6. "123" is inputted for CVV. 7. Accept button is clicked. 8. Issue number is left black. 9. Accept button is clicked. 10. Accept button is clicked to confirm the transaction. |
"1234567891234567 is an invalid card number" is displayed at the top of the screen and the transaction is aborted. The log file is not updated. |
TC11 | UC11 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "1" |
1. Nothing is inputted for amount. 2. Accept button is clicked. |
"Required" is displayed at the top of the screen. |
TC12 | UC12 | Tomcat server is running. Device identity card number is "4285860000000021". Tester is on PoS page and has inputted: Option = "1" |
1. "10.00" is inputted for amount 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "5133880000000012" is inputted for card number. 6. Accept button is clicked. 7. "11/21" is inputted for expiry date. 8. Accept button is clicked. 9. "01" is inputted for issue number. 10. Accept button is clicked. 11. Accept button is clicked to complete transaction. |
"Approved" is displayed at the top of the screen. £10.00 is transfered from card 5133880000000012 to card 4285860000000021, which can be seen here. Transaction log records transaction excluding cvv code. |
TC13 | UC13 | Tomcat server is running. Device identity card number is "4285860000000021". Tester is on PoS page and has inputted: Option = "2" |
1. "500.00" is inputted for amount 2. Accept button is clicked. 3. "bob" is inputted for name. 4. Accept button is clicked. 5. "5133880000000012" is inputted for card number. 6. Accept button is clicked. 7. "11/21" is inputted for expiry date. 8. Accept button is clicked. 9. "01" is inputted for issue number. 10. Accept button is clicked. 11. Accept button is clicked to complete transaction. |
"Declined. Insufficient balance in account 428586 000000002" is displayed at the top of the screen. No monies have been transferred. Transaction log records transaction with amount="null" and excluding cvv code. |
TC14 | UC14 | Tomcat server is running. Tester is on PoS page and has inputted: Option = "2" |
1. Cancel button is clicked. | The device returns to the front screen. |
TC15 | UC15 | Tomcat server is running. | 1. "http://localhost:8080/Com528-Assessment/badpage" is entered into URL. | Error page displayed with link to the home page. |
The projects class diagrams were created using easyUML. More information can be found here
Client Class UML Diagram
This diagram shows the implementation and supporting classes provided by the client module, supplied by Craig Gallen.
Web Class UML Diagram
This diagram shows the implementation classes and the supporting classes provided by the web container.
Use cases are actions that perform tasks, and therefore functions of the app.
The use case diagram outlines the objects, such as people, systems and organisations, required for the application to function properly along with their relationships.
Realtionships are split into categories:
- Association Relationships - shown with lines. These are specified in the key of the diagram below.
- <<include>> - base use case requires included use case in order to complete the task.
- <<extend>> - base use case can require extension use cases to complete the task, however extensions are not always necessary for task completion.
- Generalisation - a parent use case has children. The parent is essentially a generalisation of the child use cases.
The robustness diagram is a more detailed representation of how objects of the application interact. Actors use Boundary Objects to communicate with the system and Control Objects facilitate communication between the Boundary Objects and the Entity Objects. The arrows represent the flow of relationships between each component.
The sequence Diagram provides a clear view of the sequence of events throughout the application.