We need to have one tool to specify and document all APIs, as these must be easy to discover.
Knowledge about the 4 levels of maturity of a REST API (Richardson Maturity Model)
one of the first API documentation tool
able to document the API lifecycle: design, testing, documentation, mocking
offers an editor with syntax auto-completion and error feedback
APIs can be mocked and tested
it’s an advancement of Swagger (v 2.0 of both tools were exactly the same)
basically the same as Swagger with the newest updates
Alternative to the other API documentation tools, very close to the other spring tools. Therefore useful if you also use spring for your actualy REST API.
test-driven approach, docu written either as Spring MVC tests, Spring Webflux’s WebTestClient or REST-Assured
Excel tables: they are able to do this job but at a serious loss of readability, they also offer zero functionality for testing/mocking/verification
Postman was one of the first API documentation tools and the others derived their knowledge from it. Swagger became the standard afterwards and is now slowly replaced by OpenAPI, which is basicly the same with the newest updates.
The Spring REST Docs use documentation in a test-driven approach which is not within the scope of our usage of an API docu tool and may require much more initial training to work with to understand the features we do not need.
OpenAPI as the most recent generally usable tool which focuses on documentation while also providing an optional mocking feature to test the APIs
OpenAPI Specification
OpenAPI is not dependent on the usage of any other tools, therefore every context team can use it without technical restrictions. It also offers the functionality we need without laying too much focus on features we do not need (it’s not test-driven)