2018-03-24 08:44:51 +01:00
|
|
|
#include "test-tool.h"
|
2013-06-09 19:39:17 +02:00
|
|
|
#include "cache.h"
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
#include "config.h"
|
2021-03-30 15:10:50 +02:00
|
|
|
#include "blob.h"
|
|
|
|
#include "commit.h"
|
|
|
|
#include "tree.h"
|
2021-03-30 15:10:51 +02:00
|
|
|
#include "sparse-index.h"
|
2021-03-30 15:10:50 +02:00
|
|
|
|
|
|
|
static void print_cache_entry(struct cache_entry *ce)
|
|
|
|
{
|
|
|
|
const char *type;
|
|
|
|
printf("%06o ", ce->ce_mode & 0177777);
|
|
|
|
|
|
|
|
if (S_ISSPARSEDIR(ce->ce_mode))
|
|
|
|
type = tree_type;
|
|
|
|
else if (S_ISGITLINK(ce->ce_mode))
|
|
|
|
type = commit_type;
|
|
|
|
else
|
|
|
|
type = blob_type;
|
|
|
|
|
|
|
|
printf("%s %s\t%s\n",
|
|
|
|
type,
|
|
|
|
oid_to_hex(&ce->oid),
|
|
|
|
ce->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void print_cache(struct index_state *istate)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < istate->cache_nr; i++)
|
|
|
|
print_cache_entry(istate->cache[i]);
|
|
|
|
}
|
2013-06-09 19:39:17 +02:00
|
|
|
|
2018-03-24 08:44:51 +01:00
|
|
|
int cmd__read_cache(int argc, const char **argv)
|
2013-06-09 19:39:17 +02:00
|
|
|
{
|
2021-03-30 15:10:50 +02:00
|
|
|
struct repository *r = the_repository;
|
2019-09-06 00:54:31 +02:00
|
|
|
int i, cnt = 1;
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
const char *name = NULL;
|
2021-03-30 15:10:51 +02:00
|
|
|
int table = 0, expand = 0;
|
|
|
|
|
|
|
|
initialize_the_repository();
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
|
2021-03-30 15:10:50 +02:00
|
|
|
for (++argv, --argc; *argv && starts_with(*argv, "--"); ++argv, --argc) {
|
|
|
|
if (skip_prefix(*argv, "--print-and-refresh=", &name))
|
|
|
|
continue;
|
|
|
|
if (!strcmp(*argv, "--table"))
|
|
|
|
table = 1;
|
2021-03-30 15:10:51 +02:00
|
|
|
else if (!strcmp(*argv, "--expand"))
|
|
|
|
expand = 1;
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
}
|
|
|
|
|
2021-03-30 15:10:50 +02:00
|
|
|
if (argc == 1)
|
|
|
|
cnt = strtol(argv[0], NULL, 0);
|
2017-04-06 22:41:41 +02:00
|
|
|
setup_git_directory();
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
git_config(git_default_config, NULL);
|
2021-03-30 15:10:50 +02:00
|
|
|
|
2021-11-23 01:20:30 +01:00
|
|
|
prepare_repo_settings(r);
|
|
|
|
r->settings.command_requires_full_index = 0;
|
|
|
|
|
2013-06-09 19:39:17 +02:00
|
|
|
for (i = 0; i < cnt; i++) {
|
2021-03-30 15:10:50 +02:00
|
|
|
repo_read_index(r);
|
2021-03-30 15:10:51 +02:00
|
|
|
|
|
|
|
if (expand)
|
|
|
|
ensure_full_index(r->index);
|
|
|
|
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
if (name) {
|
|
|
|
int pos;
|
|
|
|
|
2021-03-30 15:10:50 +02:00
|
|
|
refresh_index(r->index, REFRESH_QUIET,
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
NULL, NULL, NULL);
|
2021-03-30 15:10:50 +02:00
|
|
|
pos = index_name_pos(r->index, name, strlen(name));
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
if (pos < 0)
|
|
|
|
die("%s not in index", name);
|
|
|
|
printf("%s is%s up to date\n", name,
|
2021-03-30 15:10:50 +02:00
|
|
|
ce_uptodate(r->index->cache[pos]) ? "" : " not");
|
fsmonitor: demonstrate that it is not refreshed after discard_index()
This one is tricky.
When `core.fsmonitor` is set, a `refresh_index()` will not perform a
full scan of files that might be modified, but will query the fsmonitor
and refresh only the ones that have been actually touched.
Due to implementation details, the fsmonitor is queried in
`refresh_cache_ent()`, but of course it only has to be queried once, so
we set a flag when we did that. But when the index was discarded, we did
not re-set that flag.
So far, this is only covered by our test suite when running with
GIT_TEST_FSMONITOR=$PWD/t7519/fsmonitor-all, and only due to the way the
built-in stash interacts with the recursive merge machinery.
Let's introduce a straight-forward regression test for this.
We simply extend the "read & discard index" loop in `test-tool
read-cache` to optionally refresh the index, report on a given file's
status, and then modify that file. Due to the bug described above, only
the first refresh will actually query the fsmonitor; subsequent loop
iterations will not.
This problem was reported by Ævar Arnfjörð Bjarmason.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2019-05-07 13:10:20 +02:00
|
|
|
write_file(name, "%d\n", i);
|
|
|
|
}
|
2021-03-30 15:10:50 +02:00
|
|
|
if (table)
|
|
|
|
print_cache(r->index);
|
|
|
|
discard_index(r->index);
|
2013-06-09 19:39:17 +02:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|