helpers_test.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. package populate_source_config_display_name_test
  2. import (
  3. "fmt"
  4. "os"
  5. "testing"
  6. "time"
  7. "github.com/porter-dev/porter/api/server/shared/config/env"
  8. "github.com/porter-dev/porter/api/types"
  9. "github.com/porter-dev/porter/internal/adapter"
  10. "github.com/porter-dev/porter/internal/encryption"
  11. "github.com/porter-dev/porter/internal/features"
  12. "github.com/porter-dev/porter/internal/models"
  13. ints "github.com/porter-dev/porter/internal/models/integrations"
  14. "github.com/porter-dev/porter/internal/repository"
  15. "github.com/porter-dev/porter/internal/repository/gorm"
  16. _gorm "gorm.io/gorm"
  17. )
  18. type tester struct {
  19. Key *[32]byte
  20. DB *_gorm.DB
  21. repo repository.Repository
  22. dbFileName string
  23. key *[32]byte
  24. initUsers []*models.User
  25. initProjects []*models.Project
  26. initClusters []*models.Cluster
  27. initKIs []*ints.KubeIntegration
  28. initStacks []*models.Stack
  29. }
  30. func setupTestEnv(tester *tester, t *testing.T) {
  31. t.Helper()
  32. db, err := adapter.New(&env.DBConf{
  33. EncryptionKey: "__random_strong_encryption_key__",
  34. SQLLite: true,
  35. SQLLitePath: tester.dbFileName,
  36. })
  37. if err != nil {
  38. t.Fatalf("%\n", err)
  39. }
  40. err = db.AutoMigrate(
  41. &models.Project{},
  42. &models.User{},
  43. &models.Cluster{},
  44. &models.Stack{},
  45. &models.StackEnvGroup{},
  46. &models.StackSourceConfig{},
  47. &models.StackRevision{},
  48. &models.StackResource{},
  49. &ints.KubeIntegration{},
  50. &ints.ClusterTokenCache{},
  51. )
  52. if err != nil {
  53. t.Fatalf("%v\n", err)
  54. }
  55. var key [32]byte
  56. for i, b := range []byte("__random_strong_encryption_key__") {
  57. key[i] = b
  58. }
  59. tester.key = &key
  60. tester.Key = &key
  61. tester.DB = db
  62. tester.repo = gorm.NewRepository(db, &key, nil)
  63. }
  64. func cleanup(tester *tester, t *testing.T) {
  65. t.Helper()
  66. // remove the created file file
  67. os.Remove(tester.dbFileName)
  68. }
  69. func initUser(tester *tester, t *testing.T) {
  70. t.Helper()
  71. user := &models.User{
  72. Email: "example@example.com",
  73. Password: "hello1234",
  74. }
  75. user, err := tester.repo.User().CreateUser(user)
  76. if err != nil {
  77. t.Fatalf("%v\n", err)
  78. }
  79. tester.initUsers = append(tester.initUsers, user)
  80. }
  81. func initCluster(tester *tester, t *testing.T) {
  82. t.Helper()
  83. if len(tester.initProjects) == 0 {
  84. initProject(tester, t)
  85. }
  86. if len(tester.initKIs) == 0 {
  87. initKubeIntegration(tester, t)
  88. }
  89. cluster := &models.Cluster{
  90. ProjectID: tester.initProjects[0].ID,
  91. Name: "cluster-test",
  92. Server: "https://localhost",
  93. KubeIntegrationID: tester.initKIs[0].ID,
  94. CertificateAuthorityData: []byte("-----BEGIN"),
  95. TokenCache: ints.ClusterTokenCache{
  96. TokenCache: ints.TokenCache{
  97. Token: []byte("token-1"),
  98. Expiry: time.Now().Add(-1 * time.Hour),
  99. },
  100. },
  101. }
  102. cluster, err := tester.repo.Cluster().CreateCluster(cluster, &features.Client{})
  103. if err != nil {
  104. t.Fatalf("%v\n", err)
  105. }
  106. tester.initClusters = append(tester.initClusters, cluster)
  107. }
  108. func initProject(tester *tester, t *testing.T) {
  109. t.Helper()
  110. proj := &models.Project{
  111. Name: "project-test",
  112. }
  113. proj, err := tester.repo.Project().CreateProject(proj)
  114. if err != nil {
  115. t.Fatalf("%v\n", err)
  116. }
  117. tester.initProjects = append(tester.initProjects, proj)
  118. }
  119. func initKubeIntegration(tester *tester, t *testing.T) {
  120. t.Helper()
  121. if len(tester.initProjects) == 0 {
  122. initProject(tester, t)
  123. }
  124. if len(tester.initUsers) == 0 {
  125. initUser(tester, t)
  126. }
  127. ki := &ints.KubeIntegration{
  128. Mechanism: ints.KubeLocal,
  129. ProjectID: tester.initProjects[0].ID,
  130. UserID: tester.initUsers[0].ID,
  131. Kubeconfig: []byte("current-context: testing\n"),
  132. ClientCertificateData: []byte("clientcertdata"),
  133. ClientKeyData: []byte("clientkeydata"),
  134. Token: []byte("token"),
  135. Username: []byte("username"),
  136. Password: []byte("password"),
  137. }
  138. ki, err := tester.repo.KubeIntegration().CreateKubeIntegration(ki)
  139. if err != nil {
  140. t.Fatalf("%v\n", err)
  141. }
  142. tester.initKIs = append(tester.initKIs, ki)
  143. }
  144. func initEmptyStack(tester *tester, t *testing.T, stackName string) {
  145. t.Helper()
  146. if len(tester.initProjects) == 0 {
  147. initProject(tester, t)
  148. }
  149. if len(tester.initUsers) == 0 {
  150. initUser(tester, t)
  151. }
  152. if len(tester.initClusters) == 0 {
  153. initCluster(tester, t)
  154. }
  155. uid, _ := encryption.GenerateRandomBytes(16)
  156. // write stack to the database with creating status
  157. stack := &models.Stack{
  158. ProjectID: tester.initProjects[0].ID,
  159. ClusterID: tester.initClusters[0].ID,
  160. Namespace: "test-namespace",
  161. Name: stackName,
  162. UID: uid,
  163. Revisions: []models.StackRevision{
  164. {
  165. RevisionNumber: 1,
  166. Status: string(types.StackRevisionStatusDeploying),
  167. SourceConfigs: []models.StackSourceConfig{},
  168. },
  169. },
  170. }
  171. newStack, err := tester.repo.Stack().CreateStack(stack)
  172. if err != nil {
  173. t.Fatalf("%v\n", err)
  174. }
  175. tester.initStacks = append(tester.initStacks, newStack)
  176. }
  177. func initStack(tester *tester, t *testing.T, stackName string) {
  178. t.Helper()
  179. if len(tester.initProjects) == 0 {
  180. initProject(tester, t)
  181. }
  182. if len(tester.initUsers) == 0 {
  183. initUser(tester, t)
  184. }
  185. if len(tester.initClusters) == 0 {
  186. initCluster(tester, t)
  187. }
  188. uid, _ := encryption.GenerateRandomBytes(16)
  189. sourceConfigs := []models.StackSourceConfig{
  190. {
  191. Name: "source-config-1",
  192. ImageRepoURI: "some-repo",
  193. ImageTag: "some-tag",
  194. UID: uid,
  195. },
  196. }
  197. // write stack to the database with creating status
  198. stack := &models.Stack{
  199. ProjectID: tester.initProjects[0].ID,
  200. ClusterID: tester.initClusters[0].ID,
  201. Namespace: "test-namespace",
  202. Name: stackName,
  203. UID: uid,
  204. Revisions: []models.StackRevision{
  205. {
  206. RevisionNumber: 1,
  207. Status: string(types.StackRevisionStatusDeploying),
  208. SourceConfigs: sourceConfigs,
  209. },
  210. },
  211. }
  212. newStack, err := tester.repo.Stack().CreateStack(stack)
  213. if err != nil {
  214. t.Fatalf("%v\n", err)
  215. }
  216. tester.initStacks = append(tester.initStacks, newStack)
  217. }
  218. func createNewStackRevision(tester *tester, t *testing.T, stackName string) {
  219. t.Helper()
  220. if len(tester.initProjects) == 0 {
  221. initProject(tester, t)
  222. }
  223. if len(tester.initUsers) == 0 {
  224. initUser(tester, t)
  225. }
  226. if len(tester.initClusters) == 0 {
  227. initCluster(tester, t)
  228. }
  229. if len(tester.initStacks) == 0 {
  230. initStack(tester, t, stackName)
  231. }
  232. stack := tester.initStacks[0]
  233. for _, s := range tester.initStacks {
  234. if s.Name == stackName {
  235. stack = s
  236. break
  237. }
  238. }
  239. prevRevision := findLatestRevisionByRevisionNumber(t, stack.Revisions)
  240. oldSourceConfig := prevRevision.SourceConfigs[0]
  241. newUid, _ := encryption.GenerateRandomBytes(16)
  242. sourceConfigs := []models.StackSourceConfig{
  243. {
  244. Name: oldSourceConfig.Name,
  245. ImageRepoURI: "some-repo-" + fmt.Sprint(prevRevision.RevisionNumber+1),
  246. ImageTag: "some-tag-" + fmt.Sprint(prevRevision.RevisionNumber+1),
  247. UID: newUid,
  248. },
  249. }
  250. newRevision := models.StackRevision{
  251. RevisionNumber: prevRevision.RevisionNumber + 1,
  252. Status: string(types.StackRevisionStatusDeploying),
  253. SourceConfigs: sourceConfigs,
  254. StackID: stack.ID,
  255. }
  256. tester.repo.Stack().AppendNewRevision(&newRevision)
  257. }
  258. func findLatestRevisionByRevisionNumber(t *testing.T, revisions []models.StackRevision) *models.StackRevision {
  259. t.Helper()
  260. latestRevision := revisions[0]
  261. for _, revision := range revisions {
  262. if revision.RevisionNumber > latestRevision.RevisionNumber {
  263. latestRevision = revision
  264. }
  265. }
  266. return &latestRevision
  267. }
  268. func appendNewSourceConfig(t *testing.T, tester *tester, stack *models.Stack, sourceConfig models.StackSourceConfig) {
  269. t.Helper()
  270. prevRevision := findLatestRevisionByRevisionNumber(t, stack.Revisions)
  271. previousSourceConfigs := []models.StackSourceConfig{}
  272. for _, sourceConfig := range prevRevision.SourceConfigs {
  273. newUid, _ := encryption.GenerateRandomBytes(16)
  274. sc := models.StackSourceConfig{
  275. Name: sourceConfig.Name,
  276. ImageRepoURI: sourceConfig.ImageRepoURI,
  277. ImageTag: sourceConfig.ImageTag,
  278. UID: newUid,
  279. }
  280. previousSourceConfigs = append(previousSourceConfigs, sc)
  281. }
  282. newRevision := models.StackRevision{
  283. RevisionNumber: prevRevision.RevisionNumber + 1,
  284. Status: string(types.StackRevisionStatusDeploying),
  285. SourceConfigs: append(prevRevision.SourceConfigs, sourceConfig),
  286. StackID: stack.ID,
  287. }
  288. tester.repo.Stack().AppendNewRevision(&newRevision)
  289. }