Вот метод, который я тестирую:
Я построил его на основе следующей конечной точки, если это поможет: https://dev.twitch.tv/docs/api/ ссылка/#отправить
public bool PostShoutOut(ShoutOut shoutOut)
{
string date = Date.GetCurrentDateTime();
string raiderName = shoutOut.RaiderName;
try
{
Dictionary queryParams = new Dictionary
{
{ "from_broadcaster_id", shoutOut.FromBroadcasterId },
{ "to_broadcaster_id", shoutOut.ToBroadcasterId },
{ "moderator_id", shoutOut.ModeratorId }
};
UriBuilder shoutOutUri = new UriBuilder(_baseUri)
{
Path = "chat/shoutouts",
Query = string.Join("&", queryParams.Select(kvp =>
$"{Uri.EscapeDataString(kvp.Key)}={Uri.EscapeDataString(kvp.Value)}"))
};
Uri finalUri = shoutOutUri.Uri;
HttpClient client = BuildClient();
HttpResponseMessage response = client.PostAsync(finalUri, null)
.GetAwaiter()
.GetResult();
string responseContent = response.Content.ReadAsStringAsync()
.GetAwaiter()
.GetResult();
if (!response.IsSuccessStatusCode)
{
HttpStatusCode statusCode = response.StatusCode;
string reason = response.ReasonPhrase;
_logger.LogError(
"[{date}] Failed to Shoutout: {raider}. Error Code: {code} -- Reason: {reason} -- Error Message: {message}",
date, raiderName, statusCode, reason, responseContent);
return false;
}
_logger.LogInformation("[{date}] Shouted Out: {raider} successfully!",
date, raiderName);
return true;
}
catch (Exception ex)
{
// _logger.LogError("Exception thrown when shouting out {raider}: {ex}",
// raiderName,
// ex.Message);
throw ex;
return false;
}
}
Вот мой тест:
[Test]
public void PostShoutOut_ShouldPostSuccessfully_ReturnTrue()
{
ShoutOut shoutOut = new ShoutOut("123456", "456231", "7895555", "TestName");
HttpResponseMessage expectedResponse = new HttpResponseMessage(HttpStatusCode.NoContent);
_mockHttpMessageHandler
.Protected()
.Setup
(
"SendAsync",
ItExpr.IsAny(),
It.IsAny()
)
.ReturnsAsync(expectedResponse);
_httpClient = new HttpClient(_mockHttpMessageHandler.Object);
_mockHttpClientFactory.Setup(cf => cf.CreateClient(It.IsAny())).Returns(_httpClient);
bool result = _httpClientRequests.PostShoutOut(shoutOut);
Assert.That(result, Is.True);
}
Проблема, с которой я столкнулся, заключается в том, что как только эта строка кода запускается, она мгновенно попадает в блок исключений:
HttpResponseMessage response = client.PostAsync(finalUri, null)
.GetAwaiter()
.GetResult();
У кого-нибудь есть идеи?
Если я просто запускаю код в prod, он работает, это просто тест, который терпит неудачу, и я не знаю, почему... У меня есть другой метод, который отправляет сообщение, и он работает, так что я не знаю, почему этот конкретный тест терпит неудачу.
Единственная разница, которую я вижу между рабочим тестом и этим неудачным, заключается в том, что рабочий тест возвращает 200, тогда как ожидается, что этот неудачный вариант вернет 204.
Изменить: вот выброшенное исключение
System.InvalidOperationException : Handler did not return a response message.
at System.Net.Http.HttpClient.g__Core|83_0(HttpRequestMessage request, HttpCompletionOption completionOption, CancellationTokenSource cts, Boolean disposeCts, CancellationTokenSource pendingRequestsCts, CancellationToken originalCancellationToken)
Подробнее здесь: https://stackoverflow.com/questions/787 ... nexception
HttpResponseMessage мгновенно выдает исключение InvalidOperationException ⇐ C#
Место общения программистов C#
1720070409
Anonymous
Вот метод, который я тестирую:
Я построил его на основе следующей конечной точки, если это поможет: https://dev.twitch.tv/docs/api/ ссылка/#отправить
public bool PostShoutOut(ShoutOut shoutOut)
{
string date = Date.GetCurrentDateTime();
string raiderName = shoutOut.RaiderName;
try
{
Dictionary queryParams = new Dictionary
{
{ "from_broadcaster_id", shoutOut.FromBroadcasterId },
{ "to_broadcaster_id", shoutOut.ToBroadcasterId },
{ "moderator_id", shoutOut.ModeratorId }
};
UriBuilder shoutOutUri = new UriBuilder(_baseUri)
{
Path = "chat/shoutouts",
Query = string.Join("&", queryParams.Select(kvp =>
$"{Uri.EscapeDataString(kvp.Key)}={Uri.EscapeDataString(kvp.Value)}"))
};
Uri finalUri = shoutOutUri.Uri;
HttpClient client = BuildClient();
HttpResponseMessage response = client.PostAsync(finalUri, null)
.GetAwaiter()
.GetResult();
string responseContent = response.Content.ReadAsStringAsync()
.GetAwaiter()
.GetResult();
if (!response.IsSuccessStatusCode)
{
HttpStatusCode statusCode = response.StatusCode;
string reason = response.ReasonPhrase;
_logger.LogError(
"[{date}] Failed to Shoutout: {raider}. Error Code: {code} -- Reason: {reason} -- Error Message: {message}",
date, raiderName, statusCode, reason, responseContent);
return false;
}
_logger.LogInformation("[{date}] Shouted Out: {raider} successfully!",
date, raiderName);
return true;
}
catch (Exception ex)
{
// _logger.LogError("Exception thrown when shouting out {raider}: {ex}",
// raiderName,
// ex.Message);
throw ex;
return false;
}
}
Вот мой тест:
[Test]
public void PostShoutOut_ShouldPostSuccessfully_ReturnTrue()
{
ShoutOut shoutOut = new ShoutOut("123456", "456231", "7895555", "TestName");
HttpResponseMessage expectedResponse = new HttpResponseMessage(HttpStatusCode.NoContent);
_mockHttpMessageHandler
.Protected()
.Setup
(
"SendAsync",
ItExpr.IsAny(),
It.IsAny()
)
.ReturnsAsync(expectedResponse);
_httpClient = new HttpClient(_mockHttpMessageHandler.Object);
_mockHttpClientFactory.Setup(cf => cf.CreateClient(It.IsAny())).Returns(_httpClient);
bool result = _httpClientRequests.PostShoutOut(shoutOut);
Assert.That(result, Is.True);
}
Проблема, с которой я столкнулся, заключается в том, что как только эта строка кода запускается, она мгновенно попадает в блок исключений:
HttpResponseMessage response = client.PostAsync(finalUri, null)
.GetAwaiter()
.GetResult();
У кого-нибудь есть идеи?
Если я просто запускаю код в prod, он работает, это просто тест, который терпит неудачу, и я не знаю, почему... У меня есть другой метод, который отправляет сообщение, и он работает, так что я не знаю, почему этот конкретный тест терпит неудачу.
Единственная разница, которую я вижу между рабочим тестом и этим неудачным, заключается в том, что рабочий тест возвращает 200, тогда как ожидается, что этот неудачный вариант вернет 204.
Изменить: вот выброшенное исключение
System.InvalidOperationException : Handler did not return a response message.
at System.Net.Http.HttpClient.g__Core|83_0(HttpRequestMessage request, HttpCompletionOption completionOption, CancellationTokenSource cts, Boolean disposeCts, CancellationTokenSource pendingRequestsCts, CancellationToken originalCancellationToken)
Подробнее здесь: [url]https://stackoverflow.com/questions/78705090/httpresponsemessage-instantly-throwing-invalidoperationexception[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия