# HG changeset patch # User Julien Cristau # Date 1392645683 -3600 # Node ID 079b5279a2cdd6cf262320a0ec2b572e87571cf6 # Parent 76e895a380ea21e8bc97ace5d8c8f3e011900031 [server] Handle unique constraint violations under recent sqlite The error message changed from "columns foo, bar, baz are not unique" to "UNIQUE constraint failed: table.foo, table.bar, table.baz". Closes #3564510 diff -r 76e895a380ea -r 079b5279a2cd server/sources/native.py --- a/server/sources/native.py Mon Nov 24 18:43:51 2014 +0100 +++ b/server/sources/native.py Mon Feb 17 15:01:23 2014 +0100 @@ -760,16 +760,20 @@ mo = re.search("unique_[a-z0-9]{32}", arg) if mo is not None: raise UniqueTogetherError(session, cstrname=mo.group(0)) - # sqlite + # old sqlite mo = re.search('columns (.*) are not unique', arg) - if mo is None: - # sqlite > 3.7 - mo = re.search('UNIQUE constraint failed: (.*)', arg) if mo is not None: # sqlite in use # we left chop the 'cw_' prefix of attribute names rtypes = [c.strip()[3:] for c in mo.group(1).split(',')] raise UniqueTogetherError(session, rtypes=rtypes) + # sqlite after http://www.sqlite.org/cgi/src/info/c80e229dd9c1230a + if arg.startswith('UNIQUE constraint failed:'): + # message looks like: "UNIQUE constraint failed: foo.cw_bar, foo.cw_baz" + # so drop the prefix, split on comma, drop the tablenames, and drop "cw_" + columns = arg.split(':', 1)[1].split(',') + rtypes = [c.split('.', 1)[1].strip()[3:] for c in columns] + raise UniqueTogetherError(session, rtypes=rtypes) raise return cursor