* Unit tests to check tagging and aggregation of Prometheus metrics * Removing the logger output routing (because it doesn't actually work in the logger implementation) * Emitting values with the logging reporter Co-authored-by: chris <chris@Profanity.local>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package logging
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/micro/go-micro/v3/metrics"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestLoggingReporter(t *testing.T) {
 | |
| 
 | |
| 	// Make a Reporter:
 | |
| 	reporter := New(metrics.Path("/prometheus"), metrics.DefaultTags(map[string]string{"service": "prometheus-test"}))
 | |
| 	assert.NotNil(t, reporter)
 | |
| 	assert.Equal(t, "prometheus-test", reporter.options.DefaultTags["service"])
 | |
| 	assert.Equal(t, ":9000", reporter.options.Address)
 | |
| 	assert.Equal(t, "/prometheus", reporter.options.Path)
 | |
| 
 | |
| 	// Check that our implementation is valid:
 | |
| 	assert.Implements(t, new(metrics.Reporter), reporter)
 | |
| 
 | |
| 	// Test tag conversion:
 | |
| 	tags := metrics.Tags{
 | |
| 		"tag1": "false",
 | |
| 		"tag2": "true",
 | |
| 	}
 | |
| 	convertedTags := convertTags(tags)
 | |
| 	assert.Equal(t, "false", convertedTags["tag1"])
 | |
| 	assert.Equal(t, "true", convertedTags["tag2"])
 | |
| 
 | |
| 	// Test submitting metrics through the interface methods:
 | |
| 	assert.NoError(t, reporter.Count("test.counter.1", 6, tags))
 | |
| 	assert.NoError(t, reporter.Count("test.counter.2", 19, tags))
 | |
| 	assert.NoError(t, reporter.Count("test.counter.1", 5, tags))
 | |
| 	assert.NoError(t, reporter.Gauge("test.gauge.1", 99, tags))
 | |
| 	assert.NoError(t, reporter.Gauge("test.gauge.2", 55, tags))
 | |
| 	assert.NoError(t, reporter.Gauge("test.gauge.1", 98, tags))
 | |
| 	assert.NoError(t, reporter.Timing("test.timing.1", time.Second, tags))
 | |
| 	assert.NoError(t, reporter.Timing("test.timing.2", time.Minute, tags))
 | |
| }
 |