You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SqlServerStorageConnectionTest.cs 4.7 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using Dapper;
  5. using DotNetCore.CAP.Infrastructure;
  6. using DotNetCore.CAP.Models;
  7. using Xunit;
  8. namespace DotNetCore.CAP.SqlServer.Test
  9. {
  10. public class SqlServerStorageConnectionTest : DatabaseTestHost
  11. {
  12. private SqlServerStorageConnection _storage;
  13. public SqlServerStorageConnectionTest()
  14. {
  15. var options = GetService<SqlServerOptions>();
  16. _storage = new SqlServerStorageConnection(options);
  17. }
  18. [Fact]
  19. public async void GetPublishedMessageAsync_Test()
  20. {
  21. var sql = "INSERT INTO [Cap].[Published]([Name],[Content],[Retries],[Added],[ExpiresAt],[StatusName]) OUTPUT INSERTED.Id VALUES(@Name,@Content,@Retries,@Added,@ExpiresAt,@StatusName);";
  22. var publishMessage = new CapPublishedMessage
  23. {
  24. Name = "SqlServerStorageConnectionTest",
  25. Content = "",
  26. StatusName = StatusName.Scheduled
  27. };
  28. var insertedId = default(int);
  29. using (var connection = ConnectionUtil.CreateConnection())
  30. {
  31. insertedId = connection.QueryFirst<int>(sql, publishMessage);
  32. }
  33. var message = await _storage.GetPublishedMessageAsync(insertedId);
  34. Assert.NotNull(message);
  35. Assert.Equal("SqlServerStorageConnectionTest", message.Name);
  36. Assert.Equal(StatusName.Scheduled, message.StatusName);
  37. }
  38. [Fact]
  39. public async void FetchNextMessageAsync_Test()
  40. {
  41. var sql = "INSERT INTO [Cap].[Queue]([MessageId],[MessageType]) VALUES(@MessageId,@MessageType);";
  42. var queue = new CapQueue
  43. {
  44. MessageId = 3333,
  45. MessageType = MessageType.Publish
  46. };
  47. using (var connection = ConnectionUtil.CreateConnection())
  48. {
  49. connection.Execute(sql, queue);
  50. }
  51. var fetchedMessage = await _storage.FetchNextMessageAsync();
  52. fetchedMessage.Dispose();
  53. Assert.NotNull(fetchedMessage);
  54. Assert.Equal(MessageType.Publish, fetchedMessage.MessageType);
  55. Assert.Equal(3333, fetchedMessage.MessageId);
  56. }
  57. [Fact]
  58. public async void StoreReceivedMessageAsync_Test()
  59. {
  60. var receivedMessage = new CapReceivedMessage
  61. {
  62. Name = "SqlServerStorageConnectionTest",
  63. Content = "",
  64. Group = "mygroup",
  65. StatusName = StatusName.Scheduled
  66. };
  67. Exception exception = null;
  68. try
  69. {
  70. await _storage.StoreReceivedMessageAsync(receivedMessage);
  71. }
  72. catch (Exception ex)
  73. {
  74. exception = ex;
  75. }
  76. Assert.Null(exception);
  77. }
  78. [Fact]
  79. public async void GetReceivedMessageAsync_Test()
  80. {
  81. var sql = $@"
  82. INSERT INTO [Cap].[Received]([Name],[Group],[Content],[Retries],[Added],[ExpiresAt],[StatusName]) OUTPUT INSERTED.Id
  83. VALUES(@Name,@Group,@Content,@Retries,@Added,@ExpiresAt,@StatusName);";
  84. var receivedMessage = new CapReceivedMessage
  85. {
  86. Name = "SqlServerStorageConnectionTest",
  87. Content = "",
  88. Group = "mygroup",
  89. StatusName = StatusName.Scheduled
  90. };
  91. var insertedId = default(int);
  92. using (var connection = ConnectionUtil.CreateConnection())
  93. {
  94. insertedId = connection.QueryFirst<int>(sql, receivedMessage);
  95. }
  96. var message = await _storage.GetReceivedMessageAsync(insertedId);
  97. Assert.NotNull(message);
  98. Assert.Equal(StatusName.Scheduled, message.StatusName);
  99. Assert.Equal("SqlServerStorageConnectionTest", message.Name);
  100. Assert.Equal("mygroup", message.Group);
  101. }
  102. [Fact]
  103. public async void GetNextReceviedMessageToBeEnqueuedAsync_Test()
  104. {
  105. var receivedMessage = new CapReceivedMessage
  106. {
  107. Name = "SqlServerStorageConnectionTest",
  108. Content = "",
  109. Group = "mygroup",
  110. StatusName = StatusName.Scheduled
  111. };
  112. await _storage.StoreReceivedMessageAsync(receivedMessage);
  113. var message = await _storage.GetNextReceviedMessageToBeEnqueuedAsync();
  114. Assert.NotNull(message);
  115. Assert.Equal(StatusName.Scheduled, message.StatusName);
  116. Assert.Equal("SqlServerStorageConnectionTest", message.Name);
  117. Assert.Equal("mygroup", message.Group);
  118. }
  119. }
  120. }