-
Notifications
You must be signed in to change notification settings - Fork 118
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Initializing shallow cloning logic and CRD change #1824
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -93,7 +93,8 @@ func init() { | |
// Optional flag to be able to override the default shallow clone depth, | ||
// which should be fine for almost all use cases we use the Git source step | ||
// for (in the context of Shipwright build). | ||
pflag.UintVar(&flagValues.depth, "depth", 1, "Create a shallow clone based on the given depth") | ||
// Setting depth to 0 means no shallow clone (full clone) | ||
pflag.UintVar(&flagValues.depth, "depth", 0, "Create a shallow clone with the given depth. 0 means full clone (no shallow).") | ||
|
||
// Mostly internal flag | ||
pflag.BoolVar(&flagValues.skipValidation, "skip-validation", false, "skip pre-requisite validation") | ||
|
@@ -120,7 +121,7 @@ func main() { | |
|
||
// Execute performs flag parsing, input validation and the Git clone | ||
func Execute(ctx context.Context) error { | ||
flagValues = settings{depth: 1} | ||
flagValues = settings{depth: 0} | ||
Comment on lines
-123
to
+124
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Likewise - please revert so we don't change the current behavior of cloning source. |
||
pflag.Parse() | ||
|
||
if flagValues.help { | ||
|
@@ -266,6 +267,7 @@ func clone(ctx context.Context) error { | |
cloneArgs = append(cloneArgs, "--branch", flagValues.revision) | ||
} | ||
|
||
// Only add depth if it's greater than 0 (meaning shallow clone is requested) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 👍 great comment. |
||
if flagValues.depth > 0 { | ||
cloneArgs = append(cloneArgs, "--depth", fmt.Sprintf("%d", flagValues.depth)) | ||
} | ||
|
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -59,6 +59,13 @@ type Git struct { | |||||||||||||||||||||||
// | ||||||||||||||||||||||||
// +optional | ||||||||||||||||||||||||
CloneSecret *string `json:"cloneSecret,omitempty"` | ||||||||||||||||||||||||
|
||||||||||||||||||||||||
// ShallowCloneDepth specifies the depth of the shallow clone. | ||||||||||||||||||||||||
// If not specified or set to 0, a full clone will be performed. | ||||||||||||||||||||||||
// Values greater than 0 will create a shallow clone with the specified depth. | ||||||||||||||||||||||||
// | ||||||||||||||||||||||||
// +optional | ||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would default this value to 1 so that we do not introduce a breaking change, and add a validation that this must be greater than or equal to 0.
Suggested change
|
||||||||||||||||||||||||
ShallowCloneDepth *int `json:"shallowCloneDepth,omitempty"` | ||||||||||||||||||||||||
Comment on lines
+63
to
+68
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would simplify the name of this field to "Depth". This matches the
Suggested change
|
||||||||||||||||||||||||
} | ||||||||||||||||||||||||
|
||||||||||||||||||||||||
// OCIArtifact describes the source code bundle container to pull | ||||||||||||||||||||||||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -79,6 +79,15 @@ func AppendGitStep( | |
) | ||
} | ||
|
||
// Check if shallow clone is requested | ||
if source.ShallowCloneDepth != nil && *source.ShallowCloneDepth > 0 { | ||
gitStep.Args = append( | ||
gitStep.Args, | ||
"--depth", | ||
fmt.Sprintf("%d", *source.ShallowCloneDepth), | ||
) | ||
} | ||
Comment on lines
+82
to
+89
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🤔 if we set a default value of 1, and validate that There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think we still need the |
||
|
||
// If configure, use Git URL rewrite flag | ||
if cfg.GitRewriteRule { | ||
gitStep.Args = append(gitStep.Args, "--git-url-rewrite") | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a breaking change - current Shipwright users will see a performance hit if we switch from "no history" when cloning to "full history." I recommend reverting this change.