#2231 closed defect (wontfix)
Trac do not locate Enscript temp file
| Reported by: | Owned by: | Jonas Borgström | |
|---|---|---|---|
| Priority: | normal | Milestone: | |
| Component: | web frontend/mod_python | Version: | 0.9b2 | 
| Severity: | major | Keywords: | enscript needinfo | 
| Cc: | Branch: | ||
| Release Notes: | |||
| API Changes: | |||
| Internal Changes: | |||
Description
I think this is related to Ticket #811.
here the log
3:43:22 AM Trac[svn_fs] DEBUG: Opening subversion file-system at h:\SVN with scope /
3:43:22 AM Trac[cache] DEBUG: Checking whether sync with repository is needed
3:43:22 AM Trac[api] DEBUG: Trying to render HTML preview using EnscriptRenderer
3:43:22 AM Trac[enscript] DEBUG: Enscript command line: C:\buRRRn\shell\enscript\bin\enscript.exe --color -h -q --language=html -p - -Ejavascript
3:43:22 AM Trac[api] WARNING: HTML preview using <trac.mimeview.enscript.EnscriptRenderer object at 0x009F8BB0> failed ([Errno 2] No such file or directory: 'c:\\windows\\temp\\tmpqdmftd')
Traceback (most recent call last):
  File "C:\Python23\lib\site-packages\trac\mimeview\api.py", line 233, in render
    result = renderer.render(req, mimetype, content, filename, rev)
  File "C:\Python23\lib\site-packages\trac\mimeview\enscript.py", line 112, in render
    np = NaivePopen(cmdline, content)
  File "C:\Python23\Lib\site-packages\trac\util.py", line 282, in __init__
    outfd = file(outfile, 'r')
IOError: [Errno 2] No such file or directory: 'c:\\windows\\temp\\tmpqdmftd'
3:43:22 AM Trac[api] DEBUG: Trying to render HTML preview using PlainTextRenderer
3:43:22 AM Trac[api] DEBUG: Using default plain text mimeviewer
3:43:22 AM Trac[svn_fs] DEBUG: Closing subversion file-system at h:\SVN
From my observation of the "c:
windows
temp
" directory
a temp file is created but not the one that Trac is looking for
I don't know enought Python but it must be related to a "makeTempFile" command not returning the correct temporary file name.
Attachments (0)
Change History (11)
comment:1 by , 20 years ago
| Resolution: | → duplicate | 
|---|---|
| Status: | new → closed | 
comment:2 by , 20 years ago
| Resolution: | duplicate | 
|---|---|
| Status: | closed → reopened | 
see my comment on ticket #2233
after resolving the DLL conflict
using tracd Enscript perfectly render the syntax highlighting
using Apache v2.0.55 under Windows 2003 now the error log is not quite the same
6:52:03 AM Trac[svn_fs] DEBUG: Opening subversion file-system at h:\SVN with scope /
6:52:03 AM Trac[cache] DEBUG: Checking whether sync with repository is needed
6:52:03 AM Trac[api] DEBUG: Trying to render HTML preview using EnscriptRenderer
6:52:03 AM Trac[enscript] DEBUG: Enscript command line: C:\buRRRn\shell\enscript\bin\enscript.exe --color -h -q --language=html -p - -Ejavascript
6:52:03 AM Trac[api] WARNING: HTML preview using <trac.mimeview.enscript.EnscriptRenderer object at 0x009F2A90> failed (Running (C:\buRRRn\shell\enscript\bin\enscript.exe --color -h -q --language=html -p - -Ejavascript) failed: 0, 'states' is not recognized as an internal or external command,
operable program or batch file.
.)
Traceback (most recent call last):
  File "C:\Python23\lib\site-packages\trac\mimeview\api.py", line 233, in render
    result = renderer.render(req, mimetype, content, filename, rev)
  File "C:\Python23\lib\site-packages\trac\mimeview\enscript.py", line 115, in render
    raise Exception, err
Exception: Running (C:\buRRRn\shell\enscript\bin\enscript.exe --color -h -q --language=html -p - -Ejavascript) failed: 0, 'states' is not recognized as an internal or external command,
operable program or batch file.
.
6:52:03 AM Trac[api] DEBUG: Trying to render HTML preview using PlainTextRenderer
6:52:03 AM Trac[api] DEBUG: Using default plain text mimeviewer
6:52:03 AM Trac[svn_fs] DEBUG: Closing subversion file-system at h:\SVN
- it's not the permissions in the enscript bin directory causing problems
- it's not the path to the enscript executable causing problems
I tried all these combinaison:
C:\buRRRn\shell\enscript\bin\enscript.exe C:/buRRRn/shell/enscript/bin/enscript.exe C:\\buRRRn\\shell\\enscript\\bin\\enscript.exe enscript.exe enscript
- I ran the enscript command line
enscript --color -h -q --language=html -p - -Ejavascript H:\tmpProject\blah\HelloWorld.js
and it generate
<!DOCTYPE html PUBLIC "-//IETF//DTD HTML 2.0//EN">
<HTML>
<HEAD>
<TITLE>Enscript Output</TITLE>
</HEAD>
<BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#1F00FF" ALINK="#FF0000" VLINK="#9900DD">
<A NAME="top">
<A NAME="file1">
<H1>H:\tmpProject\blah\HelloWorld.js</H1>
<PRE>
<B><FONT COLOR="#A020F0">function</FONT></B> <B><FONT COLOR="#0000FF">HelloWorld</FONT></B>()
    {
    <B><FONT COLOR="#A020F0">return</FONT></B> <B><FONT COLOR="#BC8F8F">"Hello world"</FON
T></B>;
    }
</PRE>
<HR>
<ADDRESS>Generated by <A HREF="http://www.iki.fi/~mtr/genscript/">GNU enscript 1.6.3</A>.</ADDRESS>
</BODY>
</HTML>
- in trac.ini
I set
enscript_path =
to nothing
and also tested by completely removing the line
and Trac still log that error:
7:16:24 AM Trac[svn_fs] DEBUG: Opening subversion file-system at h:\SVN with scope /
7:16:24 AM Trac[cache] DEBUG: Checking whether sync with repository is needed
7:16:24 AM Trac[api] DEBUG: Trying to render HTML preview using EnscriptRenderer
7:16:24 AM Trac[enscript] DEBUG: Enscript command line: enscript --color -h -q --language=html -p - -Ejavascript
7:16:24 AM Trac[api] WARNING: HTML preview using <trac.mimeview.enscript.EnscriptRenderer object at 0x009F2A90> failed (Running (enscript --color -h -q --language=html -p - -Ejavascript) failed: 0, 'enscript' is not recognized as an internal or external command,
operable program or batch file.
.)
Traceback (most recent call last):
  File "C:\Python23\lib\site-packages\trac\mimeview\api.py", line 233, in render
    result = renderer.render(req, mimetype, content, filename, rev)
  File "C:\Python23\lib\site-packages\trac\mimeview\enscript.py", line 115, in render
    raise Exception, err
Exception: Running (enscript --color -h -q --language=html -p - -Ejavascript) failed: 0, 'enscript' is not recognized as an internal or external command,
operable program or batch file.
.
7:16:24 AM Trac[api] DEBUG: Trying to render HTML preview using PlainTextRenderer
7:16:24 AM Trac[api] DEBUG: Using default plain text mimeviewer
7:16:24 AM Trac[svn_fs] DEBUG: Closing subversion file-system at h:\SVN
I asked on the mailing list to be sure, someone told me "Trac is always set to prefer SilverCity over Enscript."
I do have installed SilverCity v0.9.5 (for Python v2.3)
so I think there is 2 problems now:
- why Trac do not use SilverCity over Enscript ?
- why Enscript working with tracd but not with Trac cgi under Apache ?
comment:4 by , 19 years ago
| Keywords: | needinfo added | 
|---|
follow-up: 6 comment:5 by , 19 years ago
Also getting this on a centos 4.2 box
2006-12-08 00:29:02,330 Trac[browser] DEBUG: Rendering preview of node api.php@None with mime-type text/x-php; charset=iso-8859-15
2006-12-08 00:29:02,337 Trac[api] DEBUG: Trying to render HTML preview using PHPRenderer
2006-12-08 00:29:02,346 Trac[php] DEBUG: PHP command line: /usr/bin/php -sn
2006-12-08 00:29:02,376 Trac[api] WARNING: HTML preview using <trac.mimeview.php.PHPRenderer object at 0xb7ba9a8c> failed ([Errno 2] No such file or directory: '/tmp/tmpRiIHb2')
Traceback (most recent call last):
  File "/usr/lib/python2.3/site-packages/trac/mimeview/api.py", line 456, in render
    return Markup(self._annotate(result, annotations))
  File "/usr/lib/python2.3/site-packages/trac/mimeview/api.py", line 490, in _annotate
    for num, line in enumerate(_html_splitlines(lines)):
  File "/usr/lib/python2.3/site-packages/trac/mimeview/api.py", line 620, in _html_splitlines
    for line in lines:
  File "/usr/lib/python2.3/site-packages/trac/mimeview/php.py", line 84, in render
    np = NaivePopen(cmdline, content, capturestderr=1)
  File "/usr/lib/python2.3/site-packages/trac/util/__init__.py", line 146, in __init__
    errfd = file(errfile,'r')
IOError: [Errno 2] No such file or directory: '/tmp/tmpRiIHb2'
2006-12-08 00:29:02,381 Trac[api] DEBUG: Trying to render HTML preview using SilverCityRenderer
2006-12-08 00:29:02,460 Trac[api] DEBUG: Trying to render HTML preview using PlainTextRenderer
2006-12-08 00:29:02,461 Trac[api] DEBUG: Using default plain text mimeviewer
comment:6 by , 19 years ago
Replying to eric:
Also getting this on a centos 4.2 box
Check if SELinux is active, and if so look for AVC denial messages.
comment:7 by , 19 years ago
(was Dup: #4424) I have a very similar issiue, enscript cannot be started when I use mod_python, also other external pograms cannot be launched e.g. htmldoc for PageToPdf.
NO I don't habe SELinux installed!
Trac 0.10, with Apache 2.2 (problems only with mod_python!, running that thing in fcgi is perfect.)
comment:8 by , 19 years ago
| Component: | browser → mod_python frontend | 
|---|---|
| Milestone: | → 1.0 | 
Brief summary:
- this issue was originally reported for Enscript on Windows with Apache cgi,
while it was working with tracd
... np = NaivePopen(cmdline, content) File "C:\Python23\Lib\site-packages\trac\util.py", line 282, in __init__ outfd = file(outfile, 'r') IOError: [Errno 2] No such file or directory: 'c:\\windows\\temp\\tmpqdmftd'that particular error was "fixed" after correcting some dlls (see #2233)
- then it was reported also on Linux, for PHP:
... np = NaivePopen(cmdline, content, capturestderr=1) File "/usr/lib/python2.3/site-packages/trac/util/__init__.py", line 146, in __init__ errfd = file(errfile,'r') IOError: [Errno 2] No such file or directory: '/tmp/tmpRiIHb2'
- and in #4424 for enscript (when run from mod_python)
... np = NaivePopen(cmdline, content.encode('utf-8'), capturestderr=1) File "/var/lib/python-support/python2.4/trac/util/__init__.py", line 142, in _ _init__ outfd = file(outfile, 'r') IOError: [Errno 2] No such file or directory: '/tmp/tmpuzLyax'
… so I wonder if the trouble we see here with NaivePopen and mktemp from within Apache couldn't be due to some other implementation of mktemp suddenly becoming active due to a mix of libraries?
In any case, this does seem to be a valid issue, but with no immediate resolution plans, therefore setting it to milestone:1.0.
If those seeing the issue could get the list of libraries for their running apache process (see TracTroubleshooting for details) and look for mktemp / mkstemp symbols there, I'd be interested (nm $lib | grep mktemp).
comment:9 by , 18 years ago
| Milestone: | 1.0 | 
|---|---|
| Resolution: | → wontfix | 
| Status: | reopened → closed | 
Not likely to be resolved on our side.
comment:10 by , 13 years ago
I had exactly the same errors as described here and the solution which fixes the problem is: Copy states.exe, libiconv-2.dll and libintl-2.dll to a directory that is part of the PATH environment variable of Windows. Then it can be found by enscript.exe and everything works well.
It seems to me that, in enscript.py of Trac,
NaivePopen(cmdline, content.encode('utf-8'), capturestderr=1)
which calls
enscript.exe --color -h -q --language=html -p - -E%s
is not able to reuse the environment of enscript.exe, because actually both DLLs and states.exe is located in the same dir as enscript.exe.
CU, F@lk
comment:11 by , 13 years ago
Well, to speak more clearly, my workaround refers to [commment:2] of zwetan who said
Exception: Running (C:\buRRRn\shell\enscript\bin\enscript.exe --color -h -q --language=html -p - -Ejavascript) failed: 0, 'states' is not recognized as an internal or external command, operable program or batch file.
CU, F@lk




 
  
Yes, this seems to be a duplicate of #811.