keygen_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  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. //TODO: test file permissions
  10. func Test_keygenSummary(t *testing.T) {
  11. assert.Equal(t, "keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`", keygenSummary())
  12. }
  13. func Test_keygenHelp(t *testing.T) {
  14. ob := &bytes.Buffer{}
  15. keygenHelp(ob)
  16. assert.Equal(
  17. t,
  18. "Usage of "+os.Args[0]+" keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`\n"+
  19. " -curve string\n"+
  20. " \tECDH Curve (25519, P256) (default \"25519\")\n"+
  21. " -out-key string\n"+
  22. " \tRequired: path to write the private key to\n"+
  23. " -out-pub string\n"+
  24. " \tRequired: path to write the public key to\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, err := cert.UnmarshalX25519PrivateKey(rb)
  70. assert.Len(t, b, 0)
  71. assert.Nil(t, err)
  72. assert.Len(t, lKey, 32)
  73. rb, _ = os.ReadFile(pubF.Name())
  74. lPub, b, err := cert.UnmarshalX25519PublicKey(rb)
  75. assert.Len(t, b, 0)
  76. assert.Nil(t, err)
  77. assert.Len(t, lPub, 32)
  78. }