Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
258115db
Unverified
Commit
258115db
authored
Aug 29, 2021
by
Edward Thomson
Committed by
GitHub
Aug 29, 2021
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #6016 from libgit2/ethomson/commit_create_cb
Introduce `create_commit_cb`, deprecate `signing_cb`
parents
16a2e667
ef03e150
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
402 additions
and
59 deletions
+402
-59
include/git2/commit.h
+35
-19
include/git2/deprecated.h
+21
-0
include/git2/rebase.h
+25
-1
src/rebase.c
+69
-33
tests/rebase/sign.c
+252
-6
No files found.
include/git2/commit.h
View file @
258115db
...
@@ -503,25 +503,41 @@ GIT_EXTERN(int) git_commit_create_with_signature(
...
@@ -503,25 +503,41 @@ GIT_EXTERN(int) git_commit_create_with_signature(
GIT_EXTERN
(
int
)
git_commit_dup
(
git_commit
**
out
,
git_commit
*
source
);
GIT_EXTERN
(
int
)
git_commit_dup
(
git_commit
**
out
,
git_commit
*
source
);
/**
/**
* Commit signing callback.
* Commit creation callback: used when a function is going to create
*
* commits (for example, in `git_rebase_commit`) to allow callers to
* The callback will be called with the commit content, giving a user an
* override the commit creation behavior. For example, users may
* opportunity to sign the commit content. The signature_field
* wish to sign commits by providing this information to
* buf may be left empty to specify the default field "gpgsig".
* `git_commit_create_buffer`, signing that buffer, then calling
*
* `git_commit_create_with_signature`. The resultant commit id
* Signatures can take the form of any string, and can be created on an arbitrary
* should be set in the `out` object id parameter.
* header field. Signatures are most commonly used for verifying authorship of a
*
* commit using GPG or a similar cryptographically secure signing algorithm.
* @param out pointer that this callback will populate with the object
* See https://git-scm.com/book/en/v2/Git-Tools-Signing-Your-Work for more
* id of the commit that is created
* details.
* @param author the author name and time of the commit
*
* @param committer the committer name and time of the commit
* When the callback:
* @param message_encoding the encoding of the given message, or NULL
* - returns GIT_PASSTHROUGH, no signature will be added to the commit.
* to assume UTF8
* - returns < 0, commit creation will be aborted.
* @param message the commit message
* - returns GIT_OK, the signature parameter is expected to be filled.
* @param tree the tree to be committed
*/
* @param parent_count the number of parents for this commit
typedef
int
(
*
git_commit_signing_cb
)(
* @param parents the commit parents
git_buf
*
signature
,
git_buf
*
signature_field
,
const
char
*
commit_content
,
void
*
payload
);
* @param payload the payload pointer in the rebase options
* @return 0 if this callback has created the commit and populated the out
* parameter, GIT_PASSTHROUGH if the callback has not created a
* commit and wants the calling function to create the commit as
* if no callback had been specified, any other value to stop
* and return a failure
*/
typedef
int
(
*
git_commit_create_cb
)(
git_oid
*
out
,
const
git_signature
*
author
,
const
git_signature
*
committer
,
const
char
*
message_encoding
,
const
char
*
message
,
const
git_tree
*
tree
,
size_t
parent_count
,
const
git_commit
*
parents
[],
void
*
payload
);
/** @} */
/** @} */
GIT_END_DECL
GIT_END_DECL
...
...
include/git2/deprecated.h
View file @
258115db
...
@@ -205,6 +205,27 @@ GIT_EXTERN(void) git_buf_free(git_buf *buffer);
...
@@ -205,6 +205,27 @@ GIT_EXTERN(void) git_buf_free(git_buf *buffer);
/**@}*/
/**@}*/
/** @name Deprecated Commit Definitions
*/
/**@{*/
/**
* Provide a commit signature during commit creation.
*
* Callers should instead define a `git_commit_create_cb` that
* generates a commit buffer using `git_commit_create_buffer`, sign
* that buffer and call `git_commit_create_with_signature`.
*
* @deprecated use a `git_commit_create_cb` instead
*/
typedef
int
(
*
git_commit_signing_cb
)(
git_buf
*
signature
,
git_buf
*
signature_field
,
const
char
*
commit_content
,
void
*
payload
);
/**@}*/
/** @name Deprecated Config Functions and Constants
/** @name Deprecated Config Functions and Constants
*/
*/
/**@{*/
/**@{*/
...
...
include/git2/rebase.h
View file @
258115db
...
@@ -75,13 +75,37 @@ typedef struct {
...
@@ -75,13 +75,37 @@ typedef struct {
git_checkout_options
checkout_options
;
git_checkout_options
checkout_options
;
/**
/**
* Optional callback that allows users to override commit
* creation in `git_rebase_commit`. If specified, users can
* create their own commit and provide the commit ID, which
* may be useful for signing commits or otherwise customizing
* the commit creation.
*
* If this callback returns `GIT_PASSTHROUGH`, then
* `git_rebase_commit` will continue to create the commit.
*/
git_commit_create_cb
commit_create_cb
;
#ifdef GIT_DEPRECATE_HARD
void
*
reserved
;
#else
/**
* If provided, this will be called with the commit content, allowing
* If provided, this will be called with the commit content, allowing
* a signature to be added to the rebase commit. Can be skipped with
* a signature to be added to the rebase commit. Can be skipped with
* GIT_PASSTHROUGH. If GIT_PASSTHROUGH is returned, a commit will be made
* GIT_PASSTHROUGH. If GIT_PASSTHROUGH is returned, a commit will be made
* without a signature.
* without a signature.
*
* This field is only used when performing git_rebase_commit.
* This field is only used when performing git_rebase_commit.
*
* This callback is not invoked if a `git_commit_create_cb` is
* specified.
*
* This callback is deprecated; users should provide a
* creation callback as `commit_create_cb` that produces a
* commit buffer, signs it, and commits it.
*/
*/
git_commit_signing_cb
signing_cb
;
int
(
*
signing_cb
)(
git_buf
*
,
git_buf
*
,
const
char
*
,
void
*
);
#endif
/**
/**
* This will be passed to each of the callbacks in this struct
* This will be passed to each of the callbacks in this struct
...
...
src/rebase.c
View file @
258115db
...
@@ -943,6 +943,54 @@ int git_rebase_inmemory_index(
...
@@ -943,6 +943,54 @@ int git_rebase_inmemory_index(
return
0
;
return
0
;
}
}
#ifndef GIT_DEPRECATE_HARD
static
int
create_signed
(
git_oid
*
out
,
git_rebase
*
rebase
,
const
git_signature
*
author
,
const
git_signature
*
committer
,
const
char
*
message_encoding
,
const
char
*
message
,
git_tree
*
tree
,
size_t
parent_count
,
const
git_commit
**
parents
)
{
git_buf
commit_content
=
GIT_BUF_INIT
,
commit_signature
=
GIT_BUF_INIT
,
signature_field
=
GIT_BUF_INIT
;
int
error
;
git_error_clear
();
if
((
error
=
git_commit_create_buffer
(
&
commit_content
,
rebase
->
repo
,
author
,
committer
,
message_encoding
,
message
,
tree
,
parent_count
,
parents
))
<
0
)
goto
done
;
error
=
rebase
->
options
.
signing_cb
(
&
commit_signature
,
&
signature_field
,
commit_content
.
ptr
,
rebase
->
options
.
payload
);
if
(
error
)
{
if
(
error
!=
GIT_PASSTHROUGH
)
git_error_set_after_callback_function
(
error
,
"signing_cb"
);
goto
done
;
}
error
=
git_commit_create_with_signature
(
out
,
rebase
->
repo
,
commit_content
.
ptr
,
commit_signature
.
size
>
0
?
commit_signature
.
ptr
:
NULL
,
signature_field
.
size
>
0
?
signature_field
.
ptr
:
NULL
);
done
:
git_buf_dispose
(
&
commit_signature
);
git_buf_dispose
(
&
signature_field
);
git_buf_dispose
(
&
commit_content
);
return
error
;
}
#endif
static
int
rebase_commit__create
(
static
int
rebase_commit__create
(
git_commit
**
out
,
git_commit
**
out
,
git_rebase
*
rebase
,
git_rebase
*
rebase
,
...
@@ -957,10 +1005,6 @@ static int rebase_commit__create(
...
@@ -957,10 +1005,6 @@ static int rebase_commit__create(
git_commit
*
current_commit
=
NULL
,
*
commit
=
NULL
;
git_commit
*
current_commit
=
NULL
,
*
commit
=
NULL
;
git_tree
*
parent_tree
=
NULL
,
*
tree
=
NULL
;
git_tree
*
parent_tree
=
NULL
,
*
tree
=
NULL
;
git_oid
tree_id
,
commit_id
;
git_oid
tree_id
,
commit_id
;
git_buf
commit_content
=
GIT_BUF_INIT
,
commit_signature
=
GIT_BUF_INIT
,
signature_field
=
GIT_BUF_INIT
;
const
char
*
signature_field_string
=
NULL
,
*
commit_signature_string
=
NULL
;
int
error
;
int
error
;
operation
=
git_array_get
(
rebase
->
operations
,
rebase
->
current
);
operation
=
git_array_get
(
rebase
->
operations
,
rebase
->
current
);
...
@@ -991,37 +1035,32 @@ static int rebase_commit__create(
...
@@ -991,37 +1035,32 @@ static int rebase_commit__create(
message
=
git_commit_message
(
current_commit
);
message
=
git_commit_message
(
current_commit
);
}
}
if
((
error
=
git_commit_create_buffer
(
&
commit_content
,
rebase
->
repo
,
author
,
committer
,
message_encoding
,
message
,
tree
,
1
,
(
const
git_commit
**
)
&
parent_commit
))
<
0
)
goto
done
;
if
(
rebase
->
options
.
signing_cb
)
{
git_error_clear
();
error
=
git_error_set_after_callback_function
(
rebase
->
options
.
signing_cb
(
&
commit_signature
,
&
signature_field
,
git_buf_cstr
(
&
commit_content
),
rebase
->
options
.
payload
),
"commit signing_cb failed"
);
if
(
error
==
GIT_PASSTHROUGH
)
{
git_buf_dispose
(
&
commit_signature
);
git_buf_dispose
(
&
signature_field
);
git_error_clear
();
git_error_clear
();
error
=
GIT_OK
;
error
=
GIT_PASSTHROUGH
;
}
else
if
(
error
<
0
)
goto
done
;
}
if
(
git_buf_is_allocated
(
&
commit_signature
))
{
if
(
rebase
->
options
.
commit_create_cb
)
{
GIT_ASSERT
(
git_buf_contains_nul
(
&
commit_signature
));
error
=
rebase
->
options
.
commit_create_cb
(
&
commit_id
,
commit_signature_string
=
git_buf_cstr
(
&
commit_signature
);
author
,
committer
,
message_encoding
,
message
,
}
tree
,
1
,
(
const
git_commit
**
)
&
parent_commit
,
rebase
->
options
.
payload
);
if
(
git_buf_is_allocated
(
&
signature_field
))
{
git_error_set_after_callback_function
(
error
,
GIT_ASSERT
(
git_buf_contains_nul
(
&
signature_field
));
"commit_create_cb"
);
signature_field_string
=
git_buf_cstr
(
&
signature_field
);
}
#ifndef GIT_DEPRECATE_HARD
else
if
(
rebase
->
options
.
signing_cb
)
{
error
=
create_signed
(
&
commit_id
,
rebase
,
author
,
committer
,
message_encoding
,
message
,
tree
,
1
,
(
const
git_commit
**
)
&
parent_commit
);
}
}
#endif
if
(
error
==
GIT_PASSTHROUGH
)
error
=
git_commit_create
(
&
commit_id
,
rebase
->
repo
,
NULL
,
author
,
committer
,
message_encoding
,
message
,
tree
,
1
,
(
const
git_commit
**
)
&
parent_commit
);
if
((
error
=
git_commit_create_with_signature
(
&
commit_id
,
rebase
->
repo
,
if
(
error
)
git_buf_cstr
(
&
commit_content
),
commit_signature_string
,
signature_field_string
)))
goto
done
;
goto
done
;
if
((
error
=
git_commit_lookup
(
&
commit
,
rebase
->
repo
,
&
commit_id
))
<
0
)
if
((
error
=
git_commit_lookup
(
&
commit
,
rebase
->
repo
,
&
commit_id
))
<
0
)
...
@@ -1033,9 +1072,6 @@ done:
...
@@ -1033,9 +1072,6 @@ done:
if
(
error
<
0
)
if
(
error
<
0
)
git_commit_free
(
commit
);
git_commit_free
(
commit
);
git_buf_dispose
(
&
commit_signature
);
git_buf_dispose
(
&
signature_field
);
git_buf_dispose
(
&
commit_content
);
git_commit_free
(
current_commit
);
git_commit_free
(
current_commit
);
git_tree_free
(
parent_tree
);
git_tree_free
(
parent_tree
);
git_tree_free
(
tree
);
git_tree_free
(
tree
);
...
...
tests/rebase/sign.c
View file @
258115db
...
@@ -18,29 +18,263 @@ void test_rebase_sign__cleanup(void)
...
@@ -18,29 +18,263 @@ void test_rebase_sign__cleanup(void)
cl_git_sandbox_cleanup
();
cl_git_sandbox_cleanup
();
}
}
static
const
char
*
expected_commit_content
=
"tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
static
int
create_cb_passthrough
(
git_oid
*
out
,
const
git_signature
*
author
,
const
git_signature
*
committer
,
const
char
*
message_encoding
,
const
char
*
message
,
const
git_tree
*
tree
,
size_t
parent_count
,
const
git_commit
*
parents
[],
void
*
payload
)
{
GIT_UNUSED
(
out
);
GIT_UNUSED
(
author
);
GIT_UNUSED
(
committer
);
GIT_UNUSED
(
message_encoding
);
GIT_UNUSED
(
message
);
GIT_UNUSED
(
tree
);
GIT_UNUSED
(
parent_count
);
GIT_UNUSED
(
parents
);
GIT_UNUSED
(
payload
);
return
GIT_PASSTHROUGH
;
}
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__passthrough_create_cb
(
void
)
{
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_rebase_operation
*
rebase_operation
;
git_oid
commit_id
,
expected_id
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_commit
*
commit
;
const
char
*
expected_commit_raw_header
=
"tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
"
;
rebase_opts
.
commit_create_cb
=
create_cb_passthrough
;
cl_git_pass
(
git_reference_lookup
(
&
branch_ref
,
repo
,
"refs/heads/gravy"
));
cl_git_pass
(
git_reference_lookup
(
&
upstream_ref
,
repo
,
"refs/heads/veal"
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
branch_head
,
repo
,
branch_ref
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
upstream_head
,
repo
,
upstream_ref
));
cl_git_pass
(
git_rebase_init
(
&
rebase
,
repo
,
branch_head
,
upstream_head
,
NULL
,
&
rebase_opts
));
cl_git_pass
(
git_rebase_next
(
&
rebase_operation
,
rebase
));
cl_git_pass
(
git_rebase_commit
(
&
commit_id
,
rebase
,
NULL
,
signature
,
NULL
,
NULL
));
git_oid_fromstr
(
&
expected_id
,
"129183968a65abd6c52da35bff43325001bfc630"
);
cl_assert_equal_oid
(
&
expected_id
,
&
commit_id
);
cl_git_pass
(
git_commit_lookup
(
&
commit
,
repo
,
&
commit_id
));
cl_assert_equal_s
(
expected_commit_raw_header
,
git_commit_raw_header
(
commit
));
cl_git_fail_with
(
GIT_ITEROVER
,
git_rebase_next
(
&
rebase_operation
,
rebase
));
git_reference_free
(
branch_ref
);
git_reference_free
(
upstream_ref
);
git_annotated_commit_free
(
branch_head
);
git_annotated_commit_free
(
upstream_head
);
git_commit_free
(
commit
);
git_rebase_free
(
rebase
);
}
int
create_cb_signed_gpg
(
git_oid
*
out
,
const
git_signature
*
author
,
const
git_signature
*
committer
,
const
char
*
message_encoding
,
const
char
*
message
,
const
git_tree
*
tree
,
size_t
parent_count
,
const
git_commit
*
parents
[],
void
*
payload
)
{
git_buf
commit_content
=
GIT_BUF_INIT
;
const
char
*
gpg_signature
=
"-----BEGIN PGP SIGNATURE-----
\n
\
\n
\
\n
\
Modification 3 to gravy
\n
"
;
iQIzBAEBCgAdFiEEgVlDEfSlmKn0fvGgK++h5T2/ctIFAlwZcrAACgkQK++h5T2/
\n
\
ctIPVhAA42RyZhMdKl5Bm0KtQco2scsukIg2y7tjSwhti91zDu3HQgpusjjo0fQx
\n
\
ZzB+OrmlvQ9CDcGpZ0THIzXD8GRJoDMPqdrvZVrBWkGcHvw7/YPA8skzsjkauJ8W
\n
\
7lzF5LCuHSS6OUmPT/+5hEHPin5PB3zhfszyC+Q7aujnIuPJMrKiMnUa+w1HWifM
\n
\
km49OOygQ9S6NQoVuEQede22+c76DlDL7yFghGoo1f0sKCE/9LW6SEnwI/bWv9eo
\n
\
nom5vOPrvQeJiYCQk+2DyWo8RdSxINtY+G9bPE4RXm+6ZgcXECPm9TYDIWpL36fC
\n
\
jvtGLs98woWFElOziBMp5Tb630GMcSI+q5ivHfJ3WS5NKLYLHBNK4iSFN0/dgAnB
\n
\
dj6GcKXKWnIBWn6ZM4o40pcM5KSRUUCLtA0ZmjJH4c4zx3X5fUxd+enwkf3e9VZO
\n
\
fNKC/+xfq6NfoPUPK9+UnchHpJaJw7RG5tZS+sWCz2xpQ1y3/o49xImNyM3wnpvB
\n
\
cRAZabqIHpZa9/DIUkELOtCzln6niqkjRgg3M/YCCNznwV+0RNgz87VtyTPerdef
\n
\
xrqn0+ROMF6ebVqIs6PPtuPkxnAJu7TMKXVB5rFnAewS24e6cIGFzeIA7810py3l
\n
\
cttVRsdOoego+fiy08eFE+aJIeYiINRGhqOBTsuqG4jIdpdKxPE=
\n
\
=KbsY
\n
\
-----END PGP SIGNATURE-----"
;
git_repository
*
repo
=
(
git_repository
*
)
payload
;
int
error
;
if
((
error
=
git_commit_create_buffer
(
&
commit_content
,
repo
,
author
,
committer
,
message_encoding
,
message
,
tree
,
parent_count
,
parents
))
<
0
)
goto
done
;
error
=
git_commit_create_with_signature
(
out
,
repo
,
commit_content
.
ptr
,
gpg_signature
,
NULL
);
done:
git_buf_dispose
(
&
commit_content
);
return
error
;
}
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__create_gpg_signed
(
void
)
{
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_rebase_operation
*
rebase_operation
;
git_oid
commit_id
,
expected_id
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_commit
*
commit
;
const
char
*
expected_commit_raw_header
=
"tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
gpgsig -----BEGIN PGP SIGNATURE-----
\n
\
\n
\
iQIzBAEBCgAdFiEEgVlDEfSlmKn0fvGgK++h5T2/ctIFAlwZcrAACgkQK++h5T2/
\n
\
ctIPVhAA42RyZhMdKl5Bm0KtQco2scsukIg2y7tjSwhti91zDu3HQgpusjjo0fQx
\n
\
ZzB+OrmlvQ9CDcGpZ0THIzXD8GRJoDMPqdrvZVrBWkGcHvw7/YPA8skzsjkauJ8W
\n
\
7lzF5LCuHSS6OUmPT/+5hEHPin5PB3zhfszyC+Q7aujnIuPJMrKiMnUa+w1HWifM
\n
\
km49OOygQ9S6NQoVuEQede22+c76DlDL7yFghGoo1f0sKCE/9LW6SEnwI/bWv9eo
\n
\
nom5vOPrvQeJiYCQk+2DyWo8RdSxINtY+G9bPE4RXm+6ZgcXECPm9TYDIWpL36fC
\n
\
jvtGLs98woWFElOziBMp5Tb630GMcSI+q5ivHfJ3WS5NKLYLHBNK4iSFN0/dgAnB
\n
\
dj6GcKXKWnIBWn6ZM4o40pcM5KSRUUCLtA0ZmjJH4c4zx3X5fUxd+enwkf3e9VZO
\n
\
fNKC/+xfq6NfoPUPK9+UnchHpJaJw7RG5tZS+sWCz2xpQ1y3/o49xImNyM3wnpvB
\n
\
cRAZabqIHpZa9/DIUkELOtCzln6niqkjRgg3M/YCCNznwV+0RNgz87VtyTPerdef
\n
\
xrqn0+ROMF6ebVqIs6PPtuPkxnAJu7TMKXVB5rFnAewS24e6cIGFzeIA7810py3l
\n
\
cttVRsdOoego+fiy08eFE+aJIeYiINRGhqOBTsuqG4jIdpdKxPE=
\n
\
=KbsY
\n
\
-----END PGP SIGNATURE-----
\n
"
;
rebase_opts
.
commit_create_cb
=
create_cb_signed_gpg
;
rebase_opts
.
payload
=
repo
;
cl_git_pass
(
git_reference_lookup
(
&
branch_ref
,
repo
,
"refs/heads/gravy"
));
cl_git_pass
(
git_reference_lookup
(
&
upstream_ref
,
repo
,
"refs/heads/veal"
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
branch_head
,
repo
,
branch_ref
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
upstream_head
,
repo
,
upstream_ref
));
cl_git_pass
(
git_rebase_init
(
&
rebase
,
repo
,
branch_head
,
upstream_head
,
NULL
,
&
rebase_opts
));
cl_git_pass
(
git_rebase_next
(
&
rebase_operation
,
rebase
));
cl_git_pass
(
git_rebase_commit
(
&
commit_id
,
rebase
,
NULL
,
signature
,
NULL
,
NULL
));
git_oid_fromstr
(
&
expected_id
,
"bf78348e45c8286f52b760f1db15cb6da030f2ef"
);
cl_assert_equal_oid
(
&
expected_id
,
&
commit_id
);
cl_git_pass
(
git_commit_lookup
(
&
commit
,
repo
,
&
commit_id
));
cl_assert_equal_s
(
expected_commit_raw_header
,
git_commit_raw_header
(
commit
));
cl_git_fail_with
(
GIT_ITEROVER
,
git_rebase_next
(
&
rebase_operation
,
rebase
));
git_reference_free
(
branch_ref
);
git_reference_free
(
upstream_ref
);
git_annotated_commit_free
(
branch_head
);
git_annotated_commit_free
(
upstream_head
);
git_commit_free
(
commit
);
git_rebase_free
(
rebase
);
}
static
int
create_cb_error
(
git_oid
*
out
,
const
git_signature
*
author
,
const
git_signature
*
committer
,
const
char
*
message_encoding
,
const
char
*
message
,
const
git_tree
*
tree
,
size_t
parent_count
,
const
git_commit
*
parents
[],
void
*
payload
)
{
GIT_UNUSED
(
out
);
GIT_UNUSED
(
author
);
GIT_UNUSED
(
committer
);
GIT_UNUSED
(
message_encoding
);
GIT_UNUSED
(
message
);
GIT_UNUSED
(
tree
);
GIT_UNUSED
(
parent_count
);
GIT_UNUSED
(
parents
);
GIT_UNUSED
(
payload
);
return
GIT_EUSER
;
}
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__create_propagates_error
(
void
)
{
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_oid
commit_id
;
git_rebase_operation
*
rebase_operation
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
rebase_opts
.
commit_create_cb
=
create_cb_error
;
cl_git_pass
(
git_reference_lookup
(
&
branch_ref
,
repo
,
"refs/heads/gravy"
));
cl_git_pass
(
git_reference_lookup
(
&
upstream_ref
,
repo
,
"refs/heads/veal"
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
branch_head
,
repo
,
branch_ref
));
cl_git_pass
(
git_annotated_commit_from_ref
(
&
upstream_head
,
repo
,
upstream_ref
));
cl_git_pass
(
git_rebase_init
(
&
rebase
,
repo
,
branch_head
,
upstream_head
,
NULL
,
&
rebase_opts
));
cl_git_pass
(
git_rebase_next
(
&
rebase_operation
,
rebase
));
cl_git_fail_with
(
GIT_EUSER
,
git_rebase_commit
(
&
commit_id
,
rebase
,
NULL
,
signature
,
NULL
,
NULL
));
git_reference_free
(
branch_ref
);
git_reference_free
(
upstream_ref
);
git_annotated_commit_free
(
branch_head
);
git_annotated_commit_free
(
upstream_head
);
git_rebase_free
(
rebase
);
}
#ifndef GIT_DEPRECATE_HARD
int
signing_cb_passthrough
(
int
signing_cb_passthrough
(
git_buf
*
signature
,
git_buf
*
signature
,
git_buf
*
signature_field
,
git_buf
*
signature_field
,
const
char
*
commit_content
,
const
char
*
commit_content
,
void
*
payload
)
void
*
payload
)
{
{
static
const
char
*
expected_commit_content
=
"\
tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
\n
\
Modification 3 to gravy
\n
"
;
cl_assert_equal_b
(
false
,
git_buf_is_allocated
(
signature
));
cl_assert_equal_b
(
false
,
git_buf_is_allocated
(
signature
));
cl_assert_equal_b
(
false
,
git_buf_is_allocated
(
signature_field
));
cl_assert_equal_b
(
false
,
git_buf_is_allocated
(
signature_field
));
cl_assert_equal_s
(
expected_commit_content
,
commit_content
);
cl_assert_equal_s
(
expected_commit_content
,
commit_content
);
cl_assert_equal_p
(
NULL
,
payload
);
cl_assert_equal_p
(
NULL
,
payload
);
return
GIT_PASSTHROUGH
;
return
GIT_PASSTHROUGH
;
}
}
#endif
/* !GIT_DEPRECATE_HARD */
/* git checkout gravy ; git rebase --merge veal */
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__passthrough_signing_cb
(
void
)
void
test_rebase_sign__passthrough_signing_cb
(
void
)
{
{
#ifndef GIT_DEPRECATE_HARD
git_rebase
*
rebase
;
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
...
@@ -80,15 +314,18 @@ committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000\n";
...
@@ -80,15 +314,18 @@ committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000\n";
git_annotated_commit_free
(
upstream_head
);
git_annotated_commit_free
(
upstream_head
);
git_commit_free
(
commit
);
git_commit_free
(
commit
);
git_rebase_free
(
rebase
);
git_rebase_free
(
rebase
);
#endif
/* !GIT_DEPRECATE_HARD */
}
}
#ifndef GIT_DEPRECATE_HARD
int
signing_cb_gpg
(
int
signing_cb_gpg
(
git_buf
*
signature
,
git_buf
*
signature
,
git_buf
*
signature_field
,
git_buf
*
signature_field
,
const
char
*
commit_content
,
const
char
*
commit_content
,
void
*
payload
)
void
*
payload
)
{
{
const
char
*
gpg_signature
=
"-----BEGIN PGP SIGNATURE-----
\n
\
const
char
*
gpg_signature
=
"\
-----BEGIN PGP SIGNATURE-----
\n
\
\n
\
\n
\
iQIzBAEBCgAdFiEEgVlDEfSlmKn0fvGgK++h5T2/ctIFAlwZcrAACgkQK++h5T2/
\n
\
iQIzBAEBCgAdFiEEgVlDEfSlmKn0fvGgK++h5T2/ctIFAlwZcrAACgkQK++h5T2/
\n
\
ctIPVhAA42RyZhMdKl5Bm0KtQco2scsukIg2y7tjSwhti91zDu3HQgpusjjo0fQx
\n
\
ctIPVhAA42RyZhMdKl5Bm0KtQco2scsukIg2y7tjSwhti91zDu3HQgpusjjo0fQx
\n
\
...
@@ -113,10 +350,12 @@ cttVRsdOoego+fiy08eFE+aJIeYiINRGhqOBTsuqG4jIdpdKxPE=\n\
...
@@ -113,10 +350,12 @@ cttVRsdOoego+fiy08eFE+aJIeYiINRGhqOBTsuqG4jIdpdKxPE=\n\
cl_git_pass
(
git_buf_set
(
signature
,
gpg_signature
,
strlen
(
gpg_signature
)
+
1
));
cl_git_pass
(
git_buf_set
(
signature
,
gpg_signature
,
strlen
(
gpg_signature
)
+
1
));
return
GIT_OK
;
return
GIT_OK
;
}
}
#endif
/* !GIT_DEPRECATE_HARD */
/* git checkout gravy ; git rebase --merge veal */
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__gpg_with_no_field
(
void
)
void
test_rebase_sign__gpg_with_no_field
(
void
)
{
{
#ifndef GIT_DEPRECATE_HARD
git_rebase
*
rebase
;
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
...
@@ -124,7 +363,8 @@ void test_rebase_sign__gpg_with_no_field(void)
...
@@ -124,7 +363,8 @@ void test_rebase_sign__gpg_with_no_field(void)
git_oid
commit_id
,
expected_id
;
git_oid
commit_id
,
expected_id
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_commit
*
commit
;
git_commit
*
commit
;
const
char
*
expected_commit_raw_header
=
"tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
const
char
*
expected_commit_raw_header
=
"\
tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
...
@@ -172,9 +412,11 @@ gpgsig -----BEGIN PGP SIGNATURE-----\n\
...
@@ -172,9 +412,11 @@ gpgsig -----BEGIN PGP SIGNATURE-----\n\
git_annotated_commit_free
(
upstream_head
);
git_annotated_commit_free
(
upstream_head
);
git_commit_free
(
commit
);
git_commit_free
(
commit
);
git_rebase_free
(
rebase
);
git_rebase_free
(
rebase
);
#endif
/* !GIT_DEPRECATE_HARD */
}
}
#ifndef GIT_DEPRECATE_HARD
int
signing_cb_magic_field
(
int
signing_cb_magic_field
(
git_buf
*
signature
,
git_buf
*
signature
,
git_buf
*
signature_field
,
git_buf
*
signature_field
,
...
@@ -196,10 +438,12 @@ int signing_cb_magic_field(
...
@@ -196,10 +438,12 @@ int signing_cb_magic_field(
return
GIT_OK
;
return
GIT_OK
;
}
}
#endif
/* !GIT_DEPRECATE_HARD */
/* git checkout gravy ; git rebase --merge veal */
/* git checkout gravy ; git rebase --merge veal */
void
test_rebase_sign__custom_signature_field
(
void
)
void
test_rebase_sign__custom_signature_field
(
void
)
{
{
#ifndef GIT_DEPRECATE_HARD
git_rebase
*
rebase
;
git_rebase
*
rebase
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_reference
*
branch_ref
,
*
upstream_ref
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
git_annotated_commit
*
branch_head
,
*
upstream_head
;
...
@@ -207,7 +451,8 @@ void test_rebase_sign__custom_signature_field(void)
...
@@ -207,7 +451,8 @@ void test_rebase_sign__custom_signature_field(void)
git_oid
commit_id
,
expected_id
;
git_oid
commit_id
,
expected_id
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_rebase_options
rebase_opts
=
GIT_REBASE_OPTIONS_INIT
;
git_commit
*
commit
;
git_commit
*
commit
;
const
char
*
expected_commit_raw_header
=
"tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
const
char
*
expected_commit_raw_header
=
"\
tree cd99b26250099fc38d30bfaed7797a7275ed3366
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
parent f87d14a4a236582a0278a916340a793714256864
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
author Edward Thomson <ethomson@edwardthomson.com> 1405625055 -0400
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
committer Rebaser <rebaser@rebaser.rb> 1405694510 +0000
\n
\
...
@@ -240,4 +485,5 @@ magicsig magic word: pretty please\n";
...
@@ -240,4 +485,5 @@ magicsig magic word: pretty please\n";
git_annotated_commit_free
(
upstream_head
);
git_annotated_commit_free
(
upstream_head
);
git_commit_free
(
commit
);
git_commit_free
(
commit
);
git_rebase_free
(
rebase
);
git_rebase_free
(
rebase
);
#endif
/* !GIT_DEPRECATE_HARD */
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment