This application claims the benefit of Romanian Patent Application No. a 2016 00988, filed Dec. 8, 2016; the disclosure of which is incorporated herein by reference in its entirety.
The subject matter described in this specification relates generally to test configuration for data communication networks and more particularly to methods, systems, and computer readable media for deploying a networking test tool in a cloud computing system.
Network operators typically test network nodes for reliability and other characteristics before deploying the network nodes in live (e.g., non-test) and/or private networks. While testing a network node before deployment may be beneficial, scenarios exist where testing a network node in a live and/or private network is useful and/or necessary, e.g., for detecting and/or resolving previously undetected issues. However, issues can arise when attempting to configure network nodes for testing in a live and/or private network. In particular, configuring network nodes for testing in a live and/or private network may create or exacerbate security concerns since a test operator may need to traverse firewall and/or network address translation (NAT) devices to communicate with the network nodes.
Conventional solutions, such as secure shell (SSH) or hypertext transfer protocol (HTTP) tunneling, allow test configuration information to traverse firewall devices and NAT devices. However, these solutions are not completely secure because they require the test operator to open ports in the firewall devices (e.g., port ‘80’ for HTTP and port ‘22’ for SSH tunnels). These solutions also require significant product support work because each route which the test configuration information will traverse needs a tunnel. Moreover, HTTP encapsulation is also not preferred because although the operator may allow port ‘80’ to be opened in the firewall devices, content-aware devices can block the traffic. Furthermore, manual setup of public IP endpoints is typically be needed for NAT traversal. Hence, a significant amount of work is generally required for configuring network nodes for testing in a live and/or private network.
Accordingly, a need exists for improved methods, systems, and computer readable media for receiving test configuration information.
Methods, systems, and computer readable media for deploying a networking test tool in a cloud computing system are disclosed. An example method includes receiving user input specifying configuration information for a networking test tool for deployment in a cloud computing system. The user input specifies a range of networking test ports. The method includes deploying a central test server in the cloud computing system and deploying one or more public test agents in the cloud computing system. The method includes configuring the central test server, the one or more public test agents, and one or more private test agents in a network outside the cloud computing system to exchange test traffic using the range of networking test ports specified by the user input. The method includes configuring a firewall for the cloud computing system to open the range of networking test ports in the firewall for the test traffic.
The features described in this specification may be implemented using any appropriate combination of computing components, for example, hardware, software, and firmware. The terms “function” “node” or “module” refer to hardware, which may also include software and/or firmware components, for implementing the feature being described. In some examples, the features described in this specification may be implemented using a computer readable medium storing computer executable instructions that when executed by at least one processor of a computer control the computer to perform operations. Examples of appropriate computer readable media include non-transitory computer-readable media, such as disk memory devices, chip memory devices, programmable logic devices, and application specific integrated circuits. A computer readable medium may be located on a single device or computing platform or may be distributed across multiple devices or computing platforms.
Network environment 100 implements a networking test tool as a central server 112 hosted on cloud computing system 102, one or more public test agents 114 hosted on cloud computing system 102, and one or more private test agents 116 hosted in a private network 110, e.g., executing on a different distributed computing system within private network 110. For example, private network 110 can be an enterprise network.
In some examples, connections may only be opened or initiated by nodes inside private network 110 since security related devices (e.g., firewalls or network address translation (NAT) devices) may not allow inbound connections on ports, e.g., other than test ports. In those examples, private test agents 116 receive test configuration information from central test server 112 via outbound connections or using a proxy node or intermediate node.
The networking test tool is configured to test and verify one or more of various communications performance indicators for communications between at least public test agents 114 and private test agents 116. To protect the public test agents 114 and possibly other applications hosted on cloud computing system 102, cloud computing system 102 includes a firewall 118.
Firewall 118 can be implemented as any appropriate combination hardware and software for selectively blocking instrusive incoming communications. For example, firewall 118 can be configured for blocking incoming communications based on internet protcol (IP) addresses or Transmission Control Procotol (TCP)/User Datagram Protocol (UDP) ports or both. In some examples, firewall 118 is a stateful firewall configured to monitor underlying connections through firewall 118, e.g., to detect communications between certain applications and apply application-specific security policies.
A test administrator 120 can deploy the networking test tool using a user computer device 122 in communication with cloud computing system 102. User computer device 122 can be any appropriate computing system having a user input device, display, processors, and memory, e.g., user computer device 122 can be a laptop or desktop computer or a phone or tablet computer.
In operation, test administrator 120 can execute a web browser on user computer device 122 and navigate to a web site hosted by cloud computing system 102 for deploying applications on cloud computing system 102. Test administrator 120 uses a graphical user interface (GUI) supplied by cloud computing system 102 and displayed on user computer device 122 to deploy central test server 112 and public test agents 114. The private test agents 116 are deployed in private network 110, e.g., by a network administrator of private network 110.
Central test server 112, when deployed, includes a test setup establisher 124, a test execution manager 126, and one or more stored test scripts 128. Test setup establisher 124 is configured for discovering aspects of the networking test tool, e.g., for discovering the number of test agents and the network addresses of the test agents.
Test execution manager 126 manages execution of the test scripts 128, e.g., by sending instructions to public test agents 114 and private test agents 116 and receiving, receiving test result information from public test agents 114 and private test agents 116 (e.g., number of messages successfully received), and validating one or more network performance indicators (e.g., determining whether an error rate is below a threshold rate).
To initiate these network tests, private test agents 116 are configured to be able to initiate TCP or UDP traffic to public test agents 114. However, public test agents 114 may be protected by default by firewall 118, e.g., so that firewall 118 is blocking all incoming traffic on all ports. For this reason, firewall 118 is configured to open some TCP or UDP ports (or both) for the test traffic of the networking test tool. The same ports then are used as destination ports by private test agents 116.
Test administrator 120 can perform the ports configuration manually and post-deployment. For example, once the networking test tool is deployed with both public test agents 114 and private test agents 116, test administrator 120 can choose a range of test traffic ports and proceed with opening them manually in firewall 118 for each public test agent 114. Then, test administrator 120 or another appropriate entity manually configures those same ports as destination ports for each of private test agents 116.
These manual configuration steps, however, can be cumbersome and error-prone, and any mistake would result in failure to run the test traffic. Instead, test administrator 120 can use a network test deployer to automatically configure the appropriate ports. For example, the test traffic ports and the firewall can be configured during deployment, together, so that test administrator 120 need not perform manual configuration post-deployment. Deployment information collection and configuration of the test traffic ports can be done in a single step, i.e., during deployment.
Network test deployer 206 includes a deployment configuration GUI 208, a test agent deployer 210, a server deployer 212, and a firewall configurer 214. GUI 208 can be implemented, e.g., as a web site comprising a series of web pages.
GUI 208 is configured for prompting a user for various types of configuration information, such as resource information specifying one or more cloud computing resources (e.g., processors, memory, storage, networking components) and agent information specifying, e.g., a total number of test agents for the networking test tool. GUI 208 is also configured for prompting the user, during deployment phase and before the networking test tool is deployed, for a range of networking test ports to be used for the test traffic.
Test agent deployer 210 deploys test agents. For example, test agent deployer 210 can deploy test agents by sending commands to a cloud computing system using an application programming interface (API) of the cloud computing system to create test agent instances. Test agent deployer 210 configures test agents to use the specified range of networking test ports to exchange test traffic, e.g., test agent deployer 210 may directly configure public test agents hosted on the cloud computing system.
In general, a test agent is an instance executing on a cloud computing system, but in some examples a test agent can be a network device, a network module, a node, or a system of devices, nodes, and/or modules. For example, a test agent may be an endpoint located behind one or more security related devices, such as a firewall device or a NAT device, in a private network (e.g., a test network or an enterprise network). Test agents can each include a traffic generator and an emulator for emulating one or more network nodes.
For example, a test agent can be programmed to emulate a web server and another test agent can be programmed to emulate a user computer device. The test agents then can generate test traffic (e.g., messages and/or packets) associated with the web server and the user computer device.
In some examples, test agents store test configuration information for setting up and executing a test session. Test configuration information can include the range of networking test ports and other appropriate information such as a list of test participants and a script for generating and sending particular traffic and/or flows to the test participants.
Server deployer 212 deploys a central test server for the networking test tool, e.g., the central test server 112 of
Firewall configurer 214 configures a firewall of the cloud computing system. Firewall configurer 214 opens the range of networking test ports in the firewall for each test agent. After deployment is complete, since the central server and the test agents and the firewall have all been configured with the range of networking test ports, the networking test tool is automatically configured for running the test traffic, without any need for manual post-deployment configuration. In particular, the user need only input the range of networking test ports once, during deployment, thereby reducing the chance of the networking test tool being unable to execute test scripts.
Screen 250 includes a second prompt 254 for a number of test agents to deploy and a third prompt 256 for an instance type of the test agents. The instance type can determine, e.g., what hardware resources will be available to the test agents. Screen 250 includes a fourth prompt 258 for a user to enter a range of networking test ports to use to exchange test traffic. As shown in
Method 300 includes displaying a GUI for networking test tool deployment in a cloud computing system (302). For example, the GUI can be implemented as a series of web pages with instructions and prompts for a test administrator. The test administrator view the GUI on a web browser or other appropriate application executing on a user computer device.
Method 300 includes receiving user input specifying configuration information for a networking test tool for deployment in a cloud computing system (304). The user input specifies at least a range of networking test ports and can specify other appropriate information for the deployment. For example, receiving user input specifying configuration information can include receiving resource information specifying one or more cloud computing resources of the cloud computing system for the networking test tool and receiving agent information specifying a total number of test agents for the networking test tool.
Method 300 includes deploying test agents for the networking test tool (306). Deploying the test agents includes deploying one or more public test agents in the cloud computing system. A network administrator or other entity can deploy one or more private test agents in a network outside the cloud computing system. Deploying the test agents includes configuring the test agents to exchange test traffic using the range of networking test ports specified by the user input.
Method 300 includes configuring a firewall in the cloud computing system to open the range of networking test ports in the firewall for test traffic (308). For example, configuring the firewall can include sending commands to the firewall using an API for the firewall, writing the range of networking test ports to a designated configuration file for the firewall, or sending a request to a system controller for the cloud computing system for the system controller to configure the firewall.
Method 300 includes deploying a central test server in the cloud computing system (310). Deploying the central test server includes configuring the central test server to use the range of networking test ports specified by the user input for exchanging test traffic (312).
In some examples, deploying the central test server includes configuring the central test server to automatically communicate the range of networking test ports to at least a first private test agent in the network outside the cloud computing system, resulting in the first private test agent using a first port in the range of networking test ports as a destination port for sending test traffic to a first public test agent in the cloud computing system.
Method 400 includes selecting a test script for execution (402). For example, selecting a test script can include receiving a selected test script from a test administrator or selecting a test script scheduled to be executed.
Method 400 includes sending test ports, selected from a range of test ports configured during deployment, from the central test server to the private test agents (404). Method 400 includes using the test ports as destination ports for test traffic from the private agents to the cloud computing system (406).
For example, the private test agents can use the test ports as destination ports for the public test agents or for the central test server. Method 400 includes determining test results for the test script (408). For example, determining test results can include validating a measured value of a network performance indicator against a specified target network performance and creating and transmitting or displaying a network test report.
It will be understood that various details of the presently disclosed subject matter may be changed without departing from the scope of the presently disclosed subject matter. Furthermore, the foregoing description is for the purpose of illustration only, and not for the purpose of limitation.
Number | Date | Country | Kind |
---|---|---|---|
a 2016 00988 | Dec 2016 | RO | national |
Number | Name | Date | Kind |
---|---|---|---|
6381218 | McIntyre et al. | Apr 2002 | B1 |
7340771 | Chan et al. | Mar 2008 | B2 |
7594259 | Audet et al. | Sep 2009 | B1 |
8065418 | Abuan et al. | Nov 2011 | B1 |
9052941 | Bone | Jun 2015 | B1 |
9608906 | Constantinescu et al. | Mar 2017 | B2 |
9680877 | Duffield et al. | Jun 2017 | B2 |
9769291 | Nistor et al. | Sep 2017 | B2 |
9814008 | Nistor | Nov 2017 | B2 |
10097442 | Nistor et al. | Oct 2018 | B2 |
10110556 | Nistor | Oct 2018 | B2 |
20020124189 | Bakke | Sep 2002 | A1 |
20040125801 | Nawata | Jul 2004 | A1 |
20040139227 | Takeda | Jul 2004 | A1 |
20040240468 | Chin et al. | Dec 2004 | A1 |
20040255156 | Chan et al. | Dec 2004 | A1 |
20050076235 | Ormazabal | Apr 2005 | A1 |
20050226194 | Fan et al. | Oct 2005 | A1 |
20060062203 | Satapati | Mar 2006 | A1 |
20070044156 | Redmann | Feb 2007 | A1 |
20070083788 | Johnson | Apr 2007 | A1 |
20070213966 | Noble | Sep 2007 | A1 |
20070283002 | Bornhoevd et al. | Dec 2007 | A1 |
20080072312 | Takeyoshi et al. | Mar 2008 | A1 |
20080317020 | Horne | Dec 2008 | A1 |
20090040942 | Yang | Feb 2009 | A1 |
20090077245 | Smelyansky et al. | Mar 2009 | A1 |
20090154363 | Stephens | Jun 2009 | A1 |
20100183151 | Wing et al. | Jul 2010 | A1 |
20100198960 | Kirschnick | Aug 2010 | A1 |
20110010413 | Christenson et al. | Jan 2011 | A1 |
20110187864 | Snider | Aug 2011 | A1 |
20110289440 | Carter et al. | Nov 2011 | A1 |
20120054491 | Tippett | Mar 2012 | A1 |
20120075439 | Gong et al. | Mar 2012 | A1 |
20120078547 | Murdoch | Mar 2012 | A1 |
20120311693 | Horman et al. | Dec 2012 | A1 |
20130173962 | Li et al. | Jul 2013 | A1 |
20130272322 | Sagarwala et al. | Oct 2013 | A1 |
20130343388 | Stroud | Dec 2013 | A1 |
20140119203 | Sundaram et al. | May 2014 | A1 |
20140280901 | Blachandran et al. | Sep 2014 | A1 |
20140310397 | Tseng et al. | Oct 2014 | A1 |
20150082417 | Bhagwat et al. | Mar 2015 | A1 |
20150113588 | Wing et al. | Apr 2015 | A1 |
20150242294 | Lapierre | Aug 2015 | A1 |
20160014011 | Liu | Jan 2016 | A1 |
20160156541 | Nistor et al. | Jun 2016 | A1 |
20160173444 | Nistor | Jun 2016 | A1 |
20160174178 | Nistor | Jun 2016 | A1 |
20160234113 | Constantinescu et al. | Aug 2016 | A1 |
20160234163 | Nistor et al. | Aug 2016 | A1 |
20160248795 | Chien | Aug 2016 | A1 |
20170097841 | Chang | Apr 2017 | A1 |
20180124150 | Myron | May 2018 | A1 |
20180338346 | Routt | Nov 2018 | A1 |
20190036963 | Ahad et al. | Jan 2019 | A1 |
20190182213 | Saavedra et al. | Jun 2019 | A1 |
20190297057 | Raney et al. | Sep 2019 | A1 |
Number | Date | Country |
---|---|---|
WO 03069493 | Aug 2003 | WO |
WO 2016130280 | Aug 2016 | WO |
WO 2018106304 | Jun 2018 | WO |
Entry |
---|
Notice of Allowance and Fee(s) Due for U.S. Appl. No. 14/619,041 (dated May 9, 2017). |
Non-Final Office Action for U.S. Appl. No. 14/572,746 (dated Mar. 7, 2017). |
Non-Final Office Action for U.S. Appl. No. 14/574,359 (dated Jan. 17, 2017). |
Non-Final Office Action for U.S. Appl. No. 14/619,041 (dated Dec. 16, 2016). |
Notice of Allowance and Fee(s) Due for U.S. Appl. No. 14/619,039 (dated Nov. 7, 2016) |
Non-Final Office Action for U.S. Appl. No. 14/572,746 (dated Aug. 24, 2016). |
Non-Final Office Action for U.S. Appl. No. 14/619,039 (dated Jul. 13, 2016). |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2016/013827 (dated May 2, 2016). |
Commonly-assigned, co-pending U.S. Appl. No. 14/619,039 for “Methods, Systems, and Computer Readable Media for Identifying Network Locations Associated with Endpoints,” (Unpublished, filed Feb. 10, 2015). |
Commonly-assigned, co-pending U.S. Appl. No. 14/619,041 for “Methods, Systems, and Computer Readable Media for Facilitating the Resolving of Endpoint Hostnames in Test Environments with Firewalls, Network Address Translators (NATs), or Clouds,” (Unpublished, filed Feb. 10, 2015). |
Commonly-assigned, co-pending U.S. Appl. No. 14/574,359 for “Methods, Systems, and Computer Readable Media for Initiating and Executing Performance Tests of a Private Network and/or Components Thereof,” (Unpublished, filed Dec. 17, 2014). |
Commonly-assigned, co-pending U.S. Appl. No. 14/572,746 for “Methods, Systems, and Computer Readable Media for Receiving a Clock Synchronization Message,” (Unpublished, filed Dec. 16, 2014). |
Commonly-assigned, co-pending U.S. Appl. No. 14/557,418 for “Methods, Systems, and Computer Readable Media for Receiving Test Configuration Information,” (Unpublished, filed Dec. 1, 2014). |
“UDP hole punching,” Wikipedia, http://en.wikipedia.org/wiki/UDP_hole_punching, (Nov. 25, 2014). |
Marius Pavel Nistor, “Application Mixes Add New Levels of Realism to IxChariot 8 Network Testing,” Ixia, (Aug. 1, 2014). |
Commonly-assigned, Co-pending U.S. Appl. No. 15/934,957 for “Dynamic Firewall Configuration and Control for Accessing Services Hosted in Virtual Networks,” (Unpublished, filed Mar. 24, 2018) |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2017/051357 (dated Dec. 15, 2017). |
Extended European Search Report for European Application No. 16749568.8 (dated Jun. 8, 2018) |
Vixie et al., “Dynamic Updates in the Domain Name System (DNS Update),” RFC 2136, pp. 1-26 (Apr. 1997). |
Non-Final Office Action for U.S. Appl. No. 14/574,359 (dated Nov. 16, 2017). |
Advisory Action and AFCP 2.0 Decision for U.S. Appl. No. 14/574,359 (dated Oct. 16, 2017). |
Supplemental Notice of Allowability for U.S. Appl. No. 14/572,746 (dated Oct. 5, 2017). |
Non-Final Office Action for U.S. Appl. No. 14/557,418 (dated Sep. 27, 2017). |
Final Office Action for U.S. Appl. No. 14/557,418 (dated May 3, 2018). |
Communication of European publication number and information on the application of Article 67(3) EPC for European Patent Application No. 16749568.8 (dated Aug. 23, 2017). |
Final Office Action for U.S. Appl. No. 14/574,359 (dated Jul. 27, 2017). |
Notice of Allowance and Fee(s) Due for U.S. Appl. No. 14/572,746 (dated Jul. 11, 2017). |
Applicant Initiated Interview Summary for U.S. Appl. No. 14/572,746 (dated Jun. 22, 2017). |
Notice of Allowance and Fee(s) Due and Examiner-Initiated Interview Summary for U.S. Appl. No. 14/574,359 (dated Jun. 13, 2018). |
“NAT Port Mapping Protocol,” Wikipedia, https://en.wikipedia.org/wiki/NAT_Port_Mapping_Protocol, pp. 1-2 (Accessed Mar. 22, 2018). |
Corrected Notice of Allowability for U.S. Appl. No. 14/557,418 (dated Aug. 8, 2018). |
Notice of Allowance and Fee(s) Due, Examiner-Initiated Interview Summary, and AFCP 2.0 Decision for U.S. Appl. No. 14/557,418 (dated Jul. 24, 2018). |
Office Action for Great Britain Patent Application Serial No. 1903696.1 (dated Sep. 18, 2019). |
Non-Final Office Action for U.S. Appl. No. 15/934,957 (dated Feb. 20, 2020). |
Communication under Rule 71(3) EPC Intention to Grant for European Patent Application Serial No. 16 749 568.8 (dated Feb. 20, 2020). |
Number | Date | Country | |
---|---|---|---|
20180167285 A1 | Jun 2018 | US |