File size: 3,082 Bytes
a1041b7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import sys
import os

# Add current directory to path
sys.path.append(os.path.dirname(os.path.abspath(__file__)))

from cities_data import get_provinces, get_cities, get_districts
import create_map_poster as cmp


def test_china_hierarchy():
    print("Testing China Hierarchy...")

    # 1. Test Provinces
    provinces = get_provinces("中国", lang="cn")
    print(f"Found {len(provinces)} provinces.")
    assert len(provinces) > 30, f"Expected >30 provinces, found {len(provinces)}"
    assert any(p[1] == "广东省" for p in provinces), "广东省 not found"

    # 2. Test Cities
    cities = get_cities("中国", "广东省", lang="cn")
    print(f"Found {len(cities)} cities in 广东省.")
    assert len(cities) > 10, f"Expected >10 cities in GD, found {len(cities)}"
    assert any(c[1] == "广州市" for c in cities), "广州市 not found"

    # 3. Test Districts
    districts = get_districts("中国", "广东省", "广州市", lang="cn")
    print(f"Found {len(districts)} districts in 广州市.")
    assert len(districts) > 5, f"Expected >5 districts in GZ, found {len(districts)}"
    assert districts[0][0] == "整个城市", "First option should be '整个城市'"
    assert any(d[1] == "天河区" for d in districts), "天河区 not found"

    # 4. Test Municipality
    sh_cities = get_cities("中国", "上海市", lang="cn")
    print(f"Cities in 上海市: {sh_cities}")
    assert sh_cities == [("上海市", "上海市")], (
        "Shanghai municipality should return itself as city"
    )

    sh_districts = get_districts("中国", "上海市", "上海市", lang="cn")
    print(f"Found {len(sh_districts)} districts in 上海市.")
    assert len(sh_districts) > 10, (
        f"Expected >10 districts in SH, found {len(sh_districts)}"
    )
    assert any(d[1] == "浦东新区" for d in sh_districts), "浦东新区 not found"


def test_coordinate_lookup():
    print("\nTesting Coordinate Lookup...")

    # 1. Test Province Lookup
    coords = cmp.get_coordinates("广东省", "中国", parent="中国")
    print(f"广东省 coords: {coords}")
    assert coords is not None, "Could not find GD coords"

    # 2. Test City Lookup
    coords = cmp.get_coordinates("广州市", "中国", parent="广东省")
    print(f"广州市 coords: {coords}")
    assert coords is not None, "Could not find GZ coords"

    # 3. Test District Lookup
    coords = cmp.get_coordinates("天河区", "中国", parent="广州市")
    print(f"天河区 coords: {coords}")
    assert coords is not None, "Could not find Tianhe coords"

    # 4. Test Municipality District
    coords = cmp.get_coordinates("浦东新区", "中国", parent="上海市")
    print(f"浦东新区 coords: {coords}")
    assert coords is not None, "Could not find Pudong coords"


if __name__ == "__main__":
    try:
        test_china_hierarchy()
        test_coordinate_lookup()
        print("\n✅ All integration tests passed!")
    except Exception as e:
        print(f"\n❌ Tests failed: {e}")
        import traceback

        traceback.print_exc()
        sys.exit(1)