mirror of
https://github.com/ProtonMail/proton-bridge.git
synced 2026-02-14 12:48:33 +00:00
GODT-35: Finish all details and make tests pass
This commit is contained in:
@ -25,17 +25,17 @@ import (
|
||||
"io/ioutil"
|
||||
"mime/multipart"
|
||||
"net/http"
|
||||
"reflect"
|
||||
"testing"
|
||||
|
||||
pmmime "github.com/ProtonMail/proton-bridge/pkg/mime"
|
||||
r "github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
var testImportReqs = []*ImportMsgReq{
|
||||
{
|
||||
Metadata: &ImportMetadata{
|
||||
AddressID: "QMJs2dzTx7uqpH5PNgIzjULywU4gO9uMBhEMVFOAVJOoUml54gC0CCHtW9qYwzH-zYbZwMv3MFYncPjW1Usq7Q==",
|
||||
Unread: 0,
|
||||
Unread: Boolean(false),
|
||||
Flags: FlagReceived | FlagImported,
|
||||
LabelIDs: []string{ArchiveLabel},
|
||||
},
|
||||
@ -57,86 +57,52 @@ var testImportRes = &ImportMsgRes{
|
||||
}
|
||||
|
||||
func TestClient_Import(t *testing.T) { // nolint[funlen]
|
||||
s, c := newTestClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||
Ok(t, checkMethodAndPath(r, "POST", "/mail/v4/messages/import"))
|
||||
s, c := newTestClient(http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
||||
r.NoError(t, checkMethodAndPath(req, "POST", "/mail/v4/messages/import"))
|
||||
|
||||
contentType, params, err := pmmime.ParseMediaType(r.Header.Get("Content-Type"))
|
||||
if err != nil {
|
||||
t.Error("Expected no error while parsing request content type, got:", err)
|
||||
}
|
||||
if contentType != "multipart/form-data" {
|
||||
t.Errorf("Invalid request content type: expected %v but got %v", "multipart/form-data", contentType)
|
||||
}
|
||||
contentType, params, err := pmmime.ParseMediaType(req.Header.Get("Content-Type"))
|
||||
r.NoError(t, err)
|
||||
r.Equal(t, "multipart/form-data", contentType)
|
||||
|
||||
mr := multipart.NewReader(r.Body, params["boundary"])
|
||||
mr := multipart.NewReader(req.Body, params["boundary"])
|
||||
|
||||
// First part is message body.
|
||||
p, err := mr.NextPart()
|
||||
if err != nil {
|
||||
t.Error("Expected no error while reading second part of request body, got:", err)
|
||||
}
|
||||
r.NoError(t, err)
|
||||
|
||||
contentDisp, params, err := pmmime.ParseMediaType(p.Header.Get("Content-Disposition"))
|
||||
if err != nil {
|
||||
t.Error("Expected no error while parsing part content disposition, got:", err)
|
||||
}
|
||||
if contentDisp != "form-data" {
|
||||
t.Errorf("Invalid part content disposition: expected %v but got %v", "form-data", contentType)
|
||||
}
|
||||
if params["name"] != "0" {
|
||||
t.Errorf("Invalid part name: expected %v but got %v", "0", params["name"])
|
||||
}
|
||||
r.NoError(t, err)
|
||||
r.Equal(t, "form-data", contentDisp)
|
||||
r.Equal(t, "0", params["name"])
|
||||
|
||||
b, err := ioutil.ReadAll(p)
|
||||
if err != nil {
|
||||
t.Error("Expected no error while reading second part body, got:", err)
|
||||
}
|
||||
|
||||
if string(b) != string(testImportReqs[0].Message) {
|
||||
t.Errorf("Invalid message body: expected %v but got %v", string(testImportReqs[0].Message), string(b))
|
||||
}
|
||||
r.NoError(t, err)
|
||||
r.Equal(t, string(testImportReqs[0].Message), string(b))
|
||||
|
||||
// Second part is metadata.
|
||||
p, err = mr.NextPart()
|
||||
if err != nil {
|
||||
t.Error("Expected no error while reading first part of request body, got:", err)
|
||||
}
|
||||
r.NoError(t, err)
|
||||
|
||||
contentDisp, params, err = pmmime.ParseMediaType(p.Header.Get("Content-Disposition"))
|
||||
if err != nil {
|
||||
t.Error("Expected no error while parsing part content disposition, got:", err)
|
||||
}
|
||||
if contentDisp != "form-data" {
|
||||
t.Errorf("Invalid part content disposition: expected %v but got %v", "form-data", contentType)
|
||||
}
|
||||
if params["name"] != "Metadata" {
|
||||
t.Errorf("Invalid part name: expected %v but got %v", "Metadata", params["name"])
|
||||
}
|
||||
r.NoError(t, err)
|
||||
r.Equal(t, "form-data", contentDisp)
|
||||
r.Equal(t, "Metadata", params["name"])
|
||||
|
||||
metadata := map[string]*ImportMetadata{}
|
||||
if err := json.NewDecoder(p).Decode(&metadata); err != nil {
|
||||
t.Error("Expected no error while parsing metadata json, got:", err)
|
||||
}
|
||||
err = json.NewDecoder(p).Decode(&metadata)
|
||||
r.NoError(t, err)
|
||||
|
||||
if len(metadata) != 1 {
|
||||
t.Errorf("Expected metadata to contain exactly one item, got %v", metadata)
|
||||
}
|
||||
r.Equal(t, 1, len(metadata))
|
||||
|
||||
req := metadata["0"]
|
||||
if metadata["0"] == nil {
|
||||
t.Errorf("Expected metadata to contain one item indexed by 0, got %v", metadata)
|
||||
}
|
||||
importReq := metadata["0"]
|
||||
r.NotNil(t, req)
|
||||
|
||||
expected := *testImportReqs[0].Metadata
|
||||
if !reflect.DeepEqual(&expected, req) {
|
||||
t.Errorf("Invalid message metadata: expected %v, got %v", &expected, req)
|
||||
}
|
||||
r.Equal(t, &expected, importReq)
|
||||
|
||||
// No more parts.
|
||||
_, err = mr.NextPart()
|
||||
if err != io.EOF {
|
||||
t.Error("Expected no more parts but error was not EOF, got:", err)
|
||||
}
|
||||
r.EqualError(t, err, io.EOF.Error())
|
||||
|
||||
w.Header().Set("Content-Type", "application/json")
|
||||
|
||||
@ -144,16 +110,8 @@ func TestClient_Import(t *testing.T) { // nolint[funlen]
|
||||
}))
|
||||
defer s.Close()
|
||||
|
||||
imported, err := c.Import(context.TODO(), testImportReqs)
|
||||
if err != nil {
|
||||
t.Fatal("Expected no error while importing, got:", err)
|
||||
}
|
||||
|
||||
if len(imported) != 1 {
|
||||
t.Fatalf("Expected exactly one imported message, got %v", len(imported))
|
||||
}
|
||||
|
||||
if !reflect.DeepEqual(testImportRes, imported[0]) {
|
||||
t.Errorf("Invalid response for imported message: expected %+v but got %+v", testImportRes, imported[0])
|
||||
}
|
||||
imported, err := c.Import(context.Background(), testImportReqs)
|
||||
r.NoError(t, err)
|
||||
r.Equal(t, 1, len(imported))
|
||||
r.Equal(t, testImportRes, imported[0])
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user