Skip to content

CMPE 451 Milestone 1 Report

Zeynep Baydemir edited this page Nov 3, 2023 · 37 revisions

CMPE 451 Milestone 1 Report (Group 5)

Contributors

Table of contents

1. Executive Summary

1.1 Summary of the Project Status

Up to the first milestone, we successfully implemented some of the required features for our game review platform. This includes all authentication features, game listing, filtering, and searching on the games page, as well as the game description page (except reviews and forums). We were also able to deploy our applications. In this way, we were able to complete the demo without any mock data. Additionally, we made significant improvements to the backend, particularly in the area of continuous integration and continuous deployment (CI/CD), although it's not fully functional at the moment. So, in general, we have reached the intended stage of development.

1.2 Changes That are Planned for Moving Forward

For the future, we have identified two changes in our plan. Firstly, we noticed that there were discrepancies in the appearance of our platform on the two different platforms (mobile and frontend) due to limited collaboration between the mobile and frontend teams for design. To solve this problem, we plan to increase the frequency of meetings between these teams to guarantee a consistent user interface between both platforms.

Secondly, based on feedback received during the demo, we believe that it is necessary to re-evaluate the planned avatar feature. We will conduct further discussions with our customers to meet their expectations and needs.

2. A summary of the customer feedback and reflections

Initially, we had negative customer feedback on our requirements. We learned that there has been some miscommunication on the importance of “Domain Specific” features. The meaning of that term, and how it applies to our project has been hard to grasp, so we had a long discussion with the product owners. After that discussion, we decided to research and brainstorm some ideas for domain specific features. We came up with a handful of ideas for features and compiled them in a wiki page. Following the research, we did a meeting with stakeholders to discuss those ideas. The meeting went great, and we decided on focusing on these new features while leaving some less important ones behind. Another important source of feedback was our milestone presentation. During the presentation, some issues with our initial release were discussed. One feedback was the inconsistent style and colors between the web ui and the mobile app. Moving forward, we will have better communication between the front-end teams so that this issue can be resolved. Another discussion topic was the “Avatars” function. While not implemented yet, this functionality seems important to the stakeholders and we will need to have a discussion on it.

5. Evaluation of Tools and Processes Used to Manage the Project

5.1 Evaluation of Tools

5.1.1 Discord

Discord is an instant messaging and digital distribution platform where users communicate with voice calls, video calls, and text messages.It has the ability to save chats. Since it is used in class-wide communication for CMPE 451 course, we decided to use to Discord as our main communication platform between group members.

In discord we have created different channels for different matters. We try to discuss each subject on the channel specifically provided for it. This helps us to not lose the thread of conversation. If this were not the case and all the matters were to be discussed at a single channel, the threads of communication would quickly get messed up and the communication will be inefficient if not impossible.

5.1.2 GitHub

GitHub is a version control system that is used to store the codebase and document base of the project. It is the platform that provides the public face of the project team. On our page on GitHub, interested parties can find information about what our project is about, who the members of the team are, requirements for the project, our meeting notes etc. It also has many features that enable us to manage our codebase. This features include collaboration features, issue creation and management feature, version control feauture.

Issue creation and management in particular is a great way to partition the problem of completing the project into many small issues of overcomeable size, and assigning these issues to particular people. To enhance the power of this feature we created labels that show the progress status, priority of completion, and type of the issue, and also the team that the issue is related to. We also assign a reviewer to each issue to check the quality of the work done by the assignee. Also each issue has a deadline, which allows us to plan ahead. The comment thread below the issues is a great place to conduct the communication relating to that issue.

Version control feature is founded upon the idea of branches. A branch is an ordered list of nodes, where each node represents the version of the project at a particular point of time. Branches and branch management allows the users of GitHub to create parallel histories of project and merging these histories or drawing back from a node on a history to a previous node. It also enables the users to concurrently work on and edit the project via creating different branches. We drew advantage from this functionality extensively.

5.1.3 Trello

Trello is a web-based, kanban-style, list-making application. .It is composed of boards where another board can be created for each new subject. We used Trello in out online meetings to take notes and also create the preparatory task distribution. We also used Trello as a storage tool, to record the previous task distributions.

5.2 Evaluation of Processes

5.2.1 Issues

We have extensively made use of issue feature of GitHub. It enables to explicitly and recordably assign a task to a certain person for a pre-determined amount of time. Comment facility below the issues enables issue related communication via giving it its own channel of communication. We did not just use this issue feature as it is provided by GitHub, but made certain improvements and tailorings to make it better meet our needs. First of all we created new labels to denote the priority level, current status, type of the issue, and the sub-team that the issue is related to. Also we created an issue template of our own to assign explicit reviewers and deadlines to issues created.

5.2.2. Team Meetings

Each week at lab time we have a fixed meeting with the team. During this meeting we discuss and record the progress we made on the project during this week, specifically we detect the completed tasks that were planned last week, tasks that were completed but was not pre-planned, and tasks that were planned to be completed but are not. During these meetings we make plans for the succeeding week, also take note the risks we may encounter during the following week. We write a lab report in this meeting and record our discussion results.

Other than this fixed meeting, we meet via the internet whenever there arises need. This meeting usually take place on Discord, as it enables us the share both our voices and screens. During this meetings, we discuss the current status of the project, sometimes distribute tasks among us, make decisions regarding to the project, and reach to a certain common understanding regarding to what needs to be done.

5.2.3 Teaching Assistant / Stakeholder Meetings

In our fixed meetings we also meet with our stakeholder (which is also our teaching assistant). During these meeting we discuss the current status of our project, also showcase the working part of out project if the stakeholder requests. Other than that, we ask questions to our stakeholder and try to understand what he expects from us, what he wants the finished product to look, or what the functionality of the product must be at certain stages of its development.

5.2.4 Version Control

Version control, also known as source control, is the practice of tracking and managing changes to software code. Version control systems are software tools that help software teams manage changes to source code over time. As development environments have accelerated, version control systems help software teams work faster and smarter. They are especially useful for DevOps teams since they help them to reduce development time and increase successful deployments.

Version control software keeps track of every modification to the code in a special kind of database. If a mistake is made, developers can turn back the clock and compare earlier versions of the code to help fix the mistake while minimizing disruption to all team members.

We have used this process of GitHub extensively. We have stored our code in GitHub and while merging different histories, or undoing a modification, used version control related tools supplied by GitHub.

6. Requirements Addressed In This Milestone

In Milestone 1, we have made significant progress in addressing several key requirements, primarily focusing on the authentication aspect outlined under sub-section 1.1.1 of the project requirements.

With the latest version of our platform that we’ve presented in the demo:

  • Users are able to register to the platform providing a unique username, email and a valid password. (req. 1.1.1.1.1)
  • Users are able to login to the platform providing their username and password. (1.1.1.2.1)
  • Users are able to logout. (1.1.1.3.1)
  • Users are able to change their passwords. (1.1.1.4.1)
  • Users are able to use forgot password getting through a verification process via providing their emails. (1.1.1.5.1) Also we’ve focused on another fundamental requirements under the sub-section 1.1.8 of the project requirements which is game. After we’ve managed to complete main functionalities in game for registered users and the guest users,
  • Users are able to filter games by their tags (1.1.8.1)
  • Users are able to search games by their name (1.1.8.2)
  • Users are able to access game specific info about the game like player type, genre, minimum system requirements. (1.1.8.4)

In addition to these functional requirements, we have also addressed security-related non-functional requirements:

  • The platform generates a JWT token for every user, and each endpoint verifies the authorization header of incoming requests to ensure authentication of valid users' requests. (2.2.2.2 & 2.2.2.3)

7. Individual Contributions

8. Deliverables

8.1 Requirements

8.2 Software design documents in UML

8.4 Weekly Reports and Additional Meeting Notes



💻 Meeting Notes

Cmpe 352
Cmpe 451

📝 Requirements


🪧 Diagrams


📬 Deliverables

Cmpe 352
Cmpe 451

🎇 General Contributions

Cmpe 352 Contributions

Milestone 1
Final Milestone

Cmpe 451 Contributions

Milestone 1
Milestone 2
Final Milestone

📕 Mock Up


🕵️ User Scenario



📝 RAM


📚 Research


📑 Templates


📱 Practice App

API Documentation for Practice App
Clone this wiki locally