Tuesday, October 22, 2013

Re: MySQL error when trying to run tests with utf8mb4 charset

I think you may be barking up the wrong tree, see https://code.djangoproject.com/ticket/21196

On Friday, October 18, 2013 7:30:10 PM UTC-4, fle...@fletchowns.net wrote:
Looks like this comes from custom_user.py in django.contrib.auth.tests:

class CustomUser(AbstractBaseUser):
    email = models.EmailField(verbose_name='email address', max_length=255, unique=True)
    is_active = models.BooleanField(default=True)
    is_admin = models.BooleanField(default=False)
    date_of_birth = models.DateField()

I think this should have the same length as AbstractUser, where it does not specify a max_length, so it defaults to 75 in django.db.models.fields.EmailField. Should I submit a pull request for this change?

Thanks!

On Wednesday, October 16, 2013 11:01:45 AM UTC-7, fle...@fletchowns.net wrote:
Hello!

I tried to run ./manage.py test for the first time and I got the following error:

DatabaseError: (1071, 'Specified key was too long; max key length is 767 bytes')

Looking at the log in MySQL, it appears to be caused by this statement:

CREATE TABLE `auth_customuser` (      `id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,      `password` varchar(128) NOT NULL,      `last_login` datetime NOT NULL,      `email` varchar(255) NOT NULL UNIQUE,      `is_active` bool NOT NULL,      `is_admin` bool NOT NULL,      `date_of_birth` date NOT NULL  )

So the email field of varchar(255) is causing me to go over the single-column index of 767 bytes in InnoDB when the charset is utf8mb4, that part I understand.

Why is it trying to create this auth_customuser table anyways though? It doesn't exist in my application normally. The email field on my auth_user table is varchar(75) so no error from that, not sure why it's a different length there though.

To get around the issue temporarily I set the database engine to sqlite, but I'd like to be able to use MySQL for the tests, since that's what my application normally uses.

Thanks in advance!

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To post to this group, send email to django-users@googlegroups.com.
Visit this group at http://groups.google.com/group/django-users.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/1365ded5-dd5b-4259-ae1b-408ce135e212%40googlegroups.com.
For more options, visit https://groups.google.com/groups/opt_out.

0 Comments:

Post a Comment

Subscribe to Post Comments [Atom]

<< Home


Real Estate