| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | // 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 crypto_testimport (	. "github.com/mudler/edgevpn/pkg/utils"	. "github.com/onsi/ginkgo/v2"	. "github.com/onsi/gomega"	. "github.com/mudler/edgevpn/pkg/crypto")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))		})	})})
 |