Merge "Enhance notification doc generation with samples"

This commit is contained in:
Jenkins
2016-08-03 11:39:39 +00:00
committed by Gerrit Code Review

View File

@@ -27,14 +27,19 @@ from nova.notifications.objects import base as notification
from nova.objects import base
def full_name(cls):
return cls.__module__ + '.' + cls.__name__
class VersionedNotificationDirective(Directive):
LINK_PREFIX = 'https://git.openstack.org/cgit/openstack/nova/plain/'
SAMPLE_ROOT = 'doc/notification_samples/'
TOGGLE_SCRIPT = """
<script>
jQuery(document).ready(function(){
jQuery('#%s-div').toggle('show');
jQuery('#%s-hideshow').on('click', function(event) {
jQuery('#%s-div').toggle('show');
});
});
</script>
"""
def run(self):
notifications = self._collect_notifications()
@@ -52,14 +57,14 @@ class VersionedNotificationDirective(Directive):
payload_name = cls.fields['payload'].objname
payload_cls = ovos[payload_name][0]
for sample in cls.samples:
notifications.append((full_name(cls),
full_name(payload_cls),
notifications.append((cls.__name__,
payload_cls.__name__,
sample))
return notifications
return sorted(notifications)
def _build_markup(self, notifications):
content = []
cols = ['Notification class', 'Payload class', 'Sample file link']
cols = ['Event type', 'Notification class', 'Payload class', 'Sample']
table = nodes.table()
content.append(table)
group = nodes.tgroup(cols=len(cols))
@@ -68,7 +73,7 @@ class VersionedNotificationDirective(Directive):
head = nodes.thead()
group.append(head)
for i in range(len(cols)):
for _ in cols:
group.append(nodes.colspec(colwidth=1))
body = nodes.tbody()
@@ -84,9 +89,16 @@ class VersionedNotificationDirective(Directive):
col.append(text)
# fill the table content, one notification per row
for name, payload, sample in notifications:
for name, payload, sample_file in notifications:
event_type = sample_file[0: -5].replace('-', '.')
row = nodes.row()
body.append(row)
col = nodes.entry()
row.append(col)
text = nodes.literal(text=event_type)
col.append(text)
col = nodes.entry()
row.append(col)
text = nodes.literal(text=name)
@@ -99,12 +111,19 @@ class VersionedNotificationDirective(Directive):
col = nodes.entry()
row.append(col)
ref = nodes.reference(refuri=self.LINK_PREFIX +
self.SAMPLE_ROOT + sample)
txt = nodes.inline()
col.append(txt)
txt.append(ref)
ref.append(nodes.literal(text=sample))
with open(self.SAMPLE_ROOT + sample_file, 'r') as f:
sample_content = f.read()
event_type = sample_file[0: -5]
html_str = self.TOGGLE_SCRIPT % ((event_type, ) * 3)
html_str += ("<input type='button' id='%s-hideshow' "
"value='hide/show sample'>" % event_type)
html_str += ("<div id='%s-div'><pre>%s</pre></div>"
% (event_type, sample_content))
raw = nodes.raw('', html_str, format="html")
col.append(raw)
return content