Software Engineering Syllabus
Software Engineering Syllabus
Software Engineering Syllabus
Syllabus
1. The Nature of Software
Learners will be able to:
1.1 Discuss the nature of software.
1.2
Indicative content
a. Defining software
b. Software application
domains
i.
Systems software
ii.
Application software
iii. Engineering/scientific
software
iv. Embedded software
v.
Artificial intelligence
software
c. Legacy software
d. Changing nature of software
i.
Web apps
ii.
Mobile apps
iii. Cloud computing
iv. Product line software
Guidance
Candidates should be able to understand that producing software
is an engineering task and that engineering disciplines are often
applicable to it. They should also appreciate that producing
software is more than just programming.
Discuss theoretical models.
Indicative content
a. Prescriptive models:
i.
Waterfall models, e.g.
classic lifecycle or V model
ii.
Incremental process
models
iii. Evolutionary process
models, e.g. prototyping or
spiral model
iv. Concurrent models
Guidance
Candidates should understand how models have brought useful
structure to the discipline of software engineering, as well as
how modern software is characterised by constant change,
tight schedules and the need to meet users’ expectations. They
should also understand and be able to discuss both strengths and
weaknesses of evolutionary process models, which were originally
conceived to address these issues.1.3 Explain the motivation for development of
software engineering.
Indicative content
a. Projects running over budget
b. Projects running over time
c. Inefficient software
d. Software not meeting
requirements
e. Unmanageable projects
f. Code difficult to maintain
g. Failure to deliver
Guidance
Candidates need to be able to understand the motivations for the
development of software engineering as a discipline, as well as to
describe issues that have led to its development.
8
1.4 Describe the cost of maintenance.
Indicative content
a. Characterising maintenance,
e.g. ISO/IEC 14764
b. Corrective maintenance
c. Adaptive maintenance
d. Perfective maintenance
e. Preventative maintenance
Guidance
Candidates need to be able to understand a variety of reasons
for which maintenance is necessary, and appreciate that the
maintenance costs may often be larger than initial development
costs.9
1.5 Explain software quality.
Indicative content
a. Software functional quality
b. Software structural quality
c. The cost of quality
d. Quality of design
e. Quality of conformance
f. Performance quality
g. Feature quality
h. Reliability
i. Durability
j. Serviceability
k. Aesthetics
Guidance
Candidates need to have an appreciation of the wide variety
of factors which contribute to a measure of software quality.
They should also be able to appreciate that given factors will be
differently emphasised in a variety of contexts. 2. Software Engineering key
practices
Learners will be able to:
2.1 Describe and analyse the multidisciplinary nature of software design.
2.2
Indicative content
a. Requirements analysis and
specification
b. Software design
c. Software development
d. Software testing
e. Software maintenance
f. Software configuration
management
g. Project management
Guidance
Candidates are expected to be able to identify distinct sub
disciplines of software engineering and to be able to identify their
characteristics.
Explain team work in software engineering.
Indicative content
a. Characteristics of a software
engineer
b. Psychology of software
engineering
c. Cohesiveness of the software
team
d. Team structures
e. Agile and global teams
f. Collaboration tools
Guidance
It is important for candidates to appreciate the overall concept
that software is never developed in isolation. Paired programming
would be one example. Candidates should also understand how
having a sense of purpose, involvement, trust and improvement will
all contribute to a software team’s overall effectiveness.
2.3 Describe productivity in software engineering.
Indicative content
a. Lines of code
b. Function points
c. Constructive cost model
(CoCoMo)
d. Cyclomatic complexity
Guidance
In general, candidates should be able to measure the effectiveness
of software engineering processes for this section, possibly in lines
of code, but other measures may be applicable.
1011
2.4 Describe testing in software engineering.
2.5
Indicative content
a. Black-box testing
b. White-box testing
c. Grey-box testing
d. Unit testing
e. Integration testing
f. System testing
g. Acceptance testing
h. Smoke and sanity testing
i. Regression testing
j. Functional and non
functional testing
k. Usability testing
l. Security testing
m. Traceability testing
Guidance
Candidates are expected to be able to describe a range of valid
range of testing techniques, rather than one single technique.
Candidates should also understand that one testing approach is not
necessarily an alternative to another, but can be a complementary
approach which may uncover a different class of errors to other
methods.
Explain product maintenance.
Indicative content
a. Maintenance debt
b. Dependence on external
factors
c. Lifecycle
Guidance
Candidates need to be aware that delivery of a product is not
the end of the cycle – it will be followed by maintenance. The
idea of maintenance debt, which ties in more closely the cost of
maintenance with decisions taken earlier in the maintenance
lifecycle, is also important.
2.6 Describe the software product life cycle.
Indicative content
a. Preliminary analysis
b. Systems analysis,
requirements definition
c. Systems design
d. Development
e. Integration and testing
f. Acceptance, installation,
deployment
g. Maintenance
h. Evaluation
i. Disposal
Guidance
Candidates need to be able to explain and describe the phases that
a typical software development exercise will go through.12
3. Software development models and methods
Learners will be able to:
3.1 Explain design principles.
3.2
Indicative content
a. Transparency
b. Separation of concerns
c. Abstraction
d. Modularity
e. Development by incremental
methods
Guidance
Candidates should understand the role of software design and
its place within the modelling activity, as it sets the stage for the
construction phase – its goal is to create a software model which
will take into account (and meet) all user requirements.
Utilise and demonstrate notations for software components.
Indicative content
a. Syntax
b. Semantics
Guidance
Candidates need to be familiar with techniques for modelling
software systems. They should be able to identify the essential
features of modelling notations and distinguish between the
allowable symbols within notations and the meaning of those
symbols.
3.3 Demonstrate Unified Modelling Language (UML) modelling.
Indicative content
a. UML modelling of use cases
for a logical/end-user view
(e.g. use case diagram)
b. Class diagram
c. Object diagram
d. Activity diagram
e. Sequence diagram
Guidance
Candidates must be able to discuss and demonstrate the use of
UML techniques in order to visualise the design of a system. 13
4. Validation, verification and testing
Learners will be able to:
4.1 Describe product and process visibility.
4.2
Indicative content
a. Product visibility
b. Process visibility
Guidance
Candidates will need to be able to explain the concept of visibility
and outline ways in which visibility can be achieved for both
software products and software processes.
Explain traceability in software systems and describe the processes.
Indicative content
a. Mapping from requirements
to specifications
b. Mapping from specification to
design
c. Mapping from design to
implementation
d. Testing to ensure traceability
e. Derivation paths
f. Flowdown paths
Guidance
Candidates should be able to identify the steps a software
engineer will take to ensure that user requirements identified in a
specification are realised in an implementation.14
5. Software engineering tools and environments
Learners will be able to:
5.1 Demonstrate and explain Computer Aided Software Engineering (CASE) tools.
5.2
Indicative content
a. Automated support
b. Semi-automated support
c. Upper CASE
d. Lower CASE
Guidance
Candidates should be able to discuss the ways in which automated
tools can aid the software engineer.
Describe the role of repositories.
Indicative content
a. Package management
systems
b. Source control software
c. Software dependencies
Guidance
Candidates should understand the role of repositories in supporting
incremental development.
5.3 Explain software reuse and evolution.
Indicative content
a. The reuse landscape
b. Design patterns
c. Generator-based reuse
d. Application frameworks
e. Application system reuse
Guidance
Candidates should be able to identify the way in which software
reuse can contribute to the development of new applications.
Software should be designed to be reusable in the first instance, as
well as making sure to reuse it when the opportunity arises. 6. Project
management
Learners will be able to:
6.1 Explain how to use project estimating and project planning tools.
6.2
Indicative content
a. Algorithmic cost modelling
b. Expert judgement
c. Estimation by analogy
d. Parkinson’s Law
e. Pricing to win
Guidance
Candidates need to be able to discuss a range of techniques they
might need to employ in order to estimate the amount of effort
necessary to produce a software component.
Describe the management and maintenance of software products.
Indicative content
a. Variety of mechanisms for
updating software deployed
in customer environments
b. Risks associated with
software updates
Guidance
Candidates should be able to describe a range of strategies for
updating software products which have been deployed and are
operating in user environments. They should be able to discuss the
different levels of risks of said strategies and the context in which
they should be used.
156.3 Explain the total cost of system ownership.
Indicative content
a. Computer hardware and
programs
i.
Network hardware and
software
ii.
Server hardware and
software
iii. Workstation hardware
and software
iv. Installation and
integration of hardware and
software
v.
Purchasing research
vi. Warranties and licenses
vii. License tracking
compliance
viii. Migration expenses
ix. Risk
b. Operation expenses
i.
Infrastructure
ii.
Power
iii. Testing costs
iv. Downtime, outage and
failure expenses
v.
Diminished performance
vi. Security
vii. Backup and recovery
viii. User training
ix. Audit
x.
Insurance
xi. Information technology
personnel costs
xii. Management costs
c. Long-term expenses
i.
Replacement
ii.
Upgrade
iii. Decommissioning
Guidance
Candidates need to be able to identify all of the issues contributing
to the cost of a software product and be able to use these to
evaluate different software development strategies.
166.4 Analyse and explain the software life cycle cost modelling.
6.5
Indicative content
a. Prevention costs
b. Appraisal costs
c. Failure costs
i.
Internal failure costs
ii.
External failure costs
Guidance
Candidates should understand and have an appreciation for the
cost of quality, as well as the cost of a lack of quality, both for users
who must try to contend with glitches in software and for the team
that has built and now has to maintain it.
Describe project and product risk management.
Indicative content
a. Schedule flaws
b. Requirements inflation
c. Employee turnover
d. Specification breakdown
e. Poor productivity
Guidance
Candidates should be able to list the main risk factors in producing
software products and be able to describe techniques to mitigate
them.