test_analytics.py 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. from datetime import timedelta
  2. import pytest
  3. from ariadne import gql
  4. from django.utils import timezone
  5. from ....threads.models import Attachment, AttachmentType
  6. from ....threads.test import post_thread
  7. from ....users.datadownloads import request_user_data_download
  8. from ....users.deletesrecord import record_user_deleted_by_self
  9. from ....users.test import create_test_user
  10. from ..analytics import cumulate_data
  11. test_query = gql(
  12. """
  13. query getAnalytics($span: Int!) {
  14. analytics(span: $span) {
  15. users {
  16. ...data
  17. }
  18. userDeletions {
  19. ...data
  20. }
  21. threads {
  22. ...data
  23. }
  24. posts {
  25. ...data
  26. }
  27. attachments {
  28. ...data
  29. }
  30. dataDownloads {
  31. ...data
  32. }
  33. }
  34. }
  35. fragment data on AnalyticsData {
  36. current
  37. currentCumulative
  38. previous
  39. previousCumulative
  40. }
  41. """
  42. )
  43. previous_datetime = timezone.now() - timedelta(days=30)
  44. excluded_datetime = timezone.now() - timedelta(days=60)
  45. def test_query_without_data_executes_without_errors(admin_graphql_client):
  46. result = admin_graphql_client.query(test_query, {"span": 30})
  47. assert result["analytics"]
  48. def test_all_analytics_are_limited_to_requested_span(admin_graphql_client):
  49. result = admin_graphql_client.query(test_query, {"span": 30})
  50. for model_analytics in result["analytics"].values():
  51. assert len(model_analytics["current"]) == 30
  52. assert len(model_analytics["currentCumulative"]) == 30
  53. assert len(model_analytics["previous"]) == 30
  54. assert len(model_analytics["previousCumulative"]) == 30
  55. def test_large_analytics_span_is_reduced_to_360(admin_graphql_client):
  56. result = admin_graphql_client.query(test_query, {"span": 3000})
  57. for model_analytics in result["analytics"].values():
  58. assert len(model_analytics["current"]) == 360
  59. assert len(model_analytics["currentCumulative"]) == 360
  60. assert len(model_analytics["previous"]) == 360
  61. assert len(model_analytics["previousCumulative"]) == 360
  62. def test_short_analytics_span_is_extended_to_30(admin_graphql_client):
  63. result = admin_graphql_client.query(test_query, {"span": 0})
  64. for model_analytics in result["analytics"].values():
  65. assert len(model_analytics["current"]) == 30
  66. assert len(model_analytics["currentCumulative"]) == 30
  67. assert len(model_analytics["previous"]) == 30
  68. assert len(model_analytics["previousCumulative"]) == 30
  69. def test_recent_user_registration_appears_in_current_analytics(admin_graphql_client):
  70. create_test_user("User", "user@example.com")
  71. result = admin_graphql_client.query(test_query, {"span": 30})
  72. analytics = result["analytics"]["users"]
  73. assert sum(analytics["current"]) == 2 # includes admin
  74. assert sum(analytics["previous"]) == 0
  75. def test_older_user_registration_appears_in_previous_analytics(admin_graphql_client):
  76. create_test_user("User", "user@example.com", joined_on=previous_datetime)
  77. result = admin_graphql_client.query(test_query, {"span": 30})
  78. analytics = result["analytics"]["users"]
  79. assert sum(analytics["current"]) == 1 # includes admin
  80. assert sum(analytics["previous"]) == 1
  81. def test_old_user_registration_is_excluded_from_analytics(admin_graphql_client):
  82. create_test_user("User", "user@example.com", joined_on=excluded_datetime)
  83. result = admin_graphql_client.query(test_query, {"span": 30})
  84. analytics = result["analytics"]["users"]
  85. assert sum(analytics["current"]) == 1 # includes admin
  86. assert sum(analytics["previous"]) == 0
  87. def test_recent_thread_appears_in_current_analytics(
  88. admin_graphql_client, default_category
  89. ):
  90. post_thread(default_category)
  91. result = admin_graphql_client.query(test_query, {"span": 30})
  92. analytics = result["analytics"]["threads"]
  93. assert sum(analytics["current"]) == 1
  94. assert sum(analytics["previous"]) == 0
  95. def test_older_thread_appears_in_previous_analytics(
  96. admin_graphql_client, default_category
  97. ):
  98. post_thread(default_category, started_on=previous_datetime)
  99. result = admin_graphql_client.query(test_query, {"span": 30})
  100. analytics = result["analytics"]["threads"]
  101. assert sum(analytics["current"]) == 0
  102. assert sum(analytics["previous"]) == 1
  103. def test_old_thread_is_excluded_from_analytics(admin_graphql_client, default_category):
  104. post_thread(default_category, started_on=excluded_datetime)
  105. result = admin_graphql_client.query(test_query, {"span": 30})
  106. analytics = result["analytics"]["threads"]
  107. assert sum(analytics["current"]) == 0
  108. assert sum(analytics["previous"]) == 0
  109. def test_recent_post_appears_in_current_analytics(
  110. admin_graphql_client, default_category
  111. ):
  112. post_thread(default_category)
  113. result = admin_graphql_client.query(test_query, {"span": 30})
  114. analytics = result["analytics"]["posts"]
  115. assert sum(analytics["current"]) == 1
  116. assert sum(analytics["previous"]) == 0
  117. def test_older_post_appears_in_previous_analytics(
  118. admin_graphql_client, default_category
  119. ):
  120. post_thread(default_category, started_on=previous_datetime)
  121. result = admin_graphql_client.query(test_query, {"span": 30})
  122. analytics = result["analytics"]["posts"]
  123. assert sum(analytics["current"]) == 0
  124. assert sum(analytics["previous"]) == 1
  125. def test_old_post_is_excluded_from_analytics(admin_graphql_client, default_category):
  126. post_thread(default_category, started_on=excluded_datetime)
  127. result = admin_graphql_client.query(test_query, {"span": 30})
  128. analytics = result["analytics"]["posts"]
  129. assert sum(analytics["current"]) == 0
  130. assert sum(analytics["previous"]) == 0
  131. @pytest.fixture
  132. def attachment_type(db):
  133. return AttachmentType.objects.create(name="test", extensions="test")
  134. def test_recent_attachment_appears_in_current_analytics(
  135. admin_graphql_client, attachment_type
  136. ):
  137. Attachment.objects.create(
  138. filetype=attachment_type,
  139. uploader_name="test",
  140. uploader_slug="test",
  141. filename="test",
  142. )
  143. result = admin_graphql_client.query(test_query, {"span": 30})
  144. analytics = result["analytics"]["attachments"]
  145. assert sum(analytics["current"]) == 1
  146. assert sum(analytics["previous"]) == 0
  147. def test_older_attachment_appears_in_previous_analytics(
  148. admin_graphql_client, attachment_type
  149. ):
  150. Attachment.objects.create(
  151. filetype=attachment_type,
  152. uploader_name="test",
  153. uploader_slug="test",
  154. filename="test",
  155. uploaded_on=previous_datetime,
  156. )
  157. result = admin_graphql_client.query(test_query, {"span": 30})
  158. analytics = result["analytics"]["attachments"]
  159. assert sum(analytics["current"]) == 0
  160. assert sum(analytics["previous"]) == 1
  161. def test_old_attachment_is_excluded_from_analytics(
  162. admin_graphql_client, attachment_type
  163. ):
  164. Attachment.objects.create(
  165. filetype=attachment_type,
  166. uploader_name="test",
  167. uploader_slug="test",
  168. filename="test",
  169. uploaded_on=excluded_datetime,
  170. )
  171. result = admin_graphql_client.query(test_query, {"span": 30})
  172. analytics = result["analytics"]["attachments"]
  173. assert sum(analytics["current"]) == 0
  174. assert sum(analytics["previous"]) == 0
  175. def test_recent_data_download_appears_in_current_analytics(
  176. admin_graphql_client, superuser
  177. ):
  178. request_user_data_download(superuser)
  179. result = admin_graphql_client.query(test_query, {"span": 30})
  180. analytics = result["analytics"]["dataDownloads"]
  181. assert sum(analytics["current"]) == 1
  182. assert sum(analytics["previous"]) == 0
  183. def test_older_data_download_appears_in_previous_analytics(
  184. admin_graphql_client, superuser
  185. ):
  186. download = request_user_data_download(superuser)
  187. download.requested_on = previous_datetime
  188. download.save()
  189. result = admin_graphql_client.query(test_query, {"span": 30})
  190. analytics = result["analytics"]["dataDownloads"]
  191. assert sum(analytics["current"]) == 0
  192. assert sum(analytics["previous"]) == 1
  193. def test_old_data_download_is_excluded_from_analytics(admin_graphql_client, superuser):
  194. download = request_user_data_download(superuser)
  195. download.requested_on = excluded_datetime
  196. download.save()
  197. result = admin_graphql_client.query(test_query, {"span": 30})
  198. analytics = result["analytics"]["dataDownloads"]
  199. assert sum(analytics["current"]) == 0
  200. assert sum(analytics["previous"]) == 0
  201. def test_recent_user_deletion_appears_in_current_analytics(admin_graphql_client):
  202. record_user_deleted_by_self()
  203. result = admin_graphql_client.query(test_query, {"span": 30})
  204. analytics = result["analytics"]["userDeletions"]
  205. assert sum(analytics["current"]) == 1
  206. assert sum(analytics["previous"]) == 0
  207. def test_older_user_deletion_appears_in_previous_analytics(admin_graphql_client):
  208. deletion = record_user_deleted_by_self()
  209. deletion.deleted_on = previous_datetime
  210. deletion.save()
  211. result = admin_graphql_client.query(test_query, {"span": 30})
  212. analytics = result["analytics"]["userDeletions"]
  213. assert sum(analytics["current"]) == 0
  214. assert sum(analytics["previous"]) == 1
  215. def test_old_user_deletion_is_excluded_from_analytics(admin_graphql_client):
  216. deletion = record_user_deleted_by_self()
  217. deletion.deleted_on = excluded_datetime
  218. deletion.save()
  219. result = admin_graphql_client.query(test_query, {"span": 30})
  220. analytics = result["analytics"]["userDeletions"]
  221. assert sum(analytics["current"]) == 0
  222. assert sum(analytics["previous"]) == 0
  223. def test_data_is_cumulated():
  224. assert cumulate_data([1, 2]) == [1, 3]