Exemple #1
0
    def test_ruleset_overwrite(self):
        ruleset = VariableRuleset()

        ruleset.add(VariableRule.parse('@{foo} = /bar'))
        with self.assertRaises(AppArmorException):
            ruleset.add(VariableRule.parse(
                '@{foo} = /asdf'))  # attempt to redefine @{foo}
        self.assertEqual({
            '=': {
                '@{foo}': {'/bar'}
            },
            '+=': {}
        }, ruleset.get_merged_variables())
Exemple #2
0
 def test_dedup_variable_1(self):
     self.pl.add_variable('/etc/apparmor.d/bin.foo',
                          VariableRule.parse('@{foo} = /foo'))
     self.pl.add_variable('/etc/apparmor.d/bin.foo',
                          VariableRule.parse('@{foo} += /bar  # comment'))
     self.pl.add_variable('/etc/apparmor.d/bin.foo',
                          VariableRule.parse('@{foo}    += /bar /baz'))
     deleted = self.pl.delete_preamble_duplicates('/etc/apparmor.d/bin.foo')
     self.assertEqual(deleted, 1)
     self.assertEqual(list(self.pl.files.keys()),
                      ['/etc/apparmor.d/bin.foo'])
     self.assertEqual(self.pl.get_clean('/etc/apparmor.d/bin.foo'),
                      ['@{foo} = /foo', '@{foo} += /bar /baz', ''])
     self.assertEqual(self.pl.get_raw('/etc/apparmor.d/bin.foo'),
                      ['@{foo} = /foo', '@{foo}    += /bar /baz', ''])
Exemple #3
0
    def test_invalid_is_equal(self):
        obj = VariableRule.parse('@{foo} = /bar')

        testobj = BaseRule()  # different type

        with self.assertRaises(AppArmorBug):
            obj.is_equal(testobj)
Exemple #4
0
    def test_borked_obj_is_covered_2(self):
        obj = VariableRule.parse('@{foo} = /bar')

        testobj = VariableRule('@{foo}', '=', {'/bar'})
        testobj.values = ''

        with self.assertRaises(AppArmorBug):
            obj.is_covered(testobj)
Exemple #5
0
    def _run_test(self, param, expected):
        obj = VariableRule.parse(self.rule)
        check_obj = VariableRule.parse(param)

        self.assertTrue(VariableRule.match(param))

        self.assertEqual(obj.is_equal(check_obj), expected[0],
                         'Mismatch in is_equal, expected %s' % expected[0])
        self.assertEqual(
            obj.is_equal(check_obj, True), expected[1],
            'Mismatch in is_equal/strict, expected %s' % expected[1])

        self.assertEqual(obj.is_covered(check_obj), expected[2],
                         'Mismatch in is_covered, expected %s' % expected[2])
        self.assertEqual(
            obj.is_covered(check_obj, True, True), expected[3],
            'Mismatch in is_covered/exact, expected %s' % expected[3])
Exemple #6
0
    def _run_test(self, rawrule, expected):
        self.assertTrue(VariableRule.match(rawrule))
        obj = VariableRule.parse(rawrule)
        clean = obj.get_clean()
        raw = obj.get_raw()

        self.assertEqual(expected.strip(), clean, 'unexpected clean rule')
        self.assertEqual(rawrule.strip(), raw, 'unexpected raw rule')
Exemple #7
0
    def _check_invalid_rawrule(self, rawrule, matches_regex=False):
        obj = None
        self.assertEqual(VariableRule.match(rawrule), matches_regex)
        with self.assertRaises(AppArmorException):
            obj = VariableRule.parse(rawrule)

        self.assertIsNone(obj,
                          'VariableRule handed back an object unexpectedly')
Exemple #8
0
    def test_ruleset_1(self):
        ruleset = VariableRuleset()
        rules = [
            '@{foo} = /bar',
            '@{baz}= /asdf',
            '@{foo}    +=   /whatever',
            '@{foo}    +=   /morestuff',
        ]

        expected_raw = [
            '@{foo} = /bar',
            '@{baz}= /asdf',
            '@{foo}    +=   /whatever',
            '@{foo}    +=   /morestuff',
            '',
        ]

        expected_clean = [
            '@{baz} = /asdf',
            '@{foo} += /morestuff',
            '@{foo} += /whatever',
            '@{foo} = /bar',
            '',
        ]

        expected_clean_unsorted = [
            '@{foo} = /bar',
            '@{baz} = /asdf',
            '@{foo} += /whatever',
            '@{foo} += /morestuff',
            '',
        ]

        expected_merged = {
            '=': {
                '@{foo}': {'/bar'},
                '@{baz}': {'/asdf'},
            },
            '+=': {
                '@{foo}': {'/whatever', '/morestuff'},
            }
        }

        for rule in rules:
            ruleset.add(VariableRule.parse(rule))

        self.assertEqual(expected_raw, ruleset.get_raw())
        self.assertEqual(expected_clean, ruleset.get_clean())
        self.assertEqual(expected_clean_unsorted, ruleset.get_clean_unsorted())
        self.assertEqual(expected_merged, ruleset.get_merged_variables())
Exemple #9
0
 def _run_test(self, rawrule, expected):
     self.assertTrue(VariableRule.match(rawrule))
     obj = VariableRule.parse(rawrule)
     self.assertEqual(rawrule.strip(), obj.raw_rule)
     self._compare_obj(obj, expected)
Exemple #10
0
 def _run_test(self, rawrule, expected):
     self.assertEqual(VariableRule.match(rawrule), expected[0])
     with self.assertRaises(expected[1]):
         VariableRule.parse(rawrule)