diff options
| author | Vicent Martà <tanoku@gmail.com> | 2012-01-24 20:35:15 -0800 |
|---|---|---|
| committer | Vicent Martà <tanoku@gmail.com> | 2012-01-24 20:35:15 -0800 |
| commit | 3fd1520cd4d8b4d6b6493a7d3dc393ffd9abf1db (patch) | |
| tree | 51b29f5d8ffeb31ba751ab2a099e4f2a32d4be07 /tests-clar/config/read.c | |
| parent | a9fe8ae0ee1ddcc289fad53f1a671f02a3e9a88f (diff) | |
| download | libgit2-3fd1520cd4d8b4d6b6493a7d3dc393ffd9abf1db.tar.gz | |
Rename the Clay test suite to Clar
Clay is the name of a programming language on the makings, and we want
to avoid confusions. Sorry for the huge diff!
Diffstat (limited to 'tests-clar/config/read.c')
| -rw-r--r-- | tests-clar/config/read.c | 209 |
1 files changed, 209 insertions, 0 deletions
diff --git a/tests-clar/config/read.c b/tests-clar/config/read.c new file mode 100644 index 000000000..26e6f4248 --- /dev/null +++ b/tests-clar/config/read.c @@ -0,0 +1,209 @@ +#include "clar_libgit2.h" + +void test_config_read__simple_read(void) +{ + git_config *cfg; + int32_t i; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config0"))); + + cl_git_pass(git_config_get_int32(cfg, "core.repositoryformatversion", &i)); + cl_assert(i == 0); + cl_git_pass(git_config_get_bool(cfg, "core.filemode", &i)); + cl_assert(i == 1); + cl_git_pass(git_config_get_bool(cfg, "core.bare", &i)); + cl_assert(i == 0); + cl_git_pass(git_config_get_bool(cfg, "core.logallrefupdates", &i)); + cl_assert(i == 1); + + git_config_free(cfg); +} + +void test_config_read__case_sensitive(void) +{ + git_config *cfg; + int i; + const char *str; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config1"))); + + cl_git_pass(git_config_get_string(cfg, "this.that.other", &str)); + cl_assert(!strcmp(str, "true")); + cl_git_pass(git_config_get_string(cfg, "this.That.other", &str)); + cl_assert(!strcmp(str, "yes")); + + cl_git_pass(git_config_get_bool(cfg, "this.that.other", &i)); + cl_assert(i == 1); + cl_git_pass(git_config_get_bool(cfg, "this.That.other", &i)); + cl_assert(i == 1); + + /* This one doesn't exist */ + cl_must_fail(git_config_get_bool(cfg, "this.thaT.other", &i)); + + git_config_free(cfg); +} + +/* + * If \ is the last non-space character on the line, we read the next + * one, separating each line with SP. + */ +void test_config_read__multiline_value(void) +{ + git_config *cfg; + const char *str; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config2"))); + + cl_git_pass(git_config_get_string(cfg, "this.That.and", &str)); + cl_assert(!strcmp(str, "one one one two two three three")); + + git_config_free(cfg); +} + +/* + * This kind of subsection declaration is case-insensitive + */ +void test_config_read__subsection_header(void) +{ + git_config *cfg; + const char *str; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config3"))); + + cl_git_pass(git_config_get_string(cfg, "section.subsection.var", &str)); + cl_assert(!strcmp(str, "hello")); + + /* The subsection is transformed to lower-case */ + cl_must_fail(git_config_get_string(cfg, "section.subSectIon.var", &str)); + + git_config_free(cfg); +} + +void test_config_read__lone_variable(void) +{ + git_config *cfg; + const char *str; + int i; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config4"))); + + cl_git_pass(git_config_get_string(cfg, "some.section.variable", &str)); + cl_assert(str == NULL); + + cl_git_pass(git_config_get_bool(cfg, "some.section.variable", &i)); + cl_assert(i == 1); + + git_config_free(cfg); +} + +void test_config_read__number_suffixes(void) +{ + git_config *cfg; + int64_t i; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config5"))); + + cl_git_pass(git_config_get_int64(cfg, "number.simple", &i)); + cl_assert(i == 1); + + cl_git_pass(git_config_get_int64(cfg, "number.k", &i)); + cl_assert(i == 1 * 1024); + + cl_git_pass(git_config_get_int64(cfg, "number.kk", &i)); + cl_assert(i == 1 * 1024); + + cl_git_pass(git_config_get_int64(cfg, "number.m", &i)); + cl_assert(i == 1 * 1024 * 1024); + + cl_git_pass(git_config_get_int64(cfg, "number.mm", &i)); + cl_assert(i == 1 * 1024 * 1024); + + cl_git_pass(git_config_get_int64(cfg, "number.g", &i)); + cl_assert(i == 1 * 1024 * 1024 * 1024); + + cl_git_pass(git_config_get_int64(cfg, "number.gg", &i)); + cl_assert(i == 1 * 1024 * 1024 * 1024); + + git_config_free(cfg); +} + +void test_config_read__blank_lines(void) +{ + git_config *cfg; + int i; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config6"))); + + cl_git_pass(git_config_get_bool(cfg, "valid.subsection.something", &i)); + cl_assert(i == 1); + + cl_git_pass(git_config_get_bool(cfg, "something.else.something", &i)); + cl_assert(i == 0); + + git_config_free(cfg); +} + +void test_config_read__invalid_ext_headers(void) +{ + git_config *cfg; + cl_must_fail(git_config_open_ondisk(&cfg, cl_fixture("config/config7"))); +} + +void test_config_read__empty_files(void) +{ + git_config *cfg; + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config8"))); + git_config_free(cfg); +} + +void test_config_read__header_in_last_line(void) +{ + git_config *cfg; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config10"))); + git_config_free(cfg); +} + +void test_config_read__prefixes(void) +{ + git_config *cfg; + const char *str; + + cl_git_pass(git_config_open_ondisk(&cfg, cl_fixture("config/config9"))); + cl_git_pass(git_config_get_string(cfg, "remote.ab.url", &str)); + cl_assert(strcmp(str, "http://example.com/git/ab") == 0); + + cl_git_pass(git_config_get_string(cfg, "remote.abba.url", &str)); + cl_assert(strcmp(str, "http://example.com/git/abba") == 0); + + git_config_free(cfg); +} + +#if 0 + +BEGIN_TEST(config10, "a repo's config overrides the global config") + git_repository *repo; + git_config *cfg; + int32_t version; + + cl_git_pass(git_repository_open(&repo, REPOSITORY_FOLDER)); + cl_git_pass(git_repository_config(&cfg, repo, GLOBAL_CONFIG, NULL)); + cl_git_pass(git_config_get_int32(cfg, "core.repositoryformatversion", &version)); + cl_assert(version == 0); + git_config_free(cfg); + git_repository_free(repo); +END_TEST + +BEGIN_TEST(config11, "fall back to the global config") + git_repository *repo; + git_config *cfg; + int32_t num; + + cl_git_pass(git_repository_open(&repo, REPOSITORY_FOLDER)); + cl_git_pass(git_repository_config(&cfg, repo, GLOBAL_CONFIG, NULL)); + cl_git_pass(git_config_get_int32(cfg, "core.something", &num)); + cl_assert(num == 2); + git_config_free(cfg); + git_repository_free(repo); +END_TEST +#endif |
