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

Support clone all repo by ssh protocol in testJob (#4228) #4229

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

Accelerator1996
Copy link
Contributor

No description provided.

@@ -77,6 +80,7 @@ def setupEnv() {
env.EXTERNAL_TEST_CMD=params.EXTERNAL_TEST_CMD ? params.EXTERNAL_TEST_CMD : "mvn clean install"
env.DYNAMIC_COMPILE=params.DYNAMIC_COMPILE ? params.DYNAMIC_COMPILE : false
env.USE_JRE=params.USE_JRE ? params.USE_JRE : false
env.USE_GIT_SSH = params.USE_GIT_SSH ? params.USE_GIT_SSH : false

Choose a reason for hiding this comment

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

Suggested change
env.USE_GIT_SSH = params.USE_GIT_SSH ? params.USE_GIT_SSH : false
env.USE_GIT_SSH = params.USE_GIT_SSH ?: false

@hgeraldino
Copy link

I'm not too familiar on how these tests are run, but an alternative to changing the git clone command everywhere would be to set the URL replacement via git config. Something like:

git config --global url."ssh://".insteadOf "https://"

Now, I don't know if everything is executed within a single Jenkins context or not, so this suggestion might not be valid.

@smlambert smlambert requested review from llxia and renfeiw January 5, 2023 21:26
@Accelerator1996
Copy link
Contributor Author

I'm not too familiar on how these tests are run, but an alternative to changing the git clone command everywhere would be to set the URL replacement via git config. Something like:

git config --global url."ssh://".insteadOf "https://"

Now, I don't know if everything is executed within a single Jenkins context or not, so this suggestion might not be valid.

Thank you for your reply. I think your configuration is fine to run on the machine, but if the test job runs in docker, additional configuration is required.

@llxia
Copy link
Contributor

llxia commented Jan 16, 2023

@Accelerator1996 could you add more details to the issue #4228? I would like to understand the case that you are trying to cover.

Also, we have much more repos than the 3 repo parameters updated in the PR. In theory, a generic solution is much preferred (Hector's suggestion above). What scenario did you encounter in docker so the git config would not work?

@Accelerator1996
Copy link
Contributor Author

@Accelerator1996 could you add more details to the issue #4228? I would like to understand the case that you are trying to cover.

Also, we have much more repos than the 3 repo parameters updated in the PR. In theory, a generic solution is much preferred (Hector's suggestion above). What scenario did you encounter in docker so the git config would not work?

I'm sorry, my answer may be a bit wrong, because I thought his suggestion was to directly modify the machine environment with instructions, obviously I misunderstood. There is no doubt that his advice is very good @hgeraldino ! I think this still needs to increase the parameters of the test job, I will modify this. Thank you very much!

@Accelerator1996
Copy link
Contributor Author

Hello, @hgeraldino @llxia @renfeiw , I modified the code according to your suggestion. I tested locally and it was fine. Please review my PR again. Thank you very much!

Copy link

@hgeraldino hgeraldino left a comment

Choose a reason for hiding this comment

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

Left one comment.

One question I had was if there's any situation in which HTTPS is preferred over git+ssh; if not, would it make sense to make git+ssh the default?

@@ -141,6 +141,15 @@ def setupEnv() {
} else {
sh 'printenv'
}
if ( params.USE_GIT_SSH ) {
def gitGlobalConfig = fileExists('~/.gitconfig') ? sh(script:"git config --global -l", returnStdout:true) : ''
if (!gitGlobalConfig || !gitGlobalConfig.contains('[email protected]:.insteadof')) {

Choose a reason for hiding this comment

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

I think overwriting should be fine, no need to check for this condition. Or even better, do git config --local ... to install the preferences on the current cloned directory (Jenkins workspace for the current build)

Local (repository) level configs take precedence over global ones.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I think overwriting should be fine, no need to check for this condition. Or even better, do git config --local ... to install the preferences on the current cloned directory (Jenkins workspace for the current build)

Local (repository) level configs take precedence over global ones.

But --local can only be used inside a git repository. So I think --global can affects all git downloads.

@Accelerator1996
Copy link
Contributor Author

One question I had was if there's any situation in which HTTPS is preferred over git+ssh; if not, would it make sense to make git+ssh the default?

Maybe this situation will only exist in mainland China. Since we couldn't get overseas arm machines before, we had to use arm machines in mainland China. However, the network between mainland China and Github is very unsmooth. Although we modified our aqa-tests downstream repo to solve the problem, we think that there may be other vendors who also encounter this problem.

@karianna
Copy link
Contributor

karianna commented Nov 5, 2023

@Accelerator1996 Will need a rebase

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants