I don't think it's particularly contentious -- I'd certainly pay your
premise that Slugs are almost always unique (although as Dan pointed
out, they're often unique with other fields). However, I would make
two comments:
* There's a backwards compatibility issue. We can't just reverse the
value of the setting, because it would break all existing code. There
might be some ways to introduce it slowly (e.g., the value of an
"undefined" unique setting changes over a couple of releases).
However, even if we were going to go down this path, we still need to
balance the inconvenience of the change against the benefits.
* Explicit is better than implicit. By default, database fields won't
be unique -- you need to explicitly make them unique. Even though
there's a little bit more typing involved, there's something to be
said for being explicit about making every field unique.
If we had a clean slate, it might be worth reconsidering the default.
However, at this point, the behaviour of SlugField has been the way it
has for 6 years, and it has been, at worst, a minor inconvenience. For
me, given the inconvenience involved in making the change, this issue
just doesn't rise above "meh" level.
Yours,
Russ Magee %-)