// Copyright © 2022 Ettore Di Giacinto // // 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 . 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)) }) }) })