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

[Obs AI Assistant] Use cookie auth for internal APIs in serverless tests #203275

Merged

Conversation

viduni94
Copy link
Contributor

@viduni94 viduni94 commented Dec 6, 2024

Summary

Problem

Cookie authentication was introduced in Kibana for serverless internal API tests via #192727.
The serverless tests for Obs AI Assistant still uses API key based auth.

Solution

Change authentication to cookie based auth for internal APIs in serverless tests.

Checklist

Check the PR satisfies following conditions.

Reviewers should verify this PR satisfies this list as well.

  • Unit or functional tests were updated or added to match the most common scenarios
  • The PR description includes the appropriate Release Notes section, and the correct release_note:* label is applied per the guidelines

@viduni94 viduni94 self-assigned this Dec 6, 2024
@viduni94 viduni94 added release_note:skip Skip the PR/issue when compiling release notes v9.0.0 Team:Obs AI Assistant Observability AI Assistant backport:version Backport to applied version labels labels Dec 6, 2024
@viduni94 viduni94 marked this pull request as ready for review December 6, 2024 21:55
@viduni94 viduni94 requested a review from a team as a code owner December 6, 2024 21:55
@elasticmachine
Copy link
Contributor

Pinging @elastic/obs-ai-assistant (Team:Obs AI Assistant)

@viduni94 viduni94 force-pushed the use-cookie-auth-for-internal-apis-serverless branch from 940a9b9 to f8b1bc7 Compare December 6, 2024 21:55
@viduni94 viduni94 force-pushed the use-cookie-auth-for-internal-apis-serverless branch from 24bd659 to 1981617 Compare December 7, 2024 14:15
@@ -70,10 +58,8 @@ export default function ApiTest({ getService }: FtrProviderContext) {
await deleteInferenceEndpoint({ es, name: AI_ASSISTANT_KB_INFERENCE_ID });

const res = await observabilityAIAssistantAPIClient
.slsUser({
.slsAdmin({
Copy link
Member

Choose a reason for hiding this comment

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

If admin privileges are required to access the status endpoint, what happens when users with the editor role call it? The status endpoint is called when starting a conversation to ensure the KB has been setup. Do we have a problem there?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Hey @sorenlouv
Thanks for reviewing.

admin privileges are not required to check the KB status (I've verified this locally).
And I updated the test to check the status with the editor role.

Copy link
Member

Choose a reason for hiding this comment

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

Thank you!

@viduni94 viduni94 requested a review from sorenlouv December 9, 2024 13:29
@viduni94 viduni94 force-pushed the use-cookie-auth-for-internal-apis-serverless branch from 2bda15d to b7ba179 Compare December 9, 2024 13:31
@elasticmachine
Copy link
Contributor

💚 Build Succeeded

Metrics [docs]

✅ unchanged

History

cc @viduni94

@neptunian
Copy link
Contributor

Looks great! Thanks!

@viduni94 viduni94 merged commit 7eb0052 into elastic:main Dec 9, 2024
8 checks passed
CAWilson94 pushed a commit to CAWilson94/kibana that referenced this pull request Dec 9, 2024
…sts (elastic#203275)

## Summary

### Problem
Cookie authentication was introduced in Kibana for serverless internal
API tests via elastic#192727.
The serverless tests for Obs AI Assistant still uses API key based auth.

### Solution
Change authentication to cookie based auth for internal APIs in
serverless tests.

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
- [x] The PR description includes the appropriate Release Notes section,
and the correct `release_note:*` label is applied per the
[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)
Samiul-TheSoccerFan pushed a commit to Samiul-TheSoccerFan/kibana that referenced this pull request Dec 10, 2024
…sts (elastic#203275)

## Summary

### Problem
Cookie authentication was introduced in Kibana for serverless internal
API tests via elastic#192727.
The serverless tests for Obs AI Assistant still uses API key based auth.

### Solution
Change authentication to cookie based auth for internal APIs in
serverless tests.

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
- [x] The PR description includes the appropriate Release Notes section,
and the correct `release_note:*` label is applied per the
[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)
@kibanamachine kibanamachine added the backport missing Added to PRs automatically when the are determined to be missing a backport. label Dec 11, 2024
@kibanamachine
Copy link
Contributor

Friendly reminder: Looks like this PR hasn’t been backported yet.
To create automatically backports add a backport:* label or prevent reminders by adding the backport:skip label.
You can also create backports manually by running node scripts/backport --pr 203275 locally

CAWilson94 pushed a commit to CAWilson94/kibana that referenced this pull request Dec 12, 2024
…sts (elastic#203275)

## Summary

### Problem
Cookie authentication was introduced in Kibana for serverless internal
API tests via elastic#192727.
The serverless tests for Obs AI Assistant still uses API key based auth.

### Solution
Change authentication to cookie based auth for internal APIs in
serverless tests.

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
- [x] The PR description includes the appropriate Release Notes section,
and the correct `release_note:*` label is applied per the
[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)
@kibanamachine
Copy link
Contributor

Friendly reminder: Looks like this PR hasn’t been backported yet.
To create automatically backports add a backport:* label or prevent reminders by adding the backport:skip label.
You can also create backports manually by running node scripts/backport --pr 203275 locally

1 similar comment
@kibanamachine
Copy link
Contributor

Friendly reminder: Looks like this PR hasn’t been backported yet.
To create automatically backports add a backport:* label or prevent reminders by adding the backport:skip label.
You can also create backports manually by running node scripts/backport --pr 203275 locally

@viduni94 viduni94 added backport:skip This commit does not require backporting and removed backport:version Backport to applied version labels labels Dec 13, 2024
@kibanamachine kibanamachine removed the backport missing Added to PRs automatically when the are determined to be missing a backport. label Dec 13, 2024
@viduni94
Copy link
Contributor Author

💚 All backports created successfully

Status Branch Result
8.x

Note: Successful backport PRs will be merged automatically after passing CI.

Questions ?

Please refer to the Backport tool documentation

viduni94 added a commit to viduni94/kibana that referenced this pull request Dec 19, 2024
…sts (elastic#203275)

## Summary

### Problem
Cookie authentication was introduced in Kibana for serverless internal
API tests via elastic#192727.
The serverless tests for Obs AI Assistant still uses API key based auth.

### Solution
Change authentication to cookie based auth for internal APIs in
serverless tests.

### Checklist

Check the PR satisfies following conditions.

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
- [x] The PR description includes the appropriate Release Notes section,
and the correct `release_note:*` label is applied per the
[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)

(cherry picked from commit 7eb0052)
viduni94 added a commit that referenced this pull request Dec 19, 2024
…ess tests (#203275) (#204883)

# Backport

This will backport the following commits from `main` to `8.x`:
- [[Obs AI Assistant] Use cookie auth for internal APIs in serverless
tests (#203275)](#203275)

<!--- Backport version: 8.9.8 -->

### Questions ?
Please refer to the [Backport tool
documentation](https://github.com/sqren/backport)

<!--BACKPORT [{"author":{"name":"Viduni
Wickramarachchi","email":"viduni.wickramarachchi@elastic.co"},"sourceCommit":{"committedDate":"2024-12-09T17:20:47Z","message":"[Obs
AI Assistant] Use cookie auth for internal APIs in serverless tests
(#203275)\n\n## Summary\r\n\r\n### Problem\r\nCookie authentication was
introduced in Kibana for serverless internal\r\nAPI tests via
https://github.com/elastic/kibana/pull/192727.\r\nThe serverless tests
for Obs AI Assistant still uses API key based auth.\r\n\r\n###
Solution\r\nChange authentication to cookie based auth for internal APIs
in\r\nserverless tests.\r\n\r\n### Checklist\r\n\r\nCheck the PR
satisfies following conditions. \r\n\r\nReviewers should verify this PR
satisfies this list as well.\r\n\r\n- [x] [Unit or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [x] The PR
description includes the appropriate Release Notes section,\r\nand the
correct `release_note:*` label is applied per
the\r\n[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"7eb005242cd5b02a10023d204e3448719650808f","branchLabelMapping":{"^v9.0.0$":"main","^v8.18.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","backport:skip","v9.0.0","Team:Obs
AI
Assistant"],"number":203275,"url":"https://github.com/elastic/kibana/pull/203275","mergeCommit":{"message":"[Obs
AI Assistant] Use cookie auth for internal APIs in serverless tests
(#203275)\n\n## Summary\r\n\r\n### Problem\r\nCookie authentication was
introduced in Kibana for serverless internal\r\nAPI tests via
https://github.com/elastic/kibana/pull/192727.\r\nThe serverless tests
for Obs AI Assistant still uses API key based auth.\r\n\r\n###
Solution\r\nChange authentication to cookie based auth for internal APIs
in\r\nserverless tests.\r\n\r\n### Checklist\r\n\r\nCheck the PR
satisfies following conditions. \r\n\r\nReviewers should verify this PR
satisfies this list as well.\r\n\r\n- [x] [Unit or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [x] The PR
description includes the appropriate Release Notes section,\r\nand the
correct `release_note:*` label is applied per
the\r\n[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"7eb005242cd5b02a10023d204e3448719650808f"}},"sourceBranch":"main","suggestedTargetBranches":[],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","labelRegex":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/203275","number":203275,"mergeCommit":{"message":"[Obs
AI Assistant] Use cookie auth for internal APIs in serverless tests
(#203275)\n\n## Summary\r\n\r\n### Problem\r\nCookie authentication was
introduced in Kibana for serverless internal\r\nAPI tests via
https://github.com/elastic/kibana/pull/192727.\r\nThe serverless tests
for Obs AI Assistant still uses API key based auth.\r\n\r\n###
Solution\r\nChange authentication to cookie based auth for internal APIs
in\r\nserverless tests.\r\n\r\n### Checklist\r\n\r\nCheck the PR
satisfies following conditions. \r\n\r\nReviewers should verify this PR
satisfies this list as well.\r\n\r\n- [x] [Unit or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [x] The PR
description includes the appropriate Release Notes section,\r\nand the
correct `release_note:*` label is applied per
the\r\n[guidelines](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"7eb005242cd5b02a10023d204e3448719650808f"}}]}]
BACKPORT-->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backport:skip This commit does not require backporting release_note:skip Skip the PR/issue when compiling release notes Team:Obs AI Assistant Observability AI Assistant v8.18.0 v9.0.0
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Obs AI Assistant] Serverless tests should use cookie based auth instead of api keys for internal routes
5 participants