forked from pothtonswer/discordmuffin
204 lines
4 KiB
Go
204 lines
4 KiB
Go
package discordgo
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////// START OF TESTS
|
|
|
|
// TestChannelMessageSend tests the ChannelMessageSend() function. This should not return an error.
|
|
func TestChannelMessageSend(t *testing.T) {
|
|
|
|
if envChannel == "" {
|
|
t.Skip("Skipping, DG_CHANNEL not set.")
|
|
}
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
|
|
_, err := dg.ChannelMessageSend(envChannel, "Running REST API Tests!")
|
|
if err != nil {
|
|
t.Errorf("ChannelMessageSend returned error: %+v", err)
|
|
}
|
|
}
|
|
|
|
func TestUserAvatar(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot TestUserAvatar, dg not set.")
|
|
}
|
|
|
|
a, err := dg.UserAvatar("@me")
|
|
if err != nil {
|
|
if err.Error() == `HTTP 404 NOT FOUND, {"message": ""}` {
|
|
t.Skip("Skipped, @me doesn't have an Avatar")
|
|
}
|
|
t.Errorf(err.Error())
|
|
}
|
|
|
|
if a == nil {
|
|
t.Errorf("a == nil, should be image.Image")
|
|
}
|
|
}
|
|
|
|
/* Running this causes an error due to 2/hour rate limit on username changes
|
|
func TestUserUpdate(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot test logout, dg not set.")
|
|
}
|
|
|
|
u, err := dg.User("@me")
|
|
if err != nil {
|
|
t.Errorf(err.Error())
|
|
}
|
|
|
|
s, err := dg.UserUpdate(envEmail, envPassword, "testname", u.Avatar, "")
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
if s.Username != "testname" {
|
|
t.Error("Username != testname")
|
|
}
|
|
s, err = dg.UserUpdate(envEmail, envPassword, u.Username, u.Avatar, "")
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
if s.Username != u.Username {
|
|
t.Error("Username != " + u.Username)
|
|
}
|
|
}
|
|
*/
|
|
|
|
//func (s *Session) UserChannelCreate(recipientID string) (st *Channel, err error) {
|
|
|
|
func TestUserChannelCreate(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot TestUserChannelCreate, dg not set.")
|
|
}
|
|
|
|
if envAdmin == "" {
|
|
t.Skip("Skipped, DG_ADMIN not set.")
|
|
}
|
|
|
|
_, err := dg.UserChannelCreate(envAdmin)
|
|
if err != nil {
|
|
t.Errorf(err.Error())
|
|
}
|
|
|
|
// TODO make sure the channel was added
|
|
}
|
|
|
|
func TestUserChannels(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot TestUserChannels, dg not set.")
|
|
}
|
|
|
|
_, err := dg.UserChannels()
|
|
if err != nil {
|
|
t.Errorf(err.Error())
|
|
}
|
|
}
|
|
|
|
func TestUserGuilds(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot TestUserGuilds, dg not set.")
|
|
}
|
|
|
|
_, err := dg.UserGuilds()
|
|
if err != nil {
|
|
t.Errorf(err.Error())
|
|
}
|
|
}
|
|
|
|
func TestUserSettings(t *testing.T) {
|
|
if dg == nil {
|
|
t.Skip("Cannot TestUserSettings, dg not set.")
|
|
}
|
|
|
|
_, err := dg.UserSettings()
|
|
if err != nil {
|
|
t.Errorf(err.Error())
|
|
}
|
|
}
|
|
|
|
// TestLogout tests the Logout() function. This should not return an error.
|
|
func TestLogout(t *testing.T) {
|
|
|
|
if dg == nil {
|
|
t.Skip("Cannot TestLogout, dg not set.")
|
|
}
|
|
|
|
err := dg.Logout()
|
|
if err != nil {
|
|
t.Errorf("Logout() returned error: %+v", err)
|
|
}
|
|
}
|
|
|
|
func TestGateway(t *testing.T) {
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
_, err := dg.Gateway()
|
|
if err != nil {
|
|
t.Errorf("Gateway() returned error: %+v", err)
|
|
}
|
|
}
|
|
|
|
func TestVoiceICE(t *testing.T) {
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
|
|
_, err := dg.VoiceICE()
|
|
if err != nil {
|
|
t.Errorf("VoiceICE() returned error: %+v", err)
|
|
}
|
|
}
|
|
|
|
func TestVoiceRegions(t *testing.T) {
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
|
|
_, err := dg.VoiceRegions()
|
|
if err != nil {
|
|
t.Errorf("VoiceRegions() returned error: %+v", err)
|
|
}
|
|
}
|
|
func TestGuildRoles(t *testing.T) {
|
|
|
|
if envGuild == "" {
|
|
t.Skip("Skipping, DG_GUILD not set.")
|
|
}
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
|
|
_, err := dg.GuildRoles(envGuild)
|
|
if err != nil {
|
|
t.Errorf("GuildRoles(envGuild) returned error: %+v", err)
|
|
}
|
|
|
|
}
|
|
|
|
// TestChannelMessageSend2 tests the ChannelMessageSend() function. This should not return an error.
|
|
func TestChannelMessageSend2(t *testing.T) {
|
|
|
|
if envChannel == "" {
|
|
t.Skip("Skipping, DG_CHANNEL not set.")
|
|
}
|
|
|
|
if dg == nil {
|
|
t.Skip("Skipping, dg not set.")
|
|
}
|
|
|
|
_, err := dg.ChannelMessageSend(envChannel, "All done running REST API Tests!")
|
|
if err != nil {
|
|
t.Errorf("ChannelMessageSend returned error: %+v", err)
|
|
}
|
|
}
|