| CompSci 308 Spring 2025 |
Advanced Software Design and Implementation |
In this lab, you will practice planning the project's scope and priorities, explore flexibility in games, and develop a Team Contract.
In your OOGASalad teams, complete the following steps:
doc/SCOPE_PLANNING.md using Gitlab's Markdown formatdoc/DESIGN_EXERCISE.md using Gitlab's Markdown formatFor shared Markdown editing, you can work directly within IntelliJ using the Code With Me feature or it can be enabled directly within Google Docs.
The result of this lab will be a set of documents that captures the important points of your team's several directed discussions.
In sub-groups complete this smaller exercise that asks you to try to think about the design of a very flexible game without worrying about exactly how it will be implemented. In other words, without writing any actual implementation code, try to explore trade-offs between several designs and describe the best one in enough detail that you can get a handle on how the different rules and goals could be defined using data files.
Now that you have some experience with teams in this course, create your own Team Contract for this project. This document serves as an agreement between all teammates on a set of conventions to abide by. When making your contract, consider the following resources:
It should be created collaboratively by thinking about good or bad aspects of team project experiences you have already had, your goals for the course, how the team should communicate, the quality of work everyone wishes to achieve, and the level of group participation and individual accountability everyone feels comfortable with. The process of generating a team contract usually helps jump start a group's efforts to become a team by immediately focusing everyone on a definite task that requires communication and negotiation.
Use the questions in this worksheet to guide your discussion. Make sure to address at least these topics:
Before Moving On: Complete the file doc/TEAM_CONTRACT.md, then add, commit the file, and push it to your shared oogasalad_teamNN repository.
Like most complex software, this very large can be broken down into a set of somewhat self-contained components that are potentially usable on their own but need to work together flexibly to solve the total problem. Keep in mind when your team creates a schedule for the work to be done on various components that some components are more fundamental than others and some can simply be placeholders or have simplified implementations until they need to be fleshed out. Some components will represent the Model, while others will represent the View and/or Controller.
Within each Sprint, you may choose to start some components, make progress on others, and/or finalize the implementation of yet other components. No matter how you choose to distribute the work to be done among the sprints, there should always be something demonstrably improved over the last sprint, and the code at the end of the sprint should always run (i.e., without crashing). In industry, Sprints often end with a demo to stakeholders, and progress is measured by how many features (i.e., things a customer would see as a reason for buying your product) were completed in the Sprint, rather than how much of the data structure was set up.
Try to spend some time now clarifying the order in which the project's features will be completed and who will be taking the lead on each feature.
Discuss your plan by prioritizing the components each team member plans to take primary and secondary responsibility for and a high-level plan of how the team will spend its time to complete the program. Specifically, each person should take responsibility for specific features and use cases they intend to work on during each Sprint. This requires the team to agree on the feature priorities and set a goals for each week's work.
At the end of lab, you should have pushed your team's Markdown files to the doc folder of your provided, shared, oogasalad_teamNN repository to submit your notes about your teams' discussions:
Make sure the text of your final commit message is of the form "lab_oogasalad_design - NetIDs".