sikuli-driver team mailing list archive
-
sikuli-driver team
-
Mailing list archive
-
Message #16157
[Bug 810754] Re: X-1.0rc3: IDE: crashes on rerun when using logging module
** Tags added: idererun
** Tags added: jython
--
You received this bug notification because you are a member of Sikuli
Drivers, which is subscribed to Sikuli.
https://bugs.launchpad.net/bugs/810754
Title:
X-1.0rc3: IDE: crashes on rerun when using logging module
Status in Sikuli:
In Progress
Bug description:
*** Windows and Mac
(even for rc3 and Jython 2.5.2)
When rerunning a script in the IDE that uses the Python logging
feature, the script terminates with ...sikuli-
script.jar\Lib\logging\__init__.py", line 750, in emit ValueError: I/O
operation on closed file
Running the script from command line works, since at rerun we have a
clean startup.
----------------------------------------------------------------
I am developing a test infrastructure and want a library to setup logging to a file.
In Sikuli, I created a script with the code below. Every time I test my module within the IDE, the specified log file
gets updated, but the Sikuli IDE goes away, and I have one more "javaw.exe" running on the system
- use code below to create TestLogging.sikuli in the IDE
- Change pathname to be valid on your host
- Run in the IDE
# Module to set up logging and reporting
import os
import logging
TestLog = 0
def setupLogging(path, debug = 0):
global TestLog
if debug:
levelLog = logging.DEBUG
else:
levelLog = logging.INFO
logging.basicConfig(filename=path,level=levelLog)
TestLog = logging.getLogger()
if __name__ == "__main__":
setupLogging("C:\\Users\\bgriffin.AMD\\TestLog", debug=1)
TestLog.error("Test Error Log")
TestLog.warning("Test Warning Log")
TestLog.info("Test Info Log")
TestLog.debug("Test Debug Log")
When I import my module into a different script, I see different
behavior in the IDE between runs. The first run appears to work fine,
with messages going to the IDE Message window until I configure the
log file. The logfile only contains my explicit messages. After
editing the script below to configure a different log level, I get
error messages in the IDE message window unrelated to my script (which
runs fine). I have the script first, then the Message window text.
- Create VisualStudioIDE.sikuli from the code below
- you may need to modify sys.path depending on where you created TestLogging.sikuli
- change pathnames to be valid on your host
- Run in IDE
- Edit script, adding ", debug=1" to the setupLogging() call.
- Run
- DO NOT EXIT IDE IN BETWEEN RUNS
# Start Visual Studio using command line or a solution
import os
from sikuli.Sikuli import *
import subprocess
myPath = os.path.dirname(getBundlePath())
myParent = os.path.dirname(myPath)
if not myPath in sys.path: sys.path.append(myPath)
if not myParent in sys.path: sys.path.append(myParent)
import TestLogging # name for module with above code
VISUAL_STUDIO_IDE = "C:\\Program Files (x86)\\Microsoft Visual Studio 10.0\\Common7\\IDE\\devenv.exe"
VSApp = 0
def startVisualStudio(solution = 0):
global VSApp
VSApp = App(VISUAL_STUDIO_IDE)
VSApp.open()
wait(10) # wait for the process to start up
if not VSApp:
# add logging of failure
TestLogging.TestLog.error("Unable to start Microsoft Visual Studio")
TestLogging.TestLog.error("Executable: " + VISUAL_STUDIO_IDE)
return 0
VSApp.focus( "Start Page - Microsoft Visual Studio" )
if solution:
type("o", KEY_CTRL)
wait(2)
type(solution)
type("\n")
return 1
def closeVisualStudio():
global VSApp
if VSApp:
VSApp.close()
VSApp = 0
else:
TestLogging.TestLog.warning("Visual Studio not running.")
def captureVisualStudio():
global VSApp
vsImage = 0
if VSApp:
vs = VSApp.focusedWindow()
vsImage = capture(vs)
else:
TestLogging.TestLog.debug("Visual Studio not running?")
return vsImage
if __name__ == "__main__":
TestLogging.setupLogging("C:\\Users\\bgriffin.AMD\\TestLogVSIDE")
status = startVisualStudio()
wait(5)
if status:
TestLogging.TestLog.info("Started Visual Studio")
myVS = captureVisualStudio()
if myVS:
TestLogging.TestLog.info("Image location: " + myVS)
else:
TestLogging.TestLog.error("No Image Captured")
closeVisualStudio()
[log] App.open C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(6120)
[log] App.focus Start Page - Microsoft Visual Studio(0) #0
[log] App.close C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(6120) [log] App.open C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(5184)
[log] App.focus Start Page - Microsoft Visual Studio(0) #0 [log] Ctrl+TYPE "o"
[log] TYPE "C:\Users\bgriffin.AMD\Desktop\DataTypesVS10\DataTypesVS10.sln"
[log] TYPE " "
[log] App.close C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(5184) [log] App.open C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(1696)
[log] App.focus Start Page - Microsoft Visual Studio(0) #0
Traceback (most recent call last): File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit ValueError: I/O operation on closed file Traceback (most recent call last): File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit ValueError: I/O operation on closed file Traceback (most recent call last): File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit File "C:\Program Files (x86)\Sikuli X\sikuli-script.jar\Lib\logging\__init__.py", line 750, in emit ValueError: I/O operation on closed file
[log] App.close C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE\devenv.exe(1696)
To manage notifications about this bug go to:
https://bugs.launchpad.net/sikuli/+bug/810754/+subscriptions
References