Skip to content

Comments

Fix/issue666#889

Merged
thiagoloureiro merged 4 commits intoThreeMammals:developfrom
aliprogrammer69:fix/issue666
May 20, 2019
Merged

Fix/issue666#889
thiagoloureiro merged 4 commits intoThreeMammals:developfrom
aliprogrammer69:fix/issue666

Conversation

@aliprogrammer69
Copy link
Contributor

@aliprogrammer69 aliprogrammer69 commented May 14, 2019

fixed issue
#666

@thiagoloureiro
Copy link
Contributor

@aliprogrammer69 Hi mate, your PR looks good, Just wondering if we need to unit test this method:

GenerateRequestCacheKey

@aliprogrammer69
Copy link
Contributor Author

aliprogrammer69 commented May 15, 2019

dear @thiagoloureiro I wrote unit test to cover method GenerateRequestCacheKey and sent pull request AppVeyor build succeeded but the travis ci returned error below

The command "sudo apt-get install -qq dotnet-sdk-2.1=2.1.500*" failed and exited with 100 during .

@thiagoloureiro
Copy link
Contributor

dear @thiagoloureiro I wrote unit test to cover method GenerateRequestCacheKey and sent pull request AppVeyor build succeeded but the travis ci returned error below

The command "sudo apt-get install -qq dotnet-sdk-2.1=2.1.500*" failed and exited with 100 during .

Sometimes travis-ci causes issues, appveyor was ok, so no worries.

@aliprogrammer69
Copy link
Contributor Author

is there any problem? when are you going to release new version and publish to nuget?

@alashti
Copy link

alashti commented May 20, 2019

this bug costs a lot for us.
thanks for your work on its fixing.
when does it going to be released? is it possible to use it in following days?

@thiagoloureiro thiagoloureiro merged commit 2eb8a19 into ThreeMammals:develop May 20, 2019
@thiagoloureiro
Copy link
Contributor

will release today later the new version ok ! :)

@aliprogrammer69 aliprogrammer69 deleted the fix/issue666 branch May 20, 2019 07:45
thiagoloureiro added a commit that referenced this pull request May 20, 2019
* Fixed Format Issue for Kubernetes ServiceDiscoveryProvider

* Fixes broken links (#858)

* Fix link to issue 262

* Fixes broken link to issue 340

* Fixed broken link to issue 340 (#857)

* Update information for Okta Authorization (#853)

* +dynamic claim variables (#855)

incl. tests

* IOcelotPipelineBuilder.Use(): Return IOcelotPipelineBuilder (#875)

Fixes #685

* Fix UpstreamHost checking when reroutes duplicate validation (#864)

* Format json in reame (#877)

Format json file in AdministrationApi ReadMe

* kubernetes use in cluster (#882)

* refactor :kubernetes use in cluster

* feat:delete KubeClient

* add more flexible method to config ocelot pipeline (#880)

* update k8s doc & samples (#885)

* refactor :kubernetes use in cluster

* feat:delete KubeClient

* feat :  update k8s doc & samples

* Update kubernetes.rst

* Fix/issue666 (#889)

* cache key now can generate from query string for request with Get Methods and request content for requests with post methods

* MD5Helper Added. OutputCacheMiddleware now can generate cache key using method, url and content

* unit test created for CacheKeyGenerator

* CacheKeyGenerator Registered in OcelotBuilder as singletone

* Fix issue #890 IDefinedAggregator can't handle error codes from downstream requests (#892)

* Release/13.2.0 (#834)

* 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 19c80af.

* 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)

* Removed Warnings

* Make the full DownstreamContext available to user defined aggregators

This allows error codes to be handled
@raman-m
Copy link
Member

raman-m commented Nov 28, 2023

@aliprogrammer69 Your design is not well-developed!

It seems your PR was not carefully reviewed in 2019 or not reviewed at all, right?

@raman-m
Copy link
Member

raman-m commented Nov 28, 2023

@thiagoloureiro You managed Ocelot project in 2019...
After closing and merging this PR the original feature #666 was not closed. Why?
Why didn't you close the feature?
Ok, I'm going to close the issue to help you...

And congrats! As a team lead of this project in 2019 after your merging you've introduced new source of out-of-memory problem and/or just a memory leakage potential problem. At least this design implementation consumes high memory & CPU too. The CacheKeyGenerator class implementation is totally wrong in these lines:

if (downstreamRequest.Content != null)
{
    var requestContentString = Task.Run(async () => await downstreamRequest.Content.ReadAsStringAsync()).Result;
    downStreamUrlKeyBuilder.Append(requestContentString);
}

Congrats, Thiago! 💥

@raman-m raman-m added the bug Identified as a potential bug label Nov 28, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

bug Identified as a potential bug

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants