Ejemplo n.º 1
0
def test_dataset_has():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    result = {'age': 65} in dataset
    assert result is True
    dataset.add_file(id='1', path='test.txt', type='txt')
    result = {'type': 'txt'} in dataset
    assert result is True
Ejemplo n.º 2
0
def test_dataset_dice_regex():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf')
    dataset.add_file(id='1', path='test.gff', type='gff')
    txt = dataset.dice(type='g[tf]f')
    assert type(txt) == Dataset
    assert len(txt) == 2
Ejemplo n.º 3
0
def test_dataset_dice_regex():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf')
    dataset.add_file(id='1', path='test.gff', type='gff')
    txt = dataset.dice(type='g[tf]f')
    assert type(txt) == Dataset
    assert len(txt) == 2
Ejemplo n.º 4
0
def test_dataset_has():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    result = {'age': 65} in dataset
    assert result is True
    dataset.add_file(id='1', path='test.txt', type='txt')
    result = {'type': 'txt'} in dataset
    assert result is True
Ejemplo n.º 5
0
def test_get_tags_all_w_quotes():
    """Concatenate all metadata tags from dataset"""
    info = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'A test dataset'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    string = dataset.get_tags()
    assert string == "age=65; desc=\"A test dataset\"; id=1; sex=M;"
Ejemplo n.º 6
0
def test_get_tags_only_one():
    """Concatenate metadata tags from dataset with exclusion list"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    string = dataset.get_tags(tags='id')
    assert string == "id=1;"
Ejemplo n.º 7
0
def test_get_tags_only_one():
    """Concatenate metadata tags from dataset with exclusion list"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    string = dataset.get_tags(tags='id')
    assert string == "id=1;"
Ejemplo n.º 8
0
def test_get_tags_all_w_quotes():
    """Concatenate all metadata tags from dataset"""
    info = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'A test dataset'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    string = dataset.get_tags()
    assert string == "age=65; desc=\"A test dataset\"; id=1; sex=M;"
Ejemplo n.º 9
0
def test_rm_file_not_existing_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert len(dataset) == 1
    dataset.rm_file(path='test.pdf')
    assert len(dataset) == 1
Ejemplo n.º 10
0
def test_rm_file_not_existing_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert len(dataset) == 1
    dataset.rm_file(path='test.pdf')
    assert len(dataset) == 1
Ejemplo n.º 11
0
def test_rm_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.rm_file(path='test.txt')
    assert len(dataset) == 1
    assert dataset['test.txt'] is None
Ejemplo n.º 12
0
def test_get_tags_on_merged():
    """Merge metadata from two or more datasets"""
    info1 = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'First test dataset'}
    info2 = {'id': '2', 'sex': 'F', 'age': 61, 'desc': 'Second test dataset'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset1 = Dataset(**info1)
    dataset2 = Dataset(**info2)
    # pylint: enable=W0142
    merged = dataset1.merge(dataset2)
    string = merged.get_tags()
    assert string == '''age=65,61; desc="First test dataset","Second test dataset"; id=1,2; sex=M,F;'''
Ejemplo n.º 13
0
def test_get_tags_on_merged():
    """Merge metadata from two or more datasets"""
    info1 = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'First test dataset'}
    info2 = {'id': '2', 'sex': 'F', 'age': 61, 'desc': 'Second test dataset'}
     # Disable warning about * magic
    # pylint: disable=W0142
    dataset1 = Dataset(**info1)
    dataset2 = Dataset(**info2)
    # pylint: enable=W0142
    merged = dataset1.merge(dataset2)
    string = merged.get_tags()
    assert string == '''age=65,61; desc="First test dataset","Second test dataset"; id=1,2; sex=M,F;'''
Ejemplo n.º 14
0
def test_add_file_no_path():
    """Add file with no path"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 0
Ejemplo n.º 15
0
def test_add_file_no_path():
    """Add file with no path"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 0
Ejemplo n.º 16
0
def test_add_file_missing_values():
    """Add file with no path"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'path': 'test.txt', 'type': 'txt', 'view': ''}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 1
    assert dataset['test.txt'].get('view') == 'NA'
Ejemplo n.º 17
0
def test_add_file_missing_values():
    """Add file with no path"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'path': 'test.txt', 'type': 'txt', 'view': ''}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 1
    assert dataset['test.txt'].get('view') == 'NA'
Ejemplo n.º 18
0
def test_create_dataset_w_path():
    """Create dataset with file path"""
    info = {'id': '1', 'path': 'test.txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert not hasattr(dataset, 'path')
    assert not hasattr(dataset, 'type')
    assert len(dataset) == 1
    assert dataset._files is not None
    assert dataset.get('test.txt') is not None
    assert dataset['test.txt'].get('type') == 'txt'
    assert dataset['test.txt'].get('view') == 'text'
Ejemplo n.º 19
0
def test_create_dataset_w_path():
    """Create dataset with file path"""
    info = {'id': '1', 'path': 'test.txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert not hasattr(dataset, 'path')
    assert not hasattr(dataset, 'type')
    assert len(dataset) == 1
    assert dataset._files is not None
    assert dataset.get('test.txt') is not None
    assert dataset['test.txt'].get('type') == 'txt'
    assert dataset['test.txt'].get('view') == 'text'
Ejemplo n.º 20
0
    def insert(self, update=False, addkeys=False, dataset=None, **kwargs):
        """Add a dataset to the index. Keyword arguments contains the dataset
        attributes.

        :keyword update: specifies whether existing values has to be updated
        :keyword dataset: the :class:`Dataset` to be inserted into the index
        """
        empty_paths = [None, '', '.']

        dsid = self.format.get('id', 'id')

        if 'id' in kwargs:
            kwargs[dsid] = kwargs.pop('id')

        meta = kwargs
        if self.format.get('fileinfo'):
            log.debug('Use file specific keywords from the format')
            meta = dict([(k, v) for k, v in kwargs.items()
                        if k not in self.format.get('fileinfo')])
        if not dataset:
            dataset = Dataset(**meta)

        existing_dataset = self.datasets.get(getattr(dataset, dsid))

        if existing_dataset is not None:
            if update:
                log.debug('Update existing dataset %s', getattr(existing_dataset, dsid))
                for key, val in meta.items():
                    if addkeys or getattr(existing_dataset, key):
                        existing_dataset.__setattr__(key, val)
            dataset = existing_dataset

        if existing_dataset is None:
            if ',' in getattr(dataset, dsid):
                log.info('Gather replicates info for %s', getattr(dataset, dsid))
                reps = self.find_replicates(**kwargs)
                if reps:
                    dataset = reps[0].merge(reps[1:], dsid=dsid)
            self.datasets[getattr(dataset, dsid)] = dataset
            dataset = self.datasets.get(getattr(dataset, dsid))
        else:
            log.debug('Use existing dataset %s', getattr(dataset, dsid))

        if kwargs.get('path') not in empty_paths:
        #if os.path.isfile(kwargs.get('path')):
            log.debug('Add %s to dataset', kwargs.get('path'))
            dataset.add_file(update=update, **kwargs)

        return dataset
Ejemplo n.º 21
0
def test_merge():
    """Merge metadata from two or more datasets"""
    info1 = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'First test dataset'}
    info2 = {'id': '2', 'sex': 'F', 'age': 61, 'desc': 'Second test dataset'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset1 = Dataset(**info1)
    dataset2 = Dataset(**info2)
    # pylint: enable=W0142
    merged = dataset1.merge(dataset2)
    assert merged is not None
    assert merged.id == '1,2'
    assert merged.sex == ['M', 'F']
    assert merged.age == [65, 61]
    assert merged.desc == ['First test dataset', 'Second test dataset']
Ejemplo n.º 22
0
def test_merge():
    """Merge metadata from two or more datasets"""
    info1 = {'id': '1', 'sex': 'M', 'age': 65, 'desc': 'First test dataset'}
    info2 = {'id': '2', 'sex': 'F', 'age': 61, 'desc': 'Second test dataset'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset1 = Dataset(**info1)
    dataset2 = Dataset(**info2)
    # pylint: enable=W0142
    merged = dataset1.merge(dataset2)
    assert merged is not None
    assert merged.id == '1,2'
    assert merged.sex == ['M', 'F']
    assert merged.age == [65, 61]
    assert merged.desc == ['First test dataset', 'Second test dataset']
Ejemplo n.º 23
0
def test_str():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert str(dataset) == 'age=65; id=1; sex=M;'
Ejemplo n.º 24
0
def test_repr():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert repr(dataset) == '(Dataset)'
Ejemplo n.º 25
0
def test_rm_last_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.rm_file(path='test.txt')
    # Disable warning about:
    # - missing pytest.raises.
    # - statement with no effect
    # pylint: disable=E1101,W0104
    with pytest.raises(AttributeError):
        dataset.txt
    # pylint: enable=E1101,W0104
    assert len(dataset) == 0
Ejemplo n.º 26
0
def test_rm_last_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
        # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.rm_file(path='test.txt')
    # Disable warning about:
    # - missing pytest.raises.
    # - statement with no effect
    # pylint: disable=E1101,W0104
    with pytest.raises(AttributeError):
        dataset.txt
    # pylint: enable=E1101,W0104
    assert len(dataset) == 0
Ejemplo n.º 27
0
def test_dataset_dice_exact():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    txt = dataset.dice(type='txt', exact=True)
    assert txt
    assert type(txt) == Dataset
    assert len(txt) == 1
    dataset.add_file(id='1', path='test1.txt', type='txt')
    txt = dataset.dice(type='txt')
    assert len(txt) == 2
    txt = dataset.dice(type='t', exact=True)
    assert txt is None
Ejemplo n.º 28
0
def test_add_file():
    """Add file to existing dataset"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 1
    assert dataset is not None
    assert dataset['test.txt'] is not None
    assert dataset['test.txt'].get('type') == 'txt'
    assert dataset['test.txt'].get('view') == 'text'
Ejemplo n.º 29
0
def test_export_one_tag():
    """Export files from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    exp = dataset.export(tags='path')
    assert exp
    assert len(exp) == 2
    for dic in exp:
        assert len(dic) == 1
        assert dic.get('path') is not None
        assert dic.get('view') is None
        assert dic.get('id') is None
        assert dic.get('type') is None
Ejemplo n.º 30
0
def test_add_file():
    """Add file to existing dataset"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    fileinfo = {'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset.add_file(**fileinfo)
    # pylint: enable=W0142
    assert len(dataset) == 1
    assert dataset is not None
    assert dataset['test.txt'] is not None
    assert dataset['test.txt'].get('type') == 'txt'
    assert dataset['test.txt'].get('view') == 'text'
Ejemplo n.º 31
0
def test_export_one_tag():
    """Export files from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    exp = dataset.export(tags='path')
    assert exp
    assert len(exp) == 2
    for dic in exp:
        assert len(dic) == 1
        assert dic.get('path') is not None
        assert dic.get('view') is None
        assert dic.get('id') is None
        assert dic.get('type') is None
Ejemplo n.º 32
0
def test_multiple_files():
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    dataset.add_file(path='test1.jpg', type='jpg', view='jpeg')
    assert len(dataset) == 4
Ejemplo n.º 33
0
def test_dataset_dice_ops():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf', size=100)
    dataset.add_file(id='1', path='test.gff', type='gff', size=50)
    with pytest.raises(SyntaxError):
        txt = dataset.dice(size='!50')
Ejemplo n.º 34
0
def test_create_empty_dataset():
    """Create empty dataset"""
    dataset = Dataset()
    # Disable warning about:
    # - missing pytest.raises
    # - statement with no effect
    # pylint: disable=E1101,W0104
    with pytest.raises(AttributeError):
        dataset.id
Ejemplo n.º 35
0
def test_dataset_dice_regex_simple():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    txt = dataset.dice(type='txt')
    assert txt
    assert type(txt) == Dataset
    assert len(txt) == 1
    dataset.add_file(id='1', path='test1.txt', type='txt')
    txt = dataset.dice(type='t')
    assert len(txt) == 2
Ejemplo n.º 36
0
def test_create_dataset():
    """Create dataset with string values only"""
    info = {'id': '1', 'sex': 'M', 'age': '65'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert dataset.id == '1'
    assert dataset.sex == 'M'
    assert dataset.age == '65'
Ejemplo n.º 37
0
def test_create_dataset_w_numbers():
    """Create dataset with string and numeric values"""
    info = {'id': '1', 'sex': 'M', 'age': 65}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert dataset.id == '1'
    assert dataset.sex == 'M'
    assert dataset.age == 65
Ejemplo n.º 38
0
def test_create_dataset_w_na():
    """Create dataset with file path"""
    info = {'id': '1', 'age': 65, 'sex': ''}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    assert len(dataset) == 0
    assert dataset.id == '1'
    assert dataset.age == 65
    assert dataset.sex == 'NA'
Ejemplo n.º 39
0
def test_dataset_dice_exact():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    txt = dataset.dice(type='txt', exact=True)
    assert txt
    assert type(txt) == Dataset
    assert len(txt) == 1
    dataset.add_file(id='1', path='test1.txt', type='txt')
    txt = dataset.dice(type='txt')
    assert len(txt) == 2
    txt = dataset.dice(type='t', exact=True)
    assert txt is None
Ejemplo n.º 40
0
def test_multiple_files():
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    dataset.add_file(path='test1.jpg', type='jpg', view='jpeg')
    assert len(dataset) == 4
Ejemplo n.º 41
0
def test_dataset_dice_ops():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf', size=100)
    dataset.add_file(id='1', path='test.gff', type='gff', size=50)
    txt = dataset.dice(size='>50')
    assert type(txt) == Dataset
    assert len(txt) == 1
    assert txt.get('test.gff') is None
    assert txt.get('test.gtf') is not None
Ejemplo n.º 42
0
def test_dataset_clone():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    dataset.add_file(id='1', path='test.bam', type='bam')
    assert len(dataset) == 2
    clone = dataset.clone()
    assert id(dataset) != id(clone)
    assert type(dataset) == type(clone)
    assert dataset._metadata == clone._metadata
    assert dataset._files == clone._files
    assert dataset._attributes == clone._attributes
    assert hasattr(clone, "clone")
    assert hasattr(clone, "add_file")
    assert hasattr(clone, "rm_file")
    assert hasattr(clone, "export")
    assert hasattr(clone, "get_meta_tags")
    assert hasattr(clone, "get_meta_items")
    assert hasattr(clone, "get_tags")
    assert hasattr(clone, "merge")
    assert hasattr(clone, "get")
Ejemplo n.º 43
0
def test_dataset_clone():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    dataset.add_file(id='1', path='test.bam', type='bam')
    assert len(dataset) == 2
    clone = dataset.clone()
    assert id(dataset) != id(clone)
    assert type(dataset) == type(clone)
    assert dataset._metadata == clone._metadata
    assert dataset._files == clone._files
    assert dataset._attributes == clone._attributes
    assert hasattr(clone, "clone")
    assert hasattr(clone, "add_file")
    assert hasattr(clone, "rm_file")
    assert hasattr(clone, "export")
    assert hasattr(clone, "get_meta_tags")
    assert hasattr(clone, "get_meta_items")
    assert hasattr(clone, "get_tags")
    assert hasattr(clone, "merge")
    assert hasattr(clone, "get")
Ejemplo n.º 44
0
def test_dataset_dice_ops():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf', size=100)
    dataset.add_file(id='1', path='test.gff', type='gff', size=50)
    with pytest.raises(SyntaxError):
        txt = dataset.dice(size='!50')
Ejemplo n.º 45
0
def test_dataset_dice_regex_simple():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.txt', type='txt')
    txt = dataset.dice(type='txt')
    assert txt
    assert type(txt) == Dataset
    assert len(txt) == 1
    dataset.add_file(id='1', path='test1.txt', type='txt')
    txt = dataset.dice(type='t')
    assert len(txt) == 2
Ejemplo n.º 46
0
def test_iter():
    """Iterates over all files in dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    dataset.add_file(path='test1.jpg', type='jpg', view='jpeg')
    i = 0
    for path, info in dataset:
        assert path
        assert info
        i += 1
    assert i == 4
Ejemplo n.º 47
0
def test_dataset_dice_ops():
    info = {'id': '1', 'sex': 'M', 'age': 65}
    dataset = Dataset(**info)
    dataset.add_file(id='1', path='test.gtf', type='gtf', size=100)
    dataset.add_file(id='1', path='test.gff', type='gff', size=50)
    txt = dataset.dice(size='>50')
    assert type(txt) == Dataset
    assert len(txt) == 1
    assert txt.get('test.gff') is None
    assert txt.get('test.gtf') is not None
Ejemplo n.º 48
0
def test_rm_file():
    """Remove file from dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.rm_file(path='test.txt')
    assert len(dataset) == 1
    assert dataset['test.txt'] is None
Ejemplo n.º 49
0
def test_iter():
    """Iterates over all files in dataset"""
    info = {'id': '1', 'path': 'test.txt', 'type': 'txt', 'view': 'text'}
    # Disable warning about * magic
    # pylint: disable=W0142
    dataset = Dataset(**info)
    # pylint: enable=W0142
    dataset.add_file(path='test1.txt', type='txt', view='text')
    dataset.add_file(path='test.jpg', type='jpg', view='jpeg')
    dataset.add_file(path='test1.jpg', type='jpg', view='jpeg')
    i = 0
    for path, info in dataset:
        assert path
        assert info
        i += 1
    assert i == 4