Skip to content

Commit

Permalink
Use an extension property to get the state from an internal metric.
Browse files Browse the repository at this point in the history
  • Loading branch information
riemanli committed Apr 25, 2023
1 parent 08cce30 commit 6dfc562
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 27 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -900,7 +900,7 @@ class MetricsService(
// Only syncs pending measurements which can only be in metrics that are still running.
val toBeSyncedInternalMeasurements: List<InternalMeasurement> =
subResults
.filter { internalMetric -> determineMetricState(internalMetric) == Metric.State.RUNNING }
.filter { internalMetric -> internalMetric.state == Metric.State.RUNNING }
.flatMap { internalMetric -> internalMetric.weightedMeasurementsList }
.map { weightedMeasurement -> weightedMeasurement.measurement }
.filter { internalMeasurement ->
Expand Down Expand Up @@ -979,7 +979,7 @@ class MetricsService(
throw Exception("Unable to create the metric in the reporting database.", e)
}

if (determineMetricState(internalMetric) == Metric.State.RUNNING) {
if (internalMetric.state == Metric.State.RUNNING) {
measurementSupplier.createCmmsMeasurements(listOf(internalMetric), principal)
}

Expand Down Expand Up @@ -1029,7 +1029,7 @@ class MetricsService(
}
)
.metricsList
.filter { internalMetric -> determineMetricState(internalMetric) == Metric.State.RUNNING }
.filter { internalMetric -> internalMetric.state == Metric.State.RUNNING }
} catch (e: StatusException) {
throw Exception("Unable to create the metric in the reporting database.", e)
}
Expand Down Expand Up @@ -1373,26 +1373,14 @@ private fun InternalMetric.toMetric(): Metric {
timeInterval = source.timeInterval.toTimeInterval()
metricSpec = source.metricSpec.toMetricSpec()
filters += source.details.filtersList
state = determineMetricState(source)
state = source.state
createTime = source.createTime
if (state == Metric.State.SUCCEEDED) {
result = buildMetricResult(source)
}
}
}

/** Determines the [Metric.State] based on the given [InternalMetric]. */
private fun determineMetricState(metric: InternalMetric): Metric.State {
val measurementStates = metric.weightedMeasurementsList.map { it.measurement.state }
return if (measurementStates.all { it == InternalMeasurement.State.SUCCEEDED }) {
Metric.State.SUCCEEDED
} else if (measurementStates.any { it == InternalMeasurement.State.FAILED }) {
Metric.State.FAILED
} else {
Metric.State.RUNNING
}
}

/** Builds a [MetricResult] from the given [InternalMetric]. */
private fun buildMetricResult(metric: InternalMetric): MetricResult {
return metricResult {
Expand Down Expand Up @@ -1528,3 +1516,15 @@ private operator fun Duration.times(weight: Int): Duration {
private operator fun Duration.plus(other: Duration): Duration {
return Durations.add(this, other)
}

private val InternalMetric.state: Metric.State
get() {
val measurementStates = weightedMeasurementsList.map { it.measurement.state }
return if (measurementStates.all { it == InternalMeasurement.State.SUCCEEDED }) {
Metric.State.SUCCEEDED
} else if (measurementStates.any { it == InternalMeasurement.State.FAILED }) {
Metric.State.FAILED
} else {
Metric.State.RUNNING
}
}
11 changes: 0 additions & 11 deletions src/main/proto/wfa/measurement/internal/reporting/v2/metric.proto
Original file line number Diff line number Diff line change
Expand Up @@ -110,17 +110,6 @@ message Metric {

MetricSpec metric_spec = 6;

enum State {
// Default value. This value is unused.
STATE_UNSPECIFIED = 0;
// Computation is running.
RUNNING = 1;
// Completed successfully. Terminal state.
SUCCEEDED = 2;
// Completed with failure. Terminal state.
FAILED = 3;
}

message WeightedMeasurement {
int32 weight = 1;
Measurement measurement = 2;
Expand Down

0 comments on commit 6dfc562

Please sign in to comment.