Skip to content

Commit

Permalink
add a core.autocrlf (filter) test
Browse files Browse the repository at this point in the history
This for the first time actually runs filters, and it seems to work fine.
  • Loading branch information
Byron committed Jan 8, 2025
1 parent 5b6e5c8 commit b67c39d
Show file tree
Hide file tree
Showing 4 changed files with 160 additions and 27 deletions.
2 changes: 1 addition & 1 deletion gix-status/tests/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ gix-dir = { path = "../../gix-dir" }
gix-odb = { path = "../../gix-odb" }
gix-hash = { path = "../../gix-hash" }
gix-object = { path = "../../gix-object" }
gix-features = { path = "../../gix-features" }
gix-features = { path = "../../gix-features", features = ["parallel"] }
gix-pathspec = { path = "../../gix-pathspec" }
gix-worktree = { path = "../../gix-worktree" }
filetime = "0.2.15"
Expand Down
1 change: 1 addition & 0 deletions gix-status/tests/fixtures/generated-archives/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@ status_unchanged.tar
status_changed.tar
symlink_stack.tar
status_nonfile.tar
status_unchanged_filter.tar
23 changes: 23 additions & 0 deletions gix-status/tests/fixtures/status_unchanged_filter.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/usr/bin/env bash
set -eu -o pipefail

git init -q

touch empty
echo -n "content" >executable
chmod +x executable

mkdir dir
echo "other content" >dir/content
seq 5 >dir/content2
mkdir dir/sub-dir
(cd dir/sub-dir && ln -sf ../content symlink)

git add -A
git update-index --chmod=+x executable # For Windows.
git commit -m "Commit"

git ls-files | xargs rm

git config core.autocrlf true
git checkout -f HEAD
161 changes: 135 additions & 26 deletions gix-status/tests/status/index_as_worktree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ use std::sync::{

use bstr::BStr;
use filetime::{set_file_mtime, FileTime};
use gix_filter::eol::AutoCrlf;
use gix_index as index;
use gix_index::Entry;
use gix_status::index_as_worktree::Context;
Expand Down Expand Up @@ -38,40 +39,97 @@ fn fixture(name: &str, expected_status: &[Expectation<'_>]) -> Outcome {
}

fn nonfile_fixture(name: &str, expected_status: &[Expectation<'_>]) -> Outcome {
fixture_filtered_detailed("status_nonfile", name, &[], expected_status, |_| {}, false)
fixture_filtered_detailed(
"status_nonfile",
name,
&[],
expected_status,
|_| {},
false,
Default::default(),
false,
)
}

fn fixture_with_index(
name: &str,
prepare_index: impl FnMut(&mut gix_index::State),
expected_status: &[Expectation<'_>],
) -> Outcome {
fixture_filtered_detailed(name, "", &[], expected_status, prepare_index, false)
fixture_filtered_detailed(
name,
"",
&[],
expected_status,
prepare_index,
false,
Default::default(),
false,
)
}

fn submodule_fixture(name: &str, expected_status: &[Expectation<'_>]) -> Outcome {
fixture_filtered_detailed("status_submodule", name, &[], expected_status, |_| {}, false)
fixture_filtered_detailed(
"status_submodule",
name,
&[],
expected_status,
|_| {},
false,
Default::default(),
false,
)
}

fn conflict_fixture(name: &str, expected_status: &[Expectation<'_>]) -> Outcome {
fixture_filtered_detailed("conflicts", name, &[], expected_status, |_| {}, false)
fixture_filtered_detailed(
"conflicts",
name,
&[],
expected_status,
|_| {},
false,
Default::default(),
false,
)
}

fn submodule_fixture_status(name: &str, expected_status: &[Expectation<'_>], submodule_dirty: bool) -> Outcome {
fixture_filtered_detailed("status_submodule", name, &[], expected_status, |_| {}, submodule_dirty)
fixture_filtered_detailed(
"status_submodule",
name,
&[],
expected_status,
|_| {},
submodule_dirty,
Default::default(),
false,
)
}

fn fixture_filtered(name: &str, pathspecs: &[&str], expected_status: &[Expectation<'_>]) -> Outcome {
fixture_filtered_detailed(name, "", pathspecs, expected_status, |_| {}, false)
fixture_filtered_detailed(
name,
"",
pathspecs,
expected_status,
|_| {},
false,
Default::default(),
false,
)
}

#[allow(clippy::too_many_arguments)]
fn fixture_filtered_detailed(
name: &str,
subdir: &str,
pathspecs: &[&str],
expected_status: &[Expectation<'_>],
mut prepare_index: impl FnMut(&mut gix_index::State),
submodule_dirty: bool,
auto_crlf: gix_filter::eol::AutoCrlf,
use_odb: bool,
) -> Outcome {
// This can easily happen in some fixtures, which can cause flakiness. It's time-dependent after all.
fn ignore_racyclean(mut out: Outcome) -> Outcome {
Expand Down Expand Up @@ -105,26 +163,53 @@ fn fixture_filtered_detailed(
&index,
index.path_backing(),
);
let outcome = index_as_worktree(
&index,
&worktree,
&mut recorder,
FastEq,
SubmoduleStatusMock { dirty: submodule_dirty },
gix_object::find::Never,
&mut gix_features::progress::Discard,
Context {
pathspec: search,
stack,
filter: Default::default(),
should_interrupt: &AtomicBool::default(),
},
Options {
fs: gix_fs::Capabilities::probe(&git_dir),
stat: TEST_OPTIONS,
..Options::default()
},
)
let ctx = Context {
pathspec: search,
stack,
filter: gix_filter::Pipeline::new(
Default::default(),
gix_filter::pipeline::Options {
eol_config: gix_filter::eol::Configuration {
auto_crlf,
..Default::default()
},
..Default::default()
},
),
should_interrupt: &AtomicBool::default(),
};
let options = Options {
fs: gix_fs::Capabilities::probe(&git_dir),
stat: TEST_OPTIONS,
..Options::default()
};
let outcome = if use_odb {
let odb = gix_odb::at(git_dir.join("objects")).unwrap().into_arc().unwrap();
index_as_worktree(
&index,
&worktree,
&mut recorder,
FastEq,
SubmoduleStatusMock { dirty: submodule_dirty },
odb,
&mut gix_features::progress::Discard,
ctx,
options,
)
} else {
let odb = gix_object::find::Never;
index_as_worktree(
&index,
&worktree,
&mut recorder,
FastEq,
SubmoduleStatusMock { dirty: submodule_dirty },
&odb,
&mut gix_features::progress::Discard,
ctx,
options,
)
}
.unwrap();
recorder.records.sort_unstable_by_key(|r| r.relative_path);
assert_eq!(records_to_tuple(recorder.records), expected_status);
Expand Down Expand Up @@ -256,6 +341,8 @@ fn replace_dir_with_file() {
],
|_| {},
false,
Default::default(),
false,
);
assert_eq!(
out,
Expand Down Expand Up @@ -453,6 +540,28 @@ fn unchanged() {
fixture("status_unchanged", &[]);
}

#[test]
fn unchanged_despite_filter() {
let actual_outcome = fixture_filtered_detailed(
"status_unchanged_filter",
"",
&[],
&[],
|_| {},
false,
AutoCrlf::Enabled,
true, /* make ODB available */
);

let expected_outcome = Outcome {
entries_to_process: 5,
entries_processed: 5,
symlink_metadata_calls: 5,
..Default::default()
};
assert_eq!(actual_outcome, expected_outcome,);
}

#[test]
fn refresh() {
let expected_outcome = Outcome {
Expand Down

0 comments on commit b67c39d

Please sign in to comment.