Skip to content

Commit

Permalink
Merge branch 'master' into trimming
Browse files Browse the repository at this point in the history
  • Loading branch information
max-sixty committed Sep 8, 2024
2 parents 3a163fb + ce0027a commit d0e0b46
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 14 deletions.
10 changes: 6 additions & 4 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

All notable changes to insta and cargo-insta are documented here.

## 1.40.0
## 1.41.0

- We no longer trim starting newlines during assertions, which allows asserting
the number of leading newlines match those in a snapshot value. Existing
Expand All @@ -11,12 +11,14 @@ All notable changes to insta and cargo-insta are documented here.
future. (Note that we currently allowing differing trailing newlines but may
adjust this in the future). #569

- `cargo-insta` no longer panics when running `cargo test --accept --workspace`
on a workspace with a default crate. #532
## 1.40.0

- `cargo-insta` no longer panics when running `cargo insta test --accept --workspace`
on a workspace with a default crate. #532

- MSRV for `insta` has been raised to 1.60, and for `cargo-insta` to 1.64.

- Added support for compact debug snapshots (`assert_compact_debug_snapshot`). #514
- Added support for compact debug snapshots (`assert_compact_debug_snapshot`). #514

- Deprecate `--no-force-pass` in `cargo-insta`. The `--check` option covers the
same functionality and has a clearer name. #513
Expand Down
4 changes: 2 additions & 2 deletions cargo-insta/src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1041,7 +1041,7 @@ fn pending_snapshots_cmd(cmd: PendingSnapshotsCommand) -> Result<(), Box<dyn Err
#[derive(Serialize, Debug)]
#[serde(rename_all = "snake_case", tag = "type")]
enum SnapshotKey<'a> {
NamedSnapshot {
FileSnapshot {
path: &'a Path,
},
InlineSnapshot {
Expand Down Expand Up @@ -1070,7 +1070,7 @@ fn pending_snapshots_cmd(cmd: PendingSnapshotsCommand) -> Result<(), Box<dyn Err
expression: snapshot_ref.new.metadata().expression(),
}
} else {
SnapshotKey::NamedSnapshot { path: &target_file }
SnapshotKey::FileSnapshot { path: &target_file }
};
println!("{}", serde_json::to_string(&info).unwrap());
} else if is_inline {
Expand Down
3 changes: 3 additions & 0 deletions cargo-insta/src/container.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ impl PendingSnapshot {
}
}

/// A snapshot and its immediate context, which loads & saves the snapshot. It
/// holds either a single file snapshot, or all the inline snapshots from a
/// single rust file.
#[derive(Debug)]
pub(crate) struct SnapshotContainer {
snapshot_path: PathBuf,
Expand Down
18 changes: 10 additions & 8 deletions insta/src/runtime.rs
Original file line number Diff line number Diff line change
Expand Up @@ -50,38 +50,38 @@ pub struct AutoName;

impl From<AutoName> for ReferenceValue<'static> {
fn from(_value: AutoName) -> ReferenceValue<'static> {
ReferenceValue::Named(None)
ReferenceValue::File(None)
}
}

impl From<Option<String>> for ReferenceValue<'static> {
fn from(value: Option<String>) -> ReferenceValue<'static> {
ReferenceValue::Named(value.map(Cow::Owned))
ReferenceValue::File(value.map(Cow::Owned))
}
}

impl From<String> for ReferenceValue<'static> {
fn from(value: String) -> ReferenceValue<'static> {
ReferenceValue::Named(Some(Cow::Owned(value)))
ReferenceValue::File(Some(Cow::Owned(value)))
}
}

impl<'a> From<Option<&'a str>> for ReferenceValue<'a> {
fn from(value: Option<&'a str>) -> ReferenceValue<'a> {
ReferenceValue::Named(value.map(Cow::Borrowed))
ReferenceValue::File(value.map(Cow::Borrowed))
}
}

impl<'a> From<&'a str> for ReferenceValue<'a> {
fn from(value: &'a str) -> ReferenceValue<'a> {
ReferenceValue::Named(Some(Cow::Borrowed(value)))
ReferenceValue::File(Some(Cow::Borrowed(value)))
}
}

/// A reference to a snapshot
pub enum ReferenceValue<'a> {
/// A named snapshot, where the inner value is the snapshot name.
Named(Option<Cow<'a, str>>),
/// A file snapshot, where the inner value is the snapshot name.
File(Option<Cow<'a, str>>),
/// An inline snapshot, where the inner value is the snapshot contents.
Inline(&'a str),
}
Expand Down Expand Up @@ -198,6 +198,8 @@ fn get_snapshot_filename(
})
}

/// A single snapshot including surrounding context which asserts and save the
/// snapshot.
#[derive(Debug)]
struct SnapshotAssertionContext<'a> {
tool_config: Arc<ToolConfig>,
Expand Down Expand Up @@ -232,7 +234,7 @@ impl<'a> SnapshotAssertionContext<'a> {
let is_doctest = is_doctest(function_name);

match refval {
ReferenceValue::Named(name) => {
ReferenceValue::File(name) => {
let name = match name {
Some(name) => add_suffix_to_snapshot_name(name),
None => {
Expand Down
2 changes: 2 additions & 0 deletions insta/src/snapshot.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ lazy_static::lazy_static! {
};
}

/// Holds a pending inline snapshot loaded from a json file or read from an assert
/// macro (doesn't write to the rust file, which is done by `cargo-insta`)
#[derive(Debug)]
pub struct PendingInlineSnapshot {
pub run_id: String,
Expand Down

0 comments on commit d0e0b46

Please sign in to comment.