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(link is external).

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

May 06, 2025

Google is rolling out an updated Gemini 2.5 Pro model with significantly enhanced coding capabilities.

May 06, 2025

BrowserStack announced the acquisition of Requestly, the open-source HTTP interception and API mocking tool that eliminates critical bottlenecks in modern web development.

May 06, 2025

Jitterbit announced the evolution of its unified AI-infused low-code Harmony platform to deliver accountable, layered AI technology — including enterprise-ready AI agents — across its entire product portfolio.

May 05, 2025

The Cloud Native Computing Foundation® (CNCF®), which builds sustainable ecosystems for cloud native software, and Synadia announced that the NATS project will continue to thrive in the cloud native open source ecosystem of the CNCF with Synadia’s continued support and involvement.

May 05, 2025

RapDev announced the launch of Arlo, an AI Agent for ServiceNow designed to transform how enterprises manage operational workflows, risk, and service delivery.

May 01, 2025

Check Point® Software Technologies Ltd.(link is external) announced that its Quantum Firewall Software R82 — the latest version of Check Point’s core network security software delivering advanced threat prevention and scalable policy management — has received Common Criteria EAL4+ certification, further reinforcing its position as a trusted security foundation for critical infrastructure, government, and defense organizations worldwide.

May 01, 2025

Postman announced full support for the Model Context Protocol (MCP), helping users build better AI Agents, faster.

May 01, 2025

Opsera announced new Advanced Security Dashboard capabilities available as an extension of Opsera's Unified Insights for GitHub Copilot.

May 01, 2025

Lineaje launched new capabilities including Lineaje agentic AI-powered self-healing agents that autonomously secure open-source software, source code and containers, Gold Open Source Packages and Gold Open Source Images that enable organizations to source trusted, pre-fixed open-source software, and a software crawling and analysis engine, SCA360, that discovers and contextualizes risks at all software development stages.

April 30, 2025

Lenses.io announced the release of Lenses 6.0, enabling organizations to modernize applications and systems with real-time data as AI adoption accelerates.

April 30, 2025

Sonata Software has achieved Amazon Web Services (AWS) DevOps Competency status.

April 29, 2025

vFunction® announced significant platform advancements that reduce complexity across the architectural spectrum and target the growing disconnect between development speed and architectural integrity.

April 29, 2025

Sonatype® introduced major enhancements to Repository Firewall that expand proactive malware protection across the enterprise — from developer workstations to the network edge.

April 29, 2025

Aqua Security introduced Secure AI, full lifecycle security from code to cloud to prompt.