Edgewall Software
Modify

Opened 15 years ago

Closed 15 years ago

Last modified 9 years ago

#9268 closed defect (fixed)

[PATCH] 0.12 db-upgrade fix for repo-less installs

Reported by: jonas@… Owned by: Remy Blank
Priority: high Milestone: 0.12
Component: admin/console Version: 0.12dev
Severity: major Keywords: patch bugfix
Cc: Branch:
Release Notes:
API Changes:
Internal Changes:

Description (last modified by Christian Boos)

Doing a trac-admin instance upgrade from 0.11.7 to 0.12dev, raised this error:

    OperationalError: near "%": syntax error

(source:trunk/trac/upgrades/db24.py@9554#L48)

I know nothing about python, but I hacked around and made a patch that seems to fix the issue. db24.py was expecting to have a repo and failed when no data could be given to the subsequent queries.

This patch just checks if there is any data before running the queries.

Attachments (3)

FIX_NO_REPO_UPGRADE.diff (1.6 KB ) - added by jonas@… 15 years ago.
The patch in question
debuglog.txt (9.5 KB ) - added by jonas@… 15 years ago.
The debug log with stack-trace
9268-executemany-r9563.patch (2.1 KB ) - added by Remy Blank 15 years ago.
Handle args=[] correctly in Cursor.executemany().

Download all attachments as: .zip

Change History (13)

by jonas@…, 15 years ago

Attachment: FIX_NO_REPO_UPGRADE.diff added

The patch in question

comment:1 by Remy Blank, 15 years ago

Owner: set to Remy Blank

Good catch, thanks! I'll fix that tomorrow.

comment:2 by Christian Boos, 15 years ago

You should also tell us which line had the error, as I couldn't reproduce the issue near "%": syntax error. Actually, I didn't have any problem in upgrading an 0.11.7 environment which had no repository defined.

So, which database backend are you using, and which revision of Trac trunk?

Normally, in db23.py we create the repository table and fill it with the default repository, taking repository_dir and youngest_rev from the system table.

A freshly created, repository-less, 0.11.7 db looks like that:

sqlite> select * from system;
database_version|21
initial_database_version|21
youngest_rev|

After an upgrade, I have:

sqlite> select * from repository;
1|name|
1|youngest_rev|

in reply to:  2 ; comment:3 by jonas@…, 15 years ago

I don't have the database by hand right now, but from memory..

Replying to cboos:

You should also tell us which line had the error, as I couldn't reproduce the issue near "%": syntax error. Actually, I didn't have any problem in upgrading an 0.11.7 environment which had no repository defined.

Actually, my system has lived trough multiple updates, so it's entirely possible that it's a combination of updates that gives that result. I will look tomorrow which line was failing on my backuped instance. By the way, it would have been much easier for me to debug that error if trac-admin had printed the full stack-trace (or provided an option to do so)

So, which database backend are you using, and which revision of Trac trunk?

sqlite3

Normally, in db23.py we create the repository table and fill it with the default repository, taking repository_dir and youngest_rev from the system table.

A freshly created, repository-less, 0.11.7 db looks like that:

sqlite> select * from system;
database_version|21
initial_database_version|21
youngest_rev|

After an upgrade, I have:

sqlite> select * from repository;
1|name|
1|youngest_rev|

Okay, I'll give you these details tomorrow

in reply to:  3 comment:4 by Remy Blank, 15 years ago

Replying to jonas@…:

By the way, it would have been much easier for me to debug that error if trac-admin had printed the full stack-trace (or provided an option to do so)

The full backtrace should be in the log.

sqlite3

Could you please also provide the version of:

  • the SQLite database library
  • the SQLite Python bindings
  • the trunk revision that you are using

comment:5 by jonas@…, 15 years ago

Additional infos:

sqlite> select * from system;
database_version|21
  • libsqlite3-0 3.6.16-1ubuntu1
  • python-pysqlite2 2.5.5-1ubuntu1
  • Trac: 0.12dev r9554

by jonas@…, 15 years ago

Attachment: debuglog.txt added

The debug log with stack-trace

comment:6 by Christian Boos, 15 years ago

Description: modified (diff)

added line number info from the backtrace

comment:7 by Remy Blank, 15 years ago

I can indeed reproduce the issue if id_name_list is [] in db24.py. Working on a fix…

by Remy Blank, 15 years ago

Handle args=[] correctly in Cursor.executemany().

comment:8 by Remy Blank, 15 years ago

I don't understand why the args argument to Cursor.executemany() is optional. It isn't in the DB-API, and it doesn't make sense anyway. Handling the case where args=[] correctly, as in the patch above, fixes the issue. Feedback welcome.

comment:9 by Christian Boos, 15 years ago

Patch looks good, and I run the tests on the 3 backends with no issues.

comment:10 by Remy Blank, 15 years ago

Resolution: fixed
Status: newclosed

Thanks for testing. Patch applied in [9571].

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.