Merge "Rewrite ionice command filter using ChainingRegExpFilter"

This commit is contained in:
Jenkins 2014-08-19 22:00:43 +00:00 committed by Gerrit Code Review
commit c8941ececc
2 changed files with 50 additions and 4 deletions

View File

@ -0,0 +1,45 @@
# Copyright (c) 2014 Hitachi Data Systems, Inc.
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import os
import mock
from oslo.rootwrap import wrapper
from cinder import test
class RootwrapFilterTest(test.TestCase):
"""Test cases for etc/cinder/rootwrap.d/volume.filters
"""
def setUp(self):
super(RootwrapFilterTest, self).setUp()
self._filters = wrapper.load_filters(['etc/cinder/rootwrap.d/'])
@mock.patch.object(os, 'access', return_value=True)
def _test_match(self, cmd, mock_access):
filtermatch = wrapper.match_filter(self._filters, cmd,
exec_dirs=['/usr/bin'])
self.assertIsNotNone(filtermatch)
def test_ionice_filter(self):
self._test_match(['ionice', '-c3', 'dd', 'if=/aaa', 'of=/bbb'])
self._test_match(['ionice', '-c2', '-n7', 'dd', 'if=/aaa', 'of=/bbb',
'bs=1M', 'count=1024', 'oflag=direct'])
self._test_match(['ionice', '-c1', 'dd', 'if=/aaa', 'of=/bbb',
'iflag=direct'])
self._test_match(['ionice', '-c0', 'dd', 'if=/aaa', 'of=/bbb',
'convert=datasync'])

View File

@ -41,11 +41,12 @@ iscsiadm: CommandFilter, iscsiadm, root
# cinder/volume/drivers/lvm.py: 'shred', '-n0', '-z', '-s%dMiB'
shred: CommandFilter, shred, root
#cinder/volume/.py: utils.temporary_chown(path, 0), ...
# cinder/volume/utils.py: utils.temporary_chown(path, 0)
chown: CommandFilter, chown, root
ionice_1: RegExpFilter, ionice, root, ionice, -c[0-3]( -n[0-7])?, dd, if=\S+, of=\S+, count=\d+, bs=\S+
ionice_2: RegExpFilter, ionice, root, ionice, -c[0-3]( -n[0-7])?, dd, if=\S+, of=\S+, count=\d+, bs=\S+, iflag=direct, oflag=direct
ionice_3: RegExpFilter, ionice, root, ionice, -c[0-3]( -n[0-7])?, dd, if=\S+, of=\S+, count=\d+, bs=\S+, conv=fdatasync
# cinder/volume/utils.py: copy_volume(..., ionice='...')
ionice_1: ChainingRegExpFilter, ionice, root, ionice, -c[0-3], -n[0-7]
ionice_2: ChainingRegExpFilter, ionice, root, ionice, -c[0-3]
# cinder/volume/utils.py: setup_blkio_cgroup()
cgcreate: CommandFilter, cgcreate, root