mirror of
https://github.com/nsnail/Ocelot.git
synced 2025-06-19 21:48:15 +08:00

* Fix formatting in getting started page (#752)
* updated release docs (#745)
* Update README.md (#756)
Fixed typo "Ocleot"
* Fixed typo there => their (#763)
* Some Typo fixes (#765)
* Typo algorythm => algorithm (#764)
* Typo querystring => query string (#766)
* Typo usual => usually (#767)
* Typos (#768)
* kubernetes provider (#772)
* feat: Kubernetes ServiceDiscoveryProvider
* 编写k8s测试例子
* feat:fix kube config
* feat: remove port
* feat : complete the k8s test
* feat : add kubeserviceDiscovery test
* feat : add kube provider unittest
* feat :add kubetnetes docs
how to use ocelot with kubetnetes docs
* keep the configuration as simple as possible, no qos, no cache
* fix: use http
* add PollingKubeServiceDiscovery
* feat : refactor logger
* feat : add pollkube docs
* feat:Remove unnecessary code
* feat : code-block json
* fix issue #661 for Advanced aggregations (#704)
* Add Advanced Aggregation Feature
* fix overwrite error
* distinct data for better performance
* remove constructor parameter
* fix tests issue
* fix tests
* fix tests issue
* Add UnitTest and AcceptanceTest
* fix responseKeys typo
* Update SimpleJsonResponseAggregator.cs
* change port
* Fix code example for SSL Errors (#780)
DangerousAcceptAnyServerCertificateValidator has to be set to "true" to disable certification validation, not "false".
* Changed wording for ease of reading (#776)
Just some wording changes for clarification.
* Ignore response content if null (fix #785) (#786)
* fix bug #791 (#795)
* Update loadbalancer.rst (#796)
* UriBuilder - remove leading question mark #747 (#794)
* Update qualityofservice.rst (#801)
Tiny typo
* K8s package (#804)
* feat: Kubernetes ServiceDiscoveryProvider
* 编写k8s测试例子
* feat:fix kube config
* feat: remove port
* feat : complete the k8s test
* feat : add kubeserviceDiscovery test
* feat : add kube provider unittest
* feat :add kubetnetes docs
how to use ocelot with kubetnetes docs
* keep the configuration as simple as possible, no qos, no cache
* fix: use http
* add PollingKubeServiceDiscovery
* feat : refactor logger
* feat : add pollkube docs
* feat:Remove unnecessary code
* feat : code-block json
* feat: publish package Ocelot.Provider.Kubernetes
* Okta integration (#807)
Okta integration
* update cliamsParser (#798)
* update cliamsParser
* update using
* IOcelotBuilder opens the IMvcCoreBuilder property for easy customization (#790)
* IOcelotBuilder opens the IMvcCoreBuilder property for easy customization
* Adjustment code
* nuget package (#809)
* feat: Kubernetes ServiceDiscoveryProvider
* 编写k8s测试例子
* feat:fix kube config
* feat: remove port
* feat : complete the k8s test
* feat : add kubeserviceDiscovery test
* feat : add kube provider unittest
* feat :add kubetnetes docs
how to use ocelot with kubetnetes docs
* keep the configuration as simple as possible, no qos, no cache
* fix: use http
* add PollingKubeServiceDiscovery
* feat : refactor logger
* feat : add pollkube docs
* feat:Remove unnecessary code
* feat : code-block json
* feat: publish package Ocelot.Provider.Kubernetes
* feat : nuget package
* fix: Namesapce Spelling wrong
* fix:Namesapce Spelling Wrong
* Fix: errors when using rate limiting (#811)
* Fix: errors when using rate limiting
Add: QuotaExceededError class for requesting too much
Add: QuotaExceededError error code
Add: Add an error when limit is reached
Reflact: Extract GetResponseMessage method for getting default or configured response message for requ
* Fix: modify check_we_have_considered_all_errors_in_these_tests for adding a new OcelotErrorCode
* added missing COPY csproj files (#821)
* Add note on In-Process hosting (#816)
When using ASP.NET Core 2.2 with In-Process hosting in IIS it's important to use .UseIIS() instead of .UseIISIntegration().
* Fix bug: (#810)
If the registered Consul node is unexpectedly down and not restarted immediately, other services should continue to find the registered service.
* Fixed Dockerfile (missing Kubernetes)
* Revert "Fix bug: (#810)" (#823)
This reverts commit 19c80afb05
.
* remove duplicate `IHttpRequester` register (#819)
* remove duplicate `IHttpRequester` register
* reserve the first
* fix HttpRequesterMiddleware does not call next bug (#830)
call next so that we can do something with the response, such as add some custom header etc...
* Removed Packing to fix issues, will be sorted out after create a nuget package on Nuget.Org (#831)
* Allows access to unpass node (#825)
* Fix bug:
If the registered Consul node is unexpectedly down and not restarted immediately, other services should continue to find the registered service.
* fix bug:
If the registered Consul node is unexpectedly down and not restarted immediately, other services should continue to find the registered service.
* Updated FluentValidations Nuget Package (#833)
172 lines
6.6 KiB
C#
172 lines
6.6 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Net;
|
|
using Ocelot.Errors;
|
|
using Ocelot.Responder;
|
|
using Shouldly;
|
|
using TestStack.BDDfy;
|
|
using Xunit;
|
|
|
|
namespace Ocelot.UnitTests.Responder
|
|
{
|
|
public class ErrorsToHttpStatusCodeMapperTests
|
|
{
|
|
private readonly IErrorsToHttpStatusCodeMapper _codeMapper;
|
|
private int _result;
|
|
private List<Error> _errors;
|
|
|
|
public ErrorsToHttpStatusCodeMapperTests()
|
|
{
|
|
_codeMapper = new ErrorsToHttpStatusCodeMapper();
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(OcelotErrorCode.UnauthenticatedError)]
|
|
public void should_return_unauthorized(OcelotErrorCode errorCode)
|
|
{
|
|
ShouldMapErrorToStatusCode(errorCode, HttpStatusCode.Unauthorized);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(OcelotErrorCode.CannotFindClaimError)]
|
|
[InlineData(OcelotErrorCode.ClaimValueNotAuthorisedError)]
|
|
[InlineData(OcelotErrorCode.ScopeNotAuthorisedError)]
|
|
[InlineData(OcelotErrorCode.UnauthorizedError)]
|
|
[InlineData(OcelotErrorCode.UserDoesNotHaveClaimError)]
|
|
public void should_return_forbidden(OcelotErrorCode errorCode)
|
|
{
|
|
ShouldMapErrorToStatusCode(errorCode, HttpStatusCode.Forbidden);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(OcelotErrorCode.RequestTimedOutError)]
|
|
public void should_return_service_unavailable(OcelotErrorCode errorCode)
|
|
{
|
|
ShouldMapErrorToStatusCode(errorCode, HttpStatusCode.ServiceUnavailable);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(OcelotErrorCode.UnableToCompleteRequestError)]
|
|
public void should_return_internal_server_error(OcelotErrorCode errorCode)
|
|
{
|
|
ShouldMapErrorToStatusCode(errorCode, HttpStatusCode.InternalServerError);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData(OcelotErrorCode.CannotAddDataError)]
|
|
[InlineData(OcelotErrorCode.CannotFindDataError)]
|
|
[InlineData(OcelotErrorCode.DownstreamHostNullOrEmptyError)]
|
|
[InlineData(OcelotErrorCode.DownstreamPathNullOrEmptyError)]
|
|
[InlineData(OcelotErrorCode.DownstreampathTemplateAlreadyUsedError)]
|
|
[InlineData(OcelotErrorCode.DownstreamPathTemplateContainsSchemeError)]
|
|
[InlineData(OcelotErrorCode.DownstreamSchemeNullOrEmptyError)]
|
|
[InlineData(OcelotErrorCode.FileValidationFailedError)]
|
|
[InlineData(OcelotErrorCode.InstructionNotForClaimsError)]
|
|
[InlineData(OcelotErrorCode.NoInstructionsError)]
|
|
[InlineData(OcelotErrorCode.ParsingConfigurationHeaderError)]
|
|
[InlineData(OcelotErrorCode.RateLimitOptionsError)]
|
|
[InlineData(OcelotErrorCode.ServicesAreEmptyError)]
|
|
[InlineData(OcelotErrorCode.ServicesAreNullError)]
|
|
[InlineData(OcelotErrorCode.UnableToCreateAuthenticationHandlerError)]
|
|
[InlineData(OcelotErrorCode.UnableToFindDownstreamRouteError)]
|
|
[InlineData(OcelotErrorCode.UnableToFindLoadBalancerError)]
|
|
[InlineData(OcelotErrorCode.UnableToFindServiceDiscoveryProviderError)]
|
|
[InlineData(OcelotErrorCode.UnableToFindQoSProviderError)]
|
|
[InlineData(OcelotErrorCode.UnknownError)]
|
|
[InlineData(OcelotErrorCode.UnmappableRequestError)]
|
|
[InlineData(OcelotErrorCode.UnsupportedAuthenticationProviderError)]
|
|
public void should_return_not_found(OcelotErrorCode errorCode)
|
|
{
|
|
ShouldMapErrorToStatusCode(errorCode, HttpStatusCode.NotFound);
|
|
}
|
|
|
|
[Fact]
|
|
public void AuthenticationErrorsHaveHighestPriority()
|
|
{
|
|
var errors = new List<OcelotErrorCode>
|
|
{
|
|
OcelotErrorCode.CannotAddDataError,
|
|
OcelotErrorCode.CannotFindClaimError,
|
|
OcelotErrorCode.UnauthenticatedError,
|
|
OcelotErrorCode.RequestTimedOutError,
|
|
};
|
|
|
|
ShouldMapErrorsToStatusCode(errors, HttpStatusCode.Unauthorized);
|
|
}
|
|
|
|
[Fact]
|
|
public void AuthorisationErrorsHaveSecondHighestPriority()
|
|
{
|
|
var errors = new List<OcelotErrorCode>
|
|
{
|
|
OcelotErrorCode.CannotAddDataError,
|
|
OcelotErrorCode.CannotFindClaimError,
|
|
OcelotErrorCode.RequestTimedOutError
|
|
};
|
|
|
|
ShouldMapErrorsToStatusCode(errors, HttpStatusCode.Forbidden);
|
|
}
|
|
|
|
[Fact]
|
|
public void ServiceUnavailableErrorsHaveThirdHighestPriority()
|
|
{
|
|
var errors = new List<OcelotErrorCode>
|
|
{
|
|
OcelotErrorCode.CannotAddDataError,
|
|
OcelotErrorCode.RequestTimedOutError
|
|
};
|
|
|
|
ShouldMapErrorsToStatusCode(errors, HttpStatusCode.ServiceUnavailable);
|
|
}
|
|
|
|
[Fact]
|
|
public void check_we_have_considered_all_errors_in_these_tests()
|
|
{
|
|
// If this test fails then it's because the number of error codes has changed.
|
|
// You should make the appropriate changes to the test cases here to ensure
|
|
// they cover all the error codes, and then modify this assertion.
|
|
Enum.GetNames(typeof(OcelotErrorCode)).Length.ShouldBe(37, "Looks like the number of error codes has changed. Do you need to modify ErrorsToHttpStatusCodeMapper?");
|
|
}
|
|
|
|
private void ShouldMapErrorToStatusCode(OcelotErrorCode errorCode, HttpStatusCode expectedHttpStatusCode)
|
|
{
|
|
ShouldMapErrorsToStatusCode(new List<OcelotErrorCode> { errorCode }, expectedHttpStatusCode);
|
|
}
|
|
|
|
private void ShouldMapErrorsToStatusCode(List<OcelotErrorCode> errorCodes, HttpStatusCode expectedHttpStatusCode)
|
|
{
|
|
var errors = new List<Error>();
|
|
|
|
foreach(var errorCode in errorCodes)
|
|
{
|
|
errors.Add(new AnyError(errorCode));
|
|
}
|
|
|
|
this.Given(x => x.GivenThereAreErrors(errors))
|
|
.When(x => x.WhenIGetErrorStatusCode())
|
|
.Then(x => x.ThenTheResponseIsStatusCodeIs(expectedHttpStatusCode))
|
|
.BDDfy();
|
|
}
|
|
|
|
private void GivenThereAreErrors(List<Error> errors)
|
|
{
|
|
_errors = errors;
|
|
}
|
|
|
|
private void WhenIGetErrorStatusCode()
|
|
{
|
|
_result = _codeMapper.Map(_errors);
|
|
}
|
|
|
|
private void ThenTheResponseIsStatusCodeIs(int expectedCode)
|
|
{
|
|
_result.ShouldBe(expectedCode);
|
|
}
|
|
|
|
private void ThenTheResponseIsStatusCodeIs(HttpStatusCode expectedCode)
|
|
{
|
|
_result.ShouldBe((int)expectedCode);
|
|
}
|
|
}
|
|
}
|