Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/virtualansoftware/virtualan
Virtualan is an open source-based Open API Interface driven Service virtualization tool. Virtualan - Mock service developed on top of the spring boot framework. Any Rest API can be converted as Virtual service in minutes using annotations. Annotations: @VirtualService & @ApiVirtual
https://github.com/virtualansoftware/virtualan
automation automation-test dynamicstubbing mock servicevirtualisation shiftleft stub stubbing test-automation testing
Last synced: about 2 months ago
JSON representation
Virtualan is an open source-based Open API Interface driven Service virtualization tool. Virtualan - Mock service developed on top of the spring boot framework. Any Rest API can be converted as Virtual service in minutes using annotations. Annotations: @VirtualService & @ApiVirtual
- Host: GitHub
- URL: https://github.com/virtualansoftware/virtualan
- Owner: virtualansoftware
- License: apache-2.0
- Created: 2019-10-24T04:43:12.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-21T17:27:40.000Z (10 months ago)
- Last Synced: 2024-03-21T18:38:13.207Z (10 months ago)
- Topics: automation, automation-test, dynamicstubbing, mock, servicevirtualisation, shiftleft, stub, stubbing, test-automation, testing
- Language: HTML
- Homepage: https://tutorials.virtualan.io/#/
- Size: 87.1 MB
- Stars: 9
- Watchers: 2
- Forks: 3
- Open Issues: 37
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Virtualan
**virtualan-plugin:** [![Maven Central](https://img.shields.io/maven-central/v/io.virtualan/virtualan-plugin.svg?label=Maven%20Central)](https://search.maven.org/search?q=g:%22io.virtualan%22%20AND%20a:%22virtualan-plugin%22) **virtualization:** [![Maven Central](https://img.shields.io/maven-central/v/io.virtualan/virtualization.svg?label=Maven%20Central)](https://search.maven.org/search?q=g:%22io.virtualan%22%20AND%20a:%22virtualization%22) [![Build status](https://ci.appveyor.com/api/projects/status/31oxvck9dmghc4iv/branch/master?svg=true)](https://ci.appveyor.com/project/elans3/virtualan/branch/master)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=virtualansoftware_virtualan&metric=alert_status)](https://sonarcloud.io/dashboard?id=virtualansoftware_virtualan)> Virtualan is an open source-based Open API Interface driven, Kafka, AMQ and MQTT Service virtualization product. It supports #OpenAPI, #AsyncAPI test development. This supports #shiftleft testing.
**Product page:** https://www.linkedin.com/products/virtualan-software-virtualan/
**Tutorials:** https://tutorials.virtualan.io/#/Virtualan
**Example:** https://github.com/virtualansoftware/service-virtualization-openapi
**Video:** https://www.youtube.com/watch?v=otTjbPxT0W8
**Docker Image:** https://hub.docker.com/r/virtualan/service-virtualization
**Live demo link:**
## OpenAPI Only:
https://live.virtualandemo.com/virtualan-ui## OpenAPI and SOAP :
https://sforce.virtualandemo.com/virtualan-ui# What is Virtualan :
Virtualan would be built with spring boot framework that would convert API service as Virtualized service in matter of adding couple of annotations. **_Simply as Virtualized service_** which currently supports spring-boot based Rest service(API) with **Spring-RestController** or **CXF-Jaxrs** as Virtualized service with **@VirtualService** and **@ApiVirtual** annotations.**How it could be useful:**
In the Agile world, We need to develop (Micro)services & Test the services in parallel. How can tester or development team can develop or test parallel to all the APIs before the real Microservices would be developed? Here Virtualized service comes into the picture.## **What would be the benefits for?**
### Development team :
* If Services needs to be connected to 1 or more microservices in the development/Testing Environment if the other dependent services would not be available at the time.
* If the dependent services contract had changed then the new changes(implementation) may not be available in day-1 of the sprint.
* If Need to create several use-case scenarios during the development phase even though the dependent service(s) would not be available or not developed yet..
* end etc..### Testing team(Shift left approach) :
* **Start developing automation scripts in day-1** of the sprint in parallel with service implementation* .
* Develop and test right away.
* Prepare all the test scenarios and test cases and **test/validate all the test scripts before the actual service** is ready.
* Tester can create all scenario and including error scenarios and create automated test cases before the service is ready.
* Once the real service is ready, just switch the endpoint to real service and validate all the test-cases in a minutes.
* And etc..**Overview:**
How developer to make and deploy the (newly developing) spring boot application interface with stub as Virtualized service. How this would helps team to proceed with "Shift Left" Strategy.**What is Shift left(Wikipedia):**
Shift left testing is an approach to software testing and system testing in which testing is performed earlier in the lifecycle (i.e., moved left on the project timeline). It is the first half of the maxim "Test early and often."# **How to make my Service As Virtualized :**
Developing a sprint boot(supports from 2.0.1.RELEASE) REST services using Rest Controller or CXF(JAX-RX) can be easily deployed as Virtualized service with three simple steps .### Step (1) : Add the "virtualan-plugin" dependency
• Add "virtualan-plugin" dependency in the pom.xml
io.virtualan
virtualan-plugin
${virtualan.version}
### Step (2) : Add @VirtualService and @ApiVirtual annotations
• @VirtualService - Annotation should be added in the class level
• @ApiVirtual - Annotation should be added in the method level that the API would you like to Virtualize.
### Step (3) : Service Data base setup:
• Add the entries in the **application.properties** of the database to be used to store the test data (Example: hsql with in memory DB).
virtualan.datasource.driver-class-name=
virtualan.datasource.jdbc-url=
virtualan.datasource.username=
virtualan.datasource.password=<>## [License](#table-of-contents)
-------Copyright 2022 Virtualan Contributors (https://virtualan.io)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at [apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0)Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.---