Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add AWS region to the AWS Config Cache key #6134

Merged
merged 15 commits into from
Dec 4, 2024

Conversation

maxbog
Copy link
Contributor

@maxbog maxbog commented Sep 4, 2024

The PR adds the AWS region to the key used by the AWS config cache

Checklist

Fixes #6128

@maxbog maxbog requested a review from a team as a code owner September 4, 2024 09:37
@maxbog maxbog force-pushed the region_in_aws_config_cache branch 4 times, most recently from e025102 to a67350c Compare September 4, 2024 13:49
@maxbog maxbog force-pushed the region_in_aws_config_cache branch from a67350c to 569eeb9 Compare September 17, 2024 19:55
Copy link
Member

@zroubalik zroubalik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The build is broken

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog maxbog force-pushed the region_in_aws_config_cache branch from 569eeb9 to 8e5b30f Compare September 18, 2024 13:12
Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog maxbog force-pushed the region_in_aws_config_cache branch from 8e5b30f to baa3cc1 Compare September 18, 2024 13:37
@maxbog
Copy link
Contributor Author

maxbog commented Sep 18, 2024

@zroubalik I fixed the build

@zroubalik
Copy link
Member

zroubalik commented Sep 18, 2024

/run-e2e aws
Update: You can check the progress here

@zroubalik
Copy link
Member

zroubalik commented Sep 19, 2024

/run-e2e aws
Update: You can check the progress here

@maxbog
Copy link
Contributor Author

maxbog commented Sep 24, 2024

@zroubalik Is something wrong with the e2e tests? I see they failed twice now :(

@zroubalik
Copy link
Member

@zroubalik Is something wrong with the e2e tests? I see they failed twice now :(

yeah, issue on our side, will rerun once it is fixed

@ndlanier
Copy link

ndlanier commented Oct 4, 2024

@zroubalik any updates on the e2e testing?

@JorTurFer
Copy link
Member

JorTurFer commented Oct 6, 2024

/run-e2e aws
Update: You can check the progress here

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog
Copy link
Contributor Author

maxbog commented Oct 9, 2024

@JorTurFer I rebased the PR
Now the tests failed, but it looks like some random crash, can you please rerun the failing job and the e2e tests?

@JorTurFer
Copy link
Member

JorTurFer commented Oct 16, 2024

/run-e2e aws
Update: You can check the progress here

Copy link
Member

@JorTurFer JorTurFer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PTAL @kedacore/keda-core-contributors

@JorTurFer JorTurFer enabled auto-merge (squash) October 16, 2024 18:00
@ndlanier
Copy link

ndlanier commented Oct 28, 2024

Any insight into why it paniced/failed on the amd64 validation?

@ndlanier
Copy link

@JorTurFer is the validate - amd64 stage failure an issue with the action or an issue with the code changes in this pr?

@JorTurFer
Copy link
Member

@JorTurFer is the validate - amd64 stage failure an issue with the action or an issue with the code changes in this pr?

I've triggered it again because probably it was a transient error

@JorTurFer
Copy link
Member

@zroubalik @wozniakjan PTAL

@JorTurFer JorTurFer disabled auto-merge October 30, 2024 20:04
@maxbog
Copy link
Contributor Author

maxbog commented Nov 7, 2024

Unit test are failing, could you take a look?

The failing tests are for prometheus scaler, and the error message is: "HTTP transport must be Google OAuth2"
TBH, I'm not sure how this is related to the changes in the PR.

@JorTurFer
Copy link
Member

JorTurFer commented Nov 7, 2024

Prometheus scaler uses multiple auth providers, maybe the region change of the latest commit has had a side effect here:

// could be the case of azure managed prometheus. Try and get the round-tripper.
// If it's not the case of azure managed prometheus, we will get both transport and err as nil and proceed assuming no auth.
azureTransport, err := azure.TryAndGetAzureManagedPrometheusHTTPRoundTripper(logger, config.PodIdentity, config.TriggerMetadata)
if err != nil {
logger.V(1).Error(err, "error while init Azure Managed Prometheus client http transport")
return nil, err
}
// transport should not be nil if its a case of azure managed prometheus
if azureTransport != nil {
httpClient.Transport = azureTransport
}
gcpTransport, err := gcp.GetGCPOAuth2HTTPTransport(config, httpClient.Transport, gcp.GcpScopeMonitoringRead)
if err != nil && !errors.Is(err, gcp.ErrGoogleApplicationCrendentialsNotFound) {
logger.V(1).Error(err, "failed to get GCP client HTTP transport (either using Google application credentials or workload identity)")
return nil, err
}
if err == nil && gcpTransport != nil {
httpClient.Transport = gcpTransport
}
awsTransport, err := aws.NewSigV4RoundTripper(config)
if err != nil {
logger.V(1).Error(err, "failed to get AWS client HTTP transport ")
return nil, err
}
if err == nil && awsTransport != nil {
httpClient.Transport = awsTransport
}
}

In any case, I've triggered the tests again

@JorTurFer
Copy link
Member

Most probably it's returning an error here:

awsTransport, err := aws.NewSigV4RoundTripper(config)
if err != nil {
logger.V(1).Error(err, "failed to get AWS client HTTP transport ")
return nil, err
}

An error in that line will make fail the test although is GCP because it returns error and not the GCP transport

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog maxbog force-pushed the region_in_aws_config_cache branch from dc06dde to 1e6115b Compare November 7, 2024 10:02
@maxbog
Copy link
Contributor Author

maxbog commented Nov 7, 2024

Unit tests are passing now

CHANGELOG.md Outdated Show resolved Hide resolved
@maxbog maxbog force-pushed the region_in_aws_config_cache branch from 675b2dd to d536acb Compare November 7, 2024 21:33
@zroubalik
Copy link
Member

zroubalik commented Nov 11, 2024

/run-e2e aws
Update: You can check the progress here

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog
Copy link
Contributor Author

maxbog commented Nov 12, 2024

Can we merge the PR? I'd rather not be stuck in the conflict -> merge -> e2e test -> conflict death spiral ;)

@votzest
Copy link

votzest commented Nov 19, 2024

it seems e2e tests got stuck again? otherwise can you merge this pr @zroubalik, please?

@JorTurFer
Copy link
Member

@zroubalik @wozniakjan , PTAL

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog
Copy link
Contributor Author

maxbog commented Nov 27, 2024

@JorTurFer @zroubalik Please take a look at this PR. It's waiting for approval for 3 weeks now. The change is ready, waiting to be merged.

@zroubalik
Copy link
Member

@maxbog there are some conflicts, please fix them and then I think we can merge this.

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@maxbog
Copy link
Contributor Author

maxbog commented Nov 28, 2024

@zroubalik done, no conflicts now

Signed-off-by: Maksymilian Boguń <max@bogun.me>
@ndlanier
Copy link

ndlanier commented Dec 2, 2024

Can we force this through, can the e2e testing either be removed or ignored?

@wozniakjan
Copy link
Member

wozniakjan commented Dec 4, 2024

/run-e2e aws
Update: You can check the progress here

@wozniakjan wozniakjan enabled auto-merge (squash) December 4, 2024 08:14
@wozniakjan wozniakjan merged commit 1eaa34c into kedacore:main Dec 4, 2024
18 checks passed
ctccxxd pushed a commit to ctccxxd/keda that referenced this pull request Dec 10, 2024
* Introduce aws region into the AWS config cache

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* add CHANGELOG entry

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* embedded AWS region into Authorization metadata

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* move the fix to Unreleased version

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* Fix indentation

Signed-off-by: Maksymilian Boguń <max@bogun.me>

---------

Signed-off-by: Maksymilian Boguń <max@bogun.me>
Signed-off-by: Jan Wozniak <wozniak.jan@gmail.com>
Co-authored-by: Jorge Turrado Ferrero <Jorge_turrado@hotmail.es>
Co-authored-by: Jan Wozniak <wozniak.jan@gmail.com>
rickbrouwer pushed a commit to rickbrouwer/keda that referenced this pull request Jan 2, 2025
* Introduce aws region into the AWS config cache

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* add CHANGELOG entry

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* embedded AWS region into Authorization metadata

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* move the fix to Unreleased version

Signed-off-by: Maksymilian Boguń <max@bogun.me>

* Fix indentation

Signed-off-by: Maksymilian Boguń <max@bogun.me>

---------

Signed-off-by: Maksymilian Boguń <max@bogun.me>
Signed-off-by: Jan Wozniak <wozniak.jan@gmail.com>
Co-authored-by: Jorge Turrado Ferrero <Jorge_turrado@hotmail.es>
Co-authored-by: Jan Wozniak <wozniak.jan@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

AWS credentials cache key needs to include the region
7 participants