// Copyright 2020 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package wycheproof import ( "crypto/hmac" "testing" ) func TestHMAC(t *testing.T) { // MacTestVector type MacTestVector struct { // A brief description of the test case Comment string `json:"comment,omitempty"` // A list of flags Flags []string `json:"flags,omitempty"` // the key Key string `json:"key,omitempty"` // the plaintext Msg string `json:"msg,omitempty"` // Test result Result string `json:"result,omitempty"` // the authentication tag Tag string `json:"tag,omitempty"` // Identifier of the test case TcId int `json:"tcId,omitempty"` } // MacTestGroup type MacTestGroup struct { // the keySize in bits KeySize int `json:"keySize,omitempty"` // the expected size of the tag in bits TagSize int `json:"tagSize,omitempty"` Tests []*MacTestVector `json:"tests,omitempty"` Type interface{} `json:"type,omitempty"` } // Notes a description of the labels used in the test vectors type Notes struct { } // Root type Root struct { // the primitive tested in the test file Algorithm string `json:"algorithm,omitempty"` // the version of the test vectors. GeneratorVersion string `json:"generatorVersion,omitempty"` // additional documentation Header []string `json:"header,omitempty"` // a description of the labels used in the test vectors Notes *Notes `json:"notes,omitempty"` // the number of test vectors in this test NumberOfTests int `json:"numberOfTests,omitempty"` Schema interface{} `json:"schema,omitempty"` TestGroups []*MacTestGroup `json:"testGroups,omitempty"` } fileHashAlgs := map[string]string{ "hmac_sha1_test.json": "SHA-1", "hmac_sha224_test.json": "SHA-224", "hmac_sha256_test.json": "SHA-256", "hmac_sha384_test.json": "SHA-384", "hmac_sha512_test.json": "SHA-512", } for f := range fileHashAlgs { var root Root readTestVector(t, f, &root) for _, tg := range root.TestGroups { h := parseHash(fileHashAlgs[f]) // Skip test vectors where the tag length does not equal the // hash length, since crypto/hmac does not support generating // these truncated tags. if tg.TagSize/8 != h.Size() { continue } for _, tv := range tg.Tests { hm := hmac.New(h.New, decodeHex(tv.Key)) hm.Write(decodeHex(tv.Msg)) tag := hm.Sum(nil) got := hmac.Equal(decodeHex(tv.Tag), tag) if want := shouldPass(tv.Result, tv.Flags, nil); want != got { t.Errorf("%s, tcid: %d, type: %s, comment: %q, unexpected result", f, tv.TcId, tv.Result, tv.Comment) } } } } }