test_alias.py 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. from flask import url_for
  2. from app.config import EMAIL_DOMAIN, MAX_NB_EMAIL_FREE_PLAN, PAGE_LIMIT
  3. from app.extensions import db
  4. from app.models import User, ApiKey, GenEmail
  5. from app.utils import random_word
  6. def test_error_without_pagination(flask_client):
  7. user = User.create(
  8. email="a@b.c", password="password", name="Test User", activated=True
  9. )
  10. db.session.commit()
  11. # create api_key
  12. api_key = ApiKey.create(user.id, "for test")
  13. db.session.commit()
  14. r = flask_client.get(
  15. url_for("api.get_aliases"), headers={"Authentication": api_key.code},
  16. )
  17. assert r.status_code == 400
  18. assert r.json["error"]
  19. def test_success_with_pagination(flask_client):
  20. user = User.create(
  21. email="a@b.c", password="password", name="Test User", activated=True
  22. )
  23. db.session.commit()
  24. # create api_key
  25. api_key = ApiKey.create(user.id, "for test")
  26. db.session.commit()
  27. # create more aliases than PAGE_LIMIT
  28. for _ in range(PAGE_LIMIT + 1):
  29. GenEmail.create_new_random(user.id)
  30. db.session.commit()
  31. # get aliases on the 1st page, should return PAGE_LIMIT aliases
  32. r = flask_client.get(
  33. url_for("api.get_aliases", page_id=0), headers={"Authentication": api_key.code},
  34. )
  35. assert r.status_code == 200
  36. assert len(r.json["aliases"]) == PAGE_LIMIT
  37. # get aliases on the 2nd page, should return 2 aliases
  38. # as the total number of aliases is PAGE_LIMIT +2
  39. # 1 alias is created when user is created
  40. r = flask_client.get(
  41. url_for("api.get_aliases", page_id=1), headers={"Authentication": api_key.code},
  42. )
  43. assert r.status_code == 200
  44. assert len(r.json["aliases"]) == 2
  45. def test_delete_alias(flask_client):
  46. user = User.create(
  47. email="a@b.c", password="password", name="Test User", activated=True
  48. )
  49. db.session.commit()
  50. # create api_key
  51. api_key = ApiKey.create(user.id, "for test")
  52. db.session.commit()
  53. gen_email = GenEmail.create_new_random(user.id)
  54. db.session.commit()
  55. r = flask_client.delete(
  56. url_for("api.delete_alias", alias_id=gen_email.id),
  57. headers={"Authentication": api_key.code},
  58. )
  59. assert r.status_code == 200
  60. assert r.json == {"deleted": True}