COMP23311 Software Engineering 1 syllabus 2017-2018
The development of software systems is a challenging process. Customers expect reliable and easy to use software to be developed within a set budget and to a tight deadline. As we come to depend upon software in so many aspects of our lives, its increasing size and complexity, together with more demanding users, means the consequences of failure are increasingly severe. The stakes for today’s software engineers are high!
Experience over the last decades has taught us that software development failures are rarely caused by small scale coding problems. Instead, failures result from the difficulties of writing software that customers actually need, of keeping up with constantly changing requirements, of coping with the scale of large developments, of getting many different people with very different skill sets to work together, and of working with large bodies of existing code that no one on your team may fully understand. Being a good coder is an important part of being a good software engineer, but there are many other skills - including soft skills - that are needed too.
In this course unit, you will get the chance to expand and broaden the programming skills you gained in your first year course units by applying them in a more realistic context than is possible in a small scale lab. Instead of coding from scratch, you will be working in a team to make changes to a large open source software system, consisting of thousands of classes and tens of thousands of files - and all without breaking the existing functionality.
You will fix bugs in the code base and add new features, as well as performing larger scale refactorings to maintain or improve on non-functionality properties of the system. You will perform all this using an industry strength tool set. We will complement the hands-on experience-based learning with an understanding of the core concepts underlying current notions of software engineering best practice. Volunteer mentors from local industry will help you to put your learning into context, and to understand the key importance of being not just a good coder, but a good software engineer.
This unit aims to help students appreciate the reality of team-based software development in an industrial environment, with customer needs, budget constraints and delivery schedules to be met. Through hands-on experience with an industry-strength development toolkit applied to a large open source software system, students will gain an appreciation of the challenges of green and brownfield software development, along with an understanding of the core software engineering concepts that underpin current best practice. Students will have the core skill set needed by a practicing software engineer, and will be ready to become productive and valuable members of any modern software team.
Assessment is based on:
- Three team-based exercises, making changes to the open source system used in the course unit. Together these contribute towards 60% of the total course unit mark.
- Three individual exercises, in which students apply the Personal Software Process to practice software measurement and continuous improvement skills. Together, these contribute towards 10% of the total course unit mark.
- A multiple choice examination, at the end of the semester. This contributes towards 30% of the total course unit mark.
Team coursework deadlines on 20th October 2017, 17th November 2017 and 8th December 2017. Marking interviews for the team coursework take place in weeks 5, 9 and 12. The whole team is expected to be present. Individual coursework to be submitted on Fridays (5pm) in week 5 and week 12.
1 introductory lecture in semester 1, week 1.
One 2 hour workshop each week. In these sessions, you will gain practical, hands-on experience of the techniques being taught.
Team Study Sessions
Two 1 hour sessions per week. In these sessions you will:
- Work with your team on the team coursework
- Meet your industrial mentor (2 sessions per team)
- Get your team coursework marked in a face-to-face interview (3 sessions per team).
A number of off-line study activities and readings are provided, that build on and consolidate the topics covered in workshops. These are compulsory and are assessed in the coursework and exam.
Staff and TAs will be on hand to provide face-to-face informal feedback during workshops and team study sessions.
The RoboTA system will provide continuous feedback on aspects of the team marking system, using the Jenkins continuous integration system.
TAs will also provide written and verbal feedback on coursework, once marking is complete.
- Lectures (1 hours)
- Practical classes & workshops (64 hours)
- Analytical skills
- Group/team working
- Project management
- Oral communication
- Problem solving
- Written communication
|Programme outcome||Unit learning outcomes||Assessment|
|A2 A4 B2 C6||Make use of industry standard tools for version management, issue tracking, automated build, unit testing, code quality management, code review and continuous integration.|
|A2 A4 C5||Write unit tests to reveal a bug or describe a new feature to be added to a system, using a test-first coding approach.|
|A2 A4 D3||Explain the value of code reviews, and to write constructive and helpful reviews of code written by others.|
|A2 A4 D3||Make use of basic Git workflows to coordinate parallel development on a code base, and to maintain the quality and integrity of code scheduled for release.|
|A2 C5||Explain the role of patterns (design and architectural) in creating large code bases that will be maintainable over the long term.|
|A2 B3 C5||Explain why code that is easy to test is easy to maintain, and make use of test code smells in identifying and correcting design flaws (design for testability).|
|A2 A4 B3 C5||Apply basic refactorings with the aim of maintaining or improving code quality.|
|A2 D3||Explain the challenges inherent in cost estimation for software development, and create defensible estimates with the help of work breakdown structures.|
|Pro Git (2nd edition)||Chacon, Scott and Ben Straub||9781484200773||APress||2014||✖|
|Beginning software engineering||Stephens, Rod||9781118969144||Wrox||2015||✖|
|Effective unit testing: a guide for Java developers||Koskela, Lasse||9781935182573||Manning Publications||2013||✖|
|Clean code: a handbook of agile software craftsmanship||Martin, Robert C.||9780132350884||Prentice Hall||2008||✖|
|Pragmatic programmer: from journeyman to master||Hunt, Andrew and David Thomas||9780201616224||Addison Wesley||1999||✖|
|Clean coder: a code of conduct for professional programmers||Martin, Robert C.||9780137081073||Prentice Hall||2011||✖|
Course unit materials
Links to course unit teaching materials can be found on the School of Computer Science website for current students.