Skip to content

Commit

Permalink
Merge pull request #283 from sap-contributions/dep-metadata-v2
Browse files Browse the repository at this point in the history
Introduce struct with metadata to identify a dependency
  • Loading branch information
dmikusa authored Oct 23, 2023
2 parents 64d6194 + ba90843 commit 8365f81
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 1 deletion.
25 changes: 25 additions & 0 deletions buildmodule.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,31 @@ type BuildModuleDependency struct {
DeprecationDate time.Time `toml:"deprecation_date"`
}

// DependencyLayerContributorMetadata returns the subset of data from BuildpackDependency that is use as expected metadata for the DependencyLayerContributor.
type DependencyLayerContributorMetadata struct {
// ID is the dependency ID.
ID string `toml:"id"`

// Name is the dependency name.
Name string `toml:"name"`

// Version is the dependency version.
Version string `toml:"version"`

// SHA256 is the hash of the dependency.
SHA256 string `toml:"sha256"`
}

// GetMetadata return the relevant metadata of this dependency
func (b BuildModuleDependency) GetMetadata() DependencyLayerContributorMetadata {
return DependencyLayerContributorMetadata{
ID: b.ID,
Name: b.Name,
Version: b.Version,
SHA256: b.SHA256,
}
}

// Equals compares the 2 structs if they are equal. This is very simiar to reflect.DeepEqual
// except that properties that will not work (e.g. DeprecationDate) are ignored.
func (b1 BuildModuleDependency) Equals(b2 BuildModuleDependency) bool {
Expand Down
2 changes: 1 addition & 1 deletion layer.go
Original file line number Diff line number Diff line change
Expand Up @@ -224,7 +224,7 @@ func NewDependencyLayerContributor(dependency BuildModuleDependency, cache Depen
return DependencyLayerContributor{
Dependency: dependency,
DependencyCache: cache,
ExpectedMetadata: dependency,
ExpectedMetadata: dependency.GetMetadata(),
ExpectedTypes: types,
Logger: logger,
}
Expand Down

0 comments on commit 8365f81

Please sign in to comment.