Tethering is all about turning you smart phone into a Wifi Hotspot. This means that other devices can use your device's internet network for browsing online contents. The phone turns out to be kind of wifi router! This usually involves turning on your Wifi HotSpot from the phone and setting up a password for secured pairing. This can be achieved by changing the Network SSID the other device identifies during scanning for Wi-Fi network. There two types of connection, (1) WPA PSK (2) WPA2 PSK. Both these require password to enter. The same password is used when the other devices using your phone's network. Tethering can also happen through other connectivity media than Wifi such as Blue-tooth, USB cable. They are called Bluetooth Tethering, USB tethering respectively. Wifi tethering is not supported in all the smart phones on the market today. So if you are looking for this feature, you need to look for the specification to confirm tethering is supported or not. Most of the smart phones such as Moto-G, Samsung Galaxy S3, Samsung Grand, Nokia Lumina series have tethering support. And in certain phones, even if the handset supports the tethering feature, the tariff by your network service provider may not allow you to use the tethering feature. In that case you may see the tethering buttons disabled. Think about talking to your service provider and changing the tariff.
Thursday, February 6, 2014
Wednesday, February 5, 2014
Moto G Available on Flipkart For The Price Of Rs. 12,499/- A Much Awaited Launch.
Moto G has Stunning 4.5" HD display, 1280 x 720 HD, 329 ppi, Corning® Gorilla® Glass with Qualcomm Snapdragon 400 processor, 1 GB RAM, with 1.2 GHz quad-core CPU. 5 Megha Pixel Camera, LED flash with features Slow motion video, Burst mode, Auto HDR Panorama, Tap to Focus, 4X digital zoom. And 1.3 Megha pixel front-facing camera.
This Dual Sim phone comes with Android™ 4.3(Jelly Bean) with Guaranteed Upgrade and hence gives the pure Android experience at the comparatively low cost.
The phone has many interchangeable backs with various colors which can be purchased at Flipkart.com. Moto G users get free storage of 50GB in their Google Drive for the period of two years and at very low cost after this period.
The battery is said to be lasting a day full on an average though battery life depends on different usage patters. Motorola Power Pack Slim 2000 is available to carry power.
The phone is protected by Corning Gorilla glass, Moto G has a water repellent nano-coating inside and outside, that gives protection to the handset from light and water.
Only cons for this phone is that it does not have memory card slot so the memory can not be extended. You can have either 8GB or 16 GB built-in memory. That's all. However as mentioned earlier, moto G users get 50GB extra on their Google Drive for 2 years.
The phone is called exceptional because of its pricing. If you are expecting a very high end smart phone with high MP camera, 4G network or light weight, there are better options.
Monday, February 3, 2014
Software Test Automation Challenges/Problems And Possible Remedies
Software test automation is a process where the software is tested by another software program with less or no human intervention. As we all know, software testing happens in various stages of software testing. Unit tests are where the software is tested at unit (function/method) level. Unit tests are automated easily using Unit test frameworks such as JUnit Test in case of Java Programming Language. In unit testing user operations are not tested. Next, the developer Integration Tests can also be automated but again this testing is to verify if the interfaces(contracts) are working as expected. Even certain regression test suites/Performance and capacity test cases can be automated. Apart from Unit tests automation, there are different challenges automating Developer Integration, Regression,System, PCT tests. Based on my experience, I've listed down some of the common challenges/problems faced during test automation below.
1. Automated Tests can be extended beyond unit tests, but this is limited to software components that are of non UI type. When it comes to UI testing, we fall back to manual testing procedures. The remedy for this challenge is to design the software in such a way that the back end code is separated from its user interface. If you are dealing with legacy/existing code and if the code is not well written to separate out business logic with UI logic, the code refactoring should be considered to be able to automated testing of the business logic. By this leaving apart the UI code, rest of the code is tested by automated tests.
2. Problem in automating regression tests are that the software code gets
Coming to the automation part, as said above, the main functions of the software remain the same, but the code to achieve would've been changed. The code would've been refactored to incorporate some other changes and automated regression test code is out of sync with code and may lead to incorrect test results. The solution (as how looked at it) is that the interfaces must not change. This means that the method/function signatures' must remain the same though the method code might have been changed. If this agreement is in place, it becomes easier for automating regression tests. However this may not be the case, the developers may be forced to change the contract to achieve other application functions or to fix certain bugs. In this cases, the regression tests automation author must be in sync with the developer and make necessary change in the tests code.
3. How are we testing the user scenarios that involve the UI and require user interventions? Well, UI testing can also be automated. There are tools to automate the black box testing. Some examples for UI(black box) testing are salenium(Web Pages Automation), TestingWhiz, EggPlant(for almost any kind of application test automation including UI). The salenium records the user actions on browsers and play that. EggPlant works based on image matching technique. When we learn more about these tools, it seems that we can automation every aspects of the application, but there is a challenge too.
Using these tools we can automate the user scenario if we know exactly how the software should behave on all user actions upfront especially for automation tools that work image matching. We need to define the expected UI screens for every user actions. This works for ideal conditions, but there are several factors that can cause the software to stop functioning. For example, lets say the application is communicating to a server and the communication gets lost. This can happen at any time we do not this upfront. These kind of failure scenarios become difficult to automate. The remedy for this problem is that the automated test code/script can define fixed wait time before deciding there is no response by the application.
4. Every time UI is changed, there is effort required to update test scripts, increased maintenance cost. For certain automation tools like EggPlant the if the screen UI is even slightly changed. (The text is capitalized), the test script requires changes. The remedy for this problem is to make developers and other team members involved in the software creation about the automation scripts. The software test engineer has to in constant touch with developers to understand what changes are happening, are there any UI changes, etc and make sure the automation code/scripts are updated as per the changes.
5. The Performance and Capacity Testing is a good idea to automate since the manual testing takes lot of time. In this type of testing (PCT), the performance of each user operation or critical user operations are measured under different application usage patterns. For Ex: The user operation 'Upload File' takes 35 seconds at the load (CPU usage) 60% etc. The most difficult part in this type of automation testing is that, the application behaviour can not be defined upfront at different load conditions, and hence the automation scripts can not be written to pass or fail. However, the performance measurements aspects can be carried out and may be for base-lining when the application is first being tested for performance and capacity. For mission critical applications that do have defined speed requirements, can easily be automated, the test case is failed if a particular mission critical operation did not complete in defined/stipulated time period.
If the TDD (Test Driven Development) is not in place, the automation is a real challenge. Most of the times, the automated tests go out of sync may be because software development planning effort estimation did not consider the efforts required for automation or automation is not enforced strictly by the organization.
Subscribe to:
Posts (Atom)