VirtualBox

source: vbox/trunk/src/VBox/Main/webservice/samples/python/clienttest.py@ 48392

Last change on this file since 48392 was 47774, checked in by vboxsync, 11 years ago

Main,Frontends: IDisplay::GetScreenResolution returns the screen origin.

  • Property svn:eol-style set to LF
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 4.4 KB
Line 
1#!/usr/bin/python
2#
3# Copyright (C) 2012 Oracle Corporation
4#
5# This file is part of VirtualBox Open Source Edition (OSE), as
6# available from http://www.virtualbox.org. This file is free software;
7# you can redistribute it and/or modify it under the terms of the GNU
8# General Public License (GPL) as published by the Free Software
9# Foundation, in version 2 as it comes in the "COPYING" file of the
10# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
11# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
12#
13# Things needed to be set up before running this sample:
14# - Install Python and verify it works (2.7.2 will do, 3.x is untested yet)
15# - On Windows: Install the PyWin32 extensions for your Python version
16# (see http://sourceforge.net/projects/pywin32/)
17# - If not already done, set the environment variable "VBOX_INSTALL_PATH"
18# to point to your VirtualBox installation directory (which in turn must have
19# the "sdk" subfolder")
20# - Install the VirtualBox Python bindings by doing a
21# "[python] vboxapisetup.py install"
22# - Run this sample with "[python] clienttest.py"
23
24import os,sys
25import traceback
26
27#
28# Converts an enumeration to a printable string.
29#
30def enumToString(constants, enum, elem):
31 all = constants.all_values(enum)
32 for e in all.keys():
33 if str(elem) == str(all[e]):
34 return e
35 return "<unknown>"
36
37def main(argv):
38
39 from vboxapi import VirtualBoxManager
40 # This is a VirtualBox COM/XPCOM API client, no data needed.
41 wrapper = VirtualBoxManager(None, None)
42
43 # Get the VirtualBox manager
44 mgr = wrapper.mgr
45 # Get the global VirtualBox object
46 vbox = wrapper.vbox
47
48 print "Running VirtualBox version %s" %(vbox.version)
49
50 # Get all constants through the Python wrapper code
51 vboxConstants = wrapper.constants
52
53 # Enumerate all defined machines
54 for mach in wrapper.getArray(vbox, 'machines'):
55
56 try:
57 # Be prepared for failures - the VM can be inaccessible
58 vmname = '<inaccessible>'
59 try:
60 vmname = mach.name
61 except Exception, e:
62 None
63 vmid = '';
64 try:
65 vmid = mach.id
66 except Exception, e:
67 None
68
69 # Print some basic VM information even if there were errors
70 print "Machine name: %s [%s]" %(vmname,vmid)
71 if vmname == '<inaccessible>' or vmid == '':
72 continue
73
74 # Print some basic VM information
75 print " State: %s" %(enumToString(vboxConstants, "MachineState", mach.state))
76 print " Session state: %s" %(enumToString(vboxConstants, "SessionState", mach.sessionState))
77
78 # Do some stuff which requires a running VM
79 if mach.state == vboxConstants.MachineState_Running:
80
81 # Get the session object
82 session = mgr.getSessionObject(vbox)
83
84 # Lock the current machine (shared mode, since we won't modify the machine)
85 mach.lockMachine(session, vboxConstants.LockType_Shared)
86
87 # Acquire the VM's console and guest object
88 console = session.console
89 guest = console.guest
90
91 # Retrieve the current Guest Additions runlevel and print
92 # the installed Guest Additions version
93 addRunLevel = guest.additionsRunLevel
94 print " Additions State: %s" %(enumToString(vboxConstants, "AdditionsRunLevelType", addRunLevel))
95 if addRunLevel != vboxConstants.AdditionsRunLevelType_None:
96 print " Additions Ver: %s" %(guest.additionsVersion)
97
98 # Get the VM's display object
99 display = console.display
100
101 # Get the VM's current display resolution + bit depth + position
102 screenNum = 0 # From first screen
103 (screenW, screenH, screenBPP, screenX, screenY) = display.getScreenResolution(screenNum)
104 print " Display (%d): %dx%d, %d BPP at %d,%d" %(screenNum, screenW, screenH, screenBPP, screenX, screenY)
105
106 # We're done -- don't forget to unlock the machine!
107 session.unlockMachine()
108
109 except Exception, e:
110 print "Errror [%s]: %s" %(mach.name, str(e))
111 traceback.print_exc()
112
113 # Call destructor and delete wrapper
114 del wrapper
115
116if __name__ == '__main__':
117 main(sys.argv)
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette