diff --git a/backend/internal/payments/payments_test.go b/backend/internal/payments/payments_test.go index e5180f2..cec9891 100644 --- a/backend/internal/payments/payments_test.go +++ b/backend/internal/payments/payments_test.go @@ -160,3 +160,172 @@ func TestCreatePreferenceWithZeroTotal(t *testing.T) { t.Errorf("expected seller receivable 0, got %d", pref.SellerReceivable) } } + +// Stripe Gateway Tests + +func TestNewStripeGateway(t *testing.T) { + gateway := NewStripeGateway("sk_test_xxx", 12.0) + + if gateway.APIKey != "sk_test_xxx" { + t.Errorf("expected APIKey 'sk_test_xxx', got '%s'", gateway.APIKey) + } + if gateway.MarketplaceCommission != 12.0 { + t.Errorf("expected commission 12.0, got %f", gateway.MarketplaceCommission) + } +} + +func TestStripeCreatePreference(t *testing.T) { + gateway := NewStripeGateway("sk_test_xxx", 12.0) + + order := &domain.Order{ + ID: uuid.Must(uuid.NewV7()), + BuyerID: uuid.Must(uuid.NewV7()), + SellerID: uuid.Must(uuid.NewV7()), + TotalCents: 10000, + } + + ctx := context.Background() + pref, err := gateway.CreatePreference(ctx, order) + if err != nil { + t.Fatalf("failed to create preference: %v", err) + } + + if pref.Gateway != "stripe" { + t.Errorf("expected gateway 'stripe', got '%s'", pref.Gateway) + } + if pref.MarketplaceFee != 1200 { // 12% + t.Errorf("expected fee 1200, got %d", pref.MarketplaceFee) + } + if pref.SellerReceivable != 8800 { + t.Errorf("expected seller receivable 8800, got %d", pref.SellerReceivable) + } +} + +func TestStripeCreatePaymentIntent(t *testing.T) { + gateway := NewStripeGateway("sk_test_xxx", 12.0) + + order := &domain.Order{ + ID: uuid.Must(uuid.NewV7()), + SellerID: uuid.Must(uuid.NewV7()), + TotalCents: 10000, + } + + ctx := context.Background() + intent, err := gateway.CreatePaymentIntent(ctx, order) + if err != nil { + t.Fatalf("failed to create payment intent: %v", err) + } + + if intent["currency"] != "brl" { + t.Errorf("expected currency 'brl', got %v", intent["currency"]) + } + if intent["amount"].(int64) != 10000 { + t.Errorf("expected amount 10000, got %v", intent["amount"]) + } + if intent["application_fee"].(int64) != 1200 { + t.Errorf("expected fee 1200, got %v", intent["application_fee"]) + } +} + +// Mock Gateway Tests + +func TestNewMockGateway(t *testing.T) { + gateway := NewMockGateway(12.0, true) + + if gateway.MarketplaceCommission != 12.0 { + t.Errorf("expected commission 12.0, got %f", gateway.MarketplaceCommission) + } + if !gateway.AutoApprove { + t.Error("expected AutoApprove true") + } +} + +func TestMockCreatePreference(t *testing.T) { + gateway := NewMockGateway(12.0, true) + + order := &domain.Order{ + ID: uuid.Must(uuid.NewV7()), + TotalCents: 5000, + } + + ctx := context.Background() + pref, err := gateway.CreatePreference(ctx, order) + if err != nil { + t.Fatalf("failed to create preference: %v", err) + } + + if pref.Gateway != "mock" { + t.Errorf("expected gateway 'mock', got '%s'", pref.Gateway) + } + if pref.MarketplaceFee != 600 { + t.Errorf("expected fee 600, got %d", pref.MarketplaceFee) + } +} + +func TestMockConfirmPayment(t *testing.T) { + gateway := NewMockGateway(12.0, true) + + ctx := context.Background() + result, err := gateway.ConfirmPayment(ctx, "mock-payment-123") + if err != nil { + t.Fatalf("failed to confirm payment: %v", err) + } + + if result.Status != "approved" { + t.Errorf("expected status 'approved', got '%s'", result.Status) + } + if result.Gateway != "mock" { + t.Errorf("expected gateway 'mock', got '%s'", result.Gateway) + } +} + +func TestMockRefundPayment(t *testing.T) { + gateway := NewMockGateway(12.0, true) + + ctx := context.Background() + result, err := gateway.RefundPayment(ctx, "mock-payment-123", 5000) + if err != nil { + t.Fatalf("failed to refund payment: %v", err) + } + + if result.Status != "refunded" { + t.Errorf("expected status 'refunded', got '%s'", result.Status) + } + if result.AmountCents != 5000 { + t.Errorf("expected amount 5000, got %d", result.AmountCents) + } +} + +func TestMockContextCancellation(t *testing.T) { + gateway := NewMockGateway(12.0, true) + + order := &domain.Order{ + ID: uuid.Must(uuid.NewV7()), + TotalCents: 5000, + } + + ctx, cancel := context.WithCancel(context.Background()) + cancel() + + _, err := gateway.CreatePreference(ctx, order) + if err == nil { + t.Error("expected error for cancelled context") + } +} + +func TestStripeContextCancellation(t *testing.T) { + gateway := NewStripeGateway("sk_test_xxx", 12.0) + + order := &domain.Order{ + ID: uuid.Must(uuid.NewV7()), + TotalCents: 5000, + } + + ctx, cancel := context.WithCancel(context.Background()) + cancel() + + _, err := gateway.CreatePreference(ctx, order) + if err == nil { + t.Error("expected error for cancelled context") + } +}