コード例 #1
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_set_location():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    raise SkipTest('gh-31, precision is lost in conversion from decimal to dms')
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    # Verify that original photo has no location information
    #assert origin_metadata['latitude'] is None, origin_metadata['latitude']
    #assert origin_metadata['longitude'] is None, origin_metadata['longitude']

    status = audio.set_location(11.1111111111, 99.9999999999)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    # @TODO: understand why the decimal to degree conversion loses accuracy
    assert metadata['latitude'] == 11.1111111111, metadata['latitude']
    assert metadata['longitude'] == 99.9999999999, metadata['longitude']
コード例 #2
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_get_date_taken():
    raise SkipTest('gh-32 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    date_taken = audio.get_date_taken()

    print '%r' % date_taken
    assert date_taken == (2016, 1, 4, 5, 24, 15, 0, 19, 0), date_taken
コード例 #3
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_get_date_taken():
    raise SkipTest('gh-32 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    date_taken = audio.get_date_taken()

    print '%r' % date_taken
    assert date_taken == (2016, 1, 4, 5, 24, 15, 0, 19, 0), date_taken
コード例 #4
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_set_location():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    # Verify that original audio has different location info that what we
    #   will be setting and checking
    assert not helper.isclose(origin_metadata['latitude'], 11.1111111111), origin_metadata['latitude']
    assert not helper.isclose(origin_metadata['longitude'], 99.9999999999), origin_metadata['longitude']

    status = audio.set_location(11.1111111111, 99.9999999999)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert helper.isclose(metadata['latitude'], 11.1111111111), metadata['latitude']
    assert helper.isclose(metadata['longitude'], 99.9999999999), metadata['longitude']
コード例 #5
0
ファイル: elodie_test.py プロジェクト: jmathai/elodie
def test_update_time_on_audio():
    temporary_folder, folder = helper.create_working_folder()
    temporary_folder_destination, folder_destination = helper.create_working_folder()

    origin = "%s/audio.m4a" % folder
    shutil.copyfile(helper.get_file("audio.m4a"), origin)

    audio = Audio(origin)
    metadata = audio.get_metadata()

    reset_hash_db()
    status = elodie.update_time(audio, origin, "2000-01-01 12:00:00")
    restore_hash_db()

    audio_processed = Audio(origin)
    metadata_processed = audio_processed.get_metadata()

    shutil.rmtree(folder)
    shutil.rmtree(folder_destination)

    assert status == True, status
    assert metadata["date_taken"] != metadata_processed["date_taken"]
    assert metadata_processed["date_taken"] == helper.time_convert((2000, 1, 1, 12, 0, 0, 5, 1, 0)), metadata_processed[
        "date_taken"
    ]
コード例 #6
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_audio_extensions():
    audio = Audio()
    extensions = audio.extensions

    assert 'm4a' in extensions

    valid_extensions = Audio.get_valid_extensions()

    assert extensions == valid_extensions, valid_extensions
コード例 #7
0
ファイル: audio_test.py プロジェクト: GonzaloAlvarez/elodie
def test_set_location():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    # Verify that original audio has different location info that what we
    #   will be setting and checking
    assert not helper.isclose(origin_metadata['latitude'],
                              11.1111111111), origin_metadata['latitude']
    assert not helper.isclose(origin_metadata['longitude'],
                              99.9999999999), origin_metadata['longitude']

    status = audio.set_location(11.1111111111, 99.9999999999)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert helper.isclose(metadata['latitude'],
                          11.1111111111), metadata['latitude']
    assert helper.isclose(metadata['longitude'],
                          99.9999999999), metadata['longitude']
コード例 #8
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_set_location():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    raise SkipTest(
        'gh-31, precision is lost in conversion from decimal to dms')
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    # Verify that original photo has no location information
    #assert origin_metadata['latitude'] is None, origin_metadata['latitude']
    #assert origin_metadata['longitude'] is None, origin_metadata['longitude']

    status = audio.set_location(11.1111111111, 99.9999999999)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    # @TODO: understand why the decimal to degree conversion loses accuracy
    assert metadata['latitude'] == 11.1111111111, metadata['latitude']
    assert metadata['longitude'] == 99.9999999999, metadata['longitude']
コード例 #9
0
def test_set_location_minus():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    # Verify that original audio has different location info that what we
    #   will be setting and checking
    assert not helper.isclose(origin_metadata['latitude'],
                              11.111111), origin_metadata['latitude']
    assert not helper.isclose(origin_metadata['longitude'],
                              99.999999), origin_metadata['longitude']

    status = audio.set_location(-11.111111, -99.999999)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert helper.isclose(metadata['latitude'],
                          -11.111111), metadata['latitude']
    assert helper.isclose(metadata['longitude'],
                          -99.999999), metadata['longitude']
コード例 #10
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_audio_extensions():
    audio = Audio()
    extensions = audio.extensions

    assert 'm4a' in extensions

    valid_extensions = Audio.get_valid_extensions()

    assert extensions == valid_extensions, valid_extensions
コード例 #11
0
ファイル: googlephotos_test.py プロジェクト: sergi/elodie
def test_googlephotos_after_unsupported():
    with open('%s/config.ini-googlephotos-after-unsupported' % gettempdir(), 'w') as f:
        f.write(config_string_fmt)
    if hasattr(load_config, 'config'):
        del load_config.config

    final_file_path = helper.get_file('audio.m4a')
    sample_photo = Audio(final_file_path)
    sample_metadata = sample_photo.get_metadata()
    sample_metadata['original_name'] = 'foobar'
    gp = GooglePhotos()
    gp.after('', '', final_file_path, sample_metadata)
    db_row = gp.db.get(final_file_path)

    if hasattr(load_config, 'config'):
        del load_config.config

    assert db_row == None, db_row
コード例 #12
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_set_date_taken():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    status = audio.set_date_taken(datetime.datetime(2013, 9, 30, 7, 6, 5))

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    date_taken = metadata['date_taken']

    shutil.rmtree(folder)

    assert date_taken == (2013, 9, 30, 7, 6, 5, 0, 273, 0), metadata['date_taken']
コード例 #13
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_set_title():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    status = audio.set_title('my audio title')

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == 'my audio title', metadata['title']
コード例 #14
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_set_title_non_ascii():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    unicode_title = u'形声字 / 形聲字'
    status = audio.set_title(unicode_title)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == unicode_title, metadata['title']
コード例 #15
0
ファイル: elodie_test.py プロジェクト: dnwhte/elodie
def test_update_time_on_audio():
    temporary_folder, folder = helper.create_working_folder()
    temporary_folder_destination, folder_destination = helper.create_working_folder(
    )

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    metadata = audio.get_metadata()

    helper.reset_dbs()
    status = elodie.update_time(audio, origin, '2000-01-01 12:00:00')
    helper.restore_dbs()

    audio_processed = Audio(origin)
    metadata_processed = audio_processed.get_metadata()

    shutil.rmtree(folder)
    shutil.rmtree(folder_destination)

    assert status == True, status
    assert metadata['date_taken'] != metadata_processed['date_taken']
    assert metadata_processed['date_taken'] == helper.time_convert(
        (2000, 1, 1, 12, 0, 0, 5, 1, 0)), metadata_processed['date_taken']
コード例 #16
0
ファイル: elodie_test.py プロジェクト: dnwhte/elodie
def test_update_location_on_audio():
    temporary_folder, folder = helper.create_working_folder()
    temporary_folder_destination, folder_destination = helper.create_working_folder(
    )

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    metadata = audio.get_metadata()

    helper.reset_dbs()
    status = elodie.update_location(audio, origin, 'Sunnyvale, CA')
    helper.restore_dbs()

    audio_processed = Audio(origin)
    metadata_processed = audio_processed.get_metadata()

    shutil.rmtree(folder)
    shutil.rmtree(folder_destination)

    assert status == True, status
    assert metadata['latitude'] != metadata_processed[
        'latitude'], metadata_processed['latitude']
    assert helper.isclose(metadata_processed['latitude'],
                          37.36883), metadata_processed['latitude']
    assert helper.isclose(metadata_processed['longitude'],
                          -122.03635), metadata_processed['longitude']
コード例 #17
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_set_date_taken():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    status = audio.set_date_taken(datetime.datetime(2013, 9, 30, 7, 6, 5))

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    date_taken = metadata['date_taken']

    shutil.rmtree(folder)

    assert date_taken == (2013, 9, 30, 7, 6, 5, 0, 273, 0), metadata['date_taken']
コード例 #18
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_set_title():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    status = audio.set_title('my audio title')

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == 'my audio title', metadata['title']
コード例 #19
0
ファイル: elodie_test.py プロジェクト: jmathai/elodie
def test_update_location_on_audio():
    temporary_folder, folder = helper.create_working_folder()
    temporary_folder_destination, folder_destination = helper.create_working_folder()

    origin = "%s/audio.m4a" % folder
    shutil.copyfile(helper.get_file("audio.m4a"), origin)

    audio = Audio(origin)
    metadata = audio.get_metadata()

    reset_hash_db()
    status = elodie.update_location(audio, origin, "Sunnyvale, CA")
    restore_hash_db()

    audio_processed = Audio(origin)
    metadata_processed = audio_processed.get_metadata()

    shutil.rmtree(folder)
    shutil.rmtree(folder_destination)

    assert status == True, status
    assert metadata["latitude"] != metadata_processed["latitude"], metadata_processed["latitude"]
    assert helper.isclose(metadata_processed["latitude"], 37.36883), metadata_processed["latitude"]
    assert helper.isclose(metadata_processed["longitude"], -122.03635), metadata_processed["longitude"]
コード例 #20
0
def test_set_title():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    status = audio.set_title('my audio title')

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == 'my audio title', metadata['title']
コード例 #21
0
def test_set_title_non_ascii():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    unicode_title = u'形声字 / 形聲字'
    status = audio.set_title(unicode_title)

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == unicode_title, metadata['title']
コード例 #22
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_set_title():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    origin_metadata = audio.get_metadata()

    status = audio.set_title('my audio title')

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    shutil.rmtree(folder)

    assert metadata['title'] == 'my audio title', metadata['title']
コード例 #23
0
def test_set_date_taken():
    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    status = audio.set_date_taken(datetime.datetime(2013, 9, 30, 7, 6, 5))

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    date_taken = metadata['date_taken']

    shutil.rmtree(folder)

    assert date_taken == (2013, 9, 30, 7, 6, 5, 0, 273,
                          0), metadata['date_taken']
コード例 #24
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_set_date_taken():
    if not can_edit_exif():
        raise SkipTest('avmetareadwrite executable not found')

    temporary_folder, folder = helper.create_working_folder()

    origin = '%s/audio.m4a' % folder
    shutil.copyfile(helper.get_file('audio.m4a'), origin)

    audio = Audio(origin)
    status = audio.set_date_taken(datetime.datetime(2013, 9, 30, 7, 6, 5))

    assert status == True, status

    audio_new = Audio(origin)
    metadata = audio_new.get_metadata()

    date_taken = metadata['date_taken']

    shutil.rmtree(folder)

    assert date_taken == (2013, 9, 30, 7, 6, 5, 0, 273,
                          0), metadata['date_taken']
コード例 #25
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_get_exif():
    audio = Audio(helper.get_file('audio.m4a'))
    exif = audio.get_exif()

    assert exif is not None, exif
コード例 #26
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_is_valid():
    audio = Audio(helper.get_file('audio.m4a'))

    assert audio.is_valid()
コード例 #27
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_get_coordinate_longitude():
    raise SkipTest('gh-61 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('longitude')

    assert coordinate == -95.3677, coordinate
コード例 #28
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_get_coordinate_latitude():
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('latitude')

    assert helper.isclose(coordinate, 29.758938), coordinate
コード例 #29
0
def test_get_date_taken():
    audio = Audio(helper.get_file('audio.m4a'))
    date_taken = audio.get_date_taken()

    assert date_taken == (2016, 1, 4, 5, 28, 15, 0, 4, 0), date_taken
コード例 #30
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_get_coordinate_latitude():
    raise SkipTest('gh-61 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('latitude')

    assert coordinate == 29.75893888888889, coordinate
コード例 #31
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_get_coordinate_longitude():
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('longitude')

    assert helper.isclose(coordinate, -95.3677), coordinate
コード例 #32
0
def test_get_coordinate_longitude():
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('longitude')

    assert helper.isclose(coordinate, -95.3677), coordinate
コード例 #33
0
def test_get_coordinate_latitude():
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('latitude')

    assert helper.isclose(coordinate, 29.758938), coordinate
コード例 #34
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_get_coordinate_latitude():
    raise SkipTest('gh-61 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('latitude')

    assert coordinate == 29.75893888888889, coordinate
コード例 #35
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_is_not_valid():
    audio = Audio(helper.get_file('text.txt'))

    assert not audio.is_valid()
コード例 #36
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_is_valid():
    audio = Audio(helper.get_file('audio.m4a'))

    assert audio.is_valid()
コード例 #37
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_get_exif():
    audio = Audio(helper.get_file('audio.m4a'))
    exif = audio.get_exif()

    assert exif is not None, exif
コード例 #38
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def test_is_not_valid():
    audio = Audio(helper.get_file('text.txt'))

    assert not audio.is_valid()
コード例 #39
0
ファイル: audio_test.py プロジェクト: scudderfish/elodie
def can_edit_exif():
    audio = Audio()
    return audio.get_avmetareadwrite()
コード例 #40
0
def test_get_camera_model():
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_camera_model()

    assert coordinate is None, coordinate
コード例 #41
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def test_get_coordinate_longitude():
    raise SkipTest('gh-61 this test fails on travisci')
    audio = Audio(helper.get_file('audio.m4a'))
    coordinate = audio.get_coordinate('longitude')

    assert coordinate == -95.3677, coordinate
コード例 #42
0
ファイル: audio_test.py プロジェクト: noonat/elodie
def can_edit_exif():
    audio = Audio()
    return audio.get_avmetareadwrite()
コード例 #43
0
ファイル: audio_test.py プロジェクト: jmathai/elodie
def test_get_date_taken():
    audio = Audio(helper.get_file('audio.m4a'))
    date_taken = audio.get_date_taken()

    assert date_taken == (2016, 1, 4, 5, 28, 15, 0, 4, 0), date_taken