From c6838b69a272fc1d5e3aed865f1ea795f24f1618 Mon Sep 17 00:00:00 2001 From: Valentin Mezev <10400983+ValentinMezev@users.noreply.github.com> Date: Fri, 20 Dec 2024 16:39:13 +0200 Subject: [PATCH] Allow credit invoices (#1) This change allows negative amounts to be reported --- basicvalidators.go | 2 +- basicvalidators_test.go | 12 ++++++------ 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/basicvalidators.go b/basicvalidators.go index 1477697..c6f6708 100644 --- a/basicvalidators.go +++ b/basicvalidators.go @@ -13,7 +13,7 @@ import ( // Helper function to validate if the string is a valid currency format (with 2 decimal places) func IsValidCurrencyFormat(amount string) bool { // Regex pattern to match valid decimal with exactly two decimal places - validCurrency := regexp.MustCompile(`^\d+(\.\d{2})$`) + validCurrency := regexp.MustCompile(`^-?\d+(\.\d{2})$`) return validCurrency.MatchString(amount) } diff --git a/basicvalidators_test.go b/basicvalidators_test.go index c4aa34e..ef5841d 100644 --- a/basicvalidators_test.go +++ b/basicvalidators_test.go @@ -46,27 +46,27 @@ func TestCheckCurrency(t *testing.T) { // Test an invalid currency if IsValidCurrencyFormat("abc") { - t.Fatalf("Expected currency 100 to be invalid") + t.Fatalf("Expected currency abc to be invalid") } // Test an invalid currency if IsValidCurrencyFormat("abc.fg") { - t.Fatalf("Expected currency 100 to be invalid") + t.Fatalf("Expected currency abc.fg to be invalid") } // Test an invalid currency if IsValidCurrencyFormat("abc.23") { - t.Fatalf("Expected currency 100 to be invalid") + t.Fatalf("Expected currency abc.23 to be invalid") } // Test an invalid currency if IsValidCurrencyFormat("100.ab") { - t.Fatalf("Expected currency 100 to be invalid") + t.Fatalf("Expected currency 100.ab to be invalid") } // Test negative currency - if IsValidCurrencyFormat("-100.00") { - t.Fatalf("Expected currency 100 to be invalid") + if !IsValidCurrencyFormat("-100.00") { + t.Fatalf("Expected currency -100.00 to be valid") } //Test zero