Browse Source

Add typo detector test, fix panics

pull/1782/head
Ethan Frey 8 years ago
parent
commit
2c0d52f4b5
2 changed files with 54 additions and 0 deletions
  1. +8
    -0
      keys/wordcodec.go
  2. +46
    -0
      keys/wordcodec_test.go

+ 8
- 0
keys/wordcodec.go View File

@ -122,6 +122,11 @@ func (c WordCodec) BytesToWords(raw []byte) (words []string, err error) {
func (c WordCodec) WordsToBytes(words []string) ([]byte, error) { func (c WordCodec) WordsToBytes(words []string) ([]byte, error) {
l := len(words) l := len(words)
if l == 0 {
return nil, errors.New("Didn't provide any words")
}
n2048 := big.NewInt(2048) n2048 := big.NewInt(2048)
nData := big.NewInt(0) nData := big.NewInt(0)
// since we output words based on the remainder, the first word has the lowest // since we output words based on the remainder, the first word has the lowest
@ -143,6 +148,9 @@ func (c WordCodec) WordsToBytes(words []string) ([]byte, error) {
// copy into the container we have with the expected size // copy into the container we have with the expected size
outLen, flex := bytelenFromWords(len(words)) outLen, flex := bytelenFromWords(len(words))
toCheck := make([]byte, outLen) toCheck := make([]byte, outLen)
if len(dataBytes) > outLen {
return nil, errors.New("Invalid data, could not have been generated by this codec")
}
copy(toCheck[outLen-len(dataBytes):], dataBytes) copy(toCheck[outLen-len(dataBytes):], dataBytes)
// validate the checksum... // validate the checksum...


+ 46
- 0
keys/wordcodec_test.go View File

@ -130,6 +130,52 @@ func TestCheckInvalidLists(t *testing.T) {
} }
func getRandWord(c WordCodec) string {
idx := cmn.RandInt() % BankSize
return c.words[idx]
}
func getDiffWord(c WordCodec, not string) string {
w := getRandWord(c)
if w == not {
w = getRandWord(c)
}
return w
}
func TestCheckTypoDetection(t *testing.T) { func TestCheckTypoDetection(t *testing.T) {
assert, require := assert.New(t), require.New(t)
banks := []string{"english"}
for _, bank := range banks {
codec, err := LoadCodec(bank)
require.Nil(err, "%s: %+v", bank, err)
for i := 0; i < 10; i++ {
numBytes := cmn.RandInt()%60 + 1
data := cmn.RandBytes(numBytes)
words, err := codec.BytesToWords(data)
assert.Nil(err, "%s: %+v", bank, err)
good, err := codec.WordsToBytes(words)
assert.Nil(err, "%s: %+v", bank, err)
assert.Equal(data, good, bank)
// now try some tweaks...
cut := words[1:]
_, err = codec.WordsToBytes(cut)
assert.NotNil(err, "%s: %s", bank, words)
// swap a word within the bank, should fails
words[3] = getDiffWord(codec, words[3])
_, err = codec.WordsToBytes(words)
assert.NotNil(err, "%s: %s", bank, words)
// put a random word here, must fail
words[3] = cmn.RandStr(10)
_, err = codec.WordsToBytes(words)
assert.NotNil(err, "%s: %s", bank, words)
}
}
} }

Loading…
Cancel
Save