keygen_test.go 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. package main
  2. import (
  3. "bytes"
  4. "os"
  5. "testing"
  6. "github.com/slackhq/nebula/cert"
  7. "github.com/stretchr/testify/assert"
  8. )
  9. func Test_keygenSummary(t *testing.T) {
  10. assert.Equal(t, "keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`", keygenSummary())
  11. }
  12. func Test_keygenHelp(t *testing.T) {
  13. ob := &bytes.Buffer{}
  14. keygenHelp(ob)
  15. assert.Equal(
  16. t,
  17. "Usage of "+os.Args[0]+" keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`\n"+
  18. " -curve string\n"+
  19. " \tECDH Curve (25519, P256) (default \"25519\")\n"+
  20. " -out-key string\n"+
  21. " \tRequired: path to write the private key to\n"+
  22. " -out-pub string\n"+
  23. " \tRequired: path to write the public key to\n"+
  24. optionalPkcs11String(" -pkcs11 string\n \tOptional: PKCS#11 URI to an existing private key\n"),
  25. ob.String(),
  26. )
  27. }
  28. func Test_keygen(t *testing.T) {
  29. ob := &bytes.Buffer{}
  30. eb := &bytes.Buffer{}
  31. // required args
  32. assertHelpError(t, keygen([]string{"-out-pub", "nope"}, ob, eb), "-out-key is required")
  33. assert.Equal(t, "", ob.String())
  34. assert.Equal(t, "", eb.String())
  35. assertHelpError(t, keygen([]string{"-out-key", "nope"}, ob, eb), "-out-pub is required")
  36. assert.Equal(t, "", ob.String())
  37. assert.Equal(t, "", eb.String())
  38. // failed key write
  39. ob.Reset()
  40. eb.Reset()
  41. args := []string{"-out-pub", "/do/not/write/pleasepub", "-out-key", "/do/not/write/pleasekey"}
  42. assert.EqualError(t, keygen(args, ob, eb), "error while writing out-key: open /do/not/write/pleasekey: "+NoSuchDirError)
  43. assert.Equal(t, "", ob.String())
  44. assert.Equal(t, "", eb.String())
  45. // create temp key file
  46. keyF, err := os.CreateTemp("", "test.key")
  47. assert.Nil(t, err)
  48. defer os.Remove(keyF.Name())
  49. // failed pub write
  50. ob.Reset()
  51. eb.Reset()
  52. args = []string{"-out-pub", "/do/not/write/pleasepub", "-out-key", keyF.Name()}
  53. assert.EqualError(t, keygen(args, ob, eb), "error while writing out-pub: open /do/not/write/pleasepub: "+NoSuchDirError)
  54. assert.Equal(t, "", ob.String())
  55. assert.Equal(t, "", eb.String())
  56. // create temp pub file
  57. pubF, err := os.CreateTemp("", "test.pub")
  58. assert.Nil(t, err)
  59. defer os.Remove(pubF.Name())
  60. // test proper keygen
  61. ob.Reset()
  62. eb.Reset()
  63. args = []string{"-out-pub", pubF.Name(), "-out-key", keyF.Name()}
  64. assert.Nil(t, keygen(args, ob, eb))
  65. assert.Equal(t, "", ob.String())
  66. assert.Equal(t, "", eb.String())
  67. // read cert and key files
  68. rb, _ := os.ReadFile(keyF.Name())
  69. lKey, b, curve, err := cert.UnmarshalPrivateKeyFromPEM(rb)
  70. assert.Equal(t, cert.Curve_CURVE25519, curve)
  71. assert.Len(t, b, 0)
  72. assert.Nil(t, err)
  73. assert.Len(t, lKey, 32)
  74. rb, _ = os.ReadFile(pubF.Name())
  75. lPub, b, curve, err := cert.UnmarshalPublicKeyFromPEM(rb)
  76. assert.Equal(t, cert.Curve_CURVE25519, curve)
  77. assert.Len(t, b, 0)
  78. assert.Nil(t, err)
  79. assert.Len(t, lPub, 32)
  80. }