You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

api_private_serv_test.go 6.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "context"
  6. "net/url"
  7. "testing"
  8. asymkey_model "code.gitea.io/gitea/models/asymkey"
  9. "code.gitea.io/gitea/models/perm"
  10. "code.gitea.io/gitea/modules/private"
  11. "github.com/stretchr/testify/assert"
  12. )
  13. func TestAPIPrivateNoServ(t *testing.T) {
  14. onGiteaRun(t, func(*testing.T, *url.URL) {
  15. ctx, cancel := context.WithCancel(context.Background())
  16. defer cancel()
  17. key, user, err := private.ServNoCommand(ctx, 1)
  18. assert.NoError(t, err)
  19. assert.Equal(t, int64(2), user.ID)
  20. assert.Equal(t, "user2", user.Name)
  21. assert.Equal(t, int64(1), key.ID)
  22. assert.Equal(t, "user2@localhost", key.Name)
  23. deployKey, err := asymkey_model.AddDeployKey(1, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", false)
  24. assert.NoError(t, err)
  25. key, user, err = private.ServNoCommand(ctx, deployKey.KeyID)
  26. assert.NoError(t, err)
  27. assert.Empty(t, user)
  28. assert.Equal(t, deployKey.KeyID, key.ID)
  29. assert.Equal(t, "test-deploy", key.Name)
  30. })
  31. }
  32. func TestAPIPrivateServ(t *testing.T) {
  33. onGiteaRun(t, func(*testing.T, *url.URL) {
  34. ctx, cancel := context.WithCancel(context.Background())
  35. defer cancel()
  36. // Can push to a repo we own
  37. results, extra := private.ServCommand(ctx, 1, "user2", "repo1", perm.AccessModeWrite, "git-upload-pack", "")
  38. assert.NoError(t, extra.Error)
  39. assert.False(t, results.IsWiki)
  40. assert.Zero(t, results.DeployKeyID)
  41. assert.Equal(t, int64(1), results.KeyID)
  42. assert.Equal(t, "user2@localhost", results.KeyName)
  43. assert.Equal(t, "user2", results.UserName)
  44. assert.Equal(t, int64(2), results.UserID)
  45. assert.Equal(t, "user2", results.OwnerName)
  46. assert.Equal(t, "repo1", results.RepoName)
  47. assert.Equal(t, int64(1), results.RepoID)
  48. // Cannot push to a private repo we're not associated with
  49. results, extra = private.ServCommand(ctx, 1, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
  50. assert.Error(t, extra.Error)
  51. assert.Empty(t, results)
  52. // Cannot pull from a private repo we're not associated with
  53. results, extra = private.ServCommand(ctx, 1, "user15", "big_test_private_1", perm.AccessModeRead, "git-upload-pack", "")
  54. assert.Error(t, extra.Error)
  55. assert.Empty(t, results)
  56. // Can pull from a public repo we're not associated with
  57. results, extra = private.ServCommand(ctx, 1, "user15", "big_test_public_1", perm.AccessModeRead, "git-upload-pack", "")
  58. assert.NoError(t, extra.Error)
  59. assert.False(t, results.IsWiki)
  60. assert.Zero(t, results.DeployKeyID)
  61. assert.Equal(t, int64(1), results.KeyID)
  62. assert.Equal(t, "user2@localhost", results.KeyName)
  63. assert.Equal(t, "user2", results.UserName)
  64. assert.Equal(t, int64(2), results.UserID)
  65. assert.Equal(t, "user15", results.OwnerName)
  66. assert.Equal(t, "big_test_public_1", results.RepoName)
  67. assert.Equal(t, int64(17), results.RepoID)
  68. // Cannot push to a public repo we're not associated with
  69. results, extra = private.ServCommand(ctx, 1, "user15", "big_test_public_1", perm.AccessModeWrite, "git-upload-pack", "")
  70. assert.Error(t, extra.Error)
  71. assert.Empty(t, results)
  72. // Add reading deploy key
  73. deployKey, err := asymkey_model.AddDeployKey(19, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", true)
  74. assert.NoError(t, err)
  75. // Can pull from repo we're a deploy key for
  76. results, extra = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeRead, "git-upload-pack", "")
  77. assert.NoError(t, extra.Error)
  78. assert.False(t, results.IsWiki)
  79. assert.NotZero(t, results.DeployKeyID)
  80. assert.Equal(t, deployKey.KeyID, results.KeyID)
  81. assert.Equal(t, "test-deploy", results.KeyName)
  82. assert.Equal(t, "user15", results.UserName)
  83. assert.Equal(t, int64(15), results.UserID)
  84. assert.Equal(t, "user15", results.OwnerName)
  85. assert.Equal(t, "big_test_private_1", results.RepoName)
  86. assert.Equal(t, int64(19), results.RepoID)
  87. // Cannot push to a private repo with reading key
  88. results, extra = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
  89. assert.Error(t, extra.Error)
  90. assert.Empty(t, results)
  91. // Cannot pull from a private repo we're not associated with
  92. results, extra = private.ServCommand(ctx, deployKey.ID, "user15", "big_test_private_2", perm.AccessModeRead, "git-upload-pack", "")
  93. assert.Error(t, extra.Error)
  94. assert.Empty(t, results)
  95. // Cannot pull from a public repo we're not associated with
  96. results, extra = private.ServCommand(ctx, deployKey.ID, "user15", "big_test_public_1", perm.AccessModeRead, "git-upload-pack", "")
  97. assert.Error(t, extra.Error)
  98. assert.Empty(t, results)
  99. // Add writing deploy key
  100. deployKey, err = asymkey_model.AddDeployKey(20, "test-deploy", "sk-ecdsa-sha2-nistp256@openssh.com AAAAInNrLWVjZHNhLXNoYTItbmlzdHAyNTZAb3BlbnNzaC5jb20AAAAIbmlzdHAyNTYAAABBBGXEEzWmm1dxb+57RoK5KVCL0w2eNv9cqJX2AGGVlkFsVDhOXHzsadS3LTK4VlEbbrDMJdoti9yM8vclA8IeRacAAAAEc3NoOg== nocomment", false)
  101. assert.NoError(t, err)
  102. // Cannot push to a private repo with reading key
  103. results, extra = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_1", perm.AccessModeWrite, "git-upload-pack", "")
  104. assert.Error(t, extra.Error)
  105. assert.Empty(t, results)
  106. // Can pull from repo we're a writing deploy key for
  107. results, extra = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_2", perm.AccessModeRead, "git-upload-pack", "")
  108. assert.NoError(t, extra.Error)
  109. assert.False(t, results.IsWiki)
  110. assert.NotZero(t, results.DeployKeyID)
  111. assert.Equal(t, deployKey.KeyID, results.KeyID)
  112. assert.Equal(t, "test-deploy", results.KeyName)
  113. assert.Equal(t, "user15", results.UserName)
  114. assert.Equal(t, int64(15), results.UserID)
  115. assert.Equal(t, "user15", results.OwnerName)
  116. assert.Equal(t, "big_test_private_2", results.RepoName)
  117. assert.Equal(t, int64(20), results.RepoID)
  118. // Can push to repo we're a writing deploy key for
  119. results, extra = private.ServCommand(ctx, deployKey.KeyID, "user15", "big_test_private_2", perm.AccessModeWrite, "git-upload-pack", "")
  120. assert.NoError(t, extra.Error)
  121. assert.False(t, results.IsWiki)
  122. assert.NotZero(t, results.DeployKeyID)
  123. assert.Equal(t, deployKey.KeyID, results.KeyID)
  124. assert.Equal(t, "test-deploy", results.KeyName)
  125. assert.Equal(t, "user15", results.UserName)
  126. assert.Equal(t, int64(15), results.UserID)
  127. assert.Equal(t, "user15", results.OwnerName)
  128. assert.Equal(t, "big_test_private_2", results.RepoName)
  129. assert.Equal(t, int64(20), results.RepoID)
  130. })
  131. }