2022-01-24 10:06:25 +01:00
|
|
|
package metricdata
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-03-17 16:15:35 +01:00
|
|
|
"encoding/json"
|
2022-01-31 15:16:05 +01:00
|
|
|
"time"
|
2022-01-24 10:06:25 +01:00
|
|
|
|
2022-01-27 09:40:59 +01:00
|
|
|
"github.com/ClusterCockpit/cc-backend/schema"
|
2022-01-24 10:06:25 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var TestLoadDataCallback func(job *schema.Job, metrics []string, scopes []schema.MetricScope, ctx context.Context) (schema.JobData, error) = func(job *schema.Job, metrics []string, scopes []schema.MetricScope, ctx context.Context) (schema.JobData, error) {
|
|
|
|
panic("TODO")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Only a mock for unit-testing.
|
2022-03-17 16:15:35 +01:00
|
|
|
type TestMetricDataRepository struct{}
|
2022-01-24 10:06:25 +01:00
|
|
|
|
2022-03-17 16:15:35 +01:00
|
|
|
func (tmdr *TestMetricDataRepository) Init(_ json.RawMessage) error {
|
2022-01-24 10:06:25 +01:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (tmdr *TestMetricDataRepository) LoadData(job *schema.Job, metrics []string, scopes []schema.MetricScope, ctx context.Context) (schema.JobData, error) {
|
|
|
|
return TestLoadDataCallback(job, metrics, scopes, ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (tmdr *TestMetricDataRepository) LoadStats(job *schema.Job, metrics []string, ctx context.Context) (map[string]map[string]schema.MetricStatistics, error) {
|
|
|
|
panic("TODO")
|
|
|
|
}
|
|
|
|
|
2022-01-31 15:16:05 +01:00
|
|
|
func (tmdr *TestMetricDataRepository) LoadNodeData(cluster, partition string, metrics, nodes []string, scopes []schema.MetricScope, from, to time.Time, ctx context.Context) (map[string]map[string][]*schema.JobMetric, error) {
|
2022-01-24 10:06:25 +01:00
|
|
|
panic("TODO")
|
|
|
|
}
|