blobsum_service_test.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. package metadata
  2. import (
  3. "io/ioutil"
  4. "os"
  5. "reflect"
  6. "testing"
  7. "github.com/docker/distribution/digest"
  8. "github.com/docker/docker/layer"
  9. )
  10. func TestBlobSumService(t *testing.T) {
  11. tmpDir, err := ioutil.TempDir("", "blobsum-storage-service-test")
  12. if err != nil {
  13. t.Fatalf("could not create temp dir: %v", err)
  14. }
  15. defer os.RemoveAll(tmpDir)
  16. metadataStore, err := NewFSMetadataStore(tmpDir)
  17. if err != nil {
  18. t.Fatalf("could not create metadata store: %v", err)
  19. }
  20. blobSumService := NewBlobSumService(metadataStore)
  21. testVectors := []struct {
  22. diffID layer.DiffID
  23. blobsums []digest.Digest
  24. }{
  25. {
  26. diffID: layer.DiffID("sha256:a3ed95caeb02ffe68cdd9fd84406680ae93d633cb16422d00e8a7c22955b46d4"),
  27. blobsums: []digest.Digest{
  28. digest.Digest("sha256:f0cd5ca10b07f35512fc2f1cbf9a6cefbdb5cba70ac6b0c9e5988f4497f71937"),
  29. },
  30. },
  31. {
  32. diffID: layer.DiffID("sha256:86e0e091d0da6bde2456dbb48306f3956bbeb2eae1b5b9a43045843f69fe4aaa"),
  33. blobsums: []digest.Digest{
  34. digest.Digest("sha256:f0cd5ca10b07f35512fc2f1cbf9a6cefbdb5cba70ac6b0c9e5988f4497f71937"),
  35. digest.Digest("sha256:9e3447ca24cb96d86ebd5960cb34d1299b07e0a0e03801d90b9969a2c187dd6e"),
  36. },
  37. },
  38. {
  39. diffID: layer.DiffID("sha256:03f4658f8b782e12230c1783426bd3bacce651ce582a4ffb6fbbfa2079428ecb"),
  40. blobsums: []digest.Digest{
  41. digest.Digest("sha256:f0cd5ca10b07f35512fc2f1cbf9a6cefbdb5cba70ac6b0c9e5988f4497f71937"),
  42. digest.Digest("sha256:9e3447ca24cb96d86ebd5960cb34d1299b07e0a0e03801d90b9969a2c187dd6e"),
  43. digest.Digest("sha256:cbbf2f9a99b47fc460d422812b6a5adff7dfee951d8fa2e4a98caa0382cfbdbf"),
  44. digest.Digest("sha256:8902a7ca89aabbb868835260912159026637634090dd8899eee969523252236e"),
  45. digest.Digest("sha256:c84364306344ccc48532c52ff5209236273525231dddaaab53262322352883aa"),
  46. digest.Digest("sha256:aa7583bbc87532a8352bbb72520a821b3623523523a8352523a52352aaa888fe"),
  47. },
  48. },
  49. }
  50. // Set some associations
  51. for _, vec := range testVectors {
  52. for _, blobsum := range vec.blobsums {
  53. err := blobSumService.Add(vec.diffID, blobsum)
  54. if err != nil {
  55. t.Fatalf("error calling Set: %v", err)
  56. }
  57. }
  58. }
  59. // Check the correct values are read back
  60. for _, vec := range testVectors {
  61. blobsums, err := blobSumService.GetBlobSums(vec.diffID)
  62. if err != nil {
  63. t.Fatalf("error calling Get: %v", err)
  64. }
  65. expectedBlobsums := len(vec.blobsums)
  66. if expectedBlobsums > 5 {
  67. expectedBlobsums = 5
  68. }
  69. if !reflect.DeepEqual(blobsums, vec.blobsums[len(vec.blobsums)-expectedBlobsums:len(vec.blobsums)]) {
  70. t.Fatal("Get returned incorrect layer ID")
  71. }
  72. }
  73. // Test GetBlobSums on a nonexistent entry
  74. _, err = blobSumService.GetBlobSums(layer.DiffID("sha256:82379823067823853223359023576437723560923756b03560378f4497753917"))
  75. if err == nil {
  76. t.Fatal("expected error looking up nonexistent entry")
  77. }
  78. // Test GetDiffID on a nonexistent entry
  79. _, err = blobSumService.GetDiffID(digest.Digest("sha256:82379823067823853223359023576437723560923756b03560378f4497753917"))
  80. if err == nil {
  81. t.Fatal("expected error looking up nonexistent entry")
  82. }
  83. // Overwrite one of the entries and read it back
  84. err = blobSumService.Add(testVectors[1].diffID, testVectors[0].blobsums[0])
  85. if err != nil {
  86. t.Fatalf("error calling Add: %v", err)
  87. }
  88. diffID, err := blobSumService.GetDiffID(testVectors[0].blobsums[0])
  89. if err != nil {
  90. t.Fatalf("error calling GetDiffID: %v", err)
  91. }
  92. if diffID != testVectors[1].diffID {
  93. t.Fatal("GetDiffID returned incorrect diffID")
  94. }
  95. }