12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- // Copyright (c) 2015 The btcsuite developers
- // Use of this source code is governed by an ISC
- // license that can be found in the LICENSE file.
- package main
- import "testing"
- // TestHelp ensures the help is reasonably accurate by checking that every
- // command specified also has result types defined and the one-line usage and
- // help text can be generated for them.
- func TestHelp(t *testing.T) {
- // Ensure there are result types specified for every handler.
- for k := range rpcHandlers {
- if _, ok := rpcResultTypes[k]; !ok {
- t.Errorf("RPC handler defined for method '%v' without "+
- "also specifying result types", k)
- continue
- }
- }
- for k := range wsHandlers {
- if _, ok := rpcResultTypes[k]; !ok {
- t.Errorf("RPC handler defined for method '%v' without "+
- "also specifying result types", k)
- continue
- }
- }
- // Ensure the usage for every command can be generated without errors.
- helpCacher := newHelpCacher()
- if _, err := helpCacher.rpcUsage(true); err != nil {
- t.Fatalf("Failed to generate one-line usage: %v", err)
- }
- if _, err := helpCacher.rpcUsage(true); err != nil {
- t.Fatalf("Failed to generate one-line usage (cached): %v", err)
- }
- // Ensure the help for every command can be generated without errors.
- for k := range rpcHandlers {
- if _, err := helpCacher.rpcMethodHelp(k); err != nil {
- t.Errorf("Failed to generate help for method '%v': %v",
- k, err)
- continue
- }
- if _, err := helpCacher.rpcMethodHelp(k); err != nil {
- t.Errorf("Failed to generate help for method '%v'"+
- "(cached): %v", k, err)
- continue
- }
- }
- for k := range wsHandlers {
- if _, err := helpCacher.rpcMethodHelp(k); err != nil {
- t.Errorf("Failed to generate help for method '%v': %v",
- k, err)
- continue
- }
- if _, err := helpCacher.rpcMethodHelp(k); err != nil {
- t.Errorf("Failed to generate help for method '%v'"+
- "(cached): %v", k, err)
- continue
- }
- }
- }
|