119 lines
3.2 KiB
Go
119 lines
3.2 KiB
Go
/*
|
|
* Copyright (C) 2026 Fluxer Contributors
|
|
*
|
|
* This file is part of Fluxer.
|
|
*
|
|
* Fluxer is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Fluxer 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 Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with Fluxer. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package integration
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
"mime/multipart"
|
|
"net/http"
|
|
"testing"
|
|
)
|
|
|
|
// TestAttachmentUpload_OmittedFields tests that when title/description are omitted
|
|
// (not sent at all), they default to null
|
|
func TestAttachmentUpload_OmittedFields(t *testing.T) {
|
|
client := newTestClient(t)
|
|
user := createTestAccount(t, client)
|
|
ensureSessionStarted(t, client, user.Token)
|
|
|
|
guild := createGuild(t, client, user.Token, "Omitted Fields Test Guild")
|
|
channelID := parseSnowflake(t, guild.SystemChannel)
|
|
|
|
fileData, err := fixturesFS.ReadFile("fixtures/yeah.png")
|
|
if err != nil {
|
|
t.Fatalf("failed to read fixture: %v", err)
|
|
}
|
|
|
|
var body bytes.Buffer
|
|
writer := multipart.NewWriter(&body)
|
|
|
|
payload := map[string]any{
|
|
"content": "Omitted fields test",
|
|
"attachments": []map[string]any{
|
|
{
|
|
"id": 0,
|
|
"filename": "yeah.png",
|
|
},
|
|
},
|
|
}
|
|
payloadJSON, err := json.Marshal(payload)
|
|
if err != nil {
|
|
t.Fatalf("failed to encode payload JSON: %v", err)
|
|
}
|
|
|
|
if err := writer.WriteField("payload_json", string(payloadJSON)); err != nil {
|
|
t.Fatalf("failed to write payload_json field: %v", err)
|
|
}
|
|
|
|
fileWriter, err := writer.CreateFormFile("files[0]", "yeah.png")
|
|
if err != nil {
|
|
t.Fatalf("failed to create file field: %v", err)
|
|
}
|
|
if _, err := fileWriter.Write(fileData); err != nil {
|
|
t.Fatalf("failed to write file data: %v", err)
|
|
}
|
|
|
|
if err := writer.Close(); err != nil {
|
|
t.Fatalf("failed to close multipart writer: %v", err)
|
|
}
|
|
|
|
req, err := http.NewRequest(
|
|
http.MethodPost,
|
|
fmt.Sprintf("%s/channels/%d/messages", client.baseURL, channelID),
|
|
&body,
|
|
)
|
|
if err != nil {
|
|
t.Fatalf("failed to create request: %v", err)
|
|
}
|
|
req.Header.Set("Content-Type", writer.FormDataContentType())
|
|
client.applyCommonHeaders(req)
|
|
req.Header.Set("Authorization", user.Token)
|
|
|
|
resp, err := client.httpClient.Do(req)
|
|
if err != nil {
|
|
t.Fatalf("failed to send request: %v", err)
|
|
}
|
|
defer resp.Body.Close()
|
|
assertStatus(t, resp, http.StatusOK)
|
|
|
|
var msgResp struct {
|
|
Attachments []struct {
|
|
Filename string `json:"filename"`
|
|
Title *string `json:"title"`
|
|
Description *string `json:"description"`
|
|
} `json:"attachments"`
|
|
}
|
|
decodeJSONResponse(t, resp, &msgResp)
|
|
|
|
if len(msgResp.Attachments) != 1 {
|
|
t.Fatalf("expected 1 attachment, got %d", len(msgResp.Attachments))
|
|
}
|
|
|
|
att := msgResp.Attachments[0]
|
|
if att.Title != nil {
|
|
t.Errorf("expected omitted title to be nil, got %q", *att.Title)
|
|
}
|
|
if att.Description != nil {
|
|
t.Errorf("expected omitted description to be nil, got %q", *att.Description)
|
|
}
|
|
}
|