// Copyright 2015 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 agent import "testing" func addTestKey(t *testing.T, a Agent, keyName string) { err := a.Add(AddedKey{ PrivateKey: testPrivateKeys[keyName], Comment: keyName, }) if err != nil { t.Fatalf("failed to add key %q: %v", keyName, err) } } func removeTestKey(t *testing.T, a Agent, keyName string) { err := a.Remove(testPublicKeys[keyName]) if err != nil { t.Fatalf("failed to remove key %q: %v", keyName, err) } } func validateListedKeys(t *testing.T, a Agent, expectedKeys []string) { listedKeys, err := a.List() if err != nil { t.Fatalf("failed to list keys: %v", err) return } if len(listedKeys) != len(expectedKeys) { t.Fatalf("expeted %d key, got %d", len(expectedKeys), len(listedKeys)) return } actualKeys := make(map[string]bool) for _, key := range listedKeys { actualKeys[key.Comment] = true } matchedKeys := make(map[string]bool) for _, expectedKey := range expectedKeys { if !actualKeys[expectedKey] { t.Fatalf("expected key %q, but was not found", expectedKey) } else { matchedKeys[expectedKey] = true } } for actualKey := range actualKeys { if !matchedKeys[actualKey] { t.Fatalf("key %q was found, but was not expected", actualKey) } } } func TestKeyringAddingAndRemoving(t *testing.T) { keyNames := []string{"dsa", "ecdsa", "rsa", "user"} // add all test private keys k := NewKeyring() for _, keyName := range keyNames { addTestKey(t, k, keyName) } validateListedKeys(t, k, keyNames) // remove a key in the middle keyToRemove := keyNames[1] keyNames = append(keyNames[:1], keyNames[2:]...) removeTestKey(t, k, keyToRemove) validateListedKeys(t, k, keyNames) // remove all keys err := k.RemoveAll() if err != nil { t.Fatalf("failed to remove all keys: %v", err) } validateListedKeys(t, k, []string{}) } func TestAddDuplicateKey(t *testing.T) { keyNames := []string{"rsa", "user"} k := NewKeyring() for _, keyName := range keyNames { addTestKey(t, k, keyName) } validateListedKeys(t, k, keyNames) // Add the keys again. for _, keyName := range keyNames { addTestKey(t, k, keyName) } validateListedKeys(t, k, keyNames) // Add an existing key with an updated comment. keyName := keyNames[0] addedKey := AddedKey{ PrivateKey: testPrivateKeys[keyName], Comment: "comment updated", } err := k.Add(addedKey) if err != nil { t.Fatalf("failed to add key %q: %v", keyName, err) } // Check the that key is found and the comment was updated. keys, err := k.List() if err != nil { t.Fatalf("failed to list keys: %v", err) } if len(keys) != len(keyNames) { t.Fatalf("expected %d keys, got %d", len(keyNames), len(keys)) } isFound := false for _, key := range keys { if key.Comment == addedKey.Comment { isFound = true } } if !isFound { t.Fatal("key with the updated comment not found") } }