From 8bdd50d7562872248f9cf2030c809554b0d8e4cc Mon Sep 17 00:00:00 2001 From: Chris Sinjakli Date: Sat, 25 Dec 2021 13:30:18 +0000 Subject: [PATCH 1/2] Fix typo in spec description Looks like a regex replacement was run against this file and was a little too eager. Signed-off-by: Chris Sinjakli --- spec/prometheus/client/label_set_validator_spec.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/prometheus/client/label_set_validator_spec.rb b/spec/prometheus/client/label_set_validator_spec.rb index 4e8d9b1b..688a1397 100644 --- a/spec/prometheus/client/label_set_validator_spec.rb +++ b/spec/prometheus/client/label_set_validator_spec.rb @@ -18,7 +18,7 @@ expect(validator.validate_symbols!(version: 'alpha')).to eql(true) end - it 'raises Invaliddescribed_classError if a label set is not a hash' do + it 'raises InvalidLabelSetError if a label set is not a hash' do expect do validator.validate_symbols!('invalid') end.to raise_exception invalid From 3519342ccd9ea89027df53c38b980f946e7c8b21 Mon Sep 17 00:00:00 2001 From: Chris Sinjakli Date: Sat, 25 Dec 2021 13:31:55 +0000 Subject: [PATCH 2/2] Validate label names Up to now, we've only been performing limited validation of label names. This commit validates that the characters use match the regex `/\A[a-zA-Z_][a-zA-Z0-9_]*\Z/` as specified by: https://prometheus.io/docs/concepts/data_model/#metric-names-and-labels Signed-off-by: Chris Sinjakli --- lib/prometheus/client/label_set_validator.rb | 11 +++++++++-- spec/prometheus/client/label_set_validator_spec.rb | 6 ++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/lib/prometheus/client/label_set_validator.rb b/lib/prometheus/client/label_set_validator.rb index 8b28a42d..f3625233 100644 --- a/lib/prometheus/client/label_set_validator.rb +++ b/lib/prometheus/client/label_set_validator.rb @@ -7,6 +7,7 @@ module Client class LabelSetValidator # TODO: we might allow setting :instance in the future BASE_RESERVED_LABELS = [:job, :instance, :pid].freeze + LABEL_NAME_REGEX = /\A[a-zA-Z_][a-zA-Z0-9_]*\Z/ class LabelSetError < StandardError; end class InvalidLabelSetError < LabelSetError; end @@ -59,9 +60,15 @@ def validate_symbol(key) end def validate_name(key) - return true unless key.to_s.start_with?('__') + if key.to_s.start_with?('__') + raise ReservedLabelError, "label #{key} must not start with __" + end + + unless key.to_s =~ LABEL_NAME_REGEX + raise InvalidLabelError, "label name must match /#{LABEL_NAME_REGEX}/" + end - raise ReservedLabelError, "label #{key} must not start with __" + true end def validate_reserved_key(key) diff --git a/spec/prometheus/client/label_set_validator_spec.rb b/spec/prometheus/client/label_set_validator_spec.rb index 688a1397..f4d38987 100644 --- a/spec/prometheus/client/label_set_validator_spec.rb +++ b/spec/prometheus/client/label_set_validator_spec.rb @@ -36,6 +36,12 @@ end.to raise_exception(described_class::ReservedLabelError) end + it 'raises InvalidLabelError if a label key contains invalid characters' do + expect do + validator.validate_symbols!(:@foo => 'key') + end.to raise_exception(described_class::InvalidLabelError) + end + it 'raises ReservedLabelError if a label key is reserved' do [:job, :instance, :pid].each do |label| expect do