salt/tests/unit/modules/test_twilio_notify.py
rallytime 3273bbdab7
Merge branch '2017.7' into '2018.3'
Conflicts:
  - doc/ref/configuration/master.rst
  - doc/ref/modules/all/index.rst
  - doc/topics/grains/index.rst
  - doc/topics/releases/2016.3.4.rst
  - doc/topics/spm/spm_formula.rst
  - doc/topics/tutorials/cron.rst
  - doc/topics/tutorials/index.rst
  - doc/topics/tutorials/stormpath.rst
  - salt/engines/slack.py
  - salt/log/handlers/fluent_mod.py
  - salt/modules/cyg.py
  - salt/modules/junos.py
  - salt/modules/namecheap_dns.py
  - salt/modules/namecheap_domains.py
  - salt/modules/namecheap_ns.py
  - salt/modules/namecheap_ssl.py
  - salt/modules/namecheap_users.py
  - salt/modules/reg.py
  - salt/modules/tomcat.py
  - salt/modules/vault.py
  - salt/modules/win_file.py
  - salt/modules/zpool.py
  - salt/output/highstate.py
  - salt/renderers/pass.py
  - salt/runners/cache.py
  - salt/states/boto_apigateway.py
  - salt/states/boto_iam.py
  - salt/states/boto_route53.py
  - salt/states/msteams.py
  - salt/states/reg.py
  - salt/states/win_iis.py
  - tests/integration/modules/test_cmdmod.py
  - tests/integration/states/test_user.py
  - tests/support/helpers.py
  - tests/unit/cloud/clouds/test_openstack.py
  - tests/unit/fileserver/test_gitfs.py
  - tests/unit/modules/test_junos.py
  - tests/unit/pillar/test_git.py
  - tests/unit/states/test_win_path.py
  - tests/unit/test_pillar.py
  - tests/unit/utils/test_format_call.py
  - tests/unit/utils/test_utils.py
  - tests/unit/utils/test_warnings.py
2018-06-01 14:54:12 -04:00

137 lines
3.9 KiB
Python

# -*- coding: utf-8 -*-
'''
:codeauthor: Jayesh Kariya <jayeshk@saltstack.com>
'''
# Import Python Libs
from __future__ import absolute_import, print_function, unicode_literals
# Import Salt Testing Libs
from tests.support.mixins import LoaderModuleMockMixin
from tests.support.unit import TestCase, skipIf
from tests.support.mock import (
MagicMock,
patch,
NO_MOCK,
NO_MOCK_REASON
)
# Import Salt Libs
import salt.modules.twilio_notify as twilio_notify
HAS_LIBS = False
try:
import twilio
if twilio.__version__ > 5:
TWILIO_5 = False
else:
TWILIO_5 = True
HAS_LIBS = True
except ImportError:
pass
class MockTwilioRestException(Exception):
'''
Mock TwilioRestException class
'''
def __init__(self):
self.code = 'error code'
self.msg = 'Exception error'
self.status = 'Not send'
super(MockTwilioRestException, self).__init__(self.msg)
class MockMessages(object):
'''
Mock SMS class
'''
flag = None
def __init__(self):
self.sid = '011'
self.price = '200'
self.price_unit = '1'
self.status = 'Sent'
self.num_segments = '2'
self.body = None
self.date_sent = '01-01-2015'
self.date_created = '01-01-2015'
self.to = None
self.from_ = None
def create(self, body, to, from_):
'''
Mock create method
'''
msg = MockMessages()
if self.flag == 1:
raise MockTwilioRestException()
msg.body = body
msg.to = to
msg.from_ = from_
return msg
class MockSMS(object):
'''
Mock SMS class
'''
def __init__(self):
self.messages = MockMessages()
class MockTwilioRestClient(object):
'''
Mock TwilioRestClient class
'''
def __init__(self):
if TWILIO_5:
self.sms = MockSMS()
else:
self.messages = MockMessages()
@skipIf(not HAS_LIBS, 'twilio.rest is not available')
@skipIf(NO_MOCK, NO_MOCK_REASON)
class TwilioNotifyTestCase(TestCase, LoaderModuleMockMixin):
'''
Test cases for salt.modules.twilio_notify
'''
def setup_loader_modules(self):
return {
twilio_notify: {
'TwilioRestClient': MockTwilioRestClient,
'TwilioRestException': MockTwilioRestException
}
}
# 'send_sms' function tests: 1
def test_send_sms(self):
'''
Test if it send an sms.
'''
mock = MagicMock(return_value=MockTwilioRestClient())
with patch.object(twilio_notify, '_get_twilio', mock):
self.assertDictEqual(twilio_notify.send_sms('twilio-account',
'SALTSTACK',
'+18019999999',
'+18011111111'),
{'message': {'status': 'Sent',
'num_segments': '2',
'price': '200',
'body': 'SALTSTACK', 'sid': '011',
'date_sent': '01-01-2015',
'date_created': '01-01-2015',
'price_unit': '1'}})
MockMessages.flag = 1
self.assertDictEqual(twilio_notify.send_sms('twilio-account',
'SALTSTACK',
'+18019999999',
'+18011111111'),
{'message': {'sid': None}, '_error':
{'msg': 'Exception error',
'status': 'Not send', 'code': 'error code'}})