Opened 17 years ago
Closed 17 years ago
#9528 closed (invalid)
Oracle (cx_Oracle 4.4) exception raises AttributeError (no attribute message) with some errors
| Reported by: | erny | Owned by: | erny | 
|---|---|---|---|
| Component: | Database layer (models, ORM) | Version: | 1.0 | 
| Severity: | Keywords: | Oracle | |
| Cc: | Triage Stage: | Unreviewed | |
| Has patch: | yes | Needs documentation: | no | 
| Needs tests: | no | Patch needs improvement: | no | 
| Easy pickings: | no | UI/UX: | no | 
Description (last modified by )
- Description: Django requires the exception to have "message" attribute, but some errors don't. The real error is hidden and difficult to get.
- How to reproduce: 
- install cx_Oracle: sudo easy_install cx_Oracle #requires python-setuptools
- in your settings.py, use:
* DATABASE_ENGINE = 'oracle' * DATABASE_NAME = 'XE' # your dbname here * DATABASE_USER = 'testuser' # your user here * DATABASE_PASSWORD = 'password' # your password here * DATABASE_HOST = 'localhost' # your db host * DATABASE_PORT = '' # leave empty if default port 1521 * DEFAULT_TABLESPACE = 'NONEXISTING' # use some invalid tablespace * DEFAULT_INDEX_TABLESPACE = 'NONEXISTING' # here also
- with an empty database, run syncdb: ./manage syncdb
 
Traceback:
...
  File "/opt/csa-1.0.0-beta/parts/django/django/core/management/commands/syncdb.py", line 80, in handle_noargs
    cursor.execute(statement)
  File "/opt/csa-1.0.0-beta/parts/django/django/db/backends/oracle/base.py", line 364, in execute
    if e.message.code == 1400 and type(e) != IntegrityError:
AttributeError: DatabaseError instance has no attribute 'message'
      Attachments (1)
Change History (6)
comment:1 by , 17 years ago
| Component: | Uncategorized → Database layer (models, ORM) | 
|---|
by , 17 years ago
| Attachment: | oracle_attribute_error.diff added | 
|---|
Patch for "AttributeError: DatabaseError instance has no attribute 'message'"
comment:3 by , 17 years ago
| Has patch: | set | 
|---|---|
| Owner: | changed from to | 
| Status: | new → assigned | 
comment:4 by , 17 years ago
| Keywords: | Oracle added | 
|---|
comment:5 by , 17 years ago
| Resolution: | → invalid | 
|---|---|
| Status: | assigned → closed | 
The patch is not valid. It was made against trunk, but trunk does work correctly. 
  Note:
 See   TracTickets
 for help on using tickets.
    
I should have put the settings.py part into brackets.