mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2024-12-26 05:19:05 +01:00
Initial commit for frontend refactor
This commit is contained in:
parent
a54acb8c42
commit
f1e341f0b9
@ -27,7 +27,7 @@ type Job {
|
|||||||
tags: [Tag!]!
|
tags: [Tag!]!
|
||||||
resources: [Resource!]!
|
resources: [Resource!]!
|
||||||
concurrentJobs: JobLinkResultList
|
concurrentJobs: JobLinkResultList
|
||||||
footprint: [MetricValue]
|
footprint: Any
|
||||||
metaData: Any
|
metaData: Any
|
||||||
userData: User
|
userData: User
|
||||||
}
|
}
|
||||||
|
@ -59,10 +59,9 @@ type ComplexityRoot struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Cluster struct {
|
Cluster struct {
|
||||||
MetricConfig func(childComplexity int) int
|
Name func(childComplexity int) int
|
||||||
Name func(childComplexity int) int
|
Partitions func(childComplexity int) int
|
||||||
Partitions func(childComplexity int) int
|
SubClusters func(childComplexity int) int
|
||||||
SubClusters func(childComplexity int) int
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Count struct {
|
Count struct {
|
||||||
@ -259,7 +258,9 @@ type ComplexityRoot struct {
|
|||||||
CoresPerSocket func(childComplexity int) int
|
CoresPerSocket func(childComplexity int) int
|
||||||
FlopRateScalar func(childComplexity int) int
|
FlopRateScalar func(childComplexity int) int
|
||||||
FlopRateSimd func(childComplexity int) int
|
FlopRateSimd func(childComplexity int) int
|
||||||
|
Footprint func(childComplexity int) int
|
||||||
MemoryBandwidth func(childComplexity int) int
|
MemoryBandwidth func(childComplexity int) int
|
||||||
|
MetricConfig func(childComplexity int) int
|
||||||
Name func(childComplexity int) int
|
Name func(childComplexity int) int
|
||||||
Nodes func(childComplexity int) int
|
Nodes func(childComplexity int) int
|
||||||
NumberOfNodes func(childComplexity int) int
|
NumberOfNodes func(childComplexity int) int
|
||||||
@ -323,7 +324,7 @@ type JobResolver interface {
|
|||||||
Tags(ctx context.Context, obj *schema.Job) ([]*schema.Tag, error)
|
Tags(ctx context.Context, obj *schema.Job) ([]*schema.Tag, error)
|
||||||
|
|
||||||
ConcurrentJobs(ctx context.Context, obj *schema.Job) (*model.JobLinkResultList, error)
|
ConcurrentJobs(ctx context.Context, obj *schema.Job) (*model.JobLinkResultList, error)
|
||||||
Footprint(ctx context.Context, obj *schema.Job) ([]*schema.MetricValue, error)
|
Footprint(ctx context.Context, obj *schema.Job) (interface{}, error)
|
||||||
MetaData(ctx context.Context, obj *schema.Job) (interface{}, error)
|
MetaData(ctx context.Context, obj *schema.Job) (interface{}, error)
|
||||||
UserData(ctx context.Context, obj *schema.Job) (*model.User, error)
|
UserData(ctx context.Context, obj *schema.Job) (*model.User, error)
|
||||||
}
|
}
|
||||||
@ -394,13 +395,6 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in
|
|||||||
|
|
||||||
return e.complexity.Accelerator.Type(childComplexity), true
|
return e.complexity.Accelerator.Type(childComplexity), true
|
||||||
|
|
||||||
case "Cluster.metricConfig":
|
|
||||||
if e.complexity.Cluster.MetricConfig == nil {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
return e.complexity.Cluster.MetricConfig(childComplexity), true
|
|
||||||
|
|
||||||
case "Cluster.name":
|
case "Cluster.name":
|
||||||
if e.complexity.Cluster.Name == nil {
|
if e.complexity.Cluster.Name == nil {
|
||||||
break
|
break
|
||||||
@ -1360,6 +1354,13 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in
|
|||||||
|
|
||||||
return e.complexity.SubCluster.FlopRateSimd(childComplexity), true
|
return e.complexity.SubCluster.FlopRateSimd(childComplexity), true
|
||||||
|
|
||||||
|
case "SubCluster.footprint":
|
||||||
|
if e.complexity.SubCluster.Footprint == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.SubCluster.Footprint(childComplexity), true
|
||||||
|
|
||||||
case "SubCluster.memoryBandwidth":
|
case "SubCluster.memoryBandwidth":
|
||||||
if e.complexity.SubCluster.MemoryBandwidth == nil {
|
if e.complexity.SubCluster.MemoryBandwidth == nil {
|
||||||
break
|
break
|
||||||
@ -1367,6 +1368,13 @@ func (e *executableSchema) Complexity(typeName, field string, childComplexity in
|
|||||||
|
|
||||||
return e.complexity.SubCluster.MemoryBandwidth(childComplexity), true
|
return e.complexity.SubCluster.MemoryBandwidth(childComplexity), true
|
||||||
|
|
||||||
|
case "SubCluster.metricConfig":
|
||||||
|
if e.complexity.SubCluster.MetricConfig == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.complexity.SubCluster.MetricConfig(childComplexity), true
|
||||||
|
|
||||||
case "SubCluster.name":
|
case "SubCluster.name":
|
||||||
if e.complexity.SubCluster.Name == nil {
|
if e.complexity.SubCluster.Name == nil {
|
||||||
break
|
break
|
||||||
@ -1732,7 +1740,7 @@ type Job {
|
|||||||
tags: [Tag!]!
|
tags: [Tag!]!
|
||||||
resources: [Resource!]!
|
resources: [Resource!]!
|
||||||
concurrentJobs: JobLinkResultList
|
concurrentJobs: JobLinkResultList
|
||||||
footprint: [MetricValue]
|
footprint: Any
|
||||||
metaData: Any
|
metaData: Any
|
||||||
userData: User
|
userData: User
|
||||||
}
|
}
|
||||||
@ -1745,7 +1753,6 @@ type JobLink {
|
|||||||
type Cluster {
|
type Cluster {
|
||||||
name: String!
|
name: String!
|
||||||
partitions: [String!]! # Slurm partitions
|
partitions: [String!]! # Slurm partitions
|
||||||
metricConfig: [MetricConfig!]!
|
|
||||||
subClusters: [SubCluster!]! # Hardware partitions/subclusters
|
subClusters: [SubCluster!]! # Hardware partitions/subclusters
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1761,6 +1768,8 @@ type SubCluster {
|
|||||||
flopRateSimd: MetricValue!
|
flopRateSimd: MetricValue!
|
||||||
memoryBandwidth: MetricValue!
|
memoryBandwidth: MetricValue!
|
||||||
topology: Topology!
|
topology: Topology!
|
||||||
|
metricConfig: [MetricConfig!]!
|
||||||
|
footprint: [String!]!
|
||||||
}
|
}
|
||||||
|
|
||||||
type MetricValue {
|
type MetricValue {
|
||||||
@ -2737,72 +2746,6 @@ func (ec *executionContext) fieldContext_Cluster_partitions(ctx context.Context,
|
|||||||
return fc, nil
|
return fc, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ec *executionContext) _Cluster_metricConfig(ctx context.Context, field graphql.CollectedField, obj *schema.Cluster) (ret graphql.Marshaler) {
|
|
||||||
fc, err := ec.fieldContext_Cluster_metricConfig(ctx, field)
|
|
||||||
if err != nil {
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
ctx = graphql.WithFieldContext(ctx, fc)
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
ec.Error(ctx, ec.Recover(ctx, r))
|
|
||||||
ret = graphql.Null
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
|
||||||
ctx = rctx // use context from middleware stack in children
|
|
||||||
return obj.MetricConfig, nil
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
ec.Error(ctx, err)
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
if resTmp == nil {
|
|
||||||
if !graphql.HasFieldError(ctx, fc) {
|
|
||||||
ec.Errorf(ctx, "must not be null")
|
|
||||||
}
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
res := resTmp.([]*schema.MetricConfig)
|
|
||||||
fc.Result = res
|
|
||||||
return ec.marshalNMetricConfig2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfigᚄ(ctx, field.Selections, res)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ec *executionContext) fieldContext_Cluster_metricConfig(ctx context.Context, field graphql.CollectedField) (fc *graphql.FieldContext, err error) {
|
|
||||||
fc = &graphql.FieldContext{
|
|
||||||
Object: "Cluster",
|
|
||||||
Field: field,
|
|
||||||
IsMethod: false,
|
|
||||||
IsResolver: false,
|
|
||||||
Child: func(ctx context.Context, field graphql.CollectedField) (*graphql.FieldContext, error) {
|
|
||||||
switch field.Name {
|
|
||||||
case "name":
|
|
||||||
return ec.fieldContext_MetricConfig_name(ctx, field)
|
|
||||||
case "unit":
|
|
||||||
return ec.fieldContext_MetricConfig_unit(ctx, field)
|
|
||||||
case "scope":
|
|
||||||
return ec.fieldContext_MetricConfig_scope(ctx, field)
|
|
||||||
case "aggregation":
|
|
||||||
return ec.fieldContext_MetricConfig_aggregation(ctx, field)
|
|
||||||
case "timestep":
|
|
||||||
return ec.fieldContext_MetricConfig_timestep(ctx, field)
|
|
||||||
case "peak":
|
|
||||||
return ec.fieldContext_MetricConfig_peak(ctx, field)
|
|
||||||
case "normal":
|
|
||||||
return ec.fieldContext_MetricConfig_normal(ctx, field)
|
|
||||||
case "caution":
|
|
||||||
return ec.fieldContext_MetricConfig_caution(ctx, field)
|
|
||||||
case "alert":
|
|
||||||
return ec.fieldContext_MetricConfig_alert(ctx, field)
|
|
||||||
case "subClusters":
|
|
||||||
return ec.fieldContext_MetricConfig_subClusters(ctx, field)
|
|
||||||
}
|
|
||||||
return nil, fmt.Errorf("no field named %q was found under type MetricConfig", field.Name)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
return fc, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ec *executionContext) _Cluster_subClusters(ctx context.Context, field graphql.CollectedField, obj *schema.Cluster) (ret graphql.Marshaler) {
|
func (ec *executionContext) _Cluster_subClusters(ctx context.Context, field graphql.CollectedField, obj *schema.Cluster) (ret graphql.Marshaler) {
|
||||||
fc, err := ec.fieldContext_Cluster_subClusters(ctx, field)
|
fc, err := ec.fieldContext_Cluster_subClusters(ctx, field)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -2864,6 +2807,10 @@ func (ec *executionContext) fieldContext_Cluster_subClusters(ctx context.Context
|
|||||||
return ec.fieldContext_SubCluster_memoryBandwidth(ctx, field)
|
return ec.fieldContext_SubCluster_memoryBandwidth(ctx, field)
|
||||||
case "topology":
|
case "topology":
|
||||||
return ec.fieldContext_SubCluster_topology(ctx, field)
|
return ec.fieldContext_SubCluster_topology(ctx, field)
|
||||||
|
case "metricConfig":
|
||||||
|
return ec.fieldContext_SubCluster_metricConfig(ctx, field)
|
||||||
|
case "footprint":
|
||||||
|
return ec.fieldContext_SubCluster_footprint(ctx, field)
|
||||||
}
|
}
|
||||||
return nil, fmt.Errorf("no field named %q was found under type SubCluster", field.Name)
|
return nil, fmt.Errorf("no field named %q was found under type SubCluster", field.Name)
|
||||||
},
|
},
|
||||||
@ -4207,9 +4154,9 @@ func (ec *executionContext) _Job_footprint(ctx context.Context, field graphql.Co
|
|||||||
if resTmp == nil {
|
if resTmp == nil {
|
||||||
return graphql.Null
|
return graphql.Null
|
||||||
}
|
}
|
||||||
res := resTmp.([]*schema.MetricValue)
|
res := resTmp.(interface{})
|
||||||
fc.Result = res
|
fc.Result = res
|
||||||
return ec.marshalOMetricValue2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricValue(ctx, field.Selections, res)
|
return ec.marshalOAny2interface(ctx, field.Selections, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ec *executionContext) fieldContext_Job_footprint(ctx context.Context, field graphql.CollectedField) (fc *graphql.FieldContext, err error) {
|
func (ec *executionContext) fieldContext_Job_footprint(ctx context.Context, field graphql.CollectedField) (fc *graphql.FieldContext, err error) {
|
||||||
@ -4219,15 +4166,7 @@ func (ec *executionContext) fieldContext_Job_footprint(ctx context.Context, fiel
|
|||||||
IsMethod: true,
|
IsMethod: true,
|
||||||
IsResolver: true,
|
IsResolver: true,
|
||||||
Child: func(ctx context.Context, field graphql.CollectedField) (*graphql.FieldContext, error) {
|
Child: func(ctx context.Context, field graphql.CollectedField) (*graphql.FieldContext, error) {
|
||||||
switch field.Name {
|
return nil, errors.New("field of type Any does not have child fields")
|
||||||
case "name":
|
|
||||||
return ec.fieldContext_MetricValue_name(ctx, field)
|
|
||||||
case "unit":
|
|
||||||
return ec.fieldContext_MetricValue_unit(ctx, field)
|
|
||||||
case "value":
|
|
||||||
return ec.fieldContext_MetricValue_value(ctx, field)
|
|
||||||
}
|
|
||||||
return nil, fmt.Errorf("no field named %q was found under type MetricValue", field.Name)
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
return fc, nil
|
return fc, nil
|
||||||
@ -7511,8 +7450,6 @@ func (ec *executionContext) fieldContext_Query_clusters(ctx context.Context, fie
|
|||||||
return ec.fieldContext_Cluster_name(ctx, field)
|
return ec.fieldContext_Cluster_name(ctx, field)
|
||||||
case "partitions":
|
case "partitions":
|
||||||
return ec.fieldContext_Cluster_partitions(ctx, field)
|
return ec.fieldContext_Cluster_partitions(ctx, field)
|
||||||
case "metricConfig":
|
|
||||||
return ec.fieldContext_Cluster_metricConfig(ctx, field)
|
|
||||||
case "subClusters":
|
case "subClusters":
|
||||||
return ec.fieldContext_Cluster_subClusters(ctx, field)
|
return ec.fieldContext_Cluster_subClusters(ctx, field)
|
||||||
}
|
}
|
||||||
@ -9322,6 +9259,116 @@ func (ec *executionContext) fieldContext_SubCluster_topology(ctx context.Context
|
|||||||
return fc, nil
|
return fc, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _SubCluster_metricConfig(ctx context.Context, field graphql.CollectedField, obj *schema.SubCluster) (ret graphql.Marshaler) {
|
||||||
|
fc, err := ec.fieldContext_SubCluster_metricConfig(ctx, field)
|
||||||
|
if err != nil {
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.MetricConfig, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.([]schema.MetricConfig)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNMetricConfig2ᚕgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfigᚄ(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) fieldContext_SubCluster_metricConfig(ctx context.Context, field graphql.CollectedField) (fc *graphql.FieldContext, err error) {
|
||||||
|
fc = &graphql.FieldContext{
|
||||||
|
Object: "SubCluster",
|
||||||
|
Field: field,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
Child: func(ctx context.Context, field graphql.CollectedField) (*graphql.FieldContext, error) {
|
||||||
|
switch field.Name {
|
||||||
|
case "name":
|
||||||
|
return ec.fieldContext_MetricConfig_name(ctx, field)
|
||||||
|
case "unit":
|
||||||
|
return ec.fieldContext_MetricConfig_unit(ctx, field)
|
||||||
|
case "scope":
|
||||||
|
return ec.fieldContext_MetricConfig_scope(ctx, field)
|
||||||
|
case "aggregation":
|
||||||
|
return ec.fieldContext_MetricConfig_aggregation(ctx, field)
|
||||||
|
case "timestep":
|
||||||
|
return ec.fieldContext_MetricConfig_timestep(ctx, field)
|
||||||
|
case "peak":
|
||||||
|
return ec.fieldContext_MetricConfig_peak(ctx, field)
|
||||||
|
case "normal":
|
||||||
|
return ec.fieldContext_MetricConfig_normal(ctx, field)
|
||||||
|
case "caution":
|
||||||
|
return ec.fieldContext_MetricConfig_caution(ctx, field)
|
||||||
|
case "alert":
|
||||||
|
return ec.fieldContext_MetricConfig_alert(ctx, field)
|
||||||
|
case "subClusters":
|
||||||
|
return ec.fieldContext_MetricConfig_subClusters(ctx, field)
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("no field named %q was found under type MetricConfig", field.Name)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
return fc, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) _SubCluster_footprint(ctx context.Context, field graphql.CollectedField, obj *schema.SubCluster) (ret graphql.Marshaler) {
|
||||||
|
fc, err := ec.fieldContext_SubCluster_footprint(ctx, field)
|
||||||
|
if err != nil {
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
ctx = graphql.WithFieldContext(ctx, fc)
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
ec.Error(ctx, ec.Recover(ctx, r))
|
||||||
|
ret = graphql.Null
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
resTmp, err := ec.ResolverMiddleware(ctx, func(rctx context.Context) (interface{}, error) {
|
||||||
|
ctx = rctx // use context from middleware stack in children
|
||||||
|
return obj.Footprint, nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ec.Error(ctx, err)
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
if resTmp == nil {
|
||||||
|
if !graphql.HasFieldError(ctx, fc) {
|
||||||
|
ec.Errorf(ctx, "must not be null")
|
||||||
|
}
|
||||||
|
return graphql.Null
|
||||||
|
}
|
||||||
|
res := resTmp.([]string)
|
||||||
|
fc.Result = res
|
||||||
|
return ec.marshalNString2ᚕstringᚄ(ctx, field.Selections, res)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) fieldContext_SubCluster_footprint(ctx context.Context, field graphql.CollectedField) (fc *graphql.FieldContext, err error) {
|
||||||
|
fc = &graphql.FieldContext{
|
||||||
|
Object: "SubCluster",
|
||||||
|
Field: field,
|
||||||
|
IsMethod: false,
|
||||||
|
IsResolver: false,
|
||||||
|
Child: func(ctx context.Context, field graphql.CollectedField) (*graphql.FieldContext, error) {
|
||||||
|
return nil, errors.New("field of type String does not have child fields")
|
||||||
|
},
|
||||||
|
}
|
||||||
|
return fc, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (ec *executionContext) _SubClusterConfig_name(ctx context.Context, field graphql.CollectedField, obj *schema.SubClusterConfig) (ret graphql.Marshaler) {
|
func (ec *executionContext) _SubClusterConfig_name(ctx context.Context, field graphql.CollectedField, obj *schema.SubClusterConfig) (ret graphql.Marshaler) {
|
||||||
fc, err := ec.fieldContext_SubClusterConfig_name(ctx, field)
|
fc, err := ec.fieldContext_SubClusterConfig_name(ctx, field)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -12679,11 +12726,6 @@ func (ec *executionContext) _Cluster(ctx context.Context, sel ast.SelectionSet,
|
|||||||
}
|
}
|
||||||
|
|
||||||
out.Concurrently(i, func(ctx context.Context) graphql.Marshaler { return innerFunc(ctx, out) })
|
out.Concurrently(i, func(ctx context.Context) graphql.Marshaler { return innerFunc(ctx, out) })
|
||||||
case "metricConfig":
|
|
||||||
out.Values[i] = ec._Cluster_metricConfig(ctx, field, obj)
|
|
||||||
if out.Values[i] == graphql.Null {
|
|
||||||
atomic.AddUint32(&out.Invalids, 1)
|
|
||||||
}
|
|
||||||
case "subClusters":
|
case "subClusters":
|
||||||
out.Values[i] = ec._Cluster_subClusters(ctx, field, obj)
|
out.Values[i] = ec._Cluster_subClusters(ctx, field, obj)
|
||||||
if out.Values[i] == graphql.Null {
|
if out.Values[i] == graphql.Null {
|
||||||
@ -14519,6 +14561,16 @@ func (ec *executionContext) _SubCluster(ctx context.Context, sel ast.SelectionSe
|
|||||||
if out.Values[i] == graphql.Null {
|
if out.Values[i] == graphql.Null {
|
||||||
atomic.AddUint32(&out.Invalids, 1)
|
atomic.AddUint32(&out.Invalids, 1)
|
||||||
}
|
}
|
||||||
|
case "metricConfig":
|
||||||
|
out.Values[i] = ec._SubCluster_metricConfig(ctx, field, obj)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
atomic.AddUint32(&out.Invalids, 1)
|
||||||
|
}
|
||||||
|
case "footprint":
|
||||||
|
out.Values[i] = ec._SubCluster_footprint(ctx, field, obj)
|
||||||
|
if out.Values[i] == graphql.Null {
|
||||||
|
atomic.AddUint32(&out.Invalids, 1)
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
panic("unknown field " + strconv.Quote(field.Name))
|
panic("unknown field " + strconv.Quote(field.Name))
|
||||||
}
|
}
|
||||||
@ -15925,7 +15977,11 @@ func (ec *executionContext) marshalNJobsStatistics2ᚖgithubᚗcomᚋClusterCock
|
|||||||
return ec._JobsStatistics(ctx, sel, v)
|
return ec._JobsStatistics(ctx, sel, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ec *executionContext) marshalNMetricConfig2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfigᚄ(ctx context.Context, sel ast.SelectionSet, v []*schema.MetricConfig) graphql.Marshaler {
|
func (ec *executionContext) marshalNMetricConfig2githubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfig(ctx context.Context, sel ast.SelectionSet, v schema.MetricConfig) graphql.Marshaler {
|
||||||
|
return ec._MetricConfig(ctx, sel, &v)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ec *executionContext) marshalNMetricConfig2ᚕgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfigᚄ(ctx context.Context, sel ast.SelectionSet, v []schema.MetricConfig) graphql.Marshaler {
|
||||||
ret := make(graphql.Array, len(v))
|
ret := make(graphql.Array, len(v))
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
isLen1 := len(v) == 1
|
isLen1 := len(v) == 1
|
||||||
@ -15949,7 +16005,7 @@ func (ec *executionContext) marshalNMetricConfig2ᚕᚖgithubᚗcomᚋClusterCoc
|
|||||||
if !isLen1 {
|
if !isLen1 {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
}
|
}
|
||||||
ret[i] = ec.marshalNMetricConfig2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfig(ctx, sel, v[i])
|
ret[i] = ec.marshalNMetricConfig2githubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfig(ctx, sel, v[i])
|
||||||
}
|
}
|
||||||
if isLen1 {
|
if isLen1 {
|
||||||
f(i)
|
f(i)
|
||||||
@ -15969,16 +16025,6 @@ func (ec *executionContext) marshalNMetricConfig2ᚕᚖgithubᚗcomᚋClusterCoc
|
|||||||
return ret
|
return ret
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ec *executionContext) marshalNMetricConfig2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricConfig(ctx context.Context, sel ast.SelectionSet, v *schema.MetricConfig) graphql.Marshaler {
|
|
||||||
if v == nil {
|
|
||||||
if !graphql.HasFieldError(ctx, graphql.GetFieldContext(ctx)) {
|
|
||||||
ec.Errorf(ctx, "the requested element is null which the schema does not allow")
|
|
||||||
}
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
return ec._MetricConfig(ctx, sel, v)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ec *executionContext) marshalNMetricFootprints2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋinternalᚋgraphᚋmodelᚐMetricFootprintsᚄ(ctx context.Context, sel ast.SelectionSet, v []*model.MetricFootprints) graphql.Marshaler {
|
func (ec *executionContext) marshalNMetricFootprints2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋinternalᚋgraphᚋmodelᚐMetricFootprintsᚄ(ctx context.Context, sel ast.SelectionSet, v []*model.MetricFootprints) graphql.Marshaler {
|
||||||
ret := make(graphql.Array, len(v))
|
ret := make(graphql.Array, len(v))
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
@ -17241,54 +17287,6 @@ func (ec *executionContext) marshalOMetricStatistics2githubᚗcomᚋClusterCockp
|
|||||||
return ec._MetricStatistics(ctx, sel, &v)
|
return ec._MetricStatistics(ctx, sel, &v)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ec *executionContext) marshalOMetricValue2ᚕᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricValue(ctx context.Context, sel ast.SelectionSet, v []*schema.MetricValue) graphql.Marshaler {
|
|
||||||
if v == nil {
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
ret := make(graphql.Array, len(v))
|
|
||||||
var wg sync.WaitGroup
|
|
||||||
isLen1 := len(v) == 1
|
|
||||||
if !isLen1 {
|
|
||||||
wg.Add(len(v))
|
|
||||||
}
|
|
||||||
for i := range v {
|
|
||||||
i := i
|
|
||||||
fc := &graphql.FieldContext{
|
|
||||||
Index: &i,
|
|
||||||
Result: &v[i],
|
|
||||||
}
|
|
||||||
ctx := graphql.WithFieldContext(ctx, fc)
|
|
||||||
f := func(i int) {
|
|
||||||
defer func() {
|
|
||||||
if r := recover(); r != nil {
|
|
||||||
ec.Error(ctx, ec.Recover(ctx, r))
|
|
||||||
ret = nil
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
if !isLen1 {
|
|
||||||
defer wg.Done()
|
|
||||||
}
|
|
||||||
ret[i] = ec.marshalOMetricValue2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricValue(ctx, sel, v[i])
|
|
||||||
}
|
|
||||||
if isLen1 {
|
|
||||||
f(i)
|
|
||||||
} else {
|
|
||||||
go f(i)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
wg.Wait()
|
|
||||||
|
|
||||||
return ret
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ec *executionContext) marshalOMetricValue2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋpkgᚋschemaᚐMetricValue(ctx context.Context, sel ast.SelectionSet, v *schema.MetricValue) graphql.Marshaler {
|
|
||||||
if v == nil {
|
|
||||||
return graphql.Null
|
|
||||||
}
|
|
||||||
return ec._MetricValue(ctx, sel, v)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (ec *executionContext) unmarshalOOrderByInput2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋinternalᚋgraphᚋmodelᚐOrderByInput(ctx context.Context, v interface{}) (*model.OrderByInput, error) {
|
func (ec *executionContext) unmarshalOOrderByInput2ᚖgithubᚗcomᚋClusterCockpitᚋccᚑbackendᚋinternalᚋgraphᚋmodelᚐOrderByInput(ctx context.Context, v interface{}) (*model.OrderByInput, error) {
|
||||||
if v == nil {
|
if v == nil {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
@ -45,8 +45,8 @@ func (r *jobResolver) ConcurrentJobs(ctx context.Context, obj *schema.Job) (*mod
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Footprint is the resolver for the footprint field.
|
// Footprint is the resolver for the footprint field.
|
||||||
func (r *jobResolver) Footprint(ctx context.Context, obj *schema.Job) ([]*schema.MetricValue, error) {
|
func (r *jobResolver) Footprint(ctx context.Context, obj *schema.Job) (interface{}, error) {
|
||||||
panic(fmt.Errorf("not implemented: Footprint - footprint"))
|
return r.Repo.FetchFootprint(obj)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MetaData is the resolver for the metaData field.
|
// MetaData is the resolver for the metaData field.
|
||||||
|
@ -222,6 +222,34 @@ func (r *JobRepository) UpdateMetadata(job *schema.Job, key, val string) (err er
|
|||||||
return archive.UpdateMetadata(job, job.MetaData)
|
return archive.UpdateMetadata(job, job.MetaData)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *JobRepository) FetchFootprint(job *schema.Job) (map[string]float64, error) {
|
||||||
|
start := time.Now()
|
||||||
|
cachekey := fmt.Sprintf("footprint:%d", job.ID)
|
||||||
|
if cached := r.cache.Get(cachekey, nil); cached != nil {
|
||||||
|
job.Footprint = cached.(map[string]float64)
|
||||||
|
return job.Footprint, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := sq.Select("job.footprint").From("job").Where("job.id = ?", job.ID).
|
||||||
|
RunWith(r.stmtCache).QueryRow().Scan(&job.RawFootprint); err != nil {
|
||||||
|
log.Warn("Error while scanning for job footprint")
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(job.RawFootprint) == 0 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := json.Unmarshal(job.RawFootprint, &job.Footprint); err != nil {
|
||||||
|
log.Warn("Error while unmarshaling raw footprint json")
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
r.cache.Put(cachekey, job.Footprint, len(job.Footprint), 24*time.Hour)
|
||||||
|
log.Debugf("Timer FetchFootprint %s", time.Since(start))
|
||||||
|
return job.Footprint, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (r *JobRepository) DeleteJobsBefore(startTime int64) (int, error) {
|
func (r *JobRepository) DeleteJobsBefore(startTime int64) (int, error) {
|
||||||
var cnt int
|
var cnt int
|
||||||
q := sq.Select("count(*)").From("job").Where("job.start_time < ?", startTime)
|
q := sq.Select("count(*)").From("job").Where("job.start_time < ?", startTime)
|
||||||
|
@ -75,9 +75,7 @@
|
|||||||
name
|
name
|
||||||
}
|
}
|
||||||
metaData
|
metaData
|
||||||
flopsAnyAvg
|
footprint
|
||||||
memBwAvg
|
|
||||||
loadAvg
|
|
||||||
}
|
}
|
||||||
count
|
count
|
||||||
hasNextPage
|
hasNextPage
|
||||||
|
@ -42,28 +42,37 @@ export function init(extraInitQuery = "") {
|
|||||||
.query(
|
.query(
|
||||||
`query {
|
`query {
|
||||||
clusters {
|
clusters {
|
||||||
name,
|
name
|
||||||
metricConfig {
|
|
||||||
name, unit { base, prefix }, peak,
|
|
||||||
normal, caution, alert,
|
|
||||||
timestep, scope,
|
|
||||||
aggregation,
|
|
||||||
subClusters { name, peak, normal, caution, alert, remove }
|
|
||||||
}
|
|
||||||
partitions
|
partitions
|
||||||
subClusters {
|
subClusters {
|
||||||
name, processorType
|
name
|
||||||
|
nodes
|
||||||
|
numberOfNodes
|
||||||
|
processorType
|
||||||
socketsPerNode
|
socketsPerNode
|
||||||
coresPerSocket
|
coresPerSocket
|
||||||
threadsPerCore
|
threadsPerCore
|
||||||
flopRateScalar { unit { base, prefix }, value }
|
flopRateScalar { unit { base, prefix }, value }
|
||||||
flopRateSimd { unit { base, prefix }, value }
|
flopRateSimd { unit { base, prefix }, value }
|
||||||
memoryBandwidth { unit { base, prefix }, value }
|
memoryBandwidth { unit { base, prefix }, value }
|
||||||
numberOfNodes
|
|
||||||
topology {
|
topology {
|
||||||
node, socket, core
|
node
|
||||||
|
socket
|
||||||
|
core
|
||||||
accelerators { id }
|
accelerators { id }
|
||||||
}
|
}
|
||||||
|
metricConfig {
|
||||||
|
name
|
||||||
|
unit { base, prefix }
|
||||||
|
scope
|
||||||
|
aggregation
|
||||||
|
timestep
|
||||||
|
peak
|
||||||
|
normal
|
||||||
|
caution
|
||||||
|
alert
|
||||||
|
}
|
||||||
|
footprint
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
tags { id, name, type }
|
tags { id, name, type }
|
||||||
@ -84,13 +93,18 @@ export function init(extraInitQuery = "") {
|
|||||||
|
|
||||||
const tags = [],
|
const tags = [],
|
||||||
clusters = [];
|
clusters = [];
|
||||||
|
const allMetrics = [];
|
||||||
setContext("tags", tags);
|
setContext("tags", tags);
|
||||||
setContext("clusters", clusters);
|
setContext("clusters", clusters);
|
||||||
setContext("metrics", (cluster, metric) => {
|
setContext("allmetrics", allMetrics);
|
||||||
|
setContext("getMetricConfig", (cluster, subCluster, metric) => {
|
||||||
if (typeof cluster !== "object")
|
if (typeof cluster !== "object")
|
||||||
cluster = clusters.find((c) => c.name == cluster);
|
cluster = clusters.find((c) => c.name == cluster);
|
||||||
|
|
||||||
return cluster.metricConfig.find((m) => m.name == metric);
|
if (typeof subCluster !== "object")
|
||||||
|
subCluster = cluster.subClusters.find((sc) => sc.name == subCluster);
|
||||||
|
|
||||||
|
return subCluster.metricConfig.find((m) => m.name == metric);
|
||||||
});
|
});
|
||||||
setContext("on-init", (callback) =>
|
setContext("on-init", (callback) =>
|
||||||
state.fetching ? subscribers.push(callback) : callback(state)
|
state.fetching ? subscribers.push(callback) : callback(state)
|
||||||
@ -111,7 +125,31 @@ export function init(extraInitQuery = "") {
|
|||||||
|
|
||||||
for (let tag of data.tags) tags.push(tag);
|
for (let tag of data.tags) tags.push(tag);
|
||||||
|
|
||||||
for (let cluster of data.clusters) clusters.push(cluster);
|
let globalmetrics = [];
|
||||||
|
for (let cluster of data.clusters) {
|
||||||
|
// Add full info to context object
|
||||||
|
clusters.push(cluster);
|
||||||
|
// Build global metric list with availability for joblist metricselect
|
||||||
|
for (let subcluster of cluster.subClusters) {
|
||||||
|
for (let scm of subcluster.metricConfig) {
|
||||||
|
let match = globalmetrics.find((gm) => gm.name == scm.name);
|
||||||
|
if (match) {
|
||||||
|
let submatch = match.availability.find((av) => av.cluster == cluster.name);
|
||||||
|
if (submatch) {
|
||||||
|
submatch.subclusters.push(subcluster.name)
|
||||||
|
} else {
|
||||||
|
match.availability.push({cluster: cluster.name, subclusters: [subcluster.name]})
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
globalmetrics.push({name: scm.name, availability: [{cluster: cluster.name, subclusters: [subcluster.name]}]});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Add to ctx object
|
||||||
|
for (let gm of globalmetrics) allMetrics.push(gm);
|
||||||
|
|
||||||
|
console.log('All Metrics List', allMetrics);
|
||||||
|
|
||||||
state.data = data;
|
state.data = data;
|
||||||
tick().then(() => subscribers.forEach((cb) => cb(state)));
|
tick().then(() => subscribers.forEach((cb) => cb(state)));
|
||||||
@ -298,6 +336,7 @@ export function stickyHeader(datatableHeaderSelector, updatePading) {
|
|||||||
onDestroy(() => document.removeEventListener("scroll", onscroll));
|
onDestroy(() => document.removeEventListener("scroll", onscroll));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Outdated: Frontend Will Now Receive final MetricList from backend
|
||||||
export function checkMetricDisabled(m, c, s) { //[m]etric, [c]luster, [s]ubcluster
|
export function checkMetricDisabled(m, c, s) { //[m]etric, [c]luster, [s]ubcluster
|
||||||
const mc = getContext("metrics");
|
const mc = getContext("metrics");
|
||||||
const thisConfig = mc(c, m);
|
const thisConfig = mc(c, m);
|
||||||
@ -407,6 +446,7 @@ export function transformDataForRoofline(flopsAny, memBw) { // Uses Metric Objec
|
|||||||
|
|
||||||
// Return something to be plotted. The argument shall be the result of the
|
// Return something to be plotted. The argument shall be the result of the
|
||||||
// `nodeMetrics` GraphQL query.
|
// `nodeMetrics` GraphQL query.
|
||||||
|
// Remove "hardcoded" here or deemed necessary?
|
||||||
export function transformPerNodeDataForRoofline(nodes) {
|
export function transformPerNodeDataForRoofline(nodes) {
|
||||||
let data = null
|
let data = null
|
||||||
const x = [], y = []
|
const x = [], y = []
|
||||||
|
Loading…
Reference in New Issue
Block a user