-
Notifications
You must be signed in to change notification settings - Fork 365
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 to present error while writing to protected branch #8454
lakectl to present error while writing to protected branch #8454
Conversation
This reverts commit e12badc.
🎊 PR Preview edd426d has been successfully built and deployed to https://treeverse-lakeFS-preview-pr-8454.surge.sh 🕐 Build time: 0.012s 🤖 By surge-preview |
4f43a89
to
33ca670
Compare
@ItamarYuran please move the PR to ready for review. |
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.
There are a couple of issues with the current solution:
- 403 (forbidden) status code might be a result of another issue than writing to a protected branch.
- Your solution works specifically for uploading an object with presign mode without using multiparts.
What if I delete an object instead of uploading one? I'll still have the same issue. - I would like to have some tests here to validate we show the reason why we failed when trying to apply changes (write/delete) to a protected branch.
c3eeadb
to
cce44f3
Compare
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.
Great job!
Please add tests for lakectl fs rm and deleting an object with lakectl local commit
esti/lakectl_local_test.go
Outdated
@@ -486,6 +486,39 @@ func TestLakectlLocal_pull(t *testing.T) { | |||
} | |||
} | |||
|
|||
func TestLakectlLocal_commitProtetedBranch(t *testing.T) { |
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.
Nice!
Can you please also add a new test for deleting a file?
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.
THANKS!
esti/lakectl_test.go
Outdated
) | ||
|
||
var emptyVars = make(map[string]string) | ||
|
||
const branchProtectTimeout = graveler.BranchUpdateMaxInterval + 1 |
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.
graveler.BranchUpdateMaxInterval
is a time.Duration
unit you should add time.Second
instead of 1 to it
esti/lakectl_test.go
Outdated
runCmd(t, Lakectl()+" branch-protect add lakefs://"+vars["REPO"]+"/ '*'", false, false, vars) | ||
RunCmdAndVerifyContainsText(t, Lakectl()+" branch-protect list lakefs://"+vars["REPO"]+"/ ", false, "*", vars) | ||
// BranchUpdateMaxInterval - sleep in order to overcome branch update caching | ||
time.Sleep(branchProtectTimeout * time.Second) |
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.
change branchProtectTimeout
to be graveler.BranchUpdateMaxInterval + time.Second
and then change time.Sleep(branchProtectTimeout * time.Second)
to be time.Sleep(branchProtectTimeout)
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.
Changing, Thank you!
Closes #8333