xref: /openbmc/bmcweb/CLIENTS.md (revision fdbce79b9a238aefd52f70b2a3b3d119b595d7ca)
1# Client overview
2
3bmcweb being a user and network facing daemon, is subject to a vast array of
4tests and clients that could target it. The below attempts to provide a
5non-exhaustive list of tests and clients that bmcweb is expected to be
6compatible with, they are split into a couple categories. Entries in the test
7category are intended to be qualification tests to ensure the bmcweb meets the
8specification. Entries in the clients category are intended to host user-facing
9functionality.
10
11The base expectation is that for master versions of bmcweb, and master versions
12of these tools, the tests pass 100%. There may be cases where we workaround
13limitations in the testing tools behavior within bmcweb to make the tools pass,
14regardless of whether there is user impact.
15
16## Tests
17
18Redfish-Service-Validator: A tool to verify through GET requests that bmcweb
19properly implements the Redfish schemas in the responded Resource.
20<https://github.com/DMTF/Redfish-Service-Validator.git>
21
22Status: 100% passing. Integrated with CI to ensure no regressions.
23
24Redfish-Protocol-Validator: A tool to verify the protocol-level interactions
25with the Redfish wire-protocol, and checks those against the Redfish
26specification. <https://github.com/DMTF/Redfish-Protocol-Validator>
27
28Status: 100% of assertions passing. No CI integration.
29
30OpenBMC-test-automation: A tool based on robot framework for testing some
31portion of the OpenBMC Redfish use cases.
32
33Status: Passing for some machines with CI integration.
34
35slowloris: A tool to verify timeouts and DOS attack mitigation is implemented
36properly. <https://github.com/gkbrk/slowloris>
37
38Status: Passing, no automated enforcement.
39
40testssl.sh: A tool for verifying the correctness of the bmcweb cipher suites
41against current recommended security standards
42<https://github.com/drwetter/testssl.sh>
43
44Status: Unknown
45
46## Clients
47
48fwupd: Is a client implementation that allows updating firmware components in a
49generic way, and includes redfish as one of its plugins.
50<https://github.com/fwupd/fwupd>
51
52Status: Unknown
53
54python-redfish-library: A python library used by a number of tools.
55<https://github.com/DMTF/python-redfish-library>
56
57Status: Compatible
58
59Redfish-Event-Listener: An example client for testing and implementing
60EventService handlers. <https://github.com/DMTF/Redfish-Event-Listener>
61
62Status: Compatible. No CI integration.
63
64Redfish-Tacklebox: A collection of common utilities for managing redfish servers
65<https://github.com/DMTF/Redfish-Tacklebox>
66
67Status: Unknown.
68
69redfishtool: A generic command line tool for reading and writing operations to
70the Redfish server. <https://github.com/DMTF/Redfishtool>
71
72Status: Compatible. No automated testing.
73