aboutsummaryrefslogtreecommitdiff
path: root/object/signed/commit/parse_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'object/signed/commit/parse_test.go')
-rw-r--r--object/signed/commit/parse_test.go170
1 files changed, 170 insertions, 0 deletions
diff --git a/object/signed/commit/parse_test.go b/object/signed/commit/parse_test.go
new file mode 100644
index 00000000..c0e86e47
--- /dev/null
+++ b/object/signed/commit/parse_test.go
@@ -0,0 +1,170 @@
+package commit_test
+
+import (
+ "slices"
+ "testing"
+
+ "lindenii.org/go/furgit/object/id"
+ "lindenii.org/go/furgit/object/signed/commit"
+)
+
+func TestParseUpstreamMultiplySignedCommit(t *testing.T) {
+ t.Parallel()
+
+ // t/t7510-signed-commit.sh
+ body := []byte("" +
+ "tree 0cfbf08886fca9a91cb753ec8734c84fcbe52c9f\n" +
+ "parent 9da738312d24ef0a29be2c8c2b6fc5cf7085a293\n" +
+ "author A U Thor <author@example.com> 1112912653 -0700\n" +
+ "committer C O Mitter <committer@example.com> 1112912653 -0700\n" +
+ "gpgsig -----BEGIN PGP SIGNATURE-----\n" +
+ " \n" +
+ " iHQEABECADQWIQRz11h0S+chaY7FTocTtvUezd5DDQUCX/uBDRYcY29tbWl0dGVy\n" +
+ " QGV4YW1wbGUuY29tAAoJEBO29R7N3kMNd+8AoK1I8mhLHviPH+q2I5fIVgPsEtYC\n" +
+ " AKCTqBh+VabJceXcGIZuF0Ry+udbBQ==\n" +
+ " =tQ0N\n" +
+ " -----END PGP SIGNATURE-----\n" +
+ "gpgsig-sha256 -----BEGIN PGP SIGNATURE-----\n" +
+ " \n" +
+ " iHQEABECADQWIQRz11h0S+chaY7FTocTtvUezd5DDQUCX/uBIBYcY29tbWl0dGVy\n" +
+ " QGV4YW1wbGUuY29tAAoJEBO29R7N3kMN/NEAn0XO9RYSBj2dFyozi0JKSbssYMtO\n" +
+ " AJwKCQ1BQOtuwz//IjU8TiS+6S4iUw==\n" +
+ " =pIwP\n" +
+ " -----END PGP SIGNATURE-----\n" +
+ "\n" +
+ "second\n")
+
+ parsed, err := commit.Parse(body)
+ if err != nil {
+ t.Fatalf("Parse: %v", err)
+ }
+
+ gotPayload := string(parsed.AppendPayload(nil))
+
+ wantPayload := "" +
+ "tree 0cfbf08886fca9a91cb753ec8734c84fcbe52c9f\n" +
+ "parent 9da738312d24ef0a29be2c8c2b6fc5cf7085a293\n" +
+ "author A U Thor <author@example.com> 1112912653 -0700\n" +
+ "committer C O Mitter <committer@example.com> 1112912653 -0700\n" +
+ "\n" +
+ "second\n"
+ if gotPayload != wantPayload {
+ t.Fatalf("payload mismatch:\n got: %q\nwant: %q", gotPayload, wantPayload)
+ }
+
+ gotSHA1, ok := parsed.AppendSignature(nil, id.ObjectFormatSHA1)
+ if !ok {
+ t.Fatal("missing sha1 signature")
+ }
+
+ wantSHA1 := "" +
+ "-----BEGIN PGP SIGNATURE-----\n" +
+ "\n" +
+ "iHQEABECADQWIQRz11h0S+chaY7FTocTtvUezd5DDQUCX/uBDRYcY29tbWl0dGVy\n" +
+ "QGV4YW1wbGUuY29tAAoJEBO29R7N3kMNd+8AoK1I8mhLHviPH+q2I5fIVgPsEtYC\n" +
+ "AKCTqBh+VabJceXcGIZuF0Ry+udbBQ==\n" +
+ "=tQ0N\n" +
+ "-----END PGP SIGNATURE-----\n"
+ if string(gotSHA1) != wantSHA1 {
+ t.Fatalf("sha1 signature mismatch:\n got: %q\nwant: %q", string(gotSHA1), wantSHA1)
+ }
+
+ gotSHA256, ok := parsed.AppendSignature(nil, id.ObjectFormatSHA256)
+ if !ok {
+ t.Fatal("missing sha256 signature")
+ }
+
+ wantSHA256 := "" +
+ "-----BEGIN PGP SIGNATURE-----\n" +
+ "\n" +
+ "iHQEABECADQWIQRz11h0S+chaY7FTocTtvUezd5DDQUCX/uBIBYcY29tbWl0dGVy\n" +
+ "QGV4YW1wbGUuY29tAAoJEBO29R7N3kMN/NEAn0XO9RYSBj2dFyozi0JKSbssYMtO\n" +
+ "AJwKCQ1BQOtuwz//IjU8TiS+6S4iUw==\n" +
+ "=pIwP\n" +
+ "-----END PGP SIGNATURE-----\n"
+ if string(gotSHA256) != wantSHA256 {
+ t.Fatalf("sha256 signature mismatch:\n got: %q\nwant: %q", string(gotSHA256), wantSHA256)
+ }
+
+ gotObjectFormats := parsed.ObjectFormats()
+
+ wantObjectFormats := []id.ObjectFormat{
+ id.ObjectFormatSHA1,
+ id.ObjectFormatSHA256,
+ }
+ if !slices.Equal(gotObjectFormats, wantObjectFormats) {
+ t.Fatalf("ObjectFormats() = %v, want %v", gotObjectFormats, wantObjectFormats)
+ }
+}
+
+func TestParseStripsUnknownGpgsigHeadersFromPayload(t *testing.T) {
+ t.Parallel()
+
+ body := []byte("" +
+ "tree deadbeef\n" +
+ "gpgsig-future header\n" +
+ " continued\n" +
+ "\n" +
+ "message\n")
+
+ parsed, err := commit.Parse(body)
+ if err != nil {
+ t.Fatalf("Parse: %v", err)
+ }
+
+ gotPayload := string(parsed.AppendPayload(nil))
+
+ wantPayload := "" +
+ "tree deadbeef\n" +
+ "\n" +
+ "message\n"
+ if gotPayload != wantPayload {
+ t.Fatalf("payload mismatch:\n got: %q\nwant: %q", gotPayload, wantPayload)
+ }
+
+ if gotObjectFormats := parsed.ObjectFormats(); len(gotObjectFormats) != 0 {
+ t.Fatalf("ObjectFormats() = %v, want none", gotObjectFormats)
+ }
+}
+
+func TestParseAllowsDuplicateSignatureHeaders(t *testing.T) {
+ t.Parallel()
+
+ body := []byte("" +
+ "tree deadbeef\n" +
+ "gpgsig one\n" +
+ " two\n" +
+ "gpgsig three\n" +
+ " four\n" +
+ "\n" +
+ "message\n")
+
+ parsed, err := commit.Parse(body)
+ if err != nil {
+ t.Fatalf("Parse: %v", err)
+ }
+
+ gotPayload := string(parsed.AppendPayload(nil))
+
+ wantPayload := "" +
+ "tree deadbeef\n" +
+ "\n" +
+ "message\n"
+ if gotPayload != wantPayload {
+ t.Fatalf("payload mismatch:\n got: %q\nwant: %q", gotPayload, wantPayload)
+ }
+
+ gotSignature, ok := parsed.AppendSignature(nil, id.ObjectFormatSHA1)
+ if !ok {
+ t.Fatal("missing sha1 signature")
+ }
+
+ wantSignature := "" +
+ "one\n" +
+ "two\n" +
+ "three\n" +
+ "four\n"
+ if string(gotSignature) != wantSignature {
+ t.Fatalf("signature mismatch:\n got: %q\nwant: %q", string(gotSignature), wantSignature)
+ }
+}