t / t1300-repo-config.shon commit Merge branch 'maint' (e2b7eaf)
   1#!/bin/sh
   2#
   3# Copyright (c) 2005 Johannes Schindelin
   4#
   5
   6test_description='Test git config in different settings'
   7
   8. ./test-lib.sh
   9
  10test -f .git/config && rm .git/config
  11
  12git config core.penguin "little blue"
  13
  14cat > expect << EOF
  15[core]
  16        penguin = little blue
  17EOF
  18
  19test_expect_success 'initial' 'cmp .git/config expect'
  20
  21git config Core.Movie BadPhysics
  22
  23cat > expect << EOF
  24[core]
  25        penguin = little blue
  26        Movie = BadPhysics
  27EOF
  28
  29test_expect_success 'mixed case' 'cmp .git/config expect'
  30
  31git config Cores.WhatEver Second
  32
  33cat > expect << EOF
  34[core]
  35        penguin = little blue
  36        Movie = BadPhysics
  37[Cores]
  38        WhatEver = Second
  39EOF
  40
  41test_expect_success 'similar section' 'cmp .git/config expect'
  42
  43git config CORE.UPPERCASE true
  44
  45cat > expect << EOF
  46[core]
  47        penguin = little blue
  48        Movie = BadPhysics
  49        UPPERCASE = true
  50[Cores]
  51        WhatEver = Second
  52EOF
  53
  54test_expect_success 'similar section' 'cmp .git/config expect'
  55
  56test_expect_success 'replace with non-match' \
  57        'git config core.penguin kingpin !blue'
  58
  59test_expect_success 'replace with non-match (actually matching)' \
  60        'git config core.penguin "very blue" !kingpin'
  61
  62cat > expect << EOF
  63[core]
  64        penguin = very blue
  65        Movie = BadPhysics
  66        UPPERCASE = true
  67        penguin = kingpin
  68[Cores]
  69        WhatEver = Second
  70EOF
  71
  72test_expect_success 'non-match result' 'cmp .git/config expect'
  73
  74cat > .git/config << EOF
  75[beta] ; silly comment # another comment
  76noIndent= sillyValue ; 'nother silly comment
  77
  78# empty line
  79                ; comment
  80                haha   ="beta" # last silly comment
  81haha = hello
  82        haha = bello
  83[nextSection] noNewline = ouch
  84EOF
  85
  86cp .git/config .git/config2
  87
  88test_expect_success 'multiple unset' \
  89        'git config --unset-all beta.haha'
  90
  91cat > expect << EOF
  92[beta] ; silly comment # another comment
  93noIndent= sillyValue ; 'nother silly comment
  94
  95# empty line
  96                ; comment
  97[nextSection] noNewline = ouch
  98EOF
  99
 100test_expect_success 'multiple unset is correct' 'cmp .git/config expect'
 101
 102mv .git/config2 .git/config
 103
 104test_expect_success '--replace-all' \
 105        'git config --replace-all beta.haha gamma'
 106
 107cat > expect << EOF
 108[beta] ; silly comment # another comment
 109noIndent= sillyValue ; 'nother silly comment
 110
 111# empty line
 112                ; comment
 113        haha = gamma
 114[nextSection] noNewline = ouch
 115EOF
 116
 117test_expect_success 'all replaced' 'cmp .git/config expect'
 118
 119git config beta.haha alpha
 120
 121cat > expect << EOF
 122[beta] ; silly comment # another comment
 123noIndent= sillyValue ; 'nother silly comment
 124
 125# empty line
 126                ; comment
 127        haha = alpha
 128[nextSection] noNewline = ouch
 129EOF
 130
 131test_expect_success 'really mean test' 'cmp .git/config expect'
 132
 133git config nextsection.nonewline wow
 134
 135cat > expect << EOF
 136[beta] ; silly comment # another comment
 137noIndent= sillyValue ; 'nother silly comment
 138
 139# empty line
 140                ; comment
 141        haha = alpha
 142[nextSection]
 143        nonewline = wow
 144EOF
 145
 146test_expect_success 'really really mean test' 'cmp .git/config expect'
 147
 148test_expect_success 'get value' 'test alpha = $(git config beta.haha)'
 149git config --unset beta.haha
 150
 151cat > expect << EOF
 152[beta] ; silly comment # another comment
 153noIndent= sillyValue ; 'nother silly comment
 154
 155# empty line
 156                ; comment
 157[nextSection]
 158        nonewline = wow
 159EOF
 160
 161test_expect_success 'unset' 'cmp .git/config expect'
 162
 163git config nextsection.NoNewLine "wow2 for me" "for me$"
 164
 165cat > expect << EOF
 166[beta] ; silly comment # another comment
 167noIndent= sillyValue ; 'nother silly comment
 168
 169# empty line
 170                ; comment
 171[nextSection]
 172        nonewline = wow
 173        NoNewLine = wow2 for me
 174EOF
 175
 176test_expect_success 'multivar' 'cmp .git/config expect'
 177
 178test_expect_success 'non-match' \
 179        'git config --get nextsection.nonewline !for'
 180
 181test_expect_success 'non-match value' \
 182        'test wow = $(git config --get nextsection.nonewline !for)'
 183
 184test_expect_failure 'ambiguous get' \
 185        'git config --get nextsection.nonewline'
 186
 187test_expect_success 'get multivar' \
 188        'git config --get-all nextsection.nonewline'
 189
 190git config nextsection.nonewline "wow3" "wow$"
 191
 192cat > expect << EOF
 193[beta] ; silly comment # another comment
 194noIndent= sillyValue ; 'nother silly comment
 195
 196# empty line
 197                ; comment
 198[nextSection]
 199        nonewline = wow3
 200        NoNewLine = wow2 for me
 201EOF
 202
 203test_expect_success 'multivar replace' 'cmp .git/config expect'
 204
 205test_expect_failure 'ambiguous value' 'git config nextsection.nonewline'
 206
 207test_expect_failure 'ambiguous unset' \
 208        'git config --unset nextsection.nonewline'
 209
 210test_expect_failure 'invalid unset' \
 211        'git config --unset somesection.nonewline'
 212
 213git config --unset nextsection.nonewline "wow3$"
 214
 215cat > expect << EOF
 216[beta] ; silly comment # another comment
 217noIndent= sillyValue ; 'nother silly comment
 218
 219# empty line
 220                ; comment
 221[nextSection]
 222        NoNewLine = wow2 for me
 223EOF
 224
 225test_expect_success 'multivar unset' 'cmp .git/config expect'
 226
 227test_expect_failure 'invalid key' 'git config inval.2key blabla'
 228
 229test_expect_success 'correct key' 'git config 123456.a123 987'
 230
 231test_expect_success 'hierarchical section' \
 232        'git config Version.1.2.3eX.Alpha beta'
 233
 234cat > expect << EOF
 235[beta] ; silly comment # another comment
 236noIndent= sillyValue ; 'nother silly comment
 237
 238# empty line
 239                ; comment
 240[nextSection]
 241        NoNewLine = wow2 for me
 242[123456]
 243        a123 = 987
 244[Version "1.2.3eX"]
 245        Alpha = beta
 246EOF
 247
 248test_expect_success 'hierarchical section value' 'cmp .git/config expect'
 249
 250cat > expect << EOF
 251beta.noindent=sillyValue
 252nextsection.nonewline=wow2 for me
 253123456.a123=987
 254version.1.2.3eX.alpha=beta
 255EOF
 256
 257test_expect_success 'working --list' \
 258        'git config --list > output && cmp output expect'
 259
 260cat > expect << EOF
 261beta.noindent sillyValue
 262nextsection.nonewline wow2 for me
 263EOF
 264
 265test_expect_success '--get-regexp' \
 266        'git config --get-regexp in > output && cmp output expect'
 267
 268git config --add nextsection.nonewline "wow4 for you"
 269
 270cat > expect << EOF
 271wow2 for me
 272wow4 for you
 273EOF
 274
 275test_expect_success '--add' \
 276        'git config --get-all nextsection.nonewline > output && cmp output expect'
 277
 278cat > .git/config << EOF
 279[novalue]
 280        variable
 281EOF
 282
 283test_expect_success 'get variable with no value' \
 284        'git config --get novalue.variable ^$'
 285
 286echo novalue.variable > expect
 287
 288test_expect_success 'get-regexp variable with no value' \
 289        'git config --get-regexp novalue > output &&
 290         cmp output expect'
 291
 292git config > output 2>&1
 293
 294test_expect_success 'no arguments, but no crash' \
 295        "test $? = 129 && grep usage output"
 296
 297cat > .git/config << EOF
 298[a.b]
 299        c = d
 300EOF
 301
 302git config a.x y
 303
 304cat > expect << EOF
 305[a.b]
 306        c = d
 307[a]
 308        x = y
 309EOF
 310
 311test_expect_success 'new section is partial match of another' 'cmp .git/config expect'
 312
 313git config b.x y
 314git config a.b c
 315
 316cat > expect << EOF
 317[a.b]
 318        c = d
 319[a]
 320        x = y
 321        b = c
 322[b]
 323        x = y
 324EOF
 325
 326test_expect_success 'new variable inserts into proper section' 'cmp .git/config expect'
 327
 328test_expect_success 'alternative GIT_CONFIG (non-existing file should fail)' \
 329        'git config --file non-existing-config -l; test $? != 0'
 330
 331cat > other-config << EOF
 332[ein]
 333        bahn = strasse
 334EOF
 335
 336cat > expect << EOF
 337ein.bahn=strasse
 338EOF
 339
 340GIT_CONFIG=other-config git config -l > output
 341
 342test_expect_success 'alternative GIT_CONFIG' 'cmp output expect'
 343
 344test_expect_success 'alternative GIT_CONFIG (--file)' \
 345        'git config --file other-config -l > output && cmp output expect'
 346
 347GIT_CONFIG=other-config git config anwohner.park ausweis
 348
 349cat > expect << EOF
 350[ein]
 351        bahn = strasse
 352[anwohner]
 353        park = ausweis
 354EOF
 355
 356test_expect_success '--set in alternative GIT_CONFIG' 'cmp other-config expect'
 357
 358cat > .git/config << EOF
 359# Hallo
 360        #Bello
 361[branch "eins"]
 362        x = 1
 363[branch.eins]
 364        y = 1
 365        [branch "1 234 blabl/a"]
 366weird
 367EOF
 368
 369test_expect_success "rename section" \
 370        "git config --rename-section branch.eins branch.zwei"
 371
 372cat > expect << EOF
 373# Hallo
 374        #Bello
 375[branch "zwei"]
 376        x = 1
 377[branch "zwei"]
 378        y = 1
 379        [branch "1 234 blabl/a"]
 380weird
 381EOF
 382
 383test_expect_success "rename succeeded" "git diff expect .git/config"
 384
 385test_expect_failure "rename non-existing section" \
 386        'git config --rename-section branch."world domination" branch.drei'
 387
 388test_expect_success "rename succeeded" "git diff expect .git/config"
 389
 390test_expect_success "rename another section" \
 391        'git config --rename-section branch."1 234 blabl/a" branch.drei'
 392
 393cat > expect << EOF
 394# Hallo
 395        #Bello
 396[branch "zwei"]
 397        x = 1
 398[branch "zwei"]
 399        y = 1
 400[branch "drei"]
 401weird
 402EOF
 403
 404test_expect_success "rename succeeded" "git diff expect .git/config"
 405
 406cat >> .git/config << EOF
 407  [branch "zwei"] a = 1 [branch "vier"]
 408EOF
 409
 410test_expect_success "remove section" "git config --remove-section branch.zwei"
 411
 412cat > expect << EOF
 413# Hallo
 414        #Bello
 415[branch "drei"]
 416weird
 417EOF
 418
 419test_expect_success "section was removed properly" \
 420        "git diff -u expect .git/config"
 421
 422rm .git/config
 423
 424cat > expect << EOF
 425[gitcvs]
 426        enabled = true
 427        dbname = %Ggitcvs2.%a.%m.sqlite
 428[gitcvs "ext"]
 429        dbname = %Ggitcvs1.%a.%m.sqlite
 430EOF
 431
 432test_expect_success 'section ending' '
 433
 434        git config gitcvs.enabled true &&
 435        git config gitcvs.ext.dbname %Ggitcvs1.%a.%m.sqlite &&
 436        git config gitcvs.dbname %Ggitcvs2.%a.%m.sqlite &&
 437        cmp .git/config expect
 438
 439'
 440
 441test_expect_success numbers '
 442
 443        git config kilo.gram 1k &&
 444        git config mega.ton 1m &&
 445        k=$(git config --int --get kilo.gram) &&
 446        test z1024 = "z$k" &&
 447        m=$(git config --int --get mega.ton) &&
 448        test z1048576 = "z$m"
 449'
 450
 451cat > expect << EOF
 452true
 453false
 454true
 455false
 456true
 457false
 458true
 459false
 460EOF
 461
 462test_expect_success bool '
 463
 464        git config bool.true1 01 &&
 465        git config bool.true2 -1 &&
 466        git config bool.true3 YeS &&
 467        git config bool.true4 true &&
 468        git config bool.false1 000 &&
 469        git config bool.false2 "" &&
 470        git config bool.false3 nO &&
 471        git config bool.false4 FALSE &&
 472        rm -f result &&
 473        for i in 1 2 3 4
 474        do
 475            git config --bool --get bool.true$i >>result
 476            git config --bool --get bool.false$i >>result
 477        done &&
 478        cmp expect result'
 479
 480test_expect_failure 'invalid bool (--get)' '
 481
 482        git config bool.nobool foobar &&
 483        git config --bool --get bool.nobool'
 484
 485test_expect_failure 'invalid bool (set)' '
 486
 487        git config --bool bool.nobool foobar'
 488
 489rm .git/config
 490
 491cat > expect <<\EOF
 492[bool]
 493        true1 = true
 494        true2 = true
 495        true3 = true
 496        true4 = true
 497        false1 = false
 498        false2 = false
 499        false3 = false
 500        false4 = false
 501EOF
 502
 503test_expect_success 'set --bool' '
 504
 505        git config --bool bool.true1 01 &&
 506        git config --bool bool.true2 -1 &&
 507        git config --bool bool.true3 YeS &&
 508        git config --bool bool.true4 true &&
 509        git config --bool bool.false1 000 &&
 510        git config --bool bool.false2 "" &&
 511        git config --bool bool.false3 nO &&
 512        git config --bool bool.false4 FALSE &&
 513        cmp expect .git/config'
 514
 515rm .git/config
 516
 517cat > expect <<\EOF
 518[int]
 519        val1 = 1
 520        val2 = -1
 521        val3 = 5242880
 522EOF
 523
 524test_expect_success 'set --int' '
 525
 526        git config --int int.val1 01 &&
 527        git config --int int.val2 -1 &&
 528        git config --int int.val3 5m &&
 529        cmp expect .git/config'
 530
 531rm .git/config
 532
 533git config quote.leading " test"
 534git config quote.ending "test "
 535git config quote.semicolon "test;test"
 536git config quote.hash "test#test"
 537
 538cat > expect << EOF
 539[quote]
 540        leading = " test"
 541        ending = "test "
 542        semicolon = "test;test"
 543        hash = "test#test"
 544EOF
 545
 546test_expect_success 'quoting' 'cmp .git/config expect'
 547
 548test_expect_failure 'key with newline' 'git config key.with\\\
 549newline 123'
 550
 551test_expect_success 'value with newline' 'git config key.sub value.with\\\
 552newline'
 553
 554cat > .git/config <<\EOF
 555[section]
 556        ; comment \
 557        continued = cont\
 558inued
 559        noncont   = not continued ; \
 560        quotecont = "cont;\
 561inued"
 562EOF
 563
 564cat > expect <<\EOF
 565section.continued=continued
 566section.noncont=not continued
 567section.quotecont=cont;inued
 568EOF
 569
 570git config --list > result
 571
 572test_expect_success 'value continued on next line' 'cmp result expect'
 573
 574cat > .git/config <<\EOF
 575[section "sub=section"]
 576        val1 = foo=bar
 577        val2 = foo\nbar
 578        val3 = \n\n
 579        val4 =
 580        val5
 581EOF
 582
 583cat > expect <<\EOF
 584section.sub=section.val1
 585foo=barQsection.sub=section.val2
 586foo
 587barQsection.sub=section.val3
 588
 589
 590Qsection.sub=section.val4
 591Qsection.sub=section.val5Q
 592EOF
 593
 594git config --null --list | tr '[\000]' 'Q' > result
 595echo >>result
 596
 597test_expect_success '--null --list' 'cmp result expect'
 598
 599git config --null --get-regexp 'val[0-9]' | tr '[\000]' 'Q' > result
 600echo >>result
 601
 602test_expect_success '--null --get-regexp' 'cmp result expect'
 603
 604test_expect_success 'symlinked configuration' '
 605
 606        ln -s notyet myconfig &&
 607        GIT_CONFIG=myconfig git config test.frotz nitfol &&
 608        test -h myconfig &&
 609        test -f notyet &&
 610        test "z$(GIT_CONFIG=notyet git config test.frotz)" = znitfol &&
 611        GIT_CONFIG=myconfig git config test.xyzzy rezrov &&
 612        test -h myconfig &&
 613        test -f notyet &&
 614        test "z$(GIT_CONFIG=notyet git config test.frotz)" = znitfol &&
 615        test "z$(GIT_CONFIG=notyet git config test.xyzzy)" = zrezrov
 616
 617'
 618
 619test_done