-
Notifications
You must be signed in to change notification settings - Fork 202
/
git_latest_patch.go
78 lines (63 loc) · 2.65 KB
/
git_latest_patch.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package stage
import (
"context"
"fmt"
"github.com/werf/werf/pkg/container_backend"
"github.com/werf/werf/pkg/image"
"github.com/werf/werf/pkg/util"
)
func NewGitLatestPatchStage(gitPatchStageOptions *NewGitPatchStageOptions, baseStageOptions *NewBaseStageOptions) *GitLatestPatchStage {
s := &GitLatestPatchStage{}
s.GitPatchStage = newGitPatchStage(GitLatestPatch, gitPatchStageOptions, baseStageOptions)
return s
}
type GitLatestPatchStage struct {
*GitPatchStage
}
func (s *GitLatestPatchStage) IsEmpty(ctx context.Context, c Conveyor, prevBuiltImage *StageImage) (bool, error) {
if empty, err := s.GitPatchStage.IsEmpty(ctx, c, prevBuiltImage); err != nil {
return false, err
} else if empty {
return true, nil
}
isEmpty := true
for _, gitMapping := range s.gitMappings {
commit, err := gitMapping.GetBaseCommitForPrevBuiltImage(ctx, c, prevBuiltImage)
if err != nil {
return false, fmt.Errorf("unable to get base commit for git mapping %s: %w", gitMapping.GitRepo().GetName(), err)
}
if exist, err := gitMapping.GitRepo().IsCommitExists(ctx, commit); err != nil {
return false, fmt.Errorf("unable to check existence of commit %q in the repo %s: %w", commit, gitMapping.GitRepo().GetName(), err)
} else if !exist {
return false, fmt.Errorf("commit %q is not exist in the repo %s", commit, gitMapping.GitRepo().GetName())
}
if empty, err := gitMapping.IsPatchEmpty(ctx, c, prevBuiltImage); err != nil {
return false, err
} else if !empty {
isEmpty = false
break
}
}
return isEmpty, nil
}
func (s *GitLatestPatchStage) GetDependencies(ctx context.Context, c Conveyor, _ container_backend.ContainerBackend, _, prevBuiltImage *StageImage) (string, error) {
var args []string
for _, gitMapping := range s.gitMappings {
patchContent, err := gitMapping.GetPatchContent(ctx, c, prevBuiltImage)
if err != nil {
return "", fmt.Errorf("error getting patch between previous built image %s and current commit for git mapping %s: %w", prevBuiltImage.Image.Name(), gitMapping.Name, err)
}
args = append(args, patchContent)
}
return util.Sha256Hash(args...), nil
}
func (s *GitLatestPatchStage) SelectSuitableStage(ctx context.Context, c Conveyor, stages []*image.StageDescription) (*image.StageDescription, error) {
ancestorsImages, err := s.selectStagesAncestorsByGitMappings(ctx, c, stages)
if err != nil {
return nil, fmt.Errorf("unable to select cache images ancestors by git mappings: %w", err)
}
return s.selectStageByOldestCreationTimestamp(ancestorsImages)
}
func (s *GitLatestPatchStage) GetNextStageDependencies(ctx context.Context, c Conveyor) (string, error) {
return s.BaseStage.getNextStageGitDependencies(ctx, c)
}