summaryrefslogtreecommitdiffstats
path: root/app/channel_test.go
diff options
context:
space:
mode:
authorChris <ccbrown112@gmail.com>2017-07-31 08:52:45 -0700
committerHarrison Healey <harrisonmhealey@gmail.com>2017-07-31 11:52:45 -0400
commit72f61ab96aabf65c162c8d94b5b843b5108ee1a9 (patch)
treec80d7158613663a0b3f584a1736ef1cbff72d160 /app/channel_test.go
parent0f786a42d3289df9b4f5bdb4bddb0ecb07631608 (diff)
downloadchat-72f61ab96aabf65c162c8d94b5b843b5108ee1a9.tar.gz
chat-72f61ab96aabf65c162c8d94b5b843b5108ee1a9.tar.bz2
chat-72f61ab96aabf65c162c8d94b5b843b5108ee1a9.zip
make cli team / channel delete operations also delete webhooks and slash commands (#7028)
Diffstat (limited to 'app/channel_test.go')
-rw-r--r--app/channel_test.go66
1 files changed, 66 insertions, 0 deletions
diff --git a/app/channel_test.go b/app/channel_test.go
new file mode 100644
index 000000000..438eb959b
--- /dev/null
+++ b/app/channel_test.go
@@ -0,0 +1,66 @@
+package app
+
+import (
+ "testing"
+
+ "github.com/mattermost/platform/model"
+ "github.com/mattermost/platform/utils"
+)
+
+func TestPermanentDeleteChannel(t *testing.T) {
+ th := Setup().InitBasic()
+
+ incomingWasEnabled := utils.Cfg.ServiceSettings.EnableIncomingWebhooks
+ outgoingWasEnabled := utils.Cfg.ServiceSettings.EnableOutgoingWebhooks
+ utils.Cfg.ServiceSettings.EnableIncomingWebhooks = true
+ utils.Cfg.ServiceSettings.EnableOutgoingWebhooks = true
+ defer func() {
+ utils.Cfg.ServiceSettings.EnableIncomingWebhooks = incomingWasEnabled
+ utils.Cfg.ServiceSettings.EnableOutgoingWebhooks = outgoingWasEnabled
+ }()
+
+ channel, err := CreateChannel(&model.Channel{DisplayName: "deletion-test", Name: "deletion-test", Type: model.CHANNEL_OPEN, TeamId: th.BasicTeam.Id}, false)
+ if err != nil {
+ t.Fatal(err.Error())
+ }
+ defer func() {
+ PermanentDeleteChannel(channel)
+ }()
+
+ incoming, err := CreateIncomingWebhookForChannel(th.BasicUser.Id, channel, &model.IncomingWebhook{ChannelId: channel.Id})
+ if err != nil {
+ t.Fatal(err.Error())
+ }
+ defer DeleteIncomingWebhook(incoming.Id)
+
+ if incoming, err = GetIncomingWebhook(incoming.Id); incoming == nil || err != nil {
+ t.Fatal("unable to get new incoming webhook")
+ }
+
+ outgoing, err := CreateOutgoingWebhook(&model.OutgoingWebhook{
+ ChannelId: channel.Id,
+ TeamId: channel.TeamId,
+ CreatorId: th.BasicUser.Id,
+ CallbackURLs: []string{"http://foo"},
+ })
+ if err != nil {
+ t.Fatal(err.Error())
+ }
+ defer DeleteOutgoingWebhook(outgoing.Id)
+
+ if outgoing, err = GetOutgoingWebhook(outgoing.Id); outgoing == nil || err != nil {
+ t.Fatal("unable to get new outgoing webhook")
+ }
+
+ if err := PermanentDeleteChannel(channel); err != nil {
+ t.Fatal(err.Error())
+ }
+
+ if incoming, err = GetIncomingWebhook(incoming.Id); incoming != nil || err == nil {
+ t.Error("incoming webhook wasn't deleted")
+ }
+
+ if outgoing, err = GetOutgoingWebhook(outgoing.Id); outgoing != nil || err == nil {
+ t.Error("outgoing webhook wasn't deleted")
+ }
+}