Coverage for src/tests/test_model_constraints.py: 100%
64 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-22 06:42 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-22 06:42 +0000
1import pytest
2from sqlalchemy.exc import IntegrityError
4from couchers.db import session_scope
5from couchers.models import Cluster, Node, Page, PageType, PageVersion, Thread
6from couchers.utils import create_polygon_lat_lng, to_multi
7from tests.test_communities import create_1d_polygon, create_community
8from tests.test_fixtures import db, generate_user, testconfig # noqa
11@pytest.fixture(autouse=True)
12def _(testconfig):
13 pass
16def test_node_constraints(db):
17 # check we can't have two official clusters for a given node
18 with pytest.raises(IntegrityError) as e:
19 with session_scope() as session:
20 node = Node(geom=to_multi(create_1d_polygon(0, 2)))
21 session.add(node)
22 cluster1 = Cluster(
23 name="Testing community, cluster 1",
24 description="Testing community description",
25 parent_node=node,
26 is_official_cluster=True,
27 )
28 session.add(cluster1)
29 cluster2 = Cluster(
30 name="Testing community, cluster 2",
31 description="Testing community description",
32 parent_node=node,
33 is_official_cluster=True,
34 )
35 session.add(cluster2)
36 assert "violates unique constraint" in str(e.value)
37 assert "ix_clusters_owner_parent_node_id_is_official_cluster" in str(e.value)
40def test_page_constraints(db):
41 user, token = generate_user()
43 with session_scope() as session:
44 c_id = create_community(session, 0, 2, "Root node", [user], [], None).id
46 # check we can't create a page without an owner
47 with pytest.raises(IntegrityError) as e:
48 with session_scope() as session:
49 page = Page(
50 parent_node_id=c_id,
51 # note no owner
52 creator_user_id=user.id,
53 type=PageType.guide,
54 thread=Thread(),
55 )
56 session.add(page)
57 session.add(
58 PageVersion(
59 page=page,
60 editor_user_id=user.id,
61 title="Title",
62 content="Content",
63 )
64 )
65 assert "violates check constraint" in str(e.value)
66 assert "one_owner" in str(e.value)
68 with session_scope() as session:
69 node = Node(geom=to_multi(create_polygon_lat_lng([[0, 0], [0, 2], [2, 2], [2, 0], [0, 0]])))
70 session.add(node)
71 cluster = Cluster(
72 name="Testing Community",
73 description="Description for testing community",
74 parent_node=node,
75 )
76 session.add(cluster)
77 session.flush()
78 cluster_parent_id = cluster.parent_node_id
79 cluster_id = cluster.id
81 # check we can't create a page with two owners
82 with pytest.raises(IntegrityError) as e:
83 with session_scope() as session:
84 page = Page(
85 parent_node_id=cluster_parent_id,
86 creator_user_id=user.id,
87 owner_cluster_id=cluster_id,
88 owner_user_id=user.id,
89 type=PageType.guide,
90 thread=Thread(),
91 )
92 session.add(page)
93 session.add(
94 PageVersion(
95 page=page,
96 editor_user_id=user.id,
97 title="Title",
98 content="Content",
99 )
100 )
101 assert "violates check constraint" in str(e.value)
102 assert "one_owner" in str(e.value)
104 # main page must be owned by the right cluster
105 with pytest.raises(IntegrityError) as e:
106 with session_scope() as session:
107 main_page = Page(
108 parent_node_id=cluster_parent_id,
109 # note owner is not cluster
110 creator_user_id=user.id,
111 owner_user_id=user.id,
112 type=PageType.main_page,
113 thread=Thread(),
114 )
115 session.add(main_page)
116 session.add(
117 PageVersion(
118 page=main_page,
119 editor_user_id=user.id,
120 title="Main page for the testing community",
121 content="Empty.",
122 )
123 )
124 assert "violates check constraint" in str(e.value)
125 assert "main_page_owned_by_cluster" in str(e.value)
127 # can only have one main page
128 with pytest.raises(IntegrityError) as e:
129 with session_scope() as session:
130 main_page1 = Page(
131 parent_node_id=cluster_parent_id,
132 creator_user_id=user.id,
133 owner_cluster_id=cluster_id,
134 type=PageType.main_page,
135 thread=Thread(),
136 )
137 session.add(main_page1)
138 session.add(
139 PageVersion(
140 page=main_page1,
141 editor_user_id=user.id,
142 title="Main page 1 for the testing community",
143 content="Empty.",
144 )
145 )
146 main_page2 = Page(
147 parent_node_id=cluster_parent_id,
148 creator_user_id=user.id,
149 owner_cluster_id=cluster_id,
150 type=PageType.main_page,
151 thread=Thread(),
152 )
153 session.add(main_page2)
154 session.add(
155 PageVersion(
156 page=main_page2,
157 editor_user_id=user.id,
158 title="Main page 2 for the testing community",
159 content="Empty.",
160 )
161 )
162 assert "violates unique constraint" in str(e.value)
163 assert "ix_pages_owner_cluster_id_type" in str(e.value)