package_json_parser 0.0.17

A parser for package.json
Documentation
use derive_more::{Deref, DerefMut};
use jsonc_parser::ast::ObjectProp;
use serde::de::{SeqAccess, Visitor, value::SeqAccessDeserializer};
use serde::{Deserialize, Deserializer, Serialize};
use std::fmt;

use crate::ext::Validator;

#[derive(Debug, Serialize, Clone, Deref, DerefMut)]
pub struct Os(Vec<String>);

impl<'de> Deserialize<'de> for Os {
  fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
  where
    D: Deserializer<'de>,
  {
    struct OsVisitor;

    impl<'de> Visitor<'de> for OsVisitor {
      type Value = Os;

      fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result {
        formatter.write_str("an array of os entries")
      }

      fn visit_seq<S>(self, seq: S) -> Result<Self::Value, S::Error>
      where
        S: SeqAccess<'de>,
      {
        let value = Vec::<String>::deserialize(SeqAccessDeserializer::new(seq))?;
        Ok(Os(value))
      }
    }

    deserializer.deserialize_any(OsVisitor)
  }
}

impl Validator for Os {
  fn validate(&self, _prop: Option<&ObjectProp>) -> miette::Result<()> {
    Ok(())
  }
}

#[cfg(test)]
mod tests {
  use crate::PackageJsonParser;

  #[test]
  fn should_deserialize_os_successfully() {
    let parsed = PackageJsonParser::parse_str(r#"{"os":["darwin","linux"]}"#);
    assert!(parsed.is_ok());
  }

  #[test]
  fn should_fail_deserialize_os_when_type_is_invalid() {
    let parsed = PackageJsonParser::parse_str(r#"{"os":"darwin"}"#);
    assert!(parsed.is_ok());
    let parsed = parsed.unwrap();
    assert!(parsed.os().is_err());
  }

  #[test]
  fn should_fail_deserialize_os_when_json_is_invalid() {
    let parsed = PackageJsonParser::parse_str("{");
    assert!(parsed.is_err());
  }
}