]> source.dussan.org Git - gitea.git/commitdiff
use quoted regexp instead of git fixed-value (#20030)
authorwxiaoguang <wxiaoguang@gmail.com>
Sun, 19 Jun 2022 11:55:59 +0000 (19:55 +0800)
committerGitHub <noreply@github.com>
Sun, 19 Jun 2022 11:55:59 +0000 (12:55 +0100)
Backport #20029

modules/git/git.go
modules/git/git_test.go

index 3a3663995b3f0a69b515b7d6b199615d77749c1e..0652a75f9aeff19156634e6ed3f94ec2ee065930 100644 (file)
@@ -11,6 +11,7 @@ import (
        "fmt"
        "os"
        "os/exec"
+       "regexp"
        "runtime"
        "strings"
        "sync"
@@ -337,7 +338,7 @@ func configSetNonExist(key, value string) error {
 }
 
 func configAddNonExist(key, value string) error {
-       _, _, err := NewCommand(DefaultContext, "config", "--fixed-value", "--get", key, value).RunStdString(nil)
+       _, _, err := NewCommand(DefaultContext, "config", "--get", key, regexp.QuoteMeta(value)).RunStdString(nil)
        if err == nil {
                // already exist
                return nil
@@ -357,7 +358,7 @@ func configUnsetAll(key, value string) error {
        _, _, err := NewCommand(DefaultContext, "config", "--get", key).RunStdString(nil)
        if err == nil {
                // exist, need to remove
-               _, _, err = NewCommand(DefaultContext, "config", "--global", "--fixed-value", "--unset-all", key, value).RunStdString(nil)
+               _, _, err = NewCommand(DefaultContext, "config", "--global", "--unset-all", key, regexp.QuoteMeta(value)).RunStdString(nil)
                if err != nil {
                        return fmt.Errorf("failed to unset git global config %s, err: %w", key, err)
                }
index 061c876cde0a18ffb2cf73aa0cfa1da336fb6684..c1a9ec351aaa5bc0395e361ed141560b47f1fd71 100644 (file)
@@ -78,4 +78,10 @@ func TestGitConfig(t *testing.T) {
 
        assert.NoError(t, configUnsetAll("test.key-b", "val-2b"))
        assert.False(t, gitConfigContains("key-b = val-2b"))
+
+       assert.NoError(t, configSet("test.key-x", "*"))
+       assert.True(t, gitConfigContains("key-x = *"))
+       assert.NoError(t, configSetNonExist("test.key-x", "*"))
+       assert.NoError(t, configUnsetAll("test.key-x", "*"))
+       assert.False(t, gitConfigContains("key-x = *"))
 }