diff options
author | Wladimir J. van der Laan <laanwj@gmail.com> | 2017-07-06 15:01:27 +0200 |
---|---|---|
committer | Wladimir J. van der Laan <laanwj@gmail.com> | 2017-09-07 22:34:18 +0200 |
commit | 77aa9e59ea0e6a000a0aea5dec4ef9585356147d (patch) | |
tree | 5d1e65a047e37711c584d46c1dba3908c406f3f7 /src/rpc/protocol.h | |
parent | 52f8877525d5238f3440e73710507be889d14127 (diff) |
test: Check RPC argument mapping
Parse the dispatch tables from the server implementation files,
and the conversion table from the client.
Perform the following consistency checks:
- Arguments defined in conversion table, must be present in dispatch
table. If not, it was probably forgotten to add them to the
dispatch table, and they will not work.
- Arguments defined in conversion table must have the same names as
in the dispatch table. If not, they will not work.
- All aliases for an argument must either be present in the
conversion table, or not. Anything in between means an oversight
and some aliases won't work.
Any of these results in an error.
It also performs a consistency check to see if the same
named argument is sometimes converted, and sometimes not. E.g.
one RPC call might have a 'verbose' argument that is converted,
another RPC call might have one that is not converted. This is not
necessarily wrong, but points at a possible error (as well as
makes the API harder to memorize) - so it is emitted as a warning
(could upgrade this to error).
Diffstat (limited to 'src/rpc/protocol.h')
0 files changed, 0 insertions, 0 deletions