Software Review: Dr. Aprna Tripathi
Software Review: Dr. Aprna Tripathi
Software Review: Dr. Aprna Tripathi
– Periodically, as larger parts of the interface begin to combine, it's useful to get
together with a group of people, including other designers and users, and do a
walkthrough for a complete task.
Design Walkthroughs
– You need a task description. The task should usually be one of the
representative tasks you're using for task-centered design, or some piece of that
task.
– You need a complete, written list of the actions needed to complete the task
with the interface.
– You need an idea of who the users will be and what kind of experience they'll
bring to the job. This is an understanding you should have developed through
your task and user analysis.
Critical Design Review
• Purpose: is to ensure that the detailed design satisfies the
specifications laid down during system design.
• The critical design review process is same as the inspections
process in which a group of people get together to discuss the
design with the aim of revealing design errors or undesirable
properties.
• The review group includes,
– Author of the detailed design
– Member of the system design team
– Programmer responsible for ultimately coding the module(s)
under review
– Independent software quality engineer
Critical Design Review
• While doing design review it should be kept in mind that the aim
is to uncover design errors, not try to fix them. Fixing is done
later.
• The use of checklists
– Is considered important for the success of the review.
– It is a means of focusing the discussion or the "search" of
errors.
– It can be used by each member during private study of the
design and during the review meeting.
• For best results, the checklist should be tailored to the
project at hand, to uncover project specific errors.
Critical Design Review
• A Sample Checklist
– Does each of the modules in the system design exist in detailed design?
– Are there analyses to demonstrate that the performance requirements can be
met?
– Are all the assumptions explicitly stated, and are they acceptable?
– Are all relevant aspects of system design reflected in detailed design?
– Have the exceptional conditions been handled?
– Are all the data formats consistent with the system design?
– Is the design structured, and does it conform to local standards?
– Are the sizes of data structures estimated? Are provisions made to guard
against overflow?
Critical Design Review
– Is each statement specified in natural language easily
codable?
– Are the loop termination conditions properly specified?
– Are the conditions in the loops OK?
– Are the conditions in the if statements correct?
– Is the nesting proper?
– Is the module logic too complex?
– Are the modules highly cohesive?
Consistency Checkers
• Design reviews and walkthroughs are manual processes; the people
involved in the review and walkthrough determine the errors in the
design.
• It can also check if the used global data items are indeed defined
globally in the design.
• The trade-off here is that the more formal the design language, the
more checking can be done during design, but the cost is that the
design language becomes less flexible and tends towards a
programming language.
Software Metric, Measurement
and Indicator
Five Views of Quality
Measures
• When you obtain/observe/measure a value of
directly observable property of an entity, you have
a measure.
• Each measure has a standard unit of measure
(UOM) like seconds, meter, kilograms etc.
• In software development and software testing,
most commonly used measures are:
– Number of Defects found in a system or component
– Lines of Code (LOC, kLOC)
– Number of Test Cases
Metric
• A metric, in contrast, is a derived value which
cannot be observed/measured directly.
• It is a number derived from one or more measures
by a formula (or estimation).
• Best known metrics in software development and
software testing are:
– Number of defects found per kLOC, which serves as
an estimation of quality of code
– Productivity, i.e. Size / Effort
– Defect Density, i.e. number of defects related to size
Types of Metrics
• There are two types of metrics, objective and
subjective.
– Objective metrics can be quantized and are readily
available,
– subjective metrics rely on opinions, gut feelings, personal
attitudes etc.
• An example is CSAT (customer satisfaction), though
the former is more reliable, than the later, the reliability
of subjective metrics can be improved by having
checklists and guidelines.
• For e.g.: survey question need to have, probe areas,
facets, scale definitions before an option can be chosen
Indicator
• An indicator is “a thing that indicates the state or level
of something”.
• thus it can be simply just a number showing value of a
particular measure or metric.
• A better indicator could be a chart comparing two
measures/metrics or projecting how a measure/metric
developed during a time period.
• Also, a semaphore where red means bad and green
means good is also a very simple indicator, which can
be helpful in particular class of situations.
• Thus, indicator is most general of these terms.
Quality Measure
• A measure is to ascertain or appraise by
comparing to a standard.
• A measure gives very little or no information
in the absence of a trend to follow or an
expected value to compare against.
• Measure does not provide enough information
to make meaningful decisions.
Quality Metric
• A metric is a quantitative measure of the degree to
which a system, component, or process possesses
a given attribute.
• A metric is a comparison of two or more measures
like defects per thousand source lines of code.
• Software quality metrics is used to assess
throughout the development cycle whether the
software quality requirements are being met or
not
Quality Indicator
• An indicator usually compares a metric with a
baseline or expected result.
• Indicator help the decision-makers to make a
quick comparison that can provide a perspective
as to the “health” of a particular aspect of the
project.
• Software quality indicators act as a set of tools to
improve the management capabilities of
personnel responsible for monitoring software
development projects.
Quality Measure Metric & Indicator
• Measure does not provide enough information to
make meaningful decisions.
• Software quality metrics is used to assess
throughout the development cycle whether the
software quality requirements are being met or
not.
• Software quality indicators act as a set of tools to
improve the management capabilities of
personnel responsible for monitoring software
development projects.
Software Quality Indicator|1
• 1) Progress:
– Measures the amount of work accomplished by the developer in each phase.
– This measure flows through the development life cycle with a number of
requirements defined and baselined, then the amount of preliminary and
detailed designed completed, then the amount of code completed, and various
levels of tests completed.
• 2) Stability:
– Assesses whether the products of each phase are sufficiently stable to allow the
next phase to proceed.
– This measures the number of changes to requirements, design, and
implementation.
• 3) Process compliance:
– Measures the developer’s compliance with the development procedures
approved at the beginning of the project.
– Captures the number of procedures identified for use on the project versus
those complied with on the project.
Software Quality Indicator|2
• 4) Quality evaluation effort:
– Measures the percentage of the developer’s effort that is being spent on internal
quality evaluation activities.
– Percent of time developers are required to deal with quality evaluations and
related corrective actions.
• 5) Test coverage:
– Measures the amount of the software system covered by the developer’s testing
process.
– For module testing, this counts the number of basis paths executed/covered, &
for system testing it measures the percentage of functions tested.
• 6) Defect detection efficiency:
– Measures how many of the defects detectable in a phase were actually
discovered during that phase.
– Starts at 100% and is reduced as defects are uncovered at a later development
phase.
Software Quality Indicator|3
• 7) Defect removal rate:
– Measures the number of defects detected and resolved over a period of time.
– Number of opened and closed system problem reports (SPR) reported through
the development phases.
• 8) Defect age profile:
– Measures the number of defects that have remained unresolved for a long
period of time.
– Monthly reporting of SPRs remaining open for more than a month’s time.
• 9) Defect density:
– Detects defect-prone components of the system. Provides measure of SPRs /
Computer Software Component (CSC) to determine which is the most defect-
prone CSC.
• 10) Complexity:
– Measures the complexity of the code.
– Collects basis path counts (cyclomatic complexity) of code modules to
determine how complex each module is.
Types of Indicator
• Process Indicator
• P
Exercise
• Company “ABC” stated that they can remove 50%
defects in a week of the arrival, while company
“PQR” stated that – they can remove up to 50 defects
in a week. For the following data, sketch the BMI
graph. Assume that 4 week is equal to 1 month.
(Evaluate)
Week No. of Defect Arrival
W1 20
W2 60
W3 43
W4 67
W5 51
W6 42
W7 78
W8 34
W9 56
W10 49
W11 34