summaryrefslogtreecommitdiff
path: root/tests/notes
Commit message (Collapse)AuthorAgeFilesLines
* refactor: `tests` is now `tests/libgit2`Edward Thomson2022-02-222-725/+0
| | | | | | Like we want to separate libgit2 and utility source code, we want to separate libgit2 and utility tests. Start by moving all the tests into libgit2.
* tests: declare functions statically where appropriateEdward Thomson2021-11-111-1/+1
|
* str: introduce `git_str` for internal, `git_buf` is externalethomson/gitstrEdward Thomson2021-10-172-5/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | libgit2 has two distinct requirements that were previously solved by `git_buf`. We require: 1. A general purpose string class that provides a number of utility APIs for manipulating data (eg, concatenating, truncating, etc). 2. A structure that we can use to return strings to callers that they can take ownership of. By using a single class (`git_buf`) for both of these purposes, we have confused the API to the point that refactorings are difficult and reasoning about correctness is also difficult. Move the utility class `git_buf` to be called `git_str`: this represents its general purpose, as an internal string buffer class. The name also is an homage to Junio Hamano ("gitstr"). The public API remains `git_buf`, and has a much smaller footprint. It is generally only used as an "out" param with strict requirements that follow the documentation. (Exceptions exist for some legacy APIs to avoid breaking callers unnecessarily.) Utility functions exist to convert a user-specified `git_buf` to a `git_str` so that we can call internal functions, then converting it back again.
* tests: add missing error checksPatrick Steinhardt2020-02-071-8/+4
| | | | | | We should always verify error codes returned by function calls in our test suite to not accidentally miss any weird results. Coverity reported missing checks in several locations, which this commit fixes.
* Convert usage of `git_buf_free` to new `git_buf_dispose`Patrick Steinhardt2018-06-102-2/+2
|
* notes: Add test that read of noteless commit failsRichard Ipsum2017-12-021-0/+25
|
* notes: Add git_note_commit_iterator_newRichard Ipsum2017-10-071-0/+43
| | | | This also adds tests for this function.
* notes: Add git_note_commit_removeRichard Ipsum2017-10-071-0/+44
| | | | This also adds tests for this function.
* notes: Add git_note_commit_readRichard Ipsum2017-10-071-0/+40
| | | | This also adds tests for this function.
* notes: Add git_note_commit_createRichard Ipsum2017-10-071-0/+122
| | | | | | | | | | This adds a new function that will allow creation of notes without necessarily updating a particular ref, the notes tree is obtained from the git_commit object parameter, a new commit object pointing to the current tip of the notes tree is optionally returned via the 'note_commit_out' parameter, optionally the blob id for the note is returned through the 'note_blob_out' object.
* note: use a git_buf to return the default namespacecmn/notes-bufCarlos Martín Nieto2015-03-172-5/+12
| | | | | | | The caller has otherwise no way to know how long the string will be allocated or ability to free it. This fixes #2944.
* notes: move the notes name argumentCarlos Martín Nieto2014-12-062-7/+7
| | | | | Make it consistent between git_note_create() and git_note_remote() by putting it after the repository.
* Introduce cl_assert_equal_oidEdward Thomson2014-07-012-6/+6
|
* note: rename the id getter to git_note_id()Carlos Martín Nieto2014-01-242-4/+4
| | | | This was left over when we did the general switch.
* Remove converting user error to GIT_EUSERRussell Belfer2013-12-111-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This changes the behavior of callbacks so that the callback error code is not converted into GIT_EUSER and instead we propagate the return value through to the caller. Instead of using the giterr_capture and giterr_restore functions, we now rely on all functions to pass back the return value from a callback. To avoid having a return value with no error message, the user can call the public giterr_set_str or some such function to set an error message. There is a new helper 'giterr_set_callback' that functions can invoke after making a callback which ensures that some error message was set in case the callback did not set one. In places where the sign of the callback return value is meaningful (e.g. positive to skip, negative to abort), only the negative values are returned back to the caller, obviously, since the other values allow for continuing the loop. The hardest parts of this were in the checkout code where positive return values were overloaded as meaningful values for checkout. I fixed this by adding an output parameter to many of the internal checkout functions and removing the overload. This added some code, but it is probably a better implementation. There is some funkiness in the network code where user provided callbacks could be returning a positive or a negative value and we want to rely on that to cancel the loop. There are still a couple places where an user error might get turned into GIT_EUSER there, I think, though none exercised by the tests.
* Rename tests-clar to testsBen Straub2013-11-142-0/+451