Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

South: Unknown command 'migrate'

I'm getting a merciless

$ python manage.py migrate
Unknown command: 'migrate'
Type 'manage.py help' for usage.

I pulled the code from github onto a fresh computer. This code is tested and is working on other computers. The entire code runs fine except for the fact I can't run migrations!

Installed my virtual environment and ran pip install -r requirements.txt. It installs everything, including South. I can check by running

$ python manage.py shell
>>> import south
>>> south.__version__
'0.7.3'

However, when I run the manage.py help, the migrate and schemamigration commands don't appear listed.

I double checked that my settings.py file has 'south' listed under INSTALLED_APPS (I didn't change this file after pulling).

I tried pip uninstall south and then running pip install -r requirements.txt again, but I still get the same error.

Would really appreciate any help!

like image 598
Alexandre Avatar asked Sep 10 '12 05:09

Alexandre


4 Answers

This is caused largely by following the 1.7 (DEV version) tutorial when we all get the last stable version (1.6) installed by pip.

Either follow the 1.6 tutorial or follow the instructions to install 1.7 dev version of Django.

like image 65
R Claven Avatar answered Nov 19 '22 12:11

R Claven


Successful import of package is not enough for Django management commands. Python can import a package easy from a zipped egg but Django needs a normal uncompressed file.

Advices that simplify your problem initially:

  1. Management commands must exist as files in a normal directory path..to..south/management/commands (not zipped).
  2. Try to find and remove old installations of south manually. A frequent problem was that one version of some package has been installed by easy_install (zipped) or manually by "python setup.py install" but pip didn't uninstall it and installed it for the second time.
  3. Use only absolute directories in python path. Do not change the python path between installer and running Django either in environment or by customized manage or settings.py if possible. Some manage.py or settings.py use different python path than the one used by package intallers, e.g. added "." or ".." before other directories. You should not have other south directory in . or .. in your project.

The advice 1 is an absolute requirement of Django. The other two are heplful even if I use multiple versions somehow for testing my applications with multiple versions of Python, Django etc.

Example of investigation of the main requirement:

$ python manage.py shell
>>> import os
>>> import south.management.commands.migrate
>>> assert os.path.isfile(south.management.commands.migrate.__file__)
like image 27
hynekcer Avatar answered Nov 19 '22 12:11

hynekcer


I solved this problem by going here http://south.readthedocs.org/en/latest/installation.html and using easy_install south. I then added 'south', to my INSTALLED_APPS and it worked.

like image 5
sam Avatar answered Nov 19 '22 12:11

sam


I got the same error, but for a different reason. I did:

$ python manage.py migrate my_app --settings=settings_dev.py

But with the settings parameter, you should pass the name of the module not the name of the file. So it should have been

$ python manage.py migrate my_app --settings=settings_dev

You get a decent error message when you run the validate command like that, but when you run a south command, it'll say the command is unknown :/

like image 3
Ciske Avatar answered Nov 19 '22 10:11

Ciske