mirror of
https://github.com/prometheus/prometheus
synced 2025-01-12 18:01:36 +00:00
Merge pull request #1159 from prometheus/scalar-bool
promql: Remove scalar/scalar comparisons.
This commit is contained in:
commit
51e8badc7f
@ -60,6 +60,17 @@ func (i itemType) isAggregator() bool { return i > aggregatorsStart && i < aggre
|
||||
// Returns false otherwise.
|
||||
func (i itemType) isKeyword() bool { return i > keywordsStart && i < keywordsEnd }
|
||||
|
||||
// isCompairsonOperator returns true if the item corresponds to a comparison operator.
|
||||
// Returns false otherwise.
|
||||
func (i itemType) isComparisonOperator() bool {
|
||||
switch i {
|
||||
case itemEQL, itemNEQ, itemLTE, itemLSS, itemGTE, itemGTR:
|
||||
return true
|
||||
default:
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
// Constants for operator precedence in expressions.
|
||||
//
|
||||
const LowestPrec = 0 // Non-operators.
|
||||
|
@ -488,10 +488,7 @@ func (p *parser) expr() Expr {
|
||||
returnBool := false
|
||||
// Parse bool modifier.
|
||||
if p.peek().typ == itemBool {
|
||||
switch op {
|
||||
case itemEQL, itemNEQ, itemLTE, itemLSS, itemGTE, itemGTR:
|
||||
break
|
||||
default:
|
||||
if !op.isComparisonOperator() {
|
||||
p.errorf("bool modifier can only be used on comparison operators")
|
||||
}
|
||||
p.next()
|
||||
@ -540,6 +537,9 @@ func (p *parser) expr() Expr {
|
||||
},
|
||||
VectorMatching: lhs.VectorMatching,
|
||||
}
|
||||
if op.isComparisonOperator() && !returnBool && rhs.Type() == model.ValScalar && lhs.RHS.Type() == model.ValScalar {
|
||||
p.errorf("comparisons between scalars must use BOOL modifier")
|
||||
}
|
||||
} else {
|
||||
expr = &BinaryExpr{
|
||||
Op: op,
|
||||
@ -548,8 +548,12 @@ func (p *parser) expr() Expr {
|
||||
VectorMatching: vecMatching,
|
||||
ReturnBool: returnBool,
|
||||
}
|
||||
if op.isComparisonOperator() && !returnBool && rhs.Type() == model.ValScalar && expr.Type() == model.ValScalar {
|
||||
p.errorf("comparisons between scalars must use BOOL modifier")
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
// unaryExpr parses a unary expression.
|
||||
|
@ -85,23 +85,20 @@ var testExpr = []struct {
|
||||
input: "1 / 1",
|
||||
expected: &BinaryExpr{itemDIV, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
}, {
|
||||
input: "1 == 1",
|
||||
expected: &BinaryExpr{itemEQL, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
input: "1 == bool 1",
|
||||
expected: &BinaryExpr{itemEQL, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
}, {
|
||||
input: "1 != 1",
|
||||
expected: &BinaryExpr{itemNEQ, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
input: "1 != bool 1",
|
||||
expected: &BinaryExpr{itemNEQ, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
}, {
|
||||
input: "1 > 1",
|
||||
expected: &BinaryExpr{itemGTR, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
input: "1 > bool 1",
|
||||
expected: &BinaryExpr{itemGTR, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
}, {
|
||||
input: "1 >= 1",
|
||||
expected: &BinaryExpr{itemGTE, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
input: "1 >= bool 1",
|
||||
expected: &BinaryExpr{itemGTE, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
}, {
|
||||
input: "1 < 1",
|
||||
expected: &BinaryExpr{itemLSS, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
}, {
|
||||
input: "1 <= 1",
|
||||
expected: &BinaryExpr{itemLTE, &NumberLiteral{1}, &NumberLiteral{1}, nil, false},
|
||||
input: "1 < bool 1",
|
||||
expected: &BinaryExpr{itemLSS, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
}, {
|
||||
input: "1 <= bool 1",
|
||||
expected: &BinaryExpr{itemLTE, &NumberLiteral{1}, &NumberLiteral{1}, nil, true},
|
||||
@ -203,6 +200,10 @@ var testExpr = []struct {
|
||||
input: "1 and 1",
|
||||
fail: true,
|
||||
errMsg: "AND and OR not allowed in binary scalar expression",
|
||||
}, {
|
||||
input: "1 == 1",
|
||||
fail: true,
|
||||
errMsg: "parse error at char 7: comparisons between scalars must use BOOL modifier",
|
||||
}, {
|
||||
input: "1 or 1",
|
||||
fail: true,
|
||||
|
6
promql/testdata/comparison.test
vendored
6
promql/testdata/comparison.test
vendored
@ -40,12 +40,6 @@ eval instant at 50m SUM(http_requests) BY (job) != bool SUM(http_requests) BY (j
|
||||
{job="app-server"} 0
|
||||
|
||||
|
||||
eval instant at 50m 0 == 1
|
||||
0
|
||||
|
||||
eval instant at 50m 1 == 1
|
||||
1
|
||||
|
||||
eval instant at 50m 0 == bool 1
|
||||
0
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user