0

私は、構築中の API で django テストを機能させようとしています。私はPythonの初心者で、しばらくこれに固執しています。

いくつかの簡単な事実:

  • 私は 2 つのデータベースを使用しています。ユーザー用の postgresql データベースと、その他すべて用の mongo データベースです。
  • TastyPie、Django-MongoDB-Engine、Djangotoolbox、Django-Non-rel、Pymongo、psycopg2 を使用しています。
  • データベースに正常に接続しました。シェルからauth_userを保存すると、SQLデータベースに保存され、アプリのモデルがmongoDBに保存されます

これを別の API と統合する必要があるため、データベースとライブラリのオプションに限定されていました。

私の大きな問題はテストに関するものです - 私はそれを動作させることができません。

./manage.py テストで Django のテストを実行しようとすると、次のエラーが発生し続けます。

pymongo.errors.OperationFailure: command SON([('authenticate', 1), ('user', u'test'), ('nonce', u'blahblah'), ('key', u'blahblah')]) failed: auth fails

大規模な検索の後、私はまだそれが何であるかわかりません。明らかに何かが MongoDB で認証しようとしていて、それを許可していないことはわかっています。とにかくテスト用のDBであるため、このDBを使用してテストしてもかまいません。

助けてください!私の設定とエラーメッセージは以下の通りです。


次のように、両方のデータベースを含めるようにデータベース設定をセットアップしました。

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'main_db',
        'USER': os.environ['RDS_USERNAME'],
        'PASSWORD': os.environ['RDS_PASSWORD'],
        'HOST': os.environ['RDS_HOSTNAME'],
        'PORT': os.environ['RDS_PORT'],
    },
    'mongo': {
        'ENGINE': 'django_mongodb_engine',
        'NAME': 'mongo_db',
        'USER': os.environ['MONGO_USERNAME'],
        'PASSWORD': os.environ['MONGO_PASSWORD'],
        'HOST': os.environ['MONGO_HOSTNAME'],
        'PORT': os.environ['MONGO_PORT'],
    }
}

DATABASE_ROUTERS = ['myproject.database_router.AuthRouter']

ご覧のとおり、独自のカスタム ルーターを作成しました。

sql_databases = ['admin', 'auth', 'contenttypes', 'tastypie'
                 'sessions', 'messages', 'staticfiles']


class AuthRouter(object):
    """
    A router to control all database operations on models in the
    auth application.
    """
    def db_for_read(self, model, **hints):
        """
        Attempts to read auth models go to auth_db.
        """
        if model._meta.app_label in sql_databases:
            return 'default'
        return 'mongo'

    def db_for_write(self, model, **hints):
        """
        Attempts to write auth models go to auth_db.
        """
        if model._meta.app_label in sql_databases:
            return 'default'
        return 'mongo'

    def allow_relation(self, obj1, obj2, **hints):
        """
        Allow relations only if model does includes auth app.
        """
        if obj1._meta.app_label in sql_databases or \
           obj2._meta.app_label in sql_databases:
                return True
        return False

    def allow_migrate(self, db, model):
        """
        Make sure the auth app only appears in the 'auth_db'
        database.
        """
        if db == 'default':
            return model._meta.app_label in sql_databases
        elif model._meta.app_label in sql_databases:
            return False
        return False

完全なトレースは次のとおりです。

Traceback (most recent call last):
File "./manage.py", line 10, in <module>
  execute_from_command_line(sys.argv)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/__init__.py", line 399, in execute_from_command_line
  utility.execute()
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/__init__.py", line 392, in execute
  self.fetch_command(subcommand).run_from_argv(self.argv)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/commands/test.py", line 50, in run_from_argv
  super(Command, self).run_from_argv(argv)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/base.py", line 242, in run_from_argv
  self.execute(*args, **options.__dict__)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/commands/test.py", line 71, in execute
  super(Command, self).execute(*args, **options)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/base.py", line 285, in execute
  output = self.handle(*args, **options)
File "myproject/djenv/lib/python2.7/site-packages/django/core/management/commands/test.py", line 88, in handle
  failures = test_runner.run_tests(test_labels)
File "myproject/djenv/lib/python2.7/site-packages/django/test/runner.py", line 145, in run_tests
  old_config = self.setup_databases()
File "myproject/djenv/lib/python2.7/site-packages/django/test/runner.py", line 107, in setup_databases
  return setup_databases(self.verbosity, self.interactive, **kwargs)
File "myproject/djenv/lib/python2.7/site-packages/django/test/runner.py", line 279, in setup_databases
  verbosity, autoclobber=not interactive)
File "myproject/djenv/lib/python2.7/site-packages/django_mongodb_engine/creation.py", line 196, in create_test_db
  self.connection._reconnect()
File "myproject/djenv/lib/python2.7/site-packages/django_mongodb_engine/base.py", line 279, in _reconnect
  self._connect()
File "myproject/djenv/lib/python2.7/site-packages/django_mongodb_engine/base.py", line 268, in _connect
  if not self.database.authenticate(user, password):
File "myproject/djenv/lib/python2.7/site-packages/pymongo/database.py", line 891, in authenticate
  self.connection._cache_credentials(self.name, credentials)
File "myproject/djenv/lib/python2.7/site-packages/pymongo/mongo_client.py", line 459, in _cache_credentials
  auth.authenticate(credentials, sock_info, self.__simple_command)
File "myproject/djenv/lib/python2.7/site-packages/pymongo/auth.py", line 243, in authenticate
  auth_func(credentials[1:], sock_info, cmd_func)
File "myproject/djenv/lib/python2.7/site-packages/pymongo/auth.py", line 222, in _authenticate_mongo_cr
  cmd_func(sock_info, source, query)
File "myproject/djenv/lib/python2.7/site-packages/pymongo/mongo_client.py", line 690, in __simple_command
  helpers._check_command_response(response, None, msg)
File "myproject/djenv/lib/python2.7/site-packages/pymongo/helpers.py", line 178, in _check_command_response
  raise OperationFailure(msg % errmsg, code, response)
pymongo.errors.OperationFailure: command SON([('authenticate', 1), ('user', u'test'), ('nonce', u'blahblah'), ('key', u'blahblah')]) failed: auth fails

どんな助けでも大歓迎です!

4

1 に答える 1

0

これをどのように修正したかについて最新情報を提供したかった-読み取り/書き込みの問題(認証失敗の問題)だと思ったが、そうではなかった。

  1. このエラーが表示された場合は、認証の問題です。ユーザー名、パスワード、データベース名、またはコレクション名のいずれかが正しくありません。

    pymongo.errors.OperationFailure: command SON([('authenticate', 1), ('user', u'test'), ('nonce', 
    u'blahblah'), ('key', u'blahblah')]) failed: auth fails
    
  2. Django は、テスト データベースをセットアップするときに、データベース名の先頭に「test_」を追加します。したがって、maindb と呼ばれる私のメイン データベースは、'test_maindb' として作成されます。

    これに関する情報は、 Test Databases and Djangoで確認できます。

  3. 名前に「test_」が追加されたデータベース名として指定された別のデータベースに書き込むことができることを確認してください。

    また、代替ソリューションは、データベース設定でテスト データベース設定を定義することです。これは、データベース属性のいずれかに「TEST_」を追加することで実行できます。例は次のとおりです。

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.postgresql_psycopg2',
            'NAME': 'maindb',
            'USER': os.environ['RDS_USERNAME'],
            'PASSWORD': os.environ['RDS_PASSWORD'],
            'HOST': os.environ['RDS_HOSTNAME'],
            'PORT': os.environ['RDS_PORT'],
            'TEST_NAME': 'my_test_sql',
            'TEST_USER': 'test_sql_user',
            'TEST_PASSWORD': 'password'
        },
        'mongo': {
            'ENGINE': 'django_mongodb_engine',
            'NAME': 'mongodb',
            'USER': os.environ['MONGO_USERNAME'],
            'PASSWORD': os.environ['MONGO_PASSWORD'],
            'HOST': os.environ['MONGO_HOSTNAME'],
            'PORT': os.environ['MONGO_PORT'],
            'TEST_NAME': 'my_test_mongodb',
            'TEST_USER': 'test_mongo_user',
            'TEST_PASSWORD': 'password'
        }
    }
    

それが役に立てば幸い!また、他に何かありましたらフィードバックをお願いします

于 2014-08-19T17:54:24.200 に答える