[4.0] 2de6a95 varnishtest: fail inequality comparisons if either side is undef'ed
Lasse Karstensen
lkarsten at varnish-software.com
Thu Jan 15 16:35:43 CET 2015
commit 2de6a9578c325e78fe56d4dbd7970090a06a46d8
Author: Nils Goroll <nils.goroll at uplex.de>
Date: Wed Jan 7 12:34:58 2015 +0100
varnishtest: fail inequality comparisons if either side is undef'ed
e.g. <undef> >= 0.1 should fail for being an invalid comparison
Conflicts:
bin/varnishtest/tests/v00013.vtc
diff --git a/bin/varnishtest/tests/v00013.vtc b/bin/varnishtest/tests/v00013.vtc
index c428add..bf5c89e 100644
--- a/bin/varnishtest/tests/v00013.vtc
+++ b/bin/varnishtest/tests/v00013.vtc
@@ -37,5 +37,9 @@ client c1 {
rxresp
expect resp.status == 200
expect resp.http.foo == 2
- expect resp.http.bar >= 0.100
+
+ txreq -url /pass
+ rxresp
+ expect resp.status == 200
+ expect resp.http.foo == 0
} -run
diff --git a/bin/varnishtest/vtc_http.c b/bin/varnishtest/vtc_http.c
index 21fceed..8283c68 100644
--- a/bin/varnishtest/vtc_http.c
+++ b/bin/varnishtest/vtc_http.c
@@ -224,18 +224,16 @@ cmd_var_resolve(struct http *hp, char *spec)
} else
return (spec);
hdr = http_find_header(hh, hdr);
- if (hdr != NULL)
- return (hdr);
- return ("<undef>");
+ return (hdr);
}
static void
cmd_http_expect(CMD_ARGS)
{
struct http *hp;
- const char *lhs;
+ const char *lhs, *clhs;
char *cmp;
- const char *rhs;
+ const char *rhs, *crhs;
vre_t *vre;
const char *error;
int erroroffset;
@@ -252,14 +250,27 @@ cmd_http_expect(CMD_ARGS)
AN(av[2]);
AZ(av[3]);
lhs = cmd_var_resolve(hp, av[0]);
- if (lhs == NULL)
- lhs = "<missing>";
cmp = av[1];
rhs = cmd_var_resolve(hp, av[2]);
- if (rhs == NULL)
- rhs = "<missing>";
- if (!strcmp(cmp, "==")) {
- retval = strcmp(lhs, rhs) == 0;
+
+ clhs = lhs ? lhs : "<undef>";
+ crhs = rhs ? rhs : "<undef>";
+
+ if (!strcmp(cmp, "~") || !strcmp(cmp, "!~")) {
+ vre = VRE_compile(crhs, 0, &error, &erroroffset);
+ if (vre == NULL)
+ vtc_log(hp->vl, 0, "REGEXP error: %s (@%d) (%s)",
+ error, erroroffset, crhs);
+ i = VRE_exec(vre, clhs, strlen(clhs), 0, 0, NULL, 0, 0);
+ retval = (i >= 0 && *cmp == '~') || (i < 0 && *cmp == '!');
+ VRE_free(&vre);
+ } else if (!strcmp(cmp, "==")) {
+ retval = strcmp(clhs, crhs) == 0;
+ } else if (!strcmp(cmp, "!=")) {
+ retval = strcmp(clhs, crhs) != 0;
+ } else if (lhs == NULL || rhs == NULL) {
+ // fail inequality comparisons if either side is undef'ed
+ retval = 0;
} else if (!strcmp(cmp, "<")) {
retval = strcmp(lhs, rhs) < 0;
} else if (!strcmp(cmp, "<=")) {
@@ -268,24 +279,15 @@ cmd_http_expect(CMD_ARGS)
retval = strcmp(lhs, rhs) >= 0;
} else if (!strcmp(cmp, ">")) {
retval = strcmp(lhs, rhs) > 0;
- } else if (!strcmp(cmp, "!=")) {
- retval = strcmp(lhs, rhs) != 0;
- } else if (!strcmp(cmp, "~") || !strcmp(cmp, "!~")) {
- vre = VRE_compile(rhs, 0, &error, &erroroffset);
- if (vre == NULL)
- vtc_log(hp->vl, 0, "REGEXP error: %s (@%d) (%s)",
- error, erroroffset, rhs);
- i = VRE_exec(vre, lhs, strlen(lhs), 0, 0, NULL, 0, 0);
- retval = (i >= 0 && *cmp == '~') || (i < 0 && *cmp == '!');
- VRE_free(&vre);
}
+
if (retval == -1)
vtc_log(hp->vl, 0,
"EXPECT %s (%s) %s %s (%s) test not implemented",
- av[0], lhs, av[1], av[2], rhs);
+ av[0], clhs, av[1], av[2], crhs);
else
vtc_log(hp->vl, retval ? 4 : 0, "EXPECT %s (%s) %s \"%s\" %s",
- av[0], lhs, cmp, rhs, retval ? "match" : "failed");
+ av[0], clhs, cmp, crhs, retval ? "match" : "failed");
}
/**********************************************************************
More information about the varnish-commit
mailing list