move ZFSCli.parse_dataset_identifier to Dataset.from_string
parent
27de066f27
commit
2f5870e7fa
@ -0,0 +1,41 @@
|
|||||||
|
|
||||||
|
from unittest.mock import patch
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from simplezfs.exceptions import ValidationError
|
||||||
|
from simplezfs.types import Dataset, DatasetType
|
||||||
|
from simplezfs.validation import validate_dataset_path
|
||||||
|
|
||||||
|
|
||||||
|
class TestTypesDataset:
|
||||||
|
|
||||||
|
@patch('os.path.exists')
|
||||||
|
@pytest.mark.parametrize('identifier,name,parent,dstype,pool', [
|
||||||
|
('pool/test', 'test', 'pool', DatasetType.FILESET, 'pool'),
|
||||||
|
('pool/test@st', 'test@st', 'pool', DatasetType.SNAPSHOT, 'pool'),
|
||||||
|
('pool/test1/test@snap-12', 'test@snap-12', 'pool/test1', DatasetType.SNAPSHOT, 'pool'),
|
||||||
|
('tank/test#bm1', 'test#bm1', 'tank', DatasetType.BOOKMARK, 'tank'),
|
||||||
|
('tank/test1/test#bmark-12', 'test#bmark-12', 'tank/test1', DatasetType.BOOKMARK, 'tank'),
|
||||||
|
('pool/test2', 'test2', 'pool', DatasetType.VOLUME, 'pool'),
|
||||||
|
('pool/test2/test', 'test', 'pool/test2', DatasetType.VOLUME, 'pool'),
|
||||||
|
])
|
||||||
|
def test_from_string_valid(self, exists, identifier, name, parent, dstype, pool):
|
||||||
|
'''
|
||||||
|
Tests the happy path.
|
||||||
|
'''
|
||||||
|
validate_dataset_path(identifier)
|
||||||
|
|
||||||
|
exists.return_value = dstype == DatasetType.VOLUME
|
||||||
|
|
||||||
|
ds = Dataset.from_string(identifier)
|
||||||
|
assert isinstance(ds, Dataset)
|
||||||
|
assert ds.name == name
|
||||||
|
assert ds.parent == parent
|
||||||
|
assert ds.type == dstype
|
||||||
|
assert ds.full_path == identifier
|
||||||
|
assert ds.pool == pool
|
||||||
|
|
||||||
|
@pytest.mark.parametrize('identifier', [' /asd', ' /asd', '\0/asd', 'mirrored/asd', 'raidz fun/asd'])
|
||||||
|
def test_from_string_invalid(self, identifier):
|
||||||
|
with pytest.raises(ValidationError):
|
||||||
|
Dataset.from_string(identifier)
|
Loading…
Reference in New Issue