// 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 crypto_test import ( . "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("AESSealer", func() { It("Encode/decode", func() { key := RandStringRunes(32) message := "foo" s := &AESSealer{} encoded, err := s.Seal(message, key) Expect(err).ToNot(HaveOccurred()) Expect(encoded).ToNot(Equal(key)) Expect(len(encoded)).To(Equal(62)) // Encode again encoded2, err := s.Seal(message, key) Expect(err).ToNot(HaveOccurred()) // should differ Expect(encoded2).ToNot(Equal(encoded)) // Decrypt and check decoded, err := s.Unseal(encoded, key) Expect(err).ToNot(HaveOccurred()) Expect(decoded).To(Equal(message)) decoded, err = s.Unseal(encoded2, key) Expect(err).ToNot(HaveOccurred()) Expect(decoded).To(Equal(message)) }) }) })