12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- // Copyright © 2022 Ettore Di Giacinto <[email protected]>
- //
- // This program is free software; you can redistribute it and/or modify
- // it under the terms of the GNU General Public License as published by
- // the Free Software Foundation; either version 2 of the License, or
- // (at your option) any later version.
- //
- // This program is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU General Public License for more details.
- //
- // You should have received a copy of the GNU General Public License along
- // with this program; if not, see <http://www.gnu.org/licenses/>.
- package utils_test
- import (
- . "github.com/onsi/ginkgo"
- . "github.com/onsi/gomega"
- . "github.com/mudler/edgevpn/pkg/utils"
- )
- var _ = Describe("Crypto utilities", func() {
- Context("AES", func() {
- It("Encode/decode", func() {
- key := RandStringRunes(32)
- message := "foo"
- k := [32]byte{}
- copy([]byte(key)[:], k[:32])
- encoded, err := AESEncrypt(message, &k)
- Expect(err).ToNot(HaveOccurred())
- Expect(encoded).ToNot(Equal(key))
- Expect(len(encoded)).To(Equal(62))
- // Encode again
- encoded2, err := AESEncrypt(message, &k)
- Expect(err).ToNot(HaveOccurred())
- // should differ
- Expect(encoded2).ToNot(Equal(encoded))
- // Decrypt and check
- decoded, err := AESDecrypt(encoded, &k)
- Expect(err).ToNot(HaveOccurred())
- Expect(decoded).To(Equal(message))
- decoded, err = AESDecrypt(encoded2, &k)
- Expect(err).ToNot(HaveOccurred())
- Expect(decoded).To(Equal(message))
- })
- })
- })
|