t0021-config.sh 4.46 KB
Newer Older
1 2 3 4 5 6 7 8 9
#!/bin/sh

test_description="Test config command"

. lib/test-lib.sh

# we use a function so that we can run it both offline + online
test_config_cmd_set() {

Etienne Laurin's avatar
Etienne Laurin committed
10
  # flags (like --bool in "ipfs config --bool")
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
  cfg_flags="" # unset in case.
  test "$#" = 3 && { cfg_flags=$1; shift; }

  cfg_key=$1
  cfg_val=$2
  test_expect_success "ipfs config succeeds" '
    ipfs config $cfg_flags "$cfg_key" "$cfg_val"
  '

  test_expect_success "ipfs config output looks good" '
    echo "$cfg_val" >expected &&
    ipfs config "$cfg_key" >actual &&
    test_cmp expected actual
  '

  # also test our lib function. it should work too.
  cfg_key="Lib.$cfg_key"
  test_expect_success "test_config_set succeeds" '
    test_config_set $cfg_flags "$cfg_key" "$cfg_val"
  '

  test_expect_success "test_config_set value looks good" '
    echo "$cfg_val" >expected &&
    ipfs config "$cfg_key" >actual &&
    test_cmp expected actual
  '
}

39 40 41 42 43 44 45 46 47 48 49
# this is a bit brittle. the problem is we need to test
# with something that will be forced to unmarshal as a struct.
# (i.e. just setting 'ipfs config --json foo "[1, 2, 3]"') may
# set it as astring instead of proper json. We leverage the
# unmarshalling that has to happen.
CONFIG_SET_JSON_TEST='{
  "MDNS": {
    "Enabled": true,
    "Interval": 10
  }
}'
50 51 52 53 54

test_config_cmd() {
  test_config_cmd_set "beep" "boop"
  test_config_cmd_set "beep1" "boop2"
  test_config_cmd_set "beep1" "boop2"
Etienne Laurin's avatar
Etienne Laurin committed
55 56
  test_config_cmd_set "--bool" "beep2" "true"
  test_config_cmd_set "--bool" "beep2" "false"
57 58 59
  test_config_cmd_set "--json" "beep3" "true"
  test_config_cmd_set "--json" "beep3" "false"
  test_config_cmd_set "--json" "Discovery" "$CONFIG_SET_JSON_TEST"
60 61 62
  test_config_cmd_set "--json" "deep-not-defined.prop" "true"
  test_config_cmd_set "--json" "deep-null" "null"
  test_config_cmd_set "--json" "deep-null.prop" "true"
63

64 65 66 67 68 69 70 71 72 73
  test_expect_success "'ipfs config show' works" '
    ipfs config show >actual
  '

  test_expect_success "'ipfs config show' output looks good" '
    grep "\"beep\": \"boop\"," actual &&
    grep "\"beep1\": \"boop2\"," actual &&
    grep "\"beep2\": false," actual &&
    grep "\"beep3\": false," actual
  '
74

75
  test_expect_success "setup for config replace test" '
76 77
    cp "$IPFS_PATH/config" newconfig.json &&
	sed -i -e /PrivKey/d -e s/10GB/11GB/ newconfig.json &&
78 79 80 81 82 83 84 85
	sed -i '"'"'/PeerID/ { s/,$// } '"'"' newconfig.json
  '

  test_expect_success "run 'ipfs config replace'" '
	ipfs config replace - < newconfig.json
  '

  test_expect_success "check resulting config after 'ipfs config replace'" '
86 87 88 89 90 91 92 93
	sed -e /PrivKey/d "$IPFS_PATH/config" > replconfig.json &&
	sed -i -e'"'"'/PeerID/ { s/,$// } '"'"' replconfig.json &&
	test_cmp replconfig.json newconfig.json
  '

  # SECURITY
  # Those tests are here to prevent exposing the PrivKey on the network

94 95 96 97 98
  test_expect_success "'ipfs config Identity' fails" '
       test_expect_code 1 ipfs config Identity 2> ident_out
  '

  test_expect_success "output looks good" '
99
       echo "Error: cannot show or change private key through API" > ident_exp &&
100 101 102 103 104 105 106
       test_cmp ident_exp ident_out
  '

  test_expect_success "'ipfs config Identity.PrivKey' fails" '
       test_expect_code 1 ipfs config Identity.PrivKey 2> ident_out
  '

107 108 109 110
  test_expect_success "output looks good" '
       test_cmp ident_exp ident_out
  '

111 112 113 114 115
  test_expect_success "lower cased PrivKey" '
       sed -i -e '\''s/PrivKey/privkey/'\'' "$IPFS_PATH/config" &&
       test_expect_code 1 ipfs config Identity.privkey 2> ident_out
  '

116 117 118
  test_expect_success "output looks good" '
       test_cmp ident_exp ident_out
  '
119

120 121 122 123
  test_expect_success "fix it back" '
       sed -i -e '\''s/privkey/PrivKey/'\'' "$IPFS_PATH/config"
  '

124 125
  test_expect_success "'ipfs config show' doesn't include privkey" '
       ipfs config show > show_config &&
126
       test_expect_code 1 grep PrivKey show_config
127 128 129 130
  '

  test_expect_success "'ipfs config replace' injects privkey back" '
       ipfs config replace show_config &&
131
       grep "\"PrivKey\":" "$IPFS_PATH/config" | grep -e ": \".\+\"" >/dev/null
132
  '
133 134 135 136 137 138 139 140 141 142 143

  test_expect_success "'ipfs config replace' with privkey erors out" '
       cp "$IPFS_PATH/config" real_config &&
       test_expect_code 1 ipfs config replace - < real_config 2> replace_out
  '

  test_expect_success "output looks good" '
       echo "Error: setting private key with API is not supported" > replace_expected
       test_cmp replace_out replace_expected
  '

144 145 146 147 148 149 150 151 152 153 154 155 156 157
}

test_init_ipfs

# should work offline
test_config_cmd

# should work online
test_launch_ipfs_daemon
test_config_cmd
test_kill_ipfs_daemon


test_done