Automated test input generation for integration testing of microservice-based web applications

US11640350B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11640350-B2
Application numberUS-202117401618-A
CountryUS
Kind codeB2
Filing dateAug 13, 2021
Priority dateAug 5, 2016
Publication dateMay 2, 2023
Grant dateMay 2, 2023

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Techniques for automated generation of inputs for testing microservice-based applications. In one example, a computer-implemented method includes: traversing, by a system operatively coupled to a processor, a user interface of a microservices-based application by performing actions on user interface elements of the user interface; and generating, by the system, an aggregated log of user interface event sequences and application program interface call sets based on the traversing. The computer-implemented method also includes: determining, by the system, respective user interface event sequences that invoke the application program interface call sets; and generating, by the system, respective test inputs based on the respective user interface event sequences that invoke the application program interface call sets.

First claim

Opening claim text (preview).

What is claimed is: 1. A system comprising: a memory that stores computer executable components; and a processor that executes the computer executable components stored in the memory, wherein the computer executable components comprise: an event sequence component that determines user interface event sequences that invoke application program interface call sets of an annotated application program interface call graph associated with a microservices-based application, wherein one or more edges of the annotated application program interface call graph are annotated with coverage indications of the user interface event sequences; a coverage component that, based on a determination that the coverage indications do not cover a threshold amount of the annotated application program interface call graph, performs a traversal of a user interface of the microservices-based application with one or more mutated user interface event sequences based on one or more mutations of the user interface event sequences. 2. The system of claim 1 , wherein the coverage component further determines a user interface event sequence for mutation that is associated with an edge of the annotated application program interface call graph that is not annotated with a coverage indication. 3. The system of claim 1 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter. 4. The system of claim 1 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter value. 5. The system of claim 1 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by deletion of a user interface event of a user interface event sequence that contributes at least one parameter to invocation of an externally visible application program interface. 6. The system of claim 1 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by addition of an additional user interface event to a user interface event sequence that contributes at least one additional parameter to invocation of an externally visible application program interface. 7. The system of claim 1 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by modification of at least one data value of at least one user interface event of a user interface event sequence. 8. A computer-implemented method comprising: determining, by a system operatively coupled to a processor, user interface event sequences that invoke application program interface call sets of an annotated application program interface call graph associated with a microservices-based application, wherein one or more edges of the annotated application program interface call graph are annotated with coverage indications of the user interface event sequences; based on a determination that the coverage indications do not cover a threshold amount of the annotated application program interface call graph, performing, by the system, a traversal of a user interface of the microservices-based application with one or more mutated user interface event sequences based on one or more mutations of the user interface event sequences. 9. The computer-implemented method of claim 8 further comprising determining, by the system, a user interface event sequence for mutation that is associated with an edge of the annotated application program interface call graph that is not annotated with a coverage indication. 10. The computer-implemented method of claim 8 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter. 11. The computer-implemented method of claim 8 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter value. 12. The computer-implemented method of claim 8 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by deletion of a user interface event of a user interface event sequence that contributes at least one parameter to invocation of an externally visible application program interface. 13. The computer-implemented method of claim 8 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by addition of an additional user interface event to a user interface event sequence that contributes at least one additional parameter to invocation of an externally visible application program interface. 14. The computer-implemented method of claim 8 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by modification of at least one data value of at least one user interface event of a user interface event sequence. 15. A computer program product for automatically generating test inputs for testing of a microservices-based application, the computer program product comprising a computer readable storage medium having program instructions embodied therewith, the program instructions executable by a processing component to cause the processing component to: determine user interface event sequences that invoke application program interface call sets of an annotated application program interface call graph associated with the microservices-based application, wherein one or more edges of the annotated application program interface call graph are annotated with coverage indications of the user interface event sequences; based on a determination that the coverage indications do not cover a threshold amount of the annotated application program interface call graph, perform a traversal of a user interface of the microservices-based application with one or more mutated user interface event sequences based on one or more mutations of the user interface event sequences. 16. The computer program product of claim 15 , wherein the program instructions are further executable by the processing component to cause the processing component to: determine a user interface event sequence for mutation that is associated with an edge of the annotated application program interface call graph that is not annotated with a coverage indication. 17. The computer program product of claim 15 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter. 18. The computer program product of claim 15 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated to invoke an externally visible application program interface with at least one different parameter value. 19. The computer program product of claim 15 , wherein a mutated user interface event sequence of the one or more mutated user interface event sequences is mutated by deletion of a user interface event of a user interface event sequence that contributes at least on

Assignees

Inventors

Classifications

  • Environments for analysis, debugging or testing of software · CPC title

  • G06F9/451Primary

    Execution arrangements for user interfaces · CPC title

  • Graphs; Linked lists (G06F16/9027 takes precedence) · CPC title

  • Interaction with lists of selectable items, e.g. menus · CPC title

  • Data logging (G06F11/14, G06F11/2205 take precedence) · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US11640350B2 cover?
Techniques for automated generation of inputs for testing microservice-based applications. In one example, a computer-implemented method includes: traversing, by a system operatively coupled to a processor, a user interface of a microservices-based application by performing actions on user interface elements of the user interface; and generating, by the system, an aggregated log of user interfa…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F11/3698. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue May 02 2023 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).