summaryrefslogtreecommitdiff
path: root/tests-clar/reset/mixed.c
diff options
context:
space:
mode:
authorVicent Martí <vicent@github.com>2012-06-07 12:30:20 -0700
committerVicent Martí <vicent@github.com>2012-06-07 12:30:20 -0700
commit6c08e69fd92028822cb98368e564c5cb7964c072 (patch)
treee34d67219a554d58faa17e77fd13f5e568414938 /tests-clar/reset/mixed.c
parentb9ebcc59e7d13507d4f8faf86d68dd3ac1a4b627 (diff)
parentedebceffef1d661d073b9961d13042007325832d (diff)
downloadlibgit2-6c08e69fd92028822cb98368e564c5cb7964c072.tar.gz
Merge pull request #669 from nulltoken/topic/reset
Add git_reset()
Diffstat (limited to 'tests-clar/reset/mixed.c')
-rw-r--r--tests-clar/reset/mixed.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests-clar/reset/mixed.c b/tests-clar/reset/mixed.c
new file mode 100644
index 000000000..7cfff65d4
--- /dev/null
+++ b/tests-clar/reset/mixed.c
@@ -0,0 +1,47 @@
+#include "clar_libgit2.h"
+#include "posix.h"
+#include "reset_helpers.h"
+#include "path.h"
+
+static git_repository *repo;
+static git_object *target;
+
+void test_reset_mixed__initialize(void)
+{
+ repo = cl_git_sandbox_init("attr");
+ target = NULL;
+}
+
+void test_reset_mixed__cleanup(void)
+{
+ git_object_free(target);
+ cl_git_sandbox_cleanup();
+}
+
+void test_reset_mixed__cannot_reset_in_a_bare_repository(void)
+{
+ git_repository *bare;
+
+ cl_git_pass(git_repository_open(&bare, cl_fixture("testrepo.git")));
+ cl_assert(git_repository_is_bare(bare) == true);
+
+ retrieve_target_from_oid(&target, bare, KNOWN_COMMIT_IN_BARE_REPO);
+
+ cl_git_fail(git_reset(bare, target, GIT_RESET_MIXED));
+
+ git_repository_free(bare);
+}
+
+void test_reset_mixed__resetting_refreshes_the_index_to_the_commit_tree(void)
+{
+ unsigned int status;
+
+ cl_git_pass(git_status_file(&status, repo, "macro_bad"));
+ cl_assert(status == GIT_STATUS_CURRENT);
+ retrieve_target_from_oid(&target, repo, "605812ab7fe421fdd325a935d35cb06a9234a7d7");
+
+ cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED));
+
+ cl_git_pass(git_status_file(&status, repo, "macro_bad"));
+ cl_assert(status == GIT_STATUS_WT_NEW);
+}