既然是自动化测试,而且又需要写脚本,那是不是可以自动生成测试脚本呢?带着这个问题,我找到了下面的代码 monkeyrecoder.py
#!/usr/bin/envmonkeyrunner # Copyright 2010, TheAndroid Open Source Project # # Licensed under theApache License, Version 2.0 (the "License"); # you may not usethis file except in compliance with the License. # You may obtain acopy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required byapplicable law or agreed to in writing, software # distributed underthe License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIESOR CONDITIONS OF ANY KIND, either express or implied. # See the License forthe specific language governing permissions and # limitations underthe License. fromcom.android.monkeyrunner import MonkeyRunner as mr fromcom.android.monkeyrunner.recorder import MonkeyRecorder as recorder device =mr.waitForConnection() recorder.start(device)
首先,连接你已经打开调试模式的ANDROID设备,然后运行上面的脚本 monkeyrunner.bat monkeyrecoder.py
执行下面的代码后,将运行录制脚本的程序,截图如下:
这个软件就可以生成脚本。但是这个软件生成的脚本不是monkeyrunner可以直接运行的
TOUCH|{'x':243,'y':746,'type':'downAndUp',}
TOUCH|{'x':244,'y':763,'type':'downAndUp',}
DRAG|{'start':(384,320),'end':(76,320),'duration':1.0,'steps':10,}
这种脚本需要另外一个monkeyrunner的脚本来解释执行。monkeyplayback.py
#!/usr/bin/envmonkeyrunner # Copyright 2010, TheAndroid Open Source Project # # Licensed under theApache License, Version 2.0 (the "License"); # you may not usethis file except in compliance with the License. # You may obtain acopy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required byapplicable law or agreed to in writing, software # distributed underthe License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIESOR CONDITIONS OF ANY KIND, either express or implied. # See the License forthe specific language governing permissions and # limitations underthe License. import sys fromcom.android.monkeyrunner import MonkeyRunner # The format of thefile we are parsing is very carfeully constructed. # Each linecorresponds to a single command. Theline is split into 2 # parts with a |character. Text to the left of the pipedenotes # which command torun. The text to the right of the pipeis a python # dictionary (it canbe evaled into existence) that specifies the # arguments for thecommand. In most cases, this directlymaps to the # keyword argumentdictionary that could be passed to the underlying # command. # Lookup table to mapcommand strings to functions that implement that # command. CMD_MAP = { 'TOUCH': lambda dev, arg: dev.touch(**arg), 'DRAG': lambda dev, arg: dev.drag(**arg), 'PRESS': lambda dev, arg: dev.press(**arg), 'TYPE': lambda dev, arg: dev.type(**arg), 'WAIT': lambda dev, arg:MonkeyRunner.sleep(**arg) } # Process a singlefile for the specified device. def process_file(fp,device): for line in fp: (cmd, rest) = line.split('|') try: # Parse the pydict rest = eval(rest) except: print 'unable to parse options' continue if cmd not in CMD_MAP: print 'unknown command: ' + cmd continue CMD_MAP[cmd](device, rest) def main(): file = sys.argv[1] fp = open(file, 'r') device = MonkeyRunner.waitForConnection() process_file(fp, device) fp.close(); if __name__ =='__main__': main()