void test_stash_drop__cannot_drop_a_non_existing_stashed_state(void) { push_three_states(); cl_git_fail_with(git_stash_drop(repo, 666), GIT_ENOTFOUND); cl_git_fail_with(git_stash_drop(repo, 42), GIT_ENOTFOUND); cl_git_fail_with(git_stash_drop(repo, 3), GIT_ENOTFOUND); }
void test_stash_drop__can_purge_the_stash_from_the_bottom(void) { push_three_states(); cl_git_pass(git_stash_drop(repo, 2)); cl_git_pass(git_stash_drop(repo, 1)); cl_git_pass(git_stash_drop(repo, 0)); cl_git_fail_with(git_stash_drop(repo, 0), GIT_ENOTFOUND); }
void test_stash_drop__dropping_an_entry_rewrites_reflog_history(void) { git_reference *stash; git_reflog *reflog; const git_reflog_entry *entry; git_oid oid; size_t count; push_three_states(); cl_git_pass(git_reference_lookup(&stash, repo, GIT_REFS_STASH_FILE)); cl_git_pass(git_reflog_read(&reflog, stash)); entry = git_reflog_entry_byindex(reflog, 1); git_oid_cpy(&oid, git_reflog_entry_id_old(entry)); count = git_reflog_entrycount(reflog); git_reflog_free(reflog); cl_git_pass(git_stash_drop(repo, 1)); cl_git_pass(git_reflog_read(&reflog, stash)); entry = git_reflog_entry_byindex(reflog, 0); cl_assert_equal_i(0, git_oid_cmp(&oid, git_reflog_entry_id_old(entry))); cl_assert_equal_sz(count - 1, git_reflog_entrycount(reflog)); git_reflog_free(reflog); git_reference_free(stash); }
void test_stash_drop__dropping_the_last_entry_removes_the_stash(void) { git_reference *stash; push_three_states(); cl_git_pass(git_reference_lookup(&stash, repo, GIT_REFS_STASH_FILE)); git_reference_free(stash); cl_git_pass(git_stash_drop(repo, 0)); cl_git_pass(git_stash_drop(repo, 0)); cl_git_pass(git_stash_drop(repo, 0)); cl_git_fail_with( git_reference_lookup(&stash, repo, GIT_REFS_STASH_FILE), GIT_ENOTFOUND); }
void test_stash_drop__dropping_the_top_stash_updates_the_stash_reference(void) { git_object *next_top_stash; git_oid oid; push_three_states(); retrieve_top_stash_id(&oid); cl_git_pass(git_revparse_single(&next_top_stash, repo, "stash@{1}")); cl_assert_equal_i(false, git_oid_cmp(&oid, git_object_id(next_top_stash)) == 0); cl_git_pass(git_stash_drop(repo, 0)); retrieve_top_stash_id(&oid); cl_git_pass(git_oid_cmp(&oid, git_object_id(next_top_stash))); }
/** * Remove a stash from the stash list * * @param repo S3 class git_repository that contains the stash * @param index The index to the stash. 0 is the most recent stash. * @return R_NilValue */ SEXP git2r_stash_drop(SEXP repo, SEXP index) { int error; git_repository *repository = NULL; if (git2r_arg_check_integer_gte_zero(index)) git2r_error(__func__, NULL, "'index'", git2r_err_integer_gte_zero_arg); repository = git2r_repository_open(repo); if (!repository) git2r_error(__func__, NULL, git2r_err_invalid_repository, NULL); error = git_stash_drop(repository, INTEGER(index)[0]); git_repository_free(repository); if (error) git2r_error(__func__, GIT2R_ERROR_LAST(), NULL, NULL); return R_NilValue; }
void test_stash_drop__cannot_drop_from_an_empty_stash(void) { cl_git_fail_with(git_stash_drop(repo, 0), GIT_ENOTFOUND); }