-
Notifications
You must be signed in to change notification settings - Fork 1
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
Issue5 #6
Issue5 #6
Conversation
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.
I saw one problem in run-all-steps.sh
, the other comments are minor. Could you do the changes and ping me again. I'd like to wait with testing this until the issues are fixed.
In the other 2 scripts, we used it multiple times. Here we use it only once. Therefore, I would prefer it to be at the location, we actually use it. But, if the others want this changed, we can do that. |
I think it still makes sense. When reading the scripts, it is easier to understand what is going on if it is the same as in the other scripts. (actually, if there is a lot o shared code, we should think about factoring it out completely, but I don't think this is necessary here). |
To make this discussion short: now HG* is also exported in run-conversion.sh |
We decided to add Maltes test. It is now added to the code. About the exit codes. I used different exit codes for different exit reasons: If the majority decides to have no feedback on the exit codes, we can change them all to 1 otherwise, we should document the meaning of the codes in the README.md |
For me having and documenting different exit codes apart from the de-factor standard (usage errors: 2, other errors: 1) is over-engineering. It's not like we expect many people to write complex scripts around our scripts that need this distinction. But also changing the exit codes now is probably unnecessary bike-shedding, so perhaps the best thing is to leave things the way they are, but not give details in the README file. For READMEs, focus on the important things is a virtue. |
@PatrickFerber I just tried to convert a repository with the run-all-steps method. It said "Cloning official repo" and then for a long time nothing happened. Then it checked for incoming changesets and the script aborted with
Can't we do the check for incoming changesets before cloning the repo? |
@jendrikseipp:
As we have decided for the |
I don't really grasp what is the status quo and what is the proposed change for option 3. Maybe we can chat about this tomorrow morning. |
The script |
Awesome, thanks! |
I just tested this and was a bit confused when I read "error", but the script still continued (and the result is a compatible repo): |
I agree, we should change this to 'warning'. It also sounds like you think the message would not be explanatory enough for its own. Do you suggest to add more information? e.g. |
Yes, warning sounds good. The point that is not clear is "fully merged". Let's stick with correct mercurial terminology: warning: The branch 'merge-sccs' is not closed and hence will not be automatically deleted. |
With your new message you confused me. We do not automatically delete open branches. We delete branches that are closed and merged. We detected that this can be problematic for branches that are closed and merged into non-main branches. What kind of merge/unmerged open/closed status does your branch merge-sccs have? Furthermore, I looked into the script. The current message comes from git directly. We do not have the possibilities to change those. Of course, we could swallow them, but then some other error happens and we swallow that one too, or even report it wrongly. Therefore, I would keep it with the current error produced by git. |
Please read my comment again. We do automatically delete closed branches, don't we? I didn't want to suggest anything else. Your suggestion was "is not fully merged" and I basically said that I don't know what "fully merged" means and therefore would prefer "not closed", or, if you prefer, "not closed and merged" or "merged but not closed" or "merged but still open". My branch is merged into another one, but I didn't close it. If we can't change the message, then why did you suggest to change it? :) |
My warning was speaking about not 'fully merge' branches (I guess fully merged comes from git to speak about branches that are not merged into the main branch). You suggested We try to delete all branches that are 1. closed and 2. merged. And as far we know this fails with the mentioned error if we the branch is merged into a non-main branch. -> You said the branch is merged and opened. That we try to delete such a branch is strange and should not happen. Why did I suggest changing the message if it is (not easily possible)? I said it sounds like you would like more information in that message and indeed I though about updating it. Not knowing that this is not easily possible. 2 hours later (after your reply) I looked at how we could do this and just then detected that changing the error message is most likely not worth the effort. And therefore, informed you about this development. |
I think this clearly says that we could not delete the branch because it was open. Not that we attempted to delete an open branch. Anyway, if it isn't clear, we should change it.
I think the problem was that it is a branch which is merged into another branch which is not the main branch. Sorry for the confusion. So it is a branch which is open and not merged into main. But still, apparently, the script detected it as something which should normally be deleted. I don't know how you decided to handle such cases.
My mercurial doesn't recognize the option "--template" for hg branch. Do I need a newer version for this?
Sorry, I must have overlooked this. |
If it is open, we do not want to delete it and have to fix the script for that.
My bad, it is not |
Turns out the branch is actually closed - I assumed it was open from the original "error" message, not understanding that the problem the error pointed me to is that the branch is not integrated into the main branch. But anyway, if we can't change the message easily, let's leave it as it is and hope that other users look into the README when they encounter this error. |
I update the ReadMe slightly. In the 'Warnings' section we already spoke about the discussed problem. I added now the error message printed by git for the reader to know ah, this warning belongs to this git error message. |
Ok, sounds good. |
README.md
Outdated
The CLEANED_MERCURIAL_REPOSITORY is a location where the intermediate cleaned | ||
up Mercurial repository will be written to: | ||
|
||
./run-cleanup.sh MERCURIAL_REPOSITORY ORDERED_REPOSITORY CLEANED_MERCURIAL_REPOSITORY |
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.
I think it is strange to have two intermediate directories as parameters to a single step. It seem to disagree with the decision to merge the two steps into one. What I mean is that passing two directories here makes it seem like two steps that just happen to both be executed by a single script. I'm fine with leaving it like this but it feels odd to me.
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.
I see this as 1 intermediate repository (ORDERED_REPOSITORY). CLEANED_* is the intended output of this script, but I also dislike interface. We do not see another way to solve what we want to do. We need to 1. order the commits and 2. cleanup the repository. We do NOT want to modify the MERCURIAL_REPOSITORY.
To order the commits, we have to clone hg.fast-downward.org anew. This requires a directory and pull the users changes into it. The cleanup (hg convert) cannot be done inplace. Thus, we have to create a second directory (we do not overwrite the users repository).
Executing this script (instead of the run-all-steps.sh) shall give the user the ability to investigate what could have gone wrong. Thus, I do not create a temporary directory and delete at the end of the cleanup.
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.
That all sounds like an argument for having two separate steps for ordering and cleanup. What was the reasoning merging the steps? If the point was that the ordering is something internal, then we can make it more internal by using a temporary directory for it and not bothering the user with this. But if we want to keep the ordered repository after the script runs, it sounds like we should have two steps again.
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.
The ordering is more an internal thing for the cleanup. We observed the bad design, when Jendrik ran the ordering which took some time and then the cleanup failed because its requirement (all changes pulled in) were not satisfied. The user should see this directly. Adding the check that all changes are pulled in to the run-all-steps.sh script would be a hack. Instead we made the ordering internal to the cleanup.
We could make the ordered repository a temporary one. For me this script is used by a user who wants to have full control. Therefore, I kept the ordered repository. The user can investigate into it or just add rm DIR
to his command. If the majority wants it to be temporary and automatically removed, we can change this.
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.
I don't know, it still sounds like this should be separate steps to me. If there are conditions that the input (MERCURIAL_REPOSITORY
) has to satisfy, they should be check at the start of the first step. If the cloning takes too long to check if there are incoming changes, you could do hg -R MERCURIAL_REPOSITORY incoming hg.fast-downward.org
instead . But again, if you already discussed this, I don't want to restart that discussion.
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.
I also disagree with keeping an intermediate result around, and even making it a command-line argument. Like Florian said it breaks the abstraction. If we want to facilitate debugging if things go wrong, for me the logical thing is simply to not go out of our way and delete intermediate results in cases where things go wrong, but they should not be kept around if things go right.
I also agree it makes no sense to first clone and then test and fail if there are incoming commits. The test about incoming commits should be made right at the start if we consider it a reason to abort.
We also agreed on these points in the discussion with Silvan and Jendrik.
For what it's worth, regarding debugging: unless there are network errors or similar basic issues, there is no way in which the initial clone-and-pull steps could go wrong.
If you're OK with it, I'll push a suggested change -- if you don't like it, we can strip it or back it out.
run-cleanup.sh
Outdated
echo "Cloning official repository" | ||
hg clone "http://hg.fast-downward.org" "${ORDERED_REPOSITORY}" | ||
|
||
if hg -R "${SRC_REPOSITORY}" incoming "${ORDERED_REPOSITORY}"; then |
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.
Is this test still necessary? After the pull in line 56 the condition will be satisfied in the new repository, even if it wasn't before. I think I suggested this test but this was when we were still removing parts from the official clone before pulling.
I don't see how removing this test would cause any problems.
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.
I think this test is still necessary. It enforces that all current changes from the last Mercurial master are pulled in by the user prior to executing our script. Any 'multiple head on the same branch' issues (or other issues the pull could cause and we do not know about) can be seen in the user's repository.
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.
It enforces that all current changes from the last Mercurial master are pulled in by the user prior to executing our script.
I don't see why that would be necessary. The next step after this test is a pull and after this pull the condition that we test here is satisfied even if it wasn't before.
If our assumption is that the repository does not have multiple heads on a single branch, we should test that assumption explicitly instead of testing something unrelated that would force the user to do a step that generates a warning (not an error) when the assumption is not satisfied.
(Here is an example for testing this but note the comment about the test in line #19: https://gist.github.com/FernFerret/3178035)
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.
Our problem is, we do not exactly know when fast-export succeeds and when it fails. Malte tested it and said there are cases when multiple heads on the same branch work. We simply do not know for what exactly we have to test (and additionally, what else we do not know what else could fast-export to fail). We do not want to say you are not allowed to convert this repository, although it would convert perfectly fine.
therefore, we kept the check that all changes have to be pulled. If fast-export tells you know "you have multiple heads on branch X" or "fix that". Those issues are in the user's repository and he can fix them there.
If we would pull the newest changes ourselves, then 1. he could not find the problems that caused the error in his repository and 2. could not fix them.
(yes, he could find and fix them by pulling himself, but for me it is more naturally: "I get an error, I look into my repository" and not: "I get an error, let's look through all the temporary files")
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.
I think fast-export doesn't produce an error in this case, only a warning and an incompatible repository, But if you already discussed this, I'm fine with leaving things as they are.
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.
I looked over the changes again and it looks good to merge to me.
|
||
echo "Looking for missing commits" | ||
|
||
if hg -R "${SRC_REPOSITORY}" incoming http://hg.fast-downward.org; then |
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.
I just got the following output when I accidentally ran cleanup on a repository that was already cleaned:
Looking for missing commits
comparing with http://hg.fast-downward.org/
searching for changes
abort: repository is unrelated
Cloning official repository
It looks like the error (abort: repository is unrelated
) still had the exit code of 0 (no commits to pull) and the script continued with cloning the official repository. Should we check for this?
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.
I wouldn't bother. This is not a script meant to be run by many people many times, and we cannot predict all user errors. I think users that make this error are likely to find out eventually what went wrong, so all this would do is potentially save them a bit of time.
Also, we should merge this soon; as far as I understand, the main branch is still on code that does no reordering and is not likely to work.
No description provided.