VIEWPOINT
Testing IoT Applications - A Perspective
- Manjunatha Gurulingaiah Kukkuru, Principal Research Analyst
         Introduction
         The Internet of Things (IoT) is a network of physical objects (devices, vehicles, buildings, and other items) that are embedded with electronics,
         software, sensors, and network connectivity to collect and exchange data.
         According to a recent report by McKinsey, around 30 billion objects may be connected through IoT by 2020.
         Enterprises are adopting IoT solutions for the benefits they offer; such as, optimization in operations, reduction in costs, and improvement
         in efficiency. The development and adoption of IoT is being driven by multiple factors, including easily available low-cost sensors, increase
         in bandwidth and processing power, wide-spread usage of smartphones, availability of big data analysis tools, and scalability of internet
         protocol version 6. Organizations are now starting to focus on external benefits such as generating revenues from IoT-enabled products,
         services, and customer experiences.
         IoT: A web of interconnected layers
         The following figure indicates a reference architecture for IoT, comprising of multiple layers built on top of each other to create industry-
         specific solutions. The components in each layer include devices, protocols, and modules that need to work in sync in order to effectively
         convert data to information, and subsequently to insights.	
                                                                                                                                                                                             Domains
              Smart Grid    Manufacturing       Logistics     Agriculture         Buildings      Healthcare         Retail          Residences             Oil            Mining            Pharma
                                                                                                                                                                                 Class of Applications
                                                                                                                                                                                        Risk, Fraud &
              Resource            Tracking &        Site & Employee          Remote                Remote                               Process Visibility         Predictive
                                                                                                                   eTraceability                                                          Warranty
              Efficeincy            Tracing               Safety            Monitoring          Visualization                            & Automation               Analtics
                                                                                                                                                                                          Analytics
                                                                                                                                                                                Data Processing Layer
                           Device management                            Location /            Command Center             Presence                            Analtics and Machine Learning
                                                                        Geo Fence
                    Location    Provisioning Remote Mgmt                                                                                                             Big Data Storage
                  Access mgmt Activation      Diagnostics               Workflow                   Maps              Communication
                      Policy                       Report               Ticketing               User Mgmt                Database                      Machine Learning               Analytics
                                         Complex Event Processor                                                                                     Data Mangement
                                               Data Transformation                                                                 Cmd Interpreter               Data Ingest & Transfromation Layer
                                                                                         Protocol Adapter
                                                            Que                                                                Listner
                                                    Wi-Fi                   LAN                    WAN                 Satellite                 Cellular
                                                                                                                                                                                              Devices
               Base Stations / Readers
                       LLRP                        MODBUS                          Zigbee                       BACNet                               ZPL                            SNMP
               Connected Machines              Barcode        Sensors         RFID        Smart Phone           Actuators           Drones           GPS           Wearables        Smart Meters
         • Device layer: Consists of various devices                        actuators, wearables, RFID, etc., received                       matching, etc. Additionally, multiple
           like sensors, wearables, smart meters,                           via TCP/IP socket communication or                               APIs for geo-maps, reporting, ticketing,
           radio frequency identification (RFID)                            messaging queues like MQTT, AMQP,                                device provisioning, communication,
           tags, smartphones, drones, etc. With                             CoAP, DDS, Kafka, and HTTP / HTTPS over                          and various other modules aid in quick
           such a diverse set of devices, a huge set                        Rest API.                                                        creation of dashboards.
           of standard and custom communication
           protocols — including ZigBee, BACnet,                        • Data processing layer: With data                                 • Applications layer: With the availability
           LLRP, and Modbus — are implemented.                            available from millions of devices,                                of such rich datasets from a multitude
                                                                          performing image, preventive, and                                  of devices, a gamut of applications can
         • Data ingestion and transformation                              predictive analytics on batch-data                                 be developed for resource efficiency,
           layer: Data from the device layer is                           provides meaningful insights. Modules                              tracking and tracing, remote monitoring,
           transformed through different protocols                        like a ‘complex event processor’ enable                            predictive analytics, process visibility and
           to a standard format for further                               the analysis of transformed data by                                automation, etc. and can also be applied
           processing by the data processing                              performing real-time streaming analytics                           to different industries and segments.
           layer. This data could be from sensors,                        — such as filtering, correlation, pattern-
External Document © 2016 Infosys Limited
Unique characteristics and                     Types of IoT testing
requirements of IoT systems                    The complex architecture of IoT systems
                                               and their unique characteristics mandate
Compared to other applications, IoT            various types of tests across all system
applications are characterized by several      components. In order to ensure that the
unique factors, such as:                       scalability, performance, and security of
 • Combination of hardware, sensors,           IoT applications is up to the mark, the
   connectors, gateways, and                   following types of tests are recommended:
   application software in a single            Edge testing
   system
                                               Several emerging, industrial IoT
 • Real-time stream analytics / complex        applications require coordinated, real-
   event processing                            time analytics at the ’edge’ of a network,
                                               using algorithms that require a scale of
 • Support for data volume, velocity,
                                               computation and data volume / velocity.
   variety, and veracity
                                               However, the networks connecting these
 • Visualization of large-scale data           edge devices often fail to provide sufficient
                                               capability, bandwidth, and reliability. Thus,
                                               edge testing is very essential for any IoT
                                               application.
Challenges that thwart IoT
testing                                        Protocol and device interoperability
                                               testing
These characteristics consequently present
                                               IoT communication protocol and device
a unique set of challenges when it comes
                                               interoperability testing involves assessing
to testing IoT applications. The primary
                                               the ability to seamlessly interoperate
challenges include:
                                               protocols and devices across different
 • Dynamic environment: Unlike                 standards and specifications.
   application testing performed in a
                                               Security and privacy testing
   defined environment, IoT has a very
   dynamic environment with millions           This includes security aspects like data
   of sensors and different devices in         protection, device identity authentication,
   conjunction with intelligent software       encryption / decryption, and trust in cloud
                                               computing.
 • Real-time complexity: IoT applications
   can have multiple, real-time scenarios      Network impact testing
   and its use cases are extremely complex     Network impact testing involves
                                               measuring the qualitative and quantitative
 • Scalability of the system: Creating a       performance of a deployed IoT application
   test environment to assess functionality    in real network conditions. This can include
   along with scalability and reliability is   testing IoT devices for a combination of
   challenging                                 network size, topology, and environment
                                               conditions.
Apart from the above challenges,
there exist several factors that present       Performance and real-time testing
operational challenges:
                                               This covers complex aspects like timing
 • Related subsystems and components           analysis, load testing, real-time stream
   owned by third-party units                  analytics, and time-bound outputs, under
                                               the extremes of data volume, velocity,
 • Complex set of uses cases to create test    variety, and veracity.
   cases and data
 • Hardware quality and accuracy               End user application testing
                                               Includes the testing of all functional
 • Security and privacy issues
                                               and non-functional use cases of an IoT
 • Safety concerns                             application, which also includes user
                                               experience and usability testing.
                                                                                               External Document © 2016 Infosys Limited
Infosys IoT Validation solution
Infosys has developed a comprehensive
quality assurance (QA) strategy to handle
the unique requirements and challenges
associated with validating IoT applications.
The Infosys IoT Validation solution enables
testing with a combination of actual
devices, tools, and frameworks. In addition,
the Infosys IoT Test Framework provides
all the capabilities required to perform
functional validation, load simulation, and
security verification. It can easily integrate
with various IoT protocols and platforms,
thus providing interoperability. This is just
a glimpse of our capabilities, as we have
various tools and solutions that can be
leveraged to perform end-to-end testing
of IoT solutions. To find out more about our
IoT services, download the IoT testing flyer
here.
For more information, contact askus@infosys.com
© 2016 Infosys Limited, Bengaluru, India. All Rights Reserved. Infosys believes the information in this document is accurate as of its publication date; such information is subject to change without notice. Infosys
acknowledges the proprietary rights of other companies to the trademarks, product names and such other intellectual property rights mentioned in this document. Except as expressly permitted, neither this
documentation nor any part of it may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, printing, photocopying, recording or otherwise, without the
prior permission of Infosys Limited and/ or any named intellectual property rights holders under this document.
                                                                                                                                                                         Stay Connected