Edgewall Software
Modify

Opened 16 years ago

Closed 15 years ago

Last modified 15 years ago

#8233 closed defect (fixed)

TypeError: a float is required

Reported by: theyranos@… Owned by: Remy Blank
Priority: normal Milestone: 0.12
Component: general Version: 0.11.1
Severity: normal Keywords: datetime
Cc: Branch:
Release Notes:
API Changes:
Internal Changes:

Description

How to Reproduce

While doing a GET operation on /wiki/Akara, Trac issued an internal error.

Further investigation suggested that the problem was that the wiki page's "time" was NULL in the database (and therefore None when it gets to the offending line). I'm not sure how it got that way, but this page worked just fine before my last apt-get upgrade. I've attached a patch that fixes the problem on my system by setting self.time to None in the event "time" is NULL.

Request parameters:

{'page': u'Akara'}

User Agent was: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9) Gecko/2008052906 Firefox/3.0

System Information

Trac 0.11.1
Python 2.6.2 (release26-maint, Apr 19 2009, 02:15:38)
[GCC 4.3.3]
setuptools 0.6c9
SQLite 3.6.10
pysqlite 2.5.0
Genshi 0.5.1
mod_python 3.3.1
Pygments 0.10
Subversion 1.5.4 (r33841)
jQuery: 1.2.6

Python Traceback

Traceback (most recent call last):
  File "/usr/lib/python2.6/dist-packages/trac/web/main.py", line 423, in _dispatch_request
    dispatcher.dispatch(req)
  File "/usr/lib/python2.6/dist-packages/trac/web/main.py", line 197, in dispatch
    resp = chosen_handler.process_request(req)
  File "/usr/lib/python2.6/dist-packages/trac/wiki/web_ui.py", line 114, in process_request
    page = WikiPage(self.env, pagename)
  File "/usr/lib/python2.6/dist-packages/trac/wiki/model.py", line 43, in __init__
    self._fetch(name, version, db)
  File "/usr/lib/python2.6/dist-packages/trac/wiki/model.py", line 70, in _fetch
    self.time = datetime.fromtimestamp(time, utc)
TypeError: a float is required

The Aforementioned Patch

--- /tmp/model.py.backup        2009-04-24 16:17:46.000000000 -0400
+++ /usr/lib/python2.6/dist-packages/trac/wiki/model.py 2009-04-24 16:24:17.000000000 -0400
@@ -67,7 +67,10 @@
             version,time,author,text,comment,readonly = row
             self.version = int(version)
             self.author = author
+            try:
             self.time = datetime.fromtimestamp(time, utc)
+            except TypeError:
+              self.time = None
             self.text = text
             self.comment = comment
             self.readonly = readonly and int(readonly) or 0

Attachments (0)

Change History (5)

comment:1 by theyranos@…, 16 years ago

Sorry! By now I should know better than to make Python patches with the -w flag. Soooo stupid. Here's a corrected one.

--- /tmp/model.py.backup        2009-04-24 16:17:46.000000000 -0400
+++ /usr/lib/python2.6/dist-packages/trac/wiki/model.py 2009-04-24 16:24:17.000000000 -0400
@@ -67,7 +67,10 @@
             version,time,author,text,comment,readonly = row
             self.version = int(version)
             self.author = author
-            self.time = datetime.fromtimestamp(time, utc)
+            try:
+              self.time = datetime.fromtimestamp(time, utc)
+            except TypeError:
+              self.time = None
             self.text = text
             self.comment = comment
             self.readonly = readonly and int(readonly) or 0


comment:2 by Christian Boos, 15 years ago

Keywords: datetime added
Milestone: 0.11.6

Hm, pretty sure you'll get other errors with such a timestamp…

Maybe we could get datetime.fromtimestamp consider NULL/None as if it's 0?

comment:3 by Christian Boos, 15 years ago

#8604 was closed as duplicate.

comment:4 by Remy Blank, 15 years ago

Milestone: next-minor-0.12.x0.12
Resolution: fixed
Status: newclosed

This was fixed as part of #6466, as the from_utimestamp() considers None as 0.

comment:5 by Remy Blank, 15 years ago

Owner: set to Remy Blank

Modify Ticket

Change Properties
Set your email in Preferences
Action
as closed The owner will remain Remy Blank.
The resolution will be deleted. Next status will be 'reopened'.
to The owner will be changed from Remy Blank to the specified user.

Add Comment


E-mail address and name can be saved in the Preferences .
 
Note: See TracTickets for help on using tickets.