The present application relates generally to mobile device testing.
Mobile devices have been increasingly used to access the Internet in recent years. As users continue to demand continuous Internet access from mobile devices, ensuring a smooth transition between wireless access points and/or cellular connections has gained in importance. Testing the transition between access points or between an access point and a cellular connection, however, is conventionally a cumbersome process that typically involves a technician physically moving a mobile device out of range of one access point and in range of another access point or other connection. In addition to being difficult and time consuming, in such approaches it can be difficult to limit or control noise.
Examples described herein relate to mobile device test systems. Using the systems, methods, and computer-readable media described herein, mobile devices can be tested. An outer signal isolation enclosure can contain a plurality of inner signal isolation enclosures. The inner signal isolation enclosures can contain wireless access points. An attenuator can be connected to the wireless access points to control a contribution from the respective access points to a test signal. The attenuator receives output signals from the wireless access points contained within the inner signal isolation enclosures, and based at least in part on the received output signals, the attenuator transmits a test signal within the outer signal isolation enclosure. The test signal is received by a mobile device under test, and the performance of the mobile device can be monitored in response to the test signal.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
The foregoing and other objects, features, and advantages of the claimed subject matter will become more apparent from the following detailed description, which proceeds with reference to the accompanying figures.
Using the systems, methods, and computer-readable media described herein, a mobile device can be tested. As discussed above, testing the performance of a mobile device during a transition between access points typically involves physically transporting the mobile device out of range of one access point and in range of another access point. The mobile device test systems described herein allow a mobile device to be tested while remaining stationary in a test enclosure. The test systems described herein also allow multiple tests to be conducted using a single test system. Examples are described in detail below with reference to
Outer signal isolation enclosure 102 can be a “Faraday cage,” which is an enclosure typically having a solid conductor layer or a layer of interconnected conductive elements such as a metal mesh. The conductive nature of the Faraday cage shields the volume enclosed by the Faraday cage from electromagnetic radiation originating outside of the cage. Outer signal isolation enclosure 102 can also be another type of enclosure that may not be strictly considered to be a Faraday cage. In some examples, outer signal isolation enclosure 102 can be an “RF test enclosure” made by Ramsey Electronics.
Inner signal isolation enclosures 104 and 106 are contained within outer signal isolation enclosure 102. Inner signal isolation enclosures 104 and 106 can also be Faraday cages and can be designed and configured similarly to outer signal isolation enclosure 102. Wireless access points (APs) 108 and 110 are contained within inner signal isolation enclosures 104 and 106, respectively. Throughout this document, inner signal isolation enclosures are illustrated as containing a single AP. In some examples, multiple APs are contained within some inner signal isolation enclosures; such an arrangement can simulate an AP whose signal has noise. As used herein, “wireless access point” refers to a device that allows wireless devices, such as mobile devices, to connect to a wired connection or network. APs can receive wireless signals transmitted from and transmit wireless signals to the mobile devices. APs can communicate, for example, using IEEE 802.11 standards (as used in Wi-Fi® communications).
An attenuator 112 is connected to APs 108 and 110. Attenuator 112 receives output signals from APs 108 and 110 and wirelessly transmits a test signal within outer signal isolation enclosure 102 via antenna 114. Although shown as two separate components in
The test signal transmitted by antenna 114 can be received by one or more mobile devices under test (not shown) that are contained within outer signal isolation enclosure 102, and the performance of the device can be monitored as one or more tests are performed using the test signal. Outer signal isolation enclosure 102 thus functions to isolate the other components of mobile device test system 100 from signals originating outside of outer signal isolation enclosure 102, while inner signal isolation enclosures 104 and 106 ensure that output signals generated by APs 108 and 110, which are used by attenuator 112 to generate the test signal, are isolated from a device under test. With this arrangement, the test signal produced by attenuator 112 and transmitted by antenna 114 can be received by the device under test without interference, and one or more tests can be performed on the device.
By locating the access points (e.g., APs 108 and 110) within inner signal isolation enclosures (e.g., 104 and 106) and using an attenuator outside the inner signal isolation enclosures to transmit a test signal that includes contributions from the APs, the wireless signals from the APs can be more accurately controlled (e.g., can be varied precisely from zero signal strength to maximum signal strength).
In process block 206, a test signal is determined based at least in part on the signal contributions from the respective APs contained within the respective plurality of inner signal isolation enclosures. The test signal is transmitted within the outer signal isolation enclosure in process block 208. The contributions to the test signal from multiple APs replicate actual use situations in which a mobile device receives signals from multiple APs. For example, while being operated by a user in a non-testing scenario, a mobile device might receive a stronger signal from a nearby AP and a weaker signal from a distant AP. The test signal can thus be determined to include a greater contribution from a first AP to represent the nearby AP and a lesser contribution from a second AP to represent the distant AP. The performance of the mobile device under test in response to the test signal is monitored in process block 210. Performance can be measured, for example, in terms of dropped packets, whether a current download/upload continues, delays in a current download/upload, which AP the device connects to, dropped calls, or other metric.
In process block 310, the transmitted test signal is varied to simulate a transition of the mobile device under test between APs located external to the outer signal isolation enclosure. For example, the test signal can be varied to simulate the real-world situation where a user is walking with a mobile device from one AP to another AP (e.g., from one end of an office building where a first AP is located to the other end of the office building where a second AP is located). In some examples, varying the test signal comprises reducing a contribution to the test signal from a first of the plurality of APs and increasing a contribution to the test signal from a second of the plurality of APs. Varying the test signal in this way simulates moving the wireless device under test away from a first AP external to the outer signal isolation enclosure and toward a second AP external to the outer signal isolation enclosure. The performance of the mobile device under test in response to the test signal is monitored in process block 312.
For example, testing can be performed by starting with the contribution from the first AP at a lower level (e.g., 10%) and contribution from the second AP at a higher level (e.g., 80%). Testing can then continue with the contribution from the first AP raised over time to a higher level (e.g., 80%) while the contribution from the second AP is correspondingly lowered over the same time to a lower level (e.g., 10%). Operation of the device under test can then be monitored. For example, the device under test can be monitored to determine whether it successfully switches from being connected to the second AP to being connected to the first AP. Similarly, the device under test can be tested to determine whether streaming data continues uninterrupted during transition of connectivity between the access points.
The contribution from each AP can be independently varied. In some examples, a contribution from a first AP can be held constant while a contribution from a second AP is varied. This can simulate a mobile AP or hot spot moving along with a mobile device. For example, a user operating a mobile device could be walking with another person whose mobile device is acting as a hot spot. In this scenario, the signal from the mobile hot spot will remain relatively constant, but other APs might increase or decrease in signal strength.
Mobile device test system 400 can vary the test signal transmitted by attenuator 420 in order to perform one or more tests. For example, reducing a contribution to the test signal from one of APs 412, 414, 416, and 418 and increasing a contribution to the test signal from a second one of APs 412, 414, 416, and 418 can simulate transitioning mobile device 422 under test from a connection with one AP external to outer signal isolation enclosure 402 to a connection with another AP external to outer signal isolation enclosure 402.
Noise AP 426 is also contained within outer signal isolation enclosure 402. Unlike APs 412, 414, 416, and 418, noise AP 426 is not contained within an inner signal isolation enclosure. Noise AP 426 transmits a noise signal to mobile device 422 under test. In some examples, a plurality of noise APs is contained within outer signal isolation enclosure 402. The noise signal transmitted by noise AP 426 simulates RF signals present in an actual use environment that are considered noise. The noise signal can include multiple sub-signals of various frequencies and magnitudes.
Outer signal isolation enclosure 402; inner signal isolation enclosures 404, 406, 408, and 410; APs 412, 414, 416, and 418; attenuator 420; and antenna 424 can be similar to the corresponding components of system 100 in
System 500 also includes noise APs 518 and 520. As with inner signal isolation enclosures 504 and 506, the ellipsis between noise AP 518 and noise AP 520 indicates that additional noise APs are possible. Router 522 provides noise signals to noise APs 518 and 520 for transmission. System 500 further comprises a plurality of input ports 524. Input ports 524 connect an external computing device 526 to router 522, attenuator 512, and mobile device 516 under test. External computing device 526 is not contained within outer signal isolation enclosure 502. External computing device 526 can be, for example, a server computer or laptop computer; can run test software; and can communicate testing criteria and other information to router 522, attenuator 512, and mobile device 516 under test via input ports 524.
In some embodiments, mobile device 516 under test has a testing “app” or application or other software that enables a test sequence to be selected or specified by mobile device 516 under test. Mobile device 516 under test can communicate testing instructions to external computing device 526 via input ports 524, and external computing device 526 can communicate with router 522 and attenuator 512. Testing software, whether through a testing app on mobile device 516 under test or through external computing device 526 can be a web-based service (e.g., implemented in HTTP), allowing mobile device testing to be controlled through any device having Internet access. In some examples, at least one of the ports of input ports 524 communicates a test control signal to attenuator 512 that at least in part determines the test signal transmitted by attenuator 512. The test control signal can include testing criteria.
Input ports 524 are accessible from outside outer signal isolation enclosure 502. In this way, external computing device 526 can be plugged in to input ports 524 to communicate with the components of system 500 that are contained within outer signal isolation enclosure 502. Input ports 524 can include, for example, universal serial bus (USB) ports 528 and 530; Ethernet ports 532 and 534; serial ports 536 and 538; SubMiniature version A (SMA) ports 540 and 542; and a power port 544. Additional ports and connector types can be included as needed. Output ports 524 can also be connected to a power monitor 546 that monitors the performance of mobile device 516 under test. For example, power monitor 546 can monitor an amount of battery capacity that is used during various portions of testing. In some examples, monitoring software is installed on mobile device 516 under test and/or external computing device 526 that monitors performance metrics such as dropped packets; whether a current download/upload continues; delays in a current download/upload; dropped calls; or other metric.
Outer signal isolation enclosure 502; inner signal isolation enclosures 504 and 506; APs 508 and 510; attenuator 512; antenna 514; and noise APs 518 and 520 can be similar to the corresponding components of system 100 in
Outer signal isolation enclosure 602 can be portable. For example, the dimensions of outer signal isolation enclosure 602 can be approximately 3 feet×2 feet×3 feet, although a variety of dimensions are possible. System 600 can easily be transported among locations and can be easily stored in a single room or office.
In some embodiments, a separate cellular test signal is used that is based at least in part on the cellular input signal. The cellular test signal can be transmitted by an attenuator, router, or other device. The transition of the mobile device under test between an AP located external to the outer signal isolation enclosure and a cellular signal source located external to the outer signal isolation enclosure can be simulated by varying the second test signal, which can be a Wi-Fi test signal, and varying a signal strength of the cellular test signal. Such a scenario tests the “hand off” between cellular source and AP.
For example, testing can be performed by starting with the second test signal, which is based on contributions from one or more APs, at a higher level (e.g., 80%) and contribution from the cellular test signal at a lower level (e.g., 30%). Testing can then continue with the second test signal decreased over time to a lower level (e.g., 10%) while the cellular test signal is correspondingly increased over the same time to a higher level (e.g., 90%). Operation of the device under test can then be monitored. For example, the device under test can be monitored to determine whether it successfully switches from being connected to an AP (via the second test signal) to being connected to the cellular source. Similarly, the device under test can be tested to determine whether streaming data continues uninterrupted during transition of connectivity from AP to cellular source.
In some examples, the strength of the cellular test signal remains constant while the strength of the second test signal is reduced (e.g., reduced below a threshold). Such a scenario simulates a user connected to an AP (e.g., at a coffee shop) downloading or streaming content and then walking out of range of the AP (e.g., leaving the coffee shop) and continuing the downloading/streaming using a cellular source.
The illustrated mobile device 800 can include a controller or processor 810 (e.g., signal processor, microprocessor, ASIC, or other control and processing logic circuitry) for performing such tasks as signal coding, data processing, input/output processing, power control, and/or other functions. An operating system 812 can control the allocation and usage of the components 802 and support for one or more application programs 814. The application programs can include common mobile computing applications (e.g., email applications, calendars, contact managers, web browsers, messaging applications), or any other computing application. Operating system 812 can also support device under test (DUT) control “app” or application 892, DUT control app 892 provides an interface for selecting or specifying one or more tests to run on a mobile device, as discussed above with respect to
The illustrated mobile device 800 can include memory 820. Memory 820 can include non-removable memory 822 and/or removable memory 824. The non-removable memory 822 can include RAM, ROM, flash memory, a hard disk, or other well-known memory storage technologies. The removable memory 824 can include flash memory or a Subscriber Identity Module (SIM) card, which is well known in GSM communication systems, or other well-known memory storage technologies, such as “smart cards.” The memory 820 can be used for storing data and/or code for running the operating system 812 and the applications 814. Example data can include web pages, text, images, sound files, video data, or other data sets to be sent to and/or received from one or more network servers or other devices via one or more wired or wireless networks. The memory 820 can be used to store a subscriber identifier, such as an International Mobile Subscriber Identity (IMSI), and an equipment identifier, such as an International Mobile Equipment Identifier (IMEI). Such identifiers can be transmitted to a network server to identify users and equipment.
The mobile device 800 can support one or more input devices 830, such as a touchscreen 832, microphone 834, camera 836, physical keyboard 838 and/or trackball 840 and one or more output devices 850, such as a speaker 852 and a display 854. Other possible output devices (not shown) can include piezoelectric or other haptic output devices. Some devices can serve more than one input/output function. For example, touchscreen 832 and display 854 can be combined in a single input/output device. The input devices 830 can include a Natural User Interface (NUI). An NUI is any interface technology that enables a user to interact with a device in a “natural” manner, free from artificial constraints imposed by input devices such as mice, keyboards, remote controls, and the like. Examples of NUI methods include those relying on speech recognition, touch and stylus recognition, gesture recognition both on screen and adjacent to the screen, air gestures, head and eye tracking, voice and speech, vision, touch, gestures, and machine intelligence. Other examples of a NUI include motion gesture detection using accelerometers/gyroscopes, facial recognition, 3D displays, head, eye, and gaze tracking, immersive augmented reality and virtual reality systems, all of which provide a more natural interface, as well as technologies for sensing brain activity using electric field sensing electrodes (EEG and related methods). Thus, in one specific example, the operating system 812 or applications 814 can comprise speech-recognition software as part of a voice user interface that allows a user to operate the device 800 via voice commands. Further, the device 800 can comprise input devices and software that allows for user interaction via a user's spatial gestures, such as detecting and interpreting gestures to provide input to a gaming application.
A wireless modem 860 can be coupled to an antenna (not shown) and can support two-way communications between the processor 810 and external devices, as is well understood in the art. The modem 860 is shown generically and can include a cellular modem for communicating with the mobile communication network 804 and/or other radio-based modems (e.g., Bluetooth 864 or Wi-Fi 862). The wireless modem 860 is typically configured for communication with one or more cellular networks, such as a GSM network for data and voice communications within a single cellular network, between cellular networks, or between the mobile device and a public switched telephone network (PSTN).
The mobile device can further include at least one input/output port 880, a power supply 882, a satellite navigation system receiver 884, such as a Global Positioning System (GPS) receiver, an accelerometer 886, and/or a physical connector 890, which can be a USB port, IEEE 1394 (FireWire) port, and/or RS-232 port. The illustrated components 802 are not required or all-inclusive, as any components can be deleted and other components can be added.
In example environment 900, various types of services (e.g., computing services) are provided by a cloud 910. For example, the cloud 910 can comprise a collection of computing devices, which may be located centrally or distributed, that provide cloud-based services to various types of users and devices connected via a network such as the Internet. The implementation environment 900 can be used in different ways to accomplish computing tasks. For example, some tasks (e.g., processing user input and presenting a user interface) can be performed on local computing devices (e.g., connected devices 930, 940, 950) while other tasks (e.g., storage of data to be used in subsequent processing) can be performed in the cloud 210.
In example environment 900, the cloud 910 provides services for connected devices 930, 940, 950 with a variety of screen capabilities. Connected device 930 represents a device with a computer screen 935 (e.g., a mid-size screen). For example, connected device 930 could be a personal computer such as desktop computer, laptop, notebook, netbook, or the like. Connected device 940 represents a device with a mobile device screen 945 (e.g., a small size screen). For example, connected device 940 could be a mobile phone, smart phone, personal digital assistant, tablet computer, or the like. Connected device 950 represents a device with a large screen 955. For example, connected device 950 could be a television screen (e.g., a smart television) or another device connected to a television (e.g., a set-top box or gaming console) or the like. One or more of the connected devices 930, 940, 950 can include touchscreen capabilities. Touchscreens can accept input in different ways. For example, capacitive touchscreens detect touch input when an object (e.g., a fingertip or stylus) distorts or interrupts an electrical current running across the surface. As another example, touchscreens can use optical sensors to detect touch input when beams from the optical sensors are interrupted. Physical contact with the surface of the screen is not necessary for input to be detected by some touchscreens. Devices without screen capabilities also can be used in example environment 900. For example, the cloud 910 can provide services for one or more computers (e.g., server computers) without displays.
Services can be provided by the cloud 910 through service providers 920, or through other providers of online services (not depicted). For example, cloud services can be customized to the screen size, display capability, and/or touchscreen capability of a particular connected device (e.g., connected devices 930, 940, 950).
In example environment 900, the cloud 910 provides the technologies and solutions described herein to the various connected devices 930, 940, 950 using, at least in part, the service providers 920. For example, the service providers 920 can provide a centralized solution for various cloud-based services. The service providers 920 can manage service subscriptions for users and/or devices (e.g., for the connected devices 930, 940, 950 and/or their respective users). Cloud 910 can store various testing criteria 960 for testing mobile devices. A computing device such as connected devices 935, 940, and/or 950 can retrieve mobile device testing criteria 960 from cloud 910 to perform one or more tests of a mobile device.
With reference to
A computing system may have additional features. For example, the computing environment 1000 includes storage 1040, one or more input devices 1050, one or more output devices 1060, and one or more communication connections 1070. An interconnection mechanism (not shown) such as a bus, controller, or network interconnects the components of the computing environment 1000. Typically, operating system software (not shown) provides an operating environment for other software executing in the computing environment 1000, and coordinates activities of the components of the computing environment 1000.
The tangible storage 1040 may be removable or non-removable, and includes magnetic disks, magnetic tapes or cassettes, CD-ROMs, DVDs, or any other medium which can be used to store information and which can be accessed within the computing environment 1000. The storage 1040 stores instructions for the software 1080 implementing one or more innovations described herein.
The input device(s) 1050 may be a touch input device such as a keyboard, mouse, pen, or trackball, a voice input device, a scanning device, or another device that provides input to the computing environment 1000. For video encoding, the input device(s) 1050 may be a camera, video card, TV tuner card, or similar device that accepts video input in analog or digital form, or a CD-ROM or CD-RW that reads video samples into the computing environment 1000. The output device(s) 1060 may be a display, printer, speaker, CD-writer, or another device that provides output from the computing environment 1000.
The communication connection(s) 1070 enable communication over a communication medium to another computing entity. The communication medium conveys information such as computer-executable instructions, audio or video input or output, or other data in a modulated data signal. A modulated data signal is a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media can use an electrical, optical, RF, or other carrier.
Although the operations of some of the disclosed methods are described in a particular, sequential order for convenient presentation, it should be understood that this manner of description encompasses rearrangement, unless a particular ordering is required by specific language set forth below. For example, operations described sequentially may in some cases be rearranged or performed concurrently. Moreover, for the sake of simplicity, the attached figures may not show the various ways in which the disclosed methods can be used in conjunction with other methods.
Any of the disclosed methods can be implemented as computer-executable instructions stored on one or more computer-readable storage media (e.g., one or more optical media discs, volatile memory components (such as DRAM or SRAM), or nonvolatile memory components (such as flash memory or hard drives)) and executed on a computer (e.g., any commercially available computer, including smart phones or other mobile devices that include computing hardware). The term computer-readable storage media does not include communication connections, such as signals and carrier waves. Any of the computer-executable instructions for implementing the disclosed techniques as well as any data created and used during implementation of the disclosed embodiments can be stored on one or more computer-readable storage media. The computer-executable instructions can be part of, for example, a dedicated software application or a software application that is accessed or downloaded via a web browser or other software application (such as a remote computing application). Such software can be executed, for example, on a single local computer (e.g., any suitable commercially available computer) or in a network environment (e.g., via the Internet, a wide-area network, a local-area network, a client-server network (such as a cloud computing network), or other such network) using one or more network computers.
For clarity, only certain selected aspects of the software-based implementations are described. Other details that are well known in the art are omitted. For example, it should be understood that the disclosed technology is not limited to any specific computer language or program. For instance, the disclosed technology can be implemented by software written in C++, Java, Perl, JavaScript, Adobe Flash, or any other suitable programming language. Likewise, the disclosed technology is not limited to any particular computer or type of hardware. Certain details of suitable computers and hardware are well known and need not be set forth in detail in this disclosure.
It should also be well understood that any functionality described herein can be performed, at least in part, by one or more hardware logic components, instead of software. For example, and without limitation, illustrative types of hardware logic components that can be used include Field-programmable Gate Arrays (FPGAs), Application-specific Integrated Circuits (ASICs), Application-specific Standard Products (ASSPs), System-on-a-chip systems (SOCs), Complex Programmable Logic Devices (CPLDs), etc.
Furthermore, any of the software-based embodiments (comprising, for example, computer-executable instructions for causing a computer to perform any of the disclosed methods) can be uploaded, downloaded, or remotely accessed through a suitable communication means. Such suitable communication means include, for example, the Internet, the World Wide Web, an intranet, software applications, cable (including fiber optic cable), magnetic communications, electromagnetic communications (including RF, microwave, and infrared communications), electronic communications, or other such communication means.
The disclosed methods, apparatus, and systems should not be construed as limiting in any way. Instead, the present disclosure is directed toward all novel and nonobvious features and aspects of the various disclosed embodiments, alone and in various combinations and subcombinations with one another. The disclosed methods, apparatus, and systems are not limited to any specific aspect or feature or combination thereof, nor do the disclosed embodiments require that any one or more specific advantages be present or problems be solved.
In view of the many possible embodiments to which the principles of the disclosed invention may be applied, it should be recognized that the illustrated embodiments are only preferred examples of the invention and should not be taken as limiting the scope of the invention. Rather, the scope of the invention is defined by the following claims. We therefore claim as our invention all that comes within the scope of these claims.