-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_download.py
84 lines (68 loc) · 2.46 KB
/
test_download.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import os
import pytest
from download import download_source, validate_sources, parse_sources
@pytest.fixture
def test_data():
return [
{
"alias": "park_national",
"description": "National Park",
"source_type": "BCGW",
"source": "WHSE_ADMIN_BOUNDARIES.CLAB_NATIONAL_PARKS",
"query": None,
"primary_key": None,
"field_mapper": {"name": "ENGLISH_NAME"},
"data": {
"harvest_restriction": 1,
"og_restriction": 0,
"mining_restriction": 0,
},
},
{
"alias": "crd_water_supply_area",
"description": "CRD Water Supply Area",
"source_type": "FILE",
"source": "/vsizip//vsis3/$OBJECTSTORE_BUCKET/dss_projects_2024/harvest_restrictions/sources/CRD.gdb.zip",
"layer": "WSA_Boundary",
"query": None,
"primary_key": None,
"field_mapper": {"name": "Name"},
"data": {
"harvest_restriction": 3,
"og_restriction": 0,
"mining_restriction": 0,
},
},
]
def test_parse_sources(test_data):
sources = parse_sources(test_data)
assert sources[0]["index"] == 1
def test_parse_alias(test_data):
source = test_data[0]
source["alias"] = "National Réserve"
sources = parse_sources([source])
assert sources[0]["alias"] == "national_reserve"
def test_download_bcgw(test_data):
sources = [s for s in parse_sources(test_data) if s["alias"] == "park_national"]
sources = validate_sources(sources)
df = download_source(sources[0])
assert len(df) > 0
def test_invalid_bcgw(test_data):
sources = [s for s in parse_sources(test_data) if s["alias"] == "park_national"]
sources[0]["field_mapper"] = {"name": "INVALID_COLUMN"}
with pytest.raises(ValueError):
sources = validate_sources(sources)
def test_download_file(test_data, tmpdir):
sources = [
s for s in parse_sources(test_data) if s["alias"] == "crd_water_supply_area"
]
sources = validate_sources(sources)
df = download_source(sources[0])
assert len(df) > 0
def test_invalid_file(test_data):
sources = [
s for s in parse_sources(test_data) if s["alias"] == "crd_water_supply_area"
]
sources[0]["field_mapper"] = {"name": "INVALID_COLUMN"}
with pytest.raises(ValueError):
sources = validate_sources(sources)