联系方式

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

日期:2024-04-24 08:51

OOP Coursework

This coursework covers the first half of the course and while it has a final deadline at the end of the first

half of the semester, you will need to make regular commits on gitlab to achieve full marks. Below, we

will provide you with an overall idea of the course work and specific tasks for you to finish each week.

Set-up Instructions

Please, visit https://gitlab-student.macs.hw.ac.uk/f27sb_2023-24/f27sb_2023-

24_coursework/oop_coursework and create your own fork of this project. Once the fork has been

created, import the starter code into Eclipse. Should you struggle with any of this, please have a look at

the “How to videos” on the course page on Canvas. If you should still face any problems, please talk to a

lab helper during your lab slot.

The Coursework

For this coursework, you will need to implement a task management system with a simple text-based

user interface. The system should support several different types of tasks and should allow the user to

add new ones and remove existing ones. Please, pay close attention to the rubric at the end of the

document.

The implementation of this system needs to follow the OOP principles that we discuss in the lectures,

and it should include comments that clarify how your code addresses principles such as cohesion and

coupling. Each week, you will be asked to complete a different part of the system and it is important

that you do so because this will guide you to the most desirable solution for this coursework. Moreover,

if your git commit history does not show incremental development of the final solution, you will

receive 0 marks for this coursework.

Weekly tasks:

Week 1-2 – suggested deadline: end of week 2

• Implement a Task class which contains an ID, a name, and a description of the task. The

ID and name are mandatory fields of the Task meaning that each instance of Task should make

sure that these are specified. The description is optional and can be omitted by the user. Create

as many constructors for this class as required. Finally, implement a way to generate a textual

representation of this class. Make sure to include a comment which states java.utils.comment in every file you create.

• Implement a TaskManager class which uses a collection to store all the instances of Task that

the user creates. This class should contain the following methods:

o addTask which adds a new task to the current list of tasks. No two tasks with the same

ID should be allowed to be added to the collection of tasks. If a new task with an already

existing ID is given as a parameter, this method should return a value that shows that

this operation has been unsuccessful and ignore the new task.

o removeTask which uses the ID of a task to find it in the list and remove it. Make sure

to return success or failure of this operation because this should only work if a task with

the given ID exists in the list of current tasks.

o getSize which returns the current number of tasks in the list.

o a way to get a textual representation of all the tasks in the list.

• Implement a text-based user interface. This should display a welcome message and instructions

on how to use the system. Use a Scanner object to get the input from the user. The user

operations you need to implement are:

o Show all current tasks

o Add a new task

o Remove an existing task

o Exit the program

• You can find a good example of how to use a Scanner for user input here:

https://www.w3schools.com/java/java_user_input.asp

• All implemented classes need to ensure high cohesion and low coupling. Make sure to comment

on how you achieved this in the code.

Week 3 – suggested deadline: end of week 3

• Implement a unit test for your TaskManager class. This should test the addTask and

removeTask methods. Make sure to cover all possible options of success and failure in your

tests and use positive and negative tests. Make sure to include a comment which states java.utils.comment in every file you create.

Week 4 – suggested deadline: end of week 4

• Change the TaskManager class to be a subclass of the collection you are using to store the

Tasks in. For example, if you have been using an ArrayList in your TaskManager to store

the Tasks in, you should now make sure that your TaskManager extends ArrayList.

Subsequently, change your implementation of TaskManager to not use an ArrayList

anymore but now be the ArrayList. Make sure that all your tests still pass.

• Implement a hierarchy of tasks: Make sure to include a comment which states java.utils.comment in every file you create.

o PersonalTask which should be a subclass of Task

o WorkTask which should be a subclass of Task

o TeamWorkTask which should be a subclass of WorkTask. This task should have an

additional field for the teamName. Make sure to create all the required constructors.

• Each of the new tasks should contain a method that generates a textual representation of it

which states the type of task (i.e. personal, work, or teamwork) as well as the information

provided (i.e. ID, name, description, and teamName).

• Adjust the user interface to allow the user to create all different types of tasks.

• Adjust your JUnit test to test all different types of tasks.

Week 5 – final deadline: beginning of week 7 (check on Canvas)

• Make the Task class abstract. Make sure to remove the option to create a Task from the user

interface. Only Personal, Work, and TeamWork tasks should now be created.

• Implement a Remindable interface which contains a remindUser method.

• Add the Remindable interface to the WorkTask and TeamWorkTask and implement a

simple remindUser method that prints a reminder message.

• Implement a way to store all the current tasks on the hard disk when the program exits.

• Implement a way to read a file with tasks from the hard disk when the program is started.

o After the file has been read, print a list of all the current tasks and print all the reminder

messages from all the tasks that implement the Remindable interface.

• Add a JUnit test to make sure that your File I/O operations work correctly.

Submission guidelines

GitLab submissions

You will need to make regular commits to GitLab! You do not have to commit something every week but

there has to be a commit for each weekly task. Hence, you need to make a total of 5 commits for this

project. Each commit needs to show incremental progress towards the final goal and needs to include a

commit message that states what you have achieved since the last commit. There needs to be enough

time between each commit to sensibly be able to do all the required work. If you make 5 commits within

a single day to finish the whole program, it is very unlikely that you have done the work yourself and we

will have to have a discussion with you. If you do not make incremental commits to GitLab, you will

receive 0 marks for this assignment.

Canvas submission

Download your final GitLab project as a zip file and commit it to Canvas before the deadline. This

ensures we have a backup of your code and tells us if the submission was on time. We will only use the

submission time on Canvas to determine if your submission is on time. Hence, make sure to finish your

project early enough so you have time for the final submission.

Plagiarism

This is individual coursework. That means you can discuss the coursework with your peers, but not share

your work or use anybody else's, passing it off as your own. You can find more on the general academic

misconduct rules here: https://www.hw.ac.uk/uk/services/academic-registry/academicintegrity/academic-misconduct.htm.

You are required to do all the work yourself. It is very easy nowadays to just ask an AI to do the work for

you and while that might help you finish the coursework; it will not teach you anything. You are here to

learn and not just to bide your time until you get a degree. This assignment is meant to prepare you for

the remainder of your studies which will require you to know how to program. Getting enough

experience programming is, therefore, more important than anything else in 1st year and the only way

to gain experience is to program!

Marking Rubric

Category A B C D E-F

Functionality

(30%)

(30 – 21)

All the required

functionality

has been

implemented.

Extra care has

been taken to

handle errors

and edge cases.

(20 – 18)

All or most

required

functionality

has been

implemented

but there is no

or very little

handling of

errors and edge

cases.

(17 – 15)

At least half of

the required

functionality

has been

implemented.

There is an

attempt to

handle edge

cases and

errors.

(14 – 12)

Some of the

functionality

has been

implemented or

decent

attempts at

implementing

have been

made.

(11 – 0)

An attempt at

implementing the

most basic

functionality has

been made.

User Interface

(20%)

(20 – 14)

The user

interface is

verbose enough

to inform the

user about how

to use the

system but not

overly

complicated. It

allows to trigger

all the

implemented

functionality.

(13 – 12)

The user

interface allows

to trigger all

implemented

functions and

has some user

guidance.

(11 – 10)

The user

interface allows

to trigger most

of the

functionality

and might have

some user

guidance.

(9 – 8)

The user

interface allows

to trigger some

of the

functionality

and/or is

confusing to

use.

(7 – 0)

An attempt has

been made at

implementing the

user interface,

but it does not

allow triggering

the implemented

functions and/or

is not selfexplanatory.

Code quality

(30%)

(30 – 21)

The code

follows all the

guidelines

about

responsibility

driven design,

coupling, and

cohesion from

the lectures.

The code

structure is easy

to understand

and maintain.

(20 – 18)

The code

structure is easy

to understand

and follows

some of the

guidelines from

the lectures.

(17 – 15)

The code

structure can be

understood

with a little

effort. Attempts

have been

made at

following the

guidelines from

the lectures.

(14 – 12)

The code is hard

to read and

maintain but

attempts were

made to follow

the class

relationships

outlined in the

CW description.

(11 – 0)

The code is hard

to understand.

None of the

guidelines and

required class

relationships

have been

implemented.

Tests

(10%)

(10 – 7)

The tests cover

all methods.

Positive and

negative tests

are used. Edge

cases are

tested.

(6)

The tests cover

all methods, but

only positive

tests are used,

and edge cases

are only

covered

partially.

(5)

The tests cover

most of the

methods but

only positive

tests are used.

Edge cases are

not covered.

(4)

The tests cover

some of the

methods.

(3 – 0)

An attempt has

been made at

covering some of

the methods with

tests, but they

don’t work

correctly.

Comments (10 – 7) (6) (5) (4) (3 – 0)

(10%) The comments

are not overly

verbose but

explain the

functionality

well.

Information

about how

coupling and

cohesion are

addressed is

included. All

files and

methods that

are not selfexplanatory are

covered.

Most of the files

and methods

are covered.

Comments are

sufficient to

understand

what has been

implemented.

Some

comments on

coupling and

cohesion have

been made.

Some of the

methods and

files have

comments. The

comments are

either overly

verbose or do

not always

explain the

functionality

sufficiently.

Some

comments have

been made but

are not enough

to understand

what is going on

or are wrong.

No or only very

few comments

can be found.


版权所有:留学生编程辅导网 2020 All Rights Reserved 联系方式:QQ:821613408 微信:horysk8 电子信箱:[email protected]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:horysk8