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 API spec for Search Response Processors #440

Closed

Conversation

dbwiddis
Copy link
Member

@dbwiddis dbwiddis commented Jul 19, 2024

Description

Issues Resolved

Fixes #437

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.

dbwiddis added 3 commits July 18, 2024 17:22
Signed-off-by: Daniel Widdis <[email protected]>
Copy link
Contributor

github-actions bot commented Jul 19, 2024

Changes Analysis

Commit SHA: 59f5728
Comparing To SHA: 34ff292

API Changes

Summary

└─┬Components
  ├──[➕] schemas (47418:7)
  ├──[➕] schemas (47664:7)
  ├──[➕] schemas (47334:7)
  ├──[➕] schemas (47308:7)
  ├──[➕] schemas (47627:7)
  ├──[➕] schemas (47544:7)
  ├──[➕] schemas (47464:7)
  ├──[➕] schemas (47473:7)
  ├──[➕] schemas (47486:7)
  ├──[➕] schemas (47644:7)
  ├──[➕] schemas (47385:7)
  └─┬search_pipeline._common:SearchPipelineStructure
    └─┬response_processors
      └─┬Schema
        └──[🔀] $ref (47487:9)❌ 

Document Element Total Changes Breaking Changes
components 12 1
  • BREAKING Changes: 1 out of 12
  • Modifications: 1
  • Additions: 11
  • Breaking Modifications: 1

Report

The full API changes report is available at: https://github.com/opensearch-project/opensearch-api-specification/actions/runs/10051492286/artifacts/1728520593

API Coverage

Before After Δ
Covered (%) 490 (47.99 %) 490 (47.99 %) 0 (0 %)
Uncovered (%) 531 (52.01 %) 531 (52.01 %) 0 (0 %)
Unknown 24 24 0

dbwiddis added 2 commits July 18, 2024 18:15
Signed-off-by: Daniel Widdis <[email protected]>
Signed-off-by: Daniel Widdis <[email protected]>
Copy link
Member

@dblock dblock left a comment

Choose a reason for hiding this comment

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

Looks great!

Update CI to pass.

Maybe we can have coverage of all the other processors (a folder with tests/_core/search/pipeline/response_processors.yaml, etc.)? Eventually they will be used as samples for the documentation.

- path: /_search/pipeline/sorting_pipeline
method: DELETE
status: [200, 404]
version: '>= 2.16'
Copy link
Member

Choose a reason for hiding this comment

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

The CI failed because we lock the build to a specific version on dockerhub here - update it to the latest one that also has the new pipeline added.

Copy link
Member Author

Choose a reason for hiding this comment

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

The CI failed because we lock the build to a specific version on dockerhub here - update it to the latest one that also has the new pipeline added.

The PR adding this feature has not been merged yet. What is the usual pattern for writing a test for unmerged code, since submitting this API PR is a prerequisite to merging the PR? 🐔 🥚

Copy link
Member

Choose a reason for hiding this comment

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

I think you have two choices.

  1. Wait till the PR is merged and there's a build with it.
  2. Split this PR in 2, one for existing features and one for the new one, and (1) for the new one.

Copy link
Member Author

Choose a reason for hiding this comment

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

I had already assumed option 1 was the expectation.

Copy link
Member

Choose a reason for hiding this comment

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

Thanks @dbwiddis, looking forward to getting all this closed out!

@dbwiddis
Copy link
Member Author

Maybe we can have coverage of all the other processors (a folder with tests/_core/search/pipeline/response_processors.yaml, etc.)?

I'm really trying to timebox how much I'm doing on this. I'll follow up with another PR if necessary but I really just need to get some 2.16.0 features in.

Eventually they will be used as samples for the documentation.

I had that thought but then it just seemed like integration testing and this spec didn't seem the right place to do that. Isn't the goal here just to make sure the REST request works?

I wrote detailed samples here and it seems having a link in the API docs to one authoritative source is better than duplicating it?

@dblock
Copy link
Member

dblock commented Jul 19, 2024

I had that thought but then it just seemed like integration testing and this spec didn't seem the right place to do that. Isn't the goal here just to make sure the REST request works?

The goal here is to make sure that the schema matches between requests and responses. When you write integration tests here the OpenAPI spec is validated, not that the server works.

@dblock
Copy link
Member

dblock commented Jul 19, 2024

I wrote detailed samples here and it seems having a link in the API docs to one authoritative source is better than duplicating it?

The spec should be that source. The problem with the documentation as written is that there's no guarantee that it's correct, so our documentation contains a ton of bugs and typos. With running samples in this repo we will be able to export both the reference documentation (opensearch-project/documentation-website#7700) and working samples in 8 different programming languages that are verified to be correct and work.

@dbwiddis
Copy link
Member Author

The spec should be that source.

I like this idea (I really like it) and have been trying to figure out the best way on Flow Framework to "integ test" our templates, which are "configuration as code". I think a test framework like you have here is a great solution and I'll be writing an issue summarizing it shortly.

In the meantime to keep tracking this ask, feel free to open a new issue to build test/demo setup for Search Pipelines and assign it to me. I may not get to it immediately but it'll be a fun weekend project sometime in the next month.

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.

Add Specs for Search Pipeline SearchResponseProcessors
2 participants