-
Notifications
You must be signed in to change notification settings - Fork 350
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
lakectl log: add option to filter merge commits #8142
Changes from 19 commits
d2c2a5f
5b9b954
413e130
8578938
bdb751a
3791404
90e5605
842f365
f009268
8d5f948
8948ecd
5cd8b5a
065bfe4
2fe7125
a82f9e9
3a2dbe3
a9b50cd
d67ddbf
7e18b0d
be315e5
b424591
35e0af6
91df0b1
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 |
---|---|---|
|
@@ -41,6 +41,10 @@ const ( | |
internalPageSize = 1000 // when retrieving all records, use this page size under the hood | ||
defaultAmountArgumentValue = 100 // when no amount is specified, use this value for the argument | ||
|
||
// when using --no-merges & amount, this const is the upper limit to use huristic. | ||
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. The comment also says "3". So that constant needs to appear here, too. |
||
// The heuristic asks for 3*amount results since some will filter out | ||
maxAmountNoMerges = 333 | ||
|
||
defaultPollInterval = 3 * time.Second // default interval while pulling tasks status | ||
minimumPollInterval = time.Second // minimum interval while pulling tasks status | ||
defaultPollTimeout = time.Hour // default expiry for pull status with no update | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -66,6 +66,19 @@ func (d *dotWriter) Write(commits []apigen.Commit) { | |
} | ||
} | ||
|
||
// filter merge commits, used for --no-merges flag | ||
func filterMergeCommits(commits []apigen.Commit) []apigen.Commit { | ||
filteredCommits := make([]apigen.Commit, 0, len(commits)) | ||
itaiad200 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
// iterating through data.Commit, appending every instance with 1 or less parents. | ||
for _, commit := range commits { | ||
if len(commit.Parents) <= 1 { | ||
filteredCommits = append(filteredCommits, commit) | ||
} | ||
} | ||
return filteredCommits | ||
} | ||
|
||
// logCmd represents the log command | ||
var logCmd = &cobra.Command{ | ||
Use: "log <branch URI>", | ||
|
@@ -80,6 +93,7 @@ var logCmd = &cobra.Command{ | |
limit := Must(cmd.Flags().GetBool("limit")) | ||
since := Must(cmd.Flags().GetString("since")) | ||
dot := Must(cmd.Flags().GetBool("dot")) | ||
noMerges := Must(cmd.Flags().GetBool("no-merges")) | ||
firstParent := Must(cmd.Flags().GetBool("first-parent")) | ||
objects := Must(cmd.Flags().GetStringSlice("objects")) | ||
prefixes := Must(cmd.Flags().GetStringSlice("prefixes")) | ||
|
@@ -100,6 +114,10 @@ var logCmd = &cobra.Command{ | |
if amountForPagination <= 0 { | ||
amountForPagination = internalPageSize | ||
} | ||
// case --no-merges & --amount, ask for more results since some will filter out | ||
if noMerges && amountForPagination < maxAmountNoMerges { | ||
amountForPagination *= 3 | ||
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. Now I get the |
||
} | ||
logCommitsParams := &apigen.LogCommitsParams{ | ||
After: apiutil.Ptr(apigen.PaginationAfter(after)), | ||
Amount: apiutil.Ptr(apigen.PaginationAmount(amountForPagination)), | ||
|
@@ -151,13 +169,19 @@ var logCmd = &cobra.Command{ | |
}, | ||
} | ||
|
||
// case --no-merges, filter commits and subtract that amount from amount desired | ||
if noMerges { | ||
data.Commits = filterMergeCommits(data.Commits) | ||
amount -= len(data.Commits) | ||
} | ||
|
||
if dot { | ||
graph.Write(data.Commits) | ||
} else { | ||
Write(commitsTemplate, data) | ||
} | ||
|
||
if amount != 0 { | ||
if amount <= 0 { | ||
// user request only one page | ||
break | ||
} | ||
|
@@ -177,6 +201,7 @@ func init() { | |
logCmd.Flags().String("after", "", "show results after this value (used for pagination)") | ||
logCmd.Flags().Bool("dot", false, "return results in a dotgraph format") | ||
logCmd.Flags().Bool("first-parent", false, "follow only the first parent commit upon seeing a merge commit") | ||
logCmd.Flags().Bool("no-merges", false, "skip merge commits") | ||
logCmd.Flags().Bool("show-meta-range-id", false, "also show meta range ID") | ||
logCmd.Flags().StringSlice("objects", nil, "show results that contains changes to at least one path in that list of objects. Use comma separator to pass all objects together") | ||
logCmd.Flags().StringSlice("prefixes", nil, "show results that contains changes to at least one path in that list of prefixes. Use comma separator to pass all prefixes together") | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
|
||
ID: <COMMIT_ID> | ||
Author: esti | ||
Date: <DATE> <TIME> <TZ> | ||
|
||
${SECOND_MESSAGE} | ||
|
||
ID: <COMMIT_ID> | ||
Author: esti | ||
Date: <DATE> <TIME> <TZ> | ||
|
||
${MESSAGE} | ||
|
||
ID: <COMMIT_ID> | ||
Date: <DATE> <TIME> <TZ> | ||
|
||
Repository created | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -338,6 +338,59 @@ func TestLakectlMergeAndStrategies(t *testing.T) { | |
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" fs ls lakefs://"+repoName+"/"+featureBranch+"/", false, "lakectl_fs_ls_1_file", vars) | ||
} | ||
|
||
func TestLakectlLogNoMergesWithCommitsAndMerges(t *testing.T) { | ||
|
||
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. Nit: please remove this blank line, it does not aid readability. |
||
repoName := generateUniqueRepositoryName() | ||
storage := generateUniqueStorageNamespace(repoName) | ||
vars := map[string]string{ | ||
"REPO": repoName, | ||
"STORAGE": storage, | ||
"BRANCH": mainBranch, | ||
} | ||
|
||
featureBranch := "feature" | ||
branchVars := map[string]string{ | ||
"REPO": repoName, | ||
"STORAGE": storage, | ||
"SOURCE_BRANCH": mainBranch, | ||
"DEST_BRANCH": featureBranch, | ||
"BRANCH": featureBranch, | ||
} | ||
|
||
filePath1 := "file1" | ||
filePath2 := "file2" | ||
|
||
// create repo with 'main' branch | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" repo create lakefs://"+repoName+" "+storage, false, "lakectl_repo_create", vars) | ||
|
||
// upload 'file1' and commit | ||
vars["FILE_PATH"] = filePath1 | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" fs upload -s files/ro_1k lakefs://"+repoName+"/"+mainBranch+"/"+filePath1, false, "lakectl_fs_upload", vars) | ||
commitMessage := "first commit to main" | ||
vars["MESSAGE"] = commitMessage | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" commit lakefs://"+repoName+"/"+mainBranch+" -m \""+commitMessage+"\"", false, "lakectl_commit", vars) | ||
|
||
// create new branch 'feature' | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" branch create lakefs://"+repoName+"/"+featureBranch+" --source lakefs://"+repoName+"/"+mainBranch, false, "lakectl_branch_create", branchVars) | ||
|
||
// upload 'file2' to feature branch and commit | ||
branchVars["FILE_PATH"] = filePath2 | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" fs upload -s files/ro_1k lakefs://"+repoName+"/"+featureBranch+"/"+filePath2, false, "lakectl_fs_upload", branchVars) | ||
commitMessage = "second commit to feature branch" | ||
branchVars["MESSAGE"] = commitMessage | ||
vars["SECOND_MESSAGE"] = commitMessage | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" commit lakefs://"+repoName+"/"+featureBranch+" -m \""+commitMessage+"\"", false, "lakectl_commit", branchVars) | ||
|
||
// merge feature into main | ||
branchVars["SOURCE_BRANCH"] = featureBranch | ||
branchVars["DEST_BRANCH"] = mainBranch | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" merge lakefs://"+repoName+"/"+featureBranch+" lakefs://"+repoName+"/"+mainBranch, false, "lakectl_merge_success", branchVars) | ||
|
||
// log the commits without merges | ||
RunCmdAndVerifySuccessWithFile(t, Lakectl()+" log lakefs://"+repoName+"/"+mainBranch+" --no-merges", false, "lakectl_log_no_merges", vars) | ||
|
||
} | ||
|
||
func TestLakectlAnnotate(t *testing.T) { | ||
repoName := generateUniqueRepositoryName() | ||
storage := generateUniqueStorageNamespace(repoName) | ||
|
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.
Nit: