123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- package discordgo
- import (
- "os"
- "runtime"
- "testing"
- "time"
- )
- var (
- dg *Session
- envToken = os.Getenv("DG_TOKEN")
- envEmail = os.Getenv("DG_EMAIL")
- envPassword = os.Getenv("DG_PASSWORD")
-
- envChannel = os.Getenv("DG_CHANNEL")
-
- envAdmin = os.Getenv("DG_ADMIN")
- )
- func init() {
- if envEmail == "" || envPassword == "" || envToken == "" {
- return
- }
- if d, err := New(envEmail, envPassword, envToken); err == nil {
- dg = d
- }
- }
- func waitBoolEqual(timeout time.Duration, check *bool, want bool) bool {
- start := time.Now()
- for {
- if *check == want {
- return true
- }
- if time.Since(start) > timeout {
- return false
- }
- runtime.Gosched()
- }
- }
- func isConnected() bool {
- if dg == nil {
- return false
- }
- if dg.Token == "" {
- return false
- }
-
- if !waitBoolEqual(10*time.Second, &dg.DataReady, true) {
- return false
- }
- return true
- }
- func TestNew(t *testing.T) {
- _, err := New()
- if err != nil {
- t.Errorf("New() returned error: %+v", err)
- }
- }
- func TestInvalidToken(t *testing.T) {
- d, err := New("asjkldhflkjasdh")
- if err != nil {
- t.Fatalf("New(InvalidToken) returned error: %+v", err)
- }
-
- _, err = d.UserSettings()
- if err == nil {
- t.Errorf("New(InvalidToken), d.UserSettings returned nil error.")
- }
- }
- func TestInvalidEmailPass(t *testing.T) {
- _, err := New("invalidemail", "invalidpassword")
- if err == nil {
- t.Errorf("New(InvalidEmail, InvalidPass) returned nil error.")
- }
- }
- func TestInvalidPass(t *testing.T) {
- if envEmail == "" {
- t.Skip("Skipping New(username,InvalidPass), DG_EMAIL not set")
- return
- }
- _, err := New(envEmail, "invalidpassword")
- if err == nil {
- t.Errorf("New(Email, InvalidPass) returned nil error.")
- }
- }
- func TestNewUserPass(t *testing.T) {
- if envEmail == "" || envPassword == "" {
- t.Skip("Skipping New(username,password), DG_EMAIL or DG_PASSWORD not set")
- return
- }
- d, err := New(envEmail, envPassword)
- if err != nil {
- t.Fatalf("New(user,pass) returned error: %+v", err)
- }
- if d == nil {
- t.Fatal("New(user,pass), d is nil, should be Session{}")
- }
- if d.Token == "" {
- t.Fatal("New(user,pass), d.Token is empty, should be a valid Token.")
- }
- }
- func TestNewToken(t *testing.T) {
- if envToken == "" {
- t.Skip("Skipping New(token), DG_TOKEN not set")
- }
- d, err := New(envToken)
- if err != nil {
- t.Fatalf("New(envToken) returned error: %+v", err)
- }
- if d == nil {
- t.Fatal("New(envToken), d is nil, should be Session{}")
- }
- if d.Token == "" {
- t.Fatal("New(envToken), d.Token is empty, should be a valid Token.")
- }
- }
- func TestNewUserPassToken(t *testing.T) {
- if envEmail == "" || envPassword == "" || envToken == "" {
- t.Skip("Skipping New(username,password,token), DG_EMAIL, DG_PASSWORD or DG_TOKEN not set")
- return
- }
- d, err := New(envEmail, envPassword, envToken)
- if err != nil {
- t.Fatalf("New(user,pass,token) returned error: %+v", err)
- }
- if d == nil {
- t.Fatal("New(user,pass,token), d is nil, should be Session{}")
- }
- if d.Token == "" {
- t.Fatal("New(user,pass,token), d.Token is empty, should be a valid Token.")
- }
- }
- func TestOpenClose(t *testing.T) {
- if envToken == "" {
- t.Skip("Skipping TestClose, DG_TOKEN not set")
- }
- d, err := New(envToken)
- if err != nil {
- t.Fatalf("TestClose, New(envToken) returned error: %+v", err)
- }
- if err = d.Open(); err != nil {
- t.Fatalf("TestClose, d.Open failed: %+v", err)
- }
- if !waitBoolEqual(10*time.Second, &d.DataReady, true) {
- t.Fatal("DataReady never became true.")
- }
-
-
-
-
- time.Sleep(2 * time.Second)
-
-
-
- if err = d.UpdateStatus(0, time.Now().String()); err != nil {
- t.Errorf("UpdateStatus error: %+v", err)
- }
- if err = d.Close(); err != nil {
- t.Fatalf("TestClose, d.Close failed: %+v", err)
- }
- }
- func TestAddHandler(t *testing.T) {
- testHandlerCalled := 0
- testHandler := func(s *Session, m *MessageCreate) {
- testHandlerCalled++
- }
- interfaceHandlerCalled := 0
- interfaceHandler := func(s *Session, i interface{}) {
- interfaceHandlerCalled++
- }
- bogusHandlerCalled := false
- bogusHandler := func(s *Session, se *Session) {
- bogusHandlerCalled = true
- }
- d := Session{}
- d.AddHandler(testHandler)
- d.AddHandler(testHandler)
- d.AddHandler(interfaceHandler)
- d.AddHandler(bogusHandler)
- d.handle(&MessageCreate{})
- d.handle(&MessageDelete{})
-
- if testHandlerCalled != 2 {
- t.Fatalf("testHandler was not called twice.")
- }
-
- if interfaceHandlerCalled != 2 {
- t.Fatalf("interfaceHandler was not called twice.")
- }
- if bogusHandlerCalled {
- t.Fatalf("bogusHandler was called.")
- }
- }
- func TestRemoveHandler(t *testing.T) {
- testHandlerCalled := 0
- testHandler := func(s *Session, m *MessageCreate) {
- testHandlerCalled++
- }
- d := Session{}
- r := d.AddHandler(testHandler)
- d.handle(&MessageCreate{})
- r()
- d.handle(&MessageCreate{})
- if testHandlerCalled != 1 {
- t.Fatalf("testHandler was not called once.")
- }
- }
|