PageRenderTime 40ms CodeModel.GetById 12ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/MongoDB.Driver.Core.Tests/Core/Bindings/ReadPreferenceBindingTests.cs

http://github.com/mongodb/mongo-csharp-driver
C# | 207 lines | 159 code | 34 blank | 14 comment | 3 complexity | 61804d0b8abec4b5778b1882c8f6a62a MD5 | raw file
Possible License(s): Apache-2.0
  1. /* Copyright 2013-present MongoDB Inc.
  2. *
  3. * Licensed under the Apache License, Version 2.0 (the "License");
  4. * you may not use this file except in compliance with the License.
  5. * You may obtain a copy of the License at
  6. *
  7. * http://www.apache.org/licenses/LICENSE-2.0
  8. *
  9. * Unless required by applicable law or agreed to in writing, software
  10. * distributed under the License is distributed on an "AS IS" BASIS,
  11. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. * See the License for the specific language governing permissions and
  13. * limitations under the License.
  14. */
  15. using System;
  16. using System.Net;
  17. using System.Reflection;
  18. using System.Threading;
  19. using System.Threading.Tasks;
  20. using FluentAssertions;
  21. using MongoDB.Bson.TestHelpers.XunitExtensions;
  22. using MongoDB.Driver.Core.Bindings;
  23. using MongoDB.Driver.Core.Clusters;
  24. using MongoDB.Driver.Core.Clusters.ServerSelectors;
  25. using MongoDB.Driver.Core.Misc;
  26. using MongoDB.Driver.Core.Servers;
  27. using Moq;
  28. using Xunit;
  29. namespace MongoDB.Driver.Core.Bindings
  30. {
  31. public class ReadPreferenceBindingTests
  32. {
  33. private Mock<ICluster> _mockCluster;
  34. public ReadPreferenceBindingTests()
  35. {
  36. _mockCluster = new Mock<ICluster>();
  37. }
  38. [Fact]
  39. public void Constructor_should_throw_if_cluster_is_null()
  40. {
  41. Action act = () => new ReadPreferenceBinding(null, ReadPreference.Primary, NoCoreSession.NewHandle());
  42. act.ShouldThrow<ArgumentNullException>();
  43. }
  44. [Fact]
  45. public void Constructor_should_throw_if_readPreference_is_null()
  46. {
  47. Action act = () => new ReadPreferenceBinding(_mockCluster.Object, null, NoCoreSession.NewHandle());
  48. act.ShouldThrow<ArgumentNullException>();
  49. }
  50. [Fact]
  51. public void Constructor_should_throw_if_session_is_null()
  52. {
  53. Action act = () => new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, null);
  54. act.ShouldThrow<ArgumentNullException>();
  55. }
  56. [Fact]
  57. public void Session_should_return_expected_result()
  58. {
  59. var session = new Mock<ICoreSessionHandle>().Object;
  60. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, session);
  61. var result = subject.Session;
  62. result.Should().BeSameAs(session);
  63. }
  64. [Theory]
  65. [ParameterAttributeData]
  66. public void GetReadChannelSource_should_throw_if_disposed(
  67. [Values(false, true)]
  68. bool async)
  69. {
  70. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, NoCoreSession.NewHandle());
  71. subject.Dispose();
  72. Action act;
  73. if (async)
  74. {
  75. act = () => subject.GetReadChannelSourceAsync(CancellationToken.None).GetAwaiter().GetResult();
  76. }
  77. else
  78. {
  79. act = () => subject.GetReadChannelSource(CancellationToken.None);
  80. }
  81. act.ShouldThrow<ObjectDisposedException>();
  82. }
  83. [Theory]
  84. [ParameterAttributeData]
  85. public void GetReadChannelSource_should_use_a_read_preference_server_selector_to_select_the_server_from_the_cluster(
  86. [Values(false, true)]
  87. bool async)
  88. {
  89. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, NoCoreSession.NewHandle());
  90. var selectedServer = new Mock<IServer>().Object;
  91. var clusterId = new ClusterId();
  92. var endPoint = new DnsEndPoint("localhost", 27017);
  93. var initialClusterDescription = new ClusterDescription(
  94. clusterId,
  95. ClusterConnectionMode.Automatic,
  96. ClusterType.Unknown,
  97. new[] { new ServerDescription(new ServerId(clusterId, endPoint), endPoint) });
  98. var finalClusterDescription = initialClusterDescription.WithType(ClusterType.Standalone);
  99. _mockCluster.SetupSequence(c => c.Description).Returns(initialClusterDescription).Returns(finalClusterDescription);
  100. if (async)
  101. {
  102. _mockCluster.Setup(c => c.SelectServerAsync(It.IsAny<ReadPreferenceServerSelector>(), CancellationToken.None)).Returns(Task.FromResult(selectedServer));
  103. subject.GetReadChannelSourceAsync(CancellationToken.None).GetAwaiter().GetResult();
  104. _mockCluster.Verify(c => c.SelectServerAsync(It.IsAny<ReadPreferenceServerSelector>(), CancellationToken.None), Times.Once);
  105. }
  106. else
  107. {
  108. _mockCluster.Setup(c => c.SelectServer(It.IsAny<ReadPreferenceServerSelector>(), CancellationToken.None)).Returns(selectedServer);
  109. subject.GetReadChannelSource(CancellationToken.None);
  110. _mockCluster.Verify(c => c.SelectServer(It.IsAny<ReadPreferenceServerSelector>(), CancellationToken.None), Times.Once);
  111. }
  112. }
  113. [Theory]
  114. [ParameterAttributeData]
  115. public void GetReadChannelSource_should_fork_the_session(
  116. [Values(false, true)] bool async)
  117. {
  118. var mockSession = new Mock<ICoreSessionHandle>();
  119. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, mockSession.Object);
  120. var cancellationToken = new CancellationTokenSource().Token;
  121. var selectedServer = new Mock<IServer>().Object;
  122. _mockCluster.Setup(m => m.SelectServer(It.IsAny<IServerSelector>(), cancellationToken)).Returns(selectedServer);
  123. _mockCluster.Setup(m => m.SelectServerAsync(It.IsAny<IServerSelector>(), cancellationToken)).Returns(Task.FromResult(selectedServer));
  124. var forkedSession = new Mock<ICoreSessionHandle>().Object;
  125. mockSession.Setup(m => m.Fork()).Returns(forkedSession);
  126. var clusterId = new ClusterId();
  127. var endPoint = new DnsEndPoint("localhost", 27017);
  128. var initialClusterDescription = new ClusterDescription(
  129. clusterId,
  130. ClusterConnectionMode.Automatic,
  131. ClusterType.Unknown,
  132. new[] { new ServerDescription(new ServerId(clusterId, endPoint), endPoint) });
  133. var finalClusterDescription = initialClusterDescription.WithType(ClusterType.Standalone);
  134. _mockCluster.SetupSequence(c => c.Description).Returns(initialClusterDescription).Returns(finalClusterDescription);
  135. IChannelSourceHandle result;
  136. if (async)
  137. {
  138. result = subject.GetReadChannelSourceAsync(cancellationToken).GetAwaiter().GetResult();
  139. }
  140. else
  141. {
  142. result = subject.GetReadChannelSource(cancellationToken);
  143. }
  144. var handle = result.Should().BeOfType<ChannelSourceHandle>().Subject;
  145. var referenceCounted = handle._reference().Should().BeOfType<ReferenceCounted<IChannelSource>>().Subject;
  146. var source = referenceCounted.Instance;
  147. source.Session.Should().BeSameAs(forkedSession);
  148. }
  149. [Fact]
  150. public void Dispose_should_not_call_dispose_on_the_cluster()
  151. {
  152. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, NoCoreSession.NewHandle());
  153. subject.Dispose();
  154. _mockCluster.Verify(c => c.Dispose(), Times.Never);
  155. }
  156. [Fact]
  157. public void Dispose_should_call_dispose_on_the_session()
  158. {
  159. var mockSession = new Mock<ICoreSessionHandle>();
  160. var subject = new ReadPreferenceBinding(_mockCluster.Object, ReadPreference.Primary, mockSession.Object);
  161. subject.Dispose();
  162. mockSession.Verify(c => c.Dispose(), Times.Once);
  163. }
  164. }
  165. public static class ReadPreferenceBindingReflector
  166. {
  167. public static ICluster _cluster(this ReadPreferenceBinding obj)
  168. {
  169. var fieldInfo = typeof(ReadPreferenceBinding).GetField("_cluster", BindingFlags.NonPublic | BindingFlags.Instance);
  170. return (ICluster)fieldInfo.GetValue(obj);
  171. }
  172. }
  173. }