suite_test.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package resource_test
  2. import (
  3. "encoding/json"
  4. "io/ioutil"
  5. "os"
  6. "testing"
  7. "github.com/google/go-containerregistry/pkg/name"
  8. "github.com/google/go-containerregistry/pkg/v1"
  9. "github.com/google/go-containerregistry/pkg/v1/remote"
  10. . "github.com/onsi/ginkgo"
  11. . "github.com/onsi/gomega"
  12. "github.com/onsi/gomega/gexec"
  13. )
  14. var bins struct {
  15. In string `json:"in"`
  16. Out string `json:"out"`
  17. Check string `json:"check"`
  18. }
  19. // see testdata/static/Dockerfile
  20. const OLDER_STATIC_DIGEST = "sha256:031567a617423a84ad68b62267c30693185bd2b92c2668732efc8c70b036bd3a"
  21. const LATEST_STATIC_DIGEST = "sha256:64a6988c58cbdd634198f56452e8f8945e5b54a4bbca4bff7e960e1c830671ff"
  22. // same Dockerfile, but pushed again (twice; old + latest) to a private repo
  23. const PRIVATE_OLDER_STATIC_DIGEST = "sha256:a5e6442b86fd5f555f528deea32326e9709851f6b18d490d6dfb290c22d6ff52"
  24. const PRIVATE_LATEST_STATIC_DIGEST = "sha256:96c8ddb11d01b236fbf063e5a468d17f4c44ccffa19470471162dbd5bdc922a4"
  25. var privateRepo = os.Getenv("PRIVATE_REPO")
  26. var privateRepoUsername = os.Getenv("PRIVATE_REPO_USERNAME")
  27. var privateRepoPassword = os.Getenv("PRIVATE_REPO_PASSWORD")
  28. func checkPrivateRepoConfigured() {
  29. if privateRepo == "" || privateRepoUsername == "" || privateRepoPassword == "" {
  30. Skip("must specify $PRIVATE_REPO, $PRIVATE_REPO_USERNAME, and $PRIVATE_REPO_PASSWORD")
  31. }
  32. }
  33. var _ = SynchronizedBeforeSuite(func() []byte {
  34. var err error
  35. b := bins
  36. if _, err := os.Stat("/opt/resource/in"); err == nil {
  37. b.In = "/opt/resource/in"
  38. } else {
  39. b.In, err = gexec.Build("github.com/concourse/registry-image-resource/cmd/in")
  40. Expect(err).ToNot(HaveOccurred())
  41. }
  42. if _, err := os.Stat("/opt/resource/out"); err == nil {
  43. b.Out = "/opt/resource/out"
  44. } else {
  45. b.Out, err = gexec.Build("github.com/concourse/registry-image-resource/cmd/out")
  46. Expect(err).ToNot(HaveOccurred())
  47. }
  48. if _, err := os.Stat("/opt/resource/check"); err == nil {
  49. b.Check = "/opt/resource/check"
  50. } else {
  51. b.Check, err = gexec.Build("github.com/concourse/registry-image-resource/cmd/check")
  52. Expect(err).ToNot(HaveOccurred())
  53. }
  54. j, err := json.Marshal(b)
  55. Expect(err).ToNot(HaveOccurred())
  56. return j
  57. }, func(bp []byte) {
  58. err := json.Unmarshal(bp, &bins)
  59. Expect(err).ToNot(HaveOccurred())
  60. })
  61. var _ = SynchronizedAfterSuite(func() {
  62. }, func() {
  63. gexec.CleanupBuildArtifacts()
  64. })
  65. func TestRegistryImageResource(t *testing.T) {
  66. RegisterFailHandler(Fail)
  67. RunSpecs(t, "RegistryImageResource Suite")
  68. }
  69. func latestDigest(ref string) string {
  70. n, err := name.ParseReference(ref, name.WeakValidation)
  71. Expect(err).ToNot(HaveOccurred())
  72. image, err := remote.Image(n)
  73. Expect(err).ToNot(HaveOccurred())
  74. digest, err := image.Digest()
  75. Expect(err).ToNot(HaveOccurred())
  76. return digest.String()
  77. }
  78. func latestManifest(ref string) (string, *v1.Manifest) {
  79. n, err := name.ParseReference(ref, name.WeakValidation)
  80. Expect(err).ToNot(HaveOccurred())
  81. image, err := remote.Image(n)
  82. Expect(err).ToNot(HaveOccurred())
  83. manifest, err := image.Manifest()
  84. Expect(err).ToNot(HaveOccurred())
  85. digest, err := image.Digest()
  86. Expect(err).ToNot(HaveOccurred())
  87. return digest.String(), manifest
  88. }
  89. func cat(path string) string {
  90. bytes, err := ioutil.ReadFile(path)
  91. Expect(err).ToNot(HaveOccurred())
  92. return string(bytes)
  93. }