Go Beyond Stubbing and Mocking: Discover Service Virtualization - Part 2
May 09, 2023

Adam Attanasio
Parasoft

Service virtualization (SV) is a method that DevOps teams use to simulate components of an app's behavior. Using SV saves time, money, headache, and frustration. DevOps teams don't end up with an "us vs. them" attitude when development grinds to a halt while waiting for their fellow team members to complete their part of it.

Start with: Go Beyond Stubbing and Mocking: Discover Service Virtualization - Part 1

Test Environments: Real Vs. Virtual

As a developer, you need to produce working software. The software components often have to integrate or interact with other software. Application testing often happens in a production environment, which may present risks and cause delays.

When developing software, you want the application to be as ready as possible before exposing it to the real world. In production, the software needs to be able to deal with many different scenarios, which we can prepare for using a virtual test environment that mimics the actual system. 

When designing the software to handle all expected situations and to be capable of managing unexpected ones, you need to address multiple potential circumstances.

■ What happens if you put tremendous pressure on the software?

■ What if one of the components becomes incapacitated?

■ Will you still be able to achieve the defined goals if something unexpected happens?

By taking control over your test conditions with a virtual test environment, you make it easier to fully test and verify your application's tasks and ensure that it meets the necessary standards for deployment. This results in lower costs, higher productivity, and faster delivery to production.

Automating Load and Performance Testing

Performance testing in the form of load testing, scalability, and stress testing is already a core quality practice, but for many teams, it's largely limited to manual ad hoc tests that get "kicked off" when the system and environment are configured for testing. The goal is to get as close to production levels as possible, but it all also means a significantly longer feedback loop.

Continuous load testing is a type of software development testing that involves subjecting a computer system, network, or web application to a continuous stream of load or traffic to determine how it performs under sustained use. The purpose of continuous load testing is to identify and fix performance issues early before they balloon and impact users or customers.

Continuous load and performance testing are often used together to continuously monitor and improve the performance and stability of a system or application. This can involve automating the testing process and integrating it into the development and deployment pipelines so that the system or application is tested at various stages of its life cycle.

Modern performance testing introduces new principles driven by test automation. Service virtualization makes it possible for you to establish a reusable test environment that can be reset to a known state so that different load and performance testing conditions can be executed and evaluated.

Service Virtualization Examples

Example 1. Your team is working on a large, complex legacy app with many dependencies. The present test coverage is low, in particular when the system dependencies are consistently not available.

Service virtualization enables you to log traffic when the dependencies become available. As a result, the team can later test with virtual services if you replay the traffic. This reduces the impact of the dependencies' downtime for the team and the testers.

Example 2. Your team is working in a microservices-type architecture. One department has 10 testers and 20 developers. The group is in charge of delivering 70 small apps, which form a product.

Working teams test the applications individually and in isolation. While your team's CI/CD system works well, the outside environment is not agile. Their APIs are slow and are often not available, which makes it difficult to set up test data.

To solve the issue, each team that interfaces with the third parties uses SV tools, and the acceptance testers use them during the CI build. The developers also use them for manual exploratory tests. The team then uses the tools in the primary integration build which runs all the applications. Finally, the performance test teams use the SV tools in the full stack performance tests.

The Benefits and Challenges of Service Virtualization

The many benefits of using service virtualization include:

■ Establishes a commonality so development teams can communicate with their fellow development and test teams and share artifacts. Teams also can readily exchange SV assets within the company.

■ Easy to learn, even for non-IT people, so developers can continue their work while testers use SV to test all aspects of a project, with the resulting reduction in labor costs.

■ Supports many protocols and can record traffic for them. Ideally, these traffic recordings can be used to automatically generate virtual assets.

■ Reduces dependence on the availability of third-party components and there are no service charges for third-party databases, APIs, or services.

■ Reduces time to market because SV lessens testing, and therefore, development time.

■ Increases quality because testing is more thorough and accurate.

Some people say using service virtualization presents too many challenges. The right tool can provides solutions.

Challenge: "As opposed to testers or developers creating a stub or mock to test the project, don't SV tools cost more?"

Solution: Not using SV complicates testing and adds to expenses. Having a virtual asset that accurately behaves and responds like the actual downstream service can accelerate testing and reduce costs, rapidly offsetting any tool investment expense.

Challenge: "SV systems are large and may not be right for my small company."

Solution: Smaller organizations can see big benefits from service virtualization, since it can save both time and money for testing complex applications and distributed systems. Deploy only what you need to get started and scale up as you grow.

Challenge: "To avoid a poor user experience, how can my company make sure the service virtualization package I choose is right for my needs?"

Solution: Review the aspects to consider for selecting the right service virtualization tool for your company's requirements in this whitepaper.

Summary

Better than mocks and stubs, service virtualization serves your company well because it enables continuous testing, it's more sharable, and it's reusable. When added to your CI/CD workflow, SV reduces costs and shortens the time to market. You can increase your confidence that applications meet your business goals and technical requirements when you control your test data and environment.

Learn more about how companies deploy service virtualization as part of their software testing strategies at the Automated Software Testing & Quality Summit, hosted by Parasoft on May 16.


Adam Attanasio is a Product Manager at Parasoft
Share this

Industry News

January 16, 2025

Mendix, a Siemens business, announced the general availability of Mendix 10.18.

January 16, 2025

Red Hat announced the general availability of Red Hat OpenShift Virtualization Engine, a new edition of Red Hat OpenShift that provides a dedicated way for organizations to access the proven virtualization functionality already available within Red Hat OpenShift.

January 16, 2025

Contrast Security announced the release of Application Vulnerability Monitoring (AVM), a new capability of Application Detection and Response (ADR).

January 15, 2025

Red Hat announced the general availability of Red Hat Connectivity Link, a hybrid multicloud application connectivity solution that provides a modern approach to connecting disparate applications and infrastructure.

January 15, 2025

Appfire announced 7pace Timetracker for Jira is live in the Atlassian Marketplace.

January 14, 2025

SmartBear announced the availability of SmartBear API Hub featuring HaloAI, an advanced AI-driven capability being introduced across SmartBear's product portfolio, and SmartBear Insight Hub.

January 14, 2025

Azul announced that the integrated risk management practices for its OpenJDK solutions fully support the stability, resilience and integrity requirements in meeting the European Union’s Digital Operational Resilience Act (DORA) provisions.

January 14, 2025

OpsVerse announced a significantly enhanced DevOps copilot, Aiden 2.0.

January 13, 2025

Progress received multiple awards from prestigious organizations for its inclusive workplace, culture and focus on corporate social responsibility (CSR).

January 13, 2025

Red Hat has completed its acquisition of Neural Magic, a provider of software and algorithms that accelerate generative AI (gen AI) inference workloads.

January 13, 2025

Code Intelligence announced the launch of Spark, an AI test agent that autonomously identifies bugs in unknown code without human interaction.

January 09, 2025

Checkmarx announced a new generation in software supply chain security with its Secrets Detection and Repository Health solutions to minimize application risk.

January 08, 2025

SmartBear has appointed Dan Faulkner, the company’s Chief Product Officer, as Chief Executive Officer.

January 07, 2025

Horizon3.ai announced the release of NodeZero™ Kubernetes Pentesting, a new capability available to all NodeZero users.

January 06, 2025

GitHub announced GitHub Copilot Free.