forked from irods/irods_rule_engine_plugin_audit_amqp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_audit_plugin.py
84 lines (68 loc) · 2.97 KB
/
test_audit_plugin.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
from __future__ import print_function
import json
import sys
import multiprocessing
import os
import shutil
from . import session
from .. import lib
from queue_listener import QueueListener
if sys.version_info < (2, 7):
import unittest2 as unittest
else:
import unittest
class TestAuditPlugin(unittest.TestCase):
def setUp(self):
# Create a test file
self.largetestfile = "largefile.txt"
lib.make_file(self.largetestfile, 64*1024*1024, 'arbitrary')
with open('/etc/irods/server_config.json') as config_file:
config = json.load(config_file)
rule_engines = config["plugin_configuration"]["rule_engines"]
for rule_engine in rule_engines:
if rule_engine["instance_name"] == "irods_rule_engine_plugin-audit_amqp-instance":
self.url = rule_engine["plugin_specific_configuration"]["amqp_location"]
self.queue_name = rule_engine["plugin_specific_configuration"]["amqp_topic"]
log_directory = rule_engine["plugin_specific_configuration"]["log_path_prefix"]
# create log directory
if not os.path.exists(log_directory):
os.makedirs(log_directory)
def tearDown(self):
filepath = os.path.abspath(self.largetestfile)
if os.path.exists(filepath):
os.unlink(filepath)
def test_audit_plugin(self):
filename = self.largetestfile
with session.make_session_for_existing_admin() as admin_session:
admin_session.assert_icommand('iput -f {filename}'.format(**locals()), 'EMPTY')
admin_session.assert_icommand('iget -f {filename}'.format(**locals()), 'EMPTY')
admin_session.assert_icommand('irm -f {filename}'.format(**locals()), 'EMPTY')
# Establish communication queues
pid_queue = multiprocessing.JoinableQueue()
result_queue = multiprocessing.Queue()
listener = QueueListener(pid_queue, result_queue, self.url, self.queue_name)
listener.run()
print("result queue size is ", result_queue.qsize())
self.assertEqual(0, pid_queue.qsize(), "the joinable queue pid_queue should be empty")
self.assertTrue(1 <= result_queue.qsize(), "the result queue size should at least be one")
for i in range(result_queue.qsize()):
result = result_queue.get()
self.assertEqual(result, 'passed')
def test_delayed_rule_with_plugin_configured(self):
rule_file="test_audit_plugin_delayed_rule.r"
rule_string= '''
test_audit_plugin_delayed_rule {
delay("<PLUSET>1s</PLUSET>") {
i = 0;
}
}
INPUT null
OUTPUT ruleExecOut
'''
with open(rule_file, 'w') as f:
f.write(rule_string)
try:
with session.make_session_for_existing_admin() as admin_session:
admin_session.assert_icommand(['irule', '-r', 'irods_rule_engine_plugin-audit_amqp-instance', '-F', rule_file], 'STDERR', 'SYS_NOT_SUPPORTED')
finally:
os.unlink(rule_file)