Compare commits
4 Commits
no-conflic
...
queryset-c
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
38c36c0ba4 | ||
|
|
c1a8b468c5 | ||
|
|
890e58bfcd | ||
|
|
debc28a5cf |
@@ -25,8 +25,7 @@ _dbs = {}
|
|||||||
|
|
||||||
def register_connection(alias, name=None, host=None, port=None,
|
def register_connection(alias, name=None, host=None, port=None,
|
||||||
read_preference=READ_PREFERENCE,
|
read_preference=READ_PREFERENCE,
|
||||||
username=None, password=None,
|
username=None, password=None, authentication_source=None,
|
||||||
authentication_source=None,
|
|
||||||
authentication_mechanism=None,
|
authentication_mechanism=None,
|
||||||
**kwargs):
|
**kwargs):
|
||||||
"""Add a connection.
|
"""Add a connection.
|
||||||
@@ -71,26 +70,20 @@ def register_connection(alias, name=None, host=None, port=None,
|
|||||||
|
|
||||||
resolved_hosts = []
|
resolved_hosts = []
|
||||||
for entity in conn_host:
|
for entity in conn_host:
|
||||||
|
# Handle uri style connections
|
||||||
# Handle Mongomock
|
|
||||||
if entity.startswith('mongomock://'):
|
if entity.startswith('mongomock://'):
|
||||||
conn_settings['is_mock'] = True
|
conn_settings['is_mock'] = True
|
||||||
# `mongomock://` is not a valid url prefix and must be replaced by `mongodb://`
|
# `mongomock://` is not a valid url prefix and must be replaced by `mongodb://`
|
||||||
resolved_hosts.append(entity.replace('mongomock://', 'mongodb://', 1))
|
resolved_hosts.append(entity.replace('mongomock://', 'mongodb://', 1))
|
||||||
|
|
||||||
# Handle URI style connections, only updating connection params which
|
|
||||||
# were explicitly specified in the URI.
|
|
||||||
elif '://' in entity:
|
elif '://' in entity:
|
||||||
uri_dict = uri_parser.parse_uri(entity)
|
uri_dict = uri_parser.parse_uri(entity)
|
||||||
resolved_hosts.append(entity)
|
resolved_hosts.append(entity)
|
||||||
|
conn_settings.update({
|
||||||
if uri_dict.get('database'):
|
'name': uri_dict.get('database') or name,
|
||||||
conn_settings['name'] = uri_dict.get('database')
|
'username': uri_dict.get('username'),
|
||||||
|
'password': uri_dict.get('password'),
|
||||||
for param in ('read_preference', 'username', 'password'):
|
'read_preference': read_preference,
|
||||||
if uri_dict.get(param):
|
})
|
||||||
conn_settings[param] = uri_dict[param]
|
|
||||||
|
|
||||||
uri_options = uri_dict['options']
|
uri_options = uri_dict['options']
|
||||||
if 'replicaset' in uri_options:
|
if 'replicaset' in uri_options:
|
||||||
conn_settings['replicaSet'] = True
|
conn_settings['replicaSet'] = True
|
||||||
|
|||||||
@@ -933,6 +933,14 @@ class BaseQuerySet(object):
|
|||||||
queryset._ordering = queryset._get_order_by(keys)
|
queryset._ordering = queryset._get_order_by(keys)
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
|
def comment(self, text):
|
||||||
|
"""Add a comment to the query.
|
||||||
|
|
||||||
|
See https://docs.mongodb.com/manual/reference/method/cursor.comment/#cursor.comment
|
||||||
|
for details.
|
||||||
|
"""
|
||||||
|
return self._chainable_method("comment", text)
|
||||||
|
|
||||||
def explain(self, format=False):
|
def explain(self, format=False):
|
||||||
"""Return an explain plan record for the
|
"""Return an explain plan record for the
|
||||||
:class:`~mongoengine.queryset.QuerySet`\ 's cursor.
|
:class:`~mongoengine.queryset.QuerySet`\ 's cursor.
|
||||||
|
|||||||
@@ -339,7 +339,6 @@ class QuerySetTest(unittest.TestCase):
|
|||||||
|
|
||||||
def test_update_write_concern(self):
|
def test_update_write_concern(self):
|
||||||
"""Test that passing write_concern works"""
|
"""Test that passing write_concern works"""
|
||||||
|
|
||||||
self.Person.drop_collection()
|
self.Person.drop_collection()
|
||||||
|
|
||||||
write_concern = {"fsync": True}
|
write_concern = {"fsync": True}
|
||||||
@@ -2199,6 +2198,21 @@ class QuerySetTest(unittest.TestCase):
|
|||||||
a.author.name for a in Author.objects.order_by('-author__age')]
|
a.author.name for a in Author.objects.order_by('-author__age')]
|
||||||
self.assertEqual(names, ['User A', 'User B', 'User C'])
|
self.assertEqual(names, ['User A', 'User B', 'User C'])
|
||||||
|
|
||||||
|
def test_comment(self):
|
||||||
|
"""Make sure adding a comment to the query works."""
|
||||||
|
class User(Document):
|
||||||
|
age = IntField()
|
||||||
|
|
||||||
|
with db_ops_tracker() as q:
|
||||||
|
adult = (User.objects.filter(age__gte=18)
|
||||||
|
.comment('looking for an adult')
|
||||||
|
.first())
|
||||||
|
ops = q.get_ops()
|
||||||
|
self.assertEqual(len(ops), 1)
|
||||||
|
op = ops[0]
|
||||||
|
self.assertEqual(op['query']['$query'], {'age': {'$gte': 18}})
|
||||||
|
self.assertEqual(op['query']['$comment'], 'looking for an adult')
|
||||||
|
|
||||||
def test_map_reduce(self):
|
def test_map_reduce(self):
|
||||||
"""Ensure map/reduce is both mapping and reducing.
|
"""Ensure map/reduce is both mapping and reducing.
|
||||||
"""
|
"""
|
||||||
|
|||||||
@@ -174,9 +174,19 @@ class ConnectionTest(unittest.TestCase):
|
|||||||
c.mongoenginetest.system.users.remove({})
|
c.mongoenginetest.system.users.remove({})
|
||||||
|
|
||||||
def test_connect_uri_without_db(self):
|
def test_connect_uri_without_db(self):
|
||||||
"""Ensure connect() method works properly if the URI doesn't
|
"""Ensure connect() method works properly with uri's without database_name
|
||||||
include a database name.
|
|
||||||
"""
|
"""
|
||||||
|
c = connect(db='mongoenginetest', alias='admin')
|
||||||
|
c.admin.system.users.remove({})
|
||||||
|
c.mongoenginetest.system.users.remove({})
|
||||||
|
|
||||||
|
c.admin.add_user("admin", "password")
|
||||||
|
c.admin.authenticate("admin", "password")
|
||||||
|
c.mongoenginetest.add_user("username", "password")
|
||||||
|
|
||||||
|
if not IS_PYMONGO_3:
|
||||||
|
self.assertRaises(ConnectionError, connect, "testdb_uri_bad", host='mongodb://test:password@localhost')
|
||||||
|
|
||||||
connect("mongoenginetest", host='mongodb://localhost/')
|
connect("mongoenginetest", host='mongodb://localhost/')
|
||||||
|
|
||||||
conn = get_connection()
|
conn = get_connection()
|
||||||
@@ -186,31 +196,8 @@ class ConnectionTest(unittest.TestCase):
|
|||||||
self.assertTrue(isinstance(db, pymongo.database.Database))
|
self.assertTrue(isinstance(db, pymongo.database.Database))
|
||||||
self.assertEqual(db.name, 'mongoenginetest')
|
self.assertEqual(db.name, 'mongoenginetest')
|
||||||
|
|
||||||
def test_connect_uri_default_db(self):
|
c.admin.system.users.remove({})
|
||||||
"""Ensure connect() defaults to the right database name if
|
c.mongoenginetest.system.users.remove({})
|
||||||
the URI and the database_name don't explicitly specify it.
|
|
||||||
"""
|
|
||||||
connect(host='mongodb://localhost/')
|
|
||||||
|
|
||||||
conn = get_connection()
|
|
||||||
self.assertTrue(isinstance(conn, pymongo.mongo_client.MongoClient))
|
|
||||||
|
|
||||||
db = get_db()
|
|
||||||
self.assertTrue(isinstance(db, pymongo.database.Database))
|
|
||||||
self.assertEqual(db.name, 'test')
|
|
||||||
|
|
||||||
def test_uri_without_credentials_doesnt_override_conn_settings(self):
|
|
||||||
"""Ensure connect() uses the username & password params if the URI
|
|
||||||
doesn't explicitly specify them.
|
|
||||||
"""
|
|
||||||
c = connect(host='mongodb://localhost/mongoenginetest',
|
|
||||||
username='user',
|
|
||||||
password='pass')
|
|
||||||
|
|
||||||
# OperationFailure means that mongoengine attempted authentication
|
|
||||||
# w/ the provided username/password and failed - that's the desired
|
|
||||||
# behavior. If the MongoDB URI would override the credentials
|
|
||||||
self.assertRaises(OperationFailure, get_db)
|
|
||||||
|
|
||||||
def test_connect_uri_with_authsource(self):
|
def test_connect_uri_with_authsource(self):
|
||||||
"""Ensure that the connect() method works well with
|
"""Ensure that the connect() method works well with
|
||||||
|
|||||||
Reference in New Issue
Block a user