From b1bb76193b9e8c97a10a4cb1d37d94a7b17e8482 Mon Sep 17 00:00:00 2001 From: Matt Farina Date: Tue, 4 Apr 2023 16:14:15 -0400 Subject: [PATCH] Fix issue with - ranges being transformed to something imparsible There were AND cases that included a range which resulted in a constraing that could not be parsed. It had to do with the way the constraint was transformed. Closes #197 Signed-off-by: Matt Farina --- constraints.go | 2 +- constraints_test.go | 16 ++++++++++++---- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/constraints.go b/constraints.go index 203072e..8461c7e 100644 --- a/constraints.go +++ b/constraints.go @@ -586,7 +586,7 @@ func rewriteRange(i string) string { } o := i for _, v := range m { - t := fmt.Sprintf(">= %s, <= %s", v[1], v[11]) + t := fmt.Sprintf(">= %s, <= %s ", v[1], v[11]) o = strings.Replace(o, v[0], t, 1) } diff --git a/constraints_test.go b/constraints_test.go index 5efa92d..c725a95 100644 --- a/constraints_test.go +++ b/constraints_test.go @@ -243,6 +243,8 @@ func TestNewConstraint(t *testing.T) { {"12.3.34.1234", 0, 0, true}, {"12.3.34 ~1.2.3", 1, 2, false}, {"12.3.34~ 1.2.3", 0, 0, true}, + + {"1.0.0 - 2.0.0, <=2.0.0", 1, 3, false}, } for _, tc := range tests { @@ -394,6 +396,10 @@ func TestConstraintsCheck(t *testing.T) { {"~1.2.3", "1.3.2", false}, {"~1.1", "1.2.3", false}, {"~1.3", "2.4.5", false}, + + // Ranges should work in conjunction with other constraints anded together. + {"1.0.0 - 2.0.0 <=2.0.0", "1.5.0", true}, + {"1.0.0 - 2.0.0, <=2.0.0", "1.5.0", true}, } for _, tc := range tests { @@ -421,16 +427,18 @@ func TestRewriteRange(t *testing.T) { c string nc string }{ - {"2 - 3", ">= 2, <= 3"}, - {"2 - 3, 2 - 3", ">= 2, <= 3,>= 2, <= 3"}, - {"2 - 3, 4.0.0 - 5.1", ">= 2, <= 3,>= 4.0.0, <= 5.1"}, + {"2 - 3", ">= 2, <= 3 "}, + {"2 - 3, 2 - 3", ">= 2, <= 3 ,>= 2, <= 3 "}, + {"2 - 3, 4.0.0 - 5.1", ">= 2, <= 3 ,>= 4.0.0, <= 5.1 "}, + {"2 - 3 4.0.0 - 5.1", ">= 2, <= 3 >= 4.0.0, <= 5.1 "}, + {"1.0.0 - 2.0.0 <=2.0.0", ">= 1.0.0, <= 2.0.0 <=2.0.0"}, } for _, tc := range tests { o := rewriteRange(tc.c) if o != tc.nc { - t.Errorf("Range %s rewritten incorrectly as '%s'", tc.c, o) + t.Errorf("Range %s rewritten incorrectly as %q instead of expected %q", tc.c, o, tc.nc) } } }