// Copyright 2021 PingCAP, Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // See the License for the specific language governing permissions and // limitations under the License. package auth import ( "encoding/hex" "testing" "github.com/stretchr/testify/require" ) func TestCheckShaPasswordGood(t *testing.T) { pwd := "foobar" pwhash, _ := hex.DecodeString("24412430303524031A69251C34295C4B35167C7F1E5A7B63091349503974624D34504B5A424679354856336868686F52485A736E4A733368786E427575516C73446469496537") r, err := CheckShaPassword(pwhash, pwd) require.NoError(t, err) require.True(t, r) } func TestCheckShaPasswordBad(t *testing.T) { pwd := "not_foobar" pwhash, _ := hex.DecodeString("24412430303524031A69251C34295C4B35167C7F1E5A7B63091349503974624D34504B5A424679354856336868686F52485A736E4A733368786E427575516C73446469496537") r, err := CheckShaPassword(pwhash, pwd) require.NoError(t, err) require.False(t, r) } func TestCheckShaPasswordShort(t *testing.T) { pwd := "not_foobar" pwhash, _ := hex.DecodeString("aaaaaaaa") _, err := CheckShaPassword(pwhash, pwd) require.Error(t, err) } func TestCheckShaPasswordDigetTypeIncompatible(t *testing.T) { pwd := "not_foobar" pwhash, _ := hex.DecodeString("24422430303524031A69251C34295C4B35167C7F1E5A7B63091349503974624D34504B5A424679354856336868686F52485A736E4A733368786E427575516C73446469496537") _, err := CheckShaPassword(pwhash, pwd) require.Error(t, err) } func TestCheckShaPasswordIterationsInvalid(t *testing.T) { pwd := "not_foobar" pwhash, _ := hex.DecodeString("24412430304124031A69251C34295C4B35167C7F1E5A7B63091349503974624D34504B5A424679354856336868686F52485A736E4A733368786E427575516C73446469496537") _, err := CheckShaPassword(pwhash, pwd) require.Error(t, err) } // The output from NewSha2Password is not stable as the hash is based on the genrated salt. // This is why CheckShaPassword is used here. func TestNewSha2Password(t *testing.T) { pwd := "testpwd" pwhash := NewSha2Password(pwd) r, err := CheckShaPassword([]byte(pwhash), pwd) require.NoError(t, err) require.True(t, r) for r := range pwhash { require.Less(t, pwhash[r], uint8(128)) require.NotEqual(t, pwhash[r], 0) // NUL require.NotEqual(t, pwhash[r], 36) // '$' } }