gitea源码

commit_test.go 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package git
  4. import (
  5. "os"
  6. "path/filepath"
  7. "strings"
  8. "testing"
  9. "github.com/stretchr/testify/assert"
  10. "github.com/stretchr/testify/require"
  11. )
  12. func TestCommitsCount(t *testing.T) {
  13. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  14. commitsCount, err := CommitsCount(t.Context(),
  15. CommitsCountOptions{
  16. RepoPath: bareRepo1Path,
  17. Revision: []string{"8006ff9adbf0cb94da7dad9e537e53817f9fa5c0"},
  18. })
  19. assert.NoError(t, err)
  20. assert.Equal(t, int64(3), commitsCount)
  21. }
  22. func TestCommitsCountWithoutBase(t *testing.T) {
  23. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  24. commitsCount, err := CommitsCount(t.Context(),
  25. CommitsCountOptions{
  26. RepoPath: bareRepo1Path,
  27. Not: "master",
  28. Revision: []string{"branch1"},
  29. })
  30. assert.NoError(t, err)
  31. assert.Equal(t, int64(2), commitsCount)
  32. }
  33. func TestGetFullCommitID(t *testing.T) {
  34. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  35. id, err := GetFullCommitID(t.Context(), bareRepo1Path, "8006ff9a")
  36. assert.NoError(t, err)
  37. assert.Equal(t, "8006ff9adbf0cb94da7dad9e537e53817f9fa5c0", id)
  38. }
  39. func TestGetFullCommitIDError(t *testing.T) {
  40. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  41. id, err := GetFullCommitID(t.Context(), bareRepo1Path, "unknown")
  42. assert.Empty(t, id)
  43. if assert.Error(t, err) {
  44. assert.EqualError(t, err, "object does not exist [id: unknown, rel_path: ]")
  45. }
  46. }
  47. func TestCommitFromReader(t *testing.T) {
  48. commitString := `tree f1a6cb52b2d16773290cefe49ad0684b50a4f930
  49. parent 37991dec2c8e592043f47155ce4808d4580f9123
  50. author silverwind <me@silverwind.io> 1563741793 +0200
  51. committer silverwind <me@silverwind.io> 1563741793 +0200
  52. gpgsig -----BEGIN PGP SIGNATURE-----
  53. ` + " " + `
  54. iQIzBAABCAAdFiEEWPb2jX6FS2mqyJRQLmK0HJOGlEMFAl00zmEACgkQLmK0HJOG
  55. lEMDFBAAhQKKqLD1VICygJMEB8t1gBmNLgvziOLfpX4KPWdPtBk3v/QJ7OrfMrVK
  56. xlC4ZZyx6yMm1Q7GzmuWykmZQJ9HMaHJ49KAbh5MMjjV/+OoQw9coIdo8nagRUld
  57. vX8QHzNZ6Agx77xHuDJZgdHKpQK3TrMDsxzoYYMvlqoLJIDXE1Sp7KYNy12nhdRg
  58. R6NXNmW8oMZuxglkmUwayMiPS+N4zNYqv0CXYzlEqCOgq9MJUcAMHt+KpiST+sm6
  59. FWkJ9D+biNPyQ9QKf1AE4BdZia4lHfPYU/C/DEL/a5xQuuop/zMQZoGaIA4p2zGQ
  60. /maqYxEIM/yRBQpT1jlODKPJrMEgx7SgY2hRU47YZ4fj6350fb6fNBtiiMAfJbjL
  61. S3Gh85E9fm3hJaNSPKAaJFYL1Ya2svuWfgHj677C56UcmYis7fhiiy1aJuYdHnSm
  62. sD53z/f0J+We4VZjY+pidvA9BGZPFVdR3wd3xGs8/oH6UWaLJAMGkLG6dDb3qDLm
  63. 1LFZwsX8sdD32i1SiWanYQYSYMyFWr0awi4xdoMtYCL7uKBYtwtPyvq3cj4IrJlb
  64. mfeFhT57UbE4qukTDIQ0Y0WM40UYRTakRaDY7ubhXgLgx09Cnp9XTVMsHgT6j9/i
  65. 1pxsB104XLWjQHTjr1JtiaBQEwFh9r2OKTcpvaLcbNtYpo7CzOs=
  66. =FRsO
  67. -----END PGP SIGNATURE-----
  68. empty commit`
  69. sha := &Sha1Hash{0xfe, 0xaf, 0x4b, 0xa6, 0xbc, 0x63, 0x5f, 0xec, 0x44, 0x2f, 0x46, 0xdd, 0xd4, 0x51, 0x24, 0x16, 0xec, 0x43, 0xc2, 0xc2}
  70. gitRepo, err := OpenRepository(t.Context(), filepath.Join(testReposDir, "repo1_bare"))
  71. assert.NoError(t, err)
  72. assert.NotNil(t, gitRepo)
  73. defer gitRepo.Close()
  74. commitFromReader, err := CommitFromReader(gitRepo, sha, strings.NewReader(commitString))
  75. assert.NoError(t, err)
  76. require.NotNil(t, commitFromReader)
  77. assert.EqualValues(t, sha, commitFromReader.ID)
  78. assert.Equal(t, `-----BEGIN PGP SIGNATURE-----
  79. iQIzBAABCAAdFiEEWPb2jX6FS2mqyJRQLmK0HJOGlEMFAl00zmEACgkQLmK0HJOG
  80. lEMDFBAAhQKKqLD1VICygJMEB8t1gBmNLgvziOLfpX4KPWdPtBk3v/QJ7OrfMrVK
  81. xlC4ZZyx6yMm1Q7GzmuWykmZQJ9HMaHJ49KAbh5MMjjV/+OoQw9coIdo8nagRUld
  82. vX8QHzNZ6Agx77xHuDJZgdHKpQK3TrMDsxzoYYMvlqoLJIDXE1Sp7KYNy12nhdRg
  83. R6NXNmW8oMZuxglkmUwayMiPS+N4zNYqv0CXYzlEqCOgq9MJUcAMHt+KpiST+sm6
  84. FWkJ9D+biNPyQ9QKf1AE4BdZia4lHfPYU/C/DEL/a5xQuuop/zMQZoGaIA4p2zGQ
  85. /maqYxEIM/yRBQpT1jlODKPJrMEgx7SgY2hRU47YZ4fj6350fb6fNBtiiMAfJbjL
  86. S3Gh85E9fm3hJaNSPKAaJFYL1Ya2svuWfgHj677C56UcmYis7fhiiy1aJuYdHnSm
  87. sD53z/f0J+We4VZjY+pidvA9BGZPFVdR3wd3xGs8/oH6UWaLJAMGkLG6dDb3qDLm
  88. 1LFZwsX8sdD32i1SiWanYQYSYMyFWr0awi4xdoMtYCL7uKBYtwtPyvq3cj4IrJlb
  89. mfeFhT57UbE4qukTDIQ0Y0WM40UYRTakRaDY7ubhXgLgx09Cnp9XTVMsHgT6j9/i
  90. 1pxsB104XLWjQHTjr1JtiaBQEwFh9r2OKTcpvaLcbNtYpo7CzOs=
  91. =FRsO
  92. -----END PGP SIGNATURE-----`, commitFromReader.Signature.Signature)
  93. assert.Equal(t, `tree f1a6cb52b2d16773290cefe49ad0684b50a4f930
  94. parent 37991dec2c8e592043f47155ce4808d4580f9123
  95. author silverwind <me@silverwind.io> 1563741793 +0200
  96. committer silverwind <me@silverwind.io> 1563741793 +0200
  97. empty commit`, commitFromReader.Signature.Payload)
  98. assert.Equal(t, "silverwind <me@silverwind.io>", commitFromReader.Author.String())
  99. commitFromReader2, err := CommitFromReader(gitRepo, sha, strings.NewReader(commitString+"\n\n"))
  100. assert.NoError(t, err)
  101. commitFromReader.CommitMessage += "\n\n"
  102. commitFromReader.Signature.Payload += "\n\n"
  103. assert.Equal(t, commitFromReader, commitFromReader2)
  104. }
  105. func TestCommitWithEncodingFromReader(t *testing.T) {
  106. commitString := `tree ca3fad42080dd1a6d291b75acdfc46e5b9b307e5
  107. parent 47b24e7ab977ed31c5a39989d570847d6d0052af
  108. author KN4CK3R <admin@oldschoolhack.me> 1711702962 +0100
  109. committer KN4CK3R <admin@oldschoolhack.me> 1711702962 +0100
  110. encoding ISO-8859-1
  111. gpgsig -----BEGIN PGP SIGNATURE-----
  112. <SPACE>
  113. iQGzBAABCgAdFiEE9HRrbqvYxPT8PXbefPSEkrowAa8FAmYGg7IACgkQfPSEkrow
  114. Aa9olwv+P0HhtCM6CRvlUmPaqswRsDPNR4i66xyXGiSxdI9V5oJL7HLiQIM7KrFR
  115. gizKa2COiGtugv8fE+TKqXKaJx6uJUJEjaBd8E9Af9PrAzjWj+A84lU6/PgPS8hq
  116. zOfZraLOEWRH4tZcS+u2yFLu3ez2Wqh1xW5LNy7xqEedMXEFD1HwSJ0+pjacNkzr
  117. frp6Asyt7xRI6YmgFJZJoRsS3Ktr6rtKeRL2IErSQQyorOqj6gKrglhrhfG/114j
  118. FKB1v4or0WZ1DE8iP2SJZ3n+/K1IuWAINh7MVdb7PndfBPEa+IL+ucNk5uzEE8Jd
  119. G8smGxXUeFEt2cP1dj2W8EgAxuA9sTnH9dqI5aRqy5ifDjuya7Emm8sdOUvtGdmn
  120. SONRzusmu5n3DgV956REL7x62h7JuqmBz/12HZkr0z0zgXkcZ04q08pSJATX5N1F
  121. yN+tWxTsWg+zhDk96d5Esdo9JMjcFvPv0eioo30GAERaz1hoD7zCMT4jgUFTQwgz
  122. jw4YcO5u
  123. =r3UU
  124. -----END PGP SIGNATURE-----
  125. ISO-8859-1`
  126. commitString = strings.ReplaceAll(commitString, "<SPACE>", " ")
  127. sha := &Sha1Hash{0xfe, 0xaf, 0x4b, 0xa6, 0xbc, 0x63, 0x5f, 0xec, 0x44, 0x2f, 0x46, 0xdd, 0xd4, 0x51, 0x24, 0x16, 0xec, 0x43, 0xc2, 0xc2}
  128. gitRepo, err := OpenRepository(t.Context(), filepath.Join(testReposDir, "repo1_bare"))
  129. assert.NoError(t, err)
  130. assert.NotNil(t, gitRepo)
  131. defer gitRepo.Close()
  132. commitFromReader, err := CommitFromReader(gitRepo, sha, strings.NewReader(commitString))
  133. assert.NoError(t, err)
  134. require.NotNil(t, commitFromReader)
  135. assert.EqualValues(t, sha, commitFromReader.ID)
  136. assert.Equal(t, `-----BEGIN PGP SIGNATURE-----
  137. iQGzBAABCgAdFiEE9HRrbqvYxPT8PXbefPSEkrowAa8FAmYGg7IACgkQfPSEkrow
  138. Aa9olwv+P0HhtCM6CRvlUmPaqswRsDPNR4i66xyXGiSxdI9V5oJL7HLiQIM7KrFR
  139. gizKa2COiGtugv8fE+TKqXKaJx6uJUJEjaBd8E9Af9PrAzjWj+A84lU6/PgPS8hq
  140. zOfZraLOEWRH4tZcS+u2yFLu3ez2Wqh1xW5LNy7xqEedMXEFD1HwSJ0+pjacNkzr
  141. frp6Asyt7xRI6YmgFJZJoRsS3Ktr6rtKeRL2IErSQQyorOqj6gKrglhrhfG/114j
  142. FKB1v4or0WZ1DE8iP2SJZ3n+/K1IuWAINh7MVdb7PndfBPEa+IL+ucNk5uzEE8Jd
  143. G8smGxXUeFEt2cP1dj2W8EgAxuA9sTnH9dqI5aRqy5ifDjuya7Emm8sdOUvtGdmn
  144. SONRzusmu5n3DgV956REL7x62h7JuqmBz/12HZkr0z0zgXkcZ04q08pSJATX5N1F
  145. yN+tWxTsWg+zhDk96d5Esdo9JMjcFvPv0eioo30GAERaz1hoD7zCMT4jgUFTQwgz
  146. jw4YcO5u
  147. =r3UU
  148. -----END PGP SIGNATURE-----`, commitFromReader.Signature.Signature)
  149. assert.Equal(t, `tree ca3fad42080dd1a6d291b75acdfc46e5b9b307e5
  150. parent 47b24e7ab977ed31c5a39989d570847d6d0052af
  151. author KN4CK3R <admin@oldschoolhack.me> 1711702962 +0100
  152. committer KN4CK3R <admin@oldschoolhack.me> 1711702962 +0100
  153. encoding ISO-8859-1
  154. ISO-8859-1`, commitFromReader.Signature.Payload)
  155. assert.Equal(t, "KN4CK3R <admin@oldschoolhack.me>", commitFromReader.Author.String())
  156. commitFromReader2, err := CommitFromReader(gitRepo, sha, strings.NewReader(commitString+"\n\n"))
  157. assert.NoError(t, err)
  158. commitFromReader.CommitMessage += "\n\n"
  159. commitFromReader.Signature.Payload += "\n\n"
  160. assert.Equal(t, commitFromReader, commitFromReader2)
  161. }
  162. func TestHasPreviousCommit(t *testing.T) {
  163. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  164. repo, err := OpenRepository(t.Context(), bareRepo1Path)
  165. assert.NoError(t, err)
  166. defer repo.Close()
  167. commit, err := repo.GetCommit("8006ff9adbf0cb94da7dad9e537e53817f9fa5c0")
  168. assert.NoError(t, err)
  169. parentSHA := MustIDFromString("8d92fc957a4d7cfd98bc375f0b7bb189a0d6c9f2")
  170. notParentSHA := MustIDFromString("2839944139e0de9737a044f78b0e4b40d989a9e3")
  171. haz, err := commit.HasPreviousCommit(parentSHA)
  172. assert.NoError(t, err)
  173. assert.True(t, haz)
  174. hazNot, err := commit.HasPreviousCommit(notParentSHA)
  175. assert.NoError(t, err)
  176. assert.False(t, hazNot)
  177. selfNot, err := commit.HasPreviousCommit(commit.ID)
  178. assert.NoError(t, err)
  179. assert.False(t, selfNot)
  180. }
  181. func TestParseCommitFileStatus(t *testing.T) {
  182. type testcase struct {
  183. output string
  184. added []string
  185. removed []string
  186. modified []string
  187. }
  188. kases := []testcase{
  189. {
  190. // Merge commit
  191. output: "MM\x00options/locale/locale_en-US.ini\x00",
  192. modified: []string{
  193. "options/locale/locale_en-US.ini",
  194. },
  195. added: []string{},
  196. removed: []string{},
  197. },
  198. {
  199. // Spaces commit
  200. output: "D\x00b\x00D\x00b b/b\x00A\x00b b/b b/b b/b\x00A\x00b b/b b/b b/b b/b\x00",
  201. removed: []string{
  202. "b",
  203. "b b/b",
  204. },
  205. modified: []string{},
  206. added: []string{
  207. "b b/b b/b b/b",
  208. "b b/b b/b b/b b/b",
  209. },
  210. },
  211. {
  212. // larger commit
  213. output: "M\x00go.mod\x00M\x00go.sum\x00M\x00modules/ssh/ssh.go\x00M\x00vendor/github.com/gliderlabs/ssh/circle.yml\x00M\x00vendor/github.com/gliderlabs/ssh/context.go\x00A\x00vendor/github.com/gliderlabs/ssh/go.mod\x00A\x00vendor/github.com/gliderlabs/ssh/go.sum\x00M\x00vendor/github.com/gliderlabs/ssh/server.go\x00M\x00vendor/github.com/gliderlabs/ssh/session.go\x00M\x00vendor/github.com/gliderlabs/ssh/ssh.go\x00M\x00vendor/golang.org/x/sys/unix/mkerrors.sh\x00M\x00vendor/golang.org/x/sys/unix/syscall_darwin.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_freebsd_arm64.go\x00M\x00vendor/golang.org/x/sys/unix/zerrors_linux.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_freebsd_386.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_freebsd_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_freebsd_arm.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_freebsd_arm64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go\x00M\x00vendor/golang.org/x/sys/unix/ztypes_netbsd_arm64.go\x00M\x00vendor/modules.txt\x00",
  214. modified: []string{
  215. "go.mod",
  216. "go.sum",
  217. "modules/ssh/ssh.go",
  218. "vendor/github.com/gliderlabs/ssh/circle.yml",
  219. "vendor/github.com/gliderlabs/ssh/context.go",
  220. "vendor/github.com/gliderlabs/ssh/server.go",
  221. "vendor/github.com/gliderlabs/ssh/session.go",
  222. "vendor/github.com/gliderlabs/ssh/ssh.go",
  223. "vendor/golang.org/x/sys/unix/mkerrors.sh",
  224. "vendor/golang.org/x/sys/unix/syscall_darwin.go",
  225. "vendor/golang.org/x/sys/unix/zerrors_darwin_amd64.go",
  226. "vendor/golang.org/x/sys/unix/zerrors_darwin_arm64.go",
  227. "vendor/golang.org/x/sys/unix/zerrors_freebsd_386.go",
  228. "vendor/golang.org/x/sys/unix/zerrors_freebsd_amd64.go",
  229. "vendor/golang.org/x/sys/unix/zerrors_freebsd_arm.go",
  230. "vendor/golang.org/x/sys/unix/zerrors_freebsd_arm64.go",
  231. "vendor/golang.org/x/sys/unix/zerrors_linux.go",
  232. "vendor/golang.org/x/sys/unix/ztypes_darwin_amd64.go",
  233. "vendor/golang.org/x/sys/unix/ztypes_darwin_arm64.go",
  234. "vendor/golang.org/x/sys/unix/ztypes_dragonfly_amd64.go",
  235. "vendor/golang.org/x/sys/unix/ztypes_freebsd_386.go",
  236. "vendor/golang.org/x/sys/unix/ztypes_freebsd_amd64.go",
  237. "vendor/golang.org/x/sys/unix/ztypes_freebsd_arm.go",
  238. "vendor/golang.org/x/sys/unix/ztypes_freebsd_arm64.go",
  239. "vendor/golang.org/x/sys/unix/ztypes_netbsd_386.go",
  240. "vendor/golang.org/x/sys/unix/ztypes_netbsd_amd64.go",
  241. "vendor/golang.org/x/sys/unix/ztypes_netbsd_arm.go",
  242. "vendor/golang.org/x/sys/unix/ztypes_netbsd_arm64.go",
  243. "vendor/modules.txt",
  244. },
  245. added: []string{
  246. "vendor/github.com/gliderlabs/ssh/go.mod",
  247. "vendor/github.com/gliderlabs/ssh/go.sum",
  248. },
  249. removed: []string{},
  250. },
  251. {
  252. // git 1.7.2 adds an unnecessary \x00 on merge commit
  253. output: "\x00MM\x00options/locale/locale_en-US.ini\x00",
  254. modified: []string{
  255. "options/locale/locale_en-US.ini",
  256. },
  257. added: []string{},
  258. removed: []string{},
  259. },
  260. {
  261. // git 1.7.2 adds an unnecessary \n on normal commit
  262. output: "\nD\x00b\x00D\x00b b/b\x00A\x00b b/b b/b b/b\x00A\x00b b/b b/b b/b b/b\x00",
  263. removed: []string{
  264. "b",
  265. "b b/b",
  266. },
  267. modified: []string{},
  268. added: []string{
  269. "b b/b b/b b/b",
  270. "b b/b b/b b/b b/b",
  271. },
  272. },
  273. }
  274. for _, kase := range kases {
  275. fileStatus := NewCommitFileStatus()
  276. parseCommitFileStatus(fileStatus, strings.NewReader(kase.output))
  277. assert.Equal(t, kase.added, fileStatus.Added)
  278. assert.Equal(t, kase.removed, fileStatus.Removed)
  279. assert.Equal(t, kase.modified, fileStatus.Modified)
  280. }
  281. }
  282. func TestGetCommitFileStatusMerges(t *testing.T) {
  283. bareRepo1Path := filepath.Join(testReposDir, "repo6_merge")
  284. commitFileStatus, err := GetCommitFileStatus(t.Context(), bareRepo1Path, "022f4ce6214973e018f02bf363bf8a2e3691f699")
  285. assert.NoError(t, err)
  286. expected := CommitFileStatus{
  287. []string{
  288. "add_file.txt",
  289. },
  290. []string{
  291. "to_remove.txt",
  292. },
  293. []string{
  294. "to_modify.txt",
  295. },
  296. }
  297. assert.Equal(t, expected.Added, commitFileStatus.Added)
  298. assert.Equal(t, expected.Removed, commitFileStatus.Removed)
  299. assert.Equal(t, expected.Modified, commitFileStatus.Modified)
  300. }
  301. func Test_GetCommitBranchStart(t *testing.T) {
  302. bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
  303. repo, err := OpenRepository(t.Context(), bareRepo1Path)
  304. assert.NoError(t, err)
  305. defer repo.Close()
  306. commit, err := repo.GetBranchCommit("branch1")
  307. assert.NoError(t, err)
  308. assert.Equal(t, "2839944139e0de9737a044f78b0e4b40d989a9e3", commit.ID.String())
  309. startCommitID, err := repo.GetCommitBranchStart(os.Environ(), "branch1", commit.ID.String())
  310. assert.NoError(t, err)
  311. assert.NotEmpty(t, startCommitID)
  312. assert.Equal(t, "95bb4d39648ee7e325106df01a621c530863a653", startCommitID)
  313. }