Skip to content
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

feat: allow git remote paths to be provided as source to move2kube #998

Merged
merged 3 commits into from
Apr 10, 2023

Conversation

venkatbandarupalli
Copy link
Contributor

Details

Git remote path format

SSH

  • git@github.com git remote URL ^ branch,tag,commit ^ path within the repo
  • git@github.com git remote URL^ branch_branchname ^ path within the repo

HTTPS

  • https:// git remote URL ^ branch,tag,commit ^ path within the repo
  • https:// git remote URL ^ branch_ branchname ^ path within the repo

Example Usage

move2kube transform -s https://github.com/konveyor/move2kube-demos.git^branch_main^samples/enterprise-app --overwrite

@github-actions
Copy link

Thanks for making a pull request! 😃
One of the maintainers will review and advise on the next steps.

@github-actions github-actions bot added the feat label Mar 26, 2023
@kmehant kmehant added the lfx-project https://lfx.linuxfoundation.org/tools/mentorship/ label Mar 26, 2023
Copy link
Member

@kmehant kmehant left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR, Venkat, can you look at my comment and also please update this branch. Thanks.

m2kqacache.yaml Outdated Show resolved Hide resolved
@venkatbandarupalli venkatbandarupalli force-pushed the feat-git-src branch 2 times, most recently from 00b0c9f to 2475da3 Compare March 26, 2023 19:31
@kmehant kmehant requested a review from ashokponkumar March 27, 2023 05:02
@HarikrishnanBalagopal
Copy link
Contributor

HarikrishnanBalagopal commented Mar 27, 2023

Thanks for the PR, Venkat, can you look at my comment and also please update this branch. Thanks.

Please consider this alternative, adding the feature behind a flag

$ move2kube transform --source-repo github.com/myaccount/mysourcerepo.git --cust-repo github.com/myaccount/mycustrepo.git

Make it easier to integrate with the UI later and it avoids breaking some assumptions we have made in the CLI, API and UI.

Copy link
Member

@ashokponkumar ashokponkumar left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work Venkat! A few suggestions.

cmd/transform.go Outdated
if err != nil {
logrus.Errorf("Error while getting current user's home directory: %s", err)
}
remoteSourcesFolderAbs, err := filepath.Abs(filepath.Join(homeDir, types.AppName, common.RemoteSourcesFolder))
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we can use

TempPath = TempDirPrefix + "temp"
path to store data during the run.

Copy link
Contributor

@HarikrishnanBalagopal HarikrishnanBalagopal Mar 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please make this configurable with a flag. We can keep temp dir as default if the flag is not provided.

$ move2kube transform \
  --source-repo github.com/myaccount/mysourcerepo.git \
  --source-repo-dir data/workspaces/1/projects/1/expanded/sources/1
  --cust-repo github.com/myaccount/mycustrepo.git \
  --cust-repo-dir data/workspaces/1/projects/1/expanded/customizations/1

Comment on lines 37 to 40
// reference format - git+ssh://<git remote URL>^<branch,tag,commit>^<path within the repo>
// reference format - git+https://<git remote URL>^<branch,tag,commit>^<path within the repo>
// reference format - git+ssh://<git remote URL>^branch_<branchname>^<path within the repo>
// reference format - git+https://<git remote URL>^branch_<branchname>^<path within the repo>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why not reuse existing formats like https://pip.pypa.io/en/stable/topics/vcs-support/?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR, Venkat, can you look at my comment and also please update this branch. Thanks.

Please consider this alternative, adding the feature behind a flag

$ move2kube transform --source-repo github.com/myaccount/mysourcerepo.git --cust-repo github.com/myaccount/mycustrepo.git

Make it easier to integrate with the UI later and it avoids breaking some assumptions we have made in the CLI, API and UI.

Why would it impact the UI, it would just become an additional feature supported, isn't it? Having a single flag will help avoiding coordinating between the various ways we can get input, isn't it?

Copy link
Contributor

@HarikrishnanBalagopal HarikrishnanBalagopal Mar 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why would it impact the UI, it would just become an additional feature supported, isn't it? Having a single flag will help avoiding coordinating between the various ways we can get input, isn't it?

Would like expose this feature in the API and UI so that users can provide the URL instead of a zip file for sources and customizations.
If we use a temporary folder it will keep cloning the same repo for every transformation. Making it configurable allows us to clone just once (clone the repo again only if the user tells us to pull some new change).

Having a single flag will help avoiding coordinating between the various ways we can get input, isn't it?

The format you mentioned https://pip.pypa.io/en/stable/topics/vcs-support/ is also valid.
I suggested using a separate flag for simplicity of implementation. It also makes it less likely to accidentally break the default flows we have right now.

destpath := filepath.Join(basepath, destFolder)
_, err := os.Stat(destpath)
if err == nil {
return filepath.Join(destpath, grp.PathWithinRepo), err
Copy link
Contributor

@HarikrishnanBalagopal HarikrishnanBalagopal Mar 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

return nil if there is no error

@venkatbandarupalli
Copy link
Contributor Author

Hello @kmehant I have made the changes suggested by you.

Hello @ashokponkumar. I thank you for the suggestions.

The package (go git) which I am currently utilising in this work does not support the schema that you have mentioned here #998 (comment). It matches against this regex expression (https://github.com/go-git/go-git/blob/bf3471db54b0255ab5b159005069f37528a151b7/internal/url/url.go#L9) and returns an error as unsupported scheme "git+https". Hence, I conclude to use the formats mentioned in the code comment (https://github.com/konveyor/move2kube/pull/998/files#diff-97583a50e7076356ce7fbb5920570a45e7dd64aa07c2b32ca5c70546262f023aR37-R40).

#998 (comment) @ashokponkumar Certainly, I didn't know that we had that in the code, I will utilise that.

@HarikrishnanBalagopal I thank you for the suggestions.

@HarikrishnanBalagopal and @ashokponkumar I have understood both of your approaches for the flag. However, I don't see any conclusion derived from both of your comments for me to work on changes on using the existing -s flag or new flag for this feature. Which one should I move forward with?

@kmehant
Copy link
Member

kmehant commented Mar 28, 2023

@venkatbandarupalli

Please use the format here https://pip.pypa.io/en/stable/topics/vcs-support/ which should essentially be the input format for the user. Then you could extract components out of it and use it for your clone operation.

Please use the existing -s flag to take the git remote path as input. Also, force clone everytime irrespective of the repository being cloned already or not. As Ashok mentioned, use the temp folder path where you would clone the folder.

Can you please extend this work for plan subcommand and also when we use plan and then transform usecase?
Refer : Involved usage and one step usage slides from https://move2kube.konveyor.io/presentation

Once you are ready with the work, can you as well post a video showing the working of the following?

  1. move2kube transform usecase
  2. move2kube plan usecase
  3. move2kube plan and then transform usecase

cc @ashokponkumar @HarikrishnanBalagopal

@kmehant
Copy link
Member

kmehant commented Mar 29, 2023

@venkatbandarupalli Please be careful while adding comments in Golang. Refer to this https://stackoverflow.com/questions/53004291/exported-type-should-have-comment-or-be-unexported-golang-vs-code.

Also, please run make test-style to check linting errors and correct them.

Thank you.

@codecov
Copy link

codecov bot commented Mar 31, 2023

Codecov Report

Patch coverage has no change and project coverage change: -0.07 ⚠️

Comparison is base (205a4f5) 17.66% compared to head (8fa519d) 17.59%.

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #998      +/-   ##
==========================================
- Coverage   17.66%   17.59%   -0.07%     
==========================================
  Files          63       63              
  Lines        5249     5268      +19     
==========================================
  Hits          927      927              
- Misses       4074     4093      +19     
  Partials      248      248              
Impacted Files Coverage Δ
common/utils.go 1.00% <0.00%> (-0.02%) ⬇️
lib/planner.go 0.00% <0.00%> (ø)
types/plan/planutils.go 0.00% <0.00%> (ø)

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

☔ View full report in Codecov by Sentry.
📢 Do you have feedback about the report comment? Let us know in this issue.

@venkatbandarupalli
Copy link
Contributor Author

@kmehant

Plan and then transform usecase

video1

Transform usecase

video0

cmd/plan.go Outdated
@@ -67,7 +67,8 @@ func planHandler(cmd *cobra.Command, flags planFlags) {
planfile := flags.planfile
srcpath := flags.srcpath
name := flags.name

srcPathStruct := common.GetInputClonedPath(srcpath, common.RemoteSourcesFolder, true)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Line 70 means the following

  1. srcpath could be path on filesystem or git remote path
  2. third argument is meant for overwrite and it is set to true
  3. returned value srcPathStruct is Input struct that holds two values cloned filesystem path and git remote path.
  4. this implementation is backward compatible. If the input is filesystem path from the user, then the input struct will hold the same filesystem path that user provided and remote git path will be an empty string.

Comment on lines 202 to 212
keys := make([]string, 0, len(mapping))
for k := range mapping {
keys = append(keys, k)
}

sort.Slice(keys, func(i, j int) bool {
return len(keys[i]) > len(keys[j])
})

for _, src := range keys {
dest := mapping[src]
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change was discussed with @kmehant.

I have stumbled across a blocker for plan and then transform usecase. 
The problem was with the usage of temp directory to store the remote sources that are cloned. 
In the code here https://github.com/konveyor/move2kube/blob/6aee6e37fdb268e5cf0f25f35ffeba00291cc725/common/pathconverters/pathconverters.go#L191 
a function is used to convert absolute paths in the plan file to relative paths before being written into plan file. 
To this function both temp directory and sources directory are sent. 
The implementation tries to get the relative path with any of the provided parent paths to the paths in the plan file. 
In the case of using remote move2kube sources in the temp dir makes both of these directories as potential parents for the paths in the plan file. 
Due to this reason, I have worked on a workaround where we consider the longest parent paths first and then move to shorter ones. 
So that the most matching parents paths are chosen. 
This workaround worked for me.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@venkatbandarupalli
This might fail in the below case

If these are the two inputs to the function

/a/v/temp/somefolder
/a/v/temp/anotherfolder

If these are the paths in the plan file

/a/v/temp/anotherfolder/someconfig.yaml

Then ordering the paths based on length might result in

/a/v/temp/somefolder
/a/v/temp/anotherfolder

As I see the first one is chosen always if its a parent then the relative path will become

..

However, the relative path should be

. 

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we might better iterate over all the paths and then choose the one have the highest prefix match in that case in the above example, the chosen path will be /a/v/temp/anotherfolder and relative path will be .

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lets get inputs from @ashokponkumar and @HarikrishnanBalagopal as well.

* See the License for the specific language governing permissions and
* limitations under the License.
*/

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This file implements the git vcs feature

Comment on lines +43 to +56
func isGitCommitHash(commithash string) bool {
gitCommitHashRegex := regexp.MustCompile(`^[a-fA-F0-9]{40}$`)
return gitCommitHashRegex.MatchString(commithash)
}

func isGitBranch(branch string) bool {
gitBranchRegex := regexp.MustCompile(`^(main|development|master|(features|tests|(bug|hot)fix)((\/|-)[a-zA-Z0-9]+([-_][a-zA-Z0-9]+)*){1,2}|release(\/|-)[0-9]+(\.[0-9]+)*(-(alpha|beta|rc)[0-9]*)?)$`)
return gitBranchRegex.MatchString(branch)
}

func isGitTag(tag string) bool {
gitTagRegex := regexp.MustCompile(`^v[0-9]+(\.[0-9]+)?(\.[0-9]+)?$`)
return gitTagRegex.MatchString(tag)
}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Used regex for effective matching and extraction of parts of information from the input.

* See the License for the specific language governing permissions and
* limitations under the License.
*/

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This file defines an interface for all the VCS kind of systems that could implement this interface in the future.

Signed-off-by: venkatbandarupalli <vbandarupalli19@gmail.com>
Signed-off-by: venkatbandarupalli <vbandarupalli19@gmail.com>
…kube

Signed-off-by: venkatbandarupalli <vbandarupalli19@gmail.com>
Copy link
Member

@kmehant kmehant left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@kmehant kmehant removed the request for review from HarikrishnanBalagopal April 10, 2023 07:53
@ashokponkumar ashokponkumar merged commit 4bfde1d into konveyor:main Apr 10, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat lfx-project https://lfx.linuxfoundation.org/tools/mentorship/
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants