public void Authentication_succeeds_with_MONGODB_X509_mechanism( [Values(false, true)] bool async) { RequireEnvironment.Check().EnvironmentVariable("MONGO_X509_CLIENT_CERTIFICATE_PATH", isDefined: true); RequireEnvironment.Check().EnvironmentVariable("MONGO_X509_CLIENT_CERTIFICATE_PASSWORD", isDefined: true); RequireServer.Check().Tls(required: true); var pathToClientCertificate = Environment.GetEnvironmentVariable("MONGO_X509_CLIENT_CERTIFICATE_PATH"); var password = Environment.GetEnvironmentVariable("MONGO_X509_CLIENT_CERTIFICATE_PASSWORD"); var clientCertificate = new X509Certificate2(pathToClientCertificate, password); var userName = GetRfc2253FormattedUsernameFromX509ClientCertificate(clientCertificate); DropDatabaseUser(DriverTestConfiguration.Client, database: "$external", userName); CreateX509DatabaseUser(DriverTestConfiguration.Client, userName); var settings = DriverTestConfiguration.GetClientSettings().Clone(); var serverVersion = CoreTestConfiguration.ServerVersion; if (Feature.ServerExtractsUsernameFromX509Certificate.IsSupported(serverVersion)) { settings.Credential = MongoCredential.CreateMongoX509Credential(); } else { settings.Credential = MongoCredential.CreateMongoX509Credential(userName); } settings.SslSettings = settings.SslSettings.Clone(); settings.SslSettings.ClientCertificates = new[] { clientCertificate }; AssertAuthenticationSucceeds(settings, async, speculativeAuthenticatationShouldSucceedIfPossible: true); }
public void ListDatabases_should_invoke_the_correct_operation( [Values(false, true)] bool usingSession, [Values(false, true)] bool async) { var operationExecutor = new MockOperationExecutor(); var subject = new MongoClient(operationExecutor, DriverTestConfiguration.GetClientSettings()); var session = CreateClientSession(); var cancellationToken = new CancellationTokenSource().Token; var filterDocument = BsonDocument.Parse("{ name : \"awesome\" }"); var filterDefinition = (FilterDefinition <BsonDocument>)filterDocument; var nameOnly = true; var options = new ListDatabasesOptions { Filter = filterDefinition, NameOnly = nameOnly }; if (usingSession) { if (async) { subject.ListDatabasesAsync(session, options, cancellationToken).GetAwaiter().GetResult(); } else { subject.ListDatabases(session, options, cancellationToken); } } else { if (async) { subject.ListDatabasesAsync(options, cancellationToken).GetAwaiter().GetResult(); } else { subject.ListDatabases(options, cancellationToken); } } var call = operationExecutor.GetReadCall <IAsyncCursor <BsonDocument> >(); if (usingSession) { call.SessionId.Should().BeSameAs(session.ServerSession.Id); } else { call.UsedImplicitSession.Should().BeTrue(); } call.CancellationToken.Should().Be(cancellationToken); var operation = call.Operation.Should().BeOfType <ListDatabasesOperation>().Subject; operation.Filter.Should().Be(filterDocument); operation.NameOnly.Should().Be(nameOnly); }
public void DropDatabase_should_invoke_the_correct_operation( [Values(false, true)] bool usingSession, [Values(false, true)] bool async) { var operationExecutor = new MockOperationExecutor(); var writeConcern = new WriteConcern(1); var subject = new MongoClient(operationExecutor, DriverTestConfiguration.GetClientSettings()).WithWriteConcern(writeConcern); var session = CreateClientSession(); var cancellationToken = new CancellationTokenSource().Token; if (usingSession) { if (async) { subject.DropDatabaseAsync(session, "awesome", cancellationToken).GetAwaiter().GetResult(); } else { subject.DropDatabase(session, "awesome", cancellationToken); } } else { if (async) { subject.DropDatabaseAsync("awesome", cancellationToken).GetAwaiter().GetResult(); } else { subject.DropDatabase("awesome", cancellationToken); } } var call = operationExecutor.GetWriteCall <BsonDocument>(); if (usingSession) { call.SessionId.Should().BeSameAs(session.ServerSession.Id); } else { call.UsedImplicitSession.Should().BeTrue(); } call.CancellationToken.Should().Be(cancellationToken); var dropDatabaseOperation = call.Operation.Should().BeOfType <DropDatabaseOperation>().Subject; dropDatabaseOperation.DatabaseNamespace.Should().Be(new DatabaseNamespace("awesome")); dropDatabaseOperation.WriteConcern.Should().BeSameAs(writeConcern); }
public static MongoServer GetServer( bool?retryWrites = null) { var settings = DriverTestConfiguration.GetClientSettings(); if (retryWrites.HasValue) { settings.RetryWrites = retryWrites.Value; } var client = new MongoClient(settings); #pragma warning disable 618 return(client.GetServer()); #pragma warning restore 618 }
public void ListDatabases_should_invoke_the_correct_operation( [Values(false, true)] bool usingSession, [Values(false, true)] bool async) { var operationExecutor = new MockOperationExecutor(); var subject = new MongoClient(operationExecutor, DriverTestConfiguration.GetClientSettings()); var session = CreateClientSession(); var cancellationToken = new CancellationTokenSource().Token; if (usingSession) { if (async) { subject.ListDatabasesAsync(session, cancellationToken).GetAwaiter().GetResult(); } else { subject.ListDatabases(session, cancellationToken); } } else { if (async) { subject.ListDatabasesAsync(cancellationToken).GetAwaiter().GetResult(); } else { subject.ListDatabases(cancellationToken); } } var call = operationExecutor.GetReadCall <IAsyncCursor <BsonDocument> >(); if (usingSession) { call.SessionId.Should().BeSameAs(session.ServerSession.Id); } else { call.UsedImplicitSession.Should().BeTrue(); } call.CancellationToken.Should().Be(cancellationToken); call.Operation.Should().BeOfType <ListDatabasesOperation>(); }
// private methods /* We can't use DriverTestConfiguration.CreateDisposableClient because that results in a call to check * the cluster type, which fails because a connection cannot be established to the mongod when testing * the revoked certificate case */ private DisposableMongoClient CreateDisposableMongoClient(bool tlsInsecure) { var settings = DriverTestConfiguration.GetClientSettings().Clone(); settings.SslSettings = new SslSettings { CheckCertificateRevocation = true }; // setting AllowInsecureTls= true will automatically set CheckCertificateRevocation to false settings.AllowInsecureTls = tlsInsecure; /* We want the heartbeat to fire so that we can get the HeartBeat exception in the cluster description * in the exception that will be thrown when testing invalid certificates */ settings.HeartbeatInterval = TimeSpan.FromMilliseconds(500); /* We lower the server selection timeout to speed up tests, but choosing a value <=5s may * result in the driver being unable to perform OCSP endpoint checking in time, causing a * ServerSelectionTimeout that does include a certificate revocation status error message. */ settings.ServerSelectionTimeout = TimeSpan.FromSeconds(5 * 2); // must be > 5s // settings.SdamLogFilename = @"C:\temp\sdam" + $"{tlsInsecure}.log"; return(new DisposableMongoClient(new MongoClient(settings))); }
public void ListDatabaseNames_should_invoke_the_correct_operation( [Values(false, true)] bool usingSession, [Values(false, true)] bool async) { var operationExecutor = new MockOperationExecutor(); var subject = new MongoClient(operationExecutor, DriverTestConfiguration.GetClientSettings()); var session = CreateClientSession(); var cancellationToken = new CancellationTokenSource().Token; var listDatabaseNamesResult = @" { ""databases"" : [ { ""name"" : ""admin"", ""sizeOnDisk"" : 131072, ""empty"" : false }, { ""name"" : ""blog"", ""sizeOnDisk"" : 11669504, ""empty"" : false }, { ""name"" : ""test-chambers"", ""sizeOnDisk"" : 222883840, ""empty"" : false }, { ""name"" : ""recipes"", ""sizeOnDisk"" : 73728, ""empty"" : false }, { ""name"" : ""employees"", ""sizeOnDisk"" : 225280, ""empty"" : false } ], ""totalSize"" : 252534784, ""ok"" : 1 }"; var operationResult = BsonDocument.Parse(listDatabaseNamesResult); operationExecutor.EnqueueResult(CreateListDatabasesOperationCursor(operationResult)); IList <string> databaseNames; if (async) { if (usingSession) { databaseNames = subject.ListDatabaseNamesAsync(session, cancellationToken).GetAwaiter().GetResult().ToList(); } else { databaseNames = subject.ListDatabaseNamesAsync(cancellationToken).GetAwaiter().GetResult().ToList(); } } else { if (usingSession) { databaseNames = subject.ListDatabaseNames(session, cancellationToken).ToList(); } else { databaseNames = subject.ListDatabaseNames(cancellationToken).ToList(); } } var call = operationExecutor.GetReadCall <IAsyncCursor <BsonDocument> >(); if (usingSession) { call.SessionId.Should().BeSameAs(session.ServerSession.Id); } else { call.UsedImplicitSession.Should().BeTrue(); } call.CancellationToken.Should().Be(cancellationToken); var operation = call.Operation.Should().BeOfType <ListDatabasesOperation>().Subject; operation.NameOnly.Should().Be(true); databaseNames.Should().Equal(operationResult["databases"].AsBsonArray.Select(record => record["name"].AsString)); }
public void Watch_should_invoke_the_correct_operation( [Values(false, true)] bool usingSession, [Values(false, true)] bool async) { var operationExecutor = new MockOperationExecutor(); var clientSettings = DriverTestConfiguration.GetClientSettings(); var subject = new MongoClient(operationExecutor, clientSettings); var session = usingSession ? CreateClientSession() : null; var pipeline = new EmptyPipelineDefinition <ChangeStreamDocument <BsonDocument> >().Limit(1); var options = new ChangeStreamOptions { BatchSize = 123, Collation = new Collation("en-us"), FullDocument = ChangeStreamFullDocumentOption.UpdateLookup, MaxAwaitTime = TimeSpan.FromSeconds(123), ResumeAfter = new BsonDocument(), StartAtOperationTime = new BsonTimestamp(1, 2) }; var cancellationToken = new CancellationTokenSource().Token; var renderedPipeline = new[] { BsonDocument.Parse("{ $limit : 1 }") }; if (usingSession) { if (async) { subject.WatchAsync(session, pipeline, options, cancellationToken).GetAwaiter().GetResult(); } else { subject.Watch(session, pipeline, options, cancellationToken); } } else { if (async) { subject.WatchAsync(pipeline, options, cancellationToken).GetAwaiter().GetResult(); } else { subject.Watch(pipeline, options, cancellationToken); } } var call = operationExecutor.GetReadCall <IAsyncCursor <ChangeStreamDocument <BsonDocument> > >(); if (usingSession) { call.SessionId.Should().BeSameAs(session.ServerSession.Id); } else { call.UsedImplicitSession.Should().BeTrue(); } call.CancellationToken.Should().Be(cancellationToken); var changeStreamOperation = call.Operation.Should().BeOfType <ChangeStreamOperation <ChangeStreamDocument <BsonDocument> > >().Subject; changeStreamOperation.BatchSize.Should().Be(options.BatchSize); changeStreamOperation.Collation.Should().BeSameAs(options.Collation); changeStreamOperation.CollectionNamespace.Should().BeNull(); changeStreamOperation.DatabaseNamespace.Should().BeNull(); changeStreamOperation.FullDocument.Should().Be(options.FullDocument); changeStreamOperation.MaxAwaitTime.Should().Be(options.MaxAwaitTime); changeStreamOperation.MessageEncoderSettings.Should().NotBeNull(); changeStreamOperation.Pipeline.Should().Equal(renderedPipeline); changeStreamOperation.ReadConcern.Should().Be(clientSettings.ReadConcern); changeStreamOperation.ResultSerializer.Should().BeOfType <ChangeStreamDocumentSerializer <BsonDocument> >(); changeStreamOperation.ResumeAfter.Should().Be(options.ResumeAfter); changeStreamOperation.StartAtOperationTime.Should().Be(options.StartAtOperationTime); }