コード例 #1
0
def test_FFInputFile_add_to_input_files_for_wfrmeta_2d_list():
    ffinpf = FFInputFile(uuid=[['someuuid', 'someuuid2'],
                               ['someuuid3', 'someuuid4']],
                         workflow_argument_name='somearg')
    inpfws = InputFilesForWFRMeta()
    ffinpf.add_to_input_files_for_wfrmeta(inpfws)
    res = inpfws.as_dict()
    assert res == [{
        'workflow_argument_name': 'somearg',
        'value': 'someuuid',
        'dimension': '0-0',
        'ordinal': 1
    }, {
        'workflow_argument_name': 'somearg',
        'value': 'someuuid2',
        'dimension': '0-1',
        'ordinal': 2
    }, {
        'workflow_argument_name': 'somearg',
        'value': 'someuuid3',
        'dimension': '1-0',
        'ordinal': 3
    }, {
        'workflow_argument_name': 'somearg',
        'value': 'someuuid4',
        'dimension': '1-1',
        'ordinal': 4
    }]
コード例 #2
0
def test_FFInputFile_create_unicorn_arg_secondary_file_format_if_extra(
        minimal_file_metadata_w_extrafile, fake_format_search_result):
    ffinpf = FFInputFile(uuid='someuuid',
                         workflow_argument_name='somearg',
                         ff_env='data',
                         format_if_extra='ann')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata_w_extrafile
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    assert not ffinpf.create_unicorn_arg_secondary_file()
コード例 #3
0
def test_FFInputFile_w_extrafile_not_ready(
        minimal_file_metadata_w_extrafile_not_ready,
        fake_format_search_result):
    ffinpf = FFInputFile(uuid='someuuid', workflow_argument_name='somearg')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata_w_extrafile_not_ready
    # bucket & object_key fill_in test for our 4dn bucket
    ffinpf.ff_env = 'data'
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    assert ffinpf.bucket_name == 'elasticbeanstalk-fourfront-webprod-files'
    assert ffinpf.extra_file_s3_keys == 'someuuid/someacc.sa'
コード例 #4
0
def test_FFInputFile_add_to_input_files_for_wfrmeta():
    ffinpf = FFInputFile(uuid='someuuid', workflow_argument_name='somearg')
    inpfws = InputFilesForWFRMeta()
    ffinpf.add_to_input_files_for_wfrmeta(inpfws)
    res = inpfws.as_dict()
    assert res == [{
        'workflow_argument_name': 'somearg',
        'value': 'someuuid',
        'dimension': '0',
        'ordinal': 1
    }]
コード例 #5
0
def test_FFInputFile_list(minimal_file_metadata1, minimal_file_metadata2):
    ffinpf = FFInputFile(uuid=['someuuid', 'someuuid2'],
                         workflow_argument_name='somearg')
    # cache a fake metadata for both one with 4dn open data url and one without
    # This should be a problem since all files for a single argument should be
    # from the same bucket.
    ffinpf._metadata['someuuid'] = minimal_file_metadata1
    ffinpf._metadata['someuuid2'] = minimal_file_metadata2
    ffinpf.ff_env = 'data'
    assert ffinpf.bucket_name == 'elasticbeanstalk-fourfront-webprod-wfoutput'
    assert ffinpf.s3_key == [
        'someuuid/someacc.vcf.gz', 'someuuid2/someacc2.vcf.gz'
    ]
コード例 #6
0
def test_FFInputFile_mix_4dn_opendata_and_non_open_data(
        minimal_file_metadata1, minimal_file_metadata_4dn_opendata):
    ffinpf = FFInputFile(uuid=['someuuid', 'someuuid2'],
                         workflow_argument_name='somearg')
    # cache a fake metadata for both one with 4dn open data url and one without
    # This should be a problem since all files for a single argument should be
    # from the same bucket.
    ffinpf._metadata['someuuid'] = minimal_file_metadata1
    ffinpf._metadata['someuuid2'] = minimal_file_metadata_4dn_opendata
    ffinpf.ff_env = 'data'
    with pytest.raises(MalFormattedFFInputException) as ex_info:
        ffinpf.bucket_name
    assert 'All the input files for a given argument name must be in the same bucket' in str(
        ex_info.value)
コード例 #7
0
def test_FFInputFile_as_dict(minimal_file_metadata1):
    ffinpf = FFInputFile(uuid='someuuid',
                         workflow_argument_name='somearg',
                         ff_env='data')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata1
    assert ffinpf.as_dict() == {
        'bucket_name': 'elasticbeanstalk-fourfront-webprod-wfoutput',
        'object_key': 'someacc.vcf.gz',
        'uuid': 'someuuid',
        'workflow_argument_name': 'somearg',
        'unzip': '',
        'mount': False,
        'rename': '',
        'format_if_extra': ''
    }
コード例 #8
0
def test_FFInputFile_create_unicorn_arg_input_file(minimal_file_metadata1):
    ffinpf = FFInputFile(uuid='someuuid',
                         workflow_argument_name='somearg',
                         ff_env='data')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata1
    res = ffinpf.create_unicorn_arg_input_file()
    assert res == {
        'somearg': {
            'bucket_name': 'elasticbeanstalk-fourfront-webprod-wfoutput',
            'object_key': 'someuuid/someacc.vcf.gz',  # actual s3 key
            'unzip': '',
            'mount': False,
            'rename': ''
        }
    }
コード例 #9
0
def test_FFInputFile(fake_inputfile2):
    ffinpf = FFInputFile(**fake_inputfile2)
    assert ffinpf.workflow_argument_name == 'unrelated'
    assert ffinpf.uuid == 'e07590b8-a6cc-42ee-85b9-ed16ed0ec34e'
    assert ffinpf.unzip == ''
    assert ffinpf.mount is True
    assert ffinpf.rename == ''
    assert ffinpf.format_if_extra == 'rck.tar.index'
コード例 #10
0
def test_FFInputFile(fake_inputfile1):
    ffinpf = FFInputFile(**fake_inputfile1)
    assert ffinpf.workflow_argument_name == 'input_vcf'
    assert ffinpf.uuid == 'e7fc0f39-560a-4c5c-9bdb-040e43819eb7'
    assert ffinpf.unzip == 'gz'
    assert ffinpf.mount is False
    assert ffinpf.rename == ''
    assert ffinpf.format_if_extra == ''
コード例 #11
0
def test_FFInputFile_create_unicorn_arg_secondary_file(
        minimal_file_metadata_w_extrafile, fake_format_search_result):
    ffinpf = FFInputFile(uuid='someuuid',
                         workflow_argument_name='somearg',
                         ff_env='data')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata_w_extrafile
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    res = ffinpf.create_unicorn_arg_secondary_file()
    assert res == {
        'somearg': {
            'bucket_name': 'elasticbeanstalk-fourfront-webprod-files',
            'object_key': ['someuuid/someacc.sa',
                           'someuuid/someacc.ann'],  # actual s3 key
            'mount': False,
            'rename': ''
        }
    }
コード例 #12
0
def test_FFInputFile(fake_inputfile3):
    ffinpf = FFInputFile(**fake_inputfile3)
    assert ffinpf.workflow_argument_name == 'trio'
    assert ffinpf.uuid == [
        'b4cde603-4df9-48d2-bd06-765900b9f165',
        '2c6ca4b1-62b6-4235-98c0-e4c25a9ab1ec'
    ]
    assert ffinpf.unzip == ''
    assert ffinpf.mount is False
    assert ffinpf.rename == ['abc.rck', 'def.rck']
    assert ffinpf.format_if_extra == ''
コード例 #13
0
def test_FFInputFile_list_4dn_opendata_w_extrafile(
        minimal_file_metadata_4dn_opendata_w_extrafile,
        minimal_file_metadata_4dn_opendata_w_extrafile2,
        fake_format_search_result):
    ffinpf = FFInputFile(uuid=['someuuid', 'someuuid2'],
                         workflow_argument_name='somearg',
                         rename=['somename.bwt', 'somename2.bwt'])
    # cache a fake metadata for both one with 4dn open data url and one without
    # This should be a problem since all files for a single argument should be
    # from the same bucket.
    ffinpf._metadata[
        'someuuid'] = minimal_file_metadata_4dn_opendata_w_extrafile
    ffinpf._metadata[
        'someuuid2'] = minimal_file_metadata_4dn_opendata_w_extrafile2
    ffinpf.ff_env = 'data'
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    assert ffinpf.bucket_name == '4dn-open-data-public'
    assert ffinpf.extra_file_s3_keys == [
        [
            'fourfront-webprod/files/someuuid/someacc.sa',
            'fourfront-webprod/files/someuuid/someacc.ann'
        ],
        [
            'fourfront-webprod/files/someuuid2/someacc2.sa',
            'fourfront-webprod/files/someuuid2/someacc2.ann'
        ]
    ]
    assert ffinpf.extra_file_renames == [['somename.sa', 'somename.ann'],
                                         ['somename2.sa', 'somename2.ann']]
コード例 #14
0
def test_FFInputFile_create_unicorn_arg_secondary_file_list(
        minimal_file_metadata_w_extrafile,
        minimal_file_metadata_w_extrafile_not_ready2,
        fake_format_search_result):
    ffinpf = FFInputFile(uuid=['someuuid', 'someuuid2'],
                         workflow_argument_name='somearg',
                         rename=['somename1.bwt', 'somename2.bwt'],
                         mount=True,
                         ff_env='data')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata_w_extrafile
    ffinpf._metadata[
        'someuuid2'] = minimal_file_metadata_w_extrafile_not_ready2
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    res = ffinpf.create_unicorn_arg_secondary_file()
    assert res == {
        'somearg': {
            'bucket_name':
            'elasticbeanstalk-fourfront-webprod-files',
            'object_key': [['someuuid/someacc.sa', 'someuuid/someacc.ann'],
                           ['someuuid2/someacc2.ann']],
            'mount':
            True,
            'rename': [['somename1.sa', 'somename1.ann'], ['somename2.ann']]
        }
    }
コード例 #15
0
def test_FFInputFile(minimal_file_metadata1):
    ffinpf = FFInputFile(uuid='someuuid', workflow_argument_name='somearg')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata1
    assert ffinpf.get_file_type_from_uuid('someuuid') == 'FileProcessed'
    assert ffinpf.get_object_key_from_uuid('someuuid') == 'someacc.vcf.gz'
    assert ffinpf.get_upload_key_from_uuid(
        'someuuid') == 'someuuid/someacc.vcf.gz'
    assert ffinpf.get_s3_key_from_uuid('someuuid') == 'someuuid/someacc.vcf.gz'
    # bucket & object_key fill_in test for our 4dn bucket
    ffinpf.ff_env = 'data'
    assert ffinpf.bucket_name == 'elasticbeanstalk-fourfront-webprod-wfoutput'
    assert ffinpf.object_key == 'someacc.vcf.gz'
    assert ffinpf.s3_key == 'someuuid/someacc.vcf.gz'
コード例 #16
0
def test_FFInputFile_4dn_opendata(minimal_file_metadata_4dn_opendata):
    ffinpf = FFInputFile(uuid='someuuid', workflow_argument_name='somearg')
    # cache a fake metadata for data with 4dn open data url
    ffinpf._metadata['someuuid'] = minimal_file_metadata_4dn_opendata
    assert ffinpf.get_file_type_from_uuid('someuuid') == 'FileReference'
    assert ffinpf.get_object_key_from_uuid('someuuid') == 'someacc.txt'
    assert ffinpf.get_upload_key_from_uuid(
        'someuuid') == 'someuuid/someacc.txt'
    assert ffinpf.get_s3_key_from_uuid(
        'someuuid') == 'fourfront-webprod/files/someuuid/someacc.txt'
    # # bucket & object_key fill_in test for 4dn open data bucket
    ffinpf.ff_env = 'data'
    assert ffinpf.bucket_name == '4dn-open-data-public'
    assert ffinpf.object_key == 'someacc.txt'
    assert ffinpf.s3_key == 'fourfront-webprod/files/someuuid/someacc.txt'
コード例 #17
0
def test_FFInputFile_4dn_opendata_w_extrafile(
        minimal_file_metadata_4dn_opendata_w_extrafile,
        fake_format_search_result):
    ffinpf = FFInputFile(uuid='someuuid', workflow_argument_name='somearg')
    # cache a fake metadata for data without 4dn open data url
    ffinpf._metadata[
        'someuuid'] = minimal_file_metadata_4dn_opendata_w_extrafile
    # bucket & object_key fill_in test for our 4dn bucket
    ffinpf.ff_env = 'data'
    ffinpf._fe_map = FormatExtensionMap(ffe_all=fake_format_search_result)
    assert ffinpf.get_extra_file_formats_from_uuid('someuuid') == ['sa', 'ann']
    assert ffinpf.get_extra_file_s3_keys_from_uuid('someuuid') == [
        'fourfront-webprod/files/someuuid/someacc.sa',
        'fourfront-webprod/files/someuuid/someacc.ann'
    ]
    assert ffinpf.bucket_name == '4dn-open-data-public'
    assert ffinpf.extra_file_s3_keys == [
        'fourfront-webprod/files/someuuid/someacc.sa',
        'fourfront-webprod/files/someuuid/someacc.ann'
    ]