An application testing system may include a recorder that may record test usage of a graphical user interface (GUI) generated by an application under test (AUT). For example, the recorder may store an indication of a user input at the GUI in an automated test script. The application testing system may include a replay component that replays the automated test script to recreate the recorded test usage. For example, the replay component may determine the location of the user input on the GUI based on the automated test script. Thus, the application testing system may automatically recreate the recorded test usage based on a replay of the automated test script.
Features of the present disclosure may be illustrated by way of example and not limited in the following figure(s), in which like numerals indicate like elements, in which:
For simplicity and illustrative purposes, the present disclosure may be described by referring mainly to examples. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present disclosure. It will be readily apparent however, that the present disclosure may be practiced without limitation to these specific details. In other instances, some methods and structures have not been described in detail so as not to unnecessarily obscure the present disclosure.
Throughout the present disclosure, the terms “a” and “an” may be intended to denote at least one of a particular element. As used herein, the term “includes” means includes but not limited to, the term “including” means including but not limited to. The term “based on” means based at least in part on.
Automated testing may determine whether changes to an AUT and/or GUI have affected GUI or other application functionality. Automated test scripts—together with computer vision techniques to identify GUI elements during replay—may facilitate efficient testing of AUTs without having to have knowledge of the underlying GUI or AUT code. An automated testing system may record a snapshot that includes a visual (such as a video or still image) of the replay during the replay session. The recorded snapshot may maintain a record of the replay (the automated test).
However, in many instances, sensitive information may be present in a display space on which the GUI is presented. In these instances, the recorded snapshot may inadvertently include the sensitive information. The sensitive information may be information that a user making the recording does not wish to be included in the snapshot. For example, the sensitive information may include personal information, confidential information, and/or other information a user does not wish to be included in the snapshot. It should be noted that the sensitive information may include text, images, videos, and/or other object that may be visually displayed on the display space (such as an electronic display). The GUI itself may include sensitive information and/or other objects of the display space may include the sensitive information. It should noted that the sensitive information may occupy an area of the display space. Such area may be referred to herein as a “sensitive area.”
To address the foregoing problems relating to automated testing of a GUI, an apparatus may identify and obscure the sensitive information. The apparatus may identify the sensitive information during or after the recording. The apparatus may identify the sensitive information in various ways. For example, the apparatus may identify the sensitive information based on a user input that: identifies an area of the display space (or snapshot) to be obfuscated, identifies a GUI control to be obfuscated, and/or identifies regions not to be obfuscated and to obfuscate all other regions in the display space.
In some examples, the apparatus may automatically identify the sensitive information based on text and/or object recognition. For example, the apparatus may detect text in the display space (or the snapshot) and perform pattern matching with text patterns indicative of sensitive information. In some examples, the apparatus may obtain the text by performing optical analysis such as optical character recognition (OCR) for text contained in images and not presented as clear text in the display space (or snapshot). In some examples, the apparatus may automatically identify the sensitive information by applying machine learning (ML) techniques such as you-only-look-once (YOLO) to train models to detect objects in images that include sensitive information.
In some examples, the apparatus may generate and apply a mosaic to the snapshot so that the sensitive information is obscured. A mosaic may be an electronic alteration to an area of a display space that includes sensitive information to render the sensitive information unreadable or otherwise unrecognizable. Multiple mosaics may be applied as necessary.
Whichever manner or combination of manners is used to identify sensitive information, the apparatus may implement the mosaic in various ways. For example, the apparatus may implement the mosaic by removing pixels associated with the sensitive information, overlaying a screen element (such as an opaque window) onto the sensitive information, encrypting text of the sensitive information, modifying the sensitive information so that the sensitive information is unreadable or unrecognizable, overlaying display elements onto the sensitive areas, and/or modifying pixels through various image processing libraries, such as the OpenCV library available from opencv [dot] [org], the contents of which are incorporated by reference in its entirety herein.
It should be noted that the apparatus may apply the mosaic before, during or after the snapshot is recorded. For example, before or during the recoding, the apparatus may analyze the display space to identify sensitive information and apply the mosaic to the sensitive information on the display space so that the recorded snapshot already includes the mosaic. Alternatively, after the recording, the apparatus may analyze the snapshot to identify sensitive information and apply the mosaic to the sensitive information on the snapshot after the recording.
The apparatus 100 shown in
The apparatus 100 may include a memory 110 that may have stored thereon machine-readable instructions (which may also be termed computer readable instructions) 112-122 that the processor 102 may execute. The memory 110 may be an electronic, magnetic, optical, or other physical storage device that includes or stores executable instructions. The memory 110 may be, for example, Random Access memory (RAM), an Electrically Erasable Programmable Read-Only Memory (EEPROM), a storage device, an optical disc, and the like. The memory 110 may be a non-transitory machine-readable storage medium, where the term “non-transitory” does not encompass transitory propagating signals. Attention will now turn to operations at processor 102 to obfuscate sensitive information in a recorded visual of a replay of an automated test.
Referring to
The processor 102 may fetch, decode, and execute the instructions 114 to initiate a replay session during which the automated test script is to be replayed to automatically recreate the recorded test within a display space (such as display space 201 illustrated in
The processor 102 may fetch, decode, and execute the instructions 118 to identify a portion of the snapshot that includes sensitive information. The processor 102 may identify the portion in various ways, which are described in more detail with respect to
The processor 102 may fetch, decode, and execute the instructions 122 to save the snapshot having the applied mosaic. In this manner, the visual in the snapshot may have the sensitive information obfuscated by the mosaic while being retained for test storage and review.
The replay instructions 230 may cause a processor, such as processor 102 illustrated in
In some examples, the replay instructions 230 may cause the processor to generate a snapshot that includes a visual of the automated test of the GUI 210. For example, the user may initiate a recording of the snapshot through a record or other button of the replay GUI 220. Alternatively, or additionally, the replay instructions 230 may automatically start the recording once the automated test script 207 is replayed. In some examples, the recording may be stopped by the user or automatically stopped. In some examples, the replay snapshot may record the entire replay session.
The snapshot may record all or a portion of the area of the display space 201. Because the display space 201 (including any of the elements such as the GUI 210 or browser 211, replay GUI 220, or other display elements) may include sensitive information 203, the replay instructions 230 may generate a snapshot with mosaic 239. The snapshot with mosaic 239 may include a mosaic applied to, such as being overlaid onto, the snapshot to render the sensitive information unreadable or otherwise unrecognizable. As used herein, the term “overlaid” and similar terms such as “overlay” and “overlaying” may refer to being layered on top of. In a window display environment, for example, a window manager 215 (which may be provided by an operating system to render the display space 201) may overlay the mosaic on top of the GUI 210 by layering a window corresponding to the mosaic on top of a window corresponding to the GUI 210. The mosaic may be applied to the snapshot in other ways as well, such as by modifying or deleting pixels of the snapshot.
In some examples, the replay instructions 230 may (i.e., may cause the processor to) identify the sensitive information 203 (which may also or instead include identifying any sensitive area that includes the sensitive information) to which to apply the mosaic. For example, the replay instructions 230 may do so based on user input 233, automatically based on text patterns 235, or automatically based on ML image models trained based on ML training visuals 237, as will be described with respect to
Various manners in which the apparatus 100 may operate to identify sensitive information 203 to which to apply the mosaic are discussed in greater detail with respect to the methods 300A-300E depicted in
At 314, the processor 102 may identify areas of the display space 201. For example, the processor 102 may consult the window manager 215 to identify visual objects displayed in the display space 201. At 316, the processor may select areas from among the identified areas that are not the excluded area. The selected areas may be those areas to which a mosaic is to be applied. To illustrate, the user may wish to obscure all other parts of the display space 201, such as the user's desktop screen, other than the GUI 210 being tested and the replay GUI 220. The processor 102 may identify all windows and other visual objects other than the GUI 210 and the replay GUI 220 and identify areas occupied by the other visual objects, such as the browser 211. The processor 102 may apply a mosaic to the selected areas occupied by the other visual objects.
At block 324, the processor 102 may identify an area of the display space 201 occupied by the test object. In this example, the portion of the snapshot that includes the sensitive information 203 may be identified based on the area of the display space 201 occupied by the test object.
At block 334, the processor 102 may identify text in a snapshot, such as a visual taken of the display space 201 during a replay of the automated test script 207. In some examples, the processor 102 may perform optical character recognition (OCR) analysis on the snapshot to automatically identify the text. At block 336, the processor 102 may compare the text in the snapshot with text patterns 235. For example, the processor 102 may parse the text in the snapshot with a regular expression that is used to identify URLs.
At block 338, the processor 102 may determine that the text includes sensitive information based on the text patterns 235, and identify a portion of the snapshot for which to apply a mosaic. For example, the processor 102 may recognize a URL in text extracted from the snapshot using OCR analysis. The processor 102 may identify a position of the text in the snapshot and determine that a portion of the snapshot corresponding to the position of the text is to have a mosaic applied thereto.
Other types of images of areas, or regions, of a display space that may include sensitive information 203 may be included in an ML training visual 237 as well. For example, an image of a search bar provided by an operating system may be included in an ML training visual 237 since search input text may be considered private information. Images of areas that usually include usernames, addresses, or other sensitive information may be included in an ML training visual 237 for training an ML model to recognize areas that include sensitive information.
At block 344, the processor 102 may train an ML model based on the ML training visuals 237 that were accessed at block 342. The ML training visuals 237 may include visuals of areas of display spaces (such as display space 201) that include sensitive information (such as sensitive information 203). These areas of display spaces may also be referred to as “sensitive areas.” In some examples, the processor 102 may train the ML model using the training visuals 237 to conduct object detection. The object to be detected may include a sensitive area. In some examples, the object to be detected may include GUI controls that may include a sensitive area. As such, the processor 102 may detect multiple sensitive areas in a given recording of a display space.
In some examples, the object detection technique may include YOLO, YOLO version 2 (YOLOv2), YOLO version 3 (YOLOv3), or other ML object detection techniques. ML training in these examples may include a two-phase approach, in which a classifier network may be trained using the ML training visuals 237. Such training may be performed according to a classifier network such as VGG16, although other classifier networks may be used. In the second phase, the fully connected layers in the classifier network may each be replaced with a convolution layer to generate a convolutional neural network that is retrained with the ML training visuals 237 to create an end-to-end ML model for detecting sensitive areas.
At block 346, the processor 102 may apply the ML model to recognize a region of the display space 201 that includes sensitive information. For example, the processor 102 may input a snapshot that includes a recording of a replay session to the ML model. The processor 102 may execute the ML model to recognize and output various areas on the snapshot that are predicted to include sensitive information (sensitive areas that include the sensitive information) based on the ML training of block 344.
In examples that use trained ML models based on YOLO (and/or its v2 and v3 variants), the processor 102 may divide the snapshot into a set of boxes (such as in a grid configuration). Each box may be input to a set of convolutional layers trained (such as at block 344) to predict class scores and bounding box offsets for bounding boxes that are further divided from an input box of the set of boxes. The ML model may assign a prediction of an object and a confidence score to each of the bounding boxes based on processing through the convolutional layers. The bounding box with the highest confidence score in an input box of the set of boxes may be selected as the representative bounding box for the input box. Thus, the ML model may output, for each input box in the set of boxes (which may be arranged in a grid of boxes), a prediction of the object detected therein and a confidence score for the prediction.
In examples that use object detection techniques, for example, the processor 102 may identify a bounding box in the snapshot that the ML model predicts includes a sensitive area (such as a GUI control or other area of the snapshot of the display space 201). The processor 102 may locate the bounding box in the snapshot. For example, the processor 102 may locate a GUI control, from among various GUI controls, that includes sensitive information at a portion (such as a pixel area or region) of the snapshot and cause a mosaic to be placed at the portion of the snapshot where the GUI control is located. Other portions of the snapshot that include sensitive information may be similarly located.
Regardless of how the processor 102 identifies sensitive areas (or sensitive information) via examples illustrated in
As shown in
At block 404, the processor 102 may replay an automated test script that recorded a test of a GUI, such as GUI 210, on a display space, such as display space 201. At block 406, the processor 102 may identify, during the replay, an area of the display space that includes the sensitive information based on the ML model. For example, the ML model may detect the GUI controls, URL inputs, and/or other objects that the ML model has been trained to detect using the training image data.
At block 408, the processor 102 may generate a snapshot that includes a visual of the display space. The snapshot may include images of the GUI being test and other objects—including objects that may be unrelated to the automated test—displayed on the display space.
At block 410, the processor 102 may apply a mosaic to the snapshot based on the area of the display space that includes the sensitive information. The mosaic may obscure the area of the display space such that the sensitive information is unreadable or otherwise unrecognizable.
The machine-readable instructions 502 may cause the processor to access a user input specifying sensitive areas to be obscured in a visual recording of a replay session in which a graphical user interface (GUI) is to be automatically tested. The visual recording may include visuals (images, videos, etc.) as well as non-visual elements such as audio. The input may include an indication of a fixed area of a display space, such as display space 201, in which the GUI is displayed. In some examples, the input may include an indication to apply a mosaic to any area, other than user-indicated areas, of the display space in which the GUI is displayed. The machine-readable instructions 502 may cause the processor to identify an area, other than the user-indicated area, of the display space, and apply the mosaic to the area.
The machine-readable instructions 504 may cause the processor to perform an automated test of the GUI during the replay session. The machine-readable instructions 506 may cause the processor to generate the visual recording based on the automated test. The machine-readable instructions 508 may cause the processor to apply a mosaic in the visual recording to obscure the sensitive areas. The machine-readable instructions 510 may cause the processor to store the visual recording with the applied mosaic to store a record of the replay session.
What has been described and illustrated herein is an example of the disclosure along with some of its variations. The terms, descriptions and figures used herein are set forth by way of illustration only and are not meant as limitations. Many variations are possible within the spirit and scope of the disclosure, which is intended to be defined by the following claims—and their equivalents—in which all terms are meant in their broadest reasonable sense unless otherwise indicated.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2019/095413 | 7/10/2019 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2021/003697 | 1/14/2021 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6724946 | Kusama | Apr 2004 | B1 |
7917770 | Gopinath | Mar 2011 | B2 |
9298598 | Fryc | Mar 2016 | B2 |
9501657 | Wu | Nov 2016 | B2 |
9986290 | Ayers | May 2018 | B2 |
10204030 | Hockett | Feb 2019 | B1 |
11137871 | Duneau | Oct 2021 | B2 |
20110131551 | Amichai | Jun 2011 | A1 |
20110191676 | Guttman | Aug 2011 | A1 |
20140074452 | Carmi | Mar 2014 | A1 |
20150339213 | Lee | Nov 2015 | A1 |
20160119672 | Alonso | Apr 2016 | A1 |
20180060222 | Kogan | Mar 2018 | A1 |
20180129586 | Gillaspie | May 2018 | A1 |
20180268240 | Loce | Sep 2018 | A1 |
20180336122 | Kogan | Nov 2018 | A1 |
20190087691 | Jelveh | Mar 2019 | A1 |
20190303178 | Mastracci | Oct 2019 | A1 |
20190384699 | Arbon | Dec 2019 | A1 |
20200104244 | Christen | Apr 2020 | A1 |
20200151617 | Chauhan | May 2020 | A1 |
20200159644 | Beltran | May 2020 | A1 |
20200306638 | Fear | Oct 2020 | A1 |
20200356469 | Gupta | Nov 2020 | A1 |
20200380160 | Kraus | Dec 2020 | A1 |
Number | Date | Country |
---|---|---|
104408686 | Mar 2015 | CN |
107145800 | Sep 2017 | CN |
107330848 | Nov 2017 | CN |
108038396 | May 2018 | CN |
108491729 | Sep 2018 | CN |
109145248 | Jan 2019 | CN |
109359043 | Feb 2019 | CN |
101936802 | Jan 2019 | KR |
Entry |
---|
Chien-Hung Liu, Capture-Replay Testing for Android Applications, 2014, pp. 1-4. https://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=6846085 (Year: 2014). |
Richard Mcpherson, Defeating Image Obfuscation with Deep Learning, 2016, pp. 1-4. chrome-extension://efaidnbmnnnibpcajpcglclefindmkaj/https://arxiv.org/pdf/1609.00408.pdf (Year: 2014). |
Mattia Fazzini, From Manual Android Tests to Automated and Platform Independent Test Scripts, 2016, pp. 1-10. chrome-extension://efaidnbmnnnibpcajpcglclefindmkaj/https://arxiv.org/pdf/1608.03624 (Year: 2016). |
Jonathan A. Saddler, EventFlowSlicer: A Tool for Generating Realistic Goal-Driven GUI Tests, 2017, pp. 1-6. https://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=8115711 (Year: 2017). |
English translation, Bekmambetov (CN 109145248 A), pp. 1-19, 2019. (Year: 2019). |
Author Unknown: Open CV; “Draw a Blurring Rectangle”; https://answers.opencv.org/question/71102/draw-a-blurring-rectangle/; May 7, 2019; 3 pages. |
Shalini Gupta: Software Testing Strategy for Protection of Real Data; https://www.computerweekly.com/tip/Software-testing-strategy-for-protection-of-real-data; May 7, 2019; 4 pages. |
Number | Date | Country | |
---|---|---|---|
20220229764 A1 | Jul 2022 | US |