Esempio n. 1
0
def test_multiple_directories():
    dirs = FileListing(context_wrap(test_file_listing.MULTIPLE_DIRECTORIES))
    assert '/etc/sysconfig' in dirs
    assert 'cbq' in dirs.dirs_of('/etc/sysconfig')
    # drwxr-xr-x.  2 0 0   41 Jul  6 23:32 cbq
    obj = FilePermissions.from_dict(dirs.path_entry('/etc/sysconfig/cbq'))
    assert hasattr(obj, 'name')
    assert obj.name == 'cbq'
    assert obj.perms_owner == 'rwx'
    assert obj.perms_group == 'r-x'
    assert obj.perms_other == 'r-x'
Esempio n. 2
0
def test_single_directory():
    # Mainly just testing that we can read a single directory and
    # recognise it via the path rather than the directory in the output.
    # Testing of the main functionality is mostly done below.
    ctx = context_wrap(SINGLE_DIRECTORY, path='ls_-la_.etc.pki.tls')
    dirs = FileListing(ctx)

    assert '/etc/pki/tls' in dirs
    assert '/etc/pki/tls' in dirs.listings
    assert '/etc/pki/tls/certs' not in dirs
    assert '/etc/pki' not in dirs
    assert '/etc' not in dirs
    assert dirs.listings['/etc/pki/tls']['name'] == '/etc/pki/tls'

    assert dirs.files_of('/etc/pki/tls') == ['cert.pem', 'openssl.cnf']
    assert dirs.dirs_of('/etc/pki/tls') == ['.', '..', 'certs', 'misc', 'private']
    assert dirs.total_of('/etc/pki/tls') == 32
Esempio n. 3
0
def test_multiple_directories():
    dirs = FileListing(context_wrap(MULTIPLE_DIRECTORIES, path='ls_-la_.etc'))

    assert '/etc/sysconfig' in dirs
    assert '/etc/sysconfig' in dirs.listings
    assert '/etc/rc.d/rc3.d' in dirs
    assert '/etc/rc.d/rc4.d' not in dirs

    esc = dirs.listings['/etc/sysconfig']
    assert sorted(esc.keys()) == sorted(['entries', 'files', 'dirs', 'specials', 'total', 'name'])

    assert dirs.files_of('/etc/sysconfig') == ['ebtables-config', 'firewalld', 'grub']
    assert dirs.dirs_of('/etc/sysconfig') == ['.', '..', 'cbq', 'console']
    assert dirs.specials_of('/etc/sysconfig') == []

    # Testing the main features
    listing = dirs.listing_of('/etc/sysconfig')
    assert listing['..'] == {
        'type': 'd', 'perms': 'rwxr-xr-x.', 'links': 77, 'owner': '0',
        'group': '0', 'size': 8192, 'date': 'Jul 13 03:55', 'name': '..',
        'raw_entry': 'drwxr-xr-x. 77 0 0 8192 Jul 13 03:55 ..',
        'dir': '/etc/sysconfig'
    }
    assert listing['cbq'] == {
        'type': 'd', 'perms': 'rwxr-xr-x.', 'links': 2, 'owner': '0',
        'group': '0', 'size': 41, 'date': 'Jul  6 23:32', 'name': 'cbq',
        'raw_entry': 'drwxr-xr-x.  2 0 0   41 Jul  6 23:32 cbq',
        'dir': '/etc/sysconfig'
    }
    assert listing['firewalld'] == {
        'type': '-', 'perms': 'rw-r--r--.', 'links': 1, 'owner': '0',
        'group': '0', 'size': 72, 'date': 'Sep 15  2015',
        'name': 'firewalld', 'raw_entry':
        '-rw-r--r--.  1 0 0   72 Sep 15  2015 firewalld',
        'dir': '/etc/sysconfig'
    }
    assert listing['grub'] == {
        'type': 'l', 'perms': 'rwxrwxrwx.', 'links': 1, 'owner': '0',
        'group': '0', 'size': 17, 'date': 'Jul  6 23:32', 'name': 'grub',
        'link': '/etc/default/grub', 'raw_entry':
        'lrwxrwxrwx.  1 0 0   17 Jul  6 23:32 grub -> /etc/default/grub',
        'dir': '/etc/sysconfig'
    }

    listing = dirs.listing_of('/etc/rc.d/rc3.d')
    assert listing['..'] == {
        'type': 'd', 'perms': 'rwxr-xr-x.', 'links': 10, 'owner': '0',
        'group': '0', 'size': 4096, 'date': 'Sep 16  2015', 'name': '..',
        'raw_entry': 'drwxr-xr-x. 10 0 0 4096 Sep 16  2015 ..',
        'dir': '/etc/rc.d/rc3.d'
    }
    assert listing['K50netconsole'] == {
        'type': 'l', 'perms': 'rwxrwxrwx.', 'links': 1, 'owner': '0',
        'group': '0', 'size': 20, 'date': 'Jul  6 23:32',
        'name': 'K50netconsole', 'link': '../init.d/netconsole', 'raw_entry':
        'lrwxrwxrwx.  1 0 0   20 Jul  6 23:32 K50netconsole -> ../init.d/netconsole',
        'dir': '/etc/rc.d/rc3.d'
    }

    assert dirs.total_of('/etc/sysconfig') == 96
    assert dirs.total_of('/etc/rc.d/rc3.d') == 4

    assert dirs.dir_contains('/etc/sysconfig', 'firewalld')
    assert dirs.dir_entry('/etc/sysconfig', 'grub') == {
        'type': 'l', 'perms': 'rwxrwxrwx.', 'links': 1, 'owner': '0',
        'group': '0', 'size': 17, 'date': 'Jul  6 23:32', 'name': 'grub',
        'link': '/etc/default/grub', 'raw_entry':
        'lrwxrwxrwx.  1 0 0   17 Jul  6 23:32 grub -> /etc/default/grub',
        'dir': '/etc/sysconfig'
    }

    assert dirs.path_entry('/etc/sysconfig/cbq') == {
        'type': 'd', 'perms': 'rwxr-xr-x.', 'links': 2, 'owner': '0',
        'group': '0', 'size': 41, 'date': 'Jul  6 23:32', 'name': 'cbq',
        'raw_entry': 'drwxr-xr-x.  2 0 0   41 Jul  6 23:32 cbq',
        'dir': '/etc/sysconfig'
    }
    assert dirs.path_entry('no_slash') is None
    assert dirs.path_entry('/') is None
    assert dirs.path_entry('/foo') is None
    assert dirs.path_entry('/etc/sysconfig/notfound') is None