// constructors public BulkWriteBatchResult( int batchCount, IReadOnlyList <WriteRequest> processedRequests, IReadOnlyList <WriteRequest> unprocessedRequests, long matchedCount, long deletedCount, long insertedCount, long?modifiedCount, IReadOnlyList <BulkWriteUpsert> upserts, IReadOnlyList <BulkWriteError> writeErrors, WriteConcernError writeConcernError, IndexMap indexMap) { _batchCount = batchCount; _matchedCount = matchedCount; _deletedCount = deletedCount; _insertedCount = insertedCount; _modifiedCount = modifiedCount; _indexMap = indexMap; _processedRequests = processedRequests; _writeErrors = writeErrors; _unprocessedRequests = unprocessedRequests; _upserts = upserts; _writeConcernError = writeConcernError; }
public void OneTimeSetUp() { _connectionId = new ConnectionId(new ServerId(new ClusterId(1), new DnsEndPoint("localhost", 27017)), 2); var processedRequests = new[] { new InsertOneModel<BsonDocument>(new BsonDocument("b", 1)) }; var upserts = new BulkWriteUpsert[0]; _bulkWriteResult = new BulkWriteResult<BsonDocument>.Acknowledged(1, 1, 0, 0, 0, processedRequests, upserts); _writeConcernError = new WriteConcernError(11, "funny", new BsonDocument("c", 1)); _writeErrors = new[] { new BulkWriteError(10, ServerErrorCategory.Uncategorized, 1, "blah", new BsonDocument("a", 1)) }; _unprocessedRequests = new[] { new InsertOneModel<BsonDocument>(new BsonDocument("a", 1)) }; }
// constructors /// <summary> /// Initializes a new instance of the <see cref="BulkWriteOperationException" /> class. /// </summary> /// <param name="result">The result.</param> /// <param name="writeErrors">The write errors.</param> /// <param name="unprocessedRequests">The unprocessed requests.</param> /// <param name="writeConcernError">The write concern error.</param> public BulkWriteOperationException( BulkWriteOperationResult result, IReadOnlyList<BulkWriteError> writeErrors, WriteConcernError writeConcernError, IReadOnlyList<WriteRequest> unprocessedRequests) : base("A bulk write operation resulted in one or more errors.") { _result = result; _writeErrors = writeErrors; _writeConcernError = writeConcernError; _unprocessedRequests = unprocessedRequests; }
// constructors /// <summary> /// Initializes a new instance of the <see cref="BulkWriteOperationException" /> class. /// </summary> /// <param name="result">The result.</param> /// <param name="writeErrors">The write errors.</param> /// <param name="unprocessedRequests">The unprocessed requests.</param> /// <param name="writeConcernError">The write concern error.</param> public BulkWriteOperationException( BulkWriteOperationResult result, IReadOnlyList <BulkWriteError> writeErrors, WriteConcernError writeConcernError, IReadOnlyList <WriteRequest> unprocessedRequests) : base("A bulk write operation resulted in one or more errors.") { _result = result; _writeErrors = writeErrors; _writeConcernError = writeConcernError; _unprocessedRequests = unprocessedRequests; }
public void Constructor_should_work() { var processedRequests = new WriteRequest[0]; var upserts = new BulkWriteUpsert[0]; var result = new AcknowledgedBulkWriteOperationResult(1, 2, 3, 4, 5, processedRequests, upserts); var writeErrors = new BulkWriteError[0]; var writeConcernError = new WriteConcernError(1, "message", new BsonDocument("x", 1)); var unprocessedRequests = new WriteRequest[0]; var subject = new BulkWriteOperationException(result, writeErrors, writeConcernError, unprocessedRequests); subject.Result.Should().BeSameAs(result); subject.UnprocessedRequests.Should().BeSameAs(unprocessedRequests); subject.WriteConcernError.Should().BeSameAs(writeConcernError); subject.WriteErrors.Should().BeSameAs(writeErrors); }
public static BulkWriteBatchResult Create( BulkWriteResult result, BulkWriteException exception, IndexMap indexMap) { var matchedCount = 0L; var deletedCount = 0L; var insertedCount = 0L; long?modifiedCount = null; var upserts = __noUpserts; if (result.IsAcknowledged) { matchedCount = result.MatchedCount; deletedCount = result.DeletedCount; insertedCount = result.InsertedCount; modifiedCount = result.IsModifiedCountAvailable ? (long?)result.ModifiedCount : null; upserts = result.Upserts; } var unprocessedRequests = __noWriteRequests; var writeErrors = __noWriteErrors; WriteConcernError writeConcernError = null; if (exception != null) { unprocessedRequests = exception.UnprocessedRequests; writeErrors = exception.WriteErrors; writeConcernError = exception.WriteConcernError; } return(new BulkWriteBatchResult( result.RequestCount, result.ProcessedRequests, unprocessedRequests, matchedCount, deletedCount, insertedCount, modifiedCount, upserts, writeErrors, writeConcernError, indexMap)); }
public void Serialization_should_drop_custom_fields() { var processedRequests = new WriteRequest[0]; var upserts = new BulkWriteUpsert[0]; var result = new AcknowledgedBulkWriteOperationResult(1, 2, 3, 4, 5, processedRequests, upserts); var writeErrors = new BulkWriteError[0]; var writeConcernError = new WriteConcernError(1, "message", new BsonDocument("x", 1)); var unprocessedRequests = new WriteRequest[0]; var subject = new BulkWriteOperationException(result, writeErrors, writeConcernError, unprocessedRequests); var formatter = new BinaryFormatter(); using (var stream = new MemoryStream()) { formatter.Serialize(stream, subject); stream.Position = 0; var rehydrated = (BulkWriteOperationException)formatter.Deserialize(stream); rehydrated.Result.Should().BeNull(); rehydrated.UnprocessedRequests.Should().BeNull(); rehydrated.WriteConcernError.Should().BeNull(); rehydrated.WriteErrors.Should().BeNull(); } }
// constructors public BulkWriteBatchResult( int batchCount, IReadOnlyList<WriteRequest> processedRequests, IReadOnlyList<WriteRequest> unprocessedRequests, long matchedCount, long deletedCount, long insertedCount, long? modifiedCount, IReadOnlyList<BulkWriteUpsert> upserts, IReadOnlyList<BulkWriteError> writeErrors, WriteConcernError writeConcernError, IndexMap indexMap) { _batchCount = batchCount; _matchedCount = matchedCount; _deletedCount = deletedCount; _insertedCount = insertedCount; _modifiedCount = modifiedCount; _indexMap = indexMap; _processedRequests = processedRequests; _writeErrors = writeErrors; _unprocessedRequests = unprocessedRequests; _upserts = upserts; _writeConcernError = writeConcernError; }
// internal static methods internal static WriteConcernError FromCore(Core.Operations.WriteConcernError error) { return(error == null ? null : new WriteConcernError(error.Code, error.Message, error.Details)); }
public static BulkWriteBatchResult Create( WriteRequest request, WriteConcernResult writeConcernResult, WriteConcernException writeConcernException, IndexMap indexMap) { var processedRequests = new[] { request }; var unprocessedRequests = __noWriteRequests; BsonValue upsertId = null; var documentsAffected = 0L; if (writeConcernResult != null) { upsertId = writeConcernResult.Upserted; documentsAffected = writeConcernResult.DocumentsAffected; var updateRequest = request as UpdateRequest; if (upsertId == null && documentsAffected == 1 && updateRequest != null && updateRequest.IsUpsert.GetValueOrDefault(false) && !writeConcernResult.UpdatedExisting) { // Get the _id field first from the Update document // and then from the Query document. upsertId = updateRequest.Update.ToBsonDocument().GetValue("_id", null) ?? updateRequest.Query.ToBsonDocument().GetValue("_id", null); } } var upserts = (upsertId == null) ? __noUpserts : new[] { new BulkWriteUpsert(0, upsertId) }; var writeErrors = __noWriteErrors; WriteConcernError writeConcernError = null; if (writeConcernException != null) { var getLastErrorResponse = writeConcernResult.Wrapped; if (IsGetLasterrorResponseAWriteConcernError(getLastErrorResponse)) { writeConcernError = CreateWriteConcernErrorFromGetLastErrorResponse(getLastErrorResponse); } else { writeErrors = new[] { CreateWriteErrorFromGetLastErrorResponse(getLastErrorResponse) }; } } if (request.RequestType == WriteRequestType.Insert && writeErrors.Count == 0) { documentsAffected = 1; // note: DocumentsAffected is 0 for inserts } var matchedCount = 0L; var deletedCount = 0L; var insertedCount = 0L; long?modifiedCount = 0L; switch (request.RequestType) { case WriteRequestType.Delete: deletedCount = documentsAffected; break; case WriteRequestType.Insert: insertedCount = documentsAffected; break; case WriteRequestType.Update: matchedCount = documentsAffected - upserts.Count(); modifiedCount = null; // getLasterror does not report this value break; } return(new BulkWriteBatchResult( 1, // batchCount processedRequests, unprocessedRequests, matchedCount, deletedCount, insertedCount, modifiedCount, upserts, writeErrors, writeConcernError, indexMap)); }