From 26baa6604f4b156703592cf4f15535b1cf0d8118 Mon Sep 17 00:00:00 2001 From: mimir-d Date: Sat, 5 Oct 2024 23:09:43 +0100 Subject: [PATCH] remove TestState - this didnt seem to be more than the emitter, so just keep that for the time being; - this is an impl detail, so we can revisit this later if needed Signed-off-by: mimir-d --- src/output/measure.rs | 12 +++++------ src/output/mod.rs | 1 - src/output/run.rs | 49 +++++++++++++++++++------------------------ src/output/state.rs | 18 ---------------- src/output/step.rs | 25 ++++++++++------------ 5 files changed, 38 insertions(+), 67 deletions(-) delete mode 100644 src/output/state.rs diff --git a/src/output/measure.rs b/src/output/measure.rs index 152af80..25a7220 100644 --- a/src/output/measure.rs +++ b/src/output/measure.rs @@ -20,17 +20,15 @@ use tv::{dut, emitter, step}; /// A Measurement Series is a time-series list of measurements. /// /// ref: https://github.com/opencomputeproject/ocp-diag-core/tree/main/json_spec#measurementseriesstart -pub struct MeasurementSeries<'a> { - // note: intentional design to only allow 1 thread to output; may need - // revisiting in the future, if there's a case for multithreaded writers - emitter: &'a step::StepEmitter, +pub struct MeasurementSeries { + emitter: Arc, seq_no: Arc>, start: MeasurementSeriesStart, } -impl<'a> MeasurementSeries<'a> { - pub(crate) fn new(series_id: &str, name: &str, emitter: &'a step::StepEmitter) -> Self { +impl MeasurementSeries { + pub(crate) fn new(series_id: &str, name: &str, emitter: Arc) -> Self { Self { emitter, seq_no: Arc::new(Mutex::new(atomic::AtomicU64::new(0))), @@ -40,7 +38,7 @@ impl<'a> MeasurementSeries<'a> { pub(crate) fn new_with_details( start: MeasurementSeriesStart, - emitter: &'a step::StepEmitter, + emitter: Arc, ) -> Self { Self { emitter, diff --git a/src/output/mod.rs b/src/output/mod.rs index e7b1e5c..a666060 100644 --- a/src/output/mod.rs +++ b/src/output/mod.rs @@ -12,7 +12,6 @@ mod log; mod macros; mod measure; mod run; -mod state; mod step; pub use crate::spec::LogSeverity; diff --git a/src/output/run.rs b/src/output/run.rs index 77e7b77..f72bb22 100644 --- a/src/output/run.rs +++ b/src/output/run.rs @@ -11,12 +11,13 @@ use std::sync::Arc; use serde_json::Map; use serde_json::Value; -use tokio::sync::Mutex; use crate::output as tv; use crate::spec; use tv::step::TestStep; -use tv::{config, dut, emitter, error, log, state}; +use tv::{config, dut, emitter, error, log}; + +use super::JsonEmitter; /// The outcome of a TestRun. /// It's returned when the scope method of the [`TestRun`] object is used. @@ -37,7 +38,8 @@ pub struct TestRun { dut: dut::DutInfo, command_line: String, metadata: Option>, - state: Arc>, + + emitter: Arc, } impl TestRun { @@ -88,10 +90,7 @@ impl TestRun { /// ``` pub async fn start(self) -> Result { // TODO: this likely will go into the emitter since it's not the run's job to emit the schema version - self.state - .lock() - .await - .emitter + self.emitter .emit(&spec::RootImpl::SchemaVersion( spec::SchemaVersion::default(), )) @@ -108,7 +107,7 @@ impl TestRun { }), }); - self.state.lock().await.emitter.emit(&start).await?; + self.emitter.emit(&start).await?; Ok(StartedTestRun::new(self)) } @@ -260,7 +259,7 @@ impl TestRunBuilder { pub fn build(self) -> TestRun { let config = self.config.unwrap_or(config::Config::builder().build()); let emitter = emitter::JsonEmitter::new(config.timezone, config.writer); - let state = state::TestState::new(emitter); + TestRun { name: self.name, dut: self.dut, @@ -268,7 +267,8 @@ impl TestRunBuilder { parameters: self.parameters, command_line: self.command_line, metadata: self.metadata, - state: Arc::new(Mutex::new(state)), + + emitter: Arc::new(emitter), } } } @@ -314,9 +314,7 @@ impl StartedTestRun { artifact: spec::TestRunArtifactImpl::TestRunEnd(spec::TestRunEnd { status, result }), }); - let emitter = &self.run.state.lock().await.emitter; - - emitter.emit(&end).await?; + self.run.emitter.emit(&end).await?; Ok(()) } @@ -349,12 +347,11 @@ impl StartedTestRun { ) -> Result<(), emitter::WriterError> { let log = log::Log::builder(msg).severity(severity).build(); - let emitter = &self.run.state.lock().await.emitter; - let artifact = spec::TestRunArtifact { artifact: spec::TestRunArtifactImpl::Log(log.to_artifact()), }; - emitter + self.run + .emitter .emit(&spec::RootImpl::TestRunArtifact(artifact)) .await?; @@ -385,12 +382,11 @@ impl StartedTestRun { /// # }); /// ``` pub async fn log_with_details(&self, log: &log::Log) -> Result<(), emitter::WriterError> { - let emitter = &self.run.state.lock().await.emitter; - let artifact = spec::TestRunArtifact { artifact: spec::TestRunArtifactImpl::Log(log.to_artifact()), }; - emitter + self.run + .emitter .emit(&spec::RootImpl::TestRunArtifact(artifact)) .await?; @@ -417,12 +413,12 @@ impl StartedTestRun { /// ``` pub async fn error(&self, symptom: &str) -> Result<(), emitter::WriterError> { let error = error::Error::builder(symptom).build(); - let emitter = &self.run.state.lock().await.emitter; let artifact = spec::TestRunArtifact { artifact: spec::TestRunArtifactImpl::Error(error.to_artifact()), }; - emitter + self.run + .emitter .emit(&spec::RootImpl::TestRunArtifact(artifact)) .await?; @@ -454,12 +450,12 @@ impl StartedTestRun { msg: &str, ) -> Result<(), emitter::WriterError> { let error = error::Error::builder(symptom).message(msg).build(); - let emitter = &self.run.state.lock().await.emitter; let artifact = spec::TestRunArtifact { artifact: spec::TestRunArtifactImpl::Error(error.to_artifact()), }; - emitter + self.run + .emitter .emit(&spec::RootImpl::TestRunArtifact(artifact)) .await?; @@ -494,12 +490,11 @@ impl StartedTestRun { &self, error: &error::Error, ) -> Result<(), emitter::WriterError> { - let emitter = &self.run.state.lock().await.emitter; - let artifact = spec::TestRunArtifact { artifact: spec::TestRunArtifactImpl::Error(error.to_artifact()), }; - emitter + self.run + .emitter .emit(&spec::RootImpl::TestRunArtifact(artifact)) .await?; @@ -508,6 +503,6 @@ impl StartedTestRun { pub fn step(&self, name: &str) -> TestStep { let step_id = format!("step_{}", self.step_seqno.fetch_add(1, Ordering::AcqRel)); - TestStep::new(&step_id, name, self.run.state.clone()) + TestStep::new(&step_id, name, Arc::clone(&self.run.emitter)) } } diff --git a/src/output/state.rs b/src/output/state.rs deleted file mode 100644 index df1fe96..0000000 --- a/src/output/state.rs +++ /dev/null @@ -1,18 +0,0 @@ -// (c) Meta Platforms, Inc. and affiliates. -// -// Use of this source code is governed by an MIT-style -// license that can be found in the LICENSE file or at -// https://opensource.org/licenses/MIT. - -use crate::output::emitter; - -// TODO: will prob need some redesign -pub struct TestState { - pub emitter: emitter::JsonEmitter, -} - -impl TestState { - pub fn new(emitter: emitter::JsonEmitter) -> TestState { - TestState { emitter } - } -} diff --git a/src/output/step.rs b/src/output/step.rs index e754dd6..39662f4 100644 --- a/src/output/step.rs +++ b/src/output/step.rs @@ -7,14 +7,14 @@ use serde_json::Value; use std::sync::atomic; use std::sync::Arc; -use tokio::sync::Mutex; use crate::output as tv; use crate::spec::TestStepStart; use crate::spec::{self, TestStepArtifactImpl}; use tv::measure::MeasurementSeries; -use tv::{emitter, error, log, measure, state}; +use tv::{emitter, error, log, measure}; +use super::JsonEmitter; use super::WriterError; /// A single test step in the scope of a [`TestRun`]. @@ -23,17 +23,17 @@ use super::WriterError; pub struct TestStep { name: String, - emitter: StepEmitter, + emitter: Arc, } impl TestStep { - pub(crate) fn new(id: &str, name: &str, state: Arc>) -> TestStep { + pub(crate) fn new(id: &str, name: &str, run_emitter: Arc) -> Self { TestStep { name: name.to_owned(), - emitter: StepEmitter { - state, + emitter: Arc::new(StepEmitter { step_id: id.to_owned(), - }, + run_emitter, + }), } } @@ -471,7 +471,7 @@ impl StartedTestStep { self.measurement_id_no.load(atomic::Ordering::SeqCst) ); - MeasurementSeries::new(&series_id, name, &self.step.emitter) + MeasurementSeries::new(&series_id, name, Arc::clone(&self.step.emitter)) } /// Starts a Measurement Series (a time-series list of measurements). @@ -497,16 +497,13 @@ impl StartedTestStep { &self, start: measure::MeasurementSeriesStart, ) -> MeasurementSeries { - MeasurementSeries::new_with_details(start, &self.step.emitter) + MeasurementSeries::new_with_details(start, Arc::clone(&self.step.emitter)) } } -// TODO: move this away from here; extract trait Emitter, dont rely on json -// it will be used in measurement series pub struct StepEmitter { - // emitter: JsonEmitter, - state: Arc>, step_id: String, + run_emitter: Arc, } impl StepEmitter { @@ -516,7 +513,7 @@ impl StepEmitter { // TODO: can these copies be avoided? artifact: object.clone(), }); - self.state.lock().await.emitter.emit(&root).await?; + self.run_emitter.emit(&root).await?; Ok(()) }