SlideShare une entreprise Scribd logo
1  sur  47
Télécharger pour lire hors ligne
Unit testing in embedded environments
         with Parasoft C++test
Agenda
 Introduction
    What are the embedded systems
    What is Unit Testing
 Unit Testing With C++test
    General flow
    Test cases generation
 Unit Testing in Embedded Environments
    General flow
    Runtime requirements
    Building test executable
    Pros, Cons, limitations
 Questions ....
Introduction
What is an embedded system ?



An embedded system is a combination of computer
hardware and the software, and perhaps additional
mechanical or other parts, designed to perform a
specific function.


                   (Michael Barr - Programming Embedded Systems)
A generic embedded system



                 Memory




                                       Functional devices
      Inputs     Processor   Outputs
Example 1 - VCR
                  VCR can be made of:
                   8 bit processor
                   ROM and RAM
                   Mechanical
                    components
                   Analog modules
                    for signal
                    processing
                   Platform targeted
                    operating system
Example 2 - Opportunity
                          Opportunity:
                           CPU RAD6000
                            (RISC)
                           128 MB DRAM
                           3 MB EEPROM
                           256 MB FLASH
                           Running on
                            VxWORKS
                            (WindRiver)
                            operating system
Example 3 - Pendolino
                        Composed of many
                        sub systems running
                        on different
                        hardware platforms
                        and different
                        operating systems
Development process




    Host Machine                     CPU
                       deployment
   Cross development
      environment                   Target Platform


                                     MEM
Unit Testing


In computer programming, a unit test is a
procedure used to validate that a particular module
of source code is working properly. The procedure is
to write test cases for all functions and methods so
that whenever a change causes a regression, it can
be quickly identified and fixed.

                                     (www.wikipedia.org)
Unit testing with C++test
-test flow
-test harness architecture
-test cases
-regression testing
Unit Testing with C++test


   Automatic test cases generation
   Test cases in a form of source code
   Coverage metrics
   Post-Conditions recording for regression testing
   Automatic Stubs configuration
   Automatic test flow management
   Command line mode
   Convenient reporting system
From source code to test results

                                test results

            C++test
                                instrumented
 source          Parser          user source
  code
             Instr Generator


               Test Cases        test cases      Test
               Generator           source      Executable

                                                runtime
                                                 library
libraries   Libraries Scanner       stub
                                   source
             Stub Manager
Tests architecture - example



  #include <header>

  int funcB();

  int funcA(int b)
  {
     int a = funcB();
     return a + b;
  }
Tests architecture - example
                                      Test Executable

   test runner
       main() {             instrumented code
           call_test_case   Int funcA(int a) {
      .....}                   instr_callback();
                               int b = funcB_stub();
                               instr_callback();
                               return a + b;
                            }
   test_case
   {
     pre_cond                    Stubs
     funcA()                     funcB_stub() {
     post_cond                      return 0;
   }                             }
Test cases
Test cases architecture
                                       Test case is composed of
TestSuite_MyClass::test_foo_0()          three sections:
{
  //PreCondition initialization
  int arg_1 = 0;
  MyClass testObject();                 Pre conditions setup
    //Tested function call
                                        Tested function call
    int ret = testObject.func(arg1);    Post conditions
    //PostConditions validation          validation
    CPPTEST_ASSERT(ret == 1)

}
Automatic test cases generation
C++test's test cases generator automatically
produces source elements for:

Initializing pre-conditions like: function arguments,
global variables, 'this' object for tested function

Calling the tested function or method

Validating post-conditions (achieved test result)
Initialization strategies
 Simple (built-in) types:
    Integers (-1,0,1, min, max value)
    Floating point (-1.0, 0.0, 1.0, max, min positive, max,
     min negative)
    Heuristic values



 Complex types (user defined types) C++test will
  use available constructors and generate code
  necessary to initialize constructors arguments.
Initialization strategies
 Pointer types:
    NULL pointer
    address of a local object created on stack
    address of an object created with “new” (on heap)
 Reference types:
    local object created on stack
    object created using operator “new”
 Heuristic values for simple types:
    int
    float
    char *
Post conditions
C++test provides macros and routines for controlling
how source code test results are collected and
validated:

Test case post-conditions are controlled via
assertion macros (similar to CppUnit)
    CPPTEST_ASSERT_INTEGER_EQUAL(expected,actual)


Assertions perform a condition validation and send
results back to C++test
Test case example with post-conditions


      /* CPPTEST_TEST_CASE_BEGIN test_bufLen_0 */
      void TestSuite_bufLen_0::test_bufLen_0()
      {
         /* Pre-condition initialization */

          /* Initializing argument 0 (this) */
              /* Initializing constructor argument 1 (fill) */
              char _fill_0 = '001';
          ::Data _cpptest_TestObject (_fill_0);

          /* Tested function call */
          int _return = _cpptest_TestObject.bufLen();

          /* Post-condition check */
          CPPTEST_ASSERT_INTEGER_EQUAL(4, ( _return ))
          CPPTEST_ASSERT(( _cpptest_TestObject._data ) != 0)
      }
Regression test cases generation

   subsequent test runs


               generation                      Test results


       Test cases                Validation              Testing
       generation

                                         First test execution
                            Test cases




                            Regression
                            test cases
Stubs
Stubs – handling missing definitions

                                    Instrumented
     Libraries                       source code
         &
    object files
                                   Auto generated
                                        stubs

                                  int func2()
                                  {
                                     return 0;
                                  }
extern int func2();

int func1(int b)                    User defined
{                                      stubs
   int a = func2();
   return a + b;
}
Stubs in C++test
 Stubs are used:
   when testing in separation from other modules
   when application module is not yet ready
   when hardware module is not yet ready
 C++test provides three modes for stubbed
  function:
   original
   user-defined
   auto-generated
 Stubs configuration is managed from C++test GUI
  and persisted in C++test project
Unit Testing in embedded environments
-test flow
-runtime library
-problems & limitations
-why to unit test on target ?
Unit testing in embedded environment
C++test
                                  runtime



           Cross Compiler
runtime




                                                          linker/locator
library                            library
 source
                                                                              Test
                                                                           executable
                                    Test
 Test                             harness
harness                           binaries
source




                                                                           deploy
 code



                            host - target communication

                                       results
Unit testing in embedded environment

   Host
    Development env                               Target


           C++test              deploy
                                                  Test executable

                                                 Runtime library
             Listening                           communication
               agent     communication channel      module
C++test runtime library
C++test runtime library


 Provided in form of source code
 Implemented in plain C
 Needs to be cross-compiled for specific target
  platform
 Contains definition of communication channel
  Provided implementations:
   file
   TCP/IP sockets
 Designed to be easily customizable
C++test runtime library
Communication module
Target-to-host communication module
 Custom implementation of communication channel
  can be plugged in
 Defining communication channel requires
  implementing four methods:
   cpptestInitializeCommunication(...);
   cpptestFinalizeCommunication(...);
   cpptestSendData(const char* data, unsigned size);
 All data transfer operations, performed inside C+
  +test runtime library are implemented in terms of
  above interface
Collecting results on target
  Host
                                       Target
           C++test

                                       Test executable

                     Manual results   Runtime library
                       transfer
   File                               communication
  System                                 module




                                           Local
                                          Storage
“On the fly” results transfer

  Host
                                                   Target
           C++test

                             TCP/IP Sockets        Test executable
                                RS 232
                                RS 485
                                   I2C
                                  ICE             Runtime library
   File       Listening                           communication
  System        agent     communication channel      module
C++test runtime library
Exceptions handling module
Exceptions handling
                                           C++test uses
  Test cases execution
        sequence                            exceptions handling
                                            facilities (try, catch,
                    Test                    setjmp, longjmp,
                   case 1                   signal) to recover if
                                            exception is thrown
                            exception
                                            during test sequence
handling enabled




                    Test
With exceptions




                   case 2
                            (e.g divide
                            by zero)       If target platform does
                                            not provide exceptions
                                            handling, test sequence
                    Test
                                            is broken on first
                   case n                   exception and needs to
                                            be restarted
Test flow automation
Test flow automation
 Test sequence can be automatically performed in
  C++test GUI as well as in command line mode
 Test sequence consists of test harness
  preparation, building test executable, deploying
  test executable, starting it, and collecting results
 Limitations in automation of testing process can be
  imposed be development environment
 C++test provides easy to use XML-based format
  for defining test framework operations
Problems & Limitations
Problems & limitations
 Not enough memory on the target device to store
  test harness and tested code may block or limit
  testing capabilities


                    Compilation without debug information

                Original file     Min Instr       Med Instr     Max Instr
 GNU GCC 3.2       22 KB         22 KB (0%)      29 KB (30%)   41 KB (80%)
 MSVC++ 7.1        33 KB         33 KB (0%)      41 KB (24%)   69 KB (100%)
Tornado simpc      23 KB         23 KB (0%)      30 KB (30%)   41 KB (78%)
Problems & limitations


 Lack of communication channel may effect in weak
  test automation

 Missing support for exceptions handling may
  increase the number of runs necessary to execute
  test cases scheduled for test session.

 Additional amount of work required during
  development process
Why to unit test on target ?
Pros of unit testing on target
 All well known positives from host-based unit
  testing (early bugs detection, increased code
  robustness, ...)
 Possibility of detecting hardware problems
 Possibility of detecting software/hardware
  interaction problems
 Easy stubbing of missing software (also hardware)
  modules
 Quick and automated generation of regression
  suites
Unit testing in embedded environment - example
static int iTemperatures[2];
                                            “Critical section”
void interrupt vReadTemperatures(void) {     related bugs are hard
    ITemperatures[0] = /*Read sensor 1*/     to detect during host-
    ITemperatures[1] = /*Read sensor 2*/     based unit testing
}
                                            Target-based unit
bool testSensors() {                         testing highly increases
    int iTemp0, iTemp1;                      probability of catching
    iTemp0 = ITemperatures[0];
                                             this kind of problems,
    iTemp1 = ITemperatures[1];
    if (iTemp0 != iTemp1) { // Alarm !!!
                                             however it does not
        return -1;                           provide 100% certainty
    }                                        of catching them.
    return 0;
}
Unit testing in embedded environment - example
                          Module for driving the position
                           of functional mechanical
                           equipment
 servo                    Hardware contains “stuck-at-
          encoder          zero” problem between the
                           encoder and board interface

                       int set_position(int angl)
                       {
                           if (angl < MIN || angl > MAX)
                           {
                               return INCORRECT_ANGL;
                           }
                           return run_servo(angl);
                       }
Epilog


 C++test offers a high level of automation for tasks
which are usually performed manually, especially in
embedded environments, therefore very often it lets
    us give the positive answer for a question:


          “to test ? or not to test ?”

Contenu connexe

Tendances

Unit Testing And Mocking
Unit Testing And MockingUnit Testing And Mocking
Unit Testing And Mocking
Joe Wilson
 
Intro sur les tests unitaires
Intro sur les tests unitairesIntro sur les tests unitaires
Intro sur les tests unitaires
PHPPRO
 

Tendances (20)

Unit Testing Concepts and Best Practices
Unit Testing Concepts and Best PracticesUnit Testing Concepts and Best Practices
Unit Testing Concepts and Best Practices
 
Unit testing framework
Unit testing frameworkUnit testing framework
Unit testing framework
 
Karate for Complex Web-Service API Testing by Peter Thomas
Karate for Complex Web-Service API Testing by Peter ThomasKarate for Complex Web-Service API Testing by Peter Thomas
Karate for Complex Web-Service API Testing by Peter Thomas
 
Introduction to JUnit
Introduction to JUnitIntroduction to JUnit
Introduction to JUnit
 
Testing in-python-and-pytest-framework
Testing in-python-and-pytest-frameworkTesting in-python-and-pytest-framework
Testing in-python-and-pytest-framework
 
Unit Testing And Mocking
Unit Testing And MockingUnit Testing And Mocking
Unit Testing And Mocking
 
Introduction to Parasoft C++TEST
Introduction to Parasoft C++TEST Introduction to Parasoft C++TEST
Introduction to Parasoft C++TEST
 
11. Java Objects and classes
11. Java  Objects and classes11. Java  Objects and classes
11. Java Objects and classes
 
Testes Unitários
Testes UnitáriosTestes Unitários
Testes Unitários
 
모바일 게임 테스트 자동화 (Appium 확장)
모바일 게임 테스트 자동화 (Appium 확장)모바일 게임 테스트 자동화 (Appium 확장)
모바일 게임 테스트 자동화 (Appium 확장)
 
05 junit
05 junit05 junit
05 junit
 
Introduction to testing with MSTest, Visual Studio, and Team Foundation Serve...
Introduction to testing with MSTest, Visual Studio, and Team Foundation Serve...Introduction to testing with MSTest, Visual Studio, and Team Foundation Serve...
Introduction to testing with MSTest, Visual Studio, and Team Foundation Serve...
 
Intro sur les tests unitaires
Intro sur les tests unitairesIntro sur les tests unitaires
Intro sur les tests unitaires
 
iOS Automation: XCUITest + Gherkin
iOS Automation: XCUITest + GherkiniOS Automation: XCUITest + Gherkin
iOS Automation: XCUITest + Gherkin
 
Unit testing
Unit testingUnit testing
Unit testing
 
Unit testing with JUnit
Unit testing with JUnitUnit testing with JUnit
Unit testing with JUnit
 
Junit 4.0
Junit 4.0Junit 4.0
Junit 4.0
 
Test Driven Development With Python
Test Driven Development With PythonTest Driven Development With Python
Test Driven Development With Python
 
Unit testing with JUnit
Unit testing with JUnitUnit testing with JUnit
Unit testing with JUnit
 
Understanding Unit Testing
Understanding Unit TestingUnderstanding Unit Testing
Understanding Unit Testing
 

Similaire à Unit testing on embedded target with C++Test

In search of JavaScript code quality: unit testing
In search of JavaScript code quality: unit testingIn search of JavaScript code quality: unit testing
In search of JavaScript code quality: unit testing
Anna Khabibullina
 
Comparative Development Methodologies
Comparative Development MethodologiesComparative Development Methodologies
Comparative Development Methodologies
elliando dias
 
Automation Using Marvin Framework by Sowmya Krishnan
Automation Using Marvin Framework by Sowmya KrishnanAutomation Using Marvin Framework by Sowmya Krishnan
Automation Using Marvin Framework by Sowmya Krishnan
Radhika Puthiyetath
 
Measurement .Net Performance with BenchmarkDotNet
Measurement .Net Performance with BenchmarkDotNetMeasurement .Net Performance with BenchmarkDotNet
Measurement .Net Performance with BenchmarkDotNet
Vasyl Senko
 
Unmanaged Parallelization via P/Invoke
Unmanaged Parallelization via P/InvokeUnmanaged Parallelization via P/Invoke
Unmanaged Parallelization via P/Invoke
Dmitri Nesteruk
 

Similaire à Unit testing on embedded target with C++Test (20)

Full Stack Unit Testing
Full Stack Unit TestingFull Stack Unit Testing
Full Stack Unit Testing
 
How to fake_properly
How to fake_properlyHow to fake_properly
How to fake_properly
 
Infrastructure testing with Molecule and TestInfra
Infrastructure testing with Molecule and TestInfraInfrastructure testing with Molecule and TestInfra
Infrastructure testing with Molecule and TestInfra
 
In search of JavaScript code quality: unit testing
In search of JavaScript code quality: unit testingIn search of JavaScript code quality: unit testing
In search of JavaScript code quality: unit testing
 
Comparative Development Methodologies
Comparative Development MethodologiesComparative Development Methodologies
Comparative Development Methodologies
 
Automation Using Marvin Framework by Sowmya Krishnan
Automation Using Marvin Framework by Sowmya KrishnanAutomation Using Marvin Framework by Sowmya Krishnan
Automation Using Marvin Framework by Sowmya Krishnan
 
Unit testingandcontinousintegrationfreenest1dot4
Unit testingandcontinousintegrationfreenest1dot4Unit testingandcontinousintegrationfreenest1dot4
Unit testingandcontinousintegrationfreenest1dot4
 
Performance and Scalability Testing with Python and Multi-Mechanize
Performance and Scalability Testing with Python and Multi-MechanizePerformance and Scalability Testing with Python and Multi-Mechanize
Performance and Scalability Testing with Python and Multi-Mechanize
 
QTP Online Training
QTP Online Training QTP Online Training
QTP Online Training
 
QTP Training
QTP TrainingQTP Training
QTP Training
 
Measurement .Net Performance with BenchmarkDotNet
Measurement .Net Performance with BenchmarkDotNetMeasurement .Net Performance with BenchmarkDotNet
Measurement .Net Performance with BenchmarkDotNet
 
Unmanaged Parallelization via P/Invoke
Unmanaged Parallelization via P/InvokeUnmanaged Parallelization via P/Invoke
Unmanaged Parallelization via P/Invoke
 
Tdd with python unittest for embedded c
Tdd with python unittest for embedded cTdd with python unittest for embedded c
Tdd with python unittest for embedded c
 
Matlab isim link
Matlab isim linkMatlab isim link
Matlab isim link
 
Static code analysis: what? how? why?
Static code analysis: what? how? why?Static code analysis: what? how? why?
Static code analysis: what? how? why?
 
Node.js behind: V8 and its optimizations
Node.js behind: V8 and its optimizationsNode.js behind: V8 and its optimizations
Node.js behind: V8 and its optimizations
 
JavaScript Robotics
JavaScript RoboticsJavaScript Robotics
JavaScript Robotics
 
Hadoop: Code Injection, Distributed Fault Injection
Hadoop: Code Injection, Distributed Fault InjectionHadoop: Code Injection, Distributed Fault Injection
Hadoop: Code Injection, Distributed Fault Injection
 
Beyond Unit Testing
Beyond Unit TestingBeyond Unit Testing
Beyond Unit Testing
 
Property Based Testing in PHP
Property Based Testing in PHPProperty Based Testing in PHP
Property Based Testing in PHP
 

Plus de Engineering Software Lab

Amran Tuberi - the damage of cycling to the desert ecosystem
Amran Tuberi - the damage of cycling to the desert ecosystemAmran Tuberi - the damage of cycling to the desert ecosystem
Amran Tuberi - the damage of cycling to the desert ecosystem
Engineering Software Lab
 
Code Coverage in Theory and in practice form the DO178B perspective
Code Coverage in Theory and in practice form the DO178B perspective   Code Coverage in Theory and in practice form the DO178B perspective
Code Coverage in Theory and in practice form the DO178B perspective
Engineering Software Lab
 
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
Engineering Software Lab
 
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורה
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורהPerforce עשרת היתרונות המובילים של מערכת ניהול התצורה
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורה
Engineering Software Lab
 

Plus de Engineering Software Lab (16)

FDA software compliance 2016
FDA software compliance 2016FDA software compliance 2016
FDA software compliance 2016
 
המדריך לכוון חיישן מצב מצערת באופנועי קטמ דגמי הזרקת דלק
המדריך לכוון חיישן מצב מצערת באופנועי קטמ דגמי הזרקת דלקהמדריך לכוון חיישן מצב מצערת באופנועי קטמ דגמי הזרקת דלק
המדריך לכוון חיישן מצב מצערת באופנועי קטמ דגמי הזרקת דלק
 
ועד בית דב כרמי 1
ועד בית דב כרמי 1ועד בית דב כרמי 1
ועד בית דב כרמי 1
 
המסדרת הפכה למגוהצת
המסדרת הפכה למגוהצתהמסדרת הפכה למגוהצת
המסדרת הפכה למגוהצת
 
Amran Tuberi - the damage of cycling to the desert ecosystem
Amran Tuberi - the damage of cycling to the desert ecosystemAmran Tuberi - the damage of cycling to the desert ecosystem
Amran Tuberi - the damage of cycling to the desert ecosystem
 
Parasoft Concerto A complete ALM platform that ensures quality software can b...
Parasoft Concerto A complete ALM platform that ensures quality software can b...Parasoft Concerto A complete ALM platform that ensures quality software can b...
Parasoft Concerto A complete ALM platform that ensures quality software can b...
 
Palamida Open Source Compliance Solution
Palamida Open Source Compliance Solution Palamida Open Source Compliance Solution
Palamida Open Source Compliance Solution
 
Code coverage in theory and in practice form the do178 b perspective
Code coverage in theory and in practice form the do178 b perspectiveCode coverage in theory and in practice form the do178 b perspective
Code coverage in theory and in practice form the do178 b perspective
 
Code Coverage in Theory and in practice form the DO178B perspective
Code Coverage in Theory and in practice form the DO178B perspective   Code Coverage in Theory and in practice form the DO178B perspective
Code Coverage in Theory and in practice form the DO178B perspective
 
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
WPF/ XamDataGrid Performance, Infragistics Seminar, Israel , November 2011
 
Parasoft .TEST, Write better C# Code Using Data Flow Analysis
Parasoft .TEST, Write better C# Code Using  Data Flow Analysis Parasoft .TEST, Write better C# Code Using  Data Flow Analysis
Parasoft .TEST, Write better C# Code Using Data Flow Analysis
 
Nunit C# source code defects report by Parasoft dotTEST
Nunit  C# source code  defects report by Parasoft dotTEST Nunit  C# source code  defects report by Parasoft dotTEST
Nunit C# source code defects report by Parasoft dotTEST
 
A Scalable Software Build Accelerator
A Scalable Software Build AcceleratorA Scalable Software Build Accelerator
A Scalable Software Build Accelerator
 
Parasoft fda software compliance part2
Parasoft fda software compliance   part2Parasoft fda software compliance   part2
Parasoft fda software compliance part2
 
Parasoft fda software compliance part1
Parasoft fda software compliance   part1Parasoft fda software compliance   part1
Parasoft fda software compliance part1
 
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורה
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורהPerforce עשרת היתרונות המובילים של מערכת ניהול התצורה
Perforce עשרת היתרונות המובילים של מערכת ניהול התצורה
 

Dernier

Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Victor Rentea
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Victor Rentea
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 

Dernier (20)

How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Platformless Horizons for Digital Adaptability
Platformless Horizons for Digital AdaptabilityPlatformless Horizons for Digital Adaptability
Platformless Horizons for Digital Adaptability
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
 
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor Presentation
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 AmsterdamDEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 

Unit testing on embedded target with C++Test

  • 1. Unit testing in embedded environments with Parasoft C++test
  • 2. Agenda  Introduction  What are the embedded systems  What is Unit Testing  Unit Testing With C++test  General flow  Test cases generation  Unit Testing in Embedded Environments  General flow  Runtime requirements  Building test executable  Pros, Cons, limitations  Questions ....
  • 4. What is an embedded system ? An embedded system is a combination of computer hardware and the software, and perhaps additional mechanical or other parts, designed to perform a specific function. (Michael Barr - Programming Embedded Systems)
  • 5. A generic embedded system Memory Functional devices Inputs Processor Outputs
  • 6. Example 1 - VCR VCR can be made of:  8 bit processor  ROM and RAM  Mechanical components  Analog modules for signal processing  Platform targeted operating system
  • 7. Example 2 - Opportunity Opportunity:  CPU RAD6000 (RISC)  128 MB DRAM  3 MB EEPROM  256 MB FLASH  Running on VxWORKS (WindRiver) operating system
  • 8. Example 3 - Pendolino Composed of many sub systems running on different hardware platforms and different operating systems
  • 9. Development process Host Machine CPU deployment Cross development environment Target Platform MEM
  • 10. Unit Testing In computer programming, a unit test is a procedure used to validate that a particular module of source code is working properly. The procedure is to write test cases for all functions and methods so that whenever a change causes a regression, it can be quickly identified and fixed. (www.wikipedia.org)
  • 11. Unit testing with C++test -test flow -test harness architecture -test cases -regression testing
  • 12. Unit Testing with C++test  Automatic test cases generation  Test cases in a form of source code  Coverage metrics  Post-Conditions recording for regression testing  Automatic Stubs configuration  Automatic test flow management  Command line mode  Convenient reporting system
  • 13. From source code to test results test results C++test instrumented source Parser user source code Instr Generator Test Cases test cases Test Generator source Executable runtime library libraries Libraries Scanner stub source Stub Manager
  • 14. Tests architecture - example #include <header> int funcB(); int funcA(int b) { int a = funcB(); return a + b; }
  • 15. Tests architecture - example Test Executable test runner main() { instrumented code call_test_case Int funcA(int a) { .....} instr_callback(); int b = funcB_stub(); instr_callback(); return a + b; } test_case { pre_cond Stubs funcA() funcB_stub() { post_cond return 0; } }
  • 17. Test cases architecture Test case is composed of TestSuite_MyClass::test_foo_0() three sections: { //PreCondition initialization int arg_1 = 0; MyClass testObject();  Pre conditions setup //Tested function call  Tested function call int ret = testObject.func(arg1);  Post conditions //PostConditions validation validation CPPTEST_ASSERT(ret == 1) }
  • 18. Automatic test cases generation C++test's test cases generator automatically produces source elements for: Initializing pre-conditions like: function arguments, global variables, 'this' object for tested function Calling the tested function or method Validating post-conditions (achieved test result)
  • 19. Initialization strategies  Simple (built-in) types:  Integers (-1,0,1, min, max value)  Floating point (-1.0, 0.0, 1.0, max, min positive, max, min negative)  Heuristic values  Complex types (user defined types) C++test will use available constructors and generate code necessary to initialize constructors arguments.
  • 20. Initialization strategies  Pointer types:  NULL pointer  address of a local object created on stack  address of an object created with “new” (on heap)  Reference types:  local object created on stack  object created using operator “new”  Heuristic values for simple types:  int  float  char *
  • 21. Post conditions C++test provides macros and routines for controlling how source code test results are collected and validated: Test case post-conditions are controlled via assertion macros (similar to CppUnit)  CPPTEST_ASSERT_INTEGER_EQUAL(expected,actual) Assertions perform a condition validation and send results back to C++test
  • 22. Test case example with post-conditions /* CPPTEST_TEST_CASE_BEGIN test_bufLen_0 */ void TestSuite_bufLen_0::test_bufLen_0() { /* Pre-condition initialization */ /* Initializing argument 0 (this) */ /* Initializing constructor argument 1 (fill) */ char _fill_0 = '001'; ::Data _cpptest_TestObject (_fill_0); /* Tested function call */ int _return = _cpptest_TestObject.bufLen(); /* Post-condition check */ CPPTEST_ASSERT_INTEGER_EQUAL(4, ( _return )) CPPTEST_ASSERT(( _cpptest_TestObject._data ) != 0) }
  • 23. Regression test cases generation subsequent test runs generation Test results Test cases Validation Testing generation First test execution Test cases Regression test cases
  • 24. Stubs
  • 25. Stubs – handling missing definitions Instrumented Libraries source code & object files Auto generated stubs int func2() { return 0; } extern int func2(); int func1(int b) User defined { stubs int a = func2(); return a + b; }
  • 26. Stubs in C++test  Stubs are used:  when testing in separation from other modules  when application module is not yet ready  when hardware module is not yet ready  C++test provides three modes for stubbed function:  original  user-defined  auto-generated  Stubs configuration is managed from C++test GUI and persisted in C++test project
  • 27. Unit Testing in embedded environments -test flow -runtime library -problems & limitations -why to unit test on target ?
  • 28. Unit testing in embedded environment C++test runtime Cross Compiler runtime linker/locator library library source Test executable Test Test harness harness binaries source deploy code host - target communication results
  • 29. Unit testing in embedded environment Host Development env Target C++test deploy Test executable Runtime library Listening communication agent communication channel module
  • 31. C++test runtime library  Provided in form of source code  Implemented in plain C  Needs to be cross-compiled for specific target platform  Contains definition of communication channel Provided implementations:  file  TCP/IP sockets  Designed to be easily customizable
  • 33. Target-to-host communication module  Custom implementation of communication channel can be plugged in  Defining communication channel requires implementing four methods:  cpptestInitializeCommunication(...);  cpptestFinalizeCommunication(...);  cpptestSendData(const char* data, unsigned size);  All data transfer operations, performed inside C+ +test runtime library are implemented in terms of above interface
  • 34. Collecting results on target Host Target C++test Test executable Manual results Runtime library transfer File communication System module Local Storage
  • 35. “On the fly” results transfer Host Target C++test TCP/IP Sockets Test executable RS 232 RS 485 I2C ICE Runtime library File Listening communication System agent communication channel module
  • 37. Exceptions handling  C++test uses Test cases execution sequence exceptions handling facilities (try, catch, Test setjmp, longjmp, case 1 signal) to recover if exception is thrown exception during test sequence handling enabled Test With exceptions case 2 (e.g divide by zero)  If target platform does not provide exceptions handling, test sequence Test is broken on first case n exception and needs to be restarted
  • 39. Test flow automation  Test sequence can be automatically performed in C++test GUI as well as in command line mode  Test sequence consists of test harness preparation, building test executable, deploying test executable, starting it, and collecting results  Limitations in automation of testing process can be imposed be development environment  C++test provides easy to use XML-based format for defining test framework operations
  • 41. Problems & limitations  Not enough memory on the target device to store test harness and tested code may block or limit testing capabilities Compilation without debug information Original file Min Instr Med Instr Max Instr GNU GCC 3.2 22 KB 22 KB (0%) 29 KB (30%) 41 KB (80%) MSVC++ 7.1 33 KB 33 KB (0%) 41 KB (24%) 69 KB (100%) Tornado simpc 23 KB 23 KB (0%) 30 KB (30%) 41 KB (78%)
  • 42. Problems & limitations  Lack of communication channel may effect in weak test automation  Missing support for exceptions handling may increase the number of runs necessary to execute test cases scheduled for test session.  Additional amount of work required during development process
  • 43. Why to unit test on target ?
  • 44. Pros of unit testing on target  All well known positives from host-based unit testing (early bugs detection, increased code robustness, ...)  Possibility of detecting hardware problems  Possibility of detecting software/hardware interaction problems  Easy stubbing of missing software (also hardware) modules  Quick and automated generation of regression suites
  • 45. Unit testing in embedded environment - example static int iTemperatures[2];  “Critical section” void interrupt vReadTemperatures(void) { related bugs are hard ITemperatures[0] = /*Read sensor 1*/ to detect during host- ITemperatures[1] = /*Read sensor 2*/ based unit testing }  Target-based unit bool testSensors() { testing highly increases int iTemp0, iTemp1; probability of catching iTemp0 = ITemperatures[0]; this kind of problems, iTemp1 = ITemperatures[1]; if (iTemp0 != iTemp1) { // Alarm !!! however it does not return -1; provide 100% certainty } of catching them. return 0; }
  • 46. Unit testing in embedded environment - example  Module for driving the position of functional mechanical equipment servo  Hardware contains “stuck-at- encoder zero” problem between the encoder and board interface int set_position(int angl) { if (angl < MIN || angl > MAX) { return INCORRECT_ANGL; } return run_servo(angl); }
  • 47. Epilog C++test offers a high level of automation for tasks which are usually performed manually, especially in embedded environments, therefore very often it lets us give the positive answer for a question: “to test ? or not to test ?”