Merge pull request #1352 from comwrg/more-cases-validator

add more test cases for `proxy/vmess/validator.go`
pull/1366/head
Victoria Raymond 2018-11-02 09:35:19 +01:00 committed by GitHub
commit 787f37363b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 34 additions and 15 deletions

View File

@ -36,26 +36,45 @@ func TestUserValidator(t *testing.T) {
common.Must(v.Add(user)) common.Must(v.Add(user))
{ {
ts := protocol.Timestamp(time.Now().Unix()) testSmallLag := func(lag time.Duration) {
idHash := hasher(id.Bytes()) ts := protocol.Timestamp(time.Now().Add(time.Second * lag).Unix())
idHash.Write(ts.Bytes(nil)) idHash := hasher(id.Bytes())
userHash := idHash.Sum(nil) idHash.Write(ts.Bytes(nil))
userHash := idHash.Sum(nil)
euser, ets, found := v.Get(userHash) euser, ets, found := v.Get(userHash)
assert(found, IsTrue) assert(found, IsTrue)
assert(euser.Email, Equals, user.Email) assert(euser.Email, Equals, user.Email)
assert(int64(ets), Equals, int64(ts)) assert(int64(ets), Equals, int64(ts))
}
testSmallLag(0)
testSmallLag(40)
testSmallLag(-40)
testSmallLag(80)
testSmallLag(-80)
testSmallLag(120)
testSmallLag(-120)
} }
{ {
ts := protocol.Timestamp(time.Now().Add(time.Second * 500).Unix()) testBigLag := func(lag time.Duration) {
idHash := hasher(id.Bytes()) ts := protocol.Timestamp(time.Now().Add(time.Second * lag).Unix())
idHash.Write(ts.Bytes(nil)) idHash := hasher(id.Bytes())
userHash := idHash.Sum(nil) idHash.Write(ts.Bytes(nil))
userHash := idHash.Sum(nil)
euser, _, found := v.Get(userHash) euser, _, found := v.Get(userHash)
assert(found, IsFalse) assert(found, IsFalse)
assert(euser, IsNil) assert(euser, IsNil)
}
testBigLag(121)
testBigLag(-121)
testBigLag(310)
testBigLag(-310)
testBigLag(500)
testBigLag(-500)
} }
assert(v.Remove(user.Email), IsTrue) assert(v.Remove(user.Email), IsTrue)