mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-04-06 10:40:32 -07:00
Some checks failed
EOL CI / EOL Sanity (Ⓐ2.13) (push) Has been cancelled
EOL CI / EOL Sanity (Ⓐ2.14) (push) Has been cancelled
EOL CI / EOL Sanity (Ⓐ2.15) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.13+py2.7) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.13+py3.8) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.14+py3.9) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.15+py3.10) (push) Has been cancelled
EOL CI / EOL Units (Ⓐ2.15+py3.5) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+alpine3+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+alpine3+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+alpine3+py:azp/posix/3/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+fedora35+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+fedora35+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+fedora35+py:azp/posix/3/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+opensuse15py2+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+opensuse15py2+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.13+opensuse15py2+py:azp/posix/3/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.14+alpine3+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.14+alpine3+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.14+alpine3+py:azp/posix/3/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/1/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/2/) (push) Has been cancelled
EOL CI / EOL I (Ⓐ2.15+fedora37+py:azp/posix/3/) (push) Has been cancelled
import-galaxy / Test to import built collection artifact with Galaxy importer (push) Has been cancelled
Verify REUSE / check (push) Has been cancelled
* Unit tests: replace mock and compat with code from community.internal_test_tools (#9921) * Replace compat with equivalent from community.internal_test_tools. * Replace mock with equivalent from community.internal_test_tools. * Remove ignore.txt entries. * Add test that's no longer present in later versions.
108 lines
4 KiB
Python
108 lines
4 KiB
Python
# Copyright (c) Ansible project
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
import json
|
|
import pytest
|
|
from ansible_collections.community.internal_test_tools.tests.unit.compat.mock import patch
|
|
from ansible_collections.community.general.plugins.modules import discord
|
|
from ansible_collections.community.internal_test_tools.tests.unit.plugins.modules.utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase, set_module_args
|
|
|
|
|
|
class TestDiscordModule(ModuleTestCase):
|
|
|
|
def setUp(self):
|
|
super(TestDiscordModule, self).setUp()
|
|
self.module = discord
|
|
|
|
def tearDown(self):
|
|
super(TestDiscordModule, self).tearDown()
|
|
|
|
@pytest.fixture
|
|
def fetch_url_mock(self, mocker):
|
|
return mocker.patch('ansible.module_utils.notification.discord.fetch_url')
|
|
|
|
def test_without_parameters(self):
|
|
"""Failure if no parameters set"""
|
|
with self.assertRaises(AnsibleFailJson):
|
|
with set_module_args({}):
|
|
self.module.main()
|
|
|
|
def test_without_content(self):
|
|
"""Failure if content and embeds both are missing"""
|
|
with set_module_args({
|
|
'webhook_id': 'xxx',
|
|
'webhook_token': 'xxx'
|
|
}):
|
|
with self.assertRaises(AnsibleFailJson):
|
|
self.module.main()
|
|
|
|
def test_successful_message(self):
|
|
"""Test a basic message successfully."""
|
|
with set_module_args({
|
|
'webhook_id': 'xxx',
|
|
'webhook_token': 'xxx',
|
|
'content': 'test'
|
|
}):
|
|
|
|
with patch.object(discord, "fetch_url") as fetch_url_mock:
|
|
fetch_url_mock.return_value = (None, {"status": 204, 'msg': 'OK (0 bytes)'})
|
|
with self.assertRaises(AnsibleExitJson):
|
|
self.module.main()
|
|
|
|
self.assertTrue(fetch_url_mock.call_count, 1)
|
|
call_data = json.loads(fetch_url_mock.call_args[1]['data'])
|
|
assert call_data['content'] == "test"
|
|
|
|
def test_message_with_username(self):
|
|
"""Test a message with username set successfully."""
|
|
with set_module_args({
|
|
'webhook_id': 'xxx',
|
|
'webhook_token': 'xxx',
|
|
'content': 'test',
|
|
'username': 'Ansible Bot'
|
|
}):
|
|
|
|
with patch.object(discord, "fetch_url") as fetch_url_mock:
|
|
fetch_url_mock.return_value = (None, {"status": 204, 'msg': 'OK (0 bytes)'})
|
|
with self.assertRaises(AnsibleExitJson):
|
|
self.module.main()
|
|
|
|
self.assertTrue(fetch_url_mock.call_count, 1)
|
|
call_data = json.loads(fetch_url_mock.call_args[1]['data'])
|
|
assert call_data['username'] == "Ansible Bot"
|
|
assert call_data['content'] == "test"
|
|
|
|
def test_failed_message(self):
|
|
"""Test failure because webhook id is wrong."""
|
|
|
|
with set_module_args({
|
|
'webhook_id': 'wrong',
|
|
'webhook_token': 'xxx',
|
|
'content': 'test'
|
|
}):
|
|
|
|
with patch.object(discord, "fetch_url") as fetch_url_mock:
|
|
fetch_url_mock.return_value = (
|
|
None,
|
|
{"status": 404, 'msg': 'HTTP Error 404: Not Found', 'body': '{"message": "Unknown Webhook", "code": 10015}'},
|
|
)
|
|
with self.assertRaises(AnsibleFailJson):
|
|
self.module.main()
|
|
|
|
def test_failed_message_without_body(self):
|
|
"""Test failure with empty response body."""
|
|
|
|
with set_module_args({
|
|
'webhook_id': 'wrong',
|
|
'webhook_token': 'xxx',
|
|
'content': 'test'
|
|
}):
|
|
|
|
with patch.object(discord, "fetch_url") as fetch_url_mock:
|
|
fetch_url_mock.return_value = (None, {"status": 404, 'msg': 'HTTP Error 404: Not Found'})
|
|
with self.assertRaises(AnsibleFailJson):
|
|
self.module.main()
|