use crate::ScenarioStep;
use serde::{Deserialize, Serialize};
#[derive(Debug, Serialize, Deserialize)]
pub struct Scenario {
title: String,
name: Option<String>,
steps: Vec<ScenarioStep>,
}
impl Scenario {
pub fn new(title: &str) -> Scenario {
Scenario {
title: title.to_string(),
name: None,
steps: vec![],
}
}
pub fn title(&self) -> &str {
&self.title
}
pub fn set_name(&mut self, name: &str) {
self.name = Some(name.to_string());
}
pub fn name(&self) -> Option<&str> {
self.name.as_deref()
}
pub fn has_steps(&self) -> bool {
!self.steps.is_empty()
}
pub fn steps(&self) -> &[ScenarioStep] {
&self.steps
}
pub fn add(&mut self, step: &ScenarioStep) {
self.steps.push(step.clone());
}
}
#[cfg(test)]
mod test {
use super::Scenario;
use crate::ScenarioStep;
use crate::StepKind;
#[test]
fn has_title() {
let scen = Scenario::new("title");
assert_eq!(scen.title(), "title");
}
#[test]
fn has_no_name_initially() {
let scen = Scenario::new("title");
assert_eq!(scen.name(), None);
}
#[test]
fn sets_name() {
let mut scen = Scenario::new("title");
scen.set_name("Alfred");
assert_eq!(scen.name(), Some("Alfred"));
}
#[test]
fn has_no_steps_initially() {
let scen = Scenario::new("title");
assert_eq!(scen.steps().len(), 0);
}
#[test]
fn adds_step() {
let mut scen = Scenario::new("title");
let step = ScenarioStep::new(StepKind::Given, "and", "foo");
scen.add(&step);
assert_eq!(scen.steps(), &[step]);
}
}