|
@@ -2,11 +2,14 @@ require 'spec_helper'
|
|
|
|
|
|
describe Agents::SlackAgent do
|
|
|
before(:each) do
|
|
|
+ @fallback = "Its going to rain"
|
|
|
+ @attachments = [{'fallback' => "{{fallback}}"}]
|
|
|
@valid_params = {
|
|
|
'webhook_url' => 'https://hooks.slack.com/services/random1/random2/token',
|
|
|
'channel' => '#random',
|
|
|
'username' => "{{username}}",
|
|
|
- 'message' => "{{message}}"
|
|
|
+ 'message' => "{{message}}",
|
|
|
+ 'attachments' => @attachments
|
|
|
}
|
|
|
|
|
|
@checker = Agents::SlackAgent.new(:name => "slacker", :options => @valid_params)
|
|
@@ -15,7 +18,7 @@ describe Agents::SlackAgent do
|
|
|
|
|
|
@event = Event.new
|
|
|
@event.agent = agents(:bob_weather_agent)
|
|
|
- @event.payload = { :channel => '#random', :message => 'Looks like its going to rain', username: "Huggin user"}
|
|
|
+ @event.payload = { :channel => '#random', :message => 'Looks like its going to rain', username: "Huggin user", fallback: @fallback}
|
|
|
@event.save!
|
|
|
end
|
|
|
|
|
@@ -44,12 +47,22 @@ describe Agents::SlackAgent do
|
|
|
@checker.options['icon_emoji'] = "something"
|
|
|
expect(@checker).to be_valid
|
|
|
end
|
|
|
+
|
|
|
+ it "should allow attachments" do
|
|
|
+ @checker.options['attachments'] = nil
|
|
|
+ expect(@checker).to be_valid
|
|
|
+ @checker.options['attachments'] = []
|
|
|
+ expect(@checker).to be_valid
|
|
|
+ @checker.options['attachments'] = @attachments
|
|
|
+ expect(@checker).to be_valid
|
|
|
+ end
|
|
|
end
|
|
|
|
|
|
describe "#receive" do
|
|
|
it "receive an event without errors" do
|
|
|
any_instance_of(Slack::Notifier) do |obj|
|
|
|
mock(obj).ping(@event.payload[:message],
|
|
|
+ attachments: [{'fallback' => @fallback}],
|
|
|
channel: @event.payload[:channel],
|
|
|
username: @event.payload[:username]
|
|
|
)
|