2019-10-28 06:12:15 +00:00
|
|
|
// Copyright 2019 Google Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
|
|
// use this file except in compliance with the License. You may obtain a copy of
|
|
|
|
// the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing permissions and limitations under
|
|
|
|
// the License.
|
|
|
|
|
|
|
|
package attributecert
|
|
|
|
|
|
|
|
import (
|
2020-05-06 22:29:22 +00:00
|
|
|
"crypto/x509"
|
2019-10-28 06:12:15 +00:00
|
|
|
"encoding/json"
|
|
|
|
"io/ioutil"
|
2019-11-06 10:04:38 +00:00
|
|
|
"reflect"
|
2019-10-28 06:12:15 +00:00
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2020-05-06 22:29:22 +00:00
|
|
|
func TestVerifyAttributeCert(t *testing.T) {
|
|
|
|
testfiles := [...]string{"testdata/Intel_nuc_pc2.cer",
|
|
|
|
"testdata/Intel_nuc_pc.cer",
|
|
|
|
"testdata/Intel_pc2.cer",
|
|
|
|
"testdata/Intel_pc3.cer",
|
|
|
|
}
|
|
|
|
data, err := ioutil.ReadFile("testdata/IntelSigningKey_20April2017.cer")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to read Intel intermediate certificate: %v", err)
|
|
|
|
}
|
|
|
|
cert, err := x509.ParseCertificate(data)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to parse Intel intermediate certificate: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, filename := range(testfiles) {
|
|
|
|
data, err = ioutil.ReadFile(filename)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to read %s: %v", filename, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
attributecert, err := ParseAttributeCertificate(data)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to parse %s: %v", filename, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = attributecert.CheckSignatureFrom(cert)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to verify signature on %s: %v", filename, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-28 06:12:15 +00:00
|
|
|
func TestParseAttributeCerts(t *testing.T) {
|
|
|
|
files, err := ioutil.ReadDir("testdata")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to read test dir: %v", err)
|
|
|
|
}
|
|
|
|
for _, file := range files {
|
2020-05-06 22:29:22 +00:00
|
|
|
if strings.Contains(file.Name(), "Signing") {
|
|
|
|
continue
|
|
|
|
}
|
2019-10-28 06:12:15 +00:00
|
|
|
if strings.HasSuffix(file.Name(), ".json") {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
filename := "testdata/" + file.Name()
|
|
|
|
jsonfile := filename + ".json"
|
|
|
|
data, err := ioutil.ReadFile(filename)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to read test data %s: %v", filename, err)
|
|
|
|
}
|
2019-11-06 10:04:38 +00:00
|
|
|
got, err := ParseAttributeCertificate(data)
|
2019-10-28 06:12:15 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to parse test data %s: %v", filename, err)
|
|
|
|
}
|
|
|
|
jsondata, err := ioutil.ReadFile(jsonfile)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to read json test data %s: %v", jsonfile, err)
|
|
|
|
}
|
2019-11-06 10:04:38 +00:00
|
|
|
var want AttributeCertificate
|
|
|
|
if err := json.Unmarshal(jsondata, &want); err != nil {
|
|
|
|
t.Fatalf("failed to unmarshal file %s: %v", filename, err)
|
2019-10-28 06:12:15 +00:00
|
|
|
}
|
2019-11-06 10:04:38 +00:00
|
|
|
if !reflect.DeepEqual(&want, got) {
|
2019-10-28 06:12:15 +00:00
|
|
|
t.Fatalf("%s fails to match test data", filename)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|