Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

55 lines
1.5KB

  1. package main
  2. import (
  3. "log"
  4. "testing"
  5. "time"
  6. )
  7. func TestSession(t *testing.T) {
  8. id := "testopenid"
  9. procedure := "test procedure"
  10. //delete any existing
  11. deleteSession(id)
  12. path := getSessionPath(id)
  13. AssertEqual(t, isFileExist(path), false, "Session file should not exist")
  14. //create new
  15. original := createEmptySession(id, 100)
  16. original.Procedure = procedure
  17. original.Save()
  18. //wait 1 sec
  19. log.Print("wait for 1 sec for testing timestamp ......")
  20. time.Sleep(1 * time.Second)
  21. log.Print("......waiting done")
  22. //read back , check state
  23. s, _ := getCurrentSesssion(id)
  24. AssertEqual(t, s.Procedure, procedure, "")
  25. now := int32(time.Now().Unix())
  26. //check timing
  27. AssertEqual(t, s.Expire > now, true, "Expire should be in future")
  28. AssertEqual(t, s.UpdateAt < now, true, "Update should be in pass")
  29. AssertEqual(t, s.CreateAt == s.UpdateAt, true, "Update should be equal to create")
  30. AssertEqual(t, isExpired(now), false, "current time should not be expired")
  31. //update existing session
  32. s.setKvPair("key", "value")
  33. s.setKvPair("key1", "value1")
  34. //timeing should be exactly 1s diff
  35. AssertEqual(t, s.CreateAt+1 == s.UpdateAt, true, "second Update should be bigger create")
  36. s.Save()
  37. n, _ := getCurrentSesssion(id)
  38. AssertEqual(t, n.KvPair["key"], "value", "key = value ")
  39. AssertEqual(t, n.KvPair["key1"], "value1", "key1 = value1")
  40. //delete session, for clean up
  41. deleteSession(id)
  42. path = getSessionPath(id)
  43. AssertEqual(t, isFileExist(path), false, "Session file should not exist")
  44. }