Compare commits
	
		
			1 Commits
		
	
	
		
			v0.14.3
			...
			insert-con
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 98e1df0c45 | 
| @@ -296,22 +296,25 @@ class BaseQuerySet(object): | |||||||
|             result = None |             result = None | ||||||
|         return result |         return result | ||||||
|  |  | ||||||
|     def insert(self, doc_or_docs, load_bulk=True, |     def insert(self, doc_or_docs, load_bulk=True, write_concern=None, | ||||||
|                write_concern=None, signal_kwargs=None): |                signal_kwargs=None, continue_on_error=None): | ||||||
|         """bulk insert documents |         """bulk insert documents | ||||||
|  |  | ||||||
|         :param doc_or_docs: a document or list of documents to be inserted |         :param doc_or_docs: a document or list of documents to be inserted | ||||||
|         :param load_bulk (optional): If True returns the list of document |         :param load_bulk (optional): If True returns the list of document | ||||||
|             instances |             instances | ||||||
|         :param write_concern: Extra keyword arguments are passed down to |         :param write_concern: Optional keyword argument passed down to | ||||||
|                 :meth:`~pymongo.collection.Collection.insert` |                 :meth:`~pymongo.collection.Collection.insert`, representing | ||||||
|                 which will be used as options for the resultant |                 the write concern. For example, | ||||||
|                 ``getLastError`` command.  For example, |                 ``insert(..., write_concert={w: 2, fsync: True})`` will | ||||||
|                 ``insert(..., {w: 2, fsync: True})`` will wait until at least |                 wait until at least two servers have recorded the write | ||||||
|                 two servers have recorded the write and will force an fsync on |                 and will force an fsync on each server being written to. | ||||||
|                 each server being written to. |  | ||||||
|         :parm signal_kwargs: (optional) kwargs dictionary to be passed to |         :parm signal_kwargs: (optional) kwargs dictionary to be passed to | ||||||
|             the signal calls. |             the signal calls. | ||||||
|  |         :param continue_on_error: Optional keyword argument passed down to | ||||||
|  |                 :meth:`~pymongo.collection.Collection.insert`. Defines what | ||||||
|  |                 to do when a document cannot be inserted (e.g. due to | ||||||
|  |                 duplicate IDs). Read PyMongo's docs for more info. | ||||||
|  |  | ||||||
|         By default returns document instances, set ``load_bulk`` to False to |         By default returns document instances, set ``load_bulk`` to False to | ||||||
|         return just ``ObjectIds`` |         return just ``ObjectIds`` | ||||||
| @@ -322,12 +325,10 @@ class BaseQuerySet(object): | |||||||
|         """ |         """ | ||||||
|         Document = _import_class('Document') |         Document = _import_class('Document') | ||||||
|  |  | ||||||
|         if write_concern is None: |         # Determine if we're inserting one doc or more | ||||||
|             write_concern = {} |  | ||||||
|  |  | ||||||
|         docs = doc_or_docs |         docs = doc_or_docs | ||||||
|         return_one = False |         return_one = False | ||||||
|         if isinstance(docs, Document) or issubclass(docs.__class__, Document): |         if isinstance(docs, Document): | ||||||
|             return_one = True |             return_one = True | ||||||
|             docs = [docs] |             docs = [docs] | ||||||
|  |  | ||||||
| @@ -344,9 +345,16 @@ class BaseQuerySet(object): | |||||||
|         signals.pre_bulk_insert.send(self._document, |         signals.pre_bulk_insert.send(self._document, | ||||||
|                                      documents=docs, **signal_kwargs) |                                      documents=docs, **signal_kwargs) | ||||||
|  |  | ||||||
|  |         # Resolve optional insert kwargs | ||||||
|  |         insert_kwargs = {} | ||||||
|  |         if write_concern is not None: | ||||||
|  |             insert_kwargs.update(write_concern) | ||||||
|  |         if continue_on_error is not None: | ||||||
|  |             insert_kwargs['continue_on_error'] = continue_on_error | ||||||
|  |  | ||||||
|         raw = [doc.to_mongo() for doc in docs] |         raw = [doc.to_mongo() for doc in docs] | ||||||
|         try: |         try: | ||||||
|             ids = self._collection.insert(raw, **write_concern) |             ids = self._collection.insert(raw, **insert_kwargs) | ||||||
|         except pymongo.errors.DuplicateKeyError as err: |         except pymongo.errors.DuplicateKeyError as err: | ||||||
|             message = 'Could not save document (%s)' |             message = 'Could not save document (%s)' | ||||||
|             raise NotUniqueError(message % six.text_type(err)) |             raise NotUniqueError(message % six.text_type(err)) | ||||||
|   | |||||||
| @@ -766,8 +766,7 @@ class QuerySetTest(unittest.TestCase): | |||||||
|         self.assertEqual(record.embed.field, 2) |         self.assertEqual(record.embed.field, 2) | ||||||
|  |  | ||||||
|     def test_bulk_insert(self): |     def test_bulk_insert(self): | ||||||
|         """Ensure that bulk insert works |         """Ensure that bulk insert works.""" | ||||||
|         """ |  | ||||||
|  |  | ||||||
|         class Comment(EmbeddedDocument): |         class Comment(EmbeddedDocument): | ||||||
|             name = StringField() |             name = StringField() | ||||||
| @@ -885,9 +884,37 @@ class QuerySetTest(unittest.TestCase): | |||||||
|  |  | ||||||
|         self.assertEqual(Blog.objects.count(), 2) |         self.assertEqual(Blog.objects.count(), 2) | ||||||
|  |  | ||||||
|         Blog.objects.insert([blog2, blog3], |     def test_bulk_insert_continue_on_error(self): | ||||||
|                             write_concern={"w": 0, 'continue_on_error': True}) |         """Ensure that bulk insert works with the continue_on_error option.""" | ||||||
|         self.assertEqual(Blog.objects.count(), 3) |  | ||||||
|  |         class Person(Document): | ||||||
|  |             email = EmailField(unique=True) | ||||||
|  |  | ||||||
|  |         Person.drop_collection() | ||||||
|  |  | ||||||
|  |         Person.objects.insert([ | ||||||
|  |             Person(email='alice@example.com'), | ||||||
|  |             Person(email='bob@example.com') | ||||||
|  |         ]) | ||||||
|  |         self.assertEqual(Person.objects.count(), 2) | ||||||
|  |  | ||||||
|  |         new_docs = [ | ||||||
|  |             Person(email='alice@example.com'),  # dupe | ||||||
|  |             Person(email='bob@example.com'),  # dupe | ||||||
|  |             Person(email='steve@example.com')  # new one | ||||||
|  |         ] | ||||||
|  |  | ||||||
|  |         # By default inserting dupe docs should fail and no new docs should | ||||||
|  |         # be inserted. | ||||||
|  |         with self.assertRaises(NotUniqueError): | ||||||
|  |             Person.objects.insert(new_docs) | ||||||
|  |         self.assertEqual(Person.objects.count(), 2) | ||||||
|  |  | ||||||
|  |         # With continue_on_error, new doc should be inserted, even though we | ||||||
|  |         # still get a NotUniqueError caused by the other 2 dupes. | ||||||
|  |         with self.assertRaises(NotUniqueError): | ||||||
|  |             Person.objects.insert(new_docs, continue_on_error=True) | ||||||
|  |         self.assertEqual(Person.objects.count(), 3) | ||||||
|  |  | ||||||
|     def test_get_changed_fields_query_count(self): |     def test_get_changed_fields_query_count(self): | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user