Monday, 25 September 2017

Mouse Move Software (A simple JAVA code functionality) : Keep your computer awake without touching your mouse

Hi Everyone ,

I have a piece of a Java code very useful for those who can't change their system sleep settings to NEVER
Sharing you an easy work around ! Hope it helps ..


What is the below code doing ?
Answer: Below code is basically changing the cursor location to and fro in a continuous loop. In between every iteration in a loop there is a timedelay. Timedelay is a user input which is required at the starting of this program. As per the Timedelays ( ms ) provided from user, code will wait for some time in between of every iteration. Lets say user provided 3000 as an input , so code will wait for 3 seconds and re perform the mouse move task

Code Hierarchy :
Its a simple code , MouseMoveclass field timedelay is made private ( I dont want any other class to access or change the variable )

Created an explicit Constructor which has arguments ( This argument will inturn initiate private field timedelay ). Constructors in java are used to initiate the fields and methods , and so am i doing ...

Created a method mousemovefunc() which includes:
Robot class instance --- used for mouse actions

Finally a main function which includes :
Scanner class instance to get user value. This user value is used while class instance is made


Code :

package mousemovepackage;

import java.awt.MouseInfo;
import java.awt.Robot;
import java.util.Scanner;

public class MouseMoveclass {

private int timedelay;

public MouseMoveclass(int val){
this.timedelay = val;
System.out.println("Thanks ! Timedelay updated to "+ String.valueOf(timedelay) + "ms");
}
public void mousemovefunc() throws Exception{
Robot myinstance = new Robot();
while(true){
myinstance.delay(timedelay);
java.awt.Point pobj = MouseInfo.getPointerInfo().getLocation();
myinstance.mouseMove(pobj.x+2, pobj.y);
myinstance.delay(2000);
myinstance.mouseMove(pobj.x-2, pobj.y);
}
}
public static void main(String[] args) throws Exception {
System.out.println("Please enter the time delay(ms): ");
Scanner sc = new Scanner(System.in);
int value = sc.nextInt();
MouseMoveclass Mouseinstance = new MouseMoveclass(value);
Mouseinstance.mousemovefunc();
sc.close();
}
}

How to Create a Runnable Jar and create a One click Solution which can run one any machine ?
Follow below Steps :
Right click on the project > Click on Export :




















Click on Runnable JAR file > Next


























Select Launch configuration and Export destination and hit Finish


























Finally we will get a jar file of 2KB approx . Place this file in a folder lets say "MouseMove"
Create a bat file ( Lets say setup.bat ) 
Edit this bat file with below code :


@Echo Off

Set "JV="
For /F "Tokens=3" %%A In ('java -version 2^>^&1') Do If Not Defined JV Set "JV=%%~A"
If /I "%JV%"=="not" (Echo Java is not installed) Else Echo Java Version "%JV%"

TIMEOUT 5

java -jar C:\MouseMove\MouseMoveSoftware.jar
Pause

Code is almost done , We just need to double click setup.bat in any machine and that's it !!!

Happy Coding !!!!

Wednesday, 24 May 2017

Esspresso Custom Matchers

Esspresso Custom Matchers


private static Matcher<View> childAtPosition(
       
final Matcher<View> parentMatcher, final int position) {

   
return new TypeSafeMatcher<View>() {
       
@Override
       
public void describeTo(Description description) {
            description.appendText(
"Child at position " + position + " in parent ");
           
parentMatcher.describeTo(description);
        }

       
@Override
       
public boolean matchesSafely(View view) {
            ViewParent parent = view.getParent();
           
return parent instanceof ViewGroup && parentMatcher.matches(parent)
                    && view.equals(((ViewGroup) parent).getChildAt(
position));
        }
    };
}


Points to remember:

1.       ChildAtPosition is a custom Matcher view created above
2.       Custom view matcher requires two attributes which will be verified
a.       parentMatcher ( resource-id of parent.  Eg..  R.id.YourIDName)
b.      Child Position (which is the Index position of child )
3.       TypeSafeMatcher.matchesSafely() simply returns Boolean value if the parent is instanceof ViewGroup
4.       TypeSafeMatcher.describeTo() is simply used for debugging in console

How to use childAtPosition Matcher

Sample view from UIAutomatorViewer :



Child ID : miniBtnFour : Index : 3
Parent_One ID : fragmentCountingMenu : 0
Parent of Parent_One ID : nav_menu_fragment : 2

Code to Integrate:


ViewInteraction button77 = onView(
        allOf(withId(R.id.miniBtnFour),withText("Submit"),
                childAtPosition(
                        childAtPosition(
                               withId(R.id.nav_menu_fragment),0),
                        3),
                isDisplayed()));
button77.check(matches(withText("Submit")));
button77.perform(click());

Wednesday, 5 April 2017

Python Scripting - Automation

Python Unittest | Pyunit


Python Unit Test Module or PyUnit is a unit test framework similar to Junit .The unittest module provides classes that make it easy to support these qualities for a set of tests. Helps in creating easy Automation and handling big codes !

How to install :
Pip install unittest   ---- Step 1

Unit Test Features :
  • supports test automation
  • sharing of setup and shutdown code for tests
  • aggregation of tests into collections
  • independence of the tests from the reporting framework



Basic Functions in  UnitTest :

test fixture
test fixture represents the preparation needed to perform one or more tests, and any associate cleanup actions. This may involve, for example, creating temporary or proxy databases, directories, or starting a server process.
test case
test case is the smallest unit of testing. It checks for a specific response to a particular set of inputs. unittest provides a base class, TestCase, which may be used to create new test cases.
test suite
test suite is a collection of test cases, test suites, or both. It is used to aggregate tests that should be executed together.
test runner
test runner is a component which orchestrates the execution of tests and provides the outcome to the user. The runner may use a graphical interface, a textual interface, or return a special value to indicate the results of executing the tests.

Sample code :

------------------------------------------------Importing Libraries------------------------------------
import unittest
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.common.exceptions import TimeoutException
from pynput.keyboard import Key, Controller

def Keyboard_press_release():
    keyboard.press(Key.ctrl)
    keyboard.press(Key.tab)
    keyboard.release(Key.ctrl)
    keyboard.release(Key.tab)        

 ------------------------------------------Main Class --------------------------------------------------------------

class AdminPortalWorkflowTest(unittest.TestCase):

------------------------------------------Test case 1 --------------------------------------------------------------
    def test_Launch(self):
        self.driver = webdriver.Chrome('C:\Python27\Scripts\chromedriver.exe')       
        global keyboard
        keyboard = Controller()
        driver = self.driver
        driver.get("https://www.google.com")
        time.sleep(5) 
        Keyboard_press_release()
----------------------------------------Test case 2 ----------------------------------------------------------------                 
    def test_Check(self):
        print "func starts ..."     

----------------Created a Suite which combines Testcase 1and 2 and returns a List -----------------
           
def suite():
    suite = unittest.TestSuite()
    suite.addTest(AdminPortalWorkflowTest('test_Launch'))
    suite.addTest(AdminPortalWorkflowTest('test_Check'))
    return suite                                   

-----------------------------------------Main Function ------------------------------------------------------------
if __name__ == '__main__':

--------------------------------- Calling Suite which runs all test  --------------------------------------------
unittest.TextTestRunner(verbosity=2).run(suite())


Results :



           


Wednesday, 10 June 2015

Android Battery Drain analysis via Qpython

Hello Everybody !

Hope my previous scripts helped you guys in understanding Monkey Runner Advanced Concepts !

Script description :

The below script helps to make a track on android device battery draining and charging
After every 10 degree change in battery level android device will speak and tell you what the current level

import time
import androidhelper
droid = androidhelper.Android()
droid.batteryStartMonitoring()
new = ''
neww = ''
print 'script start'
while True :
    batteryLevel = droid.batteryGetLevel()
    new = new + str(batteryLevel[1])
    time.sleep(2)
    NewLevel = droid.batteryGetLevel()
    neww = neww + str(NewLevel[1])
    if new == neww:
       continue
    else:
        print NewLevel[1],time.asctime()
        new = neww
        if NewLevel[1] % 10 == 0:
            print 'Speaking starts'
            droid.ttsSpeak('hi dheeraj.Your phone battery is' + str(NewLevel[1]))


Sunday, 1 February 2015

Python script to open any application without manually typing touch coordinates

The below script was my dream project which i am presenting in front of you all.

I was facing a huge problems to manually write touch coordinates in my scripts before execution and sometimes those coordinates go wrong and performs a different function in Android.

Script description: Those who do not want to waste time in manually typing coordinates can use this this and make Android testing fully automated

Script :

import sys
from com.android.monkeyrunner import MonkeyRunner, MonkeyDevice, MonkeyImage

def call(d):
    s = 'event3'
    f_log = open('C:\cygwin\home\dheeraj.bajaj\getevent.txt')
    p = 3
    f = open('C:\cygwin\home\dheeraj.bajaj\out4.txt','w')  
    for line in f_log.read().splitlines():
        if "event3:" in line :
            if p == 2 or p == 1 :          
                a = line.split(' ')
                print a[3]
                b = a[3]
                i = int(b,16)
                i_log = str(i).split()
                #saveout = sys.stdout              
                print i_log  
                f.write(str(i))
                f.write("\n")                
            p-=1  
    f.close()     
    f_log.close()  

    f1 = open('C:\cygwin\home\dheeraj.bajaj\out4.txt')
    f2 = f1.readlines()  
    print int(f2[0])
    x = int(f2[0])
    print int(f2[1])
    y = int(f2[1])   
    d.touch(x,y,'DOWN_AND_UP')
    f1.close()       
           
def main():
    print "Start"
    device = MonkeyRunner.waitForConnection()
       
    if not device:
        print "Couldn't get connection"
        sys.exit()
   
    print "Found device"
    call(device)
   

if __name__ == '__main__':
    main()    




Thursday, 29 January 2015

Python script to print touch coordinates using getevent command

We have prepared a batch file containing two major commands described as below :

      1. adb shell getevent -c 200 > getevent.txt
       Description:
       The above command will create 200 events including the touch event given by user
       manually. The touch event given by user will be differentiated via 'event3'

How does getevent works ? 
adb shell getevent ( connect device and use this command )
Which returns something like:
C:\>adb shell getevent
add device 1: /dev/input/event0
name: “qwerty2″
could not get driver version for /dev/input/mouse0, Not a typewriter
could not get driver version for /dev/input/mice, Not a typewriter
/dev/input/event0: 0001 0001 00000000
/dev/input/event0: 0003 0000 00000073
/dev/input/event0: 0003 0001 000000a8
/dev/input/event0: 0003 0001 00000014
/dev/input/event0: 0003 0001 00000014
/dev/input/event0: 0003 0001 00000000
/dev/input/event0: 0003 0001 00000000
/dev/input/event0: 0003 0001 00000000
/dev/input/event0: 0001 014a 00000001
        Which returns everything in hexidecimal, but you can’t send these commands directly back, you         had to convert them to decimal,
The actual X axis coordinates : 00000073 
The actual Y axis coordinates : 000000a8
These coordinates needs to be changed to decimal using python and monkeyrunner

2. monkeyrunner.bat testcall3.py
Description :
This command will execute following functions :
a. Open the getevent text file
b. Search for the touch events ( eg., search for 'event3')
c. Display the Hex format coming infront of event3 lines
d. Convert hex to int and then to decimal
e. Finally display the X and Y coordinates

Continue sharing interesting scripts !!
Thanks !!!

Friday, 23 January 2015

Monkey Scripts runtime error detection via ADB Logcat

This is my first script in front of you all regarding runtime error detection in Monkey Runner scripts. Hope you will enjoy it !!

Script Description :

1. Started any activity ( eg., open dialer)
2. Recording logs at the same time
3. finding a word in logs via find() function
4. If script shows error ( throws exception or opens any other activity apart from dialer) then capturing screenshot
5. Saving logs and moving to the other test case with the use of break function in python

Script :

 

 

 

 

 

 

 

 

 

Will share some more interesting scripts soon !