-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[8.x] [ResponseOps][Cases] Make deprecated APIs internal in serverless (
#198378) (#198640) # Backport This will backport the following commits from `main` to `8.x`: - [[ResponseOps][Cases] Make deprecated APIs internal in serverless (#198378)](#198378) <!--- Backport version: 9.4.3 --> ### Questions ? Please refer to the [Backport tool documentation](https://github.com/sqren/backport) <!--BACKPORT [{"author":{"name":"Christos Nasikas","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-11-01T07:38:32Z","message":"[ResponseOps][Cases] Make deprecated APIs internal in serverless (#198378)\n\n## Summary\r\n \r\nFixes: https://github.com/elastic/kibana/issues/198407\r\n\r\n### Checklist\r\n\r\nDelete any items that are not applicable to this PR.\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\r\n### For maintainers\r\n\r\n- [x] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#_add_your_labels)","sha":"2ae6333b1b6c004b1daa534cdab9418758593b02","branchLabelMapping":{"^v9.0.0$":"main","^v8.17.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","Team:ResponseOps","v9.0.0","Feature:Cases","backport:prev-minor","ci:project-deploy-observability","v8.17.0"],"title":"[ResponseOps][Cases] Make deprecated APIs internal in serverless","number":198378,"url":"https://github.com/elastic/kibana/pull/198378","mergeCommit":{"message":"[ResponseOps][Cases] Make deprecated APIs internal in serverless (#198378)\n\n## Summary\r\n \r\nFixes: https://github.com/elastic/kibana/issues/198407\r\n\r\n### Checklist\r\n\r\nDelete any items that are not applicable to this PR.\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\r\n### For maintainers\r\n\r\n- [x] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#_add_your_labels)","sha":"2ae6333b1b6c004b1daa534cdab9418758593b02"}},"sourceBranch":"main","suggestedTargetBranches":["8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","branchLabelMappingKey":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/198378","number":198378,"mergeCommit":{"message":"[ResponseOps][Cases] Make deprecated APIs internal in serverless (#198378)\n\n## Summary\r\n \r\nFixes: https://github.com/elastic/kibana/issues/198407\r\n\r\n### Checklist\r\n\r\nDelete any items that are not applicable to this PR.\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\r\n### For maintainers\r\n\r\n- [x] This was checked for breaking API changes and was [labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#_add_your_labels)","sha":"2ae6333b1b6c004b1daa534cdab9418758593b02"}},{"branch":"8.x","label":"v8.17.0","branchLabelMappingKey":"^v8.17.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}] BACKPORT--> Co-authored-by: Christos Nasikas <[email protected]>
- Loading branch information
1 parent
c367380
commit cca3e27
Showing
18 changed files
with
481 additions
and
169 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
62 changes: 62 additions & 0 deletions
62
x-pack/plugins/cases/server/routes/api/cases/get_case.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { createCasesClientMock } from '../../../client/mocks'; | ||
import { getCaseRoute } from './get_case'; | ||
import { httpServerMock, loggingSystemMock } from '@kbn/core/server/mocks'; | ||
|
||
describe('getCaseRoute', () => { | ||
const casesClientMock = createCasesClientMock(); | ||
const logger = loggingSystemMock.createLogger(); | ||
const response = httpServerMock.createResponseFactory(); | ||
const kibanaVersion = '8.17'; | ||
const context = { cases: { getCasesClient: jest.fn().mockResolvedValue(casesClientMock) } }; | ||
|
||
it('throws a bad request if the includeComments is set in serverless', async () => { | ||
const router = getCaseRoute({ isServerless: true }); | ||
const request = httpServerMock.createKibanaRequest({ | ||
path: '/api/cases/{case_id}/?includeComments=true', | ||
query: { includeComments: true }, | ||
params: { case_id: 'foo' }, | ||
}); | ||
|
||
await expect( | ||
// @ts-expect-error: no need to create the context | ||
router.handler({ response, request, logger, kibanaVersion, context }) | ||
).rejects.toThrowErrorMatchingInlineSnapshot(` | ||
"Failed to retrieve case in route case id: foo | ||
include comments: true: Error: includeComments is not supported" | ||
`); | ||
}); | ||
|
||
it('does not throw a bad request if the includeComments is set in non-serverless', async () => { | ||
const router = getCaseRoute({ isServerless: false }); | ||
const request = httpServerMock.createKibanaRequest({ | ||
path: '/api/cases/{case_id}/?includeComments=true', | ||
query: { includeComments: true }, | ||
params: { case_id: 'foo' }, | ||
}); | ||
|
||
await expect( | ||
// @ts-expect-error: no need to create the context | ||
router.handler({ response, request, logger, kibanaVersion, context }) | ||
).resolves.not.toThrow(); | ||
}); | ||
|
||
it('does not throw a bad request if the includeComments is not set in serverless', async () => { | ||
const router = getCaseRoute({ isServerless: true }); | ||
const request = httpServerMock.createKibanaRequest({ | ||
path: '/api/cases/{case_id}', | ||
params: { case_id: 'foo' }, | ||
}); | ||
|
||
await expect( | ||
// @ts-expect-error: no need to create the context | ||
router.handler({ response, request, logger, kibanaVersion, context }) | ||
).resolves.not.toThrow(); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
22 changes: 22 additions & 0 deletions
22
x-pack/plugins/cases/server/routes/api/comments/get_all_comment.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { getAllCommentsRoute } from './get_all_comment'; | ||
|
||
describe('getAllCommentsRoute', () => { | ||
it('marks the endpoint internal in serverless', async () => { | ||
const router = getAllCommentsRoute({ isServerless: true }); | ||
|
||
expect(router.routerOptions?.access).toBe('internal'); | ||
}); | ||
|
||
it('marks the endpoint public in non-serverless', async () => { | ||
const router = getAllCommentsRoute({ isServerless: false }); | ||
|
||
expect(router.routerOptions?.access).toBe('public'); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
22 changes: 22 additions & 0 deletions
22
x-pack/plugins/cases/server/routes/api/stats/get_status.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { getStatusRoute } from './get_status'; | ||
|
||
describe('getStatusRoute', () => { | ||
it('marks the endpoint internal in serverless', async () => { | ||
const router = getStatusRoute({ isServerless: true }); | ||
|
||
expect(router.routerOptions?.access).toBe('internal'); | ||
}); | ||
|
||
it('marks the endpoint public in non-serverless', async () => { | ||
const router = getStatusRoute({ isServerless: false }); | ||
|
||
expect(router.routerOptions?.access).toBe('public'); | ||
}); | ||
}); |
Oops, something went wrong.