mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-28 00:25:29 +00:00
Merge pull request #3480 from ethomson/nsecs
Nanoseconds in the index: ignore for diffing
This commit is contained in:
commit
dc2cf3eb1a
@ -493,8 +493,10 @@ static int diff_list_apply_options(
|
||||
|
||||
/* Don't set GIT_DIFFCAPS_USE_DEV - compile time option in core git */
|
||||
|
||||
/* Set GIT_DIFFCAPS_TRUST_NANOSECS on a platform basis */
|
||||
/* Don't trust nanoseconds; we do not load nanos from disk */
|
||||
#ifdef GIT_USE_NSEC
|
||||
diff->diffcaps = diff->diffcaps | GIT_DIFFCAPS_TRUST_NANOSECS;
|
||||
#endif
|
||||
|
||||
/* If not given explicit `opts`, check `diff.xyz` configs */
|
||||
if (!opts) {
|
||||
|
78
tests/index/nsec.c
Normal file
78
tests/index/nsec.c
Normal file
@ -0,0 +1,78 @@
|
||||
#include "clar_libgit2.h"
|
||||
#include "index.h"
|
||||
#include "git2/sys/index.h"
|
||||
#include "git2/repository.h"
|
||||
#include "../reset/reset_helpers.h"
|
||||
|
||||
static git_repository *repo;
|
||||
static git_index *repo_index;
|
||||
|
||||
#define TEST_REPO_PATH "nsecs"
|
||||
|
||||
// Fixture setup and teardown
|
||||
void test_index_nsec__initialize(void)
|
||||
{
|
||||
repo = cl_git_sandbox_init("nsecs");
|
||||
git_repository_index(&repo_index, repo);
|
||||
}
|
||||
|
||||
void test_index_nsec__cleanup(void)
|
||||
{
|
||||
git_index_free(repo_index);
|
||||
repo_index = NULL;
|
||||
|
||||
cl_git_sandbox_cleanup();
|
||||
}
|
||||
|
||||
static bool has_nsecs(void)
|
||||
{
|
||||
const git_index_entry *entry;
|
||||
size_t i;
|
||||
bool has_nsecs = false;
|
||||
|
||||
for (i = 0; i < git_index_entrycount(repo_index); i++) {
|
||||
entry = git_index_get_byindex(repo_index, i);
|
||||
|
||||
if (entry->ctime.nanoseconds || entry->mtime.nanoseconds) {
|
||||
has_nsecs = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return has_nsecs;
|
||||
}
|
||||
|
||||
void test_index_nsec__has_nanos(void)
|
||||
{
|
||||
cl_assert_equal_b(true, has_nsecs());
|
||||
}
|
||||
|
||||
void test_index_nsec__staging_maintains_other_nanos(void)
|
||||
{
|
||||
const git_index_entry *entry;
|
||||
|
||||
cl_git_rewritefile("nsecs/a.txt", "This is file A");
|
||||
cl_git_pass(git_index_add_bypath(repo_index, "a.txt"));
|
||||
cl_git_pass(git_index_write(repo_index));
|
||||
|
||||
cl_git_pass(git_index_write(repo_index));
|
||||
|
||||
git_index_read(repo_index, 1);
|
||||
cl_assert_equal_b(true, has_nsecs());
|
||||
|
||||
cl_assert((entry = git_index_get_bypath(repo_index, "a.txt", 0)));
|
||||
cl_assert_equal_i(0, entry->ctime.nanoseconds);
|
||||
cl_assert_equal_i(0, entry->mtime.nanoseconds);
|
||||
}
|
||||
|
||||
void test_index_nsec__status_doesnt_clear_nsecs(void)
|
||||
{
|
||||
git_status_list *statuslist;
|
||||
|
||||
cl_git_pass(git_status_list_new(&statuslist, repo, NULL));
|
||||
|
||||
git_index_read(repo_index, 1);
|
||||
cl_assert_equal_b(true, has_nsecs());
|
||||
|
||||
git_status_list_free(statuslist);
|
||||
}
|
BIN
tests/resources/nsecs/.gitted/HEAD
Normal file
BIN
tests/resources/nsecs/.gitted/HEAD
Normal file
Binary file not shown.
BIN
tests/resources/nsecs/.gitted/config
Normal file
BIN
tests/resources/nsecs/.gitted/config
Normal file
Binary file not shown.
BIN
tests/resources/nsecs/.gitted/index
Normal file
BIN
tests/resources/nsecs/.gitted/index
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
BIN
tests/resources/nsecs/.gitted/refs/heads/master
Normal file
BIN
tests/resources/nsecs/.gitted/refs/heads/master
Normal file
Binary file not shown.
BIN
tests/resources/nsecs/a.txt
Normal file
BIN
tests/resources/nsecs/a.txt
Normal file
Binary file not shown.
BIN
tests/resources/nsecs/b.txt
Normal file
BIN
tests/resources/nsecs/b.txt
Normal file
Binary file not shown.
BIN
tests/resources/nsecs/c.txt
Normal file
BIN
tests/resources/nsecs/c.txt
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user