Iso Iec Ieee 29119

Download as pdf or txt
Download as pdf or txt
You are on page 1of 6

See discussions, stats, and author profiles for this publication at: https://www.researchgate.

net/publication/323759544

Overview of Software Testing Standard ISO/IEC/IEEE 29119

Article · February 2018

CITATION READS

1 13,153

2 authors, including:

Shakeel Ahmed
King Faisal University
12 PUBLICATIONS   30 CITATIONS   

SEE PROFILE

Some of the authors of this publication are also working on these related projects:

PhD Degree View project

All content following this page was uploaded by Shakeel Ahmed on 14 March 2018.

The user has requested enhancement of the downloaded file.


112 IJCSNS International Journal of Computer Science and Network Security, VOL.18 No.2, February 2018

Overview of Software Testing Standard ISO/IEC/IEEE 29119


Hesham Alaqail Shakeel Ahmed

King Faisal University, College of Computer Science and Information Technology,


Department of Computer Science, Saudi Arabia

Summary engineering testing. The first aim of such series is to create


Software testing is an essential part of software development a set of standards that agreed internationally. The second
cycle. It is considered an important activity where software is aim is to have adaptable standards for different
validated in compliance to requirements and specifications. organizational scenarios that cope up with current
Mostly, software testing is relevant to poor execution and technological advancement in software development [3].
documentation, causing additional burden on software companies
or purchasers. Estimates show that 20% to 80% of total cost of
The new international standard is envisioned to be more
software projects is spent on testing activities. Since no software comprehensive by covering various level of testing
can be perfect, the cost spent on testing activities is worthy processes. I addition, it is meant to cover documentation,
especially in safety-critical systems. This paper provides an design test techniques, testing vocabulary and concepts [1].
overview of ISO/IEC/IEEE 29119 software testing standard. The
included parts of the standard are: concepts and definitions, test In this paper, an overview of ISO/IEC/IEEE 29119
processes, test documentation, test techniques and keyword- pertaining software testing is given which focuses on some
driven test. aspects such as concepts and definitions, testing processes,
Keywords: testing documentation, test design techniques and
software testing; ISO standard; test process; ISO/IEC/IEEE keyword-driven test. The rest of the paper is constructed as
29119. follow: fundamental software testing model, concepts and
definitions, testing processes, testing documentation, test
design techniques and keyword-driven test and conclusion.
1. Introduction
Software testing is an essential part of software 2. Fundamental Software Testing Model
development cycle. Normally, to ensure the operation of
any written piece of code, there must be a testing phase to The new software testing model is based on a fundamental
discover whether the code reacts as intended [1]. The testing model where processes testing form the core of the
main aim of software testing is to detect defects. As per model in addition to three more basic entities illustrated
IEEE Standard 610.12-1990, software testing is defined as below in Figure 1. Documentation is generated as final
“The process of analyzing a software item to detect the result of performing processes test cases providing
differences between existing and required conditions (that description of the output. Techniques entity is derived
is, bugs) and to evaluate the features of the software items” from requirements to be used for designing test cases. The
[2]. In spite of the definition, testing cannot be a separate used terminologies by other model’s part are labeled as
process from software development cycle. However, it is concepts and definitions.
believed that software testing existed before the
establishment of development life cycles. According to
references, the early software testing activity was made at
1954. In reference to today’s estimates, the cost spent on
testing phase vary from 20% up to 80% particularly for
critical-safety systems. The estimates are assumed to be
for the full life cycle of the software systems. Historically,
software testing was attached with high cost and poor
coverage of testing standards professionally and
academically. Fig. 1 New fundamental testing model.

New international software testing standard was formed by The covered test process of the fundamental model
International standardization organization (ISO) and executes at three different levels, those levels are
International Electrotechnical Commission (IEC) in the illustrated at Figure 2 [1]. The organizational test process
year 2013 [1]. ISO/IEC/IEEE 29119 is a standardization refers to the activities among several projects across the
series novel which covers systems and software organization. Therefore, it contributes to the creation,

Manuscript received February 5, 2018


Manuscript revised February 20, 2018
IJCSNS International Journal of Computer Science and Network Security, VOL.18 No.2, February 2018 113

development and implementation of organizational test approaches and highlight the effective ones that reveal the
policy. The test policy states management expectations of defects [4].
the organization as well as serving as direct approach for
software testing in business terms.
4. Test Processes ISO/IEC/IEEE 29119-2

This part includes more details about test processes


illustrated in Figure 2. It identifies the test processes that
can be used for managing, governing and implementing
software testing in organizations. It provides common
descriptions of testing processes along with descriptive
diagrams which applicable for all software testing models
[5]. Figure 3 summarizes the processes and sub-processes
involved in the multilayer relationship diagram. The
organizational test is represented twice in Figure 3, once
Fig. 2 Multilayer relationship diagram for test processes.
for the creation and maintenance of test policy and second
for the organizational test strategy. Moreover, the test
Requirements and constraints are dictated by the management process is commenced for the development
organizational test process to test management processes and implementation of the test plan. The lower layer is
and dynamic test processes to engage with the dedicated for dynamic testing whenever needed by test
organizational test process in all projects belonging to plan. The dynamic testing for instance includes unit testing,
same organization. Formulation of new organizational test system testing and performance testing, etc. [1].
process is possible with different project natures that do
not comply with the designed test processes. The
comprehensive test stated by organizational test policy is
divided into number of sub-processes of testing e.g.
component, system, usability and performance testing.
Test Management processes can be also applied to testing
sub-processes. Different management plans can be used
with testing sub-processes such as system, acceptance and
performance test plans. Static and dynamic testing can be
both included in testing the sub-processes [4].

3. Concepts and Definitions ISO/IEC/IEEE


29119-1

This is the first part of the ISO/IEC/IEEE 29119 standard.


It focuses on key definitions and concepts of software
Fig. 3 Example use of multilayer model [1].
testing for better understanding of the international
standards. Software testing as concept is important for
many reasons such as information regarding quality of the 4.1 Test Monitoring and Control Process
item being tested usually required by decision makers, the
item under testing may not perform as expected and need Test monitoring and control process examines whether the
to be verified and validated, evaluation should occur progress of testing is in alignment with the organizational
throughout the life cycle of the software being developed. test plan and the test policy of the organization. If
variance is detected, correction plan should be executed to
Generally, it is acceptable that perfect software is
impossible to achieve. Therefore, software continuous remove the variance. This process can be assigned for the
testing and evaluation is required. The main goal of testing management of the project or the management of single
is to provide information about the quality of items under testing phase or type e.g. System testing or performance
testing. This information can be useful at following; testing. If the variance is detected at later stages, it would
be applied as a part of dynamic testing. The person in
removal of defects to improve the test item, improve
decision made by management by considering the risk charge of implementing test plan should implement the
attached with items, enhance the organizational following activities and tasks in Table 1 [5].
114 IJCSNS International Journal of Computer Science and Network Security, VOL.18 No.2, February 2018

Table 1: Activities and tasks example for test monitoring and control aiming to attain test completion criteria. Moreover,
process.
Activity
iteration may occur among the activities. Table 3
Code Name Task summarizes the activities and tasks of this process [5].
TMC1 Set-Up Create suitable measures and means to
update risks with the new changes.
Collect and record measures, compare 4.5 Test Environment Set-Up & Maintenance Process
TMC2 Monitor progress against test plan using measures
collected. This process is used to create and maintain the
TMC3 Control Ensure implementing the activities
required for test plan. environment where tests are performed. It may involve
Test progress against test plan and changes to test environment based on the result of the
TMC4 Report communicate results to stakeholder previous tests. The test environment may change
within specific period of time, update and
report new risks to stakeholders. depending on the configuration management processes.
The tasks and activities within this process are;
4.2 Test completion Process establishment of test environment and maintaining test
environment [5].
Test completion process is a verification test to be
performed when the test of activities is complete. It is used 4.6 Test Execution Process
as verification test to carry out the testing done on system
testing or performance testing to test the overall project. It This process is utilized to run the test procedures that are
is considered as satisfactory test leaving the testing generated as result of test design and implementation
environment in good situation. Communication to process. Test execution process may require running
stakeholder should occur when overall testing is complete. several times since all available test procedures cannot run
Table 2 below summarizes the activities and tasks at single iteration. Furthermore, when an issue is fixed, the
involved in this process [5]. test execution process should be performed again. The
activities involved within this process are; Test procedure
Table 2: Activities and tasks example for test completion process. execution, test results comparison and test execution
Code Activity Name Task recording [5].
TC1 Archive Test Assets Properly identify and store useful
test cases for later use.
Restoration of test environment Table 3: Activities and tasks for test design and implementation process.
TC2 Clean Up Test to pre-defined state upon Activity
Environment Code Name Task
completion of testing activities.
Identify Lessons Record lesson learned during the Analyze test basis to understand the
TC3 Learned project. test item requirements, combine test
TD1 Identify features into test set and prioritize by
Relevant information such as test Feature Sets
plan, test results, test status report risk value, document the feature set
TC4 Report Test and test completion report should and communicate it to stakeholders.
Completion be collected and reported to Determine the test condition for each
stakeholders. TD2 Derive Test test case; prioritize the best condition
Conditions based on risk, record test condition in
test design specification.
4.3 Dynamic Test Processes Derive test coverage items through
Derive Test applying test design techniques;
This type of testing is used to carry out the dynamic testing TD3 Coverage prioritize test coverage items based on
Items risk, record test coverage items in test
in specific phase of testing e.g. unit, system, integration design specification. Record the
and acceptance testing. Four types of dynamic test process traceability.
Determine pre-condition and input
are available; test design and implementation, test values for one or more test cases and
environment set-up and maintenance, test execution and Derive Test expected result prioritize by risk
TD4 Cases value, record test cases items in test
test incident reporting. These processes is normally design specification. Record the
considered as a part of test strategy implementation within traceability, get approval of
test plan in the test phase e.g. System testing or type stakeholder.
Distribute test cases into one or more
testing e.g. performance testing [5]. Assemble test sets based on constraints and
TD5 Test Sets execution, record test case in
procedure specification, record the
4.4 Test Design and Implementation Process traceability.
Derive test procedures from ordered
In this process, test cases and procedures are derived. test set based on pre-condition, post-
condition and dependencies, Identify
Normally, documented in test specifications, but can be Derive Test excluded test data, prioritize test
TD6 Procedures procedures based on risk, record test
executed immediately. Possibly, stored test assets can be
procedures in procedure specification,
used during this process as regression test. This process record the traceability, get approval of
can stop or reinitiate again in case of reporting new stakeholder.
incident. Also, it requires tester to apply one or more
testing techniques to derive test cases or test procedures
IJCSNS International Journal of Computer Science and Network Security, VOL.18 No.2, February 2018 115

4.7 Test Incident Reporting Process essential but considered complementary. However, they
are effective if applied in combination.
This process is used for test incident reporting as a result
of failure detection, items with unexpected or unusual The terms specification-based testing, structure-based
behavior while executing the test or in case of retest. The testing are also known as black-box testing and white-box
activities involved are; analyzing test result and create or testing (also named as clear-box testing), both black-box
update incident results [5]. testing and white-box testing are related to the visibility of
test items in software structure. In black-box testing, test
item’s visibility of the internal structure is not present
5. Test Documentation ISO/IEC/IEEE 29119- while in white-box testing the internal structure of test
3 items is visible. Grey-box testing is used as a term when
knowledge of test items is utilized from specification and
Test documentation part determines the software test structure as well. Below Table 5 shows all techniques
forms and templates that can be used by organizations, pertaining specification-based testing, structure-based
specific project or single activity of testing. It contains testing and experience-based testing [7].
definite documents that considered as an output of test
processes. These documents can have multiple versions;
such issue is related to configuration management [6]. The 7. Keyword-Driven Testing ISO/IEC/IEEE
set of documentation is useful for test practitioners, below 29119-5
Table 4 list available documents in this part.
Keyword-driven test is an approach of test specification
First two templates belong to organizational test process; which is generally used to aid test automation and creation
the three proceedings belong to management test processes of test automation framework. It can be used if no test
while the rest correspondent to dynamic test processes [1]. automation approach is planned or exist. This type of
testing can be applied to all level of testing such as
Table 4: Test documentation template list. component testing and system testing or even for test types
Seq. Documentation name Seq. Documentation name like functional testing and reliability testing. The
1 Test policy 8 Test procedure
specification advantages of applying keyword-driven testing for system
2 Organizational test 9 Test data requirement are; making system easier to use, understandable,
strategy
Test environment maintainable, reusable, automation supportive, and money
3 Test Plan 10 requirement saver.
4 Test status report 11 Test data readiness
report
Test environment Table 5: Test techniques for specification and structure based testing.
5 Test completion report 12 readiness report Specification- Experience-
based testing Structure-based based Testing
6 Test design 13 Test execution log Testing Techniques
specification Techniques Techniques
7 Test case specification 14 Test incident report Equivalence Branch / Decision
Partitioning Testing
Boundary Value Branch Condition
Analysis Testing
6. Test Techniques ISO/IEC/IEEE 29119-4 Cause-effect Branch Condition
Graphing Combination Testing
Classification Tree Data Flow Testing
This part specifies and identifies test techniques that can Method
be used with test processes in part 2. The targeted audience Combinatorial Test Modified Condition
Decision Coverage Error Guessing
of this part is testers, test managers and developers Techniques (MCDC) Testing
especially those who are in charge of software Decision Table
Testing
management and implementation. In this part, test design Random Testing
techniques are defined for specification-based testing, Scenario Testing Statement Testing
structure-based testing, and experience-based testing. In State Transition
Testing
specification-based testing, the main source of information Syntax Testing
used to design test cases is test basis, for instance user
needs, requirements, specification and models. In This part provides efficient definition and constraints for
structure-based testing the source code or model structure keyword-driven testing. It offers introduction and
is used as the source of information to develop test cases. reference approaches to implement keyword-driven testing.
In experience-based testing, the primary source of Also, requirement definition for framework of keyword-
information is the experience and knowledge of testers. driven testing is given. This enables testers to share their
Moreover, all these types of tests are used to generate the work items, test cases, test data, keywords or test
expected end results. Those test design techniques are not
116 IJCSNS International Journal of Computer Science and Network Security, VOL.18 No.2, February 2018

specifications. Moreover, this part provides interfaces processes," in ISO/IEC/IEEE 29119-2:2013(E), pp.1-68.
definitions and data exchange format from different IEEE.
vendors to ensure different system integration. [6] ISO/IEC/IEEE International Standard. 2013. “Software and
Furthermore, it includes definitions of different level of systems engineering -- Software testing --Part 3: Test
documentation," in ISO/IEC/IEEE 29119-3:2013(E), pp.1-
hierarchical keywords with explanation and advice on how 138. IEEE.
to use them. Lastly, list of examples and technical low [7] ISO/IEC/IEEE International Standard. 2015. “Software and
level keywords is provided e.g. “inputData” or systems engineering--Software testing--Part 4: Test
“checkValue” to determine test case on any particular techniques," in ISO/IEC/IEEE 29119-4:2015, pp.1-149.
technical level. It can be also combined to from business- IEEE.
level keyword if needed [8]. [8] ISO/IEC/IEEE International Standard. 2016. “Software and
systems engineering -- Software testing -- Part 5: Keyword-
Driven Testing," in ISO/IEC/IEEE 29119-5 First edition
8. Conclusion 2016-11-15 , pp.1-69. IEEE.

Software testing is an essential part of software Hesham Alaqail earned his B.Sc. in
development cycle that cannot be neglected. Actually, it is Computer Science from King Faisal
University, Saudi Arabia in 2009. He is
an activity that should start upon the creation of software pursuing his M.S. in same field at King
specifications until software deployment and further with Faisal University. Currently, Hesham is
changes and maintenance. The cost of adopting software working as Programmer Analyst at Ministry
testing approaches and practices is considerably high, but of National Guard – Health Affairs, Saudi
the final cost would be much higher in case the system Arabia. His current research interests
encounters failure especially in enterprise and safety- include Software Validation and
critical systems. The awareness of testing standard is also Verification, Machine Learning and
beneficial to purchasers, businesses and governments to Classification Techniques.
verify the quality of the market’s products on well-studied
Shakeel Ahmed received his B.Sc.
and measured basis. (Computer Science in 1997) from Kakatiya
University and M.C.A (Master of Computer
Applications in 2000) from M.K.
Acknowledgment University, India. He earned his PhD
degree in Computer Science from Indore
I would like to thank my instructor Dr. Shakeel Ahmed for University, India, in 2013. Currently he is
his assistance in understanding the testing firm in software working at King Faisal University, Saudi
quality during the academic course. Also, special thanks to Arabia as Assistant Professor in the College
my college at King Faisal University, College of Computer of Computer Sciences and Information
Science and Information Technology for facilitating all Technology. His current research interests include Mobile Ad
educational means to gain knowledge and excel. hoc networks, Software Engineering, cloud computing he has
published more than 15 papers in international journals and
conferences in the field of software engineering and cloud
References computing.
[1] Reid S. 2012. “The New Software Testing Standard”. In:
Dale C., Anderson T. (eds) Achieving Systems Safety. pp
237-255. Springer, London.
[2] Majchrzak T.A. 2012. “Software Testing”. In: Improving
Software Testing. SpringerBriefs in Information Systems.
pp 11-56. Springer, Berlin, Heidelberg.
[3] Matalonga S., Rodrigues F., Travassos G.H. 2015.
“Matching Context Aware Software Testing Design
Techniques to ISO/IEC/IEEE 29119”. In: Rout T.,
O’Connor R., Dorling A. (eds) Software Process
Improvement and Capability Determination. SPICE 2015.
Communications in Computer and Information Science, vol
526. pp 33-44. Springer, Cham.
[4] ISO/IEC/IEEE International Standard. 2013. “Software and
systems engineering --Software testing --Part 1:Concepts
and definitions," in ISO/IEC/IEEE 29119-1:2013(E) , pp.1-
64. IEEE.
[5] ISO/IEC/IEEE International Standard. 2013. “Software and
systems engineering --Software testing --Part 2:Test

View publication stats

You might also like