本文整理汇总了Python中sentinelsat.SentinelAPI.download方法的典型用法代码示例。如果您正苦于以下问题:Python SentinelAPI.download方法的具体用法?Python SentinelAPI.download怎么用?Python SentinelAPI.download使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类sentinelsat.SentinelAPI
的用法示例。
在下文中一共展示了SentinelAPI.download方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: test_scihub_unresponsive
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_scihub_unresponsive():
timeout_connect = 6
timeout_read = 6.6
timeout = (timeout_connect, timeout_read)
api = SentinelAPI("mock_user", "mock_password", timeout=timeout)
with requests_mock.mock() as rqst:
rqst.request(requests_mock.ANY, requests_mock.ANY, exc=requests.exceptions.ConnectTimeout)
with pytest.raises(requests.exceptions.ConnectTimeout):
api.query(**_small_query)
with pytest.raises(requests.exceptions.ConnectTimeout):
api.get_product_odata('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
with pytest.raises(requests.exceptions.ConnectTimeout):
api.download('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
with pytest.raises(requests.exceptions.ConnectTimeout):
api.download_all(['8df46c9e-a20c-43db-a19a-4240c2ed3b8b'])
with requests_mock.mock() as rqst:
rqst.request(requests_mock.ANY, requests_mock.ANY, exc=requests.exceptions.ReadTimeout)
with pytest.raises(requests.exceptions.ReadTimeout):
api.query(**_small_query)
with pytest.raises(requests.exceptions.ReadTimeout):
api.get_product_odata('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
with pytest.raises(requests.exceptions.ReadTimeout):
api.download('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
with pytest.raises(requests.exceptions.ReadTimeout):
api.download_all(['8df46c9e-a20c-43db-a19a-4240c2ed3b8b'])
示例2: test_download
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_download(tmpdir):
api = SentinelAPI(**_api_auth)
uuid = "1f62a176-c980-41dc-b3a1-c735d660c910"
filename = "S1A_WV_OCN__2SSH_20150603T092625_20150603T093332_006207_008194_521E"
expected_path = tmpdir.join(filename + ".zip")
# Download normally
product_info = api.download(uuid, str(tmpdir), checksum=True)
assert expected_path.samefile(product_info["path"])
assert product_info["title"] == filename
assert product_info["size"] == expected_path.size()
hash = expected_path.computehash()
modification_time = expected_path.mtime()
expected_product_info = product_info
del expected_product_info['path']
# File exists, test with checksum
# Expect no modification
product_info = api.download(uuid, str(tmpdir), check_existing=True)
assert expected_path.mtime() == modification_time
del product_info['path']
assert product_info == expected_product_info
# File exists, test without checksum
# Expect no modification
product_info = api.download(uuid, str(tmpdir), check_existing=False)
assert expected_path.mtime() == modification_time
del product_info['path']
assert product_info == expected_product_info
# Create invalid file, expect re-download
with expected_path.open("wb") as f:
f.seek(expected_product_info["size"] - 1)
f.write(b'\0')
assert expected_path.computehash("md5") != hash
product_info = api.download(uuid, str(tmpdir), check_existing=True)
assert expected_path.computehash("md5") == hash
del product_info['path']
assert product_info == expected_product_info
# Test continue
with expected_path.open("rb") as f:
content = f.read()
with expected_path.open("wb") as f:
f.write(content[:100])
assert expected_path.computehash("md5") != hash
product_info = api.download(uuid, str(tmpdir), check_existing=True)
assert expected_path.computehash("md5") == hash
del product_info['path']
assert product_info == expected_product_info
# Test MD5 check
with expected_path.open("wb") as f:
f.write(b'abcd' * 100)
assert expected_path.computehash("md5") != hash
with pytest.raises(InvalidChecksumError):
api.download(uuid, str(tmpdir), check_existing=True, checksum=True)
示例3: test_SentinelAPI_wrong_credentials
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_SentinelAPI_wrong_credentials():
api = SentinelAPI(
"wrong_user",
"wrong_password"
)
with pytest.raises(SentinelAPIError) as excinfo:
api.query(**_small_query)
assert excinfo.value.response.status_code == 401
with pytest.raises(SentinelAPIError) as excinfo:
api.get_product_odata('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
assert excinfo.value.response.status_code == 401
with pytest.raises(SentinelAPIError) as excinfo:
api.download('8df46c9e-a20c-43db-a19a-4240c2ed3b8b')
assert excinfo.value.response.status_code == 401
with pytest.raises(SentinelAPIError) as excinfo:
api.download_all(['8df46c9e-a20c-43db-a19a-4240c2ed3b8b'])
assert excinfo.value.response.status_code == 401
示例4: test_download_invalid_id
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_download_invalid_id():
api = SentinelAPI(**_api_auth)
uuid = "1f62a176-c980-41dc-xxxx-c735d660c910"
with pytest.raises(SentinelAPIError) as excinfo:
api.download(uuid)
assert 'Invalid key' in excinfo.value.msg
示例5: test_check_existing
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_check_existing(tmpdir):
api = SentinelAPI(**_api_auth)
ids = [
"5618ce1b-923b-4df2-81d9-50b53e5aded9",
"d8340134-878f-4891-ba4f-4df54f1e3ab4",
"1f62a176-c980-41dc-b3a1-c735d660c910"
]
names = ["S1A_WV_OCN__2SSV_20150526T081641_20150526T082418_006090_007E3E_104C",
"S1A_WV_OCN__2SSV_20150526T211029_20150526T211737_006097_007E78_134A",
"S1A_WV_OCN__2SSH_20150603T092625_20150603T093332_006207_008194_521E"]
paths = [tmpdir.join(fn + ".zip") for fn in names]
path_strings = list(map(str, paths))
# Init files used for testing
api.download(ids[0], str(tmpdir))
# File #1: complete and correct
assert paths[0].check(exists=1, file=1)
# File #2: complete but incorrect
with paths[1].open("wb") as f:
size = 130102
f.seek(size - 1)
f.write(b'\0')
# File #3: incomplete
dummy_content = b'aaaaaaaaaaaaaaaaaaaaaaaaa'
with paths[2].open("wb") as f:
f.write(dummy_content)
assert paths[2].check(exists=1, file=1)
# Test
expected = {str(paths[1]), str(paths[2])}
result = api.check_files(ids=ids, directory=str(tmpdir))
assert set(result) == expected
assert result[paths[1]][0]['id'] == ids[1]
assert result[paths[2]][0]['id'] == ids[2]
assert paths[0].check(exists=1, file=1)
assert paths[1].check(exists=1, file=1)
assert paths[2].check(exists=1, file=1)
result = api.check_files(paths=path_strings)
assert set(result) == expected
assert result[paths[1]][0]['id'] == ids[1]
assert result[paths[2]][0]['id'] == ids[2]
assert paths[0].check(exists=1, file=1)
assert paths[1].check(exists=1, file=1)
assert paths[2].check(exists=1, file=1)
result = api.check_files(paths=path_strings, delete=True)
assert set(result) == expected
assert result[paths[1]][0]['id'] == ids[1]
assert result[paths[2]][0]['id'] == ids[2]
assert paths[0].check(exists=1, file=1)
assert not paths[1].check(exists=1, file=1)
assert not paths[2].check(exists=1, file=1)
missing_file = str(tmpdir.join(
"S1A_EW_GRDH_1SDH_20141003T003840_20141003T003920_002658_002F54_4DD1.zip"))
result = api.check_files(paths=[missing_file])
assert set(result) == {missing_file}
assert result[missing_file][0]['id']
with pytest.raises(ValueError):
api.check_files(ids=ids)
with pytest.raises(ValueError):
api.check_files()
tmpdir.remove()
示例6: test_download
# 需要导入模块: from sentinelsat import SentinelAPI [as 别名]
# 或者: from sentinelsat.SentinelAPI import download [as 别名]
def test_download(tmpdir):
api = SentinelAPI(**_api_auth)
uuid = "1f62a176-c980-41dc-b3a1-c735d660c910"
filename = "S1A_WV_OCN__2SSH_20150603T092625_20150603T093332_006207_008194_521E"
expected_path = tmpdir.join(filename + ".zip")
tempfile_path = tmpdir.join(filename + ".zip.incomplete")
# Download normally
product_info = api.download(uuid, str(tmpdir), checksum=True)
assert expected_path.samefile(product_info["path"])
assert not tempfile_path.check(exists=1)
assert product_info["title"] == filename
assert product_info["size"] == expected_path.size()
assert product_info["downloaded_bytes"] == expected_path.size()
hash = expected_path.computehash("md5")
modification_time = expected_path.mtime()
expected_product_info = product_info
# File exists, expect nothing to happen
product_info = api.download(uuid, str(tmpdir))
assert not tempfile_path.check(exists=1)
assert expected_path.mtime() == modification_time
expected_product_info["downloaded_bytes"] = 0
assert product_info == expected_product_info
# Create invalid but full-sized tempfile, expect re-download
expected_path.move(tempfile_path)
with tempfile_path.open("wb") as f:
f.seek(expected_product_info["size"] - 1)
f.write(b'\0')
assert tempfile_path.computehash("md5") != hash
product_info = api.download(uuid, str(tmpdir))
assert expected_path.check(exists=1, file=1)
assert expected_path.computehash("md5") == hash
expected_product_info["downloaded_bytes"] = expected_product_info["size"]
assert product_info == expected_product_info
# Create invalid tempfile, without checksum check
# Expect continued download and no exception
dummy_content = b'aaaaaaaaaaaaaaaaaaaaaaaaa'
with tempfile_path.open("wb") as f:
f.write(dummy_content)
expected_path.remove()
product_info = api.download(uuid, str(tmpdir), checksum=False)
assert not tempfile_path.check(exists=1)
assert expected_path.check(exists=1, file=1)
assert expected_path.computehash("md5") != hash
expected_product_info["downloaded_bytes"] = expected_product_info["size"] - len(dummy_content)
assert product_info == expected_product_info
# Create invalid tempfile, with checksum check
# Expect continued download and exception raised
dummy_content = b'aaaaaaaaaaaaaaaaaaaaaaaaa'
with tempfile_path.open("wb") as f:
f.write(dummy_content)
expected_path.remove()
with pytest.raises(InvalidChecksumError):
api.download(uuid, str(tmpdir), checksum=True)
assert not tempfile_path.check(exists=1)
assert not expected_path.check(exists=1, file=1)
tmpdir.remove()