aboutsummaryrefslogtreecommitdiff
path: root/weed/notification/webhook/http_test.go
diff options
context:
space:
mode:
authorIbrahim Konsowa <imkonsowa@gmail.com>2025-07-10 20:22:05 +0400
committerGitHub <noreply@github.com>2025-07-10 09:22:05 -0700
commit93bbaa1fb486f95ff40f5891057f8415bdf3fc27 (patch)
tree7365c496d06e00c594fcac35e706e29c507bce04 /weed/notification/webhook/http_test.go
parent804979d68bdc1763878b91741e22c913fba62d73 (diff)
downloadseaweedfs-93bbaa1fb486f95ff40f5891057f8415bdf3fc27.tar.xz
seaweedfs-93bbaa1fb486f95ff40f5891057f8415bdf3fc27.zip
[Notifications] Support webhook notifications (#6962)
Add webhook notification support
Diffstat (limited to 'weed/notification/webhook/http_test.go')
-rw-r--r--weed/notification/webhook/http_test.go146
1 files changed, 146 insertions, 0 deletions
diff --git a/weed/notification/webhook/http_test.go b/weed/notification/webhook/http_test.go
new file mode 100644
index 000000000..5a008d2a5
--- /dev/null
+++ b/weed/notification/webhook/http_test.go
@@ -0,0 +1,146 @@
+package webhook
+
+import (
+ "encoding/json"
+ "io"
+ "net/http"
+ "net/http/httptest"
+ "testing"
+
+ "github.com/seaweedfs/seaweedfs/weed/pb/filer_pb"
+ util_http "github.com/seaweedfs/seaweedfs/weed/util/http"
+)
+
+func init() {
+ util_http.InitGlobalHttpClient()
+}
+
+func TestHttpClientSendMessage(t *testing.T) {
+ var receivedPayload map[string]interface{}
+ var receivedHeaders http.Header
+
+ server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
+ receivedHeaders = r.Header
+ body, _ := io.ReadAll(r.Body)
+ if err := json.Unmarshal(body, &receivedPayload); err != nil {
+ w.WriteHeader(http.StatusInternalServerError)
+ return
+ }
+ w.WriteHeader(http.StatusOK)
+ }))
+ defer server.Close()
+
+ cfg := &config{
+ endpoint: server.URL,
+ authBearerToken: "test-token",
+ }
+
+ client, err := newHTTPClient(cfg)
+ if err != nil {
+ t.Fatalf("Failed to create HTTP client: %v", err)
+ }
+
+ message := &filer_pb.EventNotification{
+ OldEntry: nil,
+ NewEntry: &filer_pb.Entry{
+ Name: "test.txt",
+ IsDirectory: false,
+ },
+ }
+
+ err = client.sendMessage("/test/path", message)
+ if err != nil {
+ t.Fatalf("Failed to send message: %v", err)
+ }
+
+ if receivedPayload["key"] != "/test/path" {
+ t.Errorf("Expected key '/test/path', got %v", receivedPayload["key"])
+ }
+
+ if receivedPayload["message"] == nil {
+ t.Error("Expected message to be present")
+ }
+
+ if receivedHeaders.Get("Content-Type") != "application/json" {
+ t.Errorf("Expected Content-Type 'application/json', got %s", receivedHeaders.Get("Content-Type"))
+ }
+
+ expectedAuth := "Bearer test-token"
+ if receivedHeaders.Get("Authorization") != expectedAuth {
+ t.Errorf("Expected Authorization '%s', got %s", expectedAuth, receivedHeaders.Get("Authorization"))
+ }
+}
+
+func TestHttpClientSendMessageWithoutToken(t *testing.T) {
+ var receivedHeaders http.Header
+
+ server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
+ receivedHeaders = r.Header
+ w.WriteHeader(http.StatusOK)
+ }))
+ defer server.Close()
+
+ cfg := &config{
+ endpoint: server.URL,
+ authBearerToken: "",
+ }
+
+ client, err := newHTTPClient(cfg)
+ if err != nil {
+ t.Fatalf("Failed to create HTTP client: %v", err)
+ }
+
+ message := &filer_pb.EventNotification{}
+
+ err = client.sendMessage("/test/path", message)
+ if err != nil {
+ t.Fatalf("Failed to send message: %v", err)
+ }
+
+ if receivedHeaders.Get("Authorization") != "" {
+ t.Errorf("Expected no Authorization header, got %s", receivedHeaders.Get("Authorization"))
+ }
+}
+
+func TestHttpClientSendMessageServerError(t *testing.T) {
+ server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
+ w.WriteHeader(http.StatusInternalServerError)
+ }))
+ defer server.Close()
+
+ cfg := &config{
+ endpoint: server.URL,
+ authBearerToken: "test-token",
+ }
+
+ client, err := newHTTPClient(cfg)
+ if err != nil {
+ t.Fatalf("Failed to create HTTP client: %v", err)
+ }
+
+ message := &filer_pb.EventNotification{}
+
+ err = client.sendMessage("/test/path", message)
+ if err == nil {
+ t.Error("Expected error for server error response")
+ }
+}
+
+func TestHttpClientSendMessageNetworkError(t *testing.T) {
+ cfg := &config{
+ endpoint: "http://localhost:99999",
+ authBearerToken: "",
+ }
+
+ client, err := newHTTPClient(cfg)
+ if err != nil {
+ t.Fatalf("Failed to create HTTP client: %v", err)
+ }
+
+ message := &filer_pb.EventNotification{}
+
+ err = client.sendMessage("/test/path", message)
+ if err == nil {
+ t.Error("Expected error for network failure")
+ }
+}