wip: new encoder test
This commit is contained in:
parent
c569a965e2
commit
c5df63b11d
|
@ -1,12 +1,17 @@
|
||||||
package packer
|
package packer
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Marshal(addr Addr, body []byte) ([]byte, []byte) {
|
func Encode(src, dst Addr, domain string, payload []byte) ([]byte, []byte, error) {
|
||||||
header := []byte(`IPv4,192.168.1.101,6743,` + strconv.Itoa(len(body)) + `,http,80,ex1.telebit.io`)
|
n := len(payload)
|
||||||
|
header := []byte(fmt.Sprintf(
|
||||||
|
"%s,%s,%d,%d,%s,%d,%s,\n",
|
||||||
|
src.family, src.addr, src.port,
|
||||||
|
n, dst.scheme, dst.port, domain,
|
||||||
|
))
|
||||||
raw := []byte{255 - 1, byte(len(header))}
|
raw := []byte{255 - 1, byte(len(header))}
|
||||||
header = append(raw, header...)
|
header = append(raw, header...)
|
||||||
return header, body
|
return header, payload, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,37 @@
|
||||||
|
package packer
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestEncodeDataMessage(t *testing.T) {
|
||||||
|
src := Addr{
|
||||||
|
family: "IPv4",
|
||||||
|
addr: "192.168.1.101",
|
||||||
|
port: 6743,
|
||||||
|
}
|
||||||
|
dst := Addr{
|
||||||
|
family: src.family,
|
||||||
|
port: 80,
|
||||||
|
scheme: "http",
|
||||||
|
}
|
||||||
|
domain := "ex1.telebit.io"
|
||||||
|
|
||||||
|
payload := []byte("Hello, World!")
|
||||||
|
header := []byte("IPv4,192.168.1.101,6743," + strconv.Itoa(len(payload)) + ",http,80,ex1.telebit.io,\n")
|
||||||
|
//header = append([]byte{V1, byte(len(header))}, header...)
|
||||||
|
header = append([]byte{254, byte(len(header))}, header...)
|
||||||
|
|
||||||
|
h, b, err := Encode(src, dst, domain, payload)
|
||||||
|
if nil != err {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if string(header) != string(h) {
|
||||||
|
t.Fatalf("header %q should have matched %q", h, header)
|
||||||
|
}
|
||||||
|
if string(b) != string(payload) {
|
||||||
|
t.Fatal("payload should be the exact reference to the original slice")
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,7 +4,6 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"strconv"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
@ -41,14 +40,24 @@ func TestParseWholeBlock(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
p := NewParser(ctx, th)
|
p := NewParser(ctx, th)
|
||||||
body := []byte(`Hello, World!`)
|
payload := []byte(`Hello, World!`)
|
||||||
fmt.Println("payload len", len(body))
|
fmt.Println("payload len", len(payload))
|
||||||
header := []byte("IPv4,192.168.1.101,6743," + strconv.Itoa(len(body)) + ",http,80,ex1.telebit.io,\n")
|
src := Addr{
|
||||||
fmt.Println("header len", len(header))
|
family: "IPv4",
|
||||||
raw := []byte{255 - 1, byte(len(header))}
|
addr: "192.168.1.101",
|
||||||
raw = append(raw, header...)
|
port: 6743,
|
||||||
raw = append(raw, body...)
|
}
|
||||||
fmt.Println("total len", len(raw))
|
dst := Addr{
|
||||||
|
family: "IPv4",
|
||||||
|
port: 80,
|
||||||
|
scheme: "http",
|
||||||
|
}
|
||||||
|
domain := "ex1.telebit.io"
|
||||||
|
h, b, err := Encode(src, dst, domain, payload)
|
||||||
|
if nil != err {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
raw := append(h, b...)
|
||||||
n, err := p.Write(raw)
|
n, err := p.Write(raw)
|
||||||
if nil != err {
|
if nil != err {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
|
@ -60,8 +69,8 @@ func TestParseWholeBlock(t *testing.T) {
|
||||||
if 1 != th.chunksParsed {
|
if 1 != th.chunksParsed {
|
||||||
t.Fatal("should have parsed one chunck")
|
t.Fatal("should have parsed one chunck")
|
||||||
}
|
}
|
||||||
if len(body) != th.bytesRead {
|
if len(payload) != th.bytesRead {
|
||||||
t.Fatalf("should have parsed a body of %d bytes, but saw %d\n", len(body), th.bytesRead)
|
t.Fatalf("should have parsed a payload of %d bytes, but saw %d\n", len(payload), th.bytesRead)
|
||||||
}
|
}
|
||||||
if n != len(raw) {
|
if n != len(raw) {
|
||||||
t.Fatalf("should have parsed all %d bytes, not just %d\n", n, len(raw))
|
t.Fatalf("should have parsed all %d bytes, not just %d\n", n, len(raw))
|
||||||
|
|
Loading…
Reference in New Issue