52 lines
		
	
	
		
			986 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			986 B
		
	
	
	
		
			Go
		
	
	
	
	
	
package whisper
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"crypto/elliptic"
 | 
						|
	"fmt"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/ethereum/go-ethereum/crypto"
 | 
						|
)
 | 
						|
 | 
						|
func TestSign(t *testing.T) {
 | 
						|
	prv, _ := crypto.GenerateKey()
 | 
						|
	msg := NewMessage([]byte("hello world"))
 | 
						|
	msg.sign(prv)
 | 
						|
 | 
						|
	pubKey := msg.Recover()
 | 
						|
	p1 := elliptic.Marshal(crypto.S256(), prv.PublicKey.X, prv.PublicKey.Y)
 | 
						|
	p2 := elliptic.Marshal(crypto.S256(), pubKey.X, pubKey.Y)
 | 
						|
 | 
						|
	if !bytes.Equal(p1, p2) {
 | 
						|
		t.Error("recovered pub key did not match")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestMessageEncryptDecrypt(t *testing.T) {
 | 
						|
	prv1, _ := crypto.GenerateKey()
 | 
						|
	prv2, _ := crypto.GenerateKey()
 | 
						|
 | 
						|
	data := []byte("hello world")
 | 
						|
	msg := NewMessage(data)
 | 
						|
	envelope, err := msg.Seal(DefaultPow, Opts{
 | 
						|
		From: prv1,
 | 
						|
		To:   &prv2.PublicKey,
 | 
						|
	})
 | 
						|
	if err != nil {
 | 
						|
		fmt.Println(err)
 | 
						|
		t.FailNow()
 | 
						|
	}
 | 
						|
 | 
						|
	msg1, err := envelope.Open(prv2)
 | 
						|
	if err != nil {
 | 
						|
		fmt.Println(err)
 | 
						|
		t.FailNow()
 | 
						|
	}
 | 
						|
 | 
						|
	if !bytes.Equal(msg1.Payload, data) {
 | 
						|
		fmt.Println("encryption error. data did not match")
 | 
						|
		t.FailNow()
 | 
						|
	}
 | 
						|
}
 |