pkg/build/stage/git_latest_patch.go

Summary

Maintainability
A
2 hrs
Test Coverage
C
70%
package stage

import (
    "context"
    "fmt"

    "github.com/werf/werf/v2/pkg/container_backend"
    "github.com/werf/werf/v2/pkg/image"
    "github.com/werf/werf/v2/pkg/util"
)

func NewGitLatestPatchStage(gitPatchStageOptions *NewGitPatchStageOptions, baseStageOptions *BaseStageOptions) *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, cb container_backend.ContainerBackend, prevImage, prevBuiltImage *StageImage, buildContextArchive container_backend.BuildContextArchiver) (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)
}