From dd32b9eb41d343732a8aa08ca65da9d3eb2518c7 Mon Sep 17 00:00:00 2001 From: CbcWestwolf <1004626265@qq.com> Date: Fri, 2 Dec 2022 05:36:00 +0800 Subject: [PATCH] util: add unit tests for password validation (#39540) ref pingcap/tidb#38928 --- .../password_validation_test.go | 40 ++++++++++++++++++- 1 file changed, 39 insertions(+), 1 deletion(-) diff --git a/util/password-validation/password_validation_test.go b/util/password-validation/password_validation_test.go index 323cba33ba409..8a851b2006203 100644 --- a/util/password-validation/password_validation_test.go +++ b/util/password-validation/password_validation_test.go @@ -29,7 +29,7 @@ func TestValidateDictionaryPassword(t *testing.T) { mock.SessionVars = vars vars.GlobalVarsAccessor = mock - err := mock.SetGlobalSysVar(context.Background(), variable.ValidatePasswordDictionary, "1234;5678;HIJK") + err := mock.SetGlobalSysVar(context.Background(), variable.ValidatePasswordDictionary, "abc;123;1234;5678;HIJK;中文测试;。,;!") require.NoError(t, err) testcases := []struct { pwd string @@ -41,6 +41,8 @@ func TestValidateDictionaryPassword(t *testing.T) { {"abcd12345efg", false}, {"abcd123efghij", true}, {"abcd123efghijk", false}, + {"abcd123efghij中文测试", false}, + {"abcd123。,;!", false}, } for _, testcase := range testcases { ok, err := ValidateDictionaryPassword(testcase.pwd, &vars.GlobalVarsAccessor) @@ -135,3 +137,39 @@ func TestValidatePasswordMediumPolicy(t *testing.T) { require.NoError(t, err) require.Equal(t, "", warn) } + +func TestValidatePassword(t *testing.T) { + sessionVars := variable.NewSessionVars(nil) + sessionVars.GlobalVarsAccessor = variable.NewMockGlobalAccessor4Tests() + sessionVars.GlobalVarsAccessor.(*variable.MockGlobalAccessor).SessionVars = sessionVars + sessionVars.User = &auth.UserIdentity{Username: "user", AuthUsername: "authuser"} + + err := sessionVars.GlobalVarsAccessor.SetGlobalSysVar(context.Background(), variable.ValidatePasswordPolicy, "LOW") + require.NoError(t, err) + err = ValidatePassword(sessionVars, "1234") + require.Error(t, err) + err = ValidatePassword(sessionVars, "user1234") + require.Error(t, err) + err = ValidatePassword(sessionVars, "authuser1234") + require.Error(t, err) + err = ValidatePassword(sessionVars, "User1234") + require.NoError(t, err) + + err = sessionVars.GlobalVarsAccessor.SetGlobalSysVar(context.Background(), variable.ValidatePasswordPolicy, "MEDIUM") + require.NoError(t, err) + err = ValidatePassword(sessionVars, "User1234") + require.Error(t, err) + err = ValidatePassword(sessionVars, "!User1234") + require.NoError(t, err) + err = ValidatePassword(sessionVars, "!User1234") + require.NoError(t, err) + + err = sessionVars.GlobalVarsAccessor.SetGlobalSysVar(context.Background(), variable.ValidatePasswordPolicy, "STRONG") + require.NoError(t, err) + err = sessionVars.GlobalVarsAccessor.SetGlobalSysVar(context.Background(), variable.ValidatePasswordDictionary, "User") + require.NoError(t, err) + err = ValidatePassword(sessionVars, "!User1234") + require.Error(t, err) + err = ValidatePassword(sessionVars, "!ABcd1234") + require.NoError(t, err) +}