[Bug report] includeIf config is not displayed in normal directories

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello,

I've seen this thread:
https://public-inbox.org/git/F55DC360-9C1E-45B9-B8BA-39E1001BD620@xxxxxxxxx/t/#u

and respectfully disagree with the conclusion. Conditionally included
configuration can contain items like core.sshCommand that are required
for git clone while in a normal non-git directory. These should be
displayed properly so users know what configuration they are operating
with.

Also, conditionally included config is acted upon despite not being
displayed. This makes tracking down problems much more difficult.

Further, most complaints online are about user.name and user.email not
being displayed correctly. If those items are in ~/.gitconfig, then
they are displayed in a normal non-git directory by normal git config
commands. This makes conditionally included configuration display
inconsistent with regular configuration display. Inconsistency is bad
and should be fixed.

See 'git bugreport' attached for further information, reproduction steps, etc.

Thanks,
...Stu
Thank you for filling out a Git bug report!
Please answer the following questions to help us understand your issue.

What did you do before the bug happened? (Steps to reproduce your issue)

Set up a conditional include:
vvvvvvvvvv [ ~/.gitconfig ] vvvvvvvvvv
[includeIf "gitdir:~/work/"]
	path = ~/.gitconfig-work
^^^^^^^^^^ [ ~/.gitconfig ] ^^^^^^^^^^

vvvvvvvvvv [ ~/.gitconfig-work ] vvvvvvvvvv
[user]
	name = Stuart MacDonald
	email = stuartm.coding@xxxxxxxxx
[core]
	sshCommand = "ssh -i ~/.ssh/id_rsa.stuartm_github"
^^^^^^^^^^ [ ~/.gitconfig-work ] ^^^^^^^^^^

Make sure ssh is configured properly for github access:
vvvvvvvvvv [ ~/.ssh/config ] vvvvvvvvvv
Host github github.com
  Hostname github.com
  User git
  IdentitiesOnly yes
^^^^^^^^^^ [ ~/.ssh/config ] ^^^^^^^^^^

Run the following commands in a Git bash shell:
$ mkdir ~/work/git-bug-test
$ cd ~/work/git-bug-test
$ git config --show-origin --get-all core.sshCommand 
OBSERVE A: There is no output
$ git clone --recursive git@xxxxxxxxxx:git/git.git
OBSERVE B: The clone succeeds
$ cd git
$ git config --show-origin --get-all core.sshCommand 
file:C:/Users/stuartm/.gitconfig-work        ssh -i ~/.ssh/id_rsa.stuartm_github
OBSERVE C: The configuration item is displayed
$ cd ..
$ git config --show-origin --get-all core.sshCommand 
OBSERVE D: There is no output

NOTE: In the above reproduction steps I've substituted my work email and
employer's private respository (which needs the approrpriate ssh key to be able
to clone) for my public email and a public repository. This means my
reproduction steps aren't an exact reproduction; for an exact reproduction
please substitute an email address and private repository that requires a
configured ssh key to clone.

What did you expect to happen? (Expected behavior)

I expected OBSERVE A and OBSERVE D to match OBSERVE C's output.

What happened instead? (Actual behavior)

There was no output.

What's different between what you expected and what actually happened?

Output vs no output.

Anything else you want to add:

I spent a lot of time yesterday tracking down a problem with my git
configuration that was preventing me from checking out private repositories. The
incorrect "no output" bug caused me to think I had some issue with my
conditional configuration setup and I was trapped in that dead end for too long.

It seems that includeIf is not widely discussed online. This makes it difficult
to find help. I did find
https://stackoverflow.com/questions/43919191/git-2-13-conditional-config-on-windows
which says in part "If its [sic] not git initialized then the includeIf gitdir
functionality will not work." which is actually inaccurate. It does function;
commenting out/in the sshCommand configuration line causes cloning to not work or
work from a normal directory.

Additionally, moving the sshCommand config item into ~/.gitconfig will cause
OBSERVE A and OBSERVE D to produce output. This clearly implicates includeIf
processing as the problem.

I've seen this thread
https://public-inbox.org/git/F55DC360-9C1E-45B9-B8BA-39E1001BD620@xxxxxxxxx/t/#u
and I understand that some config items don't make sense in a normal directory.
However, some do, critically core.sshCommand. Also, if user.name is in the top
level (non-conditional) .gitconfig, then it is reported by git config in a
normal directory whether that makes sense for a normal directory or not.

The minimum fix I'd like to see: conditional includes should be processed and
any configuration items for which use in a normal directory makes sense should
be present and reported properly. Again, critically, this includes
core.sshCommand.

The better fix is to have conditional include processing be at parity with
direction configuration; where a configuration item would be displayed if it was
in a top-level/direct .gitconfig file, then it should also be displayed if it's
conditionally-included. This would make the config system consistent, which is
important for ease of use.
I realise this goes against the sentiment in the git mailing list thread I
linked above. I believe that thread is wrong in its conclusion of "working as
designed".


Please review the rest of the bug report below.
You can delete any lines you don't wish to share.


[System Info]
git version:
git version 2.29.2.windows.2
cpu: x86_64
built from commit: 3464b98ce6803c98bf8fb34390cd150d66e4a0d3
sizeof-long: 4
sizeof-size_t: 8

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux