联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2019-10-28 10:41

Final Project ~ Fall 2019

Introduction

Your final project will be your focus for the majority of the semester. You will be working with a

team on your own project, developing it over three iterations, each of which will produce an

executable release.

Team formation

You will form your own teams. I strongly recommend that you form teams primarily based

around the times you are available, and secondarily around shared interests. We will form

teams as shown in the course calendar. However, you are welcome to begin discussing the final

project at any time.

Pitch

Each team will give a project pitch to the class as shown on the course calendar. It is recommended

that you review the pitch requirements with the instructor prior to your pitch. The presentation

may be at most five minutes long. Slides are optional, and handouts are encouraged. The

pitch must satisfy the following requirements.

• Share a project summary—one or two sentences that succinctly and accurately describe

the endeavor. Note: Non-trivial games are strongly discouraged due to the fact that they

are deceptively difficult.

• Identify the target audience for the proposed project and the need that it addresses.

Depending on your application, you might need to consider factors such as age, gender,

education level, interests/hobbies, native language, and access to technology. This

identification must be specific enough to allow you to test your project with representatives

from the target audience. For example, “students” is too broad as it includes an enormous

variety of ages and cultures. “Non-traditional students at Ball State University” is a more

reasonable target, since you can unambiguously identify individuals for focus group

discussion or acceptance testing.

• Briefly describe one to three key features of your proposed project.

• State the technology you propose to use to complete this project. Java and IntelliJ IDEA

are strongly recommended but not required; using the object-oriented paradigm and

GitHub are required.

• State the platform on which you will release your product. Desktop applications on the

Java platform are strongly recommended but not required. Attempting to support multiple

platforms is strongly discouraged.

• If the project has a user-interface, provide a sketch or mock-up of it. If not, provide

examples of the use case for your project, such as sample API calls for a library or Web

service.

Pitches will be evaluated using the following rubric.

Requirement Satisfactory (3) Probationary (2) Unsatisfactory (1) Unaddressed (0)

Summary statement

Target audience & need

Key features

Development &

deployment platforms

UI sketch or use case

A team must repeat their pitch if they earn 0 or 1 point in any category or if total points is less than

12. Revised pitches will be scheduled for the next possible class meeting.

Schedule

The project is divided into three iterations, each of which will be a few weeks long, as shown on

the course calendar. During each iteration you will create an increment of your project. Increments

are due before the beginning of class on the day that ends an iteration. See the course schedule for

these specific dates. You will submit these iterations via instructions provided in Canvas.

Project requirements

Technical requirements

• Each project is to be developed by a team of three or four students from the course section,

using an object-oriented approach and following the conventions for your chosen language.

• Your software architecture must separate model from view, as well as the persistence layer

if you have one. This should be done using a domain model—an object-oriented

representation of the concepts and relationships manifest in your problem domain.

• You must follow the principles of Clean Code, including structural principles (such as OOP

and SRP) and process principles (such as TDD and the Boy Scout Rule), although strictly

view-level code does not require automated tests.

• All project dependencies that are not part of the development platform must be either

tracked in the version control system (such as in a lib folder) or automatically resolved

using a dependency management system such as Maven or Gradle.

• All projects will be hosted within the class' organization on GitHub. Each will have a

README.md file in the root of the repository that lists the team members and any special

build or execution instructions.

• Your production code should be in the default repository branch, which is called master.

• Each iteration should produce an executable release, also known as a potentially-shippable

product. That is, your increment should be a usable, stable software system that implements

a subset of your product backlog. The three releases will be tagged using semantic

versioning as 0.1.0, 0.2.0, and 0.3.0, respectively.

• Representatives of the target demographic (who are not also on the project team) must test

each increment. This practice constitutes acceptance testing, and it is done by giving testers

specific tasks to accomplish using your system and observing their interaction with your

system. The tasks should come from your user stories.

Presentation requirements

Iteration review presentations will occur during the class periods at the end of an iteration. Each

review may be no more than ten minutes long and must address the following.

• Demonstrate the executable release.

• Describe the user stories that were completed and any changes that have been made to the

product backlog.

• If this is not the final iteration presentation, indicate which user stories will be

accomplished during the upcoming iteration.

• Describe a critical component of your system that was developed during the previous

iteration. This is an opportunity to share something interesting with your classmates outside

your team. You are expected to show and describe the implementation of this component.

• Summarize the results of acceptance testing.

Individual reflection essay requirements

At the end of each iteration, each team member will write a 300 to 600-word reflective essay on

the previous weeks covering this iteration. This essay should draw upon experiences from the

past iteration to directly and explicitly address one of the course's essential questions. You will

submit these essays confidentially in Canvas; they are not shared within the community, unlike

many of our other artifacts this semester.

Formal Evaluation

You will receive a grade for each of the three iterations of this project. Your grade for a given

iteration is the minimum of two iteration component grades: project, presentation, and individual

reflection essay grade and contribution grade. These two iteration component grades are

described below.

Project, presentation, and individual reflection essay grade

The evaluation for the project, presentation, and individual reflection essay takes place at two

levels of granularity. Your grade is the minimum of Step 1 and Step 2 as described below.

Step 1

The overall project system configuration is evaluated, along with your team’s presentation and

your individual reflection essay, in order to determine a maximum grade, using the following

specifications.

Maximum

Grade Project system configuration criteria

A

Project can be built without warnings or errors, and the rationale for any

suppressed warnings is clearly documented in the source code or README file.

Needed build instructions are provided in a README file. Contains unit tests for

all testable code of the model level.

B

Project contains compiler warnings, suppressed warnings are undocumented or

unjustified, or needed build instructions are not provided in a README file.

Contains unit tests for most testable code of the model level.

C Project can be built. Contains failing unit tests or few unit tests of the model level.

D

Project crashes during routine execution or contains no unit tests of the model

level.

Individual reflection essays will be evaluated holistically according to how clearly you connect

your experiences to the course's essential questions, and the quality of your writing, as described

above.

Presentation quality considers the quality of the presentation itself, based on evidence of having

met the criteria as described above for the following items:

• demonstration of project

• completed user stories

• product backlog

• critical component description

• acceptance testing results

Your maximum grade will be reduced by one letter grade if any of the following are true.

• You do not submit an individual reflection essay in a timely manner

• Your team satisfactorily completes three or fewer of the presentation items

• You submit an unsatisfactory individual reflection essay and your team satisfactorily

completes four or fewer of the presentation items

Step 2

The project source code will be evaluated following criteria from Robert C. Martin's Clean

Code. Keep in mind that Chapter 17 provides a valuable checklist. I also strongly encourage you

to use the Project Checklist provided in Canvas. The individual criteria for source code evaluation

(and their corresponding chapters in Clean Code) are:

• Meaningful Names (Ch. 2)

• Functions (Ch. 3)

• Comments (Ch. 4)

• Formatting (Ch. 5)

• Error Handling (Ch. 7)

• Unit Tests (Ch. 9)

• Classes (Ch. 10)

While I believe the big ideas of Clean Code and Test-Driven Development are holistic and

should be considered together, I also believe a finer granularity is appropriate when evaluation is

resulting in a grade. As such, I have itemized pieces below in the grade specifications.

If your submission includes or does all the following, you will receive a D or better for the

project source code grade. If all the specifications listed for a D are not met, you will receive

an F.

1. Submission will compile, run, and accurately satisfy more conditions of satisfaction of

the user stories than the previous iteration.

2. At least three of the following Clean Code/Test-Driven Development criteria (as

described above) are fully met:

a. Meaningful Names

b. Functions

c. Comments

d. Formatting

e. Error Handling

f. Unit Tests

g. Classes

3. At least three of the following technical requirements (as described above) are fully met:

a. Software architecture separates model from view

b. Project dependencies are tracked or automatically resolved

c. Project is hosted within the course’s organization on GitHub

d. README.md file with appropriate content exists

e. Production code is in the master repository branch

f. Release tagged as 0.1.0, 0.2.0, or 0.3.0, as appropriate

4. At least two commits were made since the last iteration, and the commits were pushed to

the course’s organization on GitHub.

If your submission includes or does all the following, you will receive a C or better for the

project source code grade.

5. All items listed above for a grade of D.

6. Submission will accurately satisfy at least one more user story than the previous iteration.

Additionally, a User Story document exists (in the team’s project folder in the course

Google drive) which documents User Story Names (USN) and their related Conditions of

Satisfaction (CoS). The status of each USN and COS should be indicated in some fashion,

e.g. with a completion date, or release number.

7. At least four of the Clean Code/Test-Driven Development criteria listed for a grade of D

are fully met.

8. At least four of the technical requirements listed for a grade of D are fully met.

If your submission includes or does all the following, you will receive a B or better for the

project source code grade.

9. All items listed above for a grade of C.

10. A few commits were made by many developers since the last iteration, and the commits

were pushed to the course’s organization on GitHub in a timely manner.

11. At least five of the Clean Code/Test-Driven Development criteria listed for a grade of D

are fully met.

12. At least five of the technical requirements listed for a grade of D are fully met.

If your submission includes or does all the following, you will receive an A for the project

source code grade.

13. All items listed above for a grade of B.

14. Many commits were made by the majority of developers since the last iteration, and the

commits were pushed to the course’s organization on GitHub in a timely manner.

15. Submission will accurately satisfy at least two more user stories than the previous

iteration.

16. At least six of the Clean Code/Test-Driven Development criteria listed for a grade of D

are fully met.

Contribution grade

Within twelve hours of your group’s presentation, you must conduct a rubric-based self- and peerevaluation

for each member in your group—including yourself, using the following rubric. A link

to an online form is provided in Canvas. If you do not complete this self- and peer-evaluation

within twelve hours of your presentation, I will reduce the number of requirements you complete

by one, which will result in a lower grade.

Requirement To satisfactorily complete a requirement, all listed items must be met

Commitment

Attended all scheduled group meetings (including group work times

during class) or notified the group in advance of absence. Absence(s) did

not significantly hinder the success of the group.

Participation Contributed to planning, research, implementation, testing, and

presentation.

Communication Clear, timely and accurate reports on what has been accomplished, what

is in progress, and what stands in the way, thereby facilitating progress.

Technical

contributions High quality technical contributions that facilitate success of the group.

Attitude and

Leadership

Listens to, shares with, and supports efforts of others, and actively tries to

keep the group together.

If more than half of your group members’ responses for a given requirement, including your selfevaluation,

are satisfactory, then you complete that requirement. Your contribution grade is

determined by the number of requirements you satisfactorily complete, based on the following

criteria.

Grade earned A B C D F

Number of satisfactorily completed requirements 5 4 3 2 1 or 0

Last revised: 08/14/2019.


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp