summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authormarkusheintz@chromium.org <markusheintz@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-09-27 12:05:29 +0000
committermarkusheintz@chromium.org <markusheintz@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-09-27 12:05:29 +0000
commit9bb297aa85d5684b17d11bbcbc26d1a893bbe43f (patch)
treee29560ccc601d295b85711cea980360cd01ed1bd /tools
parent49d24eb92bfe3f6fe1b397d21e7021bd9a20ca65 (diff)
downloadchromium_src-9bb297aa85d5684b17d11bbcbc26d1a893bbe43f.zip
chromium_src-9bb297aa85d5684b17d11bbcbc26d1a893bbe43f.tar.gz
chromium_src-9bb297aa85d5684b17d11bbcbc26d1a893bbe43f.tar.bz2
Change the ADMX/ADML Writer to map policy groups to "category" elements and policies to "policy" element. This will fix issue 55722 for ADMX/ADML policy templates.
BUG=55722 TEST=admx_writer_unittest.py, adml_writer_unittest.py Review URL: http://codereview.chromium.org/3439011 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@60629 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'tools')
-rw-r--r--tools/grit/grit/format/policy_templates/writers/adml_writer.py177
-rw-r--r--tools/grit/grit/format/policy_templates/writers/adml_writer_unittest.py127
-rw-r--r--tools/grit/grit/format/policy_templates/writers/admx_writer.py161
-rw-r--r--tools/grit/grit/format/policy_templates/writers/admx_writer_unittest.py201
-rw-r--r--tools/grit/grit/format/policy_templates/writers/xml_formatted_writer.py9
5 files changed, 341 insertions, 334 deletions
diff --git a/tools/grit/grit/format/policy_templates/writers/adml_writer.py b/tools/grit/grit/format/policy_templates/writers/adml_writer.py
index b18ac39..de4c82d 100644
--- a/tools/grit/grit/format/policy_templates/writers/adml_writer.py
+++ b/tools/grit/grit/format/policy_templates/writers/adml_writer.py
@@ -29,11 +29,6 @@ class ADMLWriter(xml_formatted_writer.XMLFormattedWriter):
# describe the presentation of Policy-Groups and Policies.
_presentation_table_elem = None
- # The active ADML "presentation" element. At any given point in time this
- # contains the "presentation" element for the Policy-Group that is processed.
- _active_presentation_elem = None
-
-
def _AddString(self, parent, id, text):
''' Adds an ADML "string" element to the passed parent. The following
ADML snippet contains an example:
@@ -48,128 +43,61 @@ class ADMLWriter(xml_formatted_writer.XMLFormattedWriter):
string_elem = self.AddElement(parent, 'string', {'id': id})
string_elem.appendChild(self._doc.createTextNode(text))
- def _AddStringPolicy(self, presentation_elem, policy_name, caption):
- '''Generates ADML elements for a String-Policy. A String-Policy does not
- require any ADML "string" elements. The presentation of a String-Policy is
- defined by an ADML "textBox" element. The text-box contains an ADML "label"
- element that contains the text of the text-box label. The following ADML
- snipped shows an example:
-
- <presentation ...>
- ...
- <textBox refId="$(policy_name)">
- <label>$(caption)</label>
- </textBox>
- </presentation>
-
- Args:
- presentation_elem: The ADML "presentation" element of the policy group
- that includes the policy.
- policy_name: Policy name.
- caption: Caption assisiated with the Policy.
- '''
- # A String-Policy requires no additional ADML "string" elements.
-
- # Add ADML "presentation" elements that are required by a String-Policy to
- # the presentation-table.
- textbox_elem = self.AddElement(presentation_elem, 'textBox',
- {'refId': policy_name})
- label_elem = self.AddElement(textbox_elem, 'label')
- label_elem.appendChild(self._doc.createTextNode(caption))
-
- def _AddEnumPolicy(self, string_table_elem, presentation_elem,
- policy_name, caption, items):
- '''Generates ADML elements for an Enum-Policy. For each enum item an ADML
- "string" element is added to the string-table. The presentation of an
- Enum-Policy is defined by the ADML "dropdownList" element. The following
- ADML snippet shows an example:
-
- <stringTable>
- ...
- <string id="$(item_name)">$(description)</string>
- </stringTable>
-
- <presentation ...>
- ...
- <dropdownList refId="$(policy_name)">$(caption)</dropdownlist>
- </presentation>
-
- Args:
- string_table_elem: The ADML "stringTable" element to which the ADML
- "string" elements are added.
- presentation_elem: The ADML "presentation" element of the policy group
- that includes the policy.
- policy_name: Policy name.
- caption: Caption associated with the Policy.
- items: The enum items.
- '''
- # Add ADML "string" elements to the string-table that are required by an
- # Enum-Policy.
- for item in items:
- self._AddString(string_table_elem, item['name'], item['caption'])
-
- # Add ADML "presentation" elements to the presentation-table that are
- # required by an Enum-Policy.
- dropdownlist_elem = self.AddElement(presentation_elem, 'dropdownList',
- {'refId': policy_name})
- dropdownlist_elem.appendChild(self._doc.createTextNode(caption))
-
- def _AddListPolicy(self, string_table_elem, presentation_elem, policy_name,
- caption):
- '''Generates ADML elements for a List-Policy. Each List-Policy requires an
- additional ADML "string" element that contains a description of the items
- that can be added to the list. The presentation of a List-Policy is defined
- by an ADML "listBox" element. The following ADML snippet shows an example:
-
+ def WritePolicy(self, policy):
+ '''Generates the ADML elements for a Policy.
<stringTable>
...
- <string id="$(policy_name)Desc">$(caption)</string>
+ <string id="$(policy_group_name)">$(caption)</string>
+ <string id="$(policy_group_name)_Explain">$(description)</string>
</stringTable>
- <presentation ...>
+ <presentationTables>
...
- <listBox refId="$(policy_name)Desc">$(caption)</listBox>
- </presentation>
-
- Args:
- string_table_elem: The ADML "stringTable" element to which the ADML
- "string" elements are added.
- presentation_elem: The ADML "presentation" element of the policy group
- that includes the policy.
- policy_name: Policy name.
- caption: Caption assisiated with the Policy.
- '''
- # Add ADML "string" elements to the string-table that are required by a
- # List-Policy.
- self._AddString(string_table_elem, policy_name + 'Desc', caption)
-
- # Add ADML "presentation" elements to the presentation-table that are
- # required by a List-Policy.
- listbox_elem = self.AddElement(presentation_elem, 'listBox',
- {'refId': policy_name + 'Desc'})
- listbox_elem.appendChild(self._doc.createTextNode(caption))
-
- def WritePolicy(self, policy):
- '''Generates the ADML elements for a Policy.
+ <presentation id=$(policy_group_name)/>
+ </presentationTables>
Args:
policy: The Policy to generate ADML elements for.
'''
policy_type = policy['type']
policy_name = policy['name']
- presentation_elem = self._active_presentation_elem
- string_table_elem = self._string_table_elem
+ if 'caption' in policy:
+ policy_caption = policy['caption']
+ else:
+ policy_caption = policy_name
+ if 'desc' in policy:
+ policy_description = policy['desc']
+ elif 'desc' in self._active_group:
+ policy_description = self._active_group['desc']
+ else:
+ policy_description = policy_name
+
+ self._AddString(self._string_table_elem, policy_name, policy_caption)
+ self._AddString(self._string_table_elem, policy_name + '_Explain',
+ policy_description)
+ presentation_elem = self.AddElement(
+ self._presentation_table_elem, 'presentation', {'id': policy_name})
+
if policy_type == 'main':
- # Nothing needs to be done for a Main-Policy.
pass
elif policy_type == 'string':
- self._AddStringPolicy(presentation_elem, policy_name, policy['caption'])
+ textbox_elem = self.AddElement(presentation_elem, 'textBox',
+ {'refId': policy_name})
+ label_elem = self.AddElement(textbox_elem, 'label')
+ label_elem.appendChild(self._doc.createTextNode(policy_caption))
elif policy_type == 'enum':
- self._AddEnumPolicy(string_table_elem, presentation_elem, policy_name,
- policy['caption'], policy['items'])
+ for item in policy['items']:
+ self._AddString(self._string_table_elem, item['name'], item['caption'])
+ dropdownlist_elem = self.AddElement(presentation_elem, 'dropdownList',
+ {'refId': policy_name})
+ dropdownlist_elem.appendChild(self._doc.createTextNode(policy_caption))
elif policy_type == 'list':
- self._AddListPolicy(string_table_elem, presentation_elem, policy_name,
- policy['caption'])
+ self._AddString(self._string_table_elem,
+ policy_name + 'Desc',
+ policy_caption)
+ listbox_elem = self.AddElement(presentation_elem, 'listBox',
+ {'refId': policy_name + 'Desc'})
+ listbox_elem.appendChild(self._doc.createTextNode(policy_caption))
else:
raise Exception('Unknown policy type %s.' % policy_type)
@@ -182,30 +110,15 @@ class ADMLWriter(xml_formatted_writer.XMLFormattedWriter):
elements that define the visual presentation of the Policy-Goup's Policies.
The following ADML snippet shows an example:
- <stringTable>
- ...
- <string id="$(policy_group_name)">$(caption)</string>
- <string id="$(policy_group_name)_Explain">$(description)</string>
- </stringTable>
-
- <presentationTables>
- ...
- <presentation id=$(policy_group_name)/>
- </presentationTables>
-
Args:
group: The Policy-Group to generate ADML elements for.
'''
- # Add ADML "string" elements to the string-table that are required by a
- # Policy-Group.
- id = group['name']
- self._AddString(self._string_table_elem, id, group['caption'])
- self._AddString(self._string_table_elem, id + '_Explain', group['desc'])
-
- # Add ADML "presentation" elements to the presentation-table that are
- # required by a Policy-Group.
- self._active_presentation_elem = self.AddElement(
- self._presentation_table_elem, 'presentation', {'id': id})
+ self._active_group = group;
+ if len(group['policies']) > 1:
+ # Add ADML "string" elements to the string-table that are required by a
+ # Policy-Group.
+ id = group['name'] + '_group'
+ self._AddString(self._string_table_elem, id, group['name'])
def _AddBaseStrings(self, string_table_elem, build):
''' Adds ADML "string" elements to the string-table that are referenced by
diff --git a/tools/grit/grit/format/policy_templates/writers/adml_writer_unittest.py b/tools/grit/grit/format/policy_templates/writers/adml_writer_unittest.py
index 6c2a9c2..d6924ca 100644
--- a/tools/grit/grit/format/policy_templates/writers/adml_writer_unittest.py
+++ b/tools/grit/grit/format/policy_templates/writers/adml_writer_unittest.py
@@ -39,23 +39,26 @@ class AdmlWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
called before the method "BeginPolicyGroup" can be called. It initializes
attributes of the writer.
'''
- dom_impl = minidom.getDOMImplementation('')
- writer._doc = dom_impl.createDocument(
- None, 'policyDefinitionRessources', None)
- writer._presentation_table_elem = self.writer.AddElement(
- writer._doc.documentElement, 'presentationTable')
- writer._string_table_elem = self.writer.AddElement(
- writer._doc.documentElement, 'stringTable')
-
- def _InitWriterForAddingPolicies(self, writer):
+ writer.BeginTemplate()
+
+ def _InitWriterForAddingPolicies(self, writer, policy):
'''Initialize the writer for adding policies. This method must be
called before the method "WritePolicy" can be called. It initializes
attributes of the writer.
'''
self._InitWriterForAddingPolicyGroups(writer)
- writer._active_presentation_elem = self.writer.AddElement(
- self.writer._presentation_table_elem, 'presentation',
- {'id': 'PolicyGroupStub'})
+ policy_group = {
+ 'name': 'PolicyGroup',
+ 'caption': 'Test Caption',
+ 'desc': 'This is the test description of the test policy group.',
+ 'policies': policy,
+ }
+ writer.BeginPolicyGroup(policy_group)
+
+ string_elements =\
+ self.writer._string_table_elem.getElementsByTagName('string')
+ for elem in string_elements:
+ self.writer._string_table_elem.removeChild(elem)
def testEmpty(self):
self.writer.BeginTemplate()
@@ -70,64 +73,89 @@ class AdmlWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
self.AssertXMLEquals(output, expected_output)
def testPolicyGroup(self):
- self._InitWriterForAddingPolicyGroups(self.writer)
empty_policy_group = {
'name': 'PolicyGroup',
'caption': 'Test Caption',
'desc': 'This is the test description of the test policy group.',
+ 'policies': [
+ {'name': 'PolicyStub2',
+ 'type': 'main'},
+ {'name': 'PolicyStub1',
+ 'type': 'main'},
+ ],
}
+ self._InitWriterForAddingPolicyGroups(self.writer)
self.writer.BeginPolicyGroup(empty_policy_group)
self.writer.EndPolicyGroup
# Assert generated string elements.
output = self.GetXMLOfChildren(self.writer._string_table_elem)
expected_output = (
- '<string id="PolicyGroup">\n Test Caption\n</string>\n<string'
- ' id="PolicyGroup_Explain">\n This is the test description of the'
- ' test policy group.\n</string>')
+ '<string id="SUPPORTED_TESTOS">\n'
+ ' Supported on Test OS or higher\n'
+ '</string>\n'
+ '<string id="PolicyGroup_group">\n'
+ ' PolicyGroup\n'
+ '</string>')
self.AssertXMLEquals(output, expected_output)
# Assert generated presentation elements.
output = self.GetXMLOfChildren(self.writer._presentation_table_elem)
- expected_output = '<presentation id="PolicyGroup"/>'
+ expected_output = ''
self.AssertXMLEquals(output, expected_output)
def testMainPolicy(self):
- self. _InitWriterForAddingPolicies(self.writer)
main_policy = {
'name': 'DummyMainPolicy',
'type': 'main',
}
+ self. _InitWriterForAddingPolicies(self.writer, main_policy)
self.writer.WritePolicy(main_policy)
# Assert generated string elements.
output = self.GetXMLOfChildren(self.writer._string_table_elem)
- expected_output = ''
+ expected_output = (
+ '<string id="DummyMainPolicy">\n'
+ ' DummyMainPolicy\n'
+ '</string>\n'
+ '<string id="DummyMainPolicy_Explain">\n'
+ ' This is the test description of the test policy group.\n'
+ '</string>')
self.AssertXMLEquals(output, expected_output)
# Assert generated presentation elements.
- output = self.GetXMLOfChildren(self.writer._active_presentation_elem)
- expected_output = ''
+ output = self.GetXMLOfChildren(self.writer._presentation_table_elem)
+ expected_output = '<presentation id="DummyMainPolicy"/>'
self.AssertXMLEquals(output, expected_output)
def testStringPolicy(self):
- self. _InitWriterForAddingPolicies(self.writer)
string_policy = {
'name': 'StringPolicyStub',
'type': 'string',
'caption': 'String Policy Caption',
'desc': 'This is a test description.',
}
+ self. _InitWriterForAddingPolicies(self.writer, string_policy)
self.writer.WritePolicy(string_policy)
# Assert generated string elements.
output = self.GetXMLOfChildren(self.writer._string_table_elem)
- expected_output = ''
+ expected_output = (
+ '<string id="StringPolicyStub">\n'
+ ' String Policy Caption\n'
+ '</string>\n'
+ '<string id="StringPolicyStub_Explain">\n'
+ ' This is a test description.\n'
+ '</string>')
self.AssertXMLEquals(output, expected_output)
# Assert generated presentation elements.
- output = self.GetXMLOfChildren(self.writer._active_presentation_elem)
+ output = self.GetXMLOfChildren(self.writer._presentation_table_elem)
expected_output = (
- '<textBox refId="StringPolicyStub">\n <label>\n'
- ' String Policy Caption\n </label>\n</textBox>')
+ '<presentation id="StringPolicyStub">\n'
+ ' <textBox refId="StringPolicyStub">\n'
+ ' <label>\n'
+ ' String Policy Caption\n'
+ ' </label>\n'
+ ' </textBox>\n'
+ '</presentation>')
self.AssertXMLEquals(output, expected_output)
def testEnumPolicy(self):
- self. _InitWriterForAddingPolicies(self.writer)
enum_policy = {
'name': 'EnumPolicyStub',
'type': 'enum',
@@ -146,39 +174,64 @@ class AdmlWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
},
],
}
+ self. _InitWriterForAddingPolicies(self.writer, enum_policy)
self.writer.WritePolicy(enum_policy)
# Assert generated string elements.
output = self.GetXMLOfChildren(self.writer._string_table_elem)
expected_output = (
- '<string id="item 1">\n Caption Item 1\n</string>\n<string id="item'
- ' 2">\n Caption Item 2\n</string>')
+ '<string id="EnumPolicyStub">\n'
+ ' Enum Policy Caption\n'
+ '</string>\n'
+ '<string id="EnumPolicyStub_Explain">\n'
+ ' This is a test description.\n'
+ '</string>\n'
+ '<string id="item 1">\n'
+ ' Caption Item 1\n'
+ '</string>\n'
+ '<string id="item 2">\n'
+ ' Caption Item 2\n'
+ '</string>')
self.AssertXMLEquals(output, expected_output)
# Assert generated presentation elements.
- output = self.GetXMLOfChildren(self.writer._active_presentation_elem)
+ output = self.GetXMLOfChildren(self.writer._presentation_table_elem)
expected_output = (
- '<dropdownList refId="EnumPolicyStub">\n Enum Policy Caption\n'
- '</dropdownList>')
+ '<presentation id="EnumPolicyStub">\n'
+ ' <dropdownList refId="EnumPolicyStub">\n'
+ ' Enum Policy Caption\n'
+ ' </dropdownList>\n'
+ '</presentation>')
self.AssertXMLEquals(output, expected_output)
def testListPolicy(self):
- self. _InitWriterForAddingPolicies(self.writer)
list_policy = {
'name': 'ListPolicyStub',
'type': 'list',
'caption': 'List Policy Caption',
'desc': 'This is a test description.',
}
+ self. _InitWriterForAddingPolicies(self.writer, list_policy)
self.writer.WritePolicy(list_policy)
# Assert generated string elements.
output = self.GetXMLOfChildren(self.writer._string_table_elem)
expected_output = (
- '<string id="ListPolicyStubDesc">\n List Policy Caption\n</string>')
+ '<string id="ListPolicyStub">\n'
+ ' List Policy Caption\n'
+ '</string>\n'
+ '<string id="ListPolicyStub_Explain">\n'
+ ' This is a test description.\n'
+ '</string>\n'
+ '<string id="ListPolicyStubDesc">\n'
+ ' List Policy Caption\n'
+ '</string>')
self.AssertXMLEquals(output, expected_output)
# Assert generated presentation elements.
- output = self.GetXMLOfChildren(self.writer._active_presentation_elem)
+ output = self.GetXMLOfChildren(self.writer._presentation_table_elem)
expected_output = (
- '<listBox refId="ListPolicyStubDesc">\n List Policy Caption\n'
- '</listBox>')
+ '<presentation id="ListPolicyStub">\n'
+ ' <listBox refId="ListPolicyStubDesc">\n'
+ ' List Policy Caption\n'
+ ' </listBox>\n'
+ '</presentation>')
self.AssertXMLEquals(output, expected_output)
def testPlatform(self):
diff --git a/tools/grit/grit/format/policy_templates/writers/admx_writer.py b/tools/grit/grit/format/policy_templates/writers/admx_writer.py
index 11a2007..f48680e 100644
--- a/tools/grit/grit/format/policy_templates/writers/admx_writer.py
+++ b/tools/grit/grit/format/policy_templates/writers/admx_writer.py
@@ -26,11 +26,6 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
# are generated.
_active_policies_elem = None
- # The active ADMX "policy" element. At any point in time, the active policy
- # element contains the element being generated for the Policy-Group currently
- # being processed.
- _active_policy_elem = None
-
def _AdmlString(self, name):
'''Creates a reference to the named string in an ADML file.
Args:
@@ -119,12 +114,12 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
for the root level, each level refers to its parent. Since the root
level category has no parent it does not require a parent reference.
'''
- categories_elem = self.AddElement(parent, 'categories')
+ self._categories_elem = self.AddElement(parent, 'categories')
category_name = None
for category in categories:
parent_category_name = category_name
category_name = category
- self._AddCategory(categories_elem, category_name,
+ self._AddCategory(self._categories_elem, category_name,
self._AdmlString(category_name), parent_category_name)
def _AddSupportedOn(self, parent, supported_os):
@@ -155,29 +150,7 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
def _AddStringPolicy(self, parent, name):
'''Generates ADMX elements for a String-Policy and adds them to the
- passed parent node. A String-Policy is mapped to an ADMX "text" element.
- The parent of the ADMX "text" element must be an ADMX "elements" element,
- which must by a child of the ADMX "policy" element that corresponds to the
- Policy-Group that contains the String-Policy. The following example shows
- how the JSON specification of the String-Policy "DisabledPluginsList" of the
- Policy-Group "DisabledPlugins" is mapped to ADMX:
-
- {
- 'name': 'DisabledPlugins',
- 'policies': [{
- 'name': 'DisabledPluginsList',
- 'type' : 'string',
- }, ... ]
- }
-
- <policy ... name="DisabledPlugins" ...>
- ...
- <elements>
- <text id="DisabledPluginsList" valueName="DisabledPluginsList"/>
- ...
- </elements>
- </policy>
-
+ passed parent node.
'''
attributes = {
'id': name,
@@ -187,44 +160,7 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
def _AddEnumPolicy(self, parent, name, items):
'''Generates ADMX elements for an Enum-Policy and adds them to the
- passed parent element. An Enum-Policy is mapped to an ADMX "enum" element.
- The parent of the "enum" element must be the ADMX "elements" element of the
- ADMX "policy" element that corresponds to the Policy-Group that contains the
- Enum-Policy. The following example shows how the JSON specification of the
- Enum-Policy "ProxyServerMode" of the Policy-Group "Proxy" is mapped to ADMX:
-
- {
- 'name': 'Proxy',
- 'policies': [{
- 'name': 'ProxyServerMode',
- 'type': 'enum',
- 'items': [
- {'name': 'ProxyServerDisabled', 'value': '0'},
- {'name': 'ProxyServerAutoDetect', 'value': '1'},
- ...
- ],
- }, ... ]
- }
-
- <policy ... name="Proxy" ...>
- ...
- <elements>
- <enum id="ProxyServerMode" valueName="ProxyServerMode">
- <item displayName="$(string.ProxyServerDisabled)">
- <value>
- <decimal value="0"/>
- </value>
- </item>
- <item displayName="$(string.ProxyServerAutoDetect)">
- <value>
- <decimal value="1"/>
- </value>
- </item>
- ...
- </enum>
- ...
- </elements>
- </policy>
+ passed parent element.
'''
attributes = {
'id': name,
@@ -240,27 +176,7 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
def _AddListPolicy(self, parent, name):
'''Generates ADMX XML elements for a List-Policy and adds them to the
- passed parent element. A List-Policy is mapped to an ADMX "list" element.
- The parent of the "list" element must be the ADMX "elements" element of the
- ADMX "policy" element that corresponds to the Policy-Group that contains the
- List-Policy. The following example shows how the JSON specification of the
- List-Policy "ExtensionInstallBlacklist" of the Policy-Group
- "ExtensionInstallBlacklist" is mapped to ADMX:
-
- {
- 'name': 'ExtensionInstallBlacklist',
- 'policies': [{
- 'name': 'ExtensionInstallBlacklist',
- 'type': 'list',
- }]
- },
-
- <policy ... name="ExtensionInstallBlacklist" ...>
- ...
- <elements>
- <list id="ExtensionInstallBlacklistDesc" valuePrefix=""/>
- </elements>
- </policy>
+ passed parent element.
'''
attributes = {
# The ID must be in sync with ID of the corresponding element in the ADML
@@ -307,46 +223,61 @@ class ADMXWriter(xml_formatted_writer.XMLFormattedWriter):
'''Generates AMDX elements for a Policy. There are four different policy
types: Main-Policy, String-Policy, Enum-Policy and List-Policy.
'''
+ policies_elem = self._active_policies_elem
policy_type = policy['type']
policy_name = policy['name']
+
+ attributes = {
+ 'name': policy_name,
+ 'class': self.config['win_group_policy_class'],
+ 'displayName': self._AdmlString(policy_name),
+ 'explainText': self._AdmlStringExplain(policy_name),
+ 'presentation': self._AdmlPresentation(policy_name),
+ 'key': self.config['win_reg_key_name'],
+ }
+ # Store the current "policy" AMDX element in self for later use by the
+ # WritePolicy method.
+ policy_elem = self.AddElement(policies_elem, 'policy',
+ attributes)
+ self.AddElement(policy_elem, 'parentCategory',
+ {'ref': self._active_policy_group_name})
+ self.AddElement(policy_elem, 'supportedOn',
+ {'ref': self.config['win_supported_os']})
if policy_type == 'main':
- self._AddMainPolicy(self._active_policy_elem)
+ self.AddAttribute(policy_elem, 'valueName', policy_name)
+ self._AddMainPolicy(policy_elem)
elif policy_type == 'string':
- parent = self._GetElements(self._active_policy_elem)
+ parent = self._GetElements(policy_elem)
self._AddStringPolicy(parent, policy_name)
elif policy_type == 'enum':
- parent = self._GetElements(self._active_policy_elem)
+ parent = self._GetElements(policy_elem)
self._AddEnumPolicy(parent, policy_name, policy['items'])
elif policy_type == 'list':
- parent = self._GetElements(self._active_policy_elem)
+ parent = self._GetElements(policy_elem)
self._AddListPolicy(parent, policy_name)
else:
raise Exception('Unknown policy type %s.' % policy_type)
def BeginPolicyGroup(self, group):
- '''Generates ADMX elements for a Policy-Group and adds them to the ADMX
- policies element. A Policy-Group is mapped to an ADMX "policy" element. All
- ADMX policy elements are grouped under the ADMX "policies" element.
+ '''Generates ADMX elements for a Policy-Group.
'''
- policies_elem = self._active_policies_elem
- policy_group_name = group['name']
- attributes = {
- 'name': policy_group_name,
- 'class': self.config['win_group_policy_class'],
- 'displayName': self._AdmlString(policy_group_name),
- 'explainText': self._AdmlStringExplain(policy_group_name),
- 'presentation': self._AdmlPresentation(policy_group_name),
- 'key': self.config['win_reg_key_name'],
- 'valueName': policy_group_name,
- }
- # Store the current "policy" AMDX element in self for later use by the
- # WritePolicy method.
- self._active_policy_elem = self.AddElement(policies_elem, 'policy',
- attributes)
- self.AddElement(self._active_policy_elem, 'parentCategory',
- {'ref': self.config['win_category_path'][-1]})
- self.AddElement(self._active_policy_elem, 'supportedOn',
- {'ref': self.config['win_supported_os']})
+ self._active_policy_group_name = self.config['win_category_path'][-1]
+ # If a policy group contains more than one policy then create a new
+ # category.
+ if len(group['policies']) > 1:
+ policy_group_name = group['name']
+ attributes = {
+ 'name': policy_group_name,
+ 'displayName': self._AdmlString(policy_group_name + '_group'),
+ }
+ category_elem = self.AddElement(self._categories_elem,
+ 'category',
+ attributes)
+ attributes = {
+ 'ref': self.config['win_category_path'][-1],
+ }
+ self.AddElement(category_elem, 'parentCategory', attributes)
+ self._active_policy_group_name = policy_group_name
def BeginTemplate(self):
'''Generates the skeleton of the ADMX template. An ADMX template contains
diff --git a/tools/grit/grit/format/policy_templates/writers/admx_writer_unittest.py b/tools/grit/grit/format/policy_templates/writers/admx_writer_unittest.py
index dcf58b3..04352c7 100644
--- a/tools/grit/grit/format/policy_templates/writers/admx_writer_unittest.py
+++ b/tools/grit/grit/format/policy_templates/writers/admx_writer_unittest.py
@@ -43,60 +43,135 @@ class AdmxWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
self.writer = admx_writer.GetWriter(config, messages)
self.writer.Init()
+ def _GetPoliciesElement(self, doc):
+ node_list = doc.getElementsByTagName('policies')
+ self.assertTrue(node_list.length == 1)
+ return node_list.item(0)
+
+ def _GetCategoriesElement(self, doc):
+ node_list = doc.getElementsByTagName('categories')
+ self.assertTrue(node_list.length == 1)
+ return node_list.item(0)
+
def testEmpty(self):
self.writer.BeginTemplate()
self.writer.EndTemplate()
output = self.writer.GetTemplateText()
expected_output = (
- '<?xml version="1.0" ?>\n<policyDefinitions revision="1.0"'
- ' schemaVersion="1.0">\n <policyNamespaces>\n <target'
- ' namespace="ADMXWriter.Test.Namespace" prefix="test_prefix"/>\n'
- ' <using namespace="Microsoft.Policies.Windows" prefix="windows"/>'
- '\n </policyNamespaces>\n <resources'
- ' minRequiredRevision="1.0"/>\n <supportedOn>\n'
- ' <definitions>\n <definition displayName="'
+ '<?xml version="1.0" ?>\n'
+ '<policyDefinitions revision="1.0" schemaVersion="1.0">\n'
+ ' <policyNamespaces>\n'
+ ' <target namespace="ADMXWriter.Test.Namespace"'
+ ' prefix="test_prefix"/>\n'
+ ' <using namespace="Microsoft.Policies.Windows" prefix="windows"/>\n'
+ ' </policyNamespaces>\n'
+ ' <resources minRequiredRevision="1.0"/>\n'
+ ' <supportedOn>\n'
+ ' <definitions>\n'
+ ' <definition displayName="'
'$(string.SUPPORTED_TESTOS)" name="SUPPORTED_TESTOS"/>\n'
- ' </definitions>\n </supportedOn>\n <categories>\n <category'
- ' displayName="$(string.test_category)" name="test_category"/>\n'
- ' </categories>\n <policies/>\n</policyDefinitions>')
+ ' </definitions>\n'
+ ' </supportedOn>\n'
+ ' <categories>\n'
+ ' <category displayName="$(string.test_category)"'
+ ' name="test_category"/>\n'
+ ' </categories>\n'
+ ' <policies/>\n'
+ '</policyDefinitions>')
self.AssertXMLEquals(output, expected_output)
- def testPolicyGroup(self):
- parent_elem = self._CreateDocumentElement()
- self.writer._active_policies_elem = parent_elem
+ def testEmptyPolicyGroup(self):
+ empty_policy_group = {
+ 'name': 'PolicyGroup',
+ 'policies': []
+ }
+ # Initialize writer to write a policy group.
+ self.writer.BeginTemplate()
+ # Write policy group
+ self.writer.BeginPolicyGroup(empty_policy_group)
+ self.writer.EndPolicyGroup()
+
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
+ expected_output = ''
+ self.AssertXMLEquals(output, expected_output)
+
+ output = self.GetXMLOfChildren(
+ self._GetCategoriesElement(self.writer._doc))
+ expected_output = (
+ '<category displayName="$(string.test_category)"'
+ ' name="test_category"/>')
+ self.AssertXMLEquals(output, expected_output)
+ def testPolicyGroup(self):
empty_policy_group = {
- 'name': 'PolicyGroup'
+ 'name': 'PolicyGroup',
+ 'policies': [
+ {'name': 'PolicyStub2',
+ 'type': 'main'},
+ {'name': 'PolicyStub1',
+ 'type': 'main'},
+ ]
}
+ # Initialize writer to write a policy group.
+ self.writer.BeginTemplate()
+ # Write policy group
self.writer.BeginPolicyGroup(empty_policy_group)
self.writer.EndPolicyGroup()
- output = self.GetXMLOfChildren(parent_elem)
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
+ expected_output = ''
+ self.AssertXMLEquals(output, expected_output)
+
+ output = self.GetXMLOfChildren(
+ self._GetCategoriesElement(self.writer._doc))
expected_output = (
- '<policy class="TestClass" displayName="$(string.PolicyGroup)"'
- ' explainText="$(string.PolicyGroup_Explain)" key='
- '"Software\Policies\Test" name="PolicyGroup"'
- ' presentation="$(presentation.PolicyGroup)" valueName="PolicyGroup">'
- '\n <parentCategory ref="test_category"/>\n'
- ' <supportedOn ref="SUPPORTED_TESTOS"/>\n</policy>')
+ '<category displayName="$(string.test_category)"'
+ ' name="test_category"/>\n'
+ '<category displayName="$(string.PolicyGroup_group)"'
+ ' name="PolicyGroup">\n'
+ ' <parentCategory ref="test_category"/>\n'
+ '</category>')
self.AssertXMLEquals(output, expected_output)
+
+ def _initWriterForPolicy(self, writer, policy):
+ '''Initializes the writer to write the given policy next.
+ '''
+ policy_group = {
+ 'name': 'PolicyGroup',
+ 'policies': [policy]
+ }
+ writer.BeginTemplate()
+ writer.BeginPolicyGroup(policy_group)
+
def testMainPolicy(self):
main_policy = {
'name': 'DummyMainPolicy',
'type': 'main',
}
- parent_elem = self._CreateDocumentElement()
- self.writer._active_policy_elem = parent_elem
+ self._initWriterForPolicy(self.writer, main_policy)
self.writer.WritePolicy(main_policy)
- output = self.GetXMLOfChildren(parent_elem)
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
expected_output = (
- '<enabledValue>\n <decimal value="1"/>\n</enabledValue>\n'
- '<disabledValue>\n <decimal value="0"/>\n</disabledValue>')
+ '<policy class="TestClass" displayName="$(string.DummyMainPolicy)"'
+ ' explainText="$(string.DummyMainPolicy_Explain)"'
+ ' key="Software\\Policies\\Test" name="DummyMainPolicy"'
+ ' presentation="$(presentation.DummyMainPolicy)"'
+ ' valueName="DummyMainPolicy">\n'
+ ' <parentCategory ref="test_category"/>\n'
+ ' <supportedOn ref="SUPPORTED_TESTOS"/>\n'
+ ' <enabledValue>\n'
+ ' <decimal value="1"/>\n'
+ ' </enabledValue>\n'
+ ' <disabledValue>\n'
+ ' <decimal value="0"/>\n'
+ ' </disabledValue>\n'
+ '</policy>')
+
self.AssertXMLEquals(output, expected_output)
def testStringPolicy(self):
@@ -104,21 +179,24 @@ class AdmxWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
'name': 'SampleStringPolicy',
'type': 'string',
}
- parent_elem = self.writer.AddElement(self._CreateDocumentElement(),
- 'policy')
- self.writer._active_policy_elem = parent_elem
+ self._initWriterForPolicy(self.writer, string_policy)
+
self.writer.WritePolicy(string_policy)
- output = self.GetXMLOfChildren(parent_elem)
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
expected_output = (
- '<elements>\n <text id="SampleStringPolicy"'
- ' valueName="SampleStringPolicy"/>\n</elements>')
+ '<policy class="TestClass" displayName="$(string.SampleStringPolicy)"'
+ ' explainText="$(string.SampleStringPolicy_Explain)"'
+ ' key="Software\\Policies\\Test" name="SampleStringPolicy"'
+ ' presentation="$(presentation.SampleStringPolicy)">\n'
+ ' <parentCategory ref="test_category"/>\n'
+ ' <supportedOn ref="SUPPORTED_TESTOS"/>\n'
+ ' <elements>\n'
+ ' <text id="SampleStringPolicy" valueName="SampleStringPolicy"/>\n'
+ ' </elements>\n'
+ '</policy>')
self.AssertXMLEquals(output, expected_output)
def testEnumPolicy(self):
- parent_elem = self.writer.AddElement(self._CreateDocumentElement(),
- 'policy')
- self.writer._active_policy_elem = parent_elem
-
enum_policy = {
'name': 'SampleEnumPolicy',
'type': 'enum',
@@ -127,15 +205,32 @@ class AdmxWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
{'name': 'item 2', 'value': '1'},
]
}
+
+ self._initWriterForPolicy(self.writer, enum_policy)
self.writer.WritePolicy(enum_policy)
- output = self.GetXMLOfChildren(parent_elem)
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
expected_output = (
- '<elements>\n <enum id="SampleEnumPolicy" valueName='
- '"SampleEnumPolicy">\n <item displayName="$(string.item 1)">\n'
- ' <value>\n <decimal value="0"/>\n </value>\n'
- ' </item>\n <item displayName="$(string.item 2)">\n <value>'
- '\n <decimal value="1"/>\n </value>\n </item>'
- '\n </enum>\n</elements>')
+ '<policy class="TestClass" displayName="$(string.SampleEnumPolicy)"'
+ ' explainText="$(string.SampleEnumPolicy_Explain)"'
+ ' key="Software\\Policies\\Test" name="SampleEnumPolicy"'
+ ' presentation="$(presentation.SampleEnumPolicy)">\n'
+ ' <parentCategory ref="test_category"/>\n'
+ ' <supportedOn ref="SUPPORTED_TESTOS"/>\n'
+ ' <elements>\n'
+ ' <enum id="SampleEnumPolicy" valueName="SampleEnumPolicy">\n'
+ ' <item displayName="$(string.item 1)">\n'
+ ' <value>\n'
+ ' <decimal value="0"/>\n'
+ ' </value>\n'
+ ' </item>\n'
+ ' <item displayName="$(string.item 2)">\n'
+ ' <value>\n'
+ ' <decimal value="1"/>\n'
+ ' </value>\n'
+ ' </item>\n'
+ ' </enum>\n'
+ ' </elements>\n'
+ '</policy>')
self.AssertXMLEquals(output, expected_output)
def testListPolicy(self):
@@ -143,15 +238,21 @@ class AdmxWriterTest(xml_writer_base_unittest.XmlWriterBaseTest):
'name': 'SampleListPolicy',
'type': 'list',
}
- parent_elem = self.writer.AddElement(self._CreateDocumentElement(),
- 'policy')
- self.writer._active_policy_elem = parent_elem
+ self._initWriterForPolicy(self.writer, list_policy)
self.writer.WritePolicy(list_policy)
- output = self.GetXMLOfChildren(parent_elem)
+ output = self.GetXMLOfChildren(self._GetPoliciesElement(self.writer._doc))
expected_output = (
- '<elements>\n <list id="SampleListPolicyDesc"'
- ' key="Software\Policies\Test\SampleListPolicy"'
- ' valuePrefix=""/>\n</elements>')
+ '<policy class="TestClass" displayName="$(string.SampleListPolicy)"'
+ ' explainText="$(string.SampleListPolicy_Explain)"'
+ ' key="Software\\Policies\\Test" name="SampleListPolicy"'
+ ' presentation="$(presentation.SampleListPolicy)">\n'
+ ' <parentCategory ref="test_category"/>\n'
+ ' <supportedOn ref="SUPPORTED_TESTOS"/>\n'
+ ' <elements>\n'
+ ' <list id="SampleListPolicyDesc"'
+ ' key="Software\Policies\Test\SampleListPolicy" valuePrefix=""/>\n'
+ ' </elements>\n'
+ '</policy>')
self.AssertXMLEquals(output, expected_output)
diff --git a/tools/grit/grit/format/policy_templates/writers/xml_formatted_writer.py b/tools/grit/grit/format/policy_templates/writers/xml_formatted_writer.py
index f038f2e..ad415d4 100644
--- a/tools/grit/grit/format/policy_templates/writers/xml_formatted_writer.py
+++ b/tools/grit/grit/format/policy_templates/writers/xml_formatted_writer.py
@@ -43,3 +43,12 @@ class XMLFormattedWriter(template_writer.TemplateWriter):
'''
doc = parent.ownerDocument
parent.appendChild(doc.createTextNode(text))
+
+ def AddAttribute(self, parent, name, value):
+ '''Adds a new attribute to the parent Element. If an attribute with the
+ given name already exists then it will be replaced.
+ '''
+ doc = parent.ownerDocument
+ attribute = doc.createAttribute(name)
+ attribute.value = value
+ parent.setAttributeNode(attribute)